@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;1,400&display=swap');

*{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#07142a;--blue:#0C447C;--blue-mid:#378ADD;--blue-light:#D6E8F7;
  --gold:#F5C842;--gold-dk:#C8960C;--white:#fff;--off:#f0f4f9;
  --text:#1a2a3a;--muted:#6b7f96;--border:#cdddf0;
  --green:#1a7a4a;--red:#b02020;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--off);color:var(--text);min-height:100vh}

/* NAV */
.top-nav{background:var(--navy);padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between;height:56px;position:sticky;top:0;z-index:100;border-bottom:2px solid rgba(55,138,221,.25)}
.brand{font-family:'Syne',sans-serif;font-size:1.1rem;font-weight:800;color:var(--white);letter-spacing:-.01em}
.brand span{color:var(--gold)}
.nav-tabs{display:flex}
.nav-tab{padding:.75rem 1rem;font-size:.78rem;font-weight:500;color:rgba(255,255,255,.45);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;background:none;border-left:none;border-right:none;border-top:none;font-family:inherit}
.nav-tab:hover{color:rgba(255,255,255,.8)}
.nav-tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* HERO */
.hero{background:linear-gradient(135deg,var(--navy) 0%,#0d2040 50%,#0a3060 100%);padding:3rem 1.5rem 2.5rem;text-align:center;border-bottom:1px solid rgba(55,138,221,.2)}
.hero-badge{display:inline-block;background:rgba(55,138,221,.15);border:1px solid rgba(55,138,221,.3);color:var(--blue-mid);font-size:.7rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:.35rem 1rem;border-radius:100px;margin-bottom:1rem}
.hero-title{font-family:'Syne',sans-serif;font-size:2rem;font-weight:800;color:#fff;line-height:1.1;margin-bottom:.5rem}
.hero-title span{color:var(--gold)}
.hero-sub{font-size:.9rem;color:rgba(255,255,255,.5);font-weight:300}
.progress-wrap{max-width:480px;margin:1.5rem auto 0}
.progress-labels{display:flex;justify-content:space-between;font-size:.72rem;color:rgba(255,255,255,.4);margin-bottom:.4rem}
.progress-track{height:4px;background:rgba(255,255,255,.1);border-radius:100px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--blue-mid),var(--gold));border-radius:100px;transition:width .5s ease;width:0%}
.week-dots{display:flex;justify-content:space-between;padding:.6rem 0;max-width:480px;margin:0 auto}
.wdot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.12);cursor:pointer;transition:all .2s;border:none}
.wdot.active{background:var(--gold);transform:scale(1.4)}
.wdot.done{background:var(--blue-mid)}

/* WEEK NAV */
.week-nav{background:#fff;border-bottom:1px solid var(--border);display:flex;overflow-x:auto;scrollbar-width:none;padding:0 1.5rem}
.week-nav::-webkit-scrollbar{display:none}
.week-btn{flex-shrink:0;padding:.85rem 1.1rem;font-size:.78rem;font-weight:500;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;white-space:nowrap;background:none;border-left:none;border-right:none;border-top:none;font-family:inherit}
.week-btn.active{color:var(--blue);border-bottom-color:var(--blue)}
.week-btn:hover:not(.active){color:var(--text)}

/* MAIN */
.main{max-width:860px;margin:0 auto;padding:2rem 1.5rem}

/* WEEK HERO CARD */
.week-hero{background:var(--blue);border-radius:14px;padding:1.75rem 1.75rem 1.5rem;margin-bottom:1.75rem;position:relative;overflow:hidden}
.week-hero::before{content:'';position:absolute;top:-30px;right:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,.05)}
.week-label{font-size:.72rem;font-weight:500;color:rgba(255,255,255,.55);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.4rem}
.week-title{font-family:'Syne',sans-serif;font-size:1.6rem;font-weight:800;color:#fff;line-height:1.15;margin-bottom:.75rem}
.week-tagline{font-size:.88rem;color:rgba(255,255,255,.65);line-height:1.5;max-width:520px}
.week-meta-chips{display:flex;gap:.5rem;margin-top:1rem;flex-wrap:wrap}
.chip{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.8);font-size:.72rem;padding:.3rem .75rem;border-radius:100px}

