:root{
  /* Marvel Qualities brand palette — dark + coral (matches marvelqualities.co.uk) */
  --bg:#03050c; --card:#0c1322; --ink:#e6eaf2; --muted:#94a0b4;
  --line:rgba(255,255,255,.12); --accent:#FF6B45; --accent-soft:rgba(255,107,69,.16);
  --shadow:0 1px 2px rgba(0,0,0,.45),0 16px 40px rgba(0,0,0,.55);
  --future:rgba(255,255,255,.10);
  /* life chapters (tuned to sit on the dark brand background) */
  --c-child:#d9b15a;   /* early childhood */
  --c-school:#5a9683;  /* school & growing up */
  --c-uni:#8f6fd0;     /* university */
  --c-work:#5288b6;    /* working & building */
  --c-free:#e08a4a;    /* free / active later years */
  --c-slow:#9a90b0;    /* slower, gentler years */
  --now:#FF6B45;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  background:var(--bg); color:var(--ink);
  font-family:ui-serif,Georgia,"Times New Roman",serif;
  line-height:1.55;-webkit-font-smoothing:antialiased;
  min-height:100dvh;
  padding:max(18px,env(safe-area-inset-top)) 16px max(28px,env(safe-area-inset-bottom));
}
.wrap{width:100%;max-width:560px;margin:0 auto}
.sans{font-family:ui-sans-serif,system-ui,-apple-system,sans-serif}
.hidden{display:none !important}

.acct{font-family:ui-sans-serif,system-ui,sans-serif;border:1px solid var(--line);background:var(--card);border-radius:14px;padding:12px 14px;margin:2px 0 14px;box-shadow:var(--shadow)}
.acct .ahd{font-size:13px;color:var(--muted);line-height:1.4}
.acct.in{display:flex;align-items:center;justify-content:space-between;gap:10px}
.acct .arow{display:flex;gap:8px;margin-top:9px}
.acct .arow input{flex:1;font-size:15px;padding:11px 12px;border:1.5px solid var(--line);border-radius:11px;background:transparent;color:var(--ink);outline:none;font-family:inherit}
.acct .arow input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.acct .amsg{font-size:12.5px;color:var(--accent);margin-top:8px;min-height:1px}
.acct .alink{background:none;border:none;color:var(--accent);font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap}
.acct.mini{background:transparent;border:none;box-shadow:none;display:flex;align-items:center;justify-content:flex-end;gap:6px;padding:2px 2px 0;margin-bottom:8px}
.acct.mini .ahd{font-size:12.5px}
.acct .privacy{max-width:none}
header{text-align:center;margin:6px 0 20px}
.mark{font-size:12.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;font-family:ui-sans-serif,system-ui,sans-serif}
h1{font-size:27px;line-height:1.18;margin:12px 0 8px;font-weight:600;letter-spacing:-.01em}
.sub{color:var(--muted);font-size:15.5px;margin:0 auto;max-width:36ch}

.card{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:22px 20px;box-shadow:var(--shadow);margin-bottom:16px}
.card h2{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:700;margin:0 0 14px}

label{display:block;font-family:ui-sans-serif,system-ui,sans-serif;font-size:13px;font-weight:600;letter-spacing:.02em;color:var(--muted);margin:0 0 8px}
.field{margin-bottom:16px}
input[type=number],input[type=text]{width:100%;font-family:ui-sans-serif,system-ui,sans-serif;font-size:18px;font-weight:500;color:var(--ink);background:transparent;border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;outline:none;transition:border-color .15s,box-shadow .15s}
input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
input[type=number]{-moz-appearance:textfield}
.seg{display:flex;gap:6px;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:5px}
.seg button{flex:1;font-family:ui-sans-serif,system-ui,sans-serif;font-size:14px;font-weight:600;color:var(--muted);background:transparent;border:none;border-radius:8px;padding:9px 4px;cursor:pointer;transition:all .15s}
.seg button[aria-pressed=true]{background:var(--card);color:var(--ink);box-shadow:var(--shadow)}
.row{display:flex;gap:12px}.row>*{flex:1}

