/* ===================================================================
   Japan 2026 - trip guide
   Refreshed + modern: Fraunces serif + Inter grotesk, cream paper,
   rust + autumn gold/pine. Mobile-first. Generated pages share this.
   =================================================================== */
:root{
  --bg:#faf8f3;
  --bg-soft:#f1ecdf;
  --paper:#fffefb;
  --ink:#17150f;
  --ink-soft:#595348;
  --ink-faint:#9a9283;
  --rust:#b1421a;
  --rust-soft:#c9663a;
  --gold:#b5862f;
  --pine:#3c5142;
  --rule:#ebe4d4;
  --rule-soft:#f2ecdf;
  --display:"Fraunces","Iowan Old Style",Georgia,serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI","Helvetica Neue",Arial,sans-serif;
  --shadow:0 1px 1px rgba(23,21,15,.03),0 12px 34px -10px rgba(23,21,15,.12);
  --shadow-lg:0 2px 4px rgba(23,21,15,.04),0 26px 60px -16px rgba(23,21,15,.20);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:70px;overflow-x:hidden}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.62;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{color:var(--rust);text-decoration:none}
:focus-visible{outline:2px solid var(--rust);outline-offset:3px;border-radius:3px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---- top bar ---- */
.bar{position:sticky;top:0;z-index:90;background:rgba(250,248,243,.8);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--rule)}
.bar__in{max-width:1220px;margin:0 auto;display:flex;align-items:center;gap:16px;padding:13px 24px}
.brand{font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:-.02em;display:flex;align-items:center;gap:7px;color:var(--ink)}
.brand .dot{width:7px;height:7px;border-radius:50%;background:var(--rust)}
.brand .yr{color:var(--rust)}
.bar__nav{margin-left:auto;display:flex;gap:2px;overflow-x:auto;scrollbar-width:none}
.bar__nav::-webkit-scrollbar{display:none}
.bar__nav a{font-size:13px;font-weight:500;color:var(--ink-soft);padding:7px 13px;border-radius:100px;white-space:nowrap;transition:.18s}
.bar__nav a:hover,.bar__nav a.on{color:var(--rust);background:rgba(177,66,26,.08)}
.navtoggle{display:none}
@media(max-width:720px){
  .navtoggle{display:flex;flex-direction:column;justify-content:center;gap:5px;margin-left:auto;width:44px;height:38px;padding:0 11px;background:var(--paper);border:1px solid var(--rule);border-radius:10px;cursor:pointer}
  .navtoggle__b{height:2px;background:var(--ink);border-radius:2px;transition:transform .22s ease,opacity .15s ease}
  .bar__nav{position:absolute;top:100%;left:0;right:0;margin:0;flex-direction:column;align-items:stretch;gap:3px;overflow:hidden;background:rgba(250,248,243,.98);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-bottom:1px solid var(--rule);box-shadow:var(--shadow-lg);padding:0 16px;max-height:0;opacity:0;visibility:hidden;transition:max-height .28s ease,opacity .2s ease,padding .28s ease}
  .bar.open .bar__nav{max-height:80vh;overflow-y:auto;opacity:1;visibility:visible;padding:8px 16px 14px}
  .bar__nav a{font-size:16px;font-weight:600;padding:13px 14px;border-radius:10px}
  .bar.open .navtoggle__b:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .bar.open .navtoggle__b:nth-child(2){opacity:0}
  .bar.open .navtoggle__b:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}