/* SECTION TABS */
.section-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;overflow-x:auto;scrollbar-width:none;padding-bottom:2px}
.section-tabs::-webkit-scrollbar{display:none}
.stab{padding:.55rem 1.1rem;font-size:.8rem;font-weight:500;border-radius:8px;cursor:pointer;border:1.5px solid var(--border);color:var(--muted);background:#fff;font-family:inherit;transition:all .2s;white-space:nowrap}
.stab.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.stab:hover:not(.active){border-color:var(--blue-mid);color:var(--blue)}

/* CARDS */
.card{background:#fff;border-radius:12px;border:1px solid var(--border);padding:1.5rem;margin-bottom:1.25rem}
.card-title{font-size:.72rem;font-weight:500;color:var(--blue);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}

/* CALLOUTS */
.gold-box{background:linear-gradient(135deg,#fffbea,#fff8d6);border:1px solid rgba(200,150,12,.25);border-left:4px solid var(--gold-dk);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1rem}
.gold-box .gbox-label{font-size:.7rem;font-weight:700;color:var(--gold-dk);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem}
.gold-box p{font-size:.88rem;color:#5a4000;line-height:1.55}
.blue-box{background:#eef4fb;border:1px solid rgba(12,68,124,.15);border-left:4px solid var(--blue-mid);border-radius:10px;padding:1rem 1.25rem;margin-bottom:1rem}
.blue-box p{font-size:.88rem;color:#1a3a5c;line-height:1.55}

/* WORKSHEETS */
.ws-title{font-family:'Syne',sans-serif;font-size:1.25rem;font-weight:700;color:var(--text);margin-bottom:.25rem}
.ws-sub{font-size:.85rem;color:var(--muted);margin-bottom:1.25rem}
.field-group{margin-bottom:1.25rem}
.field-label{font-size:.75rem;font-weight:600;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.4rem;display:block}
.field-hint{font-size:.8rem;color:var(--muted);font-style:italic;margin-bottom:.5rem;display:block}
.field-input{width:100%;border:none;border-bottom:2px solid var(--blue-light);background:transparent;padding:.5rem 0;font-size:.95rem;font-family:'DM Sans',sans-serif;color:var(--text);outline:none;line-height:1.5;transition:border-color .2s}
.field-input:focus{border-bottom-color:var(--blue)}
textarea.field-input{border:1.5px solid var(--border);border-radius:8px;padding:.65rem .75rem;background:#fafbfc;resize:vertical}
textarea.field-input:focus{border-color:var(--blue-mid)}

/* SCENARIOS */
.scenario-block{background:#fafbfc;border:1.5px solid var(--border);border-radius:10px;padding:1.1rem 1.25rem;margin-bottom:.85rem}
.scenario-q{font-size:.95rem;font-weight:500;color:var(--text);margin-bottom:.75rem;line-height:1.45}
.scenario-opts{display:flex;flex-direction:column;gap:.5rem}
.opt-label{display:flex;align-items:flex-start;gap:.65rem;cursor:pointer;font-size:.9rem;color:var(--muted);line-height:1.4;transition:color .15s}
.opt-label input[type=radio]{margin-top:3px;accent-color:var(--blue);flex-shrink:0}
.opt-label:hover{color:var(--text)}

/* CHECKLISTS */
.checklist-item{display:flex;align-items:flex-start;gap:.65rem;padding:.6rem 0;border-bottom:1px solid var(--border);cursor:pointer}
.checklist-item:last-child{border-bottom:none}
.check-box{width:20px;height:20px;border-radius:5px;border:2px solid var(--border);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}
.check-box.checked{background:var(--blue);border-color:var(--blue)}
.check-box.checked::after{content:'✓';color:#fff;font-size:.75rem;font-weight:700}
.check-label{font-size:.9rem;color:var(--text);line-height:1.45}
.check-label.checked{color:var(--muted);text-decoration:line-through}

/* GRID */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
@media(max-width:520px){.grid-2{grid-template-columns:1fr}}

/* HABITS TABLE */
.habits-table{width:100%;border-collapse:collapse;font-size:.82rem;min-width:540px}
.habits-table th{background:var(--navy);color:#fff;padding:.55rem .5rem;text-align:center;font-weight:500;font-size:.78rem}
.habits-table th:first-child{text-align:left;padding-left:.75rem;min-width:150px}
.habits-table td{padding:.55rem .5rem;text-align:center;border-bottom:1px solid var(--border)}
.habits-table td:first-child{text-align:left;padding-left:.75rem;font-size:.82rem}
.habits-table tr:nth-child(even){background:#f8fafc}
.habit-check{width:18px;height:18px;accent-color:var(--blue);cursor:pointer}
.total-cell{font-weight:700;color:var(--blue)}

/* IDENTITY CARD */
.identity-card{background:linear-gradient(135deg,var(--navy) 0%,#0d2a50 100%);border-radius:16px;padding:2rem;color:#fff}
.ic-label{font-size:.68rem;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.2rem;display:block}
.ic-field{border-bottom:1px solid rgba(255,255,255,.15);margin-bottom:1.1rem;padding-bottom:.4rem}
.identity-card input{background:none;border:none;outline:none;color:#fff;font-family:'DM Sans',sans-serif;font-size:1rem;width:100%;padding:.25rem 0}
.identity-card input::placeholder{color:rgba(255,255,255,.3)}
.identity-card textarea{background:none;border:none;border-bottom:1px solid rgba(255,255,255,.15);color:#fff;font-family:'DM Sans',sans-serif;font-size:.95rem;width:100%;outline:none;resize:none;padding:.25rem 0;min-height:60px}
.identity-card textarea::placeholder{color:rgba(255,255,255,.3)}
.values-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem;margin-top:.5rem}
.val-slot{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:6px;padding:.5rem .35rem;text-align:center}
.val-slot input{background:none;border:none;outline:none;color:#fff;font-size:.8rem;width:100%;text-align:center;font-family:'DM Sans',sans-serif}

/* SCORE BOX */
.score-box{background:var(--blue-light);border-radius:10px;padding:1.25rem;text-align:center;margin-top:1rem}
.score-num{font-family:'Syne',sans-serif;font-size:2.5rem;font-weight:800;color:var(--blue)}
.score-label{font-size:.85rem;color:var(--muted);margin-top:.3rem;line-height:1.4}

/* AGENDA TABLE */
.agenda-table{width:100%;border-collapse:collapse;font-size:.88rem}
.agenda-table th{background:var(--navy);color:#fff;padding:.6rem .75rem;text-align:left;font-weight:500;font-size:.78rem}
.agenda-table td{padding:.65rem .75rem;border-bottom:1px solid var(--border);vertical-align:top}
.agenda-table tr:nth-child(even) td{background:#f8fafc}
.agenda-time{color:var(--blue);font-weight:600;white-space:nowrap;font-size:.82rem}
.agenda-seg{font-weight:600;color:var(--text)}
.agenda-det{color:var(--muted);font-size:.82rem;margin-top:.15rem}

/* BUTTONS */
.complete-btn{background:rgba(26,122,74,.1);color:var(--green);border:1.5px solid rgba(26,122,74,.3);border-radius:10px;padding:.75rem 1.5rem;font-size:.88rem;font-weight:500;font-family:inherit;cursor:pointer;width:100%;margin-top:.75rem;transition:all .2s}
.complete-btn.done{background:var(--green);color:#fff;border-color:var(--green)}

/* WEEK COMPLETE BANNER */
.week-complete-banner{background:linear-gradient(135deg,#eafaf1,#d5f5e3);border:1.5px solid rgba(26,122,74,.25);border-radius:10px;padding:1rem 1.25rem;display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem}
.wcb-icon{font-size:1.4rem}
.wcb-text{font-size:.9rem;font-weight:500;color:var(--green)}

/* LOGIN MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(7,20,42,.75);z-index:200;display:none;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:440px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal-header{background:var(--navy);padding:1.75rem;text-align:center}
.modal-header h2{font-family:'Syne',sans-serif;color:#fff;font-size:1.2rem;font-weight:700}
.modal-header p{color:rgba(255,255,255,.45);font-size:.82rem;margin-top:.3rem}
.modal-body{padding:1.5rem}
.modal-input{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:.75rem 1rem;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s;margin-bottom:.75rem}
.modal-input:focus{border-color:var(--blue)}
.modal-btn{width:100%;background:var(--blue);color:#fff;border:none;border-radius:8px;padding:.8rem;font-size:.95rem;font-family:inherit;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:.6rem}
.modal-btn:hover{background:var(--blue-mid)}
.modal-cancel{width:100%;background:none;border:1.5px solid var(--border);border-radius:8px;padding:.72rem;font-size:.9rem;font-family:inherit;color:var(--muted);cursor:pointer}
.modal-err{color:var(--red);font-size:.82rem;margin-bottom:.75rem;display:none;background:#fff5f5;padding:.6rem .75rem;border-radius:6px;border:1px solid rgba(176,32,32,.2)}

/* FACILITATOR HUB */
.fac-header{background:var(--navy);border-radius:14px;padding:1.5rem;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.fac-header h2{font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:700;color:#fff}
.fac-header p{color:rgba(255,255,255,.45);font-size:.82rem;margin-top:.2rem}
.logout-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.7);padding:.45rem 1rem;border-radius:6px;font-size:.78rem;cursor:pointer;font-family:inherit;transition:all .2s}
.logout-btn:hover{background:rgba(255,255,255,.2)}
.dl-section-title{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin:1.5rem 0 .75rem}
.dl-section-title:first-child{margin-top:0}
.dl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}
.dl-card{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:1.25rem;transition:all .2s}
.dl-card:hover{border-color:var(--blue-mid);box-shadow:0 4px 16px rgba(12,68,124,.08)}
.dc-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:.75rem}
.dc-name{font-size:.88rem;font-weight:600;color:var(--text);margin-bottom:.2rem;line-height:1.3}
.dc-desc{font-size:.78rem;color:var(--muted);margin-bottom:.85rem;line-height:1.4}
.dl-btn{display:block;background:var(--blue);color:#fff;border:none;border-radius:7px;padding:.55rem;font-size:.8rem;font-weight:500;font-family:inherit;cursor:pointer;width:100%;text-align:center;transition:all .2s;text-decoration:none}
.dl-btn:hover{background:var(--blue-mid)}

/* DIVIDER */
.divider{height:1px;background:var(--border);margin:1.25rem 0}

/* COMING SOON */
.coming-soon-card{background:#fff;border:2px dashed var(--border);border-radius:12px;padding:2.5rem;text-align:center;margin-bottom:1.25rem}
.coming-soon-card .cs-emoji{font-size:2.5rem;margin-bottom:.75rem}
.coming-soon-card h3{font-family:'Syne',sans-serif;font-size:1.1rem;color:var(--text);margin-bottom:.4rem}
.coming-soon-card p{font-size:.88rem;color:var(--muted)}

/* ─── AUTH SCREEN ─── */
#auth-screen{min-height:100vh;background:linear-gradient(135deg,var(--navy) 0%,#0d2040 60%,#0a3060 100%);display:flex;align-items:center;justify-content:center;padding:1.5rem}
.auth-wrap{width:100%;max-width:420px}
.auth-brand{text-align:center;margin-bottom:2rem}
.auth-logo-badge{width:64px;height:64px;background:var(--blue);border-radius:16px;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-size:1.2rem;font-weight:800;color:#fff;margin:0 auto 1rem;border:2px solid rgba(255,255,255,.15)}
.auth-brand-name{font-family:'Syne',sans-serif;font-size:1.4rem;font-weight:800;color:#fff}
.auth-brand-name span{color:var(--gold)}
.auth-brand-sub{font-size:.82rem;color:rgba(255,255,255,.45);margin-top:.3rem}
.auth-card{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.auth-card-title{font-family:'Syne',sans-serif;font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:.25rem}
.auth-card-sub{font-size:.85rem;color:var(--muted);margin-bottom:1.5rem}
.auth-err{background:#fff5f5;border:1px solid rgba(176,32,32,.2);border-radius:8px;padding:.65rem .9rem;font-size:.85rem;color:var(--red);margin-bottom:1rem}
.auth-field{margin-bottom:1rem}
.auth-field label{display:block;font-size:.78rem;font-weight:600;color:var(--text);margin-bottom:.35rem}
.auth-field input{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:.7rem .9rem;font-size:.95rem;font-family:'DM Sans',sans-serif;outline:none;transition:border-color .2s;color:var(--text)}
.auth-field input:focus{border-color:var(--blue)}
.auth-btn{width:100%;background:var(--blue);color:#fff;border:none;border-radius:8px;padding:.85rem;font-size:.95rem;font-family:'DM Sans',sans-serif;font-weight:500;cursor:pointer;transition:all .2s;margin-top:.5rem}
.auth-btn:hover{background:var(--blue-mid)}
.auth-btn:disabled{opacity:.6;cursor:not-allowed}
.auth-switch{text-align:center;font-size:.85rem;color:var(--muted);margin-top:1.25rem}
.auth-switch a{color:var(--blue);text-decoration:none;font-weight:500}
.auth-switch a:hover{text-decoration:underline}

/* ─── USER MENU ─── */
.user-menu{position:relative;cursor:pointer}
.user-avatar{width:34px;height:34px;border-radius:50%;background:var(--blue-mid);color:#fff;font-family:'Syne',sans-serif;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.2);transition:all .2s}
.user-avatar:hover{border-color:var(--gold)}
.user-dropdown{position:absolute;right:0;top:calc(100% + 8px);background:#fff;border-radius:10px;border:1px solid var(--border);min-width:200px;box-shadow:0 8px 30px rgba(0,0,0,.15);z-index:150;overflow:hidden}
.ud-name{font-size:.88rem;font-weight:600;color:var(--text);padding:.85rem 1rem .2rem}
.ud-email{font-size:.78rem;color:var(--muted);padding:.2rem 1rem .75rem}
.ud-divider{height:1px;background:var(--border)}
.ud-btn{width:100%;background:none;border:none;padding:.75rem 1rem;font-family:'DM Sans',sans-serif;font-size:.88rem;color:var(--red);cursor:pointer;text-align:left;transition:background .15s}
.ud-btn:hover{background:#fff5f5}

/* ─── SAVE TOAST ─── */
.save-toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--green);color:#fff;font-size:.82rem;font-weight:500;padding:.55rem 1rem;border-radius:8px;opacity:0;transform:translateY(8px);transition:all .3s;pointer-events:none;z-index:300;font-family:'DM Sans',sans-serif}
.save-toast.show{opacity:1;transform:translateY(0)}

/* ─── LOADING STATE ─── */
.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--off)}
.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ─── HIDDEN UTILITY ─── */
.hidden{display:none!important}
