/* Puppy Companion design system.
   Palette, type and components ported from the product prototype (spec §12). */
:root{
  --ink:#23281F;--ink-soft:#5C6357;--ink-faint:#8C9183;
  --paper:#F4F2EB;--surface:#FFFFFF;--surface-warm:#FBFAF5;--mist:#EAEDE3;
  --pine:#2F6B57;--pine-deep:#234F40;--pine-tint:#E2ECE5;
  --honey:#D9912C;--honey-tint:#F6EAD2;--coral:#CB5C43;--coral-tint:#F6E0D9;
  --line:rgba(35,40,31,0.09);--line-strong:rgba(35,40,31,0.14);
  --shadow:0 1px 2px rgba(35,40,31,0.05), 0 8px 24px rgba(35,40,31,0.06);
  --shadow-lift:0 2px 4px rgba(35,40,31,0.06), 0 16px 40px rgba(35,40,31,0.12);
  --r-lg:26px;--r-md:18px;--r-sm:13px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{font-family:'Hanken Grotesk',system-ui,sans-serif;background:var(--paper);color:var(--ink);
  -webkit-font-smoothing:antialiased;min-height:100vh}
.h-serif{font-family:'Fraunces',serif;font-weight:500;letter-spacing:-.01em;line-height:1.05}
.mono{font-family:'DM Mono',monospace;font-variant-numeric:tabular-nums}
.eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint)}

