@charset "UTF-8";@import url(https://fonts.googleapis.com/css2?family=Archivo+Black&family=DM+Sans:wght@400;500;700&display=swap);:root{--primary:gold;--secondary:#fafafa;--accent:#fdb813;--text:#e5e7eb;--text-light:#9ca3af;--bg:#0d0d0d;--bg-card:#1a1a2e;--bg-card-hover:#252540;--bg-surface:#16162a;--border:#ffffff1a;--white:#fff;--success:#10b981;--error:#ef4444;--warning:#f59e0b}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0d0d0d;background:var(--bg);color:#e5e7eb;color:var(--text);font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.landing-page{background:var(--bg);color:var(--text);font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;overflow-x:hidden}.landing-page .container{margin:0 auto;max-width:1400px;padding:0 2rem;position:relative;z-index:1}.landing-nav{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#0d0d0df2;border-bottom:1px solid #ffffff0d;left:0;padding:1rem 0;position:fixed;right:0;top:0;z-index:1000}.landing-nav .nav-content{align-items:center;display:flex;gap:3rem}.landing-nav .nav-logo-btn{align-items:center;background:none;border:none;cursor:pointer;display:flex;padding:0}.landing-nav .nav-logo-img{height:40px;width:auto}.landing-nav .nav-links{display:flex;gap:2rem;margin-right:auto}.landing-nav .nav-link{background:none;border:none;color:#fffc;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;transition:color .3s ease}.landing-nav .nav-link:hover{color:var(--primary)}.landing-nav .nav-link:focus,.landing-nav .nav-link:hover{background:none!important;background-color:initial!important;border:none!important;box-shadow:none!important}.landing-nav .nav-link:focus{outline:none}.landing-nav .nav-auth{display:flex;gap:3rem}.landing-page .landing-nav .btn-login{background:#0000;border:none;color:#fffc;cursor:pointer;font-family:inherit;font-size:1.1rem;font-weight:500;padding:0;transition:color .3s ease}.landing-page .landing-nav .btn-login:focus,.landing-page .landing-nav .btn-login:hover{background:none!important;background-color:initial!important;border:none!important;box-shadow:none!important;color:var(--primary);outline:none}.landing-page .landing-nav .btn-signup{background:#0000;border:none;color:#fffc;cursor:pointer;font-family:inherit;font-size:1.1rem;font-weight:500;padding:0;transition:color .3s ease}.landing-page .landing-nav .btn-signup:focus,.landing-page .landing-nav .btn-signup:hover{background:none!important;background-color:initial!important;border:none!important;box-shadow:none!important;color:var(--primary);outline:none}.landing-nav .nav-hamburger{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:5px;height:32px;justify-content:center;padding:0;width:32px;z-index:1001}.landing-nav .nav-hamburger span{background:#fff;display:block;height:2px;transform-origin:center;transition:all .3s ease;width:24px}.landing-nav .nav-hamburger.open span:first-child{transform:translateY(7px) rotate(45deg)}.landing-nav .nav-hamburger.open span:nth-child(2){opacity:0}.landing-nav .nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.landing-nav .nav-auth-mobile{display:none}.landing-page .hero{align-items:center;background:#0d0d0d;display:flex;min-height:100vh;overflow:hidden;padding-top:80px;position:relative}.landing-page .hero:before{animation:pulse 8s ease-in-out infinite;background:radial-gradient(circle at 20% 50%,#ffd70026 0,#0000 50%),radial-gradient(circle at 80% 50%,#fdb8131a 0,#0000 50%);bottom:0;content:"";left:0;position:absolute;right:0;top:0}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.6}}.landing-page .hero-content{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr}.landing-page .hero-text h1{animation:slideInLeft .8s ease-out;color:#fff;font-family:Archivo Black,-apple-system,BlinkMacSystemFont,sans-serif;font-size:clamp(3rem,6vw,5rem);letter-spacing:-.03em;line-height:1.1;margin-bottom:1.5rem}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:1;transform:translateX(0)}}.landing-page .hero-text h1 .highlight{color:var(--primary)}.landing-page .hero-logo{animation:slideInLeft .8s ease-out;height:auto;margin-bottom:1.5rem;max-width:500px;width:100%}.landing-page .hero-text p{animation:slideInLeft .8s ease-out .2s backwards;color:#fffc;font-size:1.35rem;margin-bottom:2.5rem;max-width:550px}.landing-page .cta-group{animation:slideInLeft .8s ease-out .4s backwards;display:flex;flex-wrap:wrap;gap:1.5rem}.landing-page .btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-family:inherit;font-size:1.125rem;font-weight:700;padding:1.25rem 2.5rem;text-decoration:none;transition:all .3s ease}.landing-page .btn-primary{background:var(--primary);color:#0d0d0d}.landing-page .btn-primary:hover{transform:translateY(-2px)}.landing-page .btn-secondary{background:#1a1a2e;border:none;color:#fff}.landing-page .btn-secondary:hover{background:#12121f;color:var(--primary)}.landing-page .btn-white{background:#fff;color:#0d0d0d;font-size:1.25rem;padding:1.5rem 4rem}.landing-page .btn-white:hover{box-shadow:0 20px 60px #0003;transform:translateY(-5px)}.landing-page .hero-visual{animation:slideInRight .8s ease-out .3s backwards;position:relative}@keyframes slideInRight{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.landing-page .hero-screenshot-container{position:relative;transform:perspective(1000px) rotateY(-5deg);transition:transform .5s ease}.landing-page .hero-screenshot-container:hover{transform:perspective(1000px) rotateY(0deg)}.landing-page .hero-screenshot{height:auto;max-width:700px;width:100%}.landing-page .hero-carousel,.landing-page .hero-screenshot{border-radius:16px;box-shadow:0 30px 80px #00000080,0 0 0 1px #ffffff1a}.landing-page .hero-carousel{overflow:hidden;position:relative;transform:perspective(1000px) rotateY(-5deg);transition:transform .5s ease}.landing-page .hero-carousel:hover{transform:perspective(1000px) rotateY(0deg)}.landing-page .hero-carousel-track{display:flex;transition:transform .5s ease-in-out}.landing-page .hero-carousel-slide{flex-shrink:0;min-width:100%}.landing-page .hero-carousel-slide img{display:block;height:auto;width:100%}.landing-page .hero-carousel-dots{bottom:1rem;display:flex;gap:.5rem;left:50%;position:absolute;transform:translateX(-50%);z-index:10}.landing-page .hero-carousel-dot{background:#fff6;border:none;border-radius:50%;cursor:pointer;height:10px;padding:0;transition:all .3s ease;width:10px}.landing-page .hero-carousel-dot:hover{background:#ffffffb3}.landing-page .hero-carousel-dot.active{background:var(--primary);transform:scale(1.2)}.landing-page .hero-carousel-label{background:#0d0d0dcc;border-radius:20px;bottom:2.5rem;color:var(--primary);font-size:.875rem;font-weight:600;left:50%;padding:.5rem 1rem;position:absolute;transform:translateX(-50%);z-index:10}.landing-page .benefits-strip{background:var(--secondary);border-bottom:1px solid #ffffff1a;border-top:1px solid #ffffff1a;padding:2rem 0}.landing-page .benefits-grid{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}.landing-page .benefit-item{align-items:center;display:flex;gap:.75rem}.landing-page .benefit-icon{color:var(--primary);height:32px;width:32px}.landing-page .benefit-icon svg{height:100%;width:100%}.landing-page .benefit-text{color:#ffffffe6;font-size:1rem;font-weight:600}.landing-page .section-header{margin-bottom:4rem;text-align:center}.landing-page .section-label{color:var(--primary);font-size:.875rem;font-weight:700;letter-spacing:.15em;margin-bottom:1rem;text-transform:uppercase}.landing-page .section-label.light{color:var(--primary)}.landing-page .section-title{color:#0d0d0d;font-family:Archivo Black,sans-serif;font-size:clamp(2.5rem,5vw,4rem);letter-spacing:-.02em;line-height:1.1}.landing-page .section-title.light{color:#fff}.landing-page .app-preview{align-items:center;background:var(--primary);display:flex;min-height:100vh;padding:6rem 0}.landing-page .app-preview .section-label,.landing-page .app-preview .section-title{color:#0d0d0d}.landing-page .preview-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:3rem}.landing-page .preview-tab{background:#0d0d0d1a;border:2px solid #0000;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .3s ease}.landing-page .preview-tab:hover{background:#0d0d0d26}.landing-page .preview-tab.active{background:#0d0d0d;border-color:#0d0d0d;color:var(--primary)}.landing-page .preview-content{position:relative}.landing-page .preview-panel{animation:fadeIn .5s ease;display:none}.landing-page .preview-panel.active{display:block}.landing-page .preview-layout{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1.2fr 1fr}.landing-page .preview-screenshot-container{border-radius:16px;box-shadow:0 30px 80px #00000040;overflow:hidden;transition:transform .4s ease,box-shadow .4s ease}.landing-page .preview-screenshot-container:hover{box-shadow:0 40px 100px #0000004d;transform:translateY(-5px)}.landing-page .preview-screenshot{display:block;height:auto;width:100%}.landing-page .preview-info{text-align:left}.landing-page .preview-info h3{color:#0d0d0d;font-family:Archivo Black,sans-serif;font-size:2rem;margin-bottom:1.5rem}.landing-page .preview-info p{color:#0d0d0d;font-size:1.125rem;line-height:1.7;margin-bottom:2rem}.landing-page .preview-features{display:flex;flex-direction:column;gap:.75rem;list-style:none;margin:0;padding:0}.landing-page .preview-features li{align-items:center;color:#0d0d0d;display:flex;font-size:1.1rem;gap:.75rem}.landing-page .preview-features li:before{align-items:center;background:#0d0d0d;border-radius:50%;color:var(--primary);content:"\2713";display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;justify-content:center;width:24px}.landing-page .features-detailed{background:var(--bg);padding:6rem 0}.landing-page .feature-row{grid-gap:4rem;align-items:center;display:grid;gap:4rem;grid-template-columns:1fr 1fr;margin-bottom:6rem}.landing-page .feature-row:last-child{margin-bottom:0}.landing-page .feature-row.reverse .feature-image{order:2}.landing-page .feature-row.reverse .feature-content{order:1}.landing-page .feature-image{border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.landing-page .feature-image img{display:block;height:auto;width:100%}.landing-page .feature-content h3{color:#fff;font-family:Archivo Black,sans-serif;font-size:2rem;margin-bottom:1rem}.landing-page .feature-content p{color:#fffc;font-size:1.125rem;line-height:1.7;margin-bottom:1.5rem}.landing-page .feature-list{list-style:none;margin:0;padding:0}.landing-page .feature-list li{align-items:flex-start;color:#fffc;display:flex;font-size:1rem;gap:.75rem;margin-bottom:1rem}.landing-page .feature-list li:before{align-items:center;background:var(--primary);border-radius:50%;color:var(--secondary);content:"\2713";display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:24px;justify-content:center;width:24px}.landing-page .integration{align-items:center;background:#0d0d0d;display:flex;min-height:100vh;padding:6rem 0}.landing-page .integration .section-label,.landing-page .integration .section-title{color:var(--primary)}.landing-page .integration-content{grid-gap:5rem;align-items:center;display:grid;gap:5rem;grid-template-columns:1fr 1fr}.landing-page .integration-description{color:#fffc;font-size:1.25rem;margin:2rem 0}.landing-page .benefits-list{list-style:none;margin:2rem 0;padding:0}.landing-page .benefits-list li{align-items:flex-start;color:#ffffffe6;display:flex;font-size:1.125rem;gap:1rem;margin-bottom:1.25rem}.landing-page .benefits-list li:before{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;content:"\2713";display:flex;flex-shrink:0;font-size:.875rem;font-weight:700;height:28px;justify-content:center;width:28px}.landing-page .integration-visual{position:relative}.landing-page .device-badge{align-items:center;background:#ffffff1a;border-radius:12px;display:flex;gap:.75rem;margin-bottom:2rem;padding:1rem 1.5rem;width:-webkit-fit-content;width:fit-content}.landing-page .device-icon{font-size:1.5rem}.landing-page .device-badge span{color:#ffffffe6;font-weight:600}.landing-page .watch-mockup{background:linear-gradient(145deg,#1a1a1a,#2a2a2a);border-radius:24px;box-shadow:0 30px 60px #0006;max-width:400px;padding:2rem;transition:transform .4s ease,box-shadow .4s ease}.landing-page .watch-mockup:hover{box-shadow:0 40px 80px #00000080;transform:translateY(-8px)}.landing-page .watch-content{background:#0d0d0d;border-radius:16px;padding:2rem}.landing-page .watch-header{color:var(--primary);font-size:.875rem;font-weight:600;letter-spacing:.1em;margin-bottom:.75rem;text-transform:uppercase}.landing-page .watch-workout-name{color:#fff;font-family:Archivo Black,sans-serif;font-size:1.75rem;margin-bottom:1.5rem}.landing-page .watch-steps{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.landing-page .watch-step{background:#ffffff0d;border-radius:8px;display:flex;justify-content:space-between;padding:.75rem 1rem}.landing-page .step-label{color:#ffffffb3;font-weight:500}.landing-page .step-value{color:var(--primary);font-weight:600}.landing-page .watch-sync-status{align-items:center;color:#10b981;display:flex;font-size:.875rem;font-weight:600;gap:.5rem;justify-content:center}.landing-page .watch-sync-status:before{background:#10b981;border-radius:50%;content:"";height:8px;width:8px}.landing-page .community-section{background:#fff;padding:6rem 0}.landing-page .community-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,1fr)}.landing-page .community-card{background:var(--bg);border-radius:20px;padding:2.5rem;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.landing-page .community-card:hover{box-shadow:0 20px 60px #00000026;transform:translateY(-10px)}.landing-page .community-icon{background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:16px;color:var(--secondary);height:64px;margin:0 auto 1.5rem;padding:1rem;width:64px}.landing-page .community-icon svg{height:100%;width:100%}.landing-page .community-card h3{color:#fff;font-family:Archivo Black,sans-serif;font-size:1.5rem;margin-bottom:1rem}.landing-page .community-card p{color:#ffffffb3;font-size:1rem;line-height:1.6}.landing-page .how-it-works{align-items:center;background:var(--primary);display:flex;min-height:100vh;overflow:hidden;padding:6rem 0;position:relative}.landing-page .how-it-works .section-title{color:#0d0d0d}.landing-page .steps-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(4,1fr);margin-top:4rem}.landing-page .step{background:#0d0d0d0d;border:1px solid #0d0d0d1a;border-radius:20px;padding:2.5rem 2rem;position:relative;transition:all .3s ease}.landing-page .step:hover{background:#0d0d0d1a;border-color:#0d0d0d;transform:translateY(-5px)}.landing-page .step-number{align-items:center;background:#0d0d0d;border-radius:50%;box-shadow:0 10px 30px #0003;color:var(--primary);display:flex;font-family:Archivo Black,sans-serif;font-size:1.5rem;height:50px;justify-content:center;left:2rem;position:absolute;top:-20px;width:50px}.landing-page .step h3{color:#0d0d0d;font-family:Archivo Black,sans-serif;font-size:1.25rem;margin-bottom:1rem;margin-top:1rem}.landing-page .step p{color:#0d0d0dcc;font-size:.95rem;line-height:1.6}.landing-page .cta-section{background:linear-gradient(135deg,var(--primary) 0,var(--accent) 100%);overflow:hidden;padding:8rem 0;position:relative;text-align:center}.landing-page .cta-section:before{animation:rotate 20s linear infinite;background:radial-gradient(circle,#ffffff1a 0,#0000 70%);content:"";height:150%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:150%}@keyframes rotate{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.landing-page .cta-content{position:relative;z-index:1}.landing-page .cta-content h2{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:clamp(2.5rem,5vw,4.5rem);line-height:1.1;margin-bottom:1.5rem}.landing-page .cta-content p{color:#000000b3;font-size:1.5rem;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:700px}.landing-page .landing-footer{background:#0d0d0d;color:#fff9;padding:4rem 0 2rem}.landing-page .footer-content{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:2fr 1fr 1fr;margin-bottom:3rem}.landing-page .footer-section h4{color:#fff;font-family:Archivo Black,sans-serif;font-size:1.25rem;margin-bottom:1.5rem}.landing-page .footer-brand .footer-logo{height:50px;margin-bottom:1rem;width:auto}.landing-page .footer-section a,.landing-page .footer-section button,.landing-page .footer-section p{background:none;border:none;color:#fff9;cursor:pointer;display:block;font-family:inherit;font-size:1rem;margin-bottom:.75rem;padding:0;text-align:left;text-decoration:none;transition:color .3s ease}.landing-page .footer-section a:hover,.landing-page .footer-section button:hover{color:var(--primary)}.landing-page .copyright{border-top:1px solid #ffffff1a;font-size:.875rem;padding-top:2rem;text-align:center}@media (max-width:1024px){.landing-page .container{padding:0 1.5rem}.landing-page .hero-content{gap:3rem;grid-template-columns:1fr;text-align:center}.landing-page .hero-text h1{font-size:3rem}.landing-page .hero-logo,.landing-page .hero-text p{margin-left:auto;margin-right:auto}.landing-page .hero-logo{max-width:400px}.landing-page .cta-group{justify-content:center}.landing-page .hero-visual{margin:0 auto;max-width:600px;order:2}.landing-page .hero-carousel,.landing-page .hero-carousel:hover,.landing-page .hero-screenshot-container{transform:none}.landing-page .feature-row,.landing-page .integration-content,.landing-page .preview-layout{gap:3rem;grid-template-columns:1fr}.landing-page .preview-info{order:2;text-align:center}.landing-page .preview-screenshot-container{margin:0 auto;max-width:600px}.landing-page .preview-features{align-items:center}.landing-page .feature-row.reverse .feature-content,.landing-page .feature-row.reverse .feature-image{order:0}.landing-page .integration-text,.landing-page .integration-text .section-label,.landing-page .integration-text .section-title{text-align:center}.landing-page .integration-text .btn{display:inline-block}.landing-page .benefits-list{margin-left:auto;margin-right:auto;max-width:400px}.landing-page .integration-visual{display:flex;justify-content:center;order:-1}.landing-page .steps-container{gap:2.5rem 2rem;grid-template-columns:repeat(2,1fr)}.landing-page .community-grid{grid-template-columns:1fr;margin:0 auto;max-width:500px}.landing-page .footer-content{gap:2rem;grid-template-columns:1fr;text-align:center}.landing-page .footer-section a,.landing-page .footer-section button{text-align:center}.landing-page .footer-brand .footer-logo{margin-left:auto;margin-right:auto}}@media (max-width:768px){.landing-nav .nav-hamburger{display:flex}.landing-nav .nav-links{align-items:center;background:#0d0d0d;bottom:0;flex-direction:column;gap:2rem;justify-content:center;left:0;opacity:0;position:fixed;right:0;top:0;transition:all .3s ease;visibility:hidden;z-index:999}.landing-nav .nav-links.open{opacity:1;visibility:visible}.landing-nav .nav-link{font-size:1.5rem;font-weight:600}.landing-nav .nav-auth{display:none}.landing-nav .nav-auth-mobile{align-items:center;display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.landing-nav .nav-auth-mobile .btn-login,.landing-nav .nav-auth-mobile .btn-signup{background:none;border:none;color:#fffc;cursor:pointer;font-size:1.25rem;padding:.5rem 1rem;transition:color .3s ease}.landing-nav .nav-auth-mobile .btn-login:hover,.landing-nav .nav-auth-mobile .btn-signup:hover{color:var(--primary)}.landing-page .app-preview,.landing-page .hero,.landing-page .how-it-works,.landing-page .integration{min-height:auto;padding:5rem 0}.landing-page .hero{padding-top:6rem}.landing-page .hero-text h1{font-size:2.25rem}.landing-page .hero-text p{font-size:1.125rem;margin-bottom:2rem}.landing-page .hero-logo{max-width:300px}.landing-page .hero-carousel-label{bottom:2rem;font-size:.75rem;padding:.4rem .8rem}.landing-page .hero-carousel-dots{bottom:.75rem}.landing-page .hero-carousel-dot{height:8px;width:8px}.landing-page .cta-group{flex-direction:column;gap:1rem}.landing-page .btn{padding:1rem 2rem;text-align:center;width:100%}.landing-page .benefits-grid{flex-direction:column;gap:1rem}.landing-page .preview-tabs{flex-wrap:wrap;gap:.25rem;justify-content:center}.landing-page .preview-tab{flex:0 1 auto;font-size:.8rem;padding:.6rem .9rem}.landing-page .preview-info h3{font-size:1.5rem}.landing-page .preview-info p{font-size:1rem}.landing-page .preview-features li{font-size:.95rem}.landing-page .section-header{margin-bottom:2.5rem}.landing-page .section-title{font-size:clamp(2rem,8vw,2.5rem)}.landing-page .integration-description{font-size:1.1rem}.landing-page .benefits-list li{font-size:1rem}.landing-page .watch-mockup{max-width:320px;padding:1.5rem}.landing-page .watch-content{padding:1.5rem}.landing-page .watch-workout-name{font-size:1.5rem}.landing-page .steps-container{gap:3rem;grid-template-columns:1fr;margin-top:3rem}.landing-page .step{padding:2rem 1.5rem}.landing-page .step h3{font-size:1.15rem}.landing-page .feature-row{margin-bottom:3rem}.landing-page .feature-content h3{font-size:1.5rem}.landing-page .landing-footer{padding:3rem 0 1.5rem}.landing-page .footer-content{gap:1.5rem;margin-bottom:2rem}}@media (max-width:480px){.landing-page .container{padding:0 1rem}.landing-nav .nav-logo-img{height:32px}.landing-page .hero-text h1{font-size:2rem}.landing-page .hero-text p{font-size:1rem}.landing-page .hero-logo{max-width:250px}.landing-page .app-preview,.landing-page .hero,.landing-page .how-it-works,.landing-page .integration{padding:4rem 0}.landing-page .hero{padding-top:5rem}.landing-page .preview-tabs{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr);width:100%}.landing-page .preview-tab{font-size:.75rem;padding:.75rem .5rem;width:100%}.landing-page .preview-info h3{font-size:1.35rem}.landing-page .section-title{font-size:1.75rem}.landing-page .watch-mockup{max-width:280px;padding:1rem}.landing-page .watch-content{padding:1.25rem}.landing-page .watch-header{font-size:.75rem}.landing-page .watch-workout-name{font-size:1.25rem;margin-bottom:1rem}.landing-page .watch-step{font-size:.875rem;padding:.5rem .75rem}.landing-page .step{padding:1.75rem 1.25rem}.landing-page .step-number{font-size:1.25rem;height:40px;left:1.25rem;top:-16px;width:40px}.landing-page .step h3{font-size:1.1rem;margin-top:.75rem}.landing-page .step p{font-size:.9rem}.landing-page .btn{font-size:1rem;padding:.875rem 1.5rem}.landing-page .benefits-list li{font-size:.95rem}.landing-page .benefits-list li:before{font-size:.75rem;height:24px;width:24px}.landing-page .preview-features li:before{font-size:.65rem;height:20px;width:20px}.landing-page .preview-features li{font-size:.9rem;gap:.5rem}.landing-page .footer-section h4{font-size:1.1rem}.landing-page .copyright{font-size:.8rem}}.auth-page{align-items:center;background:linear-gradient(135deg,#0d0d0d,#1a1a1a 50%,#0d0d0d);display:flex;justify-content:center;min-height:100vh;padding:20px;position:relative}.auth-page:before{background:radial-gradient(circle at 20% 50%,#ffd7001a 0,#0000 50%),radial-gradient(circle at 80% 50%,#fdb81314 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.auth-container{max-width:420px;position:relative;width:100%;z-index:1}.auth-close-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-family:inherit;font-size:1.75rem;line-height:1;padding:0;position:absolute;right:16px;top:16px;transition:opacity .2s}.auth-close-btn:hover:not(:disabled){opacity:.7}.auth-close-btn:disabled{cursor:not-allowed;opacity:.5}.auth-header{margin-bottom:30px;text-align:center}.auth-logo{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:3rem;font-weight:700;letter-spacing:-1px;margin:0}.auth-tagline{color:var(--text-light);font-size:1rem;margin:8px 0 0}.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 60px #00000080;padding:40px}.auth-title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;font-weight:600;margin:0 0 10px;text-align:center}.auth-subtitle{color:var(--text-light);font-size:.9rem;line-height:1.5;margin:0 0 24px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.form-group input{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:1rem;padding:14px 16px;transition:all .2s}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.form-group input:disabled{cursor:not-allowed;opacity:.6}.auth-error{background:#ef44441a;border-left:4px solid #ef4444;color:#f87171}.auth-error,.auth-success{border-radius:8px;font-size:.875rem;padding:12px 16px;text-align:center}.auth-success{background:#48bb781a;border-left:4px solid #48bb78;color:#68d391}.forgot-password-btn{background:none;border:none;color:var(--text-light);cursor:pointer;display:block;font-family:inherit;font-size:.875rem;margin-top:-12px;padding:0;text-align:left;transition:color .2s;width:-webkit-fit-content;width:fit-content}.forgot-password-btn:hover:not(:disabled){color:var(--primary)}.forgot-password-btn:disabled{cursor:not-allowed;opacity:.6}.auth-submit{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;margin-top:10px;padding:16px;transition:transform .2s,box-shadow .2s}.auth-submit:hover:not(:disabled){box-shadow:0 6px 20px #ffd70066;transform:translateY(-2px)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{cursor:not-allowed;opacity:.6}.auth-switch{border-top:2px solid var(--border);margin-top:24px;padding-top:24px;text-align:center}.auth-switch p{color:var(--text-light);font-size:.875rem;margin:0}.auth-switch-btn{background:none;border:none;color:var(--primary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-left:6px;padding:0}.auth-switch-btn:hover{opacity:.7}.auth-switch-btn:disabled{cursor:not-allowed;opacity:.6}.auth-age-disclaimer{color:var(--text-light);font-size:.75rem;margin:16px 0 0;padding:0;text-align:center}@media (max-width:480px){.auth-card{padding:30px 24px}.auth-logo{font-size:2.5rem}}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__navigation-icon:before,.react-datepicker__year-read-view--down-arrow{border-color:#ccc;border-style:solid;border-width:3px 3px 0 0;content:"";display:block;height:9px;position:absolute;top:6px;width:9px}.react-datepicker__sr-only{border:0;-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker-wrapper{border:0;display:inline-block;padding:0}.react-datepicker{background-color:#fff;border:1px solid #aeaeae;border-radius:.3rem;color:#000;display:inline-block;font-family:Helvetica Neue,helvetica,arial,sans-serif;font-size:.8rem;line-height:normal;position:relative}.react-datepicker--time-only .react-datepicker__time-container{border-left:0}.react-datepicker--time-only .react-datepicker__time,.react-datepicker--time-only .react-datepicker__time-box{border-bottom-left-radius:.375em;border-bottom-right-radius:.375em}.react-datepicker-popper{line-height:0;z-index:1}.react-datepicker-popper .react-datepicker__triangle{stroke:#aeaeae}.react-datepicker-popper[data-placement^=bottom] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker-popper--header-bottom[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper--header-middle[data-placement^=bottom] .react-datepicker__triangle,.react-datepicker-popper[data-placement^=top] .react-datepicker__triangle{fill:#fff;color:#fff}.react-datepicker-popper--header-bottom[data-placement^=top] .react-datepicker__triangle{fill:#f0f0f0;color:#f0f0f0}.react-datepicker__header{background-color:#f0f0f0;border-bottom:1px solid #aeaeae;border-top-left-radius:.3rem;padding:8px 0;position:relative;text-align:center}.react-datepicker__header--time{padding-bottom:8px;padding-left:5px;padding-right:5px}.react-datepicker__header--time:not(.react-datepicker__header--time--only){border-top-left-radius:0}.react-datepicker__header:not(.react-datepicker__header--has-time-select,.react-datepicker__header--middle,.react-datepicker__header--bottom){border-top-right-radius:.3rem}.react-datepicker__header--middle{border-radius:0;border-top:1px solid #aeaeae;margin-top:4px}.react-datepicker__header--bottom{border-bottom:none;border-radius:0 0 .3rem .3rem;border-top:1px solid #aeaeae}.react-datepicker__header-wrapper{position:relative}.react-datepicker__header-wrapper .react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:2px}.react-datepicker__month-dropdown-container--scroll,.react-datepicker__month-dropdown-container--select,.react-datepicker__month-year-dropdown-container--scroll,.react-datepicker__month-year-dropdown-container--select,.react-datepicker__year-dropdown-container--scroll,.react-datepicker__year-dropdown-container--select{display:inline-block;margin:0 15px}.react-datepicker__month-select,.react-datepicker__month-year-select,.react-datepicker__year-select{background-color:initial;border:1px solid #aeaeae;border-radius:.3rem;color:inherit;cursor:pointer;font-family:inherit;font-size:inherit;margin-top:5px;padding:2px 5px}.react-datepicker__month-select:focus-visible,.react-datepicker__month-year-select:focus-visible,.react-datepicker__year-select:focus-visible{outline:1px auto}.react-datepicker-time__header,.react-datepicker-year-header,.react-datepicker__current-month{color:#000;font-size:.944rem;font-weight:700;margin-top:0}h2.react-datepicker__current-month{margin:0;padding:0}.react-datepicker-time__header{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.react-datepicker__navigation{align-items:center;background:none;border:none;cursor:pointer;display:flex;height:32px;justify-content:center;overflow:hidden;padding:0;position:absolute;text-align:center;text-indent:-999em;top:2px;width:32px;z-index:1}.react-datepicker__navigation--previous{left:2px}.react-datepicker__navigation--next{right:2px}.react-datepicker__navigation--next--with-time:not(.react-datepicker__navigation--next--with-today-button){right:85px}.react-datepicker__navigation--years{display:block;margin-left:auto;margin-right:auto;position:relative;top:0}.react-datepicker__navigation--years-previous{top:4px}.react-datepicker__navigation--years-upcoming{top:-4px}.react-datepicker__navigation:hover :before{border-color:#a6a6a6}.react-datepicker__navigation-icon{font-size:20px;position:relative;top:-1px;width:0}.react-datepicker__navigation-icon--next{left:-2px}.react-datepicker__navigation-icon--next:before{left:-7px;transform:rotate(45deg)}.react-datepicker__navigation-icon--previous{right:-2px}.react-datepicker__navigation-icon--previous:before{right:-7px;transform:rotate(225deg)}.react-datepicker__month-container{float:left}.react-datepicker__year{margin:.5em;text-align:center}.react-datepicker__year-wrapper{display:flex;flex-wrap:wrap;max-width:180px}.react-datepicker__year .react-datepicker__year-text{display:inline-block;margin:2px;width:5em}.react-datepicker__month{margin:.5em;text-align:center}.react-datepicker__month .react-datepicker__month-text,.react-datepicker__month .react-datepicker__quarter-text{display:inline-block;margin:2px;width:5em}.react-datepicker__input-time-container{clear:both;float:left;margin:5px 0 10px 15px;text-align:left;width:100%}.react-datepicker__input-time-container .react-datepicker-time__caption,.react-datepicker__input-time-container .react-datepicker-time__input-container{display:inline-block}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input{display:inline-block;margin-left:10px}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input{width:auto}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-inner-spin-button,.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__input input[type=time]{-moz-appearance:textfield}.react-datepicker__input-time-container .react-datepicker-time__input-container .react-datepicker-time__delimiter{display:inline-block;margin-left:5px}.react-datepicker__time-container{border-left:1px solid #aeaeae;float:right;width:85px}.react-datepicker__time-container--with-today-button{border:1px solid #aeaeae;border-radius:.375em;display:inline;position:absolute;right:-87px;top:0}.react-datepicker__time-container .react-datepicker__time{background:#fff;border-bottom-right-radius:.375em;position:relative}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{border-bottom-right-radius:.375em;margin:0 auto;overflow-x:hidden;text-align:center;width:85px}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{box-sizing:initial;height:calc(195px + 1.0625em);list-style:none;margin:0;overflow-y:scroll;padding-left:0;padding-right:0;width:100%}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:30px;padding:5px 10px;white-space:nowrap}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{background-color:#f0f0f0;cursor:pointer}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background-color:#216ba5;color:#fff;font-weight:700}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background-color:#216ba5}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled{color:#ccc}.react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--disabled:hover{background-color:initial;cursor:default}.react-datepicker__week-number{color:#ccc;display:inline-block;line-height:2.125em;margin:.208em;text-align:center;width:2.125em}.react-datepicker__week-number.react-datepicker__week-number--clickable{cursor:pointer}.react-datepicker__week-number.react-datepicker__week-number--clickable:not(.react-datepicker__week-number--selected):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__week-number--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__week-number--selected:hover{background-color:#1d5d90}.react-datepicker__day-names{margin-bottom:-8px;text-align:center;white-space:nowrap}.react-datepicker__week{white-space:nowrap}.react-datepicker__day,.react-datepicker__day-name,.react-datepicker__time-name{color:#000;display:inline-block;line-height:2.125em;margin:.208em;text-align:center;width:2.125em}.react-datepicker__day--disabled,.react-datepicker__day-name--disabled,.react-datepicker__time-name--disabled{color:#ccc;cursor:default}.react-datepicker__day,.react-datepicker__month-text,.react-datepicker__quarter-text,.react-datepicker__year-text{cursor:pointer}.react-datepicker__day:not([aria-disabled=true]):hover,.react-datepicker__month-text:not([aria-disabled=true]):hover,.react-datepicker__quarter-text:not([aria-disabled=true]):hover,.react-datepicker__year-text:not([aria-disabled=true]):hover{background-color:#f0f0f0;border-radius:.3rem}.react-datepicker__day--today,.react-datepicker__month-text--today,.react-datepicker__quarter-text--today,.react-datepicker__year-text--today{font-weight:700}.react-datepicker__day--highlighted,.react-datepicker__month-text--highlighted,.react-datepicker__quarter-text--highlighted,.react-datepicker__year-text--highlighted{background-color:#3dcc4a;border-radius:.3rem;color:#fff}.react-datepicker__day--highlighted:not([aria-disabled=true]):hover,.react-datepicker__month-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--highlighted:not([aria-disabled=true]):hover,.react-datepicker__year-text--highlighted:not([aria-disabled=true]):hover{background-color:#32be3f}.react-datepicker__day--highlighted-custom-1,.react-datepicker__month-text--highlighted-custom-1,.react-datepicker__quarter-text--highlighted-custom-1,.react-datepicker__year-text--highlighted-custom-1{color:#f0f}.react-datepicker__day--highlighted-custom-2,.react-datepicker__month-text--highlighted-custom-2,.react-datepicker__quarter-text--highlighted-custom-2,.react-datepicker__year-text--highlighted-custom-2{color:green}.react-datepicker__day--holidays,.react-datepicker__month-text--holidays,.react-datepicker__quarter-text--holidays,.react-datepicker__year-text--holidays{background-color:#ff6803;border-radius:.3rem;color:#fff;position:relative}.react-datepicker__day--holidays .overlay,.react-datepicker__month-text--holidays .overlay,.react-datepicker__quarter-text--holidays .overlay,.react-datepicker__year-text--holidays .overlay{background-color:#333;border-radius:4px;bottom:100%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__day--holidays:not([aria-disabled=true]):hover,.react-datepicker__month-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--holidays:not([aria-disabled=true]):hover,.react-datepicker__year-text--holidays:not([aria-disabled=true]):hover{background-color:#cf5300}.react-datepicker__day--holidays:hover .overlay,.react-datepicker__month-text--holidays:hover .overlay,.react-datepicker__quarter-text--holidays:hover .overlay,.react-datepicker__year-text--holidays:hover .overlay{opacity:1;visibility:visible}.react-datepicker__day--in-range,.react-datepicker__day--in-selecting-range,.react-datepicker__day--selected,.react-datepicker__month-text--in-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__month-text--selected,.react-datepicker__quarter-text--in-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__quarter-text--selected,.react-datepicker__year-text--in-range,.react-datepicker__year-text--in-selecting-range,.react-datepicker__year-text--selected{background-color:#216ba5;border-radius:.3rem;color:#fff}.react-datepicker__day--in-range:not([aria-disabled=true]):hover,.react-datepicker__day--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__day--selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__month-text--selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--in-selecting-range:not([aria-disabled=true]):hover,.react-datepicker__year-text--selected:not([aria-disabled=true]):hover{background-color:#1d5d90}.react-datepicker__day--keyboard-selected,.react-datepicker__month-text--keyboard-selected,.react-datepicker__quarter-text--keyboard-selected,.react-datepicker__year-text--keyboard-selected{background-color:#bad9f1;border-radius:.3rem;color:#000}.react-datepicker__day--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__month-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__quarter-text--keyboard-selected:not([aria-disabled=true]):hover,.react-datepicker__year-text--keyboard-selected:not([aria-disabled=true]):hover{background-color:#1d5d90;color:#fff}.react-datepicker__day--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__month-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__quarter-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range),.react-datepicker__year-text--in-selecting-range:not(.react-datepicker__day--in-range,.react-datepicker__month-text--in-range,.react-datepicker__quarter-text--in-range,.react-datepicker__year-text--in-range){background-color:#216ba580}.react-datepicker__month--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__month--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__day--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__month-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__quarter-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range),.react-datepicker__year--selecting-range .react-datepicker__year-text--in-range:not(.react-datepicker__day--in-selecting-range,.react-datepicker__month-text--in-selecting-range,.react-datepicker__quarter-text--in-selecting-range,.react-datepicker__year-text--in-selecting-range){background-color:#f0f0f0;color:#000}.react-datepicker__day--disabled,.react-datepicker__month-text--disabled,.react-datepicker__quarter-text--disabled,.react-datepicker__year-text--disabled{color:#ccc;cursor:default}.react-datepicker__day--disabled .overlay,.react-datepicker__month-text--disabled .overlay,.react-datepicker__quarter-text--disabled .overlay,.react-datepicker__year-text--disabled .overlay{background-color:#333;border-radius:4px;bottom:70%;color:#fff;left:50%;opacity:0;padding:4px;position:absolute;transform:translateX(-50%);transition:visibility 0s,opacity .3s ease-in-out;visibility:hidden;white-space:nowrap}.react-datepicker__input-container{display:inline-block;width:100%}.react-datepicker__input-container .react-datepicker__calendar-icon{box-sizing:initial;padding:.625em;position:absolute}.react-datepicker__view-calendar-icon input{padding:6px 10px 5px 25px}.react-datepicker__month-read-view,.react-datepicker__month-year-read-view,.react-datepicker__year-read-view{border:1px solid #0000;border-radius:.3rem;position:relative}.react-datepicker__month-read-view:hover,.react-datepicker__month-year-read-view:hover,.react-datepicker__year-read-view:hover{cursor:pointer}.react-datepicker__month-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view:hover .react-datepicker__year-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view:hover .react-datepicker__year-read-view--down-arrow{border-top-color:#b3b3b3}.react-datepicker__month-read-view--down-arrow,.react-datepicker__month-year-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{right:-16px;top:0;transform:rotate(135deg)}.react-datepicker__month-dropdown,.react-datepicker__month-year-dropdown,.react-datepicker__year-dropdown{background-color:#f0f0f0;border:1px solid #aeaeae;border-radius:.3rem;left:25%;position:absolute;text-align:center;top:30px;width:50%;z-index:1}.react-datepicker__month-dropdown:hover,.react-datepicker__month-year-dropdown:hover,.react-datepicker__year-dropdown:hover{cursor:pointer}.react-datepicker__month-dropdown--scrollable,.react-datepicker__month-year-dropdown--scrollable,.react-datepicker__year-dropdown--scrollable{height:150px;overflow-y:scroll}.react-datepicker__month-option,.react-datepicker__month-year-option,.react-datepicker__year-option{display:block;line-height:20px;margin-left:auto;margin-right:auto;width:100%}.react-datepicker__month-option:first-of-type,.react-datepicker__month-year-option:first-of-type,.react-datepicker__year-option:first-of-type{border-top-left-radius:.3rem;border-top-right-radius:.3rem}.react-datepicker__month-option:last-of-type,.react-datepicker__month-year-option:last-of-type,.react-datepicker__year-option:last-of-type{border-bottom-left-radius:.3rem;border-bottom-right-radius:.3rem;-webkit-user-select:none;user-select:none}.react-datepicker__month-option:hover,.react-datepicker__month-year-option:hover,.react-datepicker__year-option:hover{background-color:#ccc}.react-datepicker__month-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-upcoming,.react-datepicker__year-option:hover .react-datepicker__navigation--years-upcoming{border-bottom-color:#b3b3b3}.react-datepicker__month-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__month-year-option:hover .react-datepicker__navigation--years-previous,.react-datepicker__year-option:hover .react-datepicker__navigation--years-previous{border-top-color:#b3b3b3}.react-datepicker__month-option--selected,.react-datepicker__month-year-option--selected,.react-datepicker__year-option--selected{left:15px;position:absolute}.react-datepicker__close-icon{background-color:initial;border:0;cursor:pointer;display:table-cell;height:100%;outline:0;padding:0 6px 0 0;position:absolute;right:0;top:0;vertical-align:middle}.react-datepicker__close-icon:after{background-color:#216ba5;border-radius:50%;color:#fff;content:"×";cursor:pointer;display:table-cell;font-size:12px;height:16px;line-height:1;padding:2px;text-align:center;vertical-align:middle;width:16px}.react-datepicker__close-icon--disabled{cursor:default}.react-datepicker__close-icon--disabled:after{background-color:#ccc;cursor:default}.react-datepicker__today-button{background:#f0f0f0;border-top:1px solid #aeaeae;clear:left;cursor:pointer;font-weight:700;padding:5px 0;text-align:center}.react-datepicker__portal{align-items:center;background-color:#000c;display:flex;height:100vh;justify-content:center;left:0;position:fixed;top:0;width:100vw;z-index:2147483647}.react-datepicker__children-container{height:auto;margin:.5em;padding-left:.25em;padding-right:.25em;width:17.25em}.react-datepicker__aria-live{border:0;-webkit-clip-path:circle(0);clip-path:circle(0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.react-datepicker__calendar-icon{height:1em;vertical-align:-.125em;width:1em}.react-datepicker-popper-offset{margin-top:-.7em}.profile-questionnaire{background:linear-gradient(135deg,#0d0d0d,#1a1a1a 50%,#0d0d0d);min-height:100vh;padding:2rem 1rem;position:relative}.profile-questionnaire:before{background:radial-gradient(circle at 30% 30%,#ffd70014 0,#0000 50%),radial-gradient(circle at 70% 70%,#fdb8130f 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.questionnaire-container{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 60px #0000004d;margin:0 auto;max-width:700px;overflow:visible;padding:2rem;position:relative;z-index:1}.questionnaire-container .progress-bar{background:#0000;height:auto;margin-bottom:2rem;overflow:visible}.questionnaire-container .progress-fill{display:none}.questionnaire-container .progress-steps{display:flex;gap:1rem;justify-content:space-between}.questionnaire-container .progress-step{align-items:center;display:flex;flex:1 1;flex-direction:column}.questionnaire-container .step-number{align-items:center;background:var(--bg-card);border:2px solid var(--border);border-radius:50%;color:var(--text-light);display:flex;font-size:1.1rem;font-weight:700;height:40px;justify-content:center;margin-bottom:.5rem;transition:all .2s;width:40px}.questionnaire-container .progress-step.active .step-number{background:var(--primary);border-color:var(--primary);color:#0d0d0d}.questionnaire-container .progress-step.current .step-number{box-shadow:0 0 0 4px #ffd7004d}.questionnaire-container .step-label{color:var(--text-light);font-size:.75rem;font-weight:600;text-align:center}.questionnaire-container .progress-step.active .step-label{color:var(--text)}.step-container{display:flex;flex-direction:column;min-height:400px}.step-content{flex:1 1}.step-content h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .5rem}.step-description{color:var(--text-light);font-size:1.1rem;margin-bottom:2rem}.form-group,.form-row{margin-bottom:1.5rem}.form-row{grid-gap:1.5rem;gap:1.5rem}.form-group label{color:var(--text-light);font-size:1rem}.form-group input,.form-group select{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;box-sizing:border-box;color:var(--text);font-family:inherit;font-size:1rem;padding:.875rem;transition:all .2s;width:100%}.form-group input::placeholder{color:var(--text-light)}.form-group input:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.form-group select option{background:var(--bg-surface)}.form-group small{color:var(--text-light);display:block;font-size:.875rem;margin-top:.5rem}.checkbox-label{align-items:center;border-radius:8px;cursor:pointer;display:flex;padding:.75rem;transition:background .2s}.checkbox-label:hover{background:var(--bg-surface)}.checkbox-label input[type=checkbox]{accent-color:var(--primary);cursor:pointer;height:20px;margin-right:.75rem;width:20px}.checkbox-label span{color:var(--text);font-weight:500}.radio-group{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.radio-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;padding:1rem;transition:all .2s}.radio-option:hover{background:var(--bg-card-hover);border-color:var(--text-light)}.radio-option input[type=radio]{accent-color:var(--primary);cursor:pointer;height:20px;margin-right:.75rem;width:20px}.radio-option input[type=radio]:checked+span{color:var(--primary);font-weight:600}.radio-option:has(input:checked){background:#ffd7001a;border-color:var(--primary)}.unit-toggle{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;display:flex;margin-top:.5rem;overflow:hidden}.unit-toggle-btn{flex:1 1;font-size:1rem;padding:.75rem 1.5rem}.radio-group-inline{display:flex;gap:1rem;margin-top:.5rem}.radio-option-inline{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;flex:1 1;padding:.75rem 1rem;transition:all .2s}.radio-option-inline:hover{background:var(--bg-card-hover);border-color:var(--text-light)}.radio-option-inline input[type=radio]{accent-color:var(--primary);cursor:pointer;height:18px;margin-right:.5rem;width:18px}.radio-option-inline span{color:var(--text);font-size:.9375rem;font-weight:500}.radio-option-inline.selected{background:#ffd7001a;border-color:var(--primary)}.radio-option-inline.selected span{color:var(--primary);font-weight:600}.form-group input[type=date]{color-scheme:dark}.form-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1)}.datepicker-input{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s;width:100%}.datepicker-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.react-datepicker-wrapper{width:100%}.react-datepicker__input-container{align-items:center;display:flex;position:relative}.react-datepicker__calendar-icon{fill:var(--text-light);height:20px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px}.react-datepicker__input-container .datepicker-input{padding-right:40px}.react-datepicker{background:#1a1a2e;border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 40px #0006;font-family:inherit}.react-datepicker__header{background:#1a1a2e;border-bottom:1px solid var(--border);border-radius:12px 12px 0 0;padding:1rem}.react-datepicker__current-month{display:none}.react-datepicker-time__header,.react-datepicker__day-name{color:var(--text)}.react-datepicker__month-dropdown-container,.react-datepicker__year-dropdown-container{margin:0 .5rem}.react-datepicker__month-dropdown-container select,.react-datepicker__month-select,.react-datepicker__year-dropdown-container select,.react-datepicker__year-select{-webkit-appearance:auto;appearance:auto;background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.875rem;padding:.375rem .75rem}.react-datepicker__month-dropdown-container select:focus,.react-datepicker__month-select:focus,.react-datepicker__year-dropdown-container select:focus,.react-datepicker__year-select:focus{border-color:var(--primary);outline:none}.react-datepicker__month-select option,.react-datepicker__year-select option{background:var(--bg-card);color:var(--text)}.react-datepicker__day-name{color:#a0a0a0;font-weight:600;line-height:2.5rem;width:2.5rem}.react-datepicker__month{background:#1a1a2e;margin:0;padding:.5rem}.react-datepicker__day{border-radius:8px;color:#fff;line-height:2.5rem;transition:all .15s;width:2.5rem}.react-datepicker__day:hover{background:#ffffff1a;border-radius:8px}.react-datepicker__day--keyboard-selected,.react-datepicker__day--selected{background:var(--primary)!important;color:#0d0d0d!important;font-weight:600}.react-datepicker__day--today{color:var(--primary);font-weight:700}.react-datepicker__day--outside-month{color:#666;opacity:1}.react-datepicker__day--disabled{color:var(--text-light);cursor:not-allowed;opacity:.3}.react-datepicker__navigation{top:.75rem}.react-datepicker__navigation-icon:before{border-color:var(--text-light);border-width:2px 2px 0 0}.react-datepicker__navigation:hover :before{border-color:var(--primary)}.react-datepicker__header--has-time-select{padding:.75rem}.react-datepicker__month-dropdown,.react-datepicker__year-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.react-datepicker__month-option,.react-datepicker__year-option{color:var(--text);padding:.5rem}.react-datepicker__month-option:hover,.react-datepicker__year-option:hover{background:var(--bg-card-hover)}.react-datepicker__month-option--selected_month,.react-datepicker__year-option--selected_year{background:var(--primary);color:#0d0d0d}.react-datepicker__month-read-view,.react-datepicker__year-read-view{color:var(--text)}.react-datepicker__month-read-view--down-arrow,.react-datepicker__year-read-view--down-arrow{border-color:var(--text-light)}.react-datepicker__triangle{display:none}.react-datepicker-popper{z-index:100}.react-datepicker-popper[data-placement^=bottom]{padding-top:0}.react-datepicker-popper[data-placement^=top]{padding-bottom:0}.file-input{background:var(--bg-surface);border:2px dashed var(--border);border-radius:10px;color:var(--text);cursor:pointer;padding:.75rem;width:100%}.file-input:hover{background:var(--bg-card-hover);border-color:var(--primary)}.mileage-options{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.mileage-option{align-items:flex-start;background:var(--bg-surface);border:2px solid var(--border);border-radius:12px;cursor:pointer;display:flex;padding:1.25rem;transition:all .2s}.mileage-option:hover{background:var(--bg-card-hover);border-color:var(--text-light);box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.mileage-option input[type=radio]{accent-color:var(--primary);cursor:pointer;flex-shrink:0;height:20px;margin-right:1rem;margin-top:.25rem;width:20px}.mileage-option.selected{background:#ffd7001a;border-color:var(--primary);box-shadow:0 4px 12px #ffd70033}.mileage-option-content{flex:1 1}.mileage-option-content strong{color:var(--text);display:block;font-size:1.1rem;margin-bottom:.25rem}.mileage-option-content p{color:var(--text-light);font-size:.95rem;margin:0}.mileage-option-content .days-per-week{color:var(--primary);font-weight:600;margin-top:.25rem}.mileage-option.selected .mileage-option-content strong{color:var(--primary)}.info-box{margin-bottom:1.5rem}.info-box strong{color:var(--primary);margin-bottom:.25rem}.info-box p{margin:.5rem 0 0}.success-box{background:#48bb781a;border-left:4px solid #48bb78;border-radius:8px;color:#68d391;font-weight:600;margin-top:1.5rem;padding:1rem 1.25rem}.pb-section{border-top:2px solid var(--border);margin-top:2rem;padding-top:1.5rem}.pb-section h3{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .5rem}.pb-description{color:var(--text-light);font-size:.9375rem;margin-bottom:1rem}.pb-grid{grid-gap:1rem;gap:1rem}.pb-input-group{gap:.375rem}.pb-input-group label{font-size:.8125rem}.pb-input-group input{background:var(--bg-surface);border:2px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;transition:all .2s}.pb-input-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.pb-input-group input::placeholder{color:var(--text-light);opacity:.6}.pb-input-group input.valid{border-color:#48bb78}.pb-input-group input.invalid{border-color:#fc8181}.pb-error{color:#fc8181;font-size:.6875rem;margin-top:.125rem}.pb-hint{color:var(--text-light);display:block;font-size:.8125rem;margin-top:.75rem}.review-pbs{grid-gap:.25rem 1rem;display:grid;gap:.25rem 1rem;grid-template-columns:repeat(2,1fr)}.review-pbs p{font-size:.9375rem;margin:0}.review-section{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.review-item{background:var(--bg-surface);border-left:4px solid var(--primary);border-radius:10px;padding:1.25rem}.review-item strong{color:var(--text);display:block;font-size:1.1rem;margin-bottom:.5rem}.review-item p{color:var(--text-light);line-height:1.6;margin:.25rem 0}.vdot-display{color:var(--primary)!important;font-weight:600;margin-top:.5rem!important}.error-message{background:#ef44441a;border-left:4px solid #ef4444;color:#f87171;font-size:.95rem}.button-group{border-top:2px solid var(--border);display:flex;gap:1rem;margin-top:2rem;padding-top:2rem}.profile-questionnaire .btn-primary,.profile-questionnaire .btn-secondary{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-family:inherit;font-size:1.1rem;font-weight:600;padding:1rem 2rem;transition:all .2s}.profile-questionnaire .btn-primary{background:var(--primary);color:#0d0d0d}.profile-questionnaire .btn-primary:hover:not(:disabled){box-shadow:0 10px 25px #ffd70066;transform:translateY(-2px)}.profile-questionnaire .btn-primary:disabled{cursor:not-allowed;opacity:.6}.profile-questionnaire .btn-secondary{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-light)}.profile-questionnaire .btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text);transform:translateY(-2px)}.profile-questionnaire .btn-submit{font-size:1.2rem;padding:1.25rem 2rem}@media (max-width:768px){.profile-questionnaire{padding:1rem .5rem}.questionnaire-container{border-radius:16px;padding:1.5rem}.questionnaire-container .progress-bar{margin-bottom:1.5rem}.questionnaire-container .progress-steps{gap:.5rem}.questionnaire-container .step-label{font-size:.65rem}.questionnaire-container .step-number{font-size:.9rem;height:32px;width:32px}.step-container{min-height:auto}.step-content h2{font-size:1.5rem}.step-description{font-size:1rem}.form-row{grid-template-columns:1fr}.radio-group-inline{flex-direction:column}.unit-toggle-btn{font-size:.9375rem;padding:.625rem 1rem}.height-imperial{flex-wrap:wrap}.height-imperial input{width:60px}.pb-grid,.review-pbs{grid-template-columns:1fr}.button-group{flex-direction:column-reverse}.profile-questionnaire .btn-primary,.profile-questionnaire .btn-secondary{width:100%}}.step-content{animation:fadeIn .3s ease-out}.form-group input:invalid:not(:placeholder-shown){border-color:#fc8181}.form-group input:valid:not(:placeholder-shown){border-color:#68d391}.profile-questionnaire .btn-primary:disabled:after{animation:ellipsis 1.5s infinite;content:"..."}@keyframes ellipsis{0%{content:""}33%{content:"."}66%{content:".."}to{content:"..."}}.profile-image-section{gap:.75rem;margin-bottom:1.5rem}.profile-image-preview:hover:not(.uploading){border-color:var(--primary);transform:scale(1.02)}.profile-image-placeholder{gap:.25rem;height:100%;width:100%}.change-photo-btn{border:2px solid var(--border);color:var(--text)}.change-photo-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.photo-hint{color:var(--text-light);font-size:.75rem}.trophy-case{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;overflow:hidden}.trophy-case-header{align-items:center;background:linear-gradient(135deg,var(--bg-surface) 0,var(--bg-card) 100%);color:var(--text);display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.trophy-case-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.125rem;margin:0}.trophy-count{background:#ffd70033;border-radius:20px;color:var(--primary);font-size:.875rem;font-weight:600;padding:.25rem .75rem}.trophy-tabs{border-bottom:1px solid var(--border);display:flex}.trophy-tab{background:#0000;border:none;color:var(--text-light);cursor:pointer;flex:1 1;font-family:inherit;font-size:.8125rem;font-weight:600;padding:.875rem .5rem;position:relative;transition:all .2s}.trophy-tab:hover{background:var(--bg-card-hover);color:var(--text)}.trophy-tab.active{color:var(--primary)}.trophy-tab.active:after{background:var(--primary);bottom:-1px;content:"";height:2px;left:0;position:absolute;right:0}.trophy-content{max-height:calc(100vh - 300px);overflow-y:auto;padding:1rem}.trophy-loading{color:var(--text-light);padding:3rem 1rem;text-align:center}.pbs-section{display:flex;flex-direction:column;gap:1rem}.pbs-header{align-items:center;display:flex;justify-content:space-between}.pbs-source{color:var(--text-light);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.pbs-actions{display:flex;gap:.5rem}.add-pb-btn,.edit-pb-btn{background:var(--primary);border:none;border-radius:6px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:.375rem .75rem;transition:all .2s}.edit-pb-btn{background:#0000;border:1px solid var(--primary);color:var(--primary)}.add-pb-btn:hover,.edit-pb-btn:hover{box-shadow:0 2px 8px #ffd7004d;transform:translateY(-1px)}.edit-pb-btn:hover{background:#ffd7001a;box-shadow:0 2px 8px #ffd70033}.add-pb-form{background:var(--bg-surface);border-radius:10px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.add-pb-form input,.add-pb-form select{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:.875rem;padding:.5rem .75rem}.add-pb-form input:focus,.add-pb-form select:focus{border-color:var(--primary);outline:none}.save-pb-btn{background:var(--primary);border:none;border-radius:6px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:700;margin-top:.25rem;padding:.625rem 1rem}.save-pb-btn:hover{filter:brightness(1.1)}.edit-pb-modal{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.edit-pb-form{background:var(--bg-card);border-radius:12px;display:flex;flex-direction:column;gap:1rem;max-width:400px;padding:1.5rem;width:100%}.edit-pb-header{align-items:center;display:flex;justify-content:space-between}.edit-pb-header h4{color:var(--primary);font-size:1.125rem;margin:0}.close-btn{color:var(--text-light);font-size:1.5rem;line-height:1}.close-btn:hover{color:var(--text)}.edit-pb-form input{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:.875rem;padding:.5rem .75rem}.edit-pb-form input:focus{border-color:var(--primary);outline:none}.add-pb-form input[type=date],.edit-pb-form input[type=date]{color-scheme:dark}.add-pb-form input[type=date]::-webkit-calendar-picker-indicator,.edit-pb-form input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7}.add-pb-form input[type=date]::-webkit-calendar-picker-indicator:hover,.edit-pb-form input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.edit-pb-actions{display:flex;gap:.75rem;margin-top:.5rem}.edit-pb-actions .save-pb-btn{flex:1 1}.delete-pb-btn{background:#0000;border:1px solid #ef4444;border-radius:6px;color:#ef4444;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.625rem 1rem;transition:all .2s}.delete-pb-btn:hover{background:#ef4444;color:#fff}.pb-form-row{display:flex;flex-direction:column;gap:.375rem}.pb-form-label{color:var(--text-light);font-size:.75rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.pb-distance-selector{display:flex;gap:1rem}.pb-radio-option{align-items:center;color:var(--text);cursor:pointer;display:flex;font-size:.875rem;gap:.375rem}.pb-radio-option input[type=radio]{accent-color:var(--primary);padding:0;width:auto}.pb-custom-distance{display:flex;gap:.5rem}.pb-custom-distance input{flex:1 1}.pb-custom-distance select{width:80px}.pbs-list{display:flex;flex-direction:column}.pb-row{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:.75rem 0;position:relative}.pb-row:last-child{border-bottom:none}.pb-row.no-pb{opacity:.5}.pb-row.editable{border-radius:6px;cursor:pointer;margin:0 -.5rem;padding-left:.5rem;padding-right:.5rem;transition:background .2s}.pb-row.editable:hover{background:#ffd7001a}.pb-row.editable.no-pb{cursor:default}.pb-row.editable.no-pb:hover{background:#0000}.edit-icon{color:var(--text-light);font-size:.875rem;position:absolute;right:.5rem}.pb-distance{color:var(--text);font-size:.875rem;font-weight:600}.pb-time{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1rem}.pb-row.no-pb .pb-time{color:var(--text-light);font-family:inherit;font-weight:400}.pb-details{align-items:flex-end;display:flex;flex-direction:column;gap:.125rem}.pb-date{color:var(--text-light);font-size:.6875rem}.pb-row.custom-pb{background:#ffd7000d;border-radius:6px;margin:0 -.5rem;padding-left:.5rem;padding-right:.5rem}.achievements-grid{display:flex;flex-direction:column;gap:.5rem}.achievement-item{align-items:center;background:var(--bg-surface);border-radius:10px;display:flex;gap:.75rem;padding:.75rem;position:relative;transition:all .2s}.achievement-item.earned{background:#ffd70026}.achievement-item.locked{opacity:.6}.achievement-item.locked .achievement-icon{filter:grayscale(100%)}.achievement-icon{flex-shrink:0;font-size:1.5rem}.achievement-info{flex:1 1;min-width:0}.achievement-name{color:var(--secondary);display:block;font-size:.875rem;font-weight:700;margin-bottom:.125rem}.achievement-desc{color:var(--text-light);display:block;font-size:.75rem;line-height:1.3}.lock-icon{font-size:.875rem;opacity:.5}.challenge-badge-item{align-items:flex-start;background:linear-gradient(135deg,#ffd70033,#ffd7000d);border:1px solid #ffd7004d;border-radius:12px;display:flex;gap:.75rem;overflow:hidden;padding:1rem;position:relative}.challenge-badge-item:before{background:linear-gradient(90deg,var(--primary),var(--secondary));content:"";height:3px;left:0;position:absolute;right:0;top:0}.badge-medal{flex-shrink:0;font-size:2rem}.badge-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.badge-title{color:var(--secondary);font-size:.9375rem;font-weight:700}.badge-achievement{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:.875rem}.badge-month{color:var(--text-light);font-size:.75rem;font-weight:500}.challenges-list{display:flex;flex-direction:column;gap:.75rem}.challenge-trophy-item{align-items:flex-start;background:linear-gradient(135deg,#ffd70026 0,var(--bg-card) 50%);border-left:4px solid var(--primary);border-radius:10px;display:flex;gap:.75rem;padding:1rem}.challenge-icon{flex-shrink:0;font-size:1.5rem}.challenge-info{flex:1 1;min-width:0}.challenge-title{color:var(--secondary);display:block;font-size:.9375rem;font-weight:700;margin-bottom:.25rem}.challenge-details{color:var(--text);display:block;font-size:.8125rem;margin-bottom:.25rem}.challenge-date{color:var(--text-light);display:block;font-size:.75rem}.races-list{display:flex;flex-direction:column;gap:.75rem}.race-result-item{background:var(--bg-surface);border-radius:10px;overflow:hidden}.race-result-header{align-items:center;background:var(--bg-card-hover);color:var(--text);display:flex;gap:.75rem;padding:.875rem 1rem}.race-medal{font-size:1.25rem}.race-info{flex:1 1}.race-name{display:block;font-size:.9375rem;font-weight:700}.race-distance{display:block;font-size:.75rem;opacity:.9}.race-result-body{align-items:center;display:flex;justify-content:space-between;padding:.875rem 1rem}.race-time{display:flex;flex-direction:column}.time-label{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.time-value{font-size:1.125rem}.race-date-info{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem;text-align:right}.date-value{color:var(--text-light);font-size:.8125rem}.position-badge{background:var(--primary);border-radius:10px;color:#0d0d0d;font-size:.6875rem;font-weight:700;padding:.125rem .5rem}.empty-state{padding:2rem 1rem;text-align:center}.empty-icon{display:block;font-size:2.5rem;margin-bottom:.75rem;opacity:.5}.empty-state p{color:var(--text);font-weight:500;margin:0 0 .25rem}.empty-hint{color:var(--text-light);font-size:.8125rem}.view-challenges-link{color:var(--primary);cursor:pointer;font-weight:500;text-decoration:none}.view-challenges-link:hover{text-decoration:underline}.view-challenges-btn{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:700;margin-top:1rem;padding:.625rem 1.25rem;transition:all .2s}.view-challenges-btn:hover{box-shadow:0 4px 12px #ffd7004d;transform:translateY(-1px)}@media (max-width:1200px){.trophy-case{margin-bottom:1.5rem}.trophy-content{max-height:400px}.achievements-grid{display:grid;grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.achievements-grid{grid-template-columns:1fr}}.home-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.home-container{display:flex;flex-direction:column;gap:1.5rem;margin:0 auto;max-width:1200px}.next-workout{background:var(--bg-card);border-left:6px solid var(--primary);border-radius:16px;box-shadow:0 4px 20px #0000004d;overflow:hidden;padding:2rem;position:relative}.next-workout--empty{border-left-color:#a0aec0;padding:3rem 2rem;text-align:center}.next-workout--empty h2{color:var(--text-light);margin-bottom:.5rem}.next-workout--empty p{color:var(--text-light)}.next-workout__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.next-workout__date-info{display:flex;flex-direction:column;gap:.25rem}.next-workout__label{color:var(--primary);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.next-workout__date{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0}.next-workout__header-right{align-items:center;display:flex;gap:.75rem}.unit-toggle-btn{font-size:.875rem;padding:.375rem .75rem}.next-workout__badge{border-radius:20px;color:#fff;font-size:.875rem;font-weight:600;padding:.5rem 1rem}.next-workout__body{display:flex;flex-direction:column;gap:1.25rem}.next-workout__main{align-items:flex-start;display:flex;gap:2rem}.next-workout__distance{align-items:baseline;display:flex;flex-shrink:0;gap:.25rem}.distance-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:3rem;line-height:1}.distance-unit{color:var(--text-light);font-size:1.25rem;font-weight:500}.next-workout__description{flex:1 1}.next-workout__description p{color:var(--text);font-size:1.125rem;line-height:1.6;margin:0}.next-workout__targets{background:var(--bg-surface);border-radius:12px;display:flex;flex-wrap:wrap;gap:1.5rem;padding:1rem 1.5rem}.target-item{display:flex;flex-direction:column;gap:.25rem}.target-label{color:var(--text-light);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.target-value{color:var(--primary);font-size:1.125rem;font-weight:600}.target-value--secondary{color:var(--text-light);font-weight:500}.next-workout__notes{background:#ffd7001a;border-left:3px solid var(--primary);border-radius:8px;padding:1rem}.next-workout__notes p{color:var(--text);font-size:.9375rem;font-style:italic;margin:0}.next-workout__actions{border-top:1px solid var(--border);display:flex;gap:1rem;margin-top:1.5rem;padding-top:1.5rem}.next-workout__actions .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.next-workout__actions .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.next-workout__actions .btn-secondary{background:var(--bg-surface);border:none;border-radius:10px;color:var(--text);cursor:pointer;font-family:inherit;font-size:1rem;font-weight:500;padding:.875rem 1.5rem;transition:all .2s}.next-workout__actions .btn-secondary:hover{background:var(--bg-card-hover)}.next-workout__note{background:#ffd70026;border-radius:8px;color:var(--primary);font-size:.875rem;font-weight:500;margin-top:1rem;padding:.75rem 1rem}.home-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}.home-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem}.card-title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:.875rem;letter-spacing:.05em;margin:0 0 1.25rem;text-transform:uppercase}.card-empty{color:var(--text-light);font-size:.9375rem;margin:0}.race-countdown__race{display:flex;flex-direction:column;gap:.25rem;margin-bottom:1.25rem}.race-name{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem}.race-date{color:var(--text-light);font-size:.875rem}.race-countdown__timer{align-items:center;display:flex;gap:.75rem;margin-bottom:1.25rem}.countdown-item{align-items:center;display:flex;flex-direction:column}.countdown-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2.5rem;line-height:1}.countdown-label{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.countdown-divider{color:var(--text-light);font-size:1.5rem;font-weight:300}.race-countdown__phase{margin-bottom:1rem}.phase-badge{background:var(--primary)!important;border-radius:20px;color:#0d0d0d;display:inline-block;font-size:.75rem;font-weight:600;padding:.375rem .75rem}.race-countdown__progress{display:flex;flex-direction:column;gap:.5rem}.progress-bar{background:var(--bg-surface);border-radius:4px;height:8px;overflow:hidden}.progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:var(--text-light);font-size:.75rem}.recent-sessions__list{display:flex;flex-direction:column;gap:.75rem}.recent-sessions__item{align-items:center;background:var(--bg-surface);border-radius:10px;display:flex;gap:.75rem;padding:.75rem}.session-badge{align-items:center;border-radius:8px;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:32px;justify-content:center;width:32px}.session-info{display:flex;flex-direction:column;gap:.125rem}.session-date{color:var(--text);font-size:.875rem;font-weight:500}.session-distance{color:var(--text-light);font-size:.75rem}.training-health__stat{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:.75rem 0}.training-health__stat:last-of-type{border-bottom:none}.training-health__stat .stat-label{color:var(--text-light);font-size:.875rem}.training-health__stat .stat-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem}.training-health__focus{background:var(--bg-surface);border-radius:8px;margin-top:1rem;padding:.75rem}.focus-label{color:var(--text-light);display:block;font-size:.75rem;font-weight:600;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.focus-value{color:var(--text);font-size:.9375rem}.feature-cards-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-top:1.5rem}.feature-card{background:var(--bg-card);border-left:6px solid var(--primary);border-radius:16px;box-shadow:0 4px 20px #0000004d;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.feature-card:hover{box-shadow:0 8px 30px #0006;transform:translateY(-4px)}.feature-card__header{align-items:center;display:flex;justify-content:space-between}.feature-card__icon{align-items:center;display:flex;font-size:2rem;line-height:1}.feature-card__title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.125rem;margin:0}.feature-card__stat{color:var(--text-light);font-size:.875rem;margin:0}.feature-card__cta{color:var(--primary);font-size:.875rem;font-weight:600;margin-top:auto}.latest-run{background:var(--bg-card);border-left:6px solid #22c55e;border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem 2rem}.latest-run__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.25rem}.latest-run__title-area{display:flex;flex-direction:column;gap:.25rem}.latest-run__label{color:#22c55e;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.latest-run__title{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.latest-run__icon{align-items:center;background:#22c55e26;border-radius:10px;display:flex;height:40px;justify-content:center;width:40px}.latest-run__icon svg{color:#22c55e;height:20px;width:20px}.latest-run__stats{display:flex;flex-wrap:wrap;gap:2rem}.latest-run__stat{align-items:baseline;display:flex;gap:.25rem}.latest-run__stat-value{color:#22c55e;font-family:Archivo Black,sans-serif;font-size:1.75rem;line-height:1}.latest-run__stat-label{color:var(--text-light);font-size:.875rem;font-weight:500}@media (max-width:1024px){.home-grid{grid-template-columns:repeat(2,1fr)}.home-grid .training-health{grid-column:1/-1}.feature-cards-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.home-page{padding:1rem}.home-container{gap:1rem}.next-workout{padding:1.5rem}.next-workout__main{flex-direction:column;gap:1rem}.distance-value{font-size:2.5rem}.feature-cards-grid,.home-grid{grid-template-columns:1fr}.countdown-value{font-size:2rem}.latest-run{padding:1.25rem 1.5rem}.latest-run__stats{gap:1.5rem}.latest-run__stat-value{font-size:1.5rem}}@media (max-width:480px){.next-workout__header{flex-direction:column;gap:1rem}.next-workout__header-right{align-self:flex-start}.next-workout__targets{gap:1rem}.target-item{min-width:calc(50% - .5rem)}.next-workout__actions{flex-direction:column}.next-workout__actions .btn-primary,.next-workout__actions .btn-secondary{text-align:center;width:100%}.race-countdown__timer{justify-content:center}.latest-run__stats{gap:1rem}.latest-run__stat-value{font-size:1.25rem}}.activity-feed-section{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;overflow:hidden}.activity-feed-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem 2rem}.activity-feed-title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.activity-feed-toggle{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;display:flex;overflow:hidden}.activity-feed-toggle .toggle-btn{background:#0000;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.activity-feed-toggle .toggle-btn:first-child{border-right:1px solid var(--border)}.activity-feed-toggle .toggle-btn:hover:not(.active){background:var(--bg-card-hover);color:var(--text)}.activity-feed-toggle .toggle-btn.active{background:var(--primary);color:#0d0d0d}.activity-feed-content{max-height:650px;min-height:550px;overflow-y:auto}.activity-feed-loading{color:var(--text-light);padding:2rem;text-align:center}.activity-feed-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:500px;padding:5rem 2rem;text-align:center}.activity-feed-empty-icon{font-size:5rem;margin-bottom:2rem;opacity:.6}.activity-feed-empty h4{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 1rem}.activity-feed-empty p{color:var(--text-light);font-size:1.125rem;margin:0 0 2rem}.activity-feed-empty .btn-primary{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.activity-feed-empty .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.activity-feed-list{padding:.5rem 0}.activity-item{display:flex;gap:1rem;padding:1rem 2rem;transition:background .2s}.activity-item:hover{background:var(--bg-surface)}.activity-item-avatar{align-items:center;background:var(--primary);border-radius:50%;display:flex;flex-shrink:0;height:44px;justify-content:center;overflow:hidden;width:44px}.activity-item-avatar img{height:100%;object-fit:cover;width:100%}.activity-item-avatar span{color:#0d0d0d;font-size:1rem;font-weight:700}.activity-item-content{flex:1 1;min-width:0}.activity-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem}.activity-item-name{color:var(--text);font-size:.9375rem;font-weight:600}.activity-item-time{color:var(--text-light);font-size:.75rem}.activity-item-body{align-items:center;display:flex;gap:.5rem}.activity-item-icon{font-size:1rem}.activity-item-title{color:var(--text);font-size:.875rem}.activity-item-description{color:var(--text-light);font-size:.8125rem;line-height:1.4;margin:.5rem 0 0}.next-workout-card{border-left:4px solid var(--primary)}.next-workout-card__date{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1rem;margin-bottom:.75rem}.next-workout-card__type{margin-bottom:.75rem}.workout-type-badge{border-radius:16px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;padding:.375rem .75rem}.next-workout-card__distance{align-items:baseline;display:flex;gap:.25rem;margin-bottom:.75rem}.next-workout-card__distance .distance-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;line-height:1}.next-workout-card__distance .distance-unit{color:var(--text-light);font-size:1rem}.next-workout-card__description{color:var(--text);font-size:.875rem;line-height:1.5;margin:0}.retest-note{background:#ffd70026;border-radius:6px;color:var(--primary);font-size:.75rem;font-weight:500;margin-top:.75rem;padding:.5rem .75rem}@media (max-width:768px){.activity-feed-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1.25rem 1.5rem}.activity-feed-toggle{width:100%}.activity-feed-toggle .toggle-btn{flex:1 1;text-align:center}.activity-item{padding:1rem 1.5rem}.activity-feed-content{max-height:500px;min-height:400px}.activity-feed-empty{min-height:350px;padding:3rem 1.5rem}}@media (max-width:480px){.activity-item-avatar{height:36px;width:36px}.activity-item-avatar span{font-size:.875rem}.next-workout-card__distance .distance-value{font-size:1.75rem}}.retest-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.retest-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{border-bottom:2px solid #e2e8f0;padding:2rem}.modal-header h2{font-size:1.75rem}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#a0aec0;cursor:pointer;display:flex;font-size:2rem;height:40px;justify-content:center;padding:0;transition:all .2s;width:40px}.close-btn:hover{background:#edf2f7;color:var(--secondary)}.modal-body{padding:2rem}.modal-description{color:var(--text-light);font-size:1.1rem;margin-bottom:2rem}.workout-choice{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:2rem}.choice-btn{align-items:center;background:#f7fafc;border:3px solid #e2e8f0;border-radius:15px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;padding:1.5rem;text-align:center;transition:all .2s}.choice-btn:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.choice-btn.selected{background:#ffd7001a;border-color:var(--primary);box-shadow:0 4px 12px #ffd70033}.choice-icon{font-size:3rem;margin-bottom:.75rem}.choice-content strong{color:var(--secondary);display:block;font-size:1.1rem;margin-bottom:.25rem}.choice-content p{color:var(--text-light);font-size:.9rem;margin:0}.retest-form{animation:slideDown .3s ease-out;background:#f7fafc;border-radius:12px;margin-top:1.5rem;padding:1.5rem}.retest-form h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.2rem;margin:0 0 1.5rem}.retest-form .form-group{margin-bottom:1.25rem}.retest-form label{color:var(--text);display:block;font-weight:600;margin-bottom:.5rem}.retest-form input,.retest-form select{background:#fff;border:2px solid #e2e8f0;border-radius:10px;box-sizing:border-box;font-family:inherit;font-size:1rem;padding:.875rem;transition:all .2s;width:100%}.retest-form input:focus,.retest-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.retest-form small{color:var(--text-light);display:block;font-size:.875rem;margin-top:.5rem}.comparison-section{margin-bottom:2rem}.comparison-section h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.3rem;margin:0 0 1rem}.vdot-comparison{align-items:center;background:#ffd7001a;border-radius:12px;display:flex;gap:1.5rem;justify-content:center;margin-bottom:1rem;padding:1.5rem}.vdot-new,.vdot-old{align-items:center;background:#fff;border-radius:10px;display:flex;flex-direction:column;min-width:100px;padding:1rem}.vdot-new .label,.vdot-old .label{color:var(--text-light);font-size:.875rem;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.vdot-old .value{color:#a0aec0;font-size:2rem;font-weight:700}.vdot-new .value{color:var(--secondary);font-size:2rem;font-weight:700}.vdot-arrow{color:var(--primary);font-size:2rem}.vdot-improvement{text-align:center}.improvement-value{background:#c6f6d5;border-radius:8px;color:#48bb78;display:block;font-size:1.1rem;font-weight:700;padding:.5rem 1rem}.pace-comparison-table{overflow-x:auto}.pace-comparison-table table{background:#fff;border-collapse:collapse;border-radius:10px;overflow:hidden;width:100%}.pace-comparison-table td,.pace-comparison-table th{border-bottom:1px solid #e2e8f0;padding:1rem;text-align:left}.pace-comparison-table thead{background:#f7fafc}.pace-comparison-table th{color:var(--secondary);font-size:.875rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.pace-comparison-table tbody tr:last-child td{border-bottom:none}.pace-comparison-table td{color:var(--text-light)}.new-pace{color:var(--secondary)!important;font-weight:700}.info-box{background:#ffd7001a;border-left:4px solid var(--primary);border-radius:8px;margin-top:1.5rem;padding:1rem 1.25rem}.info-box strong{color:var(--secondary);display:block;margin-bottom:.5rem}.info-box p{color:var(--text);margin:.25rem 0}.error-message{background:#fed7d7;border-left:4px solid #c53030;border-radius:10px;color:#c53030;margin-top:1.5rem;padding:1rem}.modal-footer{border-top:2px solid #e2e8f0;gap:1rem;padding:2rem}.btn-primary,.btn-secondary{border:none;border-radius:10px;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 2rem;transition:all .2s}.btn-primary{color:var(--secondary)}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #ffd70066}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#e2e8f0;color:var(--text-light)}.btn-secondary:hover:not(:disabled){background:#cbd5e0}.btn-large{font-size:1.1rem;padding:1.25rem 2rem;width:100%}@media (max-width:768px){.retest-modal{max-height:95vh}.modal-header{padding:1.5rem}.modal-header h2{font-size:1.5rem}.modal-body{padding:1.5rem}.workout-choice{grid-template-columns:1fr}.vdot-comparison{flex-direction:column;gap:1rem}.vdot-arrow{transform:rotate(90deg)}.modal-footer{flex-direction:column-reverse;padding:1.5rem}.btn-primary,.btn-secondary{width:100%}}.garmin-connect{margin:1.5rem 0}.garmin-connect-section{text-align:center}.garmin-note{color:var(--text-light);font-size:.875rem;margin-top:.75rem}.garmin-connect-btn{align-items:center;background:linear-gradient(135deg,#007cc3,#005a8f);border:none;border-radius:10px;box-shadow:0 4px 12px #007cc34d;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:1rem;font-weight:600;gap:.75rem;margin:0 auto;padding:.875rem 1.5rem;transition:all .2s}.garmin-connect-btn:hover:not(:disabled){box-shadow:0 6px 16px #007cc366;transform:translateY(-2px)}.garmin-connect-btn:disabled{cursor:not-allowed;opacity:.6}.garmin-icon{height:24px;width:24px}.garmin-connected{background:var(--bg-card);border-radius:12px;box-shadow:0 2px 8px #0000004d;padding:1.5rem}.garmin-status{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:.75rem;margin-bottom:1rem;padding-bottom:1rem}.garmin-icon.connected{color:#10b981;height:32px;width:32px}.garmin-status-info{display:flex;flex-direction:column;gap:.25rem}.connected-text{color:#10b981;font-size:1.125rem;font-weight:600}.user-id{color:var(--text-light);font-family:monospace;font-size:.75rem}.garmin-permissions{background:var(--bg-surface);border-radius:8px;margin-bottom:1rem;padding:.75rem}.permissions-label{color:var(--text-light);display:block;font-size:.75rem;letter-spacing:.05em;margin-bottom:.5rem;text-transform:uppercase}.permissions-list{display:flex;flex-wrap:wrap;gap:.5rem}.permission-badge{background:#ffd70026;border-radius:4px;color:var(--primary);font-size:.75rem;font-weight:500;padding:.25rem .5rem}.garmin-warning{background:#fbbf2426;border:1px solid #fbbf244d;border-radius:8px;color:#fbbf24;margin-bottom:1rem}.garmin-error,.garmin-warning{font-size:.875rem;padding:.75rem 1rem}.garmin-error{align-items:center;background:#dc262626;border:1px solid #dc26264d;border-radius:8px;color:#f87171;display:flex;gap:.75rem;margin-top:1rem}.garmin-error svg{flex-shrink:0;height:20px;width:20px}.garmin-actions{display:flex;flex-wrap:wrap;gap:.75rem}.garmin-test-btn{align-items:center;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;color:#166534;cursor:pointer;display:flex;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s}.garmin-test-btn:hover:not(:disabled){background:#dcfce7;border-color:#4ade80}.garmin-test-btn:disabled{cursor:not-allowed;opacity:.5}.garmin-sync-btn{align-items:center;background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.625rem;min-width:180px;padding:.75rem 1.5rem;transition:all .2s}.garmin-sync-btn:hover:not(:disabled){box-shadow:0 4px 12px #ffd7004d;transform:translateY(-1px)}.garmin-sync-btn:disabled{cursor:not-allowed;opacity:.6}.sync-icon{height:20px;width:20px}.garmin-disconnect-btn{background:#0000;border:1px solid var(--border);border-radius:8px;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem 1.25rem;transition:all .2s}.garmin-disconnect-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-light);color:var(--text)}.spinner{animation:spin .8s linear infinite;border:2px solid #0003;border-radius:50%;border-top:2px solid var(--secondary);display:inline-block;height:16px;width:16px}.garmin-test-btn .spinner{border-color:#166534 #1665344d #1665344d}.sync-status{animation:slideIn .3s ease-out;border-radius:8px;margin-top:1rem;padding:1rem}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sync-status.success{background:#f0fdf4;border:1px solid #86efac}.sync-status.error{background:#fef2f2;border:1px solid #fca5a5}.sync-status.info{background:#ffd7001a;border:1px solid var(--primary)}.sync-status-content{display:flex;gap:.75rem}.sync-status-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:1rem;font-weight:700;height:24px;justify-content:center;width:24px}.sync-status.success .sync-status-icon{background:#22c55e;color:#fff}.sync-status.error .sync-status-icon{background:#ef4444;color:#fff}.sync-status.info .sync-status-icon{background:var(--primary);color:#0d0d0d}.sync-status-message{color:var(--text);font-weight:600}.sync-status-details{color:var(--text-light);font-size:.875rem;margin-top:.25rem}@media (max-width:640px){.garmin-actions{flex-direction:column}.garmin-sync-btn,.garmin-test-btn{justify-content:center;min-width:100%}}.workout-step-editor-v2{display:flex;flex-direction:column;gap:1rem}.steps-toolbar{display:flex;gap:.75rem;justify-content:flex-end}.btn-add-repeat,.btn-add-step{align-items:center;border-radius:6px;cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.375rem;padding:.625rem 1rem;transition:all .2s}.btn-add-step{background:var(--primary);border:none;color:#0d0d0d}.btn-add-step:hover{box-shadow:0 4px 12px #ffd7004d;transform:translateY(-1px)}.btn-add-repeat{background:#0000;border:1px solid var(--border);color:var(--text)}.btn-add-repeat:hover{border-color:var(--primary);color:var(--primary)}.steps-list-v2{display:flex;flex-direction:column;gap:.5rem}.no-steps-hint{color:var(--text-light);font-size:.875rem;margin:0;padding:2rem 1rem;text-align:center}.step-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.step-card.editing{border-color:#3182ce;border-width:2px}.step-card-header{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:.75rem;padding:.75rem 1rem}.step-card.editing .step-card-header{border-bottom:none;padding-bottom:.5rem}.drag-handle{grid-gap:3px;cursor:grab;display:grid;gap:3px;grid-template-columns:repeat(2,4px);padding:.25rem}.drag-handle span{background:var(--text-light);border-radius:50%;height:4px;width:4px}.step-editing-label,.step-type-label{color:var(--text);flex:1 1;font-size:.9375rem;font-weight:600}.step-editing-label{color:var(--text-light);font-style:italic}.step-actions{align-items:center;display:flex;gap:.5rem}.btn-edit-step{background:none;border:none;color:#3182ce;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:600;padding:.25rem .5rem;transition:color .2s}.btn-edit-step:hover{color:#4299e1}.btn-delete-step{align-items:center;background:none;border:none;color:var(--text-light);cursor:pointer;display:flex;padding:.25rem;transition:color .2s}.btn-delete-step:hover{color:#dc2626}.step-card-body{align-items:center;display:flex;gap:1.5rem;padding:.75rem 1rem}.step-stat{display:flex;flex-direction:column}.stat-value{font-size:1.125rem;font-weight:700}.stat-label{font-size:.75rem}.step-pace-badge{background:#ffd70026;border-radius:4px;color:var(--primary);font-size:.75rem;font-weight:600;margin-left:auto;padding:.375rem .75rem}.step-card.run{border-left:4px solid #3182ce}.step-card.recover{border-left:4px solid #718096}.step-card.warmup{border-left:4px solid #48bb78}.step-card.cooldown{border-left:4px solid #38b2ac}.step-card.rest{border-left:4px solid #a0aec0}.step-edit-form{display:flex;flex-direction:column;gap:1.25rem;padding:1rem}.edit-section h4{color:var(--text);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.edit-row{align-items:center;display:flex;gap:1rem;margin-bottom:.75rem}.edit-row label{color:var(--text-light);font-size:.8125rem;min-width:80px}.edit-row input[type=number],.edit-row select{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:.875rem;min-width:150px;padding:.625rem .75rem}.edit-row input:focus,.edit-row select:focus{border-color:#3182ce;outline:none}.duration-inputs{display:flex;gap:.5rem}.duration-inputs input{width:80px}.duration-inputs select{min-width:70px}.time-row{align-items:flex-start;flex-direction:column;gap:.5rem}.time-inputs{align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;display:flex;gap:.25rem;padding:.5rem .75rem}.time-input{-moz-appearance:textfield;background:#0000!important;border:none!important;color:var(--text);font-family:inherit;font-size:1rem;padding:.375rem .25rem!important;text-align:center;width:48px!important}.time-input::-webkit-inner-spin-button,.time-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.time-input:focus{background:var(--bg-surface)!important;border-radius:4px;outline:none}.time-separator{color:var(--text);font-size:1.125rem;font-weight:600;-webkit-user-select:none;user-select:none}.time-hint{color:var(--text-light);font-size:.75rem;margin-top:.25rem}.edit-section textarea{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:.875rem;min-height:60px;padding:.75rem;resize:vertical;width:100%}.edit-section textarea:focus{border-color:#3182ce;outline:none}.char-count,.edit-section textarea::placeholder{color:var(--text-light)}.char-count{display:block;font-size:.75rem;margin-top:.25rem;text-align:right}.edit-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.btn-cancel{background:#0000;border:1px solid var(--border);border-radius:6px;padding:.625rem 1.25rem}.btn-cancel,.btn-done{cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .2s}.btn-done{background:#3182ce;border:none;border-radius:6px;color:#fff;padding:.625rem 1.5rem}.btn-done:hover{background:#4299e1}.repeat-block{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;overflow:hidden}.repeat-header{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;gap:.75rem;padding:.75rem 1rem}.repeat-label{color:var(--text);font-size:.9375rem;font-weight:600}.repeat-count-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--text);font-family:inherit;font-size:.875rem;padding:.375rem .5rem;text-align:center;width:50px}.repeat-count-input:focus{border-color:var(--primary);outline:none}.repeat-times{color:var(--text);flex:1 1;font-size:.875rem}.repeat-steps{display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.repeat-footer{border-top:1px solid var(--border);padding:.75rem 1rem}.skip-last-recover{align-items:center;color:var(--text);cursor:pointer;display:flex;font-size:.8125rem;gap:.5rem}.skip-last-recover input[type=checkbox]{cursor:pointer;height:16px;width:16px}.info-icon{align-items:center;background:#3182ce;border-radius:50%;color:#fff;cursor:help;display:inline-flex;font-size:.625rem;font-weight:700;height:16px;justify-content:center;width:16px}.workout-summary{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;display:flex;gap:2rem;justify-content:flex-end;padding:1rem}.summary-stat{align-items:flex-end;display:flex;flex-direction:column}.summary-value{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1.25rem}.summary-label{color:var(--text-light);font-size:.75rem}@media (max-width:640px){.steps-toolbar{flex-direction:column}.btn-add-repeat,.btn-add-step{justify-content:center;width:100%}.step-card-body{flex-wrap:wrap;gap:1rem}.step-pace-badge{margin-left:0;text-align:center;width:100%}.edit-row{align-items:flex-start;flex-direction:column;gap:.5rem}.duration-inputs,.edit-row input[type=number],.edit-row select{width:100%}.duration-inputs input{flex:1 1;width:auto}.repeat-header{flex-wrap:wrap;gap:.5rem}.workout-summary{align-items:flex-end;flex-direction:column;gap:.75rem}}@media (max-width:480px){.step-card-body,.step-card-header{padding:.625rem .75rem}.step-actions{align-items:flex-end;flex-direction:column;gap:.25rem}.btn-edit-step{font-size:.75rem}}.workout-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.workout-modal{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.modal-close{align-items:center;background:#fff3;border-radius:50%;color:#fff;display:flex;height:32px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:all .2s;width:32px;z-index:10}.modal-close:hover{background:#ffffff4d}.modal-header{border-radius:16px 16px 0 0;color:#fff}.modal-header h2{font-size:1.5rem;margin:0 0 .25rem}.modal-date{font-size:.9375rem;opacity:.9}.modal-body{padding:1.5rem}.workout-modal .pace-zones-display{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1.25rem;padding:1rem}.workout-modal .pace-zones-display h4{align-items:center;color:var(--text);display:flex;font-size:.875rem;gap:.5rem;margin:0 0 .75rem}.workout-modal .vdot-badge{background:var(--primary);border-radius:4px;color:#0d0d0d;font-size:.75rem;font-weight:700;padding:.125rem .5rem}.workout-modal .pace-zones-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(5,1fr)}.workout-modal .pace-zone{align-items:center;border-left:3px solid;border-radius:8px;display:flex;flex-direction:column;padding:.5rem}.workout-modal .pace-zone.easy{background:#48bb781a;border-left-color:#48bb78}.workout-modal .pace-zone.marathon{background:#38b2ac1a;border-left-color:#38b2ac}.workout-modal .pace-zone.threshold{background:#ed89361a;border-left-color:#ed8936}.workout-modal .pace-zone.interval{background:#f565651a;border-left-color:#f56565}.workout-modal .pace-zone.repetition{background:#9f7aea1a;border-left-color:#9f7aea}.workout-modal .zone-label{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.workout-modal .zone-pace{color:var(--text);font-size:.75rem;font-weight:600;margin-top:.125rem}.workout-modal .steps-section{margin-top:.5rem}.workout-modal .steps-section h4{color:var(--text);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.form-group{margin-bottom:1.25rem}.form-group input,.form-group textarea{border:2px solid var(--border);font-size:1rem;padding:.75rem 1rem;width:100%}.form-group textarea{min-height:80px}.type-selector{grid-gap:.5rem;gap:.5rem;grid-template-columns:repeat(4,1fr)}.type-option{background:#0000;border-radius:8px;color:var(--text);font-family:inherit;padding:.625rem .5rem}.type-option:hover{border-color:var(--type-color)}.type-option.selected{border-color:#0000;color:#fff}.type-label{font-size:.8125rem}.modal-actions{align-items:center;border-top:1px solid var(--border);display:flex;justify-content:space-between;margin-top:1.5rem;padding-top:1.5rem}.modal-actions-right{display:flex;gap:.75rem}.btn-cancel,.btn-delete,.btn-save{border-radius:8px;cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel,.btn-save{border:none}.btn-save{background:var(--primary);color:#0d0d0d}.btn-save:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.btn-cancel:disabled,.btn-delete:disabled,.btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}.btn-delete{background:#0000;border:2px solid #dc2626;color:#dc2626}.btn-delete:hover{background:#dc2626;color:#fff}.recommended-pace-hint{align-items:center;background:#ffd7001a;border-radius:6px;display:flex;font-size:.8125rem;gap:.5rem;margin-top:.5rem;padding:.5rem .75rem}.recommended-pace-hint .hint-label{color:var(--text-light);font-weight:500}.recommended-pace-hint .hint-value{color:var(--primary);flex:1 1;font-weight:700}.recommended-pace-hint .btn-use-pace{background:var(--primary);border:none;border-radius:4px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:.25rem .75rem;transition:all .2s}.recommended-pace-hint .btn-use-pace:hover{box-shadow:0 2px 8px #ffd70066;transform:translateY(-1px)}@media (max-width:640px){.workout-modal .pace-zones-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:480px){.workout-modal{margin:.5rem;max-height:calc(100vh - 1rem)}.modal-body,.modal-header{padding:1.25rem}.type-selector{grid-template-columns:repeat(3,1fr)}.workout-modal .pace-zones-grid{grid-template-columns:repeat(2,1fr)}.modal-actions{flex-direction:column;gap:.75rem}.btn-delete{order:1;width:100%}.modal-actions-right{order:0;width:100%}.btn-cancel,.btn-save{flex:1 1}}.workout-importer-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.workout-importer{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:600px;overflow-y:auto;position:relative;width:100%}.workout-importer .modal-close{align-items:center;background:#ffffff1a;border:none;border-radius:50%;color:var(--text-light);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:all .2s;width:32px;z-index:10}.workout-importer .modal-close:hover{background:#fff3;color:var(--text)}.importer-header{border-bottom:1px solid var(--border);padding:1.5rem}.importer-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .25rem}.importer-header p{color:var(--text-light);font-size:.875rem;margin:0}.importer-body{padding:1.5rem}.importer-error{background:#dc262626;border-radius:8px;color:#f87171;font-size:.875rem;padding:.75rem 1rem}.importer-error,.workout-importer .form-group{margin-bottom:1rem}.workout-importer .form-group label{color:var(--text);display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.workout-importer .form-group input[type=date]{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9375rem;padding:.75rem;width:100%}.workout-importer .form-group input[type=date]:focus{border-color:var(--primary);outline:none}.workout-importer .json-input{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:.8125rem;min-height:200px;padding:.75rem;resize:vertical;width:100%}.workout-importer .json-input:focus{border-color:var(--primary);outline:none}.workout-importer .json-input::placeholder{color:var(--text-light);opacity:.5}.btn-parse{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-bottom:1rem;padding:.75rem;transition:all .2s;width:100%}.btn-parse:hover{background:#ffd7001a;border-color:var(--primary)}.workout-preview{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1rem;padding:1rem}.workout-preview h3{color:var(--text-light);font-size:.75rem;letter-spacing:.05em;margin:0 0 .75rem;text-transform:uppercase}.preview-name{color:var(--text);font-size:1.125rem;font-weight:700;margin-bottom:.25rem}.preview-description{color:var(--text-light);font-size:.875rem;margin-bottom:.75rem}.preview-steps h4{color:var(--text);font-size:.8125rem;font-weight:600;margin:0 0 .5rem}.preview-steps ul{margin:0;padding-left:1.25rem}.preview-steps li{color:var(--text);font-size:.875rem;line-height:1.4;margin-bottom:.25rem}.importer-actions{display:flex;gap:.75rem;margin-bottom:1.5rem}.importer-actions .btn-cancel{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem;transition:all .2s}.importer-actions .btn-cancel:hover{background:var(--bg-card-hover)}.importer-actions .btn-import{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem;transition:all .2s}.importer-actions .btn-import:hover:not(:disabled){box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.importer-actions .btn-import:disabled{cursor:not-allowed;opacity:.5}.format-help{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1rem}.format-help h4{color:var(--text-light);letter-spacing:.05em;text-transform:uppercase}.format-help h4,.format-help pre{font-size:.75rem;margin:0 0 .75rem}.format-help pre{background:#0000004d;border-radius:8px;color:var(--text);font-family:Monaco,Menlo,Ubuntu Mono,monospace;overflow-x:auto;padding:.75rem}.format-notes{color:var(--text-light);font-size:.75rem}.format-notes p{margin:0 0 .25rem}.format-notes strong{color:var(--text)}@media (max-width:480px){.workout-importer{border-radius:0;max-height:100vh}.importer-body,.importer-header{padding:1rem}.importer-actions{flex-direction:column}}.calendar-view{background:var(--bg-card);border-radius:20px;box-shadow:0 4px 20px #0000004d;padding:2rem}.calendar-header{align-items:center;border-bottom:2px solid var(--border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.month-year{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0}.btn-create-plan{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;padding:.625rem 1.25rem;transition:all .2s}.btn-create-plan:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.calendar-header-actions{align-items:center;display:flex;gap:.75rem}.btn-create-workout{align-items:center;background:var(--primary);border:none;border-radius:50%;color:#0d0d0d;cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.btn-create-workout:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.btn-create-workout svg{stroke:#0d0d0d}.btn-import-workout{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;color:var(--text);cursor:pointer;display:flex;height:40px;justify-content:center;transition:all .2s;width:40px}.btn-import-workout:hover{background:#ffd7001a;border-color:var(--primary);color:var(--primary)}.btn-import-workout svg{stroke:currentColor}.calendar-body{align-items:center;display:flex;gap:.5rem}.calendar-content{flex:1 1}.nav-arrow{background:none;border:none;color:var(--primary);cursor:pointer;font-size:2rem;font-weight:900;padding:1rem .75rem;text-shadow:0 0 2px var(--primary);transition:opacity .2s}.nav-arrow:hover{opacity:.7}.calendar-weekdays{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr);margin-bottom:.5rem}.weekday{color:var(--text-light);font-size:.875rem;font-weight:600;padding:.5rem;text-align:center}.calendar-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.calendar-day{aspect-ratio:1;background:var(--bg-surface);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;min-height:80px;overflow:hidden;padding:.5rem;position:relative;transition:all .2s}.calendar-day:hover{background:var(--bg-card-hover);transform:translateY(-2px)}.calendar-day:not(.has-workout):hover:after{align-items:center;background:var(--primary);border-radius:50%;bottom:8px;color:#0d0d0d;content:"+";display:flex;font-size:1rem;font-weight:700;height:20px;justify-content:center;position:absolute;right:8px;width:20px}.calendar-day.other-month{opacity:.4}.calendar-day.today{background:#ffd70026;border:2px solid var(--primary)}.calendar-day.race-day{background:linear-gradient(135deg,#ffd7004d,#ffed4a33)}.calendar-day.has-workout{cursor:pointer}.calendar-day.drag-over{background:#ffd7004d;border:2px dashed var(--primary);transform:scale(1.02)}.calendar-day.dragging{opacity:.5}.day-number{color:var(--text);font-size:.875rem;font-weight:600}.calendar-day.today .day-number{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;display:flex;height:24px;justify-content:center;width:24px}.workout-indicator{align-items:center;cursor:grab;display:flex;flex-direction:row;gap:4px}.workout-indicator:first-of-type{margin-top:auto}.workout-indicator+.workout-indicator{margin-top:2px}.workout-indicator:active{cursor:grabbing}.workout-indicator:hover{opacity:.85}.workout-badge{border-radius:4px;color:#fff;font-size:.75rem;font-weight:700;padding:2px 6px;text-align:center;width:-webkit-fit-content;width:fit-content}.workout-distance{color:var(--text-light);font-size:.7rem;font-weight:500}.race-badge{background:var(--primary);border-radius:4px;color:#0d0d0d;font-size:.625rem;font-weight:700;padding:.1875rem .375rem;position:absolute;right:4px;text-transform:uppercase;top:4px}.calendar-legend{border-top:2px solid var(--border);margin-top:1.5rem;padding-top:1.5rem}.legend-title{color:var(--text);font-size:.875rem;font-weight:600;margin-bottom:.75rem}.legend-items{display:flex;flex-wrap:wrap;gap:1rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-color{border-radius:4px;height:16px;width:16px}.legend-label{color:var(--text-light);font-size:.8125rem}.workout-popup-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.workout-popup{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-width:400px;overflow:hidden;width:100%}.popup-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:all .2s;width:32px}.popup-close:hover{background:#ffffff4d}.popup-header{color:#fff;padding:1.5rem;position:relative}.popup-type{display:block;font-family:Archivo Black,sans-serif;font-size:1.5rem;margin-bottom:.25rem}.popup-date{font-size:.9375rem;opacity:.9}.popup-body{padding:1.5rem}.popup-stat{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:.75rem 0}.popup-stat:last-child{border-bottom:none}.stat-label{color:var(--text-light);font-size:.875rem;font-weight:500}.stat-value{color:var(--text);font-size:1rem;font-weight:600}.popup-description{padding-top:.75rem}.popup-description .stat-label{display:block;margin-bottom:.5rem}.popup-description p{color:var(--text);font-size:.9375rem;line-height:1.6;margin:0}.popup-steps{border-top:1px solid var(--border);margin-top:.75rem;padding-top:.75rem}.popup-steps .stat-label{display:block;margin-bottom:.5rem}.step-list-display{display:flex;flex-direction:column;gap:.375rem}.step-display-item{align-items:center;background:var(--bg-surface);border-radius:6px;display:flex;font-size:.8125rem;gap:.5rem;padding:.5rem .75rem}.step-badge{background:#718096;border-radius:4px;color:#fff;font-size:.6875rem;font-weight:600;padding:.125rem .5rem;text-transform:uppercase}.step-badge--warmup{background:#48bb78}.step-badge--active{background:#4299e1}.step-badge--interval{background:#f56565}.step-badge--recovery{background:#9f7aea}.step-badge--cooldown{background:#38b2ac}.step-badge--rest{background:#718096}.step-duration{color:var(--text);font-weight:500}.step-pace{background:var(--bg-card);border-radius:4px;color:var(--text-light);font-size:.6875rem;font-weight:600;padding:.125rem .375rem}.step-pace--easy{color:#48bb78}.step-pace--marathon{color:#38b2ac}.step-pace--threshold{color:#ed8936}.step-pace--interval{color:#f56565}.step-pace--repetition{color:#9f7aea}.popup-stat.recommended-pace{background:#ffd70014;border-radius:8px;margin:.5rem 0;padding:.75rem}.popup-stat.recommended-pace .stat-label{color:var(--primary);font-size:.75rem;letter-spacing:.5px;text-transform:uppercase}.popup-stat.recommended-pace .pace-highlight{color:var(--primary);font-weight:700}.popup-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;margin-top:1.25rem;padding-top:1rem}.popup-btn{border-radius:8px;cursor:pointer;flex:1 1;font-family:inherit;font-size:.875rem;font-weight:600;padding:.75rem 1rem;transition:all .2s}.popup-btn-edit{background:var(--primary);border:none;color:#0d0d0d}.popup-btn-edit:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.popup-btn-delete{background:#0000;border:2px solid #dc2626;color:#dc2626}.popup-btn-delete:hover{background:#dc2626;color:#fff}@media (max-width:768px){.calendar-view{padding:1rem}.month-year{font-size:1.125rem}.btn-create-plan{font-size:.75rem;padding:.5rem 1rem}.nav-arrow{font-size:1.25rem;padding:.5rem .25rem}.weekday{font-size:.75rem;padding:.25rem}.calendar-day{min-height:60px;padding:.25rem}.day-number{font-size:.75rem}.workout-badge{padding:1px 4px}.workout-badge,.workout-distance{font-size:.625rem}.legend-items{gap:.5rem}.legend-item{font-size:.75rem}.legend-color{height:12px;width:12px}}@media (max-width:480px){.calendar-header{align-items:flex-start;flex-direction:column;gap:.75rem}.month-year,.nav-arrow{font-size:1rem}.nav-arrow{padding:.25rem}.calendar-day{aspect-ratio:auto;min-height:50px}.workout-distance{display:none}}.create-plan-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.create-plan-modal{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:520px;overflow-y:auto;position:relative;width:100%}.create-plan-modal .modal-close{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:50%;color:var(--text-light);cursor:pointer;display:flex;font-size:1.25rem;height:32px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:all .2s;width:32px;z-index:10}.create-plan-modal .modal-close:hover{background:var(--bg-card-hover);color:var(--text)}.create-plan-modal .modal-header{padding:1.5rem 1.5rem 0}.create-plan-modal .modal-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.create-plan-modal .modal-header p{color:var(--text-light);font-size:.9375rem;margin:0}.create-plan-modal .modal-body{padding:1.5rem}.create-plan-modal .modal-error{background:#dc262626;border-radius:8px;color:#f87171;font-size:.875rem;margin-bottom:1rem;padding:.75rem 1rem}.create-plan-modal .form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.create-plan-modal .form-group{display:flex;flex-direction:column;margin-bottom:1rem}.create-plan-modal .checkbox-group{margin-bottom:1rem}.create-plan-modal .checkbox-label{align-items:center;color:var(--text);cursor:pointer;display:flex;font-size:.9375rem;font-weight:600;gap:.75rem}.create-plan-modal .checkbox-label input[type=checkbox]{accent-color:var(--primary);cursor:pointer;height:20px;width:20px}.create-plan-modal .checkbox-label span{margin-bottom:0}.create-plan-modal .form-group label{color:var(--text);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.create-plan-modal .form-group input,.create-plan-modal .form-group select{background:var(--bg-surface);border:2px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s}.create-plan-modal .form-group input:focus,.create-plan-modal .form-group select:focus{border-color:var(--primary);outline:none}.create-plan-modal .form-group input[type=date]{color-scheme:dark}.create-plan-modal .form-group input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7}.create-plan-modal .form-group input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.create-plan-modal .form-hint{color:var(--text-light);font-size:.75rem;margin-top:.25rem}.create-plan-modal .modal-actions{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem}.create-plan-modal .btn-cancel,.create-plan-modal .btn-save{border-radius:8px;cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.create-plan-modal .btn-cancel{background:var(--bg-surface);border:none;color:var(--text)}.create-plan-modal .btn-cancel:hover{background:var(--bg-card-hover)}.create-plan-modal .btn-save{background:var(--primary);border:none;color:#0d0d0d}.create-plan-modal .btn-save:hover:not(:disabled){box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}.create-plan-modal .btn-cancel:disabled,.create-plan-modal .btn-save:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:520px){.create-plan-modal .form-row{gap:0;grid-template-columns:1fr}.create-plan-modal .form-group{margin-bottom:1rem}.create-plan-modal .modal-actions{flex-direction:column}.create-plan-modal .btn-cancel,.create-plan-modal .btn-save{text-align:center;width:100%}}.workout-builder-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.workout-builder{background:var(--bg-card);border-radius:16px;box-shadow:0 8px 32px #0006;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.workout-builder-header{align-items:center;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:10}.workout-builder-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.workout-builder-date{color:var(--text-light);flex:1 1;font-size:.875rem;font-weight:500;text-align:center}.workout-builder-header .close-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:1.5rem;line-height:1;padding:.25rem .5rem;transition:color .2s}.workout-builder-header .close-btn:hover{color:var(--text)}.workout-builder form{display:flex;flex-direction:column;gap:1.25rem;padding:1.5rem}.loading-paces{color:var(--text-light);padding:3rem;text-align:center}.pace-zones-display{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;padding:1rem}.pace-zones-display h4{align-items:center;color:var(--text);display:flex;font-size:.875rem;gap:.5rem;margin:0 0 .75rem}.vdot-badge{background:var(--primary);border-radius:4px;color:#0d0d0d;font-size:.75rem;font-weight:700;padding:.125rem .5rem}.pace-zones-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(5,1fr)}.pace-zone{align-items:center;border-left:3px solid;border-radius:8px;display:flex;flex-direction:column;padding:.5rem}.pace-zone.easy{background:#48bb781a;border-left-color:#48bb78}.pace-zone.marathon{background:#38b2ac1a;border-left-color:#38b2ac}.pace-zone.threshold{background:#ed89361a;border-left-color:#ed8936}.pace-zone.interval{background:#f565651a;border-left-color:#f56565}.pace-zone.repetition{background:#9f7aea1a;border-left-color:#9f7aea}.zone-label{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.zone-pace{color:var(--text);font-size:.75rem;font-weight:600;margin-top:.125rem}.steps-section h4,.templates-section h4{color:var(--text);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.steps-section{margin-top:.5rem}.templates-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr)}.template-btn{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:500;padding:.75rem;transition:all .2s}.template-btn:hover{background:#ffd7001a;border-color:var(--primary)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text)}.form-group input,.form-group textarea{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:.9375rem;padding:.75rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-light)}.schedule-group{position:relative}.schedule-hint{color:var(--text-light);font-size:.75rem}.error-message{background:#dc26261a;border:1px solid #dc26264d;border-radius:8px;color:#dc2626}.error-message,.success-message{font-size:.875rem;padding:.75rem 1rem}.success-message{background:#48bb781a;border:1px solid #48bb784d;border-radius:8px;color:#48bb78}.form-actions{display:flex;gap:1rem;padding-top:.5rem}.btn-secondary{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);cursor:pointer;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;padding:.875rem;transition:all .2s}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover)}.btn-primary{align-items:center;background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem;transition:all .2s}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.btn-primary:disabled,.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-primary .spinner{animation:spin .8s linear infinite;border:2px solid #0003;border-radius:50%;border-top-color:#0d0d0d;height:16px;width:16px}.btn-garmin{background:#007aff;color:#fff}.btn-garmin:hover:not(:disabled){background:#0062cc;box-shadow:0 4px 12px #007aff66}.btn-success{align-items:center;background:#28a745;border:none;border-radius:8px;color:#fff;display:flex;flex:1 1;font-family:inherit;font-size:.9375rem;font-weight:600;gap:.5rem;justify-content:center;opacity:.8;padding:.875rem}.garmin-required-hint{color:var(--text-light);font-size:.8125rem;margin:0;text-align:center}@media (max-width:640px){.workout-builder{border-radius:0;max-height:100vh}.pace-zones-grid{grid-template-columns:repeat(3,1fr)}.pace-zones-grid .pace-zone:nth-child(4),.pace-zones-grid .pace-zone:nth-child(5){grid-column:span 1}.templates-grid{grid-template-columns:1fr}}@media (max-width:480px){.workout-builder form,.workout-builder-header{padding:1rem}.pace-zones-grid{grid-template-columns:repeat(2,1fr)}.form-actions{flex-direction:column}}.training-plan-view{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.training-plan-container{margin:0 auto;max-width:1000px}.plan-main-column,.training-plan-layout{display:flex;flex-direction:column}.plan-main-column{gap:1.5rem}.plan-overview-header{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;color:var(--text);padding:1.5rem 2rem}.plan-overview-header h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.75rem;margin:0 0 1rem}.plan-progress-bar{align-items:center;display:flex;gap:1rem}.progress-track{background:#fff3;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-track .progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s ease}.progress-label{color:#ffffffe6;font-size:.875rem;white-space:nowrap}.week-summary-card{border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.25rem 1.5rem}.week-summary-card,.week-summary-card.retest{background:var(--bg-card)}.week-summary-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.week-summary-info{align-items:center;display:flex;gap:.75rem}.week-summary-info h3{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .25rem}.week-summary-title-row{align-items:center;display:flex;gap:.75rem}.btn-current-week{background:var(--bg-surface);border:none;border-radius:12px;color:var(--primary);cursor:pointer;font-family:inherit;font-size:.6875rem;font-weight:600;padding:.25rem .625rem;transition:all .2s}.btn-current-week:hover{background:var(--primary);color:#0d0d0d}.week-summary-phase{color:var(--text-light);font-size:.8125rem;font-weight:500}.week-summary-dates{color:var(--text-light);display:block;font-size:.75rem;margin-top:.25rem}.week-summary-stats{align-items:center;display:flex;gap:1.25rem}.unit-toggle-group{background:var(--bg-surface);border:1px solid var(--border);border-radius:6px;display:flex;overflow:hidden}.unit-toggle-btn{background:#0000;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:.25rem .625rem;text-transform:uppercase;transition:all .2s}.unit-toggle-btn:first-child{border-right:1px solid var(--border)}.unit-toggle-btn:hover:not(.active){background:var(--bg-card-hover);color:var(--text)}.unit-toggle-btn.active{background:var(--primary);color:#0d0d0d}.summary-stat{text-align:center}.summary-stat-value{color:var(--primary);display:block;font-family:Archivo Black,sans-serif;font-size:1.5rem;line-height:1}.summary-stat-label{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.retest-badge-small{background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:12px;color:#fff;font-size:.6875rem;font-weight:700;padding:.25rem .625rem}.week-navigation{align-items:center;border-bottom:1px solid var(--border);display:flex;gap:4px;margin-bottom:1rem;padding-bottom:.75rem;width:100%}.week-nav-pill{align-items:center;background:var(--bg-surface);border:none;border-radius:6px;color:var(--text-light);cursor:pointer;display:flex;flex:1 1;font-family:inherit;font-size:.6875rem;font-weight:600;height:28px;justify-content:center;margin:0 2px;min-width:0;padding:0;transition:all .2s}.week-nav-pill:hover{background:var(--bg-card-hover);color:var(--text)}.week-nav-pill.active{background:var(--primary);color:#0d0d0d}.week-nav-pill.current:not(.active){background:#ffd7001a;border:2px solid var(--primary)}.week-workout-row{display:flex;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem;width:100%}.workout-day-card{align-items:center;background:var(--bg-surface);border-radius:10px;display:flex;flex:1 1;flex-direction:column;gap:.375rem;min-width:0;padding:.75rem .5rem;transition:all .2s}.workout-day-card:hover{background:var(--bg-card-hover)}.workout-day-card.today{background:#ffd70026;border:2px solid var(--primary)}.card-day{color:var(--text-light);font-size:.6875rem;font-weight:600;text-transform:uppercase}.workout-day-card.today .card-day{color:var(--secondary)}.card-type{border-radius:4px;color:#fff;font-size:.6875rem;font-weight:700;padding:.125rem .5rem}.card-distance{color:var(--text);font-size:.75rem;font-weight:600}.card-pace-info{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.25rem;margin-top:.25rem;padding-top:.375rem;width:100%}.pace-row{align-items:center;display:flex;flex-wrap:wrap;font-size:.625rem;gap:.375rem;justify-content:center}.pace-label{color:var(--text-light);font-weight:500;min-width:35px;text-transform:uppercase}.pace-value{color:var(--primary);font-weight:600}.pace-value.secondary{color:var(--text-light);opacity:.7}.week-summary-toggle{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;font-family:inherit;justify-content:space-between;padding:0;text-align:left;width:100%}.week-summary-toggle-left{align-items:center;display:flex;gap:.75rem}.week-summary-toggle-left h3{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0}.week-toggle-arrow{color:var(--text-light);font-size:.75rem}.week-summary-phase-inline{color:var(--text-light);font-size:.8125rem;font-weight:500}.week-summary-toggle-right{align-items:center;display:flex;gap:.75rem}.week-summary-stat-inline{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1rem}.week-summary-content{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.week-summary-focus{color:var(--text);font-size:.8125rem;line-height:1.4;margin:0}.btn-retest-compact{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:700;margin-top:.75rem;padding:.5rem 1rem;transition:all .2s}.btn-retest-compact:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-1px)}@media (max-width:768px){.training-plan-view{padding:1rem}.plan-overview-header{padding:1.25rem 1.5rem}.plan-overview-header h1{font-size:1.5rem}.week-summary-header{align-items:flex-start;flex-direction:column;gap:.75rem}.week-summary-stats{align-self:flex-start}.workout-day-card{padding:.5rem .375rem}.pace-row{font-size:.5625rem}}@media (max-width:480px){.week-summary-info h3{font-size:1.125rem}.summary-stat-value{font-size:1.25rem}.week-nav-pill{font-size:.5625rem;height:24px}}.settings-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-modal{animation:slideUp .3s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.settings-header{align-items:center;border-bottom:2px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem 2rem}.settings-header h2{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0}.settings-modal .close-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1.75rem;line-height:1;padding:0;transition:all .2s}.settings-modal .close-btn:hover{color:var(--primary)}.settings-tabs{border-bottom:2px solid var(--border);display:flex;padding:0 2rem}.tab-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:1rem 1.5rem;position:relative;transition:color .2s}.tab-btn.active,.tab-btn:hover{color:var(--text)}.tab-btn.active:after{background:var(--primary);border-radius:3px 3px 0 0;bottom:-2px;content:"";height:3px;left:0;position:absolute;right:0}.settings-form{padding:2rem}.tab-content{min-height:300px}.settings-form .form-group{margin-bottom:1.5rem}.settings-form label{color:var(--text-light);display:block;font-size:.9375rem;font-weight:600;margin-bottom:.5rem}.settings-form input,.settings-form select{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;box-sizing:border-box;color:var(--text);font-family:inherit;font-size:1rem;padding:.875rem;transition:all .2s;width:100%}.settings-form input::placeholder{color:var(--text-light)}.settings-form input:focus,.settings-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.settings-form select option{background:var(--bg-surface);color:var(--text)}.settings-form small{color:var(--text-light);display:block;font-size:.8125rem;margin-top:.375rem}.settings-form .form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.settings-form .form-row .form-group{margin-bottom:1.5rem}.profile-image-section{align-items:center;border-bottom:2px solid var(--border);display:flex;flex-direction:column;margin-bottom:2rem;padding-bottom:1.5rem}.profile-image-preview{align-items:center;background:var(--bg-surface);border:3px solid var(--border);border-radius:50%;cursor:pointer;display:flex;height:120px;justify-content:center;overflow:hidden;transition:all .2s;width:120px}.profile-image-preview:hover{border-color:var(--primary);transform:scale(1.02)}.profile-image-preview img{height:100%;object-fit:cover;width:100%}.profile-image-placeholder{align-items:center;color:var(--text-light);display:flex;flex-direction:column;justify-content:center}.profile-image-placeholder span:first-child{font-size:2rem;margin-bottom:.25rem}.profile-image-placeholder .placeholder-text{font-size:.75rem;font-weight:600}.change-photo-btn{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text-light);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:600;margin-top:.75rem;padding:.5rem 1rem;transition:all .2s}.change-photo-btn:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--text-light);color:var(--text)}.change-photo-btn:disabled{cursor:not-allowed;opacity:.6}.profile-image-preview.uploading{cursor:not-allowed;opacity:.7}.upload-spinner{animation:spin 1s linear infinite;font-size:2rem;margin-bottom:.25rem}.height-imperial{align-items:center;display:flex;gap:.5rem}.height-imperial input{text-align:center;width:70px}.height-imperial .height-unit{color:var(--text-light);font-size:.875rem;font-weight:500}.race-time-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.training-level-options{display:flex;flex-direction:column;gap:.75rem}.training-level-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;padding:1rem;transition:all .2s}.training-level-option:hover{background:var(--bg-card-hover);border-color:var(--text-light)}.training-level-option.selected{background:#ffd7001a;border-color:var(--primary)}.training-level-option input[type=radio]{accent-color:var(--primary);cursor:pointer;height:20px;margin-right:1rem;width:20px}.level-content{display:flex;flex-direction:column}.level-name{color:var(--text);font-size:1rem;font-weight:600}.level-desc{color:var(--text-light);font-size:.8125rem;margin-top:.125rem}.pb-hint{margin-bottom:.75rem!important;margin-top:0!important}.pb-grid{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.pb-input-group{display:flex;flex-direction:column;gap:.25rem}.pb-input-group label{color:var(--text-light);font-size:.75rem;font-weight:600;margin-bottom:0}.pb-input-group input{font-size:.9375rem;padding:.625rem .75rem}.settings-form input[type=date]{background:var(--bg-surface);color:var(--text);color-scheme:dark}.settings-form input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7}.settings-form input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.settings-form .datepicker-input{background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;color:var(--text);cursor:pointer;font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s;width:100%}.settings-form .datepicker-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #ffd70026;outline:none}.settings-form .react-datepicker-wrapper{width:100%}.settings-form .react-datepicker__input-container{align-items:center;display:flex;position:relative}.settings-form .react-datepicker__calendar-icon{fill:var(--text-light);height:20px;pointer-events:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px}.settings-form .react-datepicker__input-container .datepicker-input{padding-right:40px}.privacy-info{background:var(--bg-surface);border:1px solid var(--border);border-radius:10px;display:flex;gap:1rem;margin-top:1.5rem;padding:1rem}.privacy-info__icon{flex-shrink:0}.privacy-info__icon svg{color:var(--primary);height:24px;width:24px}.privacy-info__text{display:flex;flex-direction:column;gap:.25rem}.privacy-info__text strong{color:var(--text);font-size:.9375rem}.privacy-info__text p{color:var(--text-light);font-size:.8125rem;line-height:1.4;margin:0}.settings-error{background:#ef44441a;border-left:4px solid #ef4444;color:#f87171}.settings-error,.settings-success{border-radius:10px;margin-bottom:1.5rem;padding:1rem}.settings-success{background:#48bb781a;border-left:4px solid #48bb78;color:#68d391}.settings-footer{border-top:2px solid var(--border);display:flex;gap:1rem;margin-top:1rem;padding-top:1rem}.settings-footer .btn-primary,.settings-footer .btn-secondary{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-family:inherit;font-size:1rem;font-weight:600;padding:.875rem 1.5rem;transition:all .2s}.settings-footer .btn-primary{background:var(--primary);color:#0d0d0d}.settings-footer .btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #ffd70066;transform:translateY(-2px)}.settings-footer .btn-primary:disabled{cursor:not-allowed;opacity:.6}.settings-footer .btn-secondary{background:var(--bg-surface);border:1px solid var(--border);color:var(--text-light)}.settings-footer .btn-secondary:hover{background:var(--bg-card-hover);color:var(--text)}@media (max-width:768px){.settings-modal{margin:.5rem;max-height:95vh;max-width:100%}.settings-header{padding:1rem 1.5rem}.settings-header h2{font-size:1.25rem}.settings-tabs{padding:0 1rem}.tab-btn{font-size:.9375rem;padding:.75rem 1rem}.settings-form{padding:1.5rem}.pb-grid,.race-time-row,.settings-form .form-row{grid-template-columns:1fr}.height-imperial{flex-wrap:wrap}.height-imperial input{width:60px}.profile-image-preview{height:100px;width:100px}.settings-footer{flex-direction:column-reverse}.settings-footer .btn-primary,.settings-footer .btn-secondary{width:100%}}.training-paces-display{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}.vdot-display{border-bottom:1px solid var(--border);justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.vdot-display,.vdot-label{align-items:center;display:flex}.vdot-label{color:var(--text);font-size:.9375rem;font-weight:600}.vdot-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.75rem}.paces-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(5,1fr)}.pace-item{align-items:center;border-radius:8px;display:flex;flex-direction:column;padding:.75rem .5rem;text-align:center}.pace-item.easy{background:#48bb7826}.pace-item.marathon{background:#38b2ac26}.pace-item.threshold{background:#ed893626}.pace-item.interval{background:#f5656526}.pace-item.repetition{background:#9f7aea26}.pace-zone{color:var(--text-light);font-size:.6875rem;font-weight:600;letter-spacing:.5px;margin-bottom:.25rem;text-transform:uppercase}.pace-value{color:var(--text);font-size:.875rem;font-weight:700}.pace-item.easy .pace-value{color:#48bb78}.pace-item.marathon .pace-value{color:#38b2ac}.pace-item.threshold .pace-value{color:#ed8936}.pace-item.interval .pace-value{color:#f56565}.pace-item.repetition .pace-value{color:#9f7aea}.pace-unit{font-size:.6875rem;margin-top:.125rem}.pace-speed,.pace-unit{color:var(--text-light)}.pace-speed{font-size:.625rem;margin-top:.25rem;opacity:.8}.vdot-changed-badge{background:var(--primary);border-radius:10px;color:#0d0d0d;display:inline-block;font-size:.625rem;font-weight:700;letter-spacing:.5px;margin-left:.5rem;padding:.125rem .5rem;text-transform:uppercase}.training-paces-display.preview{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}@media (max-width:768px){.paces-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:480px){.paces-grid{grid-template-columns:repeat(2,1fr)}.vdot-display{flex-direction:column;gap:.5rem;text-align:center}}.community-dropdown{position:relative}.community-trigger{align-items:center;display:flex;gap:.375rem}.dropdown-arrow{height:16px;transition:transform .2s ease;width:16px}.dropdown-arrow.open{transform:rotate(180deg)}.community-menu{animation:slideDown .15s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 30px #0006;left:50%;min-width:220px;padding:.5rem;position:absolute;top:calc(100% + 8px);transform:translateX(-50%);z-index:100}@keyframes slideDown{0%{opacity:0;transform:translateX(-50%) translateY(-8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.community-item{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;text-align:left;transition:background .15s ease;width:100%}.community-item:hover{background:var(--bg-surface)}.community-item:hover .community-item__title{color:var(--primary)}.community-item.active{background:#ffd70026}.community-item__icon{flex-shrink:0;font-size:1.25rem}.community-item__content{display:flex;flex-direction:column;gap:.125rem}.community-item__title{color:var(--secondary);font-size:.9375rem;font-weight:600}.community-item__desc{color:var(--text-light);font-size:.75rem}@media (max-width:768px){.community-menu{left:auto;right:-1rem;transform:none}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}}.global-search{flex:0 0 auto;margin:0 .5rem;position:relative}.global-search--expanded{flex:1 1;margin:0 1.5rem;max-width:450px}.global-search__trigger{align-items:center;background:#0000;border:none;border-radius:8px;cursor:pointer;display:flex;height:40px;justify-content:center;transition:background-color .2s;width:40px}.global-search__trigger:hover{background:var(--bg-surface)}.global-search__trigger svg{color:var(--text-light);height:20px;transition:color .2s;width:20px}.global-search__trigger:hover svg{color:var(--primary)}.global-search__input-wrapper{align-items:center;display:flex;position:relative}.global-search__icon{color:var(--text-light);height:18px;left:.75rem;pointer-events:none;position:absolute;width:18px}.global-search__input{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.875rem;outline:none;padding:.5rem 2.5rem;transition:border-color .2s,background-color .2s;width:100%}.global-search__input:focus{background:var(--bg-card);border-color:var(--primary)}.global-search__input::placeholder{color:var(--text-light)}.global-search__spinner{animation:search-spin .8s linear infinite;border:2px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:16px;position:absolute;right:.75rem;width:16px}@keyframes search-spin{to{transform:rotate(1turn)}}.global-search__dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 8px 32px #0000004d;left:0;max-height:400px;min-width:350px;overflow-y:auto;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.global-search__no-results{color:var(--text-light);font-size:.875rem;padding:1.5rem;text-align:center}.global-search__section{padding:.5rem 0}.global-search__section:not(:last-child){border-bottom:1px solid var(--border)}.global-search__section-header{color:var(--text-light);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.5rem 1rem;text-transform:uppercase}.global-search__result{align-items:center;background:none;border:none;cursor:pointer;display:flex;gap:.75rem;padding:.625rem 1rem;text-align:left;transition:background-color .15s;width:100%}.global-search__result:hover{background:var(--bg-surface)}.global-search__result-avatar{align-items:center;background:var(--bg-surface);border-radius:50%;color:var(--primary);display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:36px;justify-content:center;overflow:hidden;width:36px}.global-search__result-avatar img{height:100%;object-fit:cover;width:100%}.global-search__result-icon{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:.875rem;font-weight:700;height:36px;justify-content:center;width:36px}.global-search__result-icon.club{background:#6366f126;color:#818cf8}.global-search__result-icon.group{background:#22c55e26;color:#4ade80}.global-search__result-icon.race{background:#fbbf2426;color:#fbbf24}.global-search__result-info{flex:1 1;min-width:0}.global-search__result-name{color:var(--text);font-size:.875rem;font-weight:600}.global-search__result-meta,.global-search__result-name{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.global-search__result-meta{color:var(--text-light);font-size:.75rem}.global-search__user-result{align-items:center;display:flex;gap:.5rem;justify-content:space-between;padding:.625rem 1rem;transition:background-color .15s}.global-search__user-result:hover{background:var(--bg-surface)}.global-search__user-info{align-items:center;display:flex;flex:1 1;gap:.75rem;min-width:0}.global-search__user-actions{align-items:center;display:flex;flex-shrink:0;gap:.375rem}.global-search__action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-family:inherit;font-size:.75rem;font-weight:600;justify-content:center;transition:all .15s}.global-search__action-btn.follow{background:var(--primary);color:#0d0d0d;padding:.375rem .75rem}.global-search__action-btn.follow:hover{filter:brightness(1.1)}.global-search__action-btn.following{background:#0000;border:1px solid var(--border);color:var(--text-light);padding:.375rem .75rem}.global-search__action-btn.following:hover{border-color:#ef4444;color:#ef4444}.global-search__action-btn.message,.global-search__action-btn.profile{background:var(--bg-surface);color:var(--text-light);height:28px;width:28px}.global-search__action-btn.message:hover,.global-search__action-btn.profile:hover{background:var(--primary);color:#0d0d0d}.global-search__action-btn svg{height:14px;width:14px}.global-search__action-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.global-search{margin:0;position:static}.global-search--expanded{margin:0;max-width:none;position:static}.global-search--expanded .global-search__input-wrapper{background:var(--bg-card);border-bottom:1px solid var(--border);height:auto;left:0;padding:1rem;position:fixed;right:0;top:0;width:100%;z-index:1001}.global-search--expanded .global-search__input{padding:.75rem 2.5rem}.global-search--expanded .global-search__icon{left:1.75rem}.global-search--expanded .global-search__dropdown{border-radius:0;left:0;max-height:calc(100vh - 70px);position:fixed;right:0;top:70px}}.challenges-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.challenges-container{margin:0 auto;max-width:1200px}.challenges-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.challenges-header__left h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .25rem}.challenges-header__left p{color:var(--text-light);margin:0}.btn-create-challenge{background:var(--primary);border:none;border-radius:8px;color:#0d0d0d;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.btn-create-challenge:hover{box-shadow:0 2px 8px #ffd70066;transform:translateY(-1px)}.challenges-tabs{background:var(--bg-card);border-radius:10px;display:inline-flex;margin-bottom:1.5rem;padding:4px}.challenges-tabs .tab{background:#0000;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;font-size:.9375rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.challenges-tabs .tab:hover:not(.active){color:var(--text)}.challenges-tabs .tab.active{background:var(--primary);color:#0d0d0d}.challenges-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.challenges-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;grid-column:1/-1;padding:3rem;text-align:center}.challenges-empty p{color:var(--text-light);margin-bottom:1rem}.challenges-empty .btn-primary,.challenges-empty .btn-secondary{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.challenges-empty .btn-primary{background:var(--primary);color:#0d0d0d}.challenges-empty .btn-secondary{background:var(--bg-surface);color:var(--text)}.challenges-loading{color:var(--text-light);padding:3rem;text-align:center}.challenge-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.challenge-card__header{align-items:flex-start;display:flex;justify-content:space-between}.challenge-card__title{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.125rem;margin:0}.challenge-card__badge{border-radius:20px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.challenge-card__badge--distance{background:var(--primary);color:#0d0d0d}.challenge-card__badge--streak{background:#fef3c7;color:#92400e}.challenge-card__badge--specific{background:#dcfce7;color:#166534}.challenge-card__description{color:var(--text-light);font-size:.9375rem;line-height:1.5;margin:0}.challenge-card__meta{color:var(--text-light);display:flex;font-size:.875rem;gap:1.5rem}.challenge-card__target{align-items:baseline;display:flex;gap:.25rem}.challenge-card__target-value{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem}.challenge-card__target-unit{color:var(--text-light);font-size:.875rem}.challenge-card__progress{display:flex;flex-direction:column;gap:.5rem}.challenge-card__progress-bar{background:var(--bg-surface);border-radius:4px;height:8px;overflow:hidden}.challenge-card__progress-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .3s ease}.challenge-card__progress-text{color:var(--text-light);display:flex;font-size:.75rem;justify-content:space-between}.challenge-card__footer{border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.5rem;margin-top:auto;padding-top:1rem}.challenge-card__footer-row{display:flex;gap:.75rem}.challenge-card__footer button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.625rem 1rem;transition:all .2s}.challenge-card__footer .btn-join{background:var(--bg-surface);border:1px solid var(--border);color:var(--primary)}.challenge-card__footer .btn-join:hover{background:var(--bg-card-hover);border-color:var(--primary)}.challenge-card__footer .btn-leave{background:#dc2626;color:#fff}.challenge-card__footer .btn-leave:hover{background:#b91c1c}.challenge-card__footer .btn-leaderboard{background:var(--primary);color:#0d0d0d}.challenge-card__footer .btn-leaderboard:hover{box-shadow:0 4px 12px #ffd70066}.challenge-card__footer .btn-edit{background:var(--bg-surface);border:1px solid var(--border);color:var(--primary)}.challenge-card__footer .btn-edit:hover{background:var(--bg-card-hover);border-color:var(--primary)}.challenge-card__footer .btn-delete{background:#dc2626;color:#fff}.challenge-card__footer .btn-delete:hover{background:#b91c1c}.challenge-card__participants{color:var(--text-light);font-size:.75rem}.monthly-challenges-section{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;margin-bottom:2rem;padding:1.5rem}.monthly-header{margin-bottom:1.25rem}.monthly-header h2{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0 0 .25rem}.monthly-subtitle{color:var(--text-light);font-size:.875rem}.monthly-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.monthly-challenge-card{align-items:center;background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;display:flex;gap:1rem;padding:1rem;transition:all .2s}.monthly-challenge-card:hover{background:var(--bg-card-hover);border-color:var(--primary)}.monthly-challenge-card.joined{background:#ffd7000d;border-color:var(--primary)}.monthly-challenge-card.completed{background:linear-gradient(135deg,#ffd70026,#ffd7000d);border-color:var(--primary)}.monthly-challenge-icon{flex-shrink:0;font-size:2rem}.monthly-challenge-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem;min-width:0}.monthly-challenge-title{color:var(--text);font-size:.9375rem;font-weight:700}.monthly-challenge-target{color:var(--text-light);font-size:.8125rem}.monthly-progress{margin-top:.5rem}.monthly-progress .progress-bar{background:var(--bg-card);border-radius:3px;height:6px;margin-bottom:.25rem;overflow:hidden}.monthly-progress .progress-fill{background:var(--primary);border-radius:3px;height:100%;transition:width .3s ease}.monthly-progress .progress-text{color:var(--text-light);font-size:.75rem}.monthly-challenge-actions{flex-shrink:0}.btn-join-small,.btn-leave-small{border:none;border-radius:8px;cursor:pointer;font-size:.8125rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.btn-join-small{background:var(--primary);color:#0d0d0d}.btn-join-small:hover{box-shadow:0 2px 8px #ffd70066}.btn-leave-small{background:#dc262626;color:#f87171}.btn-leave-small:hover{background:#dc262640}.completed-badge{background:var(--primary);border-radius:20px;color:#0d0d0d;display:inline-block;font-size:.75rem;font-weight:700;padding:.375rem .75rem}.challenges-empty__actions{display:flex;gap:.75rem;justify-content:center;margin-top:1rem}.create-challenge-modal{max-width:560px}.challenge-type-options{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr)}.type-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;padding:1rem .5rem;text-align:center;transition:all .2s}.type-option input{display:none}.type-option:hover{background:var(--bg-card-hover);border-color:var(--primary)}.type-option.selected{background:#ffd7001a;border-color:var(--primary)}.type-icon{font-size:1.5rem}.type-label{color:var(--text);font-size:.875rem;font-weight:600}.type-desc{color:var(--text-light);font-size:.75rem}.visibility-options{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}.visibility-option{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:10px;cursor:pointer;display:flex;gap:.75rem;padding:.875rem;transition:all .2s}.visibility-option input{display:none}.visibility-option:hover{background:var(--bg-card-hover);border-color:var(--primary)}.visibility-option.selected{background:#ffd7001a;border-color:var(--primary)}.visibility-icon{flex-shrink:0;font-size:1.25rem}.visibility-text{display:flex;flex-direction:column;gap:.125rem}.visibility-label{color:var(--text);font-size:.875rem;font-weight:600}.visibility-desc{color:var(--text-light);font-size:.6875rem}.form-hint{color:var(--text-light);display:block;font-size:.75rem;margin-top:.375rem}@media (max-width:768px){.challenges-page{padding:1rem}.challenges-header{align-items:stretch;flex-direction:column;gap:1rem}.btn-create-challenge{width:100%}.challenges-grid,.monthly-grid{grid-template-columns:1fr}.monthly-challenge-card{flex-wrap:wrap}.monthly-challenge-info{flex:1 1 60%}.monthly-challenge-actions{flex:0 0 auto}.challenges-empty__actions{flex-direction:column}.challenge-type-options,.visibility-options{grid-template-columns:1fr}}.clubs-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.clubs-container{margin:0 auto;max-width:1200px}.clubs-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.clubs-header__left h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .25rem}.clubs-header__left p{color:var(--text-light);margin:0}.clubs-header__actions{display:flex;gap:.75rem}.clubs-header__actions .btn-primary,.clubs-header__actions .btn-secondary{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.clubs-header__actions .btn-primary{background:var(--primary);color:#0d0d0d}.clubs-header__actions .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.clubs-header__actions .btn-secondary{background:var(--bg-card);border:1px solid var(--border);color:var(--text)}.clubs-header__actions .btn-secondary:hover{background:var(--bg-card-hover)}.clubs-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.clubs-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:4rem 2rem;text-align:center}.clubs-empty__icon{font-size:3rem;margin-bottom:1rem}.clubs-empty h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.clubs-empty p{color:var(--text-light);margin:0 0 1.5rem}.clubs-empty .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.clubs-loading{color:var(--text-light);padding:3rem;text-align:center}.club-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;cursor:pointer;display:flex;flex-direction:column;gap:1rem;padding:1.5rem;transition:transform .2s,box-shadow .2s}.club-card:hover{box-shadow:0 8px 30px #0006;transform:translateY(-4px)}.club-card__header{align-items:flex-start;display:flex;gap:.5rem;justify-content:space-between}.club-card__title-row{display:flex;flex-direction:column;gap:.375rem}.club-card__title{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.club-card__role{border-radius:20px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase;white-space:nowrap}.club-card__role--super_admin{background:var(--primary);color:#0d0d0d}.club-card__role--admin{background:#fef3c7;color:#92400e}.club-card__role--member{background:#e0e7ff;color:#3730a3}.club-card__description{color:var(--text-light);font-size:.9375rem;line-height:1.5;margin:0}.club-card__stats{display:flex;gap:1.5rem}.club-card__stat{display:flex;flex-direction:column;gap:.125rem}.club-card__stat-value{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem}.club-card__stat-label{color:var(--text-light);font-size:.75rem}.club-card__footer{border-top:1px solid var(--border);display:flex;gap:.75rem;margin-top:auto;padding-top:1rem}.club-card__footer button{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.625rem 1rem;transition:all .2s}.club-card__footer .btn-view{background:var(--primary);color:#0d0d0d}.club-card__footer .btn-leave{background:#dc262626;color:#f87171}.modal-small{max-width:400px}.join-form{padding:1rem 0}.create-club-modal{max-width:500px}.type-selector{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.type-btn{align-items:center;background:var(--bg-surface);border:2px solid var(--border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.375rem;padding:1rem;transition:all .2s}.type-btn:hover{background:var(--bg-card-hover);border-color:var(--primary)}.type-btn.active{background:#ffd7001a;border-color:var(--primary)}.type-btn .type-icon{font-size:2rem;line-height:1}.type-btn .type-label{color:var(--text);font-family:Archivo Black,sans-serif;font-size:1rem}.type-btn .type-desc{color:var(--text-light);font-size:.75rem}.type-btn.active .type-label{color:var(--primary)}.club-extended-fields{background:var(--bg-surface);border:1px solid var(--border);border-radius:12px;margin-bottom:1rem;padding:1rem}.club-extended-fields .form-group:last-child{margin-bottom:0}.club-type-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem;padding:.25rem .5rem}.club-type-badge--club{background:#ffd70026;color:var(--primary)}.club-type-badge--group{background:#6366f126;color:#818cf8}@media (max-width:768px){.clubs-page{padding:1rem}.clubs-header{flex-direction:column;gap:1rem}.clubs-header__actions{width:100%}.clubs-header__actions .btn-primary,.clubs-header__actions .btn-secondary{flex:1 1}.clubs-grid{grid-template-columns:1fr}}.races-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.races-container{margin:0 auto;max-width:1200px}.races-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:2rem}.races-header__left h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0 0 .25rem}.races-header__left p{color:var(--text-light);margin:0}.races-header__actions .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.races-header__actions .btn-primary:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.races-tabs{background:var(--bg-card);border-radius:10px;display:inline-flex;margin-bottom:1.5rem;padding:4px}.races-tabs .tab{background:#0000;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;font-size:.9375rem;font-weight:500;padding:.625rem 1.25rem;transition:all .2s}.races-tabs .tab:hover:not(.active){color:var(--text)}.races-tabs .tab.active{background:var(--primary);color:#0d0d0d}.races-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:4rem 2rem;text-align:center}.races-empty__icon{font-size:3rem;margin-bottom:1rem}.races-empty h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.races-empty p{color:var(--text-light);margin:0 0 1.5rem}.races-empty .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.races-loading{color:var(--text-light);padding:3rem;text-align:center}.goal-races-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.goal-race-card{background:var(--bg-card);border-left:6px solid var(--border);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem;position:relative}.goal-race-card.primary{border-left-color:var(--primary)}.goal-race-card.past{opacity:.7}.primary-badge{background:#fef3c7;border-radius:20px;color:#92400e;font-size:.75rem;font-weight:600;padding:.25rem .75rem;position:absolute;right:1rem;top:1rem}.goal-race-card__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.goal-race-card__header h3{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.distance-badge{background:var(--primary);border-radius:20px;color:#0d0d0d;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.goal-race-card__date{align-items:center;color:var(--text-light);display:flex;font-size:1rem;gap:.75rem;margin-bottom:.75rem}.days-until{background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;color:var(--primary);font-size:.75rem;font-weight:600;padding:.25rem .5rem}.goal-race-card__target{color:var(--text);font-size:.9375rem;margin-bottom:.5rem}.goal-race-card__notes{color:var(--text-light);font-size:.875rem;font-style:italic;margin-bottom:1rem}.goal-race-card__footer{border-top:1px solid var(--border);display:flex;gap:.75rem;padding-top:1rem}.btn-edit{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--primary);cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.btn-edit:hover{background:var(--bg-card-hover);border-color:var(--primary)}.btn-delete{background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:all .2s}.btn-delete:hover{background:#b91c1c}.results-list{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.result-card{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:1.5rem}.result-card__header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.5rem}.result-card__header h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.125rem;margin:0}.result-card__date{color:var(--text-light);font-size:.875rem;margin-bottom:.75rem}.result-card__time{align-items:center;display:flex;gap:.75rem;margin-bottom:.75rem}.time-value{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem}.position{background:#fef3c7;border-radius:4px;color:#92400e;font-size:.875rem;font-weight:600;padding:.25rem .5rem}.result-card__notes{color:var(--text-light);font-size:.875rem;font-style:italic;margin-bottom:1rem}.result-card__footer{border-top:1px solid var(--border);display:flex;gap:.75rem;padding-top:1rem}@media (max-width:768px){.races-page{padding:1rem}.races-header{flex-direction:column;gap:1rem}.races-header__actions .btn-primary{width:100%}.goal-races-list,.results-list{grid-template-columns:1fr}}.messages-page{background:linear-gradient(135deg,var(--bg) 0,var(--bg-surface) 100%);min-height:calc(100vh - 73px);padding:2rem}.messages-container{margin:0 auto;max-width:800px}.messages-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.messages-header h1{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:2rem;margin:0}.btn-new-message{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-new-message:hover{box-shadow:0 4px 12px #ffd70066;transform:translateY(-2px)}.messages-loading{color:var(--text-light);padding:3rem;text-align:center}.messages-empty{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;padding:4rem 2rem;text-align:center}.messages-empty__icon{margin-bottom:1rem}.messages-empty__icon svg{color:var(--text-light);height:64px;width:64px}.messages-empty h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.5rem;margin:0 0 .5rem}.messages-empty p{color:var(--text-light);margin:0 0 1.5rem}.messages-empty .btn-primary{background:var(--primary);border:none;border-radius:10px;color:#0d0d0d;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem}.conversations-list{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;gap:.5rem;overflow:hidden}.conversation-item{align-items:center;border-bottom:1px solid var(--border);cursor:pointer;display:flex;gap:1rem;padding:1rem 1.25rem;transition:background .2s}.conversation-item:last-child{border-bottom:none}.conversation-item:hover{background:var(--bg-surface)}.conversation-item--unread{background:#ffd7000d}.conversation-item--unread:hover{background:#ffd7001a}.conversation-item__avatar{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:48px;justify-content:center;overflow:hidden;width:48px}.conversation-item__avatar.has-image{background:var(--bg-surface)}.conversation-item__avatar img{height:100%;object-fit:cover;width:100%}.conversation-item__content{flex:1 1;min-width:0}.conversation-item__header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem}.conversation-item__name{color:var(--text);font-weight:600}.conversation-item--unread .conversation-item__name{color:var(--primary)}.conversation-item__time{color:var(--text-light);font-size:.75rem}.conversation-item__preview{align-items:center;display:flex;gap:.5rem}.conversation-item__message{color:var(--text-light);flex:1 1;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-item__message--empty{font-style:italic}.conversation-item__badge{background:var(--primary);border-radius:10px;color:#0d0d0d;font-size:.75rem;font-weight:700;min-width:20px;padding:.125rem .5rem;text-align:center}.conversation-view{background:var(--bg-card);border-radius:16px;box-shadow:0 4px 20px #0000004d;display:flex;flex-direction:column;height:calc(100vh - 73px - 4rem);overflow:hidden}.conversation-header{align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border);display:flex;gap:1rem;padding:1rem 1.25rem}.conversation-header .back-button{background:none;border:none;color:var(--primary);cursor:pointer;font-size:1rem;padding:0}.conversation-header .back-button:hover{opacity:.8}.conversation-header__avatar{align-items:center;background:var(--primary);border-radius:50%;color:#0d0d0d;display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;overflow:hidden;width:40px}.conversation-header__avatar.has-image{background:var(--bg-surface)}.conversation-header__avatar img{height:100%;object-fit:cover;width:100%}.conversation-header__name{color:var(--text);font-weight:600}.messages-thread{display:flex;flex:1 1;flex-direction:column;gap:.75rem;overflow-y:auto;padding:1rem}.messages-empty-thread{align-items:center;color:var(--text-light);display:flex;flex:1 1;justify-content:center}.message-bubble{display:flex;flex-direction:column;max-width:70%}.message-bubble--sent{align-self:flex-end}.message-bubble--received{align-self:flex-start}.message-bubble__content{word-wrap:break-word;border-radius:16px;line-height:1.4;padding:.75rem 1rem}.message-bubble--sent .message-bubble__content{background:var(--primary);border-bottom-right-radius:4px;color:#0d0d0d}.message-bubble--received .message-bubble__content{background:var(--bg-surface);border-bottom-left-radius:4px;color:var(--text)}.message-bubble__meta{display:flex;gap:.5rem;margin-top:.25rem;padding:0 .5rem}.message-bubble--sent .message-bubble__meta{justify-content:flex-end}.message-bubble__time{color:var(--text-light);font-size:.625rem}.message-bubble__read{color:var(--primary);font-size:.625rem}.message-input-form{background:var(--bg-surface);border-top:1px solid var(--border);display:flex;gap:.75rem;padding:1rem}.message-input{background:var(--bg-card);border:1px solid var(--border);border-radius:24px;color:var(--text);flex:1 1;font-family:inherit;font-size:.9375rem;padding:.75rem 1rem}.message-input:focus{border-color:var(--primary);outline:none}.message-input::placeholder{color:var(--text-light)}.btn-send{align-items:center;background:var(--primary);border:none;border-radius:50%;color:#0d0d0d;cursor:pointer;display:flex;flex-shrink:0;height:44px;justify-content:center;transition:all .2s;width:44px}.btn-send:hover:not(:disabled){transform:scale(1.05)}.btn-send:disabled{cursor:not-allowed;opacity:.5}.btn-send svg{height:20px;width:20px}.selected-user{align-items:center;background:var(--bg-surface);border-radius:8px;display:flex;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.selected-user__label{color:var(--text-light);font-size:.875rem}.selected-user__name{color:var(--primary);flex:1 1;font-weight:600}.selected-user__remove{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1.25rem;line-height:1;padding:0}.selected-user__remove:hover{color:var(--text)}.search-results{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.search-result-item{align-items:center;background:var(--bg-surface);border-radius:8px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem;transition:background .2s}.search-result-item:hover{background:var(--bg-card-hover)}.search-result-avatar{align-items:center;background:var(--border);border-radius:50%;color:var(--text);display:flex;flex-shrink:0;font-weight:600;height:40px;justify-content:center;overflow:hidden;width:40px}.search-result-avatar.has-image{background:var(--bg-surface)}.search-result-avatar img{height:100%;object-fit:cover;width:100%}.search-result-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.search-result-name{color:var(--text);font-weight:600}.search-result-email{color:var(--text-light);font-size:.8125rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-empty,.search-loading{color:var(--text-light);padding:1rem;text-align:center}@media (max-width:768px){.messages-page{padding:1rem}.messages-header{align-items:stretch;flex-direction:column;gap:1rem}.messages-header h1{font-size:1.5rem}.conversation-view{height:calc(100vh - 73px - 2rem)}.message-bubble{max-width:85%}.conversation-item{padding:.875rem 1rem}.conversation-item__avatar{height:44px;width:44px}}.App{background:var(--bg);display:flex;flex-direction:column;min-height:100vh}.app-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:16px 24px}.header-content{justify-content:space-between;margin:0 auto;max-width:1200px}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:2rem}.header-right{align-items:center;display:flex;gap:.5rem}.header-logo{color:var(--primary);font-family:Archivo Black,sans-serif;font-size:1.5rem;font-weight:700;margin:0}.header-logo-img{height:40px;width:auto}.header-nav{align-items:center;display:flex;gap:.5rem}.nav-link{background:#0000;border:none;border-radius:6px;color:#fff9;cursor:pointer;font-family:inherit;font-size:.9375rem;font-weight:500;padding:8px 16px;position:relative;transition:all .2s}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{color:var(--primary);font-weight:600}.nav-link.active:after{background:var(--primary);border-radius:2px;bottom:-4px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:20px}.header-message-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-light);cursor:pointer;display:flex;flex-shrink:0;height:40px;justify-content:center;padding:0;position:relative;transition:all .2s;width:40px}.header-message-btn:hover{border-color:var(--primary);color:var(--primary)}.header-message-btn svg{height:20px;width:20px}.message-badge{background:#dc2626;border-radius:10px;color:#fff;font-size:.625rem;font-weight:700;line-height:1.2;min-width:18px;padding:.125rem .375rem;position:absolute;right:-4px;text-align:center;top:-4px}.profile-menu-container{position:relative}.profile-avatar{align-items:center;background:linear-gradient(135deg,var(--primary) 0,#e6c300 100%);border:2px solid #fff3;border-radius:50%;color:#0d0d0d;cursor:pointer;display:flex;font-family:Archivo Black,sans-serif;font-size:1rem;font-weight:700;height:40px;justify-content:center;transition:all .2s;width:40px}.profile-avatar:hover{border-color:var(--primary);box-shadow:0 4px 12px #ffd7004d;transform:scale(1.05)}.profile-avatar.has-image{overflow:hidden;padding:0}.profile-avatar-img{height:100%;object-fit:cover;width:100%}.profile-menu-backdrop{bottom:0;left:0;position:fixed;right:0;top:0;z-index:99}.profile-menu{animation:menuSlideDown .2s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 40px #00000080;min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);z-index:100}@keyframes menuSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.profile-menu-header{background:var(--bg-surface);padding:16px}.profile-menu-email{color:var(--text-light);display:block;font-size:.875rem;word-break:break-all}.profile-menu-name{color:var(--secondary);display:block;font-size:1rem;font-weight:600;margin-top:4px}.profile-menu-divider{background:var(--border);height:1px}.profile-menu-item{align-items:center;background:none;border:none;color:var(--text);cursor:pointer;display:flex;font-family:inherit;font-size:.9375rem;gap:12px;padding:12px 16px;text-align:left;transition:all .15s;width:100%}.profile-menu-item:hover{background:var(--bg-card-hover)}.profile-menu-item svg{color:var(--text-light);height:18px;width:18px}.profile-menu-item.logout,.profile-menu-item.logout svg{color:#dc2626}.profile-menu-item.logout:hover{background:#dc262626}.app-main{flex:1 1}.loading-screen{align-items:center;background:var(--bg);color:var(--text);display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-logo{height:80px;margin-bottom:2rem;width:auto}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #ffffff1a;border-radius:50%;border-top:3px solid var(--primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}@media (max-width:768px){.header-left{gap:1rem}.nav-link{font-size:.875rem;padding:6px 12px}}@media (max-width:480px){.header-content{gap:8px}.header-left{gap:.75rem}.header-logo{font-size:1.25rem}.nav-link{font-size:.8125rem;padding:6px 10px}.profile-menu{min-width:200px;right:-8px}}.modal-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .2s ease-out;background:var(--bg-card);border:1px solid var(--border);border-radius:16px;box-shadow:0 20px 60px #00000080;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:1.5rem}.modal-header h2{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1.25rem;margin:0}.modal-close{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1.5rem;line-height:1;padding:0}.modal-close:hover{color:var(--secondary)}.modal-content form{padding:1.5rem}.modal-error{background:#dc262626;border-radius:8px;color:#f87171;font-size:.875rem;padding:.75rem 1rem}.form-group,.modal-error{margin-bottom:1rem}.form-group label{color:var(--secondary);display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{background:var(--bg-surface);border:1px solid var(--border);border-radius:8px;color:var(--text);font-family:inherit;font-size:1rem;padding:.75rem;transition:border-color .2s;width:100%}.form-group select option{background:var(--bg-card);color:var(--text)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none}.form-group textarea{resize:vertical}input[type=date]{background:var(--bg-surface);color:var(--text);color-scheme:dark}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(1);opacity:.7;-webkit-transition:opacity .2s;transition:opacity .2s}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}input[type=date]::-moz-calendar-picker-indicator{filter:invert(1)}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.form-checkbox label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.form-checkbox input[type=checkbox]{width:auto}.input-with-unit{align-items:center;display:flex;gap:.5rem}.input-with-unit input{flex:1 1}.input-with-unit .unit{color:var(--text-light);font-size:.875rem}.modal-footer{border-top:1px solid var(--border);display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem;padding-top:1rem}.btn-cancel,.btn-submit{border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel{background:var(--bg-surface);color:var(--text)}.btn-cancel:hover{background:var(--bg-card-hover)}.btn-submit{background:var(--primary);color:#0d0d0d}.btn-submit:hover{box-shadow:0 4px 12px #ffd70066}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.leaderboard-modal{max-width:450px}.leaderboard-challenge{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:1rem 1.5rem}.leaderboard-challenge h3{color:var(--secondary);font-family:Archivo Black,sans-serif;font-size:1rem;margin:0 0 .25rem}.leaderboard-challenge p{color:var(--text-light);font-size:.875rem;margin:0}.leaderboard-empty,.leaderboard-loading{color:var(--text-light);padding:2rem;text-align:center}.leaderboard-list{max-height:400px;overflow-y:auto;padding:1rem 1.5rem}.leaderboard-item{align-items:center;border-radius:8px;display:flex;gap:1rem;margin-bottom:.5rem;padding:.75rem}.leaderboard-item:hover{background:var(--bg-card-hover)}.leaderboard-item.completed{background:#10b98126}.leaderboard-rank{font-size:1.125rem;font-weight:700;text-align:center;width:32px}.leaderboard-user{flex:1 1}.leaderboard-name{color:var(--secondary);display:block;font-weight:600;margin-bottom:.25rem}.leaderboard-progress-bar{background:var(--bg-surface);border-radius:2px;height:4px;overflow:hidden}.leaderboard-progress-fill{background:var(--primary);height:100%}.leaderboard-stats{text-align:right}.leaderboard-value{color:var(--secondary);display:block;font-weight:600}.leaderboard-percent{color:var(--text-light);font-size:.75rem}.leaderboard-my-rank{background:#ffd70026;color:var(--primary);font-weight:600;padding:1rem 1.5rem;text-align:center}@media (max-width:480px){.form-row{grid-template-columns:1fr}.modal-footer{flex-direction:column}.modal-footer button{width:100%}}
/*# sourceMappingURL=main.a8e47a62.css.map*/