*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg);background-image:var(--bg-image,none);color:var(--text);background-position:50%;background-size:cover;background-attachment:fixed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:background-color .3s,color .3s}.app-layout{min-height:100vh;display:flex}.sidebar{background:0 0;border-right:none;flex-direction:column;width:220px;height:100vh;padding:1rem;transition:width .2s;display:flex;position:sticky;top:0}.sidebar.collapsed{width:60px}.sidebar-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.logo{color:var(--text);white-space:nowrap;font-size:.9rem;font-weight:700;overflow:hidden}.collapse-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:1rem}.sidebar-nav{flex-direction:column;flex:1;gap:.25rem;display:flex}.nav-link{color:var(--text-muted);border:1px solid #0000;border-radius:8px;align-items:center;gap:.75rem;padding:.6rem .75rem;text-decoration:none;transition:all .15s;display:flex}.nav-link:hover{background:var(--glass-hover);color:var(--text)}.nav-link.active{background:var(--glass-active);color:var(--accent);font-weight:600}.nav-icon{font-size:1.1rem}.nav-label{font-size:.85rem}.sidebar-footer{flex-direction:column;gap:.75rem;margin-top:auto;display:flex}.user-card{background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem;display:flex}.user-avatar{font-size:1.5rem}.user-info{flex:1}.user-name{color:var(--text);font-size:.8rem;font-weight:600}.xp-bar{background:var(--glass-border);border-radius:2px;height:4px;margin-top:4px}.xp-fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s}.theme-switcher{align-items:center;gap:.5rem;display:flex}.dark-toggle{cursor:pointer;background:0 0;border:none;font-size:1.2rem}.theme-select{color:var(--text);background:0 0;border:none;border-radius:6px;flex:1;padding:.3rem;font-size:.75rem}.main-content{flex:1;min-height:100vh;padding:2rem;overflow-y:auto}.card{box-shadow:none;background:0 0;border:none;border-radius:12px;padding:1.25rem;transition:background .2s}.card:hover{background:var(--glass-hover)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.kpi-card{text-align:center}.kpi-value{color:var(--accent);font-size:2rem;font-weight:700}.kpi-label{color:var(--text-muted);margin-top:.25rem;font-size:.8rem}.page-header{margin-bottom:1.5rem}.page-header h1{font-size:1.5rem;font-weight:700}.page-header p{color:var(--text-muted);margin-top:.25rem;font-size:.85rem}.chart-container{margin-bottom:2rem}.participant-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;display:grid}.participant-card{align-items:center;gap:1rem;display:flex}.participant-avatar{border:3px solid var(--accent);border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:2.5rem;display:flex}.participant-info{flex:1}.participant-name{font-size:.9rem;font-weight:600}.participant-goals{flex-wrap:wrap;gap:.25rem;margin-top:.25rem;display:flex}.goal-chip{background:var(--glass-active);color:var(--accent);border-radius:12px;padding:.15rem .5rem;font-size:.65rem}.week-grid{grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:.5rem;display:grid}.week-cell{text-align:center;background:0 0;border:none;border-radius:8px;padding:.75rem .5rem;font-size:.75rem}.week-cell.done{background:var(--success-bg);color:var(--success)}.week-cell.missed{background:var(--danger-bg);opacity:.7}.week-cell.current{box-shadow:0 0 12px var(--accent-border);background:var(--glass-active)}.week-cell.future{opacity:.4}.wizard-steps{gap:.5rem;margin-bottom:2rem;display:flex}.wizard-step{text-align:center;background:0 0;border:none;border-radius:8px;flex:1;padding:.5rem;font-size:.75rem}.wizard-step.active{background:var(--glass-active);color:var(--accent);font-weight:600}.wizard-content{min-height:300px}.wizard-nav{justify-content:space-between;margin-top:2rem;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1.5rem;font-size:.85rem;font-weight:600;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-secondary{color:var(--text);background:0 0;border:none}.btn-secondary:hover{background:var(--glass-hover)}.journal-entry{margin-bottom:1rem}.journal-date{color:var(--text-muted);font-size:.75rem}.journal-text{margin-top:.5rem;line-height:1.6}.journal-insights{background:var(--glass-active);border:none;border-radius:8px;margin-top:.5rem;padding:.75rem;font-size:.8rem}.log-form{flex-direction:column;gap:1rem;max-width:500px;display:flex}.form-group label{color:var(--text-muted);margin-bottom:.25rem;font-size:.8rem;display:block}.form-group input,.form-group select,.form-group textarea{background:var(--glass-hover);width:100%;color:var(--text);border:none;border-radius:8px;padding:.6rem;font-size:.85rem;transition:background .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:var(--glass-active);outline:none}body,body.theme-default.dark{--bg:#0f1729;--bg-image:url(/bg-default-dm.png);--sidebar-bg:#0a1020a6;--sidebar-image:none;--text:#e8eaf0;--text-muted:#8892a4;--accent:#f59e0b;--accent-border:#f59e0b4d;--glass-card:#0f17298c;--glass-border:#ffffff0f;--glass-border-hover:#ffffff1f;--glass-hover:#ffffff0a;--glass-active:#f59e0b14;--card-shadow:0 4px 24px #0000004d, inset 0 1px 0 #ffffff08;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a}body.theme-default.light{--bg:#f5f5f0;--bg-image:url(/bg-default-lm.png);--sidebar-bg:#ffffff80;--sidebar-image:none;--text:#1a1a1a;--text-muted:#6b7280;--accent:#d97706;--accent-border:#d977064d;--glass-card:#ffffff8c;--glass-border:#0000000f;--glass-border-hover:#0000001f;--glass-hover:#00000008;--glass-active:#d9770614;--card-shadow:0 4px 24px #0000000f, inset 0 1px 0 #fffc;--success:#16a34a;--success-bg:#16a34a14;--danger:#dc2626;--danger-bg:#dc262614}body.theme-rose-gold.dark{--bg:#1a1210;--bg-image:none;--sidebar-bg:#140e0ce6;--sidebar-image:none;--text:#f4e8e8;--text-muted:#c4a0a0;--accent:#b76e79;--accent-border:#b76e794d;--glass-card:#3c1e1473;--glass-border:#b76e791f;--glass-border-hover:#b76e7940;--glass-hover:#b76e790f;--glass-active:#b76e791f;--card-shadow:0 4px 24px #0000004d, inset 0 1px 0 #b76e790d;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a}body.theme-rose-gold.light{--bg:#fff5f5;--bg-image:none;--sidebar-bg:#fffc;--sidebar-image:none;--text:#1d1d1f;--text-muted:#6b5c5c;--accent:#b76e79;--accent-border:#b76e7940;--glass-card:#fff9;--glass-border:#b76e791a;--glass-border-hover:#b76e7933;--glass-hover:#b76e790a;--glass-active:#b76e7914;--card-shadow:0 4px 24px #0000000a, inset 0 1px 0 #ffffffe6;--success:#16a34a;--success-bg:#16a34a14;--danger:#dc2626;--danger-bg:#dc262614}body.theme-lavender.dark{--bg:#0f0a1a;--bg-image:none;--sidebar-bg:#0a0714e6;--sidebar-image:none;--text:#e8e4f0;--text-muted:#a89cc4;--accent:#b4a7d6;--accent-border:#b4a7d64d;--glass-card:#1e0f3280;--glass-border:#b4a7d61a;--glass-border-hover:#b4a7d633;--glass-hover:#b4a7d60f;--glass-active:#b4a7d61a;--card-shadow:0 4px 24px #0000004d, inset 0 1px 0 #b4a7d60a;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a}body.theme-lavender.light{--bg:#f8f5ff;--bg-image:none;--sidebar-bg:#fffc;--sidebar-image:none;--text:#1a1a2e;--text-muted:#6b5c8a;--accent:#7c3aed;--accent-border:#7c3aed40;--glass-card:#fff9;--glass-border:#7c3aed14;--glass-border-hover:#7c3aed29;--glass-hover:#7c3aed08;--glass-active:#7c3aed14;--card-shadow:0 4px 24px #0000000a, inset 0 1px 0 #ffffffe6;--success:#16a34a;--success-bg:#16a34a14;--danger:#dc2626;--danger-bg:#dc262614}body.theme-champagne.dark{--bg:#1a1a1a;--bg-image:none;--sidebar-bg:#141414e6;--sidebar-image:none;--text:#f0ece4;--text-muted:#b8a88c;--accent:#f7e7ce;--accent-border:#f7e7ce33;--glass-card:#28231980;--glass-border:#f7e7ce14;--glass-border-hover:#f7e7ce29;--glass-hover:#f7e7ce0a;--glass-active:#f7e7ce14;--card-shadow:0 4px 24px #0000004d, inset 0 1px 0 #f7e7ce08;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a}body.theme-champagne.light{--bg:#fffaf5;--bg-image:none;--sidebar-bg:#fffc;--sidebar-image:none;--text:#1a1a1a;--text-muted:#7a6b55;--accent:#c8860a;--accent-border:#c8860a33;--glass-card:#fff9;--glass-border:#c8aa781a;--glass-border-hover:#c8aa7833;--glass-hover:#c8aa780a;--glass-active:#c8860a0f;--card-shadow:0 4px 24px #0000000a, inset 0 1px 0 #ffffffe6;--success:#16a34a;--success-bg:#16a34a14;--danger:#dc2626;--danger-bg:#dc262614}body.theme-tactical.dark{--bg:#0a0a0a;--bg-image:none;--sidebar-bg:#050505f2;--sidebar-image:none;--text:#e0e8f0;--text-muted:#7a8fa8;--accent:#2196f3;--accent-border:#2196f34d;--glass-card:#0a142899;--glass-border:#2196f31a;--glass-border-hover:#2196f340;--glass-hover:#2196f30f;--glass-active:#2196f31a;--card-shadow:0 4px 24px #0006, 0 0 1px #2196f333;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a;font-family:JetBrains Mono,Fira Code,monospace}body.theme-tactical.light{--bg:#f0f2f5;--bg-image:none;--sidebar-bg:#ffffffe6;--sidebar-image:none;--text:#0a0a0a;--text-muted:#4a5568;--accent:#1565c0;--accent-border:#1565c033;--glass-card:#ffffffb3;--glass-border:#1565c014;--glass-border-hover:#1565c029;--glass-hover:#1565c008;--glass-active:#1565c014;--card-shadow:0 4px 24px #0000000d;--success:#16a34a;--success-bg:#16a34a14;--danger:#dc2626;--danger-bg:#dc262614}body.theme-gunmetal.dark{--bg:#1a1a2e;--bg-image:none;--sidebar-bg:#12121fe6;--sidebar-image:none;--text:#d0d8e0;--text-muted:#7a8a9c;--accent:#8ca0b8;--accent-border:#8ca0b833;--glass-card:#1b28388c;--glass-border:#6478961f;--glass-border-hover:#64789640;--glass-hover:#6478960f;--glass-active:#8ca0b81a;--card-shadow:0 4px 24px #0000004d, inset 0 1px 0 #ffffff05;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a}body.theme-gunmetal.light{--bg:#e8e8e8;--bg-image:none;--sidebar-bg:#f5f5f5e6;--sidebar-image:none;--text:#1a1a2e;--text-muted:#4a5060;--accent:#3a5070;--accent-border:#3a507033;--glass-card:#ffffffa6;--glass-border:#323c5014;--glass-border-hover:#323c5029;--glass-hover:#323c5008;--glass-active:#3a507014;--card-shadow:0 4px 24px #0000000d;--success:#16a34a;--success-bg:#16a34a14;--danger:#dc2626;--danger-bg:#dc262614}body.theme-midnight.dark{--bg:#0a0e1a;--bg-image:none;--sidebar-bg:#060910f2;--sidebar-image:none;--text:#d0e8ff;--text-muted:#5a8ab0;--accent:#00a3ff;--accent-border:#00a3ff4d;--glass-card:#0a14288c;--glass-border:#00a3ff1a;--glass-border-hover:#00a3ff40;--glass-hover:#00a3ff0d;--glass-active:#00a3ff1a;--card-shadow:0 4px 24px #0006, 0 0 2px #00a3ff26;--success:#22c55e;--success-bg:#22c55e1a;--danger:#ef4444;--danger-bg:#ef44441a}body.theme-midnight.light{--bg:#f5f7fa;--bg-image:none;--sidebar-bg:#ffffffe6;--sidebar-image:none;--text:#0a0e1a;--text-muted:#4a6080;--accent:#0070c0;--accent-border:#0070c033;--glass-card:#ffffffb3;--glass-border:#0064b40f;--glass-border-hover:#0064b424;--glass-hover:#0064b408;--glass-active:#0070c014;--card-shadow:0 4px 24px #0000000a;--success:#16a34a;--success-bg:#16a34a14;--danger:#dc2626;--danger-bg:#dc262614}.auth-page{min-height:100dvh;display:flex}.auth-hero{background:50%/cover no-repeat;flex:1;align-items:flex-end;padding:3rem;display:flex;position:relative}.auth-hero-overlay{background:linear-gradient(#0000 50%,#000000b3 100%);position:absolute;inset:0}.auth-hero-content{z-index:1;position:relative}.auth-brand{color:#fff;margin:0;font-size:2rem;font-weight:700}.auth-tagline{color:#fffc;margin-top:.5rem;font-size:1.1rem}.auth-panel{background:var(--bg);justify-content:center;align-items:center;width:420px;min-width:380px;padding:2rem;display:flex}.auth-form-wrapper{width:100%;max-width:340px}.auth-title{color:var(--text);margin:0;font-size:1.5rem;font-weight:700}.auth-subtitle{color:var(--text-muted);margin-top:.5rem;margin-bottom:2rem;font-size:.85rem}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.auth-field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.4rem;font-size:.8rem;font-weight:500;display:block}.auth-field input{border:1px solid var(--glass-border);background:var(--glass);width:100%;color:var(--text);border-radius:8px;padding:.75rem 1rem;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb,33,150,243), .15);outline:none}.auth-field input::placeholder{color:var(--text-muted);opacity:.6}.auth-error{background:var(--danger-bg);color:var(--danger);border-radius:8px;padding:.6rem 1rem;font-size:.85rem}.auth-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;width:100%;margin-top:.5rem;padding:.85rem;font-size:1rem;font-weight:600;transition:opacity .2s,transform .1s}.auth-btn:hover{opacity:.9}.auth-btn:active{transform:scale(.98)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-switch{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.85rem}.auth-switch button{color:var(--accent);cursor:pointer;background:0 0;border:none;margin-left:.4rem;font-weight:600}.auth-switch button:hover{text-decoration:underline}@media (width<=768px){.auth-page{flex-direction:column}.auth-hero{flex:none;min-height:200px}.auth-panel{width:100%;min-width:unset}}.setup-progress{gap:.75rem;margin-bottom:2rem;display:flex}.setup-dot{background:var(--glass);border:2px solid var(--glass-border);width:32px;height:32px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.setup-dot.active{background:var(--accent);border-color:var(--accent);color:#fff}.setup-dot.done{background:var(--success);border-color:var(--success);color:#fff}.setup-nav{gap:.75rem;margin-top:2rem;display:flex}.setup-nav .auth-btn{flex:1}.auth-btn-secondary{border:1px solid var(--glass-border);color:var(--text);cursor:pointer;background:0 0;border-radius:8px;padding:.85rem 1.5rem;font-size:.9rem;font-weight:500}.auth-btn-secondary:hover{background:var(--glass-hover)}.avatar-grid{grid-template-columns:repeat(8,1fr);gap:.4rem;margin-top:1rem;display:grid}.avatar-option{aspect-ratio:1;border:2px solid var(--glass-border);background:var(--glass);cursor:pointer;border-radius:8px;width:100%;font-size:1.3rem;transition:border-color .15s,transform .1s}.avatar-option:hover{border-color:var(--accent);transform:scale(1.1)}.avatar-option.selected{border-color:var(--accent);background:var(--glass-hover);transform:scale(1.1)}.goal-select-grid{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.goal-select-chip{border:1px solid var(--glass-border);background:var(--glass);color:var(--text);cursor:pointer;border-radius:20px;padding:.5rem 1rem;font-size:.8rem;transition:all .15s}.goal-select-chip:hover{border-color:var(--accent)}.goal-select-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.auth-field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:500}.logo-img{object-fit:contain;border-radius:8px;width:36px;height:36px}.logo-text{font-size:.95rem;font-weight:600}.auth-logo{object-fit:contain;width:180px;height:auto;margin-bottom:.5rem}.nav-icon-img{object-fit:contain;width:32px;height:32px}.ff-login-page{background:#060b16;min-height:100dvh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.ff-hero{background:url(/bg-login-hero.png) 0/cover no-repeat;flex:1;align-items:flex-start;padding:2.5rem;display:flex;position:relative}.ff-hero-overlay{background:linear-gradient(90deg,#060b164d 0%,#060b16b3 85%,#060b16f2 100%);position:absolute;inset:0}.ff-hero-content{z-index:1;flex-direction:column;justify-content:space-between;max-width:500px;height:100%;display:flex;position:relative}.ff-brand{align-items:center;gap:.75rem;display:flex}.ff-brand-logo{object-fit:contain;width:48px;height:48px}.ff-brand-name{color:#f5f7fa;letter-spacing:1px;font-size:1.1rem;font-weight:700;display:block}.ff-brand-sub{color:#a7b3c7;letter-spacing:2px;font-size:.7rem;font-weight:500;display:block}.ff-tagline{margin-top:3rem}.ff-tagline span{color:#f5f7fa;letter-spacing:-.5px;font-size:2.8rem;font-weight:800;line-height:1.1;display:block}.ff-tagline-accent{color:#f59e0b!important}.ff-hero-desc{color:#a7b3c7;margin-top:1.5rem;font-size:.95rem;line-height:1.7}.ff-features{gap:1.5rem;margin-top:auto;padding-top:3rem;display:flex}.ff-feature{text-align:center;flex-direction:column;align-items:center;gap:.5rem;display:flex}.ff-feature-icon{color:#00e5ff;background:#00e5ff0d;border:1.5px solid #00e5ff4d;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.1rem;display:flex}.ff-feature span:last-child{color:#a7b3c7;font-size:.65rem;line-height:1.3}.ff-panel{background:linear-gradient(135deg,#060b16 0%,#0a1630 45%,#030712 100%);border-left:1px solid #ffffff0a;justify-content:center;align-items:center;width:420px;min-width:380px;padding:2.5rem;display:flex}.ff-panel-inner{width:100%;max-width:340px}.ff-logo{object-fit:contain;width:80px;height:80px;margin:0 auto 1.25rem;display:block}.ff-title{color:#f5f7fa;text-align:center;margin:0;font-size:1.5rem;font-weight:700}.ff-subtitle{color:#a7b3c7;text-align:center;margin-top:.5rem;margin-bottom:2rem;font-size:.85rem}.ff-form{flex-direction:column;gap:1.25rem;display:flex}.ff-field{flex-direction:column;gap:.4rem;display:flex}.ff-field-label{color:#a7b3c7;text-transform:uppercase;letter-spacing:.8px;font-size:.75rem;font-weight:600}.ff-input-wrap{align-items:center;display:flex;position:relative}.ff-input-icon{color:#6e7a91;pointer-events:none;width:18px;height:18px;position:absolute;left:.85rem}.ff-input-wrap input{color:#f5f7fa;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a1630b8;border:1px solid #ffffff14;border-radius:10px;width:100%;padding:.8rem 1rem .8rem 2.75rem;font-size:.9rem;transition:border-color .2s,box-shadow .2s}.ff-input-wrap input:focus{border-color:#00e5ff80;outline:none;box-shadow:0 0 0 3px #00e5ff1a,0 0 24px #00e5ff14}.ff-input-wrap input::placeholder{color:#6e7a91}.ff-eye-btn{color:#6e7a91;cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1rem;position:absolute;right:.75rem}.ff-error{color:#ef4444;background:#ef44441a;border:1px solid #ef444433;border-radius:8px;padding:.6rem 1rem;font-size:.85rem}.ff-btn{color:#060b16;cursor:pointer;background:linear-gradient(135deg,#f59e0b,#ffb547);border:none;border-radius:10px;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:.5rem;padding:.85rem 1.5rem;font-size:1rem;font-weight:700;transition:opacity .2s,transform .1s,box-shadow .2s;display:flex;box-shadow:0 4px 20px #f59e0b40}.ff-btn:hover{opacity:.92;box-shadow:0 6px 28px #f59e0b59}.ff-btn:active{transform:scale(.98)}.ff-btn:disabled{opacity:.5;cursor:not-allowed}.ff-btn-arrow{font-size:1.2rem;font-weight:400}.ff-btn-secondary{color:#f5f7fa;cursor:pointer;background:0 0;border:1px solid #ffffff14;border-radius:10px;padding:.85rem 1.5rem;font-size:.9rem;font-weight:500;transition:background .15s}.ff-btn-secondary:hover{background:#ffffff0a}.ff-switch{text-align:center;color:#6e7a91;margin-top:1.75rem;font-size:.85rem}.ff-switch button{color:#f59e0b;cursor:pointer;background:0 0;border:none;margin-left:.4rem;font-weight:600}.ff-switch button:hover{text-decoration:underline}.ff-setup-progress{justify-content:center;gap:.75rem;margin-bottom:2rem;display:flex}.ff-setup-dot{color:#6e7a91;background:#0a1630b8;border:2px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:600;display:flex}.ff-setup-dot.active{color:#060b16;background:linear-gradient(135deg,#f59e0b,#ffb547);border-color:#f59e0b}.ff-setup-dot.done{color:#060b16;background:#14f1d9;border-color:#14f1d9}.ff-setup-nav{gap:.75rem;margin-top:2rem;display:flex}.ff-setup-nav .ff-btn{flex:1}.ff-avatar-grid{grid-template-columns:repeat(8,1fr);gap:.4rem;margin-top:.75rem;display:grid}.ff-avatar-opt{aspect-ratio:1;cursor:pointer;background:#0a1630b8;border:2px solid #ffffff0f;border-radius:8px;width:100%;font-size:1.3rem;transition:border-color .15s,transform .1s}.ff-avatar-opt:hover{border-color:#00e5ff;transform:scale(1.1)}.ff-avatar-opt.selected{background:#00e5ff14;border-color:#00e5ff;transform:scale(1.1)}.ff-goal-grid{flex-wrap:wrap;gap:.5rem;margin-top:.75rem;display:flex}.ff-goal-chip{color:#a7b3c7;cursor:pointer;background:#0a1630b8;border:1px solid #ffffff14;border-radius:20px;padding:.5rem 1rem;font-size:.8rem;transition:all .15s}.ff-goal-chip:hover{color:#f5f7fa;border-color:#00e5ff4d}.ff-goal-chip.active{color:#00e5ff;background:#00e5ff1a;border-color:#00e5ff;box-shadow:0 0 12px #00e5ff26}@media (width<=900px){.ff-login-page{flex-direction:column}.ff-hero{flex:none;min-height:300px;padding:1.5rem}.ff-hero-content{max-width:100%}.ff-tagline span{font-size:2rem}.ff-features{flex-wrap:wrap;gap:1rem}.ff-panel{width:100%;min-width:unset;padding:2rem 1.5rem}}@media (width<=480px){.ff-tagline span{font-size:1.6rem}.ff-features{display:none}.ff-hero{min-height:200px}}.ff-app{color:#f5f7fa;background:linear-gradient(135deg,#060b16 0%,#0a1630 45%,#030712 100%);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.ff-sidebar{border-right:1px solid #ffffff0a;flex-direction:column;width:200px;height:100vh;padding:1.25rem .75rem;display:flex;position:sticky;top:0;overflow-y:auto}.ff-sidebar-brand{align-items:center;gap:.6rem;margin-bottom:1.5rem;padding:0 .5rem;display:flex}.ff-sidebar-logo{object-fit:contain;width:38px;height:38px}.ff-sidebar-name{color:#f5f7fa;font-size:.9rem;font-weight:700}.ff-sidebar-nav{flex-direction:column;flex:1;gap:.2rem;display:flex}.ff-nav-link{color:#a7b3c7;border:1px solid #0000;border-radius:8px;align-items:center;gap:.6rem;padding:.55rem .75rem;font-size:.82rem;text-decoration:none;transition:all .15s;display:flex}.ff-nav-link:hover{color:#f5f7fa;background:#ffffff0a}.ff-nav-link.active{color:#f59e0b;background:#f59e0b1a;border-color:#f59e0b33;font-weight:600}.ff-nav-icon{flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.ff-nav-icon svg{width:18px;height:18px}.ff-nav-label{white-space:nowrap}.ff-sidebar-user{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a163066;border:1px solid #ffffff0f;border-radius:10px;margin-top:auto;padding:.75rem}.ff-sidebar-level{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#0a163066;border:1px solid #ffffff0f;border-radius:10px;margin-top:.5rem;padding:.75rem}.ff-user-top{align-items:center;gap:.6rem;display:flex}.ff-user-avatar{background:#f59e0b1a;border:2px solid #f59e0b;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.5rem;display:flex}.ff-user-meta{flex-direction:column;display:flex}.ff-user-name{color:#f5f7fa;font-size:.8rem;font-weight:600}.ff-user-badge{color:#f59e0b;font-size:.65rem}.ff-user-level{color:#a7b3c7;justify-content:space-between;margin-bottom:.3rem;font-size:.65rem;display:flex}.ff-xp-bar{background:#ffffff14;border-radius:2px;height:4px}.ff-xp-fill{background:linear-gradient(90deg,#00e5ff,#14f1d9);border-radius:2px;height:100%}.ff-logout{color:#6e7a91;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:.5rem;margin-top:.75rem;padding:.5rem .75rem;font-size:.8rem;transition:color .15s;display:flex}.ff-logout:hover{color:#f5f7fa}.ff-main{background:url(/bg-default-dm.png) 50%/cover no-repeat fixed;flex:1;min-height:100vh;padding:1.5rem 2rem;overflow-y:auto}.ff-dashboard{max-width:1200px}.ff-dash-header{justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;display:flex}.ff-dash-title{color:#f5f7fa;margin:0;font-size:1.6rem;font-weight:700}.ff-dash-subtitle{color:#a7b3c7;margin-top:.25rem;font-size:.9rem}.ff-dash-date{color:#a7b3c7;font-size:.8rem}.ff-accent{color:#f59e0b}.ff-kpi-row{grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem;display:grid}.ff-kpi-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a1630b8;border:1px solid #ffffff0f;border-radius:12px;align-items:center;gap:.75rem;padding:1rem;display:flex}.ff-kpi-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.1rem;display:flex}.ff-kpi-icon.orange{background:#f59e0b1f;border:1px solid #f59e0b4d}.ff-kpi-icon.cyan{background:#00e5ff14;border:1px solid #00e5ff40}.ff-kpi-img{object-fit:contain;flex-shrink:0;width:80px;height:80px}.ff-kpi-img.ff-kpi-img-lg{width:95px;height:95px}.ff-kpi-value{color:#f5f7fa;font-size:1.4rem;font-weight:700}.ff-kpi-label{color:#a7b3c7;font-size:.75rem}.ff-kpi-sub{color:#6e7a91;font-size:.65rem}.ff-dash-mid{grid-template-columns:1fr 1.2fr .8fr;gap:1rem;margin-bottom:1.5rem;display:grid}.ff-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a1630b8;border:1px solid #ffffff0f;border-radius:12px;padding:1.25rem}.ff-card-header{color:#a7b3c7;letter-spacing:.8px;text-transform:uppercase;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.7rem;font-weight:700;display:flex}.ff-today-list{flex-direction:column;gap:.6rem;display:flex}.ff-today-row{grid-template-columns:24px 1fr auto auto;align-items:center;gap:.5rem;font-size:.8rem;display:grid}.ff-today-icon{font-size:.9rem}.ff-status-low{color:#f59e0b;font-size:.7rem}.ff-muted{color:#6e7a91;font-size:.75rem}.ff-momentum{flex-direction:column;justify-content:center;align-items:center;min-height:300px;display:flex;position:relative}.ff-ring-container{width:220px;height:220px;position:relative}.ff-ring-svg{width:100%;height:100%}.ff-ring-text{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.ff-ring-label{color:#a7b3c7;letter-spacing:1px;text-transform:uppercase;font-size:.65rem}.ff-ring-value{color:#f5f7fa;font-size:3rem;font-weight:800;line-height:1}.ff-ring-status{color:#00e5ff;margin-top:.25rem;font-size:.75rem;font-weight:700}.ff-ring-msg{text-align:center;color:#a7b3c7;white-space:pre-line;margin-top:1rem;font-size:.8rem}.ff-dash-right{flex-direction:column;gap:1rem;display:flex}.ff-weekly-bars{align-items:flex-end;gap:.5rem;height:60px;margin-bottom:.25rem;display:flex}.ff-bar-col{color:#6e7a91;flex-direction:column;flex:1;align-items:center;gap:.25rem;font-size:.65rem;display:flex}.ff-bar-track{background:#ffffff0a;border-radius:3px;align-items:flex-end;width:100%;height:50px;display:flex}.ff-bar-fill{background:linear-gradient(#ffb547,#f59e0b);border-radius:3px;width:100%;min-height:2px;transition:height .3s}.ff-weekly-label{color:#6e7a91;font-size:.65rem}.ff-next-workout{align-items:center;gap:.75rem;display:flex}.ff-next-title{color:#f5f7fa;font-size:.85rem;font-weight:600}.ff-hydration{align-items:center;gap:.75rem;display:flex}.ff-hydration-val{color:#f5f7fa;font-size:1.1rem;font-weight:700}.ff-kpi-bottom{grid-template-columns:repeat(5,1fr)}.ff-kpi-card-lg{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#0a1630b8;border:1px solid #ffffff0f;border-radius:12px;padding:1rem}.ff-kpi-card-head{color:#a7b3c7;letter-spacing:.5px;align-items:center;gap:.4rem;margin-bottom:.5rem;font-size:.7rem;font-weight:600;display:flex}.ff-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.ff-dot.red{background:#ef4444}.ff-dot.cyan{background:#00e5ff}.ff-dot.purple{background:#a855f7}.ff-dot.orange{background:#f59e0b}.ff-dot.green{background:#22c55e}.ff-kpi-big{color:#f5f7fa;font-size:1.5rem;font-weight:700}.ff-kpi-unit{color:#6e7a91;font-size:.7rem;font-weight:400}.ff-kpi-progress{background:#ffffff0f;border-radius:2px;height:4px;margin-top:.5rem}.ff-kpi-progress-fill{background:#00e5ff;border-radius:2px;height:100%}.ff-ring-mini{color:#00e5ff;font-size:.8rem;font-weight:700}.ff-recent{margin-top:0}.ff-empty{text-align:center;color:#a7b3c7;padding:2rem 0}.ff-activity-list{flex-direction:column;gap:.5rem;display:flex}.ff-activity-row{border-bottom:1px solid #ffffff0a;justify-content:space-between;padding:.5rem 0;font-size:.8rem;display:flex}.ff-activity-type{color:#f5f7fa;font-weight:500}@media (width<=1100px){.ff-dash-mid{grid-template-columns:1fr 1fr}.ff-dash-right{flex-flow:wrap;grid-column:1/-1}.ff-kpi-bottom{grid-template-columns:repeat(3,1fr)}}@media (width<=768px){.ff-sidebar{display:none}.ff-kpi-row{grid-template-columns:repeat(2,1fr)}.ff-dash-mid{grid-template-columns:1fr}.ff-kpi-bottom{grid-template-columns:repeat(2,1fr)}}.ff-info-text{color:#a7b3c7;margin-bottom:1rem;font-size:.85rem;line-height:1.6}.ff-info-text strong{color:#f5f7fa}.ff-info-table{border-collapse:collapse;width:100%;font-size:.8rem}.ff-info-table th{text-align:left;color:#6e7a91;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #ffffff0f;padding:.5rem .75rem;font-size:.7rem;font-weight:600}.ff-info-table td{color:#f5f7fa;border-bottom:1px solid #ffffff0a;padding:.6rem .75rem}.ff-info-list{padding:0;list-style:none}.ff-info-list li{color:#a7b3c7;border-bottom:1px solid #ffffff0a;padding:.5rem 0;font-size:.85rem}.ff-info-list li strong{color:#f5f7fa}.ff-info-list li:last-child{border-bottom:none}