.btn{width:100%;font-family:ui-sans-serif,system-ui,sans-serif;font-size:15px;font-weight:600;color:#fff;background:var(--accent);border:none;border-radius:13px;padding:15px;cursor:pointer}
.btn.ghost{color:var(--accent);background:transparent;border:1.5px solid var(--line)}
.btn.sm{width:auto;padding:10px 16px;font-size:14px}
.linkbtn{font-family:ui-sans-serif,system-ui,sans-serif;font-size:14px;font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;padding:8px}
.privacy{color:var(--muted);font-size:12px;text-align:center;margin-top:10px;font-family:ui-sans-serif,system-ui,sans-serif;max-width:38ch;margin-left:auto;margin-right:auto}
.stephint{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12.5px;color:var(--muted);text-align:center;margin-bottom:14px;letter-spacing:.03em}

/* family list in setup */
.person{border:1px solid var(--line);border-radius:13px;padding:12px;margin-bottom:10px;background:var(--bg)}
.person .prow{display:flex;gap:9px;align-items:flex-end}
.person .prow+.prow{margin-top:10px}
.person .grow{flex:1}
.person .age{max-width:60px}
.person .cc{max-width:56px}
.person .exp{flex:1;min-width:72px}
.person input{font-size:16px;padding:11px 12px}
.person label{font-size:11.5px;margin-bottom:5px}
.cc-in{text-transform:uppercase}
.person .del{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;padding:4px 6px;align-self:center}
.addline{font-family:ui-sans-serif,system-ui,sans-serif;font-size:13px;color:var(--muted);margin:4px 0 10px}

/* grid */
.lead{text-align:center;margin:0 0 2px}
.lead .big{font-family:ui-sans-serif,system-ui,sans-serif;font-size:15px;font-weight:600}
.lead .pct{color:var(--muted);font-size:13px;font-family:ui-sans-serif,system-ui,sans-serif;margin-top:3px}
.grid{display:grid;gap:2px;margin:16px 0 10px;grid-template-columns:repeat(52,1fr)}
.grid i{display:block;width:100%;aspect-ratio:1/1;border-radius:1.5px;background:var(--future)}
.grid i.c-child{background:var(--c-child)} .grid i.c-school{background:var(--c-school)}
.grid i.c-uni{background:var(--c-uni)}
.grid i.c-work{background:var(--c-work)} .grid i.c-free{background:var(--c-free)}
.grid i.c-slow{background:var(--c-slow)}
.grid i.fut{opacity:.34}
.grid i.now{background:var(--now)!important;opacity:1;box-shadow:0 0 0 1.5px var(--now)}
.legend{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 14px;color:var(--muted);font-size:11.5px;font-family:ui-sans-serif,system-ui,sans-serif;margin-top:6px}
.legend span{display:inline-flex;align-items:center;gap:5px}
.dot{width:9px;height:9px;border-radius:2px;display:inline-block}

/* counters */
.counters{display:flex;flex-direction:column;gap:12px}
.counter{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding-bottom:11px;border-bottom:1px solid var(--line)}
.counter:last-child{border-bottom:none;padding-bottom:0}
.counter .who{font-size:16px}
.counter .who small{display:block;font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;color:var(--muted);margin-top:2px}
.counter .val{font-family:ui-sans-serif,system-ui,sans-serif;font-size:15px;font-weight:700;color:var(--accent);white-space:nowrap;text-align:right}

/* closing soonest */
.soon{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:9px 0;border-bottom:1px solid var(--line)}
.soon:last-child{border-bottom:none}
.soon .t{font-size:15.5px}
.soon .y{font-family:ui-sans-serif,system-ui,sans-serif;font-size:13px;font-weight:700;color:var(--accent);white-space:nowrap}

/* catalogue */
.cat{border:1px solid var(--line);border-radius:14px;margin-bottom:10px;overflow:hidden;background:var(--card)}
.cat>.head{display:flex;align-items:center;gap:10px;width:100%;background:transparent;border:none;cursor:pointer;padding:14px 16px;text-align:left;font-family:inherit}
.cat>.head .ic{font-size:20px}
.cat>.head .nm{flex:1;font-size:17px;font-weight:600;color:var(--ink)}
.cat>.head .meta{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;color:var(--muted)}
.cat>.head .chev{color:var(--muted);transition:transform .2s;font-size:13px;font-family:ui-sans-serif,system-ui,sans-serif}
.cat[data-open=true]>.head .chev{transform:rotate(90deg)}
.cat .body{display:none;padding:2px 12px 10px}
.cat[data-open=true] .body{display:block}
.item{display:flex;gap:12px;padding:11px 6px;border-top:1px solid var(--line)}
.item:first-child{border-top:none}
.item .tick{flex:none;width:26px;height:26px;border-radius:50%;border:1.6px solid var(--line);background:transparent;cursor:pointer;margin-top:2px;font-size:14px;color:#fff;display:flex;align-items:center;justify-content:center;transition:all .12s}
.item[data-state=want] .tick{background:var(--accent);border-color:var(--accent)}
.item[data-state=done] .tick{background:var(--c-school);border-color:var(--c-school)}
.item .txt{flex:1}
.item .ti{font-size:16px;line-height:1.35}
.item .wy{font-family:ui-sans-serif,system-ui,sans-serif;font-size:13px;color:var(--muted);margin-top:3px;line-height:1.45}
.item .win{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;font-weight:600;margin-top:5px;color:var(--accent)}
.item .win.passed{color:var(--muted)}
.item .pickup{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12.5px;line-height:1.45;color:var(--c-school);background:var(--accent-soft);border-radius:8px;padding:7px 10px;margin-top:6px}
.item[data-state=want] .ti{font-weight:600}
.item .rm{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;font-weight:600;color:var(--muted);background:none;border:none;padding:6px 0 0;cursor:pointer;text-decoration:underline}
.item .rm:hover{color:var(--now)}

.rdesc{font-family:ui-sans-serif,system-ui,sans-serif;font-size:14.5px;color:var(--muted);line-height:1.5;margin:0 0 14px}
#feedbackCard textarea{width:100%;font-family:ui-sans-serif,system-ui,sans-serif;font-size:16px;color:var(--ink);background:transparent;border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;outline:none;resize:vertical}
#feedbackCard textarea:focus,#feedbackCard input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
#feedbackCard input{width:100%;font-family:ui-sans-serif,system-ui,sans-serif;font-size:16px;color:var(--ink);background:transparent;border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;outline:none}
#remind .btn{width:auto;padding:13px 22px}
.reflect{color:var(--muted);font-size:15px;font-style:italic;text-align:center;margin:16px 4px 0;line-height:1.5}
.foot{text-align:center;margin-top:4px}
.note-soft{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;color:var(--muted);text-align:center;margin-top:12px}
.sitefoot{font-family:ui-sans-serif,system-ui,sans-serif;font-size:12px;color:var(--muted);text-align:center;margin:10px 0 4px;line-height:1.7}
.sitefoot a{color:var(--muted);text-decoration:underline}
.sitefoot .byline{letter-spacing:.04em}
.hero{max-width:40ch;margin:2px auto 22px;text-align:center;font-size:16.5px;line-height:1.6;color:var(--ink)}
.hero-emph{font-style:italic;font-weight:600;color:var(--accent);white-space:nowrap}

/* Marvel Qualities brand UI font (Inter) — applied to UI chrome; reflective copy stays serif */
.sans,.mark,label,input,select,textarea,button,.btn,.linkbtn,.seg button,.legend,.amsg,
.rdesc,.note-soft,.sitefoot,.stephint,.privacy,.lead .big,.lead .pct,.counter .who small,
.counter .val,.win .left,.win .note,.cat .head .meta,.item .wy,.item .win,.item .pickup,
.acct,.acct .ahd{font-family:"Inter",ui-sans-serif,system-ui,-apple-system,sans-serif}