/* ---- home hero ---- */
.hero{position:relative;min-height:min(92vh,860px);display:flex;align-items:flex-end;overflow:hidden}
.hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;animation:slowzoom 18s ease-out both}
@keyframes slowzoom{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero__scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,8,.8) 0%,rgba(15,12,8,.25) 46%,rgba(15,12,8,.08) 100%)}
.hero__in{position:relative;max-width:1220px;margin:0 auto;width:100%;padding:0 24px 64px;color:#fdf8ee}
.kick{display:inline-block;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:#fbe6c2;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(6px);padding:7px 14px;border-radius:100px;margin-bottom:22px}
.hero h1{font-family:var(--display);font-weight:600;font-size:clamp(52px,12vw,120px);line-height:.92;letter-spacing:-.035em;margin:0 0 20px;text-shadow:0 4px 40px rgba(0,0,0,.3);animation:rise 1s cubic-bezier(.2,.7,.2,1) both}
.hero h1 .ja{display:block;font-weight:400;font-size:.3em;letter-spacing:.04em;color:#ece0c8;margin-top:14px;text-shadow:none}
@keyframes rise{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:none}}
.hero__sub{font-family:var(--display);font-style:italic;font-size:clamp(20px,3.6vw,30px);color:#f5ecda;margin:0;max-width:28ch;animation:rise 1s .12s cubic-bezier(.2,.7,.2,1) both}

/* ---- facts ribbon ---- */
.ribbon{background:var(--ink);color:#f3ecdd}
.ribbon__in{max-width:1220px;margin:0 auto;display:flex;flex-wrap:wrap;padding:6px 24px}
.ribbon .r{flex:1;min-width:128px;padding:22px 8px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.ribbon .r:last-child{border-right:none}
.ribbon dt{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#b8a981;margin-bottom:7px;font-weight:600}
.ribbon dd{margin:0;font-family:var(--display);font-size:23px;font-weight:500;letter-spacing:-.01em}

/* ---- section heading ---- */
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.shead{display:flex;align-items:baseline;gap:18px;margin:104px 0 10px}
.shead h2{font-family:var(--display);font-weight:600;font-size:clamp(30px,5.4vw,46px);letter-spacing:-.025em;margin:0;white-space:nowrap}
.shead::after{content:"";flex:1;height:1px;background:var(--rule);transform:translateY(-8px)}
.slead{color:var(--ink-soft);max-width:62ch;margin:0 0 48px;font-size:17.5px}

/* ---- route timeline (home) ---- */
.route{margin:8px 0 40px}
.stop{display:grid;grid-template-columns:1fr;background:var(--paper);border:1px solid var(--rule);border-radius:20px;overflow:hidden;box-shadow:var(--shadow);transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s;color:inherit}
.stop:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.stop__img{position:relative;aspect-ratio:16/10;overflow:hidden}
.stop__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.stop:hover .stop__img img{transform:scale(1.05)}
.stop__tag{position:absolute;top:14px;left:14px;background:rgba(250,248,243,.92);color:var(--ink);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:6px 11px;border-radius:100px;backdrop-filter:blur(6px)}
.stop__tag.day{background:rgba(60,81,66,.9);color:#eaf2ec}
.stop__body{padding:24px 26px 26px}
.stop__no{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:9px}
.stop__name{font-family:var(--display);font-weight:600;font-size:29px;line-height:1.04;margin:0 0 5px;letter-spacing:-.02em;color:var(--ink)}
.stop__name .ja{font-weight:400;font-size:.58em;color:var(--ink-faint);margin-left:9px}
.stop__meta{font-size:12.5px;color:var(--ink-faint);margin:0 0 13px;font-weight:500}
.stop__txt{color:var(--ink-soft);font-size:15px;margin:0 0 16px}
.stop__go{font-size:13px;font-weight:600;color:var(--rust);display:inline-flex;align-items:center;gap:7px}
.stop__go .arr{transition:transform .2s}
.stop:hover .stop__go .arr{transform:translateX(5px)}
.hop{display:flex;align-items:center;gap:12px;justify-content:center;color:var(--ink-faint);font-size:12px;letter-spacing:.04em;font-weight:500;margin:-8px 0 22px}
.hop::before,.hop::after{content:"";height:1px;width:40px;background:var(--rule)}
@media(min-width:760px){
  .stop{grid-template-columns:44% 1fr}
  .stop__img{aspect-ratio:auto;height:100%;min-height:264px}
  .stop:nth-child(even) .stop__img{order:2}
  .stop__body{padding:34px 40px;display:flex;flex-direction:column;justify-content:center}
  .stop__name{font-size:34px}
}

/* ---- city page hero ---- */
.chero{position:relative;min-height:min(74vh,620px);display:flex;align-items:flex-end;overflow:hidden}
.chero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;animation:slowzoom 18s ease-out both}
.chero__scrim{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,12,8,.76),rgba(15,12,8,.04) 62%)}
.chero__in{position:relative;max-width:1120px;margin:0 auto;width:100%;padding:0 24px 44px;color:#fdf8ee}
.chero__crumb{display:inline-block;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:#fbe6c2;font-weight:600;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:6px 13px;border-radius:100px;margin-bottom:16px;backdrop-filter:blur(6px)}
.chero h1{font-family:var(--display);font-weight:600;font-size:clamp(48px,9.5vw,88px);line-height:.94;letter-spacing:-.035em;margin:0}
.chero h1 .ja{font-weight:400;font-size:.36em;color:#ece0c8;margin-left:16px;letter-spacing:.02em}

/* ---- page subnav ---- */
.subnav{position:sticky;top:55px;z-index:80;background:rgba(250,248,243,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--rule)}
.subnav__in{max-width:1120px;margin:0 auto;display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;padding:9px 18px}
.subnav__in::-webkit-scrollbar{display:none}
.subnav a{font-size:13px;font-weight:600;color:var(--ink-soft);padding:8px 14px;white-space:nowrap;border-radius:100px;transition:.18s}
.subnav a:hover{color:var(--rust)}
.subnav a.on{color:#fff;background:var(--rust)}

/* ---- facts strip ---- */
.cfacts{display:flex;flex-wrap:wrap;border:1px solid var(--rule);border-radius:18px;background:var(--paper);margin:40px 0 8px;overflow:hidden;box-shadow:var(--shadow)}
.cfacts .f{flex:1;min-width:128px;padding:20px 22px;border-right:1px solid var(--rule)}
.cfacts .f:last-child{border-right:none}
.cfacts dt{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px;font-weight:600}
.cfacts dd{margin:0;font-family:var(--display);font-weight:500;font-size:18px;letter-spacing:-.01em}
.cintro{font-size:19px;line-height:1.72;color:var(--ink);max-width:66ch;margin:34px 0 8px}

/* ---- day-trip callout (base pages) ---- */
.daytrip-link{display:flex;align-items:center;gap:16px;background:var(--paper);border:1px solid var(--rule);border-left:3px solid var(--pine);border-radius:14px;padding:16px 20px;margin:26px 0 0;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.daytrip-link:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.daytrip-link img{width:64px;height:64px;border-radius:10px;object-fit:cover;flex-shrink:0}
.daytrip-link__k{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--pine);font-weight:700;margin-bottom:3px}
.daytrip-link__n{font-family:var(--display);font-weight:600;font-size:20px;color:var(--ink);letter-spacing:-.01em}
.daytrip-link__a{margin-left:auto;color:var(--rust);font-weight:600;font-size:13px;white-space:nowrap}

/* ---- city sections ---- */
.csec{scroll-margin-top:118px}
.csec h3.kh{font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--rust);margin:76px 0 8px;display:flex;align-items:center;gap:14px}
.csec h3.kh::after{content:"";flex:1;height:1px;background:var(--rule)}
.csec .sublead{color:var(--ink-soft);margin:0 0 30px;font-size:15.5px}

/* DO - editorial numbered features */
.feat{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:52px;align-items:center}
.feat__img{aspect-ratio:3/2;border-radius:18px;overflow:hidden;box-shadow:var(--shadow)}
.feat__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.feat:hover .feat__img img{transform:scale(1.04)}
.feat__n{font-family:var(--display);font-weight:500;font-size:40px;color:var(--gold);line-height:1;letter-spacing:-.02em;opacity:.9}
.feat h4{font-family:var(--display);font-weight:600;font-size:28px;line-height:1.1;margin:8px 0 12px;letter-spacing:-.02em}
.feat p{margin:0;color:var(--ink-soft);font-size:15.5px}
@media(min-width:720px){
  .feat{grid-template-columns:1fr 1fr;gap:48px}
  .feat:nth-child(even) .feat__img{order:2}
}

/* STAY / EAT - rows + placeholder slots */
.rows{display:flex;flex-direction:column;gap:16px}
.row{display:grid;grid-template-columns:92px 1fr;gap:18px;align-items:center;background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.row:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.row__thumb{width:92px;height:92px;border-radius:12px;object-fit:cover;background:var(--bg-soft)}
.row__name{font-family:var(--display);font-weight:600;font-size:20px;margin:0 0 6px;letter-spacing:-.01em}
.row__tags{display:flex;flex-wrap:wrap;gap:7px;margin:0 0 7px}
.tag{font-size:11px;font-weight:600;color:var(--pine);background:rgba(60,81,66,.09);padding:4px 10px;border-radius:100px}
.tag.gold{color:var(--gold);background:rgba(181,134,47,.11)}
.row__note{margin:0;font-size:14px;color:var(--ink-soft)}
.row__link{font-size:12.5px;font-weight:600;color:var(--rust);margin-top:7px;display:inline-block}
.slot{display:flex;align-items:center;justify-content:center;gap:10px;border:1.5px dashed var(--rule);border-radius:16px;padding:26px;color:var(--ink-faint);font-size:14.5px;font-weight:500;text-align:center;transition:.2s}
.slot:hover{border-color:var(--rust-soft);color:var(--ink-soft);background:rgba(177,66,26,.02)}
.slot b{color:var(--rust);font-weight:600}

/* quick-facts eyebrow + place lists (eat / wishlist) */
.facts-eyebrow{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin:36px 0 0}
.facts-eyebrow + .cfacts{margin-top:8px}
.places{display:flex;flex-direction:column;gap:14px;margin-bottom:16px}
.place{background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:15px 18px;box-shadow:var(--shadow)}
.place__h{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px 12px}
.place__n{font-family:var(--display);font-weight:600;font-size:18px;letter-spacing:-.01em}
.place__a{font-size:12px;color:var(--ink-faint);font-weight:600}
.place__tbc{font-size:10.5px;font-weight:600;color:var(--gold);background:rgba(181,134,47,.12);padding:2px 8px;border-radius:100px}
.place__tags{display:flex;flex-wrap:wrap;gap:7px;margin:8px 0 0}
.place__note{margin:8px 0 0;font-size:14.5px;color:var(--ink-soft);line-height:1.55}
.place__link{display:inline-block;margin-top:8px;font-size:12.5px;font-weight:600;color:var(--rust)}
.wishblock{margin-top:8px}
.subhead{font-family:var(--display);font-weight:600;font-size:20px;margin:0 0 16px;letter-spacing:-.01em}

/* getting around */
.move{display:grid;grid-template-columns:1fr;gap:14px}
.move .m{background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:18px 20px;box-shadow:var(--shadow)}
.move .m dt{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px;font-weight:600}
.move .m dd{margin:0;font-size:15px;color:var(--ink-soft)}
@media(min-width:640px){.move{grid-template-columns:1fr 1fr}}

/* day-by-day */
.days{border-left:2px solid var(--rule);margin:8px 0 0}
.day{position:relative;padding:0 0 30px 28px}
.day::before{content:"";position:absolute;left:-7px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--rust);box-shadow:0 0 0 4px var(--bg)}
.day__d{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:700;margin-bottom:5px}
.day h5{font-family:var(--display);font-size:19px;font-weight:600;margin:0 0 6px;letter-spacing:-.01em}
.day p{margin:0;color:var(--ink-soft);font-size:14.5px}

/* prev / next */
.pn{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:90px 0 0}
.pn a{display:block;background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow);transition:transform .25s,box-shadow .25s}
.pn a:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.pn .lab{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin-bottom:5px}
.pn .nm{font-family:var(--display);font-weight:600;font-size:19px;color:var(--ink);letter-spacing:-.01em}
.pn .next{text-align:right}

/* travel page: flight cards */
.flights{display:flex;flex-direction:column;gap:18px}
.fcard{background:var(--paper);border:1px solid var(--rule);border-radius:18px;padding:20px 22px;box-shadow:var(--shadow)}
.fcard__head{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 16px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--rule)}
.fcard__grp{font-family:var(--display);font-weight:600;font-size:21px;letter-spacing:-.01em}
.fcard__org{color:var(--ink-faint);font-weight:500}
.fcard__pax{font-size:11px;color:var(--ink-faint);font-weight:600;letter-spacing:.12em;text-transform:uppercase}
.fcard__arr{margin-left:auto;font-size:13px;font-weight:600;color:var(--rust)}
.leg{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:10px 0}
.leg__end{display:flex;flex-direction:column;min-width:0}
.leg__end.to{align-items:flex-end;text-align:right}
.leg__time{font-family:var(--display);font-weight:600;font-size:23px;line-height:1.05;letter-spacing:-.01em}
.leg__code{font-size:12px;color:var(--ink-soft);font-weight:500;margin-top:3px}
.leg__mid{display:flex;flex-direction:column;align-items:center;color:var(--ink-faint);min-width:108px}
.leg__flt{font-size:11.5px;font-weight:600;color:var(--pine);text-align:center}
.leg__arrow{color:var(--rule);font-size:18px;line-height:1;margin:2px 0}
.leg__dur{font-size:11px}
.leg__note{font-size:12px;color:var(--ink-faint);margin:0 0 4px}
.layover{font-size:12.5px;color:var(--ink-faint);text-align:center;padding:8px 0;font-style:italic}
.fcard__alt{margin:14px 0 0;font-size:13px;color:var(--ink-soft);border-top:1px dashed var(--rule);padding-top:12px}
.tnotes{margin:0;padding-left:20px;display:flex;flex-direction:column;gap:10px}
.tnotes li{font-size:15px;color:var(--ink-soft);line-height:1.55}
@media(max-width:520px){
  .leg__time{font-size:20px}
  .leg__mid{min-width:88px}
}

/* trip map (home) - animated real Japan silhouette */
.tripmap{position:relative;background:var(--paper);border:1px solid var(--rule);border-radius:20px;padding:22px 24px 20px;box-shadow:var(--shadow)}
.tripmap svg{display:block;margin:0 auto;width:min(100%,640px);height:auto;overflow:hidden}
.mapland{fill:#ece4d1;stroke:#cdbf9f;stroke-width:1;stroke-linejoin:round}
.maproute{fill:none;stroke:var(--rust);stroke-width:3.2;stroke-linejoin:round;stroke-linecap:round;stroke-dasharray:1200;stroke-dashoffset:1200}
.mapday{fill:none;stroke:var(--pine);stroke-width:2.4;stroke-dasharray:0.1 7;stroke-linecap:round}
.mapleader{stroke:var(--ink-faint);stroke-width:1;opacity:.45}
.mapnode-base{fill:var(--rust);stroke:#fff;stroke-width:2}
.mapnode-day{fill:var(--paper);stroke:var(--pine);stroke-width:2.5}
.maplabel{font-family:var(--sans);font-size:20px;font-weight:600;fill:var(--ink);paint-order:stroke;stroke:#fffefb;stroke-width:3px}
.maplabel.dt{fill:var(--pine)}
[data-reveal]{opacity:0;transition:opacity .5s ease}
[data-reveal].shown{opacity:1}
.maplegend{display:flex;gap:24px;flex-wrap:wrap;justify-content:center;margin-top:16px;font-size:13px;color:var(--ink-soft);font-weight:500}
.maplegend span{display:inline-flex;align-items:center;gap:9px}
.maplegend i{display:inline-block;width:28px;border-top:3px solid var(--rust)}
.maplegend .dot i{border-top:3px dotted var(--pine)}
.mapcap{margin:8px 0 0;text-align:center;font-size:12.5px;color:var(--ink-faint)}

/* day counter + replay overlay */
.mapcounter{position:absolute;top:18px;left:20px;display:flex;flex-direction:column;line-height:1;background:rgba(255,254,251,.84);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid var(--rule);border-radius:14px;padding:11px 15px;box-shadow:var(--shadow);pointer-events:none}
.mapcounter__n{font-family:var(--display);font-weight:600;font-size:27px;color:var(--rust);letter-spacing:-.01em}
.mapcounter__of{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;margin-top:4px}
.mapcounter__place{font-family:var(--display);font-size:15px;font-weight:600;color:var(--ink);margin-top:6px}
.mapreplay{position:absolute;top:18px;right:20px;font-family:var(--sans);font-size:12px;font-weight:600;color:var(--ink-soft);background:rgba(255,254,251,.84);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid var(--rule);border-radius:100px;padding:7px 14px;cursor:pointer;transition:.18s}
.mapreplay:hover{color:var(--rust);border-color:var(--rust-soft)}

@media(max-width:620px){
  .tripmap svg{width:100%}
  .maplabel{font-size:30px;stroke-width:4px}
  .maproute{stroke-width:5}
  .mapday{stroke-width:4;stroke-dasharray:0.1 11}
  .mapleader{stroke-width:1.6}
  .mapnode-base{r:11}
  .mapnode-day{r:9}
  .mapcounter{top:12px;left:12px;padding:9px 12px}
  .mapcounter__n{font-size:22px}
  .mapreplay{top:12px;right:12px}
}
@media(prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1}
  .maproute{stroke-dasharray:none;stroke-dashoffset:0}
}

/* trip overview strip (home) */
.overview{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:26px}
.overview .ov{display:flex;flex-direction:column;gap:6px;background:var(--paper);border:1px solid var(--rule);border-radius:14px;padding:15px 17px;box-shadow:var(--shadow);color:inherit;transition:transform .2s,box-shadow .2s}
a.ov:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.ov__k{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.ov__v{font-family:var(--display);font-weight:600;font-size:17px;color:var(--ink);letter-spacing:-.01em}
.ov__s{font-size:11px;font-weight:600;align-self:flex-start;padding:2px 9px;border-radius:100px}
.ov__s.ok{color:var(--pine);background:rgba(60,81,66,.1)}
.ov__s.todo{color:var(--rust);background:rgba(177,66,26,.09)}
.ov__s.info{color:var(--gold);background:rgba(181,134,47,.12)}
.ov__sub{display:block;font-family:var(--sans);font-size:11.5px;font-weight:600;color:var(--ink-faint);letter-spacing:0;margin-top:2px}

/* checklist page */
.ckprog{margin:34px 0 0}
.ckprog__bar{height:9px;background:var(--rule-soft);border:1px solid var(--rule);border-radius:100px;overflow:hidden}
.ckprog__bar span{display:block;height:100%;width:0;background:var(--rust);border-radius:100px;transition:width .35s ease}
.ckprog__t{font-size:13px;color:var(--ink-soft);font-weight:600;margin:9px 0 0}
.ckph{margin-top:8px}
.cklist{display:flex;flex-direction:column;gap:10px;margin:0 0 8px}
.ckrow{display:flex;align-items:flex-start;gap:12px;background:var(--paper);border:1px solid var(--rule);border-radius:12px;padding:14px 16px;box-shadow:var(--shadow);transition:opacity .2s}
.ck{display:flex;align-items:flex-start;gap:12px;cursor:pointer;flex:1;min-width:0}
.ck__in{position:absolute;opacity:0;width:0;height:0}
.ck__box{flex-shrink:0;width:22px;height:22px;border:2px solid var(--rule);border-radius:7px;margin-top:1px;position:relative;transition:.15s}
.ck__in:checked + .ck__box{background:var(--rust);border-color:var(--rust)}
.ck__in:checked + .ck__box::after{content:"";position:absolute;left:6px;top:2px;width:6px;height:11px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.ck__in:focus-visible + .ck__box{outline:2px solid var(--rust);outline-offset:2px}
.ck__body{display:flex;flex-direction:column;gap:3px;min-width:0}
.ck__t{font-size:15.5px;color:var(--ink);font-weight:600;line-height:1.4}
.ck__when{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}
.ck__note{font-size:13.5px;color:var(--ink-soft);line-height:1.5}
.ck__link{flex-shrink:0;font-size:12.5px;font-weight:600;color:var(--rust);white-space:nowrap;margin-top:2px}
.ckrow.done{opacity:.6}
.ckrow.done .ck__t{text-decoration:line-through;color:var(--ink-faint)}
@media(max-width:720px){.overview{grid-template-columns:1fr 1fr}}
@media(max-width:430px){.overview{grid-template-columns:1fr}}

/* budget page */
.bsum{display:flex;flex-wrap:wrap;gap:16px;margin:34px 0 8px}
.bsum__b{flex:1;min-width:190px;background:var(--paper);border:1px solid var(--rule);border-radius:16px;padding:20px 24px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:5px}
.bsum__n{font-family:var(--display);font-weight:600;font-size:34px;color:var(--rust);letter-spacing:-.02em}
.bsum__u{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint);font-weight:600}
.btable-wrap{margin:30px 0 0;overflow-x:auto}
.btable{width:100%;border-collapse:collapse;font-size:15px}
.btable th{text-align:left;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);font-weight:600;padding:0 14px 12px;border-bottom:1px solid var(--rule)}
.btable td{padding:16px 14px;border-bottom:1px solid var(--rule-soft);vertical-align:top}
.btable .bnum{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
.bcat__n{font-family:var(--display);font-weight:600;font-size:17px;display:block}
.bref{display:block;font-size:12.5px;color:var(--ink-faint);margin-top:4px;max-width:48ch}
.btable tfoot td{border-bottom:none;border-top:2px solid var(--rule);padding-top:16px}
.btable tfoot .bcat__n{font-weight:700}
.bk-todo{color:var(--ink-faint);font-weight:500;font-size:13px}
.bbk{color:var(--ink-soft)}
.binr{display:block;font-size:12px;color:var(--ink-faint);font-weight:500;margin-top:2px}
.bsum__inr{font-size:15px;color:var(--ink-soft);font-weight:600;margin-top:-1px}
.bratenote{font-size:12.5px;color:var(--ink-faint);margin:6px 0 0}

/* footer */
footer{border-top:1px solid var(--rule);margin-top:104px;padding:60px 24px 96px;text-align:center;color:var(--ink-faint);font-size:13px}
footer .ar{font-family:var(--display);font-size:32px;color:var(--rust);margin:0 0 10px}
footer p{margin:6px 0}
footer a{color:var(--rust)}

@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation:none!important;transition:none!important}.reveal{opacity:1;transform:none}}
