:root{--bg:#0f172a;--surface:#131f34;--surface-soft:#17253d;--text-primary:#e5ecf6;--text-secondary:#9fb0c9;--text-muted:#7385a1;--border:#90aad033;--accent:#7cb3ff;--accent-strong:#4f8ef7;--success:#35cfa1;--danger:#f37f7f;--shadow:0 14px 30px #02061738}*{box-sizing:border-box}html,body,#app{min-height:100%;margin:0}body{background:radial-gradient(circle at top, #13203a 0%, var(--bg) 50%);color:var(--text-primary);font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;line-height:1.45}button,input,textarea{font:inherit}.app-shell{width:min(1100px,94vw);margin:0 auto;padding:2rem 0 3rem}.top-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.top-header__brand h1{margin:.2rem 0 0;font-size:clamp(1.3rem,2.5vw,1.85rem)}.user-menu-wrap{position:relative}.user-icon-btn{border:1px solid var(--border);color:#fff;cursor:pointer;background:linear-gradient(160deg,#7cb3ff38,#4f8ef740);border-radius:999px;width:40px;height:40px;font-weight:700}.user-dropdown{border:1px solid var(--border);width:220px;box-shadow:var(--shadow);z-index:20;background:#101c31;border-radius:14px;gap:.35rem;padding:.6rem;display:grid;position:absolute;top:48px;right:0}.user-dropdown__email{color:var(--text-secondary);word-break:break-word;margin:0 0 .35rem;font-size:.78rem}.user-dropdown button{color:var(--text-primary);text-align:left;cursor:pointer;background:#7cb3ff14;border:none;border-radius:8px;padding:.45rem .55rem}.user-dropdown button:hover{background:#7cb3ff29}.hero-banner{border:1px solid var(--border);box-shadow:var(--shadow);background:linear-gradient(150deg,#7cb3ff1a,#131f34b3);border-radius:20px;margin-bottom:1.15rem;padding:1.35rem 1.45rem}.hero-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.hero-banner__eyebrow{text-transform:uppercase;letter-spacing:.08rem;color:#a6ccff;margin:0 0 .4rem;font-size:.72rem;font-weight:600}.hero-banner h2{letter-spacing:-.005em;margin:0;font-size:clamp(1.15rem,2.3vw,1.55rem);font-weight:600}.hero-banner p{color:var(--text-secondary);max-width:60ch;margin:.45rem 0 0}.phase-nav button,.reset-btn,.week-complete-btn,.auth-submit-btn,.back-btn{cursor:pointer;color:var(--text-primary);border:1px solid #0000;border-radius:10px;transition:all .2s}.progress-section{background:var(--surface);border:1px solid var(--border);border-radius:16px;margin-bottom:1rem;padding:1rem 1.05rem}.progress-row{justify-content:space-between;align-items:center;gap:1rem;display:flex}.progress-row h2{margin:0;font-size:1.02rem;font-weight:600}.progress-row span{color:#b8d5ff;font-size:.9rem;font-weight:500}.progress-track{background:#0b1424;border:1px solid #90aad024;border-radius:999px;height:10px;margin-top:.8rem;overflow:hidden}.progress-fill{border-radius:inherit;background:linear-gradient(90deg, var(--accent-strong), var(--success));height:100%;transition:width .28s}.progress-caption{color:var(--text-muted);margin:.5rem 0 0;font-size:.84rem}.top-actions{justify-content:flex-end;margin:1rem 0 .8rem;display:flex}.phase-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.9rem;display:grid}.phase-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;padding:1rem}.phase-card>p:first-child{color:#a6ccff;text-transform:uppercase;letter-spacing:.05em;margin:0;font-size:.75rem;font-weight:600}.phase-card h3{margin:.35rem 0;font-size:1rem}.phase-card span{color:var(--text-muted);font-size:.82rem}.phase-card p{color:var(--text-secondary);margin:.7rem 0;font-size:.87rem}.phase-card button{color:var(--text-primary);cursor:pointer;background:#7cb3ff21;border:1px solid #7cb3ff54;border-radius:10px;padding:.48rem .8rem}.phase-card button:hover{background:#7cb3ff38}.phase-detail__top{justify-content:space-between;align-items:center;margin-bottom:.8rem;display:flex}.phase-detail__header{background:var(--surface);border:1px solid var(--border);border-radius:14px;margin-bottom:1rem;padding:.95rem}.phase-detail__header p{color:var(--text-secondary);margin:0}.phase-detail__header p:first-child{color:#a6ccff;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.phase-detail__header h3{margin:.25rem 0;font-size:1.1rem}.phase-detail__header span{color:var(--text-muted);font-size:.82rem}.reset-btn{background:#f37f7f24;border-color:#f37f7f4d;padding:.48rem .82rem;font-size:.83rem}.reset-btn:hover{background:#f8717133}.weeks-grid{gap:1rem;display:grid}.week-card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:16px;padding:1.1rem;scroll-margin-top:5.8rem;transition:border-color .2s,transform .2s}.week-card:hover{border-color:#90aad059;transform:translateY(-2px)}.week-card__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.8rem;display:flex}.week-card__header p{color:#93c5fd;letter-spacing:.03em;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:600}.week-card__header h3{margin:.24rem 0 0;font-size:1.02rem;font-weight:600}.week-complete-btn{background:#35cfa11f;border-color:#35cfa157;padding:.43rem .74rem;font-size:.8rem}.week-complete-btn:hover{background:#34d3992e}.week-card__days{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.8rem;margin-top:.95rem;display:grid}.day-item{background:var(--surface-soft);border:1px solid #90aad029;border-radius:16px;padding:.82rem;transition:border-color .2s,background-color .2s;box-shadow:inset 0 1px #ffffff05}.day-item:hover{border-color:#819abe47}.day-item.is-complete{background:#0f2b2a73;border-color:#34d399a6}.checkbox-label{color:var(--text-secondary);align-items:center;gap:.42rem;font-size:.78rem;display:flex}.day-item__header h4{color:var(--text-primary);margin:.42rem 0 .62rem;font-size:.9rem;font-weight:500}.day-item textarea{resize:vertical;width:100%;min-height:84px;color:var(--text-primary);background:#0a1323bf;border:1px solid #819abe2e;border-radius:12px;padding:.56rem}.day-item textarea::placeholder{color:#5f708a}.day-item textarea:focus,.auth-form input:focus{border-color:#3b82f6;outline:2px solid #60a5fa59}.auth-shell{place-items:center;min-height:100vh;padding:1rem;display:grid}.auth-stack{justify-items:center;gap:.7rem;width:min(440px,95vw);display:grid}.auth-intro{text-align:center;width:100%}.auth-intro h1{letter-spacing:-.01em;margin:0;font-size:1.4rem;font-weight:650}.auth-card{background:var(--surface);border:1px solid var(--border);width:100%;box-shadow:var(--shadow);border-radius:20px;padding:1.25rem}.auth-mode-title{color:var(--text-secondary);margin:.25rem 0 0;font-size:.95rem;font-weight:500}.auth-subtitle{color:var(--text-secondary);margin:0;font-size:.92rem}.auth-form{gap:.68rem;display:grid}.auth-form label{color:var(--text-secondary);text-align:left;gap:.3rem;font-size:.8rem;font-weight:500;display:grid}.auth-form input{color:var(--text-primary);background:#0a1323c7;border:1px solid #90aad038;border-radius:12px;padding:.62rem .68rem}.auth-submit-btn{background:#4f8ef72e;border-color:#7cb3ff59;margin-top:.25rem;padding:.58rem .9rem;font-weight:600}.auth-submit-btn:hover{background:#3b82f63d}.auth-submit-btn:disabled{opacity:.65;cursor:not-allowed}.auth-switch-btn{color:var(--accent);cursor:pointer;background:0 0;border:none;align-self:center;margin-top:.7rem;padding:0;font-size:.82rem;display:inline-flex}.auth-switch-btn:hover{color:#93c5fd}.auth-error,.auth-feedback{margin:0;font-size:.82rem}.auth-error{color:var(--danger)}.auth-feedback{color:var(--success)}.back-btn{background:#7cb3ff1f;border-color:#7cb3ff4d;padding:.48rem .82rem;font-size:.83rem}.back-btn:hover{background:#7cb3ff33}@media (width<=760px){.app-shell{width:95vw;padding-top:1rem}.progress-row{flex-direction:column;align-items:flex-start}.phase-detail__top{flex-wrap:wrap;gap:.5rem}}
