*{margin:0;padding:0;box-sizing:border-box}
:root{
  --teal:#113B40; --teal2:#2C585E; --rust:#C75B33; --rust2:#A8431F; --gold:#E29A63;
  --cream:#FCFCF8; --tint:#F2F1EA; --line:#D8E0DB; --ink:#113B40; --muted:#5E7370;
  --good:#2E6B62; --warn:#B98A2E;
}
html{-webkit-text-size-adjust:100%}
body{background:var(--cream);color:var(--ink);font-family:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.55;font-size:16px;min-height:100vh}
.serif{font-family:"Fraunces","Georgia",serif}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit;font-size:16px;color:var(--ink)}
a{color:var(--rust2)}

.wrap{max-width:640px;margin:0 auto;padding:0 18px}

/* top bar */
.top{background:var(--teal);position:sticky;top:0;z-index:40;box-shadow:0 2px 12px rgba(17,59,64,.22)}
.top .bar{max-width:640px;margin:0 auto;padding:12px 18px;display:flex;align-items:center;gap:10px}
.top .brand{color:var(--gold);font-weight:700;letter-spacing:1.5px;font-size:12.5px;text-decoration:none;white-space:nowrap}
.top .who{margin-left:auto;color:#D8E0DB;font-size:12px;display:flex;align-items:center;gap:8px}
.top .who button{background:none;border:1px solid var(--teal2);color:#D8E0DB;border-radius:8px;padding:4px 10px;font-size:11.5px}
.top .who button:active{background:var(--teal2)}

/* generic */
.screen{padding:26px 0 90px;animation:fade .18s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
h1.pagetitle{font-family:"Fraunces",serif;font-size:clamp(26px,6.4vw,34px);font-weight:600;line-height:1.15;margin-bottom:6px}
.kicker{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--rust);font-weight:700;margin-bottom:8px}
.lede{font-size:15.5px;color:var(--muted);margin-bottom:18px}
.card{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:18px;margin-bottom:12px}
.card h3{font-size:16.5px;font-weight:700;margin-bottom:4px}
.card p.sub{font-size:13.5px;color:var(--muted)}
label.f{display:block;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin:14px 0 5px}
input[type=text],input[type=date],textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:11px 13px;background:#fff}
input:focus,textarea:focus{outline:2px solid var(--gold);border-color:var(--gold)}
textarea{min-height:74px;resize:vertical;line-height:1.5}

.btn{display:block;width:100%;text-align:center;background:var(--rust);color:#fff;border:none;border-radius:13px;padding:15px;font-size:16px;font-weight:700;text-decoration:none}
.btn:active{background:var(--rust2)}
.btn.teal{background:var(--teal)}
.btn.ghost{background:transparent;color:var(--rust2);border:2px solid var(--rust)}
.btn.quiet{background:var(--tint);color:var(--ink);font-weight:600}
.btn+.btn{margin-top:10px}
.btn:disabled{opacity:.45}
.row{display:flex;gap:10px}
.row .btn{flex:1}

/* gate */
.gate{min-height:100vh;display:flex;flex-direction:column;justify-content:center;background:var(--teal);color:#F2F1EA;padding:30px 0}
.gate .kick{font-size:11px;letter-spacing:3px;color:var(--gold);text-transform:uppercase;font-weight:700}
.gate h1{font-family:"Fraunces",serif;font-size:clamp(30px,8vw,42px);font-weight:600;color:#FCFCF8;line-height:1.1;margin:12px 0 8px}
.gate p{color:#C3D1CC;font-size:15px;margin-bottom:22px;max-width:44ch}
.gate input{background:#fff;border:none;border-radius:12px;padding:15px;width:100%;font-size:18px;text-align:center;letter-spacing:2px;text-transform:uppercase;font-weight:700}
.gate .err{color:#F3B79B;font-size:14px;margin-top:10px;min-height:20px}
.gate .fine{color:#93A6A1;font-size:12px;margin-top:22px}
.gate .fine a{color:var(--gold)}
.gate .btn{margin-top:14px;background:var(--rust)}

/* home tiles */
.tile{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:17px 18px;margin-bottom:11px;text-decoration:none;color:var(--ink)}
.tile:active{border-color:var(--gold)}
.tile .ico{flex:none;width:44px;height:44px;border-radius:12px;background:var(--teal);color:var(--gold);display:flex;align-items:center;justify-content:center;font-family:"Fraunces",serif;font-size:20px;font-weight:600}
.tile.orange .ico{background:var(--rust);color:#fff}
.tile .t{font-size:16.5px;font-weight:700}
.tile .d{font-size:13px;color:var(--muted);margin-top:1px}
.tile .arr{margin-left:auto;color:var(--rust);font-size:18px}
.resume{background:var(--gold);border:none;border-radius:14px;padding:14px 16px;margin-bottom:14px;width:100%;text-align:left}
.resume .t{font-weight:700;color:#33291F}
.resume .d{font-size:12.5px;color:#5c4425}

/* checklist */
.check{display:flex;gap:12px;align-items:flex-start;background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;margin-bottom:9px}
.check input{width:22px;height:22px;accent-color:var(--rust);flex:none;margin-top:2px}
.check .t{font-size:14.5px}
.check .t b{display:block}
.check .t span{color:var(--muted);font-size:13px}

/* runner */
.runhead{background:var(--teal);color:#F2F1EA;border-radius:16px;padding:16px 18px;margin-bottom:14px;position:sticky;top:62px;z-index:30;box-shadow:0 6px 18px rgba(17,59,64,.18)}
.runhead .conv{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:700}
.runhead h2{font-family:"Fraunces",serif;font-size:21px;font-weight:600;color:#FCFCF8;margin:2px 0 8px}
.timerline{display:flex;align-items:center;gap:12px}
.clock{font-variant-numeric:tabular-nums;font-size:30px;font-weight:700;font-family:"Fraunces",serif;letter-spacing:1px}
.clock.warn{color:var(--gold)}
.clock.over{color:#F3A18B}
.timerline .tbtn{background:var(--teal2);color:#F2F1EA;border:none;border-radius:9px;padding:8px 14px;font-size:13px;font-weight:600}
.timerline .tmsg{font-size:12px;color:#C3D1CC;margin-left:auto;text-align:right;max-width:150px;line-height:1.3}
.timerline .tmsg.over{color:#F3B79B}
.progress{height:5px;background:var(--teal2);border-radius:99px;margin-top:10px;overflow:hidden}
.progress i{display:block;height:100%;background:var(--gold);border-radius:99px;transition:width 1s linear}
.progress i.over{background:#E07B5A}

.script{background:var(--tint);border-left:4px solid var(--gold);border-radius:0 12px 12px 0;padding:14px 16px;margin-bottom:14px;font-size:14.5px}
.script .why{color:var(--muted);margin-bottom:8px}
.script ul{margin:6px 0 2px 18px}
.script li{margin-bottom:5px}
.force{background:#FBEDE4;border:1.5px solid var(--rust);border-radius:12px;padding:12px 15px;margin-bottom:14px;font-size:14.5px;font-weight:600;color:var(--rust2)}
.force .fk{display:block;font-size:10.5px;letter-spacing:2px;text-transform:uppercase;margin-bottom:3px}

.cap h4{font-size:14px;font-weight:700;margin:16px 0 6px}
.cap .hint{font-size:12.5px;color:var(--muted);margin-top:-2px;margin-bottom:6px}

/* dynamic lists */
.dyn{margin-bottom:6px}
.dyn .drow{display:flex;gap:8px;margin-bottom:8px;align-items:flex-start}
.dyn .drow input{flex:1}
.dyn .drow input.small{flex:0 0 92px}
.dyn .drow input.mid{flex:0 0 110px}
.dyn .drow select{flex:0 0 92px;border:1.5px solid var(--line);border-radius:11px;padding:11px 8px;background:#fff}
.dyn .del{flex:none;background:var(--tint);border:none;color:var(--rust2);border-radius:9px;width:38px;height:44px;font-size:17px}
.addrow{background:none;border:1.5px dashed var(--line);color:var(--muted);border-radius:11px;padding:10px;width:100%;font-size:14px;font-weight:600}
.addrow:active{border-color:var(--gold);color:var(--rust2)}

/* runner footer nav */
.runnav{position:fixed;bottom:0;left:0;right:0;background:var(--cream);border-top:1.5px solid var(--line);padding:10px 18px calc(10px + env(safe-area-inset-bottom));z-index:35}
.runnav .in{max-width:640px;margin:0 auto;display:flex;gap:10px;align-items:center}
.runnav button{border:none;border-radius:12px;padding:13px 18px;font-size:15px;font-weight:700}
.runnav .back{background:var(--tint);color:var(--ink);flex:0 0 auto}
.runnav .next{background:var(--rust);color:#fff;flex:1}
.runnav .park{background:var(--teal);color:var(--gold);flex:0 0 auto;font-size:13px}
.badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:99px;background:var(--gold);color:#33291F;font-size:12px;font-weight:700;margin-left:6px;padding:0 6px}

/* parking drawer */
.drawer{position:fixed;inset:0;background:rgba(17,59,64,.5);z-index:60;display:flex;align-items:flex-end}
.drawer .panel{background:var(--cream);border-radius:20px 20px 0 0;width:100%;max-width:640px;margin:0 auto;max-height:80vh;overflow:auto;padding:20px 18px calc(20px + env(safe-area-inset-bottom))}
.drawer h3{font-family:"Fraunces",serif;font-size:20px;margin-bottom:4px}
.drawer .sub{font-size:13px;color:var(--muted);margin-bottom:14px}
.parkitem{display:flex;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:11px;padding:11px 13px;margin-bottom:8px;font-size:14.5px;align-items:center}
.parkitem .del{margin-left:auto;background:none;border:none;color:var(--rust2);font-size:16px}

/* summary */
.gap{background:#FBEDE4;border:1.5px solid var(--rust);border-radius:12px;padding:12px 15px;margin-bottom:12px;font-size:14px;color:var(--rust2);font-weight:600}
.sumblock{background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:15px 17px;margin-bottom:10px}
.sumblock .k{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--rust);font-weight:700;margin-bottom:5px}
.sumblock .v{font-size:14.5px;white-space:pre-wrap}
.sumblock .v em{color:var(--muted)}

/* five questions */
.fq{background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:22px 20px;margin-bottom:12px}
.fq .n{font-family:"Fraunces",serif;font-size:30px;color:var(--rust);line-height:1}
.fq h3{font-size:18px;font-weight:700;margin:8px 0 5px}
.fq p{font-size:14px;color:var(--muted)}
.anchor{font-family:"Fraunces",serif;font-style:italic;font-size:19px;color:var(--rust2);border-left:3px solid var(--rust);padding-left:16px;margin:20px 0}

/* weekly */
.bigclock{text-align:center;padding:26px 0 10px}
.bigclock .c{font-family:"Fraunces",serif;font-size:74px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1}
.bigclock .who{font-size:17px;font-weight:700;margin-top:8px}
.bigclock .nextup{font-size:13px;color:var(--muted);margin-top:3px}

/* misc */
.fine{font-size:12.5px;color:var(--muted);line-height:1.5}
.hr{border:none;border-top:1.5px solid var(--line);margin:20px 0}
.pill{display:inline-block;background:var(--tint);border:1px solid var(--line);border-radius:99px;padding:4px 12px;font-size:12px;font-weight:600;color:var(--muted);margin:0 6px 6px 0}
.toast{position:fixed;bottom:86px;left:50%;transform:translateX(-50%);background:var(--teal);color:#F2F1EA;border-radius:99px;padding:10px 20px;font-size:13.5px;font-weight:600;z-index:70;box-shadow:0 8px 24px rgba(17,59,64,.3);animation:fade .2s ease}

@media print{ .top,.runnav{display:none} }

/* ---- v2: dashboard ---- */
.dash-days{background:var(--teal);color:#F2F1EA;border-radius:18px;padding:22px 22px 18px;margin-bottom:12px;text-align:center}
.dash-days.empty{padding:26px 22px}
.dash-days .dd-num{font-size:64px;font-weight:700;line-height:1;color:#FCFCF8}
.dash-days .dd-lbl{font-size:13px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:700;margin-top:4px}
.dash-days .dd-bar{height:8px;background:var(--teal2);border-radius:99px;margin:14px 0 8px;overflow:hidden}
.dash-days .dd-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold),var(--rust));border-radius:99px}
.dash-days .dd-sub{font-size:12px;color:#C3D1CC}
.linkbtn{background:none;border:none;color:var(--gold);font-size:12px;text-decoration:underline;cursor:pointer;padding:0 2px}
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
@media(max-width:520px){.dash-grid{grid-template-columns:1fr}}
.dash-card{display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--line);border-radius:16px;padding:14px 16px;text-align:left;font-family:inherit}
.dash-card.static{cursor:default}
.dash-card.wide{margin-bottom:10px}
.dash-card .dc-t{font-size:14px;font-weight:700}
.dash-card .dc-d{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.45}
.dash-card .dc-d .bad{color:var(--rust2);font-weight:700}
.ringsvg{width:64px;height:64px;flex:none}
.rule-lbl{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin:20px 0 10px}
.pill.bad{color:var(--rust2);border-color:var(--rust);background:#FBEDE4}
.tstats{margin-bottom:12px}

/* ---- v2: tracker ---- */
.titem{background:#fff;border:1.5px solid var(--line);border-radius:14px;padding:12px 13px;margin-bottom:10px}
.titem input[type=text]{border:none;padding:4px 2px;font-weight:600;border-radius:0}
.titem input[type=text]:focus{outline:none;box-shadow:0 2px 0 var(--gold)}
.titem .trow2{display:flex;gap:7px;margin-top:8px;flex-wrap:wrap;align-items:center}
.titem .trow2 select,.titem .trow2 input{border:1.5px solid var(--line);border-radius:9px;padding:8px;font-size:13.5px;background:#fff}
.titem .trow2 select{flex:1 1 90px}
.titem .trow2 input[type=date]{flex:1 1 120px}
.titem .trow2 .del{flex:none;background:var(--tint);border:none;color:var(--rust2);border-radius:9px;width:36px;height:37px;font-size:16px}
.titem .tnotes{font-size:13px;color:var(--muted);font-weight:400 !important;margin-top:6px;width:100%}
.titem.tdone{opacity:.62;border-color:#BFD6CB;background:#F3F8F4}
.titem.tdone > input[type=text]{text-decoration:line-through}
.titem.tblock{border-color:var(--rust);background:#FBEDE4}
.titem.tlate{border-color:var(--warn)}
.titem select.stat{font-weight:700}

/* ---- v2: worksheets ---- */
.wsh{font-size:14.5px;font-weight:700;margin:18px 0 6px}
.wsowner{background:var(--teal);color:var(--gold);border-radius:10px;padding:8px 14px;font-weight:700;font-size:14px;letter-spacing:1px;margin:22px 0 4px}
.wgrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
@media(max-width:560px){.wgrid{grid-template-columns:1fr}}
.wsel{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:11px;background:#fff;font-size:15px}

/* ---- v3: walkthrough ---- */
.walk{text-align:center;padding:20px 0}
.walk .wnum{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);font-weight:700}
.walk .wart{width:92px;height:92px;border-radius:26px;background:var(--teal);color:var(--gold);font-size:40px;font-weight:600;display:flex;align-items:center;justify-content:center;margin:18px auto}
.walk .wdots{display:flex;gap:8px;justify-content:center;margin-top:18px}
.walk .wdots i{width:9px;height:9px;border-radius:50%;background:var(--line)}
.walk .wdots i.on{background:var(--rust)}
.linkbtn2{background:none;border:none;color:var(--muted);font-size:13px;text-decoration:underline;margin-top:16px;display:inline-block}

/* ---- v3: who am I + top bar ---- */
.mebtn{background:var(--rust);border:none;color:#fff;border-radius:8px;padding:4px 10px;font-size:11.5px;font-weight:700}
.tile .ico.okico{background:#2E6B62;color:#fff}

/* ---- v3: journey next-card ---- */
.next-card{background:linear-gradient(135deg,var(--teal),var(--teal2));color:#F2F1EA;border-radius:18px;padding:22px;margin-bottom:12px}
.next-card .nk{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);font-weight:700}
.next-card .nt{font-size:26px;font-weight:600;color:#FCFCF8;margin:6px 0 4px}
.next-card .nd{font-size:14px;color:#D8E0DB;margin-bottom:14px;line-height:1.5}
.next-card .btn{background:var(--rust)}
.chips2{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.chip2{background:var(--teal2);color:#D8E0DB;border-radius:99px;padding:5px 13px;font-size:12.5px;font-weight:600}
.chip2.ok{background:#2E6B62;color:#fff}

/* ---- v3: prep ---- */
.preppart{font-family:"Fraunces",serif;font-size:20px;font-weight:600;margin:26px 0 8px;display:flex;align-items:center;gap:10px}
.preppart .pn{flex:none;width:30px;height:30px;border-radius:50%;background:var(--rust);color:#fff;font-family:"Inter",sans-serif;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center}
.wgline{display:block;background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:14px 15px;margin-bottom:9px}
.wgline .wgl b{display:block;font-size:15px}
.wgline .wgl span{display:block;font-size:12.5px;color:var(--muted);margin-top:1px;line-height:1.45}
.segrow{display:flex;gap:8px;margin-top:11px}
.seg{flex:1;background:var(--tint);border:1.5px solid var(--line);border-radius:10px;padding:10px 4px;font-size:13px;font-weight:700;color:var(--muted);text-align:center}
.seg.on.sG{background:#2E6B62;border-color:#2E6B62;color:#fff}
.seg.on.sC{background:var(--gold);border-color:var(--gold);color:#33291F}
.seg.on.sF{background:var(--rust2);border-color:var(--rust2);color:#fff}
.wgcount{margin-top:10px;font-size:13.5px;font-weight:600;color:var(--muted);background:var(--tint);border-radius:10px;padding:10px 14px}
.wgcount.ok{background:#EAF3EC;color:#2E6B62}

/* ---- v3: team map ---- */
.maprow{display:flex;gap:12px;background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:12px 14px;margin-bottom:8px}
.mapbody b{font-size:15px}
.mapline{font-size:13px;margin-top:2px}
.mapline .g{color:#2E6B62;font-weight:700}
.mapline .c{color:var(--warn);font-weight:700}
.mapline .f{color:var(--rust2);font-weight:700}

/* ---- v3: auto checks ---- */
.check.auto{cursor:default}
.autoico{flex:none;width:22px;height:22px;border-radius:50%;background:var(--tint);border:1.5px solid var(--line);color:var(--muted);font-size:13px;display:flex;align-items:center;justify-content:center;margin-top:2px;font-weight:700}
.autoico.ok{background:#2E6B62;border-color:#2E6B62;color:#fff}
