:root{
  --teal:#0E3A3F; --teal-light:#155E63; --amber:#E8843C; --amber-soft:#F2A86B;
  --cream:#F7F2E9; --cream-deep:#EFE7D7; --ink:#16201F; --muted:#5C6B6D;
  --serif:'Fraunces',Georgia,serif; --sans:'Hanken Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0}
body{background:var(--cream);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}

/* Gate */
.gate{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:28px;background:radial-gradient(circle at 50% 120%,var(--teal-light),var(--teal))}
.gate .mark{margin-bottom:18px}
.wordmark{font-family:var(--serif);font-weight:600;font-size:clamp(40px,12vw,64px);color:var(--cream);letter-spacing:-1px;line-height:1}
.wordmark span{color:var(--amber)}
.gate .tag{color:rgba(247,242,233,.8);margin-top:10px;font-weight:500;letter-spacing:.3px}
#login-form{margin-top:30px;display:flex;flex-direction:column;gap:12px;width:100%;max-width:300px}
#password{padding:14px 16px;border-radius:10px;border:1.5px solid rgba(247,242,233,.25);
  background:rgba(247,242,233,.08);color:var(--cream);font-size:16px;font-family:var(--sans)}
#password::placeholder{color:rgba(247,242,233,.5)}
#login-form button{padding:14px;border:0;border-radius:10px;background:var(--amber);color:#fff;
  font-weight:700;font-size:15px;font-family:var(--sans);cursor:pointer}
.error{color:var(--amber-soft);font-size:13px;font-weight:600}

/* Topbar */
.topbar{position:sticky;top:0;z-index:5;background:var(--teal);display:flex;align-items:center;gap:10px;padding:14px 18px;padding-top:max(14px,env(safe-area-inset-top))}
.topbar-text{display:flex;flex-direction:column;line-height:1.1}
.topbar-word{font-family:var(--serif);font-weight:600;font-size:18px;color:var(--cream)}
.topbar-word span{color:var(--amber)}
.topbar-sub{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(247,242,233,.55)}

/* Progress */
.progresswrap{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--teal);border-top:1px solid rgba(247,242,233,.08)}
.progressbar{flex:1;height:8px;border-radius:999px;background:rgba(247,242,233,.18);overflow:hidden}
.progressfill{height:100%;width:0;background:var(--amber);border-radius:999px;transition:width .3s}
.progresslabel{font-size:12px;font-weight:700;color:rgba(247,242,233,.8);white-space:nowrap}

/* Sections + cards */
#sections{max-width:760px;margin:0 auto;padding:18px 16px 60px}
.section-title{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--teal);margin:26px 0 12px}
.card{background:#fff;border:1px solid var(--cream-deep);border-radius:14px;padding:16px;margin-bottom:12px}
.card.done{opacity:.72}
.card-title{font-weight:700;font-size:16px;color:var(--ink)}
.card-why{font-size:13px;color:var(--muted);margin-top:5px;line-height:1.45}
.card-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.badge{font-size:11px;font-weight:700;padding:4px 9px;border-radius:999px;background:var(--cream-deep);color:var(--muted)}
.badge.cost{background:var(--cream-deep);color:var(--teal)}
.badge.dep{background:#fbe7d6;color:#a85a22}
.pills{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.pill{font-size:12px;font-weight:700;padding:7px 12px;border-radius:999px;border:1.5px solid var(--cream-deep);
  background:transparent;color:var(--muted);cursor:pointer;font-family:var(--sans)}
.pill[aria-pressed="true"][data-status="not_started"]{background:var(--muted);border-color:var(--muted);color:#fff}
.pill[aria-pressed="true"][data-status="in_progress"]{background:var(--amber);border-color:var(--amber);color:#fff}
.pill[aria-pressed="true"][data-status="done"]{background:var(--teal);border-color:var(--teal);color:#fff}
.pill[aria-pressed="true"][data-status="blocked"]{background:#b23b3b;border-color:#b23b3b;color:#fff}
.notes{margin-top:12px;width:100%;min-height:54px;resize:vertical;padding:10px 12px;border-radius:10px;
  border:1.5px solid var(--cream-deep);font-family:var(--sans);font-size:14px;color:var(--ink);background:var(--cream)}
.notes:focus{outline:none;border-color:var(--amber)}
.links{margin-top:10px;display:flex;flex-wrap:wrap;gap:12px}
.links a{font-size:13px;font-weight:600;color:var(--teal)}

/* Toast */
.toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);background:var(--teal);color:var(--cream);
  font-size:13px;font-weight:600;padding:10px 16px;border-radius:999px;box-shadow:0 8px 24px rgba(14,58,63,.25)}
@media(min-width:560px){#sections{padding-left:24px;padding-right:24px}}
