.app{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary)}.main-content{flex:1;padding:32px 0}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);color:var(--text-primary)}.app-loading .loading-spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--coach-primary);margin-bottom:20px}.app-loading p{color:var(--text-secondary);font-size:16px}.lazy-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;min-height:400px}.lazy-loading .loading-spinner{width:36px;height:36px;border:3px solid var(--border-color);border-top-color:var(--coach-primary);margin-bottom:16px}.lazy-loading p{color:var(--text-secondary);font-size:14px;margin:0}.no-activity{text-align:center;padding:40px 20px;color:var(--text-muted)}.auth-error-banner{margin-top:32px;padding:24px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;max-width:500px;text-align:center}.auth-error-banner .error-text{color:#ef4444;font-size:14px;margin-bottom:16px;line-height:1.6}.auth-error-banner .retry-auth-btn{padding:10px 24px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.auth-error-banner .retry-auth-btn:hover{background:#dc2626;transform:translateY(-2px)}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:24px}.error-content{max-width:500px;text-align:center}.error-icon{width:80px;height:80px;background:var(--status-danger-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:36px;color:var(--status-danger)}.error-title{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.error-message{font-size:16px;color:var(--text-secondary);margin-bottom:32px;line-height:1.6}.error-actions{display:flex;gap:12px;justify-content:center}.error-details{margin-top:32px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;text-align:left}.error-details-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.error-stack{font-family:monospace;font-size:12px;color:var(--text-secondary);background:var(--bg-secondary);padding:16px;border-radius:8px;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.landing-page{min-height:100vh;background:var(--bg-primary)}.landing-nav{position:fixed;top:0;left:0;right:0;background:#0a0e17f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);z-index:1000}.landing-nav-container{max-width:1200px;margin:0 auto;padding:16px 24px;display:flex;justify-content:space-between;align-items:center}.landing-logo{display:flex;align-items:center;gap:12px;font-size:20px;font-weight:700;color:var(--text-primary)}.landing-logo:before{content:"";width:4px;height:24px;background:linear-gradient(180deg,var(--coach-primary),var(--coach-accent));border-radius:2px}.logo-icon{display:none}.landing-nav-links{display:flex;align-items:center;gap:8px}.landing-nav-links a.nav-link{text-decoration:none}.nav-link{background:none;color:var(--text-secondary);font-size:14px;font-weight:500;padding:10px 16px;border-radius:8px;transition:all .2s ease;border:none;cursor:pointer}.nav-link:hover{color:var(--text-primary);background:var(--bg-elevated)}.nav-cta{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:14px;font-weight:600;padding:12px 24px;border-radius:8px;transition:all .2s ease;border:none;cursor:pointer}.nav-cta:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.landing-hero{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 50%,var(--bg-card) 100%);padding:160px 24px 100px;text-align:center;color:var(--text-primary);position:relative;overflow:hidden}.landing-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(6,182,212,.15) 0%,transparent 60%);pointer-events:none}.hero-content{max-width:900px;margin:0 auto;position:relative;z-index:1}.hero-title{font-size:56px;font-weight:800;margin-bottom:24px;letter-spacing:-1px;line-height:1.1}.hero-title-line{display:block;color:var(--text-primary)}.hero-title-accent{display:block;background:linear-gradient(135deg,var(--coach-primary) 0%,var(--coach-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:20px;line-height:1.7;color:var(--text-secondary);margin-bottom:48px;max-width:600px;margin-left:auto;margin-right:auto}.hero-paths{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:700px;margin:0 auto}.hero-path-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:16px;padding:32px 24px;text-decoration:none;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center}.hero-path-card:hover{border-color:var(--coach-primary);transform:translateY(-4px);box-shadow:0 0 30px var(--border-glow)}.path-icon{width:64px;height:64px;background:var(--status-info-bg);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--coach-primary)}.hero-path-card h3{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.hero-path-card p{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.landing-section{padding:100px 24px;background:var(--bg-primary)}.landing-section-alt{background:var(--bg-secondary)}.section-container{max-width:1100px;margin:0 auto}.section-container-narrow{max-width:800px}.section-header{text-align:center;margin-bottom:60px}.section-badge{display:inline-block;background:var(--status-info-bg);border:1px solid var(--coach-primary);color:var(--coach-primary);font-size:13px;font-weight:600;padding:8px 18px;border-radius:50px;margin-bottom:20px;text-transform:uppercase;letter-spacing:.5px}.section-title{font-size:36px;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.2}.title-accent{background:linear-gradient(135deg,var(--coach-primary) 0%,var(--coach-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.section-subtitle{font-size:18px;color:var(--text-secondary);max-width:600px;margin:0 auto;line-height:1.6}.section-cta{text-align:center;margin-top:48px;display:flex;flex-direction:column;align-items:center;gap:16px}.cta-link{color:var(--text-secondary);font-size:14px;text-decoration:none;transition:color .2s ease}.cta-link:hover{color:var(--coach-primary)}.coach-pricing-inline{margin-top:60px;padding-top:48px;border-top:1px solid var(--border-color)}.pricing-inline-title{text-align:center;font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:32px}.pricing-grid-inline{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.pricing-card-inline{background:var(--bg-card);border:1px solid var(--border-color);border-radius:14px;padding:24px;text-align:center;position:relative;transition:all .2s ease}.pricing-card-inline:hover{border-color:var(--border-accent)}.pricing-card-inline.highlighted{border:2px solid var(--coach-primary);box-shadow:0 0 30px var(--border-glow)}.pricing-badge-inline{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:11px;font-weight:600;padding:4px 14px;border-radius:50px;white-space:nowrap}.pricing-card-inline h4{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.pricing-amount-inline{margin-bottom:8px}.pricing-amount-inline .amount{font-size:32px;font-weight:700;color:var(--coach-primary)}.pricing-amount-inline .period{font-size:14px;color:var(--text-muted)}.pricing-desc-inline{font-size:13px;color:var(--text-secondary);margin-bottom:16px}.pricing-list-inline{list-style:none;padding:0;margin:0;text-align:left}.pricing-list-inline li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-primary);padding:6px 0}.pricing-list-inline svg{color:var(--status-success);flex-shrink:0}.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);padding:28px;border-radius:14px;transition:all .3s ease}.feature-card:hover{border-color:var(--border-accent);transform:translateY(-4px)}.feature-title{font-size:17px;font-weight:600;color:var(--text-primary);margin-bottom:10px}.feature-description{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}.solo-pricing-highlight{margin-top:60px;display:flex;justify-content:center}.solo-price-card{background:var(--bg-card);border:2px solid var(--coach-primary);border-radius:20px;padding:40px;max-width:400px;text-align:center;box-shadow:0 0 40px var(--border-glow)}.solo-price-header h3{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.solo-price .price-amount{font-size:48px;font-weight:800;color:var(--coach-primary)}.solo-price-desc{font-size:15px;color:var(--text-secondary);margin:16px 0 24px}.solo-features-list{list-style:none;padding:0;margin:0 0 28px;text-align:left}.solo-features-list li{display:flex;align-items:center;gap:12px;padding:10px 0;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.solo-features-list li:last-child{border-bottom:none}.solo-features-list svg{color:var(--status-success);flex-shrink:0}.analytics-preview{margin-bottom:48px}.analytics-mockup{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;max-width:800px;margin:0 auto;box-shadow:0 20px 60px #0000004d}.mockup-header{background:var(--bg-secondary);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color)}.mockup-title{font-size:14px;font-weight:600;color:var(--text-primary)}.mockup-tabs{display:flex;gap:4px}.mockup-tabs .tab{padding:6px 12px;font-size:12px;color:var(--text-muted);border-radius:6px;cursor:default}.mockup-tabs .tab.active{background:var(--coach-primary);color:var(--bg-primary)}.mockup-content{padding:24px}.mockup-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.summary-item{background:var(--bg-secondary);border-radius:10px;padding:16px;text-align:center}.summary-item .summary-value{display:block;font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.summary-item.streak .summary-value{color:#f59e0b}.summary-item.compliance .summary-value{color:#10b981}.summary-item.weight-change .summary-value{color:#06b6d4}.summary-item.calories .summary-value{color:#8b5cf6}.summary-item .summary-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.mockup-chart-area{position:relative;margin-bottom:16px}.chart-label-y{position:absolute;left:0;top:0;bottom:20px;width:40px;display:flex;flex-direction:column;justify-content:space-between;font-size:10px;color:var(--text-muted);text-align:right;padding-right:8px}.weight-chart-svg{width:calc(100% - 50px);height:120px;margin-left:50px}.chart-label-x{display:flex;justify-content:space-between;margin-left:50px;font-size:10px;color:var(--text-muted);margin-top:8px}.mockup-trend{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:#06b6d41a;border-radius:8px}.trend-arrow{font-size:18px;font-weight:700}.trend-arrow.down{color:#10b981}.trend-arrow.up{color:#ef4444}.trend-text{font-size:14px;color:var(--text-primary);font-weight:500}.analytics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.analytics-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;transition:all .2s ease}.analytics-item:hover{border-color:var(--border-accent)}.analytics-item h4{font-size:15px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.analytics-item p{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.5}.comparison-table{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden;max-width:700px;margin:0 auto}.comparison-header{display:grid;grid-template-columns:2fr 1fr 1fr;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.comparison-header .comp-cell{padding:16px 20px;font-size:13px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px}.comparison-row{display:grid;grid-template-columns:2fr 1fr 1fr;border-bottom:1px solid var(--border-color)}.comparison-row:last-child{border-bottom:none}.comp-cell{padding:16px 20px;font-size:14px;color:var(--text-secondary)}.comp-cell.feature{color:var(--text-primary);font-weight:500}.comp-cell.us.highlight{color:var(--coach-primary);font-weight:600}.comp-cell.them{color:var(--text-muted)}.comparison-note{text-align:center;margin-top:20px}.comparison-note p{font-size:12px;color:var(--text-muted)}.custom-build-content,.download-content{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.download-features{display:flex;flex-direction:column;gap:24px}.download-feature{display:flex;gap:16px;align-items:flex-start}.download-feature-icon{width:48px;height:48px;background:var(--status-info-bg);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--coach-primary);flex-shrink:0}.download-feature h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 4px}.download-feature p{font-size:14px;color:var(--text-secondary);margin:0}.download-cta{display:flex;justify-content:center}.download-card{background:var(--bg-card);border:2px solid var(--coach-primary);border-radius:20px;padding:40px;text-align:center;box-shadow:0 0 40px var(--border-glow);max-width:350px}.download-icon-large{width:80px;height:80px;background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));border-radius:20px;display:flex;align-items:center;justify-content:center;color:var(--bg-primary);margin:0 auto 20px}.download-card h3{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.download-card>p{font-size:14px;color:var(--text-secondary);margin:0 0 24px}.download-note{display:block;font-size:12px;color:var(--text-muted);margin-top:12px}.custom-build-features{display:flex;flex-direction:column;gap:24px}.custom-feature{display:flex;gap:16px;align-items:flex-start}.custom-feature-icon{width:48px;height:48px;background:var(--status-info-bg);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--coach-primary);flex-shrink:0}.custom-feature-text h4{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 6px}.custom-feature-text p{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.custom-build-cta{display:flex;justify-content:center}.custom-cta-card{background:var(--bg-card);border:2px solid var(--coach-primary);border-radius:20px;padding:40px;text-align:center;box-shadow:0 0 40px var(--border-glow);max-width:400px}.custom-cta-card h3{font-size:22px;font-weight:700;color:var(--text-primary);margin:0 0 16px}.custom-cta-card p{font-size:14px;color:var(--text-secondary);line-height:1.7;margin:0 0 28px}.custom-cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:16px;font-weight:600;padding:16px 32px;border-radius:10px;text-decoration:none;transition:all .2s ease}.custom-cta-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.custom-cta-note{display:block;font-size:13px;color:var(--text-muted);margin-top:12px}.landing-pricing{padding:100px 24px;background:var(--bg-secondary)}.pricing-container{max-width:1100px;margin:0 auto}.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}.pricing-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:36px;text-align:center;position:relative;transition:all .3s ease}.pricing-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.pricing-card-highlighted{border:2px solid var(--coach-primary);transform:scale(1.02);box-shadow:0 0 40px var(--border-glow)}.pricing-card-highlighted:hover{transform:scale(1.02) translateY(-4px)}.pricing-badge,.service-badge{position:absolute;top:-14px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:12px;font-weight:600;padding:6px 20px;border-radius:50px}.pricing-name,.service-name{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.pricing-price,.service-price{margin-bottom:8px}.price-amount{font-size:48px;font-weight:700;color:var(--coach-primary)}.price-period{font-size:16px;color:var(--text-muted)}.pricing-description,.service-description{font-size:14px;color:var(--text-secondary);margin-bottom:28px}.pricing-features,.service-features{list-style:none;text-align:left;margin-bottom:32px;padding:0}.pricing-features li,.service-features li{display:flex;align-items:center;gap:12px;padding:12px 0;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.pricing-features li:last-child,.service-features li:last-child{border-bottom:none}.pricing-features svg,.service-features svg{color:var(--status-success);flex-shrink:0}.pricing-cta,.service-cta{width:100%;background:var(--bg-elevated);color:var(--text-primary);font-size:14px;font-weight:600;padding:16px 24px;border-radius:10px;border:1px solid var(--border-color);transition:all .2s ease;cursor:pointer}.pricing-cta:hover,.service-cta:hover{border-color:var(--coach-primary);color:var(--coach-primary)}.pricing-cta-primary,.service-cta-primary{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);border:none}.pricing-cta-primary:hover,.service-cta-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px);color:var(--bg-primary)}.landing-services{padding:100px 24px;background:var(--bg-primary)}.landing-services-featured{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 50%,var(--bg-card) 100%);position:relative;overflow:hidden}.landing-services-featured:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 100%,rgba(6,182,212,.1) 0%,transparent 60%);pointer-events:none}.services-featured-badge{display:inline-block;background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:14px;font-weight:600;padding:8px 20px;border-radius:50px;margin-bottom:20px}.services-url-preview{text-align:center;margin:40px 0}.url-preview-box{display:inline-flex;align-items:center;gap:12px;background:var(--bg-card);border:2px solid var(--coach-primary);border-radius:12px;padding:16px 32px;box-shadow:0 0 30px var(--border-glow)}.url-icon{font-size:24px}.url-text{font-family:Monaco,Consolas,monospace;font-size:20px;color:var(--text-primary)}.url-highlight{color:var(--coach-primary);font-weight:600}.url-caption{font-size:14px;color:var(--text-muted);margin-top:12px}.services-cta-featured{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-secondary) 100%);border:2px solid var(--coach-primary);box-shadow:0 0 40px var(--border-glow)}.services-cta-btn-featured{font-size:18px;padding:18px 48px;animation:pulse 2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #06b6d466}50%{box-shadow:0 0 0 10px #06b6d400}}.services-cta-note{font-size:13px;color:var(--text-muted);margin-top:12px;margin-bottom:0}.services-container{max-width:1000px;margin:0 auto;position:relative;z-index:1}.services-showcase{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}.service-showcase-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;display:flex;gap:16px;transition:all .2s ease}.service-showcase-item:hover{border-color:var(--border-accent);transform:translateY(-2px)}.service-showcase-icon{font-size:28px;flex-shrink:0}.service-showcase-content h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.service-showcase-content p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0}.services-cta{text-align:center;margin-top:48px;padding:40px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px}.services-cta-text{font-size:18px;color:var(--text-secondary);margin-bottom:24px}.services-cta-btn{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:16px;font-weight:600;padding:16px 48px;border-radius:10px;border:none;cursor:pointer;transition:all .2s ease}.services-cta-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.landing-faq{padding:100px 24px;background:var(--bg-secondary)}.faq-container{max-width:800px;margin:0 auto}.faq-list{margin-top:48px}.faq-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;margin-bottom:12px;overflow:hidden;transition:all .2s ease}.faq-item:hover{border-color:var(--border-accent)}.faq-item-open{border-color:var(--coach-primary)}.faq-question{width:100%;display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background:none;border:none;color:var(--text-primary);font-size:16px;font-weight:500;text-align:left;cursor:pointer;transition:all .2s ease}.faq-question:hover{color:var(--coach-primary)}.faq-icon{font-size:24px;color:var(--coach-primary);font-weight:300}.faq-answer{padding:0 24px 20px;animation:fadeIn .2s ease}.faq-answer p{font-size:14px;color:var(--text-secondary);line-height:1.7;margin:0}.landing-cta-section{padding:100px 24px;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-primary) 100%);text-align:center}.cta-container{max-width:600px;margin:0 auto}.cta-container h2{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:16px;line-height:1.2}.cta-title-accent{background:linear-gradient(135deg,var(--coach-primary) 0%,var(--coach-accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.cta-container p{font-size:18px;color:var(--text-secondary);margin-bottom:32px}.cta-buttons{display:flex;justify-content:center;gap:16px}.cta-primary{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:16px;font-weight:600;padding:16px 36px;border-radius:10px;border:none;cursor:pointer;transition:all .2s ease}.cta-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.cta-secondary{background:transparent;color:var(--text-primary);font-size:16px;font-weight:600;padding:16px 36px;border-radius:10px;border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.cta-secondary:hover{border-color:var(--coach-primary);color:var(--coach-primary)}.landing-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);color:var(--text-primary);padding:60px 24px 30px}.footer-container{max-width:1100px;margin:0 auto}.footer-main{display:flex;justify-content:space-between;gap:48px;margin-bottom:48px}.footer-brand{max-width:300px}.footer-brand .logo-text{font-size:20px;font-weight:700;display:block;margin-bottom:12px}.footer-tagline{font-size:14px;color:var(--text-secondary);line-height:1.6}.footer-links{display:flex;gap:64px}.footer-column h4{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.footer-column a{display:block;font-size:14px;color:var(--text-secondary);text-decoration:none;margin-bottom:10px;transition:color .2s ease}.footer-column a:hover{color:var(--coach-primary)}.footer-bottom{border-top:1px solid var(--border-color);padding-top:24px;text-align:center}.footer-copyright{font-size:12px;color:var(--text-muted)}@media(max-width:992px){.features-grid,.pricing-grid,.analytics-grid,.mockup-summary{grid-template-columns:repeat(2,1fr)}.custom-build-content,.download-content{grid-template-columns:1fr;gap:40px}.custom-cta-card,.download-card{max-width:100%}.hero-paths{max-width:500px}.pricing-card-highlighted{transform:none}.pricing-card-highlighted:hover{transform:translateY(-4px)}.footer-main{flex-direction:column;gap:32px}.footer-links{gap:32px}}@media(max-width:768px){.hero-title{font-size:40px}.hero-subtitle{font-size:16px}.hero-paths{grid-template-columns:1fr;max-width:350px}.features-grid,.pricing-grid,.analytics-grid{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}.pricing-grid-inline{grid-template-columns:1fr;max-width:320px;margin-left:auto;margin-right:auto}.comparison-table{font-size:13px}.comp-cell{padding:12px 14px}.mockup-summary{grid-template-columns:repeat(2,1fr);gap:12px}.summary-item .summary-value{font-size:20px}.section-title{font-size:28px}.landing-section{padding:80px 24px}.mockup-stats{grid-template-columns:1fr}.cta-buttons{flex-direction:column;align-items:center}.cta-primary,.cta-secondary{width:100%;max-width:300px}.footer-links{flex-wrap:wrap;gap:24px}.footer-column{min-width:120px}}@media(max-width:480px){.landing-nav-container{padding:12px 16px}.landing-hero{padding:140px 16px 80px}.hero-title{font-size:32px}.price-amount{font-size:36px}.cta-container h2{font-size:24px}.solo-price-card{padding:28px}}.footer-contact-btn{background:none;border:none;color:var(--text-secondary);font-size:14px;padding:0;cursor:pointer;text-align:left;transition:color .2s ease}.footer-contact-btn:hover{color:var(--coach-primary)}.contact-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:24px}.contact-modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:40px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.contact-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-muted);font-size:28px;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.contact-modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.contact-modal h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.contact-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:32px}.contact-form{display:flex;flex-direction:column;gap:20px}.contact-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.contact-form-group{display:flex;flex-direction:column;gap:8px}.contact-form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.contact-form-group input,.contact-form-group select,.contact-form-group textarea{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:12px 14px;font-size:14px;color:var(--text-primary);transition:all .2s ease}.contact-form-group input:focus,.contact-form-group select:focus,.contact-form-group textarea:focus{outline:none;border-color:var(--coach-primary);box-shadow:0 0 0 3px var(--status-info-bg)}.contact-form-group input::placeholder,.contact-form-group textarea::placeholder{color:var(--text-muted)}.contact-form-group textarea{resize:vertical;min-height:100px}.contact-error{color:var(--status-error);font-size:14px;margin:0}.contact-submit-btn{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:16px;font-weight:600;padding:14px 24px;border-radius:10px;border:none;cursor:pointer;transition:all .2s ease}.contact-submit-btn:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-1px)}.contact-submit-btn:disabled{opacity:.7;cursor:not-allowed}.contact-direct{text-align:center;font-size:13px;color:var(--text-muted);margin-top:20px}.contact-direct a{color:var(--coach-primary);text-decoration:none}.contact-direct a:hover{text-decoration:underline}.contact-success{text-align:center;padding:20px 0}.contact-success-icon{width:64px;height:64px;background:var(--status-success-bg);color:var(--status-success);font-size:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.contact-success h3{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.contact-success p{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.contact-email-link{display:inline-block;color:var(--coach-primary);font-weight:500;text-decoration:none;margin-bottom:24px}.contact-email-link:hover{text-decoration:underline}.contact-done-btn{background:var(--bg-elevated);color:var(--text-primary);font-size:14px;font-weight:500;padding:12px 32px;border-radius:8px;border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.contact-done-btn:hover{border-color:var(--coach-primary)}@media(max-width:600px){.contact-modal{padding:24px;margin:16px}.contact-form-row{grid-template-columns:1fr}}@media(max-width:768px){.services-showcase{grid-template-columns:1fr}.services-cta{padding:24px}.services-cta-text{font-size:16px}}.landing-mobile-toggle{display:none;background:none;border:none;padding:8px;cursor:pointer;z-index:1002}.landing-hamburger{display:flex;flex-direction:column;gap:5px;width:24px}.landing-hamburger span{display:block;height:2px;background:var(--text-primary);border-radius:2px;transition:all .3s ease}.landing-hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.landing-hamburger.open span:nth-child(2){opacity:0}.landing-hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.landing-mobile-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:999}@media(max-width:768px){.landing-mobile-toggle,.landing-mobile-overlay{display:block}.landing-nav-links{position:fixed;top:0;right:-280px;width:280px;height:100vh;background:var(--bg-card);flex-direction:column;padding:80px 24px 24px;gap:8px;z-index:1001;transition:right .3s ease;box-shadow:-4px 0 20px #0000004d}.landing-nav-links.mobile-open{right:0}.landing-nav-links .nav-link{width:100%;text-align:left;padding:14px 16px;border-radius:8px}.landing-nav-links .nav-cta{width:100%;margin-top:16px}}@media(max-width:480px){.landing-nav-links{width:100%;right:-100%}.landing-nav-links.mobile-open{right:0}}.install-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border-color);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:16px;z-index:1000;box-shadow:0 -4px 20px #0000004d;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.install-banner-content{display:flex;align-items:center;gap:14px}.install-banner-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--bg-primary);flex-shrink:0}.install-banner-text{display:flex;flex-direction:column;gap:2px}.install-banner-text strong{font-size:15px;color:var(--text-primary)}.install-banner-text span{font-size:13px;color:var(--text-secondary)}.install-banner-actions{display:flex;gap:10px;flex-shrink:0}.install-btn-primary{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:14px;font-weight:600;padding:10px 24px;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.install-btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.install-btn-dismiss{background:transparent;color:var(--text-muted);font-size:14px;padding:10px 16px;border-radius:8px;border:none;cursor:pointer;transition:color .2s ease}.install-btn-dismiss:hover{color:var(--text-secondary)}.install-app-btn{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:14px;font-weight:600;padding:12px 24px;border-radius:10px;border:none;cursor:pointer;transition:all .2s ease}.install-app-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.install-button-wrapper{display:flex;flex-direction:column;align-items:center;gap:8px}.install-status{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary);padding:10px 20px;background:var(--bg-secondary);border-radius:8px}.install-status.installed{color:var(--status-success)}.install-status svg{color:var(--status-success)}.install-hint{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);padding:12px 16px;background:var(--bg-secondary);border-radius:8px;max-width:300px;text-align:left}.install-hint svg{flex-shrink:0;color:var(--text-muted)}.install-ios-btn{display:inline-flex;align-items:center;gap:8px;background:var(--bg-elevated);color:var(--text-primary);font-size:14px;font-weight:500;padding:12px 24px;border-radius:10px;border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.install-ios-btn:hover{border-color:var(--coach-primary);color:var(--coach-primary)}.ios-instructions{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px;margin-top:12px;text-align:left;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ios-instructions p{font-size:14px;color:var(--text-primary);margin:0 0 12px}.ios-instructions ol{margin:0;padding-left:20px}.ios-instructions li{font-size:13px;color:var(--text-secondary);margin-bottom:8px;line-height:1.5}.ios-instructions li:last-child{margin-bottom:0}.ios-icon{display:inline-block;background:var(--bg-elevated);padding:2px 6px;border-radius:4px;font-size:12px}@media(max-width:480px){.install-banner{flex-direction:column;padding:16px;gap:14px}.install-banner-content,.install-banner-actions{width:100%}.install-btn-primary{flex:1}.install-btn-dismiss{flex-shrink:0}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:20px}.login-box{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:40px;box-shadow:var(--shadow-lg)}.login-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px;text-align:center}.login-title:before{content:"";display:block;width:60px;height:4px;background:linear-gradient(90deg,var(--coach-primary),var(--coach-accent));border-radius:2px;margin:0 auto 16px}.login-subtitle{color:var(--text-secondary);font-size:14px;text-align:center;margin-bottom:24px}.error-message{background:var(--status-danger-bg);color:var(--status-danger);padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid var(--status-danger)}.reset-message{background:var(--status-success-bg, rgba(3, 127, 12, .12));color:var(--status-success, #2ecc71);padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid var(--status-success, #2ecc71)}.reset-link{margin-top:8px;text-align:center}.auth-toggle{text-align:center;margin-top:20px}.toggle-btn{background:transparent;color:var(--coach-primary);border:none;font-size:14px;cursor:pointer;padding:8px}.toggle-btn:hover{text-decoration:underline}.demo-credentials{margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color);text-align:center}.demo-credentials p{color:var(--text-secondary);font-size:13px;margin-bottom:12px}.demo-buttons{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.demo-btn{padding:10px 16px;background:transparent;color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.demo-btn:hover{border-color:var(--coach-primary);color:var(--coach-primary)}.demo-btn-client{background:var(--bg-secondary);border-color:var(--text-secondary)}.demo-btn-client:hover{border-color:var(--accent-color, var(--coach-accent, #22c55e));color:var(--accent-color, var(--coach-accent, #22c55e))}.demo-btn-solo{background:var(--bg-secondary);border-color:#00b894}.demo-btn-solo:hover{border-color:#00cec9;color:#00cec9}.login-form{display:flex;flex-direction:column;gap:20px}.login-form .form-group{margin-bottom:0}.login-form label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.login-form input,.login-form select{width:100%;padding:14px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:14px;transition:all .2s ease}.login-form input:focus,.login-form select:focus{border-color:var(--coach-primary);box-shadow:var(--focus-ring)}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;margin-top:8px}.login-btn:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{background:var(--status-danger-bg);color:var(--status-danger);padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid var(--status-danger)}.login-divider{display:flex;align-items:center;gap:16px;margin:24px 0;color:var(--text-muted);font-size:13px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.demo-login-btn{width:100%;padding:14px;background:transparent;color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.demo-login-btn:hover{border-color:var(--coach-primary);color:var(--coach-primary)}.login-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid var(--border-color)}.login-footer p{color:var(--text-secondary);font-size:14px}.login-footer a{color:var(--coach-primary);text-decoration:none;font-weight:500}.login-footer a:hover{text-decoration:underline}.back-btn{display:flex;align-items:center;gap:8px;background:transparent;color:var(--text-secondary);border:none;font-size:14px;cursor:pointer;margin-bottom:24px;padding:0}.back-btn:hover{color:var(--text-primary)}.login-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-secondary);padding:4px;border-radius:10px}.login-tab{flex:1;padding:12px;background:transparent;color:var(--text-secondary);border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.login-tab.active{background:var(--coach-primary);color:var(--bg-primary)}.login-tab:hover:not(.active){color:var(--text-primary)}@media(max-width:480px){.login-container{padding:40px 16px 16px;align-items:flex-start}.login-box{padding:24px 20px;border-radius:12px}.login-title{font-size:24px}.login-form input,.login-form select{padding:12px 14px;font-size:16px}.login-btn{padding:14px;font-size:16px}.demo-buttons{flex-direction:column;gap:10px}.demo-btn{width:100%;padding:12px}}@supports (-webkit-touch-callout: none){.login-form input,.login-form select{font-size:16px}}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:0;position:sticky;top:0;z-index:1000}.header .container{max-width:100%;padding:0;width:100%}.header-content{display:flex;align-items:center;padding:0 24px;height:56px;max-width:100%;margin:0 auto;overflow:visible}.logo{font-size:18px;font-weight:700;color:var(--text-primary);white-space:nowrap;flex-shrink:0;display:flex;align-items:center;gap:8px;margin-right:32px}.logo:before{content:"";width:4px;height:20px;background:linear-gradient(180deg,var(--coach-primary),var(--coach-accent));border-radius:2px}.nav{display:flex;gap:4px;align-items:center;height:100%;flex-wrap:nowrap;overflow:visible}.desktop-nav{flex:1;min-width:0;display:flex;justify-content:flex-start;overflow:visible}.nav-btn{background:transparent;color:var(--text-secondary);padding:8px 14px;border-radius:6px;font-size:13px;font-weight:500;white-space:nowrap;border:none;transition:all .15s ease;cursor:pointer;height:36px;display:flex;align-items:center;flex-shrink:0;overflow:visible;text-overflow:clip;max-width:none;min-width:fit-content;outline:none}.nav-btn:focus-visible{outline:2px solid var(--coach-primary);outline-offset:2px}.nav-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-btn.active{background:var(--coach-primary);color:var(--bg-primary);font-weight:600}.nav-dropdown{position:relative;flex-shrink:0}.nav-dropdown-trigger{display:flex;align-items:center;gap:4px;white-space:nowrap;overflow:visible}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.nav-dropdown-trigger.open .dropdown-arrow{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;min-width:180px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #0000004d;padding:6px 0;z-index:2000;animation:dropdownFadeIn .15s ease}.nav-dropdown-menu-fixed{min-width:180px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px #00000080;padding:6px 0;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.nav-dropdown-item,.nav-dropdown-menu-fixed button{display:block;width:100%;padding:10px 16px;background:transparent;border:none;text-align:left;font-size:13px;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;outline:none}.nav-dropdown-item:hover,.nav-dropdown-menu-fixed button:hover{background:var(--bg-elevated);color:var(--text-primary)}.nav-dropdown-item:focus-visible,.nav-dropdown-menu-fixed button:focus-visible{outline:2px solid var(--coach-primary);outline-offset:-2px}.nav-dropdown-item.active,.nav-dropdown-menu-fixed button.active{background:var(--coach-primary);color:var(--bg-primary);font-weight:600}@media(min-width:1400px){.nav{gap:6px}.nav-btn{padding:8px 16px;font-size:14px}}@media(max-width:1399px)and (min-width:1200px){.nav-btn{padding:8px 12px;font-size:13px}.logo{margin-right:24px}}@media(max-width:1199px)and (min-width:992px){.nav-btn{padding:8px 10px;font-size:12px;min-width:fit-content}.logo{font-size:16px;margin-right:16px}.user-name{display:none}.user-section{gap:8px}.desktop-nav{flex-wrap:nowrap;overflow:visible}}@media(max-width:991px){.header-content{justify-content:space-between;padding:0 16px;height:52px}.hamburger-btn{display:flex;order:2}.desktop-nav{display:none!important}.mobile-menu-overlay{display:block}.logo{order:0;font-size:16px;margin-right:0;flex:0 0 auto}.user-section.desktop-only{display:none}.header-right.mobile-only{display:flex;align-items:center;gap:8px;order:3}.header-right .user-role{font-size:9px;padding:3px 6px}.header-right .logout-btn{padding:6px 10px;font-size:11px}}@media(max-width:767px){.header-content{padding:12px 16px}.logo{font-size:14px}.user-section.desktop-only{display:none}.header-right.mobile-only{gap:6px}.header-right .user-role{font-size:8px;padding:2px 5px}.header-right .logout-btn{padding:5px 8px;font-size:10px}}.user-section{display:flex;align-items:center;gap:12px;margin-left:auto;flex-shrink:0}.header-right.mobile-only{display:none}.user-role{font-size:10px;font-weight:700;color:var(--coach-primary);background:var(--status-info-bg);padding:4px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.user-name{font-size:13px;color:var(--text-primary);font-weight:500}.logout-btn{background:transparent;color:var(--text-secondary);padding:8px 14px;border:1px solid var(--border-color);border-radius:6px;font-size:12px;font-weight:500;transition:all .15s ease;outline:none}.logout-btn:hover{border-color:var(--status-danger);color:var(--status-danger);background:var(--status-danger-bg)}.logout-btn:focus-visible{outline:2px solid var(--coach-primary);outline-offset:2px}.hamburger-btn{display:none;background:transparent;border:none;padding:8px;cursor:pointer;z-index:101;outline:none}.hamburger-btn:focus-visible{outline:2px solid var(--coach-primary);outline-offset:2px;border-radius:4px}.hamburger-icon{display:block;width:24px;height:2px;background:var(--text-primary);position:relative;transition:background .2s ease}.hamburger-icon:before,.hamburger-icon:after{content:"";position:absolute;width:24px;height:2px;background:var(--text-primary);left:0;transition:transform .2s ease}.hamburger-icon:before{top:-7px}.hamburger-icon:after{top:7px}.mobile-menu-overlay{display:none;position:fixed;inset:0;background:#000000b3;z-index:200;animation:fadeIn .2s ease}.mobile-nav{position:fixed;top:0;right:0;width:280px;max-width:85vw;height:100vh;background:var(--bg-secondary);display:flex;flex-direction:column;animation:slideIn .3s ease;overflow-y:auto}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.mobile-nav-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color)}.mobile-nav-header h2{margin:0;font-size:18px;color:var(--text-primary)}.close-btn{background:transparent;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;line-height:1;transition:color .2s ease;outline:none}.close-btn:focus-visible{outline:2px solid var(--coach-primary);outline-offset:2px;border-radius:4px}.mobile-nav-items{flex:1;padding:12px 0;overflow-y:auto}.mobile-nav-btn{display:block;width:100%;padding:14px 20px;background:transparent;border:none;text-align:left;font-size:15px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;outline:none}.mobile-nav-btn:hover{background:var(--bg-elevated);color:var(--text-primary)}.mobile-nav-btn:focus-visible{outline:2px solid var(--coach-primary);outline-offset:-2px}.mobile-nav-btn.active{background:var(--coach-primary);color:var(--bg-primary);font-weight:600}.mobile-nav-section{padding:12px 20px 6px;font-size:11px;font-weight:700;color:var(--coach-primary);text-transform:uppercase;letter-spacing:.05em;border-top:1px solid var(--border-color);margin-top:8px}.mobile-nav-section:first-child{border-top:none;margin-top:0}.mobile-nav-btn.indented{padding-left:32px}.mobile-nav-footer{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px}.user-role-mobile{font-size:10px;font-weight:700;color:var(--coach-primary);background:var(--status-info-bg);padding:6px 10px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em;align-self:flex-start}.user-name-mobile{font-size:14px;color:var(--text-primary);font-weight:500}.logout-btn-mobile{background:transparent;color:var(--status-danger);padding:10px 18px;border:1px solid var(--status-danger);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.logout-btn-mobile:hover{background:var(--status-danger-bg)}@media(min-width:992px){.hamburger-btn{display:none}.mobile-menu-overlay{display:none!important}.desktop-nav,.user-section.desktop-only{display:flex}.header-right.mobile-only{display:none}}.dashboard{max-width:1400px}.dashboard .page-title{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:32px;display:flex;align-items:center;gap:12px}.dashboard .page-title:before{content:"";width:4px;height:28px;background:linear-gradient(180deg,var(--coach-primary),var(--coach-accent));border-radius:2px}.dashboard .stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px}.dashboard .stat-card{background:var(--bg-card);padding:24px;border-radius:12px;border:1px solid var(--border-color);position:relative;overflow:hidden;transition:all .3s ease}.dashboard .stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--coach-primary),var(--coach-accent))}.dashboard .stat-card:hover{border-color:var(--border-accent);box-shadow:0 0 25px var(--border-glow);transform:translateY(-2px)}.dashboard .stat-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.dashboard .stat-value{font-size:36px;font-weight:700;color:var(--coach-primary);text-shadow:0 0 30px var(--border-glow)}.dashboard-section{margin-top:40px}.dashboard-section .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.dashboard-section .section-title{font-size:16px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em;margin:0}.dashboard-section .clear-all-btn{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s ease}.dashboard-section .clear-all-btn:hover{background:var(--bg-elevated);border-color:var(--coach-primary);color:var(--coach-primary)}.activity-card{background:var(--bg-card);padding:0;border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.activity-item{display:flex;gap:16px;padding:20px 24px;border-bottom:1px solid var(--border-color);transition:background .2s ease;align-items:flex-start}.activity-item.clickable{cursor:pointer}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:var(--bg-elevated)}.activity-item.clickable:hover{background:#00bcd40d}.activity-dot{width:10px;height:10px;background:var(--coach-primary);border-radius:50%;margin-top:6px;flex-shrink:0;box-shadow:0 0 10px var(--border-glow)}.activity-item[data-type=lead] .activity-dot{background:var(--coach-primary);box-shadow:0 0 10px var(--border-glow)}.activity-item[data-type=payment] .activity-dot{background:var(--status-success);box-shadow:0 0 10px #10b98166}.activity-item[data-type=message] .activity-dot{background:var(--coach-primary)}.activity-item[data-type=milestone] .activity-dot{background:#8b5cf6;box-shadow:0 0 10px #8b5cf666}.activity-item[data-type=checkin] .activity-dot{background:var(--coach-accent);box-shadow:0 0 10px #00bcd466}.activity-content{flex:1;min-width:0}.activity-text{font-size:14px;color:var(--text-primary);margin-bottom:6px}.activity-meta{display:flex;gap:12px;align-items:center}.activity-time{font-size:12px;color:var(--text-muted)}.activity-exact-time{font-size:11px;color:var(--text-muted);opacity:.7;padding-left:12px;border-left:1px solid var(--border-color)}.activity-clear-btn{background:transparent;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;opacity:0;transition:all .2s ease;flex-shrink:0}.activity-item:hover .activity-clear-btn{opacity:1}.activity-clear-btn:hover{background:#ef44441a;color:var(--status-error)}.no-activity{padding:40px;text-align:center;color:var(--text-muted)}.dashboard-error{max-width:600px;margin:80px auto;padding:48px;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-color);text-align:center}.dashboard-error .error-icon{font-size:64px;margin-bottom:24px;opacity:.8}.dashboard-error h3{font-size:24px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.dashboard-error p{font-size:16px;color:var(--text-secondary);margin-bottom:32px;line-height:1.6}.dashboard-error .retry-btn{padding:12px 32px;background:var(--coach-primary);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.dashboard-error .retry-btn:hover{background:var(--coach-accent);box-shadow:0 0 20px var(--border-glow);transform:translateY(-2px)}.quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:32px}.quick-action-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:16px 12px;min-height:80px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.quick-action-btn:hover{background:var(--bg-elevated);border-color:var(--coach-primary);transform:translateY(-2px);box-shadow:0 4px 12px #00bcd426}.quick-action-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:var(--coach-primary)}.quick-action-icon svg{width:22px;height:22px;fill:currentColor}.quick-action-label{white-space:nowrap;text-align:center}@media(max-width:600px){.quick-actions{grid-template-columns:repeat(2,1fr)}}@media(max-width:360px){.quick-actions{grid-template-columns:1fr}}.dashboard-widgets{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;align-items:stretch}@media(max-width:900px){.dashboard-widgets{grid-template-columns:1fr}}.widget-schedule{margin-top:0;display:flex;flex-direction:column}.widget-schedule .schedule-card{flex:1;display:flex;flex-direction:column}.schedule-card{background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.schedule-item{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s ease}.schedule-item:last-child{border-bottom:none}.schedule-item:hover{background:var(--bg-elevated)}.schedule-time{font-size:14px;font-weight:600;color:var(--coach-primary);min-width:80px}.schedule-details{flex:1}.schedule-client{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:2px}.schedule-type{font-size:12px;color:var(--text-muted)}.schedule-status{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}.schedule-status.upcoming{background:#00bcd41a;color:var(--coach-primary)}.schedule-status.completed{background:#10b9811a;color:var(--status-success)}.no-sessions{padding:40px 20px;text-align:center;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.no-sessions-icon{width:48px;height:48px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--text-muted)}.no-sessions-icon svg{width:24px;height:24px;fill:currentColor}.no-sessions p{color:var(--text-muted);margin-bottom:16px}.schedule-session-btn{padding:10px 20px;background:var(--coach-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.schedule-session-btn:hover{background:var(--coach-accent);transform:translateY(-1px)}.view-all-btn{background:transparent;border:none;color:var(--coach-primary);font-size:13px;cursor:pointer;transition:color .2s ease}.view-all-btn:hover{color:var(--coach-accent);text-decoration:underline}.widget-attention{margin-top:0;display:flex;flex-direction:column}.attention-card{background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);overflow:hidden;flex:1;display:flex;flex-direction:column}.attention-item{display:flex;align-items:center;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border-color);cursor:pointer;transition:background .2s ease;flex:1}.attention-item:last-child{border-bottom:none}.attention-item:hover{background:var(--bg-elevated)}.attention-item.has-items{background:#ef44440d}.attention-item.has-items:hover{background:#ef44441a}.attention-item.has-items .attention-count{color:var(--status-error)}.attention-icon{width:36px;height:36px;border-radius:8px;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-muted);flex-shrink:0}.attention-icon svg{width:18px;height:18px}.attention-item.has-items .attention-icon{background:#ef44441a;color:var(--status-error)}.attention-details{flex:1;display:flex;flex-direction:column;gap:2px}.attention-count{font-size:20px;font-weight:600;color:var(--text-primary);line-height:1}.attention-label{font-size:12px;color:var(--text-muted)}.attention-arrow{color:var(--text-muted);opacity:0;transition:opacity .2s ease}.attention-item:hover .attention-arrow{opacity:1}.client-logins-card{background:var(--bg-card);border-radius:12px;border:1px solid var(--border-color);padding:16px}.client-logins-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.client-login-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-elevated);border-radius:8px;transition:background .2s ease}.client-login-item:hover{background:#00bcd40d}.client-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.client-status-dot.online{background:var(--status-success);box-shadow:0 0 8px #10b98180}.client-status-dot.today{background:var(--status-success)}.client-status-dot.recent{background:var(--coach-primary)}.client-status-dot.week{background:var(--status-warning)}.client-status-dot.inactive{background:var(--status-error)}.client-status-dot.never{background:var(--text-muted)}.client-login-info{flex:1;min-width:0}.client-login-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.client-login-time{font-size:12px;color:var(--text-muted)}.no-logins{padding:32px;text-align:center;color:var(--text-muted)}.subscription-gate{min-height:100vh;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:24px}.subscription-gate.loading{flex-direction:column;gap:16px;color:var(--text-secondary)}.subscription-gate.loading .loading-subtext{font-size:13px;color:var(--text-muted);margin-top:-8px}.subscription-gate-content{max-width:900px;width:100%;text-align:center}.gate-icon{width:100px;height:100px;background:var(--status-warning-bg);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:var(--status-warning)}.subscription-gate h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 12px}.gate-subtitle{font-size:16px;color:var(--text-secondary);margin:0 0 32px}.gate-error{background:var(--status-error-bg);color:var(--status-error);padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:14px}.gate-plans{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:32px}.gate-plans.solo{grid-template-columns:1fr;max-width:350px;margin-left:auto;margin-right:auto}.gate-plan{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:28px;position:relative;transition:all .2s ease}.gate-plan:hover{border-color:var(--border-accent)}.gate-plan.highlighted{border:2px solid var(--coach-primary);box-shadow:0 0 30px var(--border-glow)}.plan-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);font-size:11px;font-weight:600;padding:4px 14px;border-radius:50px;white-space:nowrap}.gate-plan h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.plan-price{margin-bottom:8px}.plan-price .amount{font-size:36px;font-weight:700;color:var(--coach-primary)}.plan-price .period{font-size:14px;color:var(--text-muted)}.plan-desc{font-size:14px;color:var(--text-secondary);margin:0 0 20px}.plan-features{list-style:none;padding:0;margin:0 0 24px;text-align:left}.plan-features li{font-size:14px;color:var(--text-primary);padding:8px 0;border-bottom:1px solid var(--border-color);display:flex;align-items:center;gap:8px}.plan-features li:last-child{border-bottom:none}.plan-features li:before{content:"✓";color:var(--status-success);font-weight:600}.subscribe-btn{width:100%;background:var(--bg-elevated);color:var(--text-primary);font-size:14px;font-weight:600;padding:14px 24px;border-radius:10px;border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease}.subscribe-btn:hover:not(:disabled){border-color:var(--coach-primary);color:var(--coach-primary)}.subscribe-btn.primary{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);border:none}.subscribe-btn.primary:hover:not(:disabled){box-shadow:var(--shadow-glow);transform:translateY(-1px);color:var(--bg-primary)}.subscribe-btn:disabled{opacity:.6;cursor:not-allowed}.gate-footer{padding-top:24px;border-top:1px solid var(--border-color)}.gate-footer p{font-size:13px;color:var(--text-muted);margin:0 0 12px}.logout-link{background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;text-decoration:underline;transition:color .2s ease}.logout-link:hover{color:var(--coach-primary)}@media(max-width:768px){.gate-plans{grid-template-columns:1fr;max-width:350px;margin-left:auto;margin-right:auto}.subscription-gate h1{font-size:24px}.plan-price .amount{font-size:28px}}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 4px 20px #0000004d;animation:slideIn .3s ease;pointer-events:auto}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.toast-message{flex:1;font-size:14px;color:var(--text-primary);line-height:1.4}.toast-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.toast-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.toast-success{border-left:4px solid var(--status-success)}.toast-success .toast-icon{background:var(--status-success-bg);color:var(--status-success)}.toast-error{border-left:4px solid var(--status-error)}.toast-error .toast-icon{background:var(--status-error-bg);color:var(--status-error)}.toast-warning{border-left:4px solid var(--status-warning)}.toast-warning .toast-icon{background:var(--status-warning-bg);color:var(--status-warning)}.toast-info{border-left:4px solid var(--coach-primary)}.toast-info .toast-icon{background:var(--status-info-bg);color:var(--coach-primary)}@media(max-width:480px){.toast-container{left:16px;right:16px;bottom:16px;max-width:none}}.demo-mode-banner{background:linear-gradient(90deg,var(--status-warning-bg),rgba(245,158,11,.15));border-bottom:1px solid var(--status-warning);padding:8px 16px;position:relative;z-index:1001}.demo-mode-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:10px;text-align:center}.demo-mode-icon{font-size:14px}.demo-mode-text{font-size:12px;color:var(--text-primary)}.demo-mode-text strong{color:var(--status-warning)}.demo-mode-link{color:var(--coach-primary);text-decoration:none;font-weight:500;margin-left:4px}.demo-mode-link:hover{text-decoration:underline}@media(max-width:480px){.demo-mode-text{font-size:11px}.demo-mode-banner{padding:6px 12px}}.mobile-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:8px 0;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));z-index:100;justify-content:space-around}@media(max-width:991px){.mobile-bottom-nav{display:flex}.main-content{padding-bottom:80px!important}}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;transition:all .2s ease;min-width:60px;position:relative}.mobile-nav-item:hover{color:var(--text-secondary)}.mobile-nav-item.active{color:var(--coach-primary)}.mobile-nav-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center}.mobile-nav-icon svg{width:24px;height:24px}.mobile-nav-label{font-size:10px;font-weight:500;white-space:nowrap}.mobile-nav-item.active .mobile-nav-icon{transform:scale(1.1)}.mobile-more-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:150;animation:fadeIn .2s ease}@media(max-width:991px){.mobile-more-overlay{display:block}}.mobile-more-menu{position:fixed;bottom:70px;left:16px;right:16px;max-height:70vh;background:var(--bg-secondary);border-radius:16px;border:1px solid var(--border-color);overflow:hidden;animation:slideUp .25s ease;box-shadow:0 -4px 24px #0000004d}.mobile-more-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-color);font-weight:600;color:var(--text-primary)}.mobile-more-close{background:transparent;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:4px 8px;line-height:1}.mobile-more-close:hover{color:var(--text-primary)}.mobile-more-items{max-height:calc(70vh - 60px);overflow-y:auto;padding:8px 0}.mobile-more-section{padding:12px 20px 6px;font-size:11px;font-weight:700;color:var(--coach-primary);text-transform:uppercase;letter-spacing:.05em}.mobile-more-item{display:block;width:100%;padding:14px 20px;background:transparent;border:none;text-align:left;font-size:15px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.mobile-more-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.mobile-more-item.active{background:#00bcd41a;color:var(--coach-primary);font-weight:500}.notification-permission-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.notification-permission-modal{background:var(--bg-card, #1a1f2e);border:1px solid var(--border-color, #2d3748);border-radius:16px;padding:32px;max-width:400px;width:100%;text-align:center;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.permission-icon{width:64px;height:64px;margin:0 auto 20px;background:linear-gradient(135deg,var(--coach-primary, #06b6d4),var(--coach-accent, #0891b2));border-radius:50%;display:flex;align-items:center;justify-content:center}.permission-icon svg{width:32px;height:32px;color:#fff}.notification-permission-modal h2{margin:0 0 12px;font-size:22px;font-weight:700;color:var(--text-primary, #fff)}.permission-text{color:var(--text-secondary, #a0aec0);font-size:14px;line-height:1.6;margin:0 0 20px}.permission-benefits{list-style:none;padding:0;margin:0 0 24px;text-align:left}.permission-benefits li{display:flex;align-items:center;gap:10px;padding:8px 0;color:var(--text-secondary, #a0aec0);font-size:14px}.permission-benefits li svg{width:18px;height:18px;color:var(--coach-primary, #06b6d4);flex-shrink:0}.permission-instructions{text-align:left;background:var(--bg-secondary, #0f1419);border-radius:8px;padding:16px;margin-bottom:20px}.permission-instructions h4{margin:0 0 8px;font-size:13px;font-weight:600;color:var(--text-primary, #fff)}.permission-instructions h4:not(:first-child){margin-top:16px}.permission-instructions ol{margin:0;padding-left:20px;color:var(--text-secondary, #a0aec0);font-size:13px;line-height:1.8}.permission-instructions strong{color:var(--text-primary, #fff)}.permission-actions{display:flex;flex-direction:column;gap:10px}.btn-enable-notifications{width:100%;padding:14px 20px;background:linear-gradient(135deg,var(--coach-primary, #06b6d4),var(--coach-accent, #0891b2));color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.btn-enable-notifications:hover{transform:translateY(-1px);box-shadow:0 4px 12px #06b6d44d}.btn-enable-notifications:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-skip{width:100%;padding:12px 20px;background:transparent;color:var(--text-secondary, #a0aec0);border:1px solid var(--border-color, #2d3748);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-skip:hover{border-color:var(--text-secondary, #a0aec0);color:var(--text-primary, #fff)}@media(max-width:480px){.notification-permission-modal{padding:24px 20px;margin:16px}.permission-icon{width:56px;height:56px}.permission-icon svg{width:28px;height:28px}.notification-permission-modal h2{font-size:20px}}.sync-status-indicator{position:fixed;bottom:80px;left:16px;display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--card-bg, #1e1e2e);border-radius:20px;box-shadow:0 2px 12px #0000004d;z-index:1000;font-size:12px;font-weight:500;animation:slideIn .3s ease}.sync-status-indicator.offline{background:#ff6b6b;color:#fff}.sync-status-indicator.online{background:var(--card-bg, #1e1e2e);color:var(--text-secondary, #a0a0a0)}.sync-status-indicator.syncing{background:var(--primary-color, #037F0C);color:#fff}.sync-status-icon{display:flex;align-items:center;justify-content:center}.sync-status-icon .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.sync-status-text{white-space:nowrap}.sync-toast{position:fixed;bottom:130px;left:50%;transform:translate(-50%) translateY(20px);background:var(--card-bg, #1e1e2e);color:var(--text-primary, #fff);padding:12px 20px;border-radius:8px;box-shadow:0 4px 20px #0000004d;z-index:1001;font-size:14px;opacity:0;transition:all .3s ease;pointer-events:none}.sync-toast.show{opacity:1;transform:translate(-50%) translateY(0)}@media(max-width:768px){.sync-status-indicator{bottom:70px;left:12px;padding:6px 10px;font-size:11px}.sync-toast{bottom:120px;width:calc(100% - 32px);max-width:300px;text-align:center}}:root{--color-bg-primary: #0a0e17;--color-bg-secondary: #111827;--color-bg-card: #1a2332;--color-bg-elevated: #243044;--color-bg-input: #0f1419;--color-border-base: #2d3a4f;--color-border-accent: #06b6d4;--color-border-glow: rgba(6, 182, 212, .3);--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-text-inverse: #0a0e17;--color-success: #22c55e;--color-success-bg: rgba(34, 197, 94, .15);--color-success-glow: rgba(34, 197, 94, .3);--color-warning: #eab308;--color-warning-bg: rgba(234, 179, 8, .15);--color-warning-glow: rgba(234, 179, 8, .3);--color-danger: #ef4444;--color-danger-bg: rgba(239, 68, 68, .15);--color-danger-glow: rgba(239, 68, 68, .3);--color-info: #06b6d4;--color-info-bg: rgba(6, 182, 212, .15);--color-info-glow: rgba(6, 182, 212, .3);--color-brand-primary: #06b6d4;--color-brand-secondary: #1a2332;--color-brand-accent: #22c55e;--bg-primary: var(--color-bg-primary);--bg-secondary: var(--color-bg-secondary);--bg-card: var(--color-bg-card);--bg-elevated: var(--color-bg-elevated);--bg-input: var(--color-bg-input);--border-color: var(--color-border-base);--border-accent: var(--color-border-accent);--border-glow: var(--color-border-glow);--text-primary: var(--color-text-primary);--text-secondary: var(--color-text-secondary);--text-muted: var(--color-text-muted);--status-success: var(--color-success);--status-success-bg: var(--color-success-bg);--status-warning: var(--color-warning);--status-warning-bg: var(--color-warning-bg);--status-danger: var(--color-danger);--status-danger-bg: var(--color-danger-bg);--status-info: var(--color-info);--status-info-bg: var(--color-info-bg);--coach-primary: var(--color-brand-primary);--coach-secondary: var(--color-brand-secondary);--coach-accent: var(--color-brand-accent);--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-xs: var(--space-1);--space-sm: var(--space-2);--space-md: var(--space-4);--space-lg: var(--space-6);--space-xl: var(--space-8);--space-2xl: var(--space-12);--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif;--font-mono: "Monaco", "Menlo", "Courier New", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--text-6xl: 3.75rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--leading-none: 1;--leading-tight: 1.25;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--tracking-tighter: -.05em;--tracking-tight: -.025em;--tracking-normal: 0;--tracking-wide: .025em;--tracking-wider: .05em;--tracking-widest: .1em;--radius-none: 0;--radius-sm: .375rem;--radius-base: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--z-base: 1;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 900;--z-modal: 1000;--z-popover: 1100;--z-tooltip: 1200;--z-notification: 1300;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .3);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-base: 0 4px 6px rgba(0, 0, 0, .4);--shadow-md: 0 6px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .5);--shadow-2xl: 0 25px 80px rgba(0, 0, 0, .6);--shadow-glow-sm: 0 0 10px var(--color-border-glow);--shadow-glow: 0 0 20px var(--color-border-glow);--shadow-glow-lg: 0 0 30px var(--color-border-glow);--shadow-focus: 0 0 0 3px var(--color-info-bg);--duration-fast: .15s;--duration-base: .2s;--duration-slow: .3s;--duration-slower: .5s;--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--transition-colors: color var(--duration-base) var(--ease-out), background-color var(--duration-base) var(--ease-out), border-color var(--duration-base) var(--ease-out);--transition-transform: transform var(--duration-base) var(--ease-out);--transition-opacity: opacity var(--duration-base) var(--ease-out);--transition-all: var(--transition-colors), var(--transition-transform), var(--transition-opacity), box-shadow var(--duration-base) var(--ease-out);--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px;--container-sm: 640px;--container-md: 768px;--container-lg: 1024px;--container-xl: 1280px;--container-2xl: 1400px;--button-padding-sm: var(--space-2) var(--space-4);--button-padding-base: var(--space-3) var(--space-6);--button-padding-lg: var(--space-4) var(--space-8);--input-padding: var(--space-3) var(--space-4);--input-border-width: 1px;--card-padding: var(--space-6);--card-border-width: 1px;--header-height: 64px;--sidebar-width: 280px}[data-theme=light]{--color-bg-primary: #ffffff;--color-bg-secondary: #f8fafc;--color-bg-card: #ffffff;--color-bg-elevated: #f1f5f9;--color-bg-input: #ffffff;--color-border-base: #e2e8f0;--color-border-accent: #06b6d4;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-text-inverse: #ffffff}@media(prefers-reduced-motion:reduce){:root{--duration-fast: 0ms;--duration-base: 0ms;--duration-slow: 0ms;--duration-slower: 0ms}*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.stepper-container{display:flex;align-items:center;gap:.5rem;background:var(--color-bg-input, #0f1419);border:1px solid var(--color-border-base, #2d3a4f);border-radius:var(--radius-md, 12px);padding:.35rem}.stepper-btn{width:44px;height:44px;min-width:44px;display:flex;align-items:center;justify-content:center;background:var(--color-brand-primary, #06b6d4);color:#fff;border:none;border-radius:var(--radius-base, 8px);font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.stepper-btn:hover{transform:scale(1.05);box-shadow:0 4px 15px #06b6d466}.stepper-btn:active{transform:scale(.95)}.stepper-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.stepper-value{flex:1;text-align:center;font-size:1.5rem;font-weight:700;color:var(--color-text-primary, #f1f5f9);min-width:60px}.stepper-value-small{font-size:1.125rem}.stepper-input{flex:1;text-align:center;font-size:1.25rem;font-weight:600;color:var(--color-text-primary, #f1f5f9);background:transparent;border:none;outline:none;min-width:60px;padding:.5rem}.stepper-input:focus{background:#06b6d41a;border-radius:var(--radius-sm, 6px)}.stepper-container.compact{padding:.25rem}.stepper-container.compact .stepper-btn{width:36px;height:36px;min-width:36px;font-size:1rem}.stepper-container.compact .stepper-value{font-size:1.25rem;min-width:50px}.stepper-inline{display:flex;gap:.5rem}.stepper-inline .stepper-btn-inline{flex:1;padding:.5rem .75rem;background:var(--color-bg-elevated, #243044);color:var(--color-text-primary, #f1f5f9);border:1px solid var(--color-border-base, #2d3a4f);border-radius:var(--radius-sm, 6px);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.stepper-inline .stepper-btn-inline:hover{background:#06b6d426;border-color:var(--color-brand-primary, #06b6d4);color:var(--color-brand-primary, #06b6d4)}.stepper-inline .stepper-btn-inline:active{transform:scale(.95)}.stepper-card{background:var(--color-bg-card, #1a2332);border:1px solid var(--color-border-base, #2d3a4f);border-radius:var(--radius-md, 12px);padding:1rem}.stepper-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.stepper-card-header label{font-size:.875rem;font-weight:600;color:var(--color-text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.05em}.stepper-card-header .indicator{width:4px;height:16px;background:var(--color-brand-primary, #06b6d4);border-radius:2px;margin-right:.5rem}.stepper-card-header-row{display:flex;align-items:center}@media(max-width:480px){.stepper-btn{width:40px;height:40px;min-width:40px;font-size:1.125rem}.stepper-value{font-size:1.25rem;min-width:50px}.stepper-container.compact .stepper-btn{width:32px;height:32px;min-width:32px}}*{margin:0;padding:0;box-sizing:border-box}:root{--aws-sky-blue: var(--coach-primary, #06b6d4);--aws-dark-blue: var(--bg-secondary, #111827);--aws-light-gray: var(--bg-elevated, #243044);--aws-gray: var(--text-secondary, #94a3b8);--white: var(--bg-card, #1a2332);--border-gray: var(--border-color, #2d3a4f);--success: var(--status-success, #22c55e);--warning: var(--status-warning, #eab308);--error: var(--status-danger, #ef4444);--primary-green: var(--status-success, #22c55e);--focus-ring: var(--shadow-focus, 0 0 0 3px rgba(6, 182, 212, .4))}body{font-family:var(--font-sans, -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", sans-serif);background-color:var(--bg-primary, #0a0e17);color:var(--text-primary, #f1f5f9);line-height:var(--leading-normal, 1.6);min-height:100vh;scrollbar-gutter:stable}html{scrollbar-gutter:stable;overflow-y:scroll}#root{min-height:100vh}.container{max-width:var(--container-2xl, 1400px);margin:0 auto;padding:0 var(--space-lg, 1.5rem)}button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,a:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:none;box-shadow:var(--shadow-focus, 0 0 0 3px rgba(6, 182, 212, .4))}button:focus,input:focus,textarea:focus,select:focus,a:focus{outline:2px solid transparent;outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:var(--coach-primary);color:var(--bg-primary);padding:var(--space-sm) var(--space-md);z-index:9999;transition:top .2s}.skip-link:focus{top:0}button{cursor:pointer;border:none;font-family:inherit;transition:all .2s ease}button:hover{opacity:.9}button:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:linear-gradient(135deg,var(--coach-primary),var(--coach-accent));color:var(--bg-primary);padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;border:none;transition:all .2s ease}.btn-primary:hover{box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-secondary{background:transparent;color:var(--text-primary);padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--coach-primary);color:var(--coach-primary)}.btn-action{background:transparent;color:var(--coach-primary);padding:8px 16px;border-radius:6px;font-size:13px;font-weight:500;border:1px solid var(--coach-primary)}.btn-action:hover{background:var(--status-info-bg)}.btn-danger{background:var(--status-danger);color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:600;border:none}.btn-danger:hover{background:#dc2626}input,textarea,select{font-family:inherit;border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;font-size:14px;background:var(--bg-input);color:var(--text-primary);transition:all .2s ease}input::placeholder,textarea::placeholder{color:var(--text-muted)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--coach-primary);box-shadow:var(--focus-ring)}input:disabled,textarea:disabled,select:disabled{background:var(--bg-secondary);cursor:not-allowed;opacity:.6}.page-title{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 24px}.section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 16px;text-transform:uppercase;letter-spacing:.05em}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:24px;transition:all .2s ease}.card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--bg-card);padding:24px;border-radius:12px;border:1px solid var(--border-color);position:relative;overflow:hidden;transition:all .2s ease}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--coach-primary),var(--coach-accent))}.stat-card:hover{border-color:var(--border-accent);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.stat-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;color:var(--coach-primary)}.status-badge{display:inline-flex;align-items:center;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.status-badge.active,.status-badge.success{background:var(--status-success-bg);color:var(--status-success);border:1px solid var(--status-success)}.status-badge.pending,.status-badge.warning{background:var(--status-warning-bg);color:var(--status-warning);border:1px solid var(--status-warning)}.status-badge.inactive,.status-badge.danger,.status-badge.error{background:var(--status-danger-bg);color:var(--status-danger);border:1px solid var(--status-danger)}.status-badge.info{background:var(--status-info-bg);color:var(--status-info);border:1px solid var(--status-info)}table{width:100%;border-collapse:collapse}th{padding:16px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--bg-secondary);border-bottom:2px solid var(--border-color)}td{padding:16px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}tbody tr{transition:background .2s ease}tbody tr:hover{background:var(--bg-elevated)}.no-data{text-align:center;padding:60px 20px;color:var(--text-muted)}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.form-group small{display:block;font-size:12px;color:var(--text-muted);margin-top:6px}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:18px;color:var(--text-primary)}.modal-body{padding:24px}.modal-actions{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color)}.close-btn{background:none;border:none;font-size:24px;color:var(--text-muted);cursor:pointer;padding:0;line-height:1;transition:color .2s}.close-btn:hover{color:var(--text-primary)}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--coach-primary)}.loading{text-align:center;padding:60px 20px;color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--coach-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.message{padding:16px 20px;border-radius:8px;font-size:14px;margin-bottom:16px}.message.success{background:var(--status-success-bg);color:var(--status-success);border:1px solid var(--status-success)}.message.error{background:var(--status-danger-bg);color:var(--status-danger);border:1px solid var(--status-danger)}.message.warning{background:var(--status-warning-bg);color:var(--status-warning);border:1px solid var(--status-warning)}.message.info{background:var(--status-info-bg);color:var(--status-info);border:1px solid var(--status-info)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media(max-width:768px){.container{padding:0 var(--space-md)}.stats-grid{grid-template-columns:1fr}.stat-value{font-size:28px}}