/* ============ ONBOARDING ============ */
.onboard{min-height:100vh;background:var(--paper);display:flex;flex-direction:column;align-items:center}
.ob-step{position:relative;width:100%;max-width:480px;min-height:100vh;padding:64px 24px 40px;display:none;flex-direction:column}
.ob-step.active{display:flex}
.ob-logo{width:62px;height:62px;border-radius:20px;background:var(--pine);display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.ob-logo svg{width:34px;height:34px;stroke:#fff;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.ob-step h1{font-family:'Fraunces',serif;font-weight:500;font-size:33px;line-height:1.08;letter-spacing:-.01em}
.ob-step h1 em{font-style:italic;color:var(--pine)}
.ob-step .lede{font-size:15px;color:var(--ink-soft);line-height:1.5;margin-top:14px}
.ob-spacer{flex:1}
.btn-primary{background:var(--pine);color:#fff;border:none;border-radius:16px;padding:17px;width:100%;
  font-family:inherit;font-size:16px;font-weight:600;cursor:pointer;transition:transform .12s, background .2s}
.btn-primary:active{transform:scale(.98);background:var(--pine-deep)}
.btn-primary:disabled{background:var(--line-strong);color:var(--ink-faint);cursor:not-allowed}
.btn-google{background:#fff;color:var(--ink);border:1px solid var(--line-strong);border-radius:16px;padding:16px;width:100%;
  font-family:inherit;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:12px;
  box-shadow:var(--shadow);transition:transform .12s;text-decoration:none}
.btn-google:active{transform:scale(.98)}
.btn-google svg{width:21px;height:21px}
.ob-ghost{background:none;border:none;color:var(--ink-faint);font-family:inherit;font-size:13.5px;font-weight:600;
  cursor:pointer;width:100%;text-align:center;margin-top:18px;padding:6px;text-decoration:none;display:block}
.ob-ghost u{color:var(--pine);text-decoration:none;border-bottom:1.5px solid var(--pine-tint)}

.choice{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:20px;
  cursor:pointer;display:flex;gap:16px;align-items:center;box-shadow:var(--shadow);transition:transform .12s, border-color .2s;margin-bottom:13px;text-align:left;width:100%;font-family:inherit;text-decoration:none;color:inherit}
.choice:active{transform:scale(.98)}
.choice:focus-visible{outline:2px solid var(--pine);outline-offset:2px}
.choice .ci{width:48px;height:48px;border-radius:14px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.choice .ci.a{background:var(--pine-tint)} .choice .ci.a svg{stroke:var(--pine)}
.choice .ci.b{background:var(--honey-tint)} .choice .ci.b svg{stroke:var(--honey)}
.choice .ci svg{width:24px;height:24px;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.choice .ctx b{font-size:16px;font-weight:600;display:block;margin-bottom:3px}
.choice .ctx span{font-size:13px;color:var(--ink-soft);line-height:1.35}

.field{margin-bottom:18px}
.field label{font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);display:block;margin-bottom:8px}
.field input{width:100%;border:1px solid var(--line-strong);border-radius:13px;padding:15px;font-family:inherit;font-size:16px;background:var(--surface);color:var(--ink)}
.field input:focus{outline:none;border-color:var(--pine);box-shadow:0 0 0 3px var(--pine-tint)}
.field .hint{font-size:12px;color:var(--ink-faint);margin-top:7px}
.seg{display:flex;gap:8px}
.seg button{flex:1;border:1px solid var(--line-strong);background:var(--surface);border-radius:13px;padding:14px;
  font-family:inherit;font-size:15px;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.15s}
.seg button.on{background:var(--pine);color:#fff;border-color:var(--pine)}
/* Radio-backed segmented control (no JS): the checked input styles its label. */
.seg-radio{display:flex;gap:8px}
.seg-radio input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}
.seg-radio label{flex:1;text-align:center;border:1px solid var(--line-strong);background:var(--surface);border-radius:13px;padding:14px;
  font-family:inherit;font-size:15px;font-weight:600;color:var(--ink-soft);cursor:pointer;transition:.15s}
.seg-radio input:checked + label{background:var(--pine);color:#fff;border-color:var(--pine)}
.seg-radio input:focus-visible + label{outline:2px solid var(--pine);outline-offset:2px}
.ob-back{position:absolute;top:62px;left:24px;background:none;border:none;cursor:pointer;padding:6px;color:var(--ink-soft);text-decoration:none}
.ob-back svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.done-mark{width:84px;height:84px;border-radius:50%;background:var(--pine-tint);display:flex;align-items:center;justify-content:center;margin-bottom:26px}
.done-mark svg{width:42px;height:42px;stroke:var(--pine);fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.form-error{background:var(--coral-tint);color:#8f3a28;border-radius:var(--r-sm);padding:12px 14px;font-size:13px;font-weight:500;margin-bottom:16px;line-height:1.4}

/* ============ APP SHELL (responsive) ============ */
/* Mobile-first: a centered scrolling column with a fixed bottom tab bar. */
.screen{max-width:760px;margin:0 auto;padding:28px 20px 120px}

/* Today becomes a multi-column dashboard on wide screens (see media query). */
.dashboard{display:flex;flex-direction:column}
.panel > .section-label:first-child{margin-top:0}
.panel > .focus:first-child{margin-top:0}

.nav{position:fixed;bottom:0;left:0;right:0;z-index:30;height:74px;
  background:linear-gradient(to top, var(--paper) 72%, rgba(244,242,235,0));
  display:flex;align-items:flex-start;justify-content:space-around;padding:12px 16px 0;border-top:1px solid var(--line)}
.nav-btn{background:none;border:none;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;align-items:center;gap:5px;
  color:var(--ink-faint);font-size:10.5px;font-weight:600;padding:8px 14px;border-radius:14px;transition:color .2s;text-decoration:none}
.nav-btn svg{width:23px;height:23px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.nav-btn.active{color:var(--pine)}
.nav-btn:focus-visible{outline:2px solid var(--pine);outline-offset:2px}

.card{background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow);padding:18px}
.section-label{display:flex;align-items:center;justify-content:space-between;margin:26px 4px 12px}
.section-label h3{font-size:13px;font-weight:700;letter-spacing:.04em;color:var(--ink-soft);text-transform:uppercase}
.section-label .link{font-size:12.5px;font-weight:600;color:var(--pine);background:none;border:none;cursor:pointer;font-family:inherit;text-decoration:none}

.today-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.greet h1{font-family:'Fraunces',serif;font-weight:500;font-size:28px;line-height:1.05;margin-top:4px}
.greet h1 em{font-style:italic;color:var(--pine)}
.avatar{width:52px;height:52px;border-radius:50%;flex-shrink:0;background:radial-gradient(circle at 35% 30%, #C9A36b, #8a5a33);
  box-shadow:0 0 0 3px var(--paper), 0 0 0 4.5px var(--line-strong);display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;color:#fff;font-size:22px;font-weight:600;cursor:pointer;border:none;text-decoration:none}

.focus{margin-top:18px;border-radius:var(--r-lg);padding:24px 22px;background:linear-gradient(150deg, #FFFFFF 0%, #F3F7F1 100%);
  box-shadow:var(--shadow-lift);position:relative;overflow:hidden;display:flex;align-items:center;gap:20px}
.focus::before{content:"";position:absolute;top:-40%;right:-20%;width:200px;height:200px;border-radius:50%;background:var(--pine-tint);opacity:.5;filter:blur(8px)}
.focus.overdue{background:linear-gradient(150deg,#FFFFFF 0%, #FaeFEb 100%)}
.focus.overdue::before{background:var(--coral-tint)}
.ring-wrap{position:relative;width:118px;height:118px;flex-shrink:0;z-index:1}
.ring-wrap svg{transform:rotate(-90deg)}
.ring-bg{stroke:var(--mist)} .ring-fg{stroke:var(--pine);transition:stroke-dashoffset 1s linear, stroke .4s}
.focus.overdue .ring-fg{stroke:var(--coral)}
.ring-core{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}
.ring-core .time{font-family:'DM Mono',monospace;font-size:23px;font-weight:500;line-height:1}
.ring-core .unit{font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);margin-top:4px}
.focus-body{z-index:1;flex:1}
.focus-body .label{font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--pine)}
.focus.overdue .focus-body .label{color:var(--coral)}
.focus-body h2{font-family:'Fraunces',serif;font-weight:500;font-size:21px;margin:6px 0 8px;line-height:1.12}
.focus-body p{font-size:13px;color:var(--ink-soft);line-height:1.4}
.ring-pulse{animation:breathe 4s ease-in-out infinite}
@keyframes breathe{0%,100%{opacity:1}50%{opacity:.55}}

.quick-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:9px}
.quick-grid form{display:contents}
.qbtn{width:100%}
.qbtn{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-sm);cursor:pointer;font-family:inherit;
  padding:13px 4px 11px;display:flex;flex-direction:column;align-items:center;gap:7px;transition:transform .12s ease;box-shadow:var(--shadow)}
.qbtn:active{transform:scale(.93)} .qbtn:focus-visible{outline:2px solid var(--pine);outline-offset:2px}
.qbtn svg{width:25px;height:25px;stroke:var(--pine);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.qbtn span{font-size:11px;font-weight:600;color:var(--ink-soft)}
.qhint{text-align:center;font-size:11.5px;color:var(--ink-faint);margin-top:11px}
.plan{padding:4px 16px}
.plan-row{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line)}
.plan-row:last-child{border-bottom:none}
.plan-row.tap{cursor:pointer} .plan-row.tap:active{opacity:.6}
.plan form{display:contents}
button.plan-row{width:100%;border:none;background:none;font-family:inherit;text-align:left}
button.plan-row:focus-visible{outline:2px solid var(--pine);outline-offset:2px}
.plan-row .pic{width:36px;height:36px;border-radius:11px;background:var(--pine-tint);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.plan-row .pic svg{width:19px;height:19px;stroke:var(--pine);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.plan-row .pinfo{flex:1}
.plan-row .pinfo b{font-size:14px;font-weight:600;display:block}
.plan-row .pinfo span{font-size:12px;color:var(--ink-faint)}
.plan-row .pprog{font-family:'DM Mono';font-size:11.5px;color:var(--ink-soft);text-align:right;white-space:nowrap;line-height:1.5}
.plan-dots{display:flex;gap:4px;margin-top:5px}
.plan-dots i{width:7px;height:7px;border-radius:50%;background:var(--mist)}
.plan-dots i.on{background:var(--pine)}
.plan-note{font-size:11.5px;color:var(--ink-faint);padding:12px 0 4px;text-align:center;line-height:1.4}

.nudge{display:flex;gap:13px;align-items:flex-start;padding:15px 16px;border-radius:var(--r-md);margin-bottom:9px;background:var(--surface);box-shadow:var(--shadow)}
.nudge .ic{width:34px;height:34px;border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.nudge .ic svg{width:18px;height:18px;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nudge.amber .ic{background:var(--honey-tint)} .nudge.amber .ic svg{stroke:var(--honey)}
.nudge.pine .ic{background:var(--pine-tint)} .nudge.pine .ic svg{stroke:var(--pine)}
.nudge.coral .ic{background:var(--coral-tint)} .nudge.coral .ic svg{stroke:var(--coral)}
.nudge .txt{flex:1} .nudge .txt b{font-size:14px;font-weight:600;display:block;margin-bottom:2px}
.nudge .txt p{font-size:12.5px;color:var(--ink-soft);line-height:1.4}
.nudge .act{align-self:center;background:var(--mist);border:none;border-radius:20px;padding:7px 13px;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink);cursor:pointer;flex-shrink:0;text-decoration:none}

.timeline{position:relative;padding-left:6px}
.tl-item{display:flex;gap:14px;padding:3px 0;position:relative}
.tl-item:not(:last-child)::before{content:"";position:absolute;left:16px;top:34px;bottom:-4px;width:1.5px;background:var(--line-strong)}
.tl-dot{width:33px;height:33px;border-radius:50%;flex-shrink:0;z-index:1;background:var(--surface-warm);border:1px solid var(--line);display:flex;align-items:center;justify-content:center}
.tl-dot svg{width:16px;height:16px;stroke:var(--pine);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.tl-body{flex:1;padding-bottom:14px;display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.tl-body .what{font-size:14px;font-weight:600}
.tl-body .what small{display:block;font-weight:400;font-size:12px;color:var(--ink-faint);margin-top:1px}
.tl-body .when{font-family:'DM Mono',monospace;font-size:12px;color:var(--ink-faint);white-space:nowrap}
.tl-empty{text-align:center;color:var(--ink-faint);font-size:13px;padding:20px 10px;line-height:1.5}

.page-head h1{font-family:'Fraunces',serif;font-weight:500;font-size:30px;line-height:1.05;margin-top:5px}
.page-head p{font-size:13.5px;color:var(--ink-soft);margin-top:8px;line-height:1.4}

/* ============ RECORDS / PROFILE ============ */
.prof-top{display:flex;align-items:center;gap:15px;margin-top:4px}
.prof-top .pa{width:60px;height:60px;border-radius:50%;background:radial-gradient(circle at 35% 30%, #C9A36B, #8a5a33);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;color:#fff;font-size:25px;font-weight:600;flex-shrink:0}
.prof-top .pi{flex:1}
.prof-top .pi h1{font-family:'Fraunces',serif;font-size:26px;font-weight:500;line-height:1}
.prof-top .pi span{font-size:13px;color:var(--ink-faint)}
.meter{margin-top:18px;background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow);padding:16px 18px}
.meter .mt{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.meter .mt b{font-size:13.5px;font-weight:600} .meter .mt span{font-size:12.5px;font-weight:600;color:var(--pine)}
.bar{height:8px;border-radius:6px;background:var(--mist);overflow:hidden}
.bar i{display:block;height:100%;background:var(--pine);border-radius:6px;transition:width .5s}
.vault-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.vault-cell{background:var(--surface);border-radius:var(--r-sm);padding:14px;box-shadow:var(--shadow)}
.vault-cell .k{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.vault-cell .v{font-size:15px;font-weight:600;margin-top:5px}
.vault-cell .v.mono{font-family:'DM Mono',monospace;font-size:13.5px;font-weight:500}
.contact{display:flex;align-items:center;gap:13px;padding:13px 16px;background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow);margin-bottom:9px}
.contact .cic{width:40px;height:40px;border-radius:11px;background:var(--pine-tint);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact .cic svg{width:19px;height:19px;stroke:var(--pine);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.contact .ctxt{flex:1} .contact .ctxt b{font-size:14px;font-weight:600;display:block} .contact .ctxt span{font-size:12.5px;color:var(--ink-faint)}
.contact .call{width:38px;height:38px;border-radius:50%;background:var(--pine);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;text-decoration:none}
.contact .call svg{width:17px;height:17px;stroke:#fff;fill:none;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.appt{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow);margin-bottom:9px}
.appt .atxt{flex:1} .appt .atxt b{font-size:14px;font-weight:600;display:block} .appt .atxt span{font-size:12.5px;color:var(--ink-faint)}
.vacc{background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow);padding:6px 16px}
.vrow{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line)}
.vrow:last-child{border-bottom:none}
.vrow .vdot{width:22px;height:22px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.vrow.done .vdot{background:var(--pine)} .vrow.done .vdot svg{width:12px;height:12px;stroke:#fff;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.vrow.next .vdot{background:var(--honey-tint);border:2px solid var(--honey)}
.vrow .vname{flex:1;font-size:14px;font-weight:600} .vrow .vdate{font-family:'DM Mono',monospace;font-size:12px;color:var(--ink-soft)}

/* ============ JOURNAL ============ */
.growth{margin-top:6px;background:var(--surface);border-radius:var(--r-md);padding:18px 18px 14px;box-shadow:var(--shadow)}
.growth .top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:10px}
.growth .big{font-family:'Fraunces',serif;font-size:26px;font-weight:500}
.growth .big small{font-size:14px;color:var(--ink-faint);font-family:'Hanken Grotesk',sans-serif}
.growth .delta{font-size:12px;font-weight:600;color:var(--pine);background:var(--pine-tint);padding:4px 9px;border-radius:20px}
.spark{width:100%;height:62px}
.spark .ln{fill:none;stroke:var(--pine);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.spark .ar{fill:url(#sparkgrad);opacity:.9}
.spark .band{fill:#2F6B57;opacity:.12} .spark .exp{fill:none;stroke:#2F6B57;stroke-width:1.2;stroke-dasharray:3 3;opacity:.45}
.growth .legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:9px;font-size:11px;color:var(--ink-faint)}
.growth .legend i{display:inline-block;width:11px;height:11px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.growth .verdict{font-size:12.5px;color:var(--ink-soft);margin-top:11px;line-height:1.45} .growth .verdict b{color:var(--ink)}
.growth .ax{display:flex;justify-content:space-between;font-family:'DM Mono',monospace;font-size:10px;color:var(--ink-faint);margin-top:4px}
.recap{margin-top:6px;background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow);overflow:hidden}
.recap .ph{height:120px;background:linear-gradient(135deg,#cfe0d4,#a9c6b3 60%, #d8c79c);position:relative;display:flex;align-items:flex-end;padding:14px}
.recap .ph .wk{font-family:'Fraunces',serif;color:#fff;font-size:20px;font-weight:600;text-shadow:0 1px 6px rgba(0,0,0,.25)}
.recap .ph .auto{position:absolute;top:12px;left:14px;background:rgba(255,255,255,.85);border-radius:20px;padding:5px 11px;font-size:10.5px;font-weight:700;color:var(--pine);display:flex;gap:5px;align-items:center}
.recap .ph .auto svg{width:12px;height:12px;stroke:var(--pine);fill:none;stroke-width:2}
.recap .body{padding:16px 18px}
.recap .body p{font-size:13.5px;line-height:1.5;color:var(--ink-soft)}
.recap .body p b{color:var(--ink);font-weight:600}
.recap .chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:13px}
.chip{font-size:11.5px;font-weight:600;padding:5px 11px;border-radius:20px;background:var(--mist);color:var(--ink-soft)}
.chip.star{background:var(--honey-tint);color:#a9701a;display:flex;gap:5px;align-items:center}
.moment{display:flex;gap:13px;align-items:center;padding:13px 4px;border-bottom:1px solid var(--line)}
.moment:last-child{border-bottom:none}
.moment .thumb{width:54px;height:54px;border-radius:14px;flex-shrink:0;background:linear-gradient(135deg,#d8c79c,#bda06a);background-size:cover;background-position:center}
.moment .mtxt b{font-size:14px;font-weight:600;display:block} .moment .mtxt span{font-size:12px;color:var(--ink-faint)}

/* ============ SHARE ============ */
.story{margin-top:6px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lift);background:#1f2a23;position:relative;aspect-ratio:4/5}
.story .img{position:absolute;inset:0;background:linear-gradient(160deg,#cdbd8f,#9f7a4f 55%,#5d6e57);background-size:cover;background-position:center}
.story .grad{position:absolute;inset:0;background:linear-gradient(to top, rgba(20,28,22,.78) 0%, rgba(20,28,22,0) 50%)}
.story .cap{position:absolute;left:0;right:0;bottom:0;padding:22px}
.story .cap .auto{display:inline-flex;gap:6px;align-items:center;background:rgba(255,255,255,.92);border-radius:20px;padding:5px 11px;font-size:10.5px;font-weight:700;color:var(--pine);margin-bottom:11px}
.story .cap .auto svg{width:12px;height:12px;stroke:var(--pine);fill:none;stroke-width:2}
.story .cap h2{font-family:'Fraunces',serif;color:#fff;font-size:24px;font-weight:500;line-height:1.12;margin-bottom:6px}
.story .badge{position:absolute;top:16px;left:16px;background:rgba(255,255,255,.9);border-radius:20px;padding:6px 12px;font-family:'DM Mono',monospace;font-size:11px;color:var(--ink)}
.share-targets{display:flex;gap:10px;margin-top:16px}
.starget{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 6px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;font-family:inherit;box-shadow:var(--shadow);transition:transform .12s}
.starget:active{transform:scale(.95)}
.starget .si{width:42px;height:42px;border-radius:13px;display:flex;align-items:center;justify-content:center}
.starget .si svg{width:22px;height:22px}
.starget span{font-size:11.5px;font-weight:600;color:var(--ink-soft)}
.si.more{background:var(--ink)}
.edit-row{display:flex;gap:9px;margin-top:14px}
.edit-btn{flex:1;background:var(--mist);border:none;border-radius:var(--r-sm);padding:12px;font-family:inherit;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}

/* Narrow centered column (Share story reads best portrait, not full-width). */
.narrow{max-width:460px;margin:0 auto}

/* toast */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;border-radius:28px;padding:12px 16px;z-index:70;display:flex;align-items:center;gap:13px;box-shadow:0 12px 30px rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:opacity .25s, transform .25s;max-width:88%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.toast .tmsg{font-size:13.5px;font-weight:500;white-space:nowrap} .toast .tmsg b{font-weight:700}
.toast .undo{background:none;border:none;color:#9fd8c4;font-family:inherit;font-weight:700;font-size:13px;cursor:pointer;padding:2px 4px}

/* Wide screens: top nav bar + roomier content; Today turns into a dashboard. */
@media (min-width:820px){
  .nav{top:0;bottom:auto;height:auto;border-top:none;border-bottom:1px solid var(--line);
    background:var(--surface);justify-content:center;gap:6px;padding:10px 16px;box-shadow:var(--shadow)}
  .nav-btn{flex-direction:row;gap:8px;font-size:13.5px;padding:9px 18px}
  .nav-btn svg{width:20px;height:20px}
  .screen{padding:106px 24px 48px;max-width:1040px}
  .dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px;align-items:start}
  .dashboard .panel{min-width:0}
}
@media (max-width:480px){
  .ob-step{padding:40px 22px 36px}
}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
