/* ==========================================================================
   OnePlan Travel, Journal (blog)
   pool.day look (Averia serif slate headlines, white, soft-grey panels)
   + qash-style readable article column (~720px, rounded images, calm body)
   ========================================================================== */
:root{
  --f-display:"Averia Serif Libre", Georgia, "Times New Roman", serif;
  --f-text:"Inter", "SF Pro Text", Helvetica, Arial, sans-serif;
  --primary:#0066cc;
  --ink:#334558; --ink-80:#516375; --ink-48:#8694a3;
  --canvas:#fff; --pearl:#f4f6f9; --panel:#eef1f5;
  --hairline:#e6e9ee; --black:#000; --pill:9999px;
  --maxw:1100px; --read:720px;
}
*,*::before,*::after{ box-sizing:border-box }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto } }
body{ margin:0; background:var(--canvas); color:var(--ink-80); font-family:var(--f-text); font-size:17px; line-height:1.6; letter-spacing:-.01em; -webkit-font-smoothing:antialiased }
img{ max-width:100%; display:block }
a{ color:inherit; text-decoration:none }
:focus-visible{ outline:2px solid var(--primary); outline-offset:3px; border-radius:6px }

/* ---------- top bar ---------- */
.jbar{ position:sticky; top:0; z-index:50; background:rgba(255,255,255,.85); backdrop-filter:saturate(180%) blur(20px); -webkit-backdrop-filter:saturate(180%) blur(20px); border-bottom:1px solid var(--hairline) }
.jbar-in{ max-width:var(--maxw); margin:0 auto; height:62px; padding:0 22px; display:flex; align-items:center; justify-content:space-between; gap:16px }
.jbar .brand{ display:flex; align-items:center } .jbar .brand img{ height:30px; width:30px; display:block; border-radius:8px }
.jbar-right{ display:flex; align-items:center; gap:16px }
.jbar .blink{ font-size:14px; font-weight:500; color:var(--ink-48); transition:color .2s } .jbar .blink:hover{ color:var(--ink) }
.langtog{ display:inline-flex; align-items:center; background:rgba(20,28,40,.05); border:1px solid var(--hairline); border-radius:9999px; padding:2px; gap:2px }
.langtog a{ font-size:11px; font-weight:600; color:var(--ink-48); border-radius:9999px; padding:4px 10px; transition:color .2s, background .2s } .langtog a.on{ background:#fff; color:var(--ink); box-shadow:0 1px 3px rgba(20,28,40,.10) }
.jbar .get{ color:var(--ink); font-size:15px; font-weight:400; transition:color .2s } .jbar .get:hover{ color:var(--primary) }

/* ---------- index, pool.day/research grid (3-up cards, thiings 3D icons) ---------- */
.jwrap{ max-width:1200px; margin:0 auto; padding:0 24px }
.jhead{ padding:clamp(54px,7vw,104px) 0 clamp(40px,5vw,66px); max-width:760px }
.jhead h1{ font-family:var(--f-display); font-weight:400; font-size:clamp(42px,6vw,64px); line-height:1.0; letter-spacing:-.04em; color:var(--ink); margin:0 }
.jhead p{ margin:22px 0 0; font-size:clamp(18px,2.2vw,22px); line-height:1.45; letter-spacing:-.015em; color:var(--ink-48); max-width:52ch }

.jgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(36px,3.6vw,52px) 32px; padding-bottom:clamp(72px,9vw,128px) }
.jcard{ display:flex; flex-direction:column }
.jthumb{ aspect-ratio:1/1; border-radius:16px; overflow:hidden; background:var(--pearl); display:grid; place-items:center }
.jthumb img{ width:64%; height:64%; object-fit:contain; filter:drop-shadow(0 14px 24px rgba(40,70,110,.20)); transition:transform .55s cubic-bezier(.16,1,.3,1) }
.jcard:hover .jthumb img{ transform:scale(1.08) rotate(-2deg) }
.jmeta{ font-size:16px; font-weight:500; letter-spacing:-.02em; color:var(--ink-48); margin:18px 0 7px }
.jtitle{ font-family:var(--f-display); font-weight:400; font-size:clamp(22px,1.7vw,25px); line-height:1.16; letter-spacing:-.03em; color:var(--ink); margin:0; transition:color .2s }
.jcard:hover .jtitle{ color:var(--primary) }
.jgrid .reveal:nth-child(3n+2){ transition-delay:.06s }
.jgrid .reveal:nth-child(3n+3){ transition-delay:.12s }

/* filter tabs */
.jfilter{ display:flex; flex-wrap:wrap; gap:9px; margin:0 0 clamp(30px,4vw,46px) }
.jf{ font-family:var(--f-text); font-size:14px; font-weight:500; letter-spacing:-.01em; color:var(--ink-48); background:#fff; border:1px solid var(--hairline); border-radius:9999px; padding:9px 17px; cursor:pointer; transition:color .2s, background .2s, border-color .2s }
.jf:hover{ color:var(--ink); border-color:var(--ink-48) }
.jf.on{ background:var(--ink); color:#fff; border-color:var(--ink) }
.jcard.is-hidden{ display:none }

/* ---------- article ---------- */
.article{ max-width:var(--read); margin:0 auto; padding:clamp(38px,5vw,68px) 22px 0 }
.art-back{ display:inline-flex; align-items:center; gap:7px; font-size:13.5px; font-weight:500; color:var(--ink-80); padding:7px 15px 7px 12px; border:1px solid var(--hairline); border-radius:var(--pill); background:var(--pearl); margin-bottom:28px; transition:color .2s, background .2s, border-color .2s, transform .2s } .art-back:hover{ color:var(--primary); background:#fff; border-color:#d4dae2; transform:translateX(-2px) }
.art-cat{ font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.12em; color:var(--primary); margin:0 0 16px }
.article h1{ font-family:var(--f-display); font-weight:400; font-size:clamp(34px,5vw,52px); line-height:1.05; letter-spacing:-.035em; color:var(--ink); margin:0 }
.art-meta{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; margin-top:22px; font-size:14px; color:var(--ink-48) }
.art-meta .dot{ opacity:.45 }
.art-cover{ margin:clamp(30px,4vw,46px) 0 0; border-radius:20px; overflow:hidden; aspect-ratio:16/9; background:var(--pearl) }
.art-cover img{ width:100%; height:100%; object-fit:cover }

.art-body{ font-size:18px; line-height:1.75; color:var(--ink-80); margin-top:clamp(30px,4vw,46px) }
.art-body > p{ margin:0 0 22px }
.art-body .lead{ font-size:21px; line-height:1.6; color:var(--ink); margin-bottom:28px }
.art-body h2{ font-family:var(--f-display); font-weight:400; font-size:clamp(26px,3vw,33px); line-height:1.14; letter-spacing:-.025em; color:var(--ink); margin:46px 0 16px }
.art-body h3{ font-family:var(--f-text); font-weight:600; font-size:19px; color:var(--ink); margin:32px 0 10px }
.art-body ul{ margin:0 0 22px; padding-left:20px } .art-body li{ margin:0 0 10px }
.art-body strong{ color:var(--ink); font-weight:600 }
.art-body a{ color:var(--primary); text-decoration:underline; text-underline-offset:2px }
.art-body figure{ margin:32px 0 } .art-body figure img{ border-radius:16px } .art-body figcaption{ font-size:13px; color:var(--ink-48); text-align:center; margin-top:12px }
/* app screenshot figure: a phone screen on a soft panel */
.art-body figure.art-shot{ background:var(--pearl); border-radius:22px; padding:clamp(26px,5vw,48px) }
.art-body figure.art-shot img{ display:block; width:min(280px,66%); margin:0 auto; border-radius:30px; box-shadow:0 22px 48px -18px rgba(20,28,40,.34) }
.art-body figure.art-shot figcaption{ margin-top:20px }
.art-body blockquote{ margin:34px 0; padding:4px 0 4px 24px; border-left:3px solid var(--primary); font-family:var(--f-display); font-weight:400; font-size:clamp(22px,2.6vw,28px); line-height:1.3; letter-spacing:-.02em; color:var(--ink) }

/* end CTA */
.art-cta{ max-width:var(--read); margin:clamp(48px,6vw,74px) auto 0; padding:clamp(32px,4.5vw,52px) 26px; background:var(--pearl); border-radius:24px; text-align:center }
.art-cta h3{ font-family:var(--f-display); font-weight:400; font-size:clamp(24px,3vw,32px); line-height:1.15; letter-spacing:-.025em; color:var(--ink); margin:0 0 8px }
.art-cta p{ font-size:16px; color:var(--ink-48); margin:0 0 22px }
.badge{ display:inline-flex; align-items:center; gap:10px; background:var(--black); color:#fff; border-radius:14px; padding:12px 20px; transition:background .2s } .badge:hover{ background:#1a1a1a }
.badge .b1{ font-size:10px; opacity:.7; display:block; line-height:1.2 } .badge .b2{ font-weight:600; font-size:15px; display:block }
.apple-glyph{ width:17px; height:21px; flex:none; background:currentColor; -webkit-mask:url(/assets/Apple-logo.svg) no-repeat center/contain; mask:url(/assets/Apple-logo.svg) no-repeat center/contain }

/* more from the journal */
.art-more{ max-width:var(--read); margin:clamp(48px,6vw,84px) auto 0; padding:0 22px }
.art-more h4{ font-family:var(--f-text); font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.12em; color:var(--ink-48); margin:0 0 6px; padding-bottom:14px; border-bottom:1px solid var(--hairline) }
.art-more a{ display:flex; justify-content:space-between; align-items:baseline; gap:18px; font-family:var(--f-display); font-weight:400; font-size:20px; letter-spacing:-.02em; color:var(--ink); padding:17px 0; border-bottom:1px solid var(--hairline); transition:color .2s } .art-more a:hover{ color:var(--primary) }
.art-more a .ar{ font-family:var(--f-text); font-size:13px; color:var(--ink-48); flex:none }

/* ---------- footer ---------- */
.jfoot{ background:var(--canvas); border-top:1px solid var(--hairline); color:var(--ink-48); padding:46px 0 40px; margin-top:clamp(56px,7vw,96px) }
.jfoot .in{ max-width:var(--maxw); margin:0 auto; padding:0 22px; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; align-items:center; font-size:13px }
.jfoot .links{ display:flex; gap:20px } .jfoot a{ color:var(--ink-48); transition:color .2s } .jfoot a:hover{ color:var(--primary) }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(14px); transition:opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1) }
.reveal.in{ opacity:1; transform:none }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none } }

/* ---------- responsive ---------- */
@media (max-width:920px){
  .jgrid{ grid-template-columns:repeat(2,1fr); gap:40px 26px }
}
@media (max-width:600px){
  .jgrid{ grid-template-columns:1fr; gap:30px }
  .jbar .blink{ display:none }
  .art-meta{ gap:8px }
}

/* ==========================================================================
   TRIP PLAN, scroll-synced map (sticky map + itinerary that drives it)
   ========================================================================== */
.trip{ display:grid; grid-template-columns:0.92fr 1.08fr; align-items:start; max-width:1320px; margin:0 auto }
.trip-doc{ padding:clamp(34px,4vw,62px) clamp(22px,3.4vw,56px) 64px; max-width:600px; margin-left:auto }
.trip-doc .art-back{ margin-bottom:18px }
.trip-doc h1{ font-family:var(--f-display); font-weight:400; font-size:clamp(34px,4.6vw,50px); line-height:1.04; letter-spacing:-.035em; color:var(--ink); margin:10px 0 0 }
.trip-map{ position:sticky; top:62px; height:calc(100vh - 62px); border-left:1px solid var(--hairline); background:var(--pearl) }
#trip-map{ width:100%; height:100%; background:var(--pearl) }
.leaflet-container{ font-family:var(--f-text) }
.trip-mapnote{ position:absolute; bottom:10px; left:12px; z-index:600; margin:0; font-size:10px; color:var(--ink-48); background:rgba(255,255,255,.7); padding:2px 7px; border-radius:6px }

.trip-intro{ margin-top:24px }
.trip-day{ font-family:var(--f-text); font-size:13px; font-weight:600; text-transform:uppercase; letter-spacing:.12em; color:var(--primary); margin:52px 0 4px; padding-top:26px; border-top:1px solid var(--hairline) }
.trip-stop{ position:relative; padding:22px 0 22px 46px; transition:opacity .35s }
.trip-stop:not(.is-active){ opacity:.55 }
.trip-stop-no{ position:absolute; left:0; top:24px; width:30px; height:30px; border-radius:50%; border:1px solid var(--hairline); background:#fff; display:grid; place-items:center; font-family:var(--f-text); font-size:13px; font-weight:600; color:var(--ink-48); transition:background .3s, color .3s, border-color .3s }
.trip-stop.is-active .trip-stop-no{ background:var(--primary); color:#fff; border-color:var(--primary) }
.trip-stop h3{ font-family:var(--f-display); font-weight:400; font-size:25px; line-height:1.12; letter-spacing:-.02em; color:var(--ink); margin:0 }
.trip-when{ font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-48); margin:5px 0 10px }
.trip-stop p:not(.trip-when){ font-size:17px; line-height:1.7; color:var(--ink-80); margin:0 0 12px }

/* numbered map pins (Leaflet divIcon) */
.trip-pin span{ display:grid; place-items:center; width:28px; height:28px; border-radius:50% 50% 50% 0; transform:rotate(-45deg); background:#fff; border:2px solid var(--primary); box-shadow:0 2px 8px rgba(20,28,40,.28); transition:background .25s, transform .25s }
.trip-pin span b{ transform:rotate(45deg); font:600 12px/1 var(--f-text); color:var(--primary) }
.trip-pin.is-active span{ background:var(--primary); transform:rotate(-45deg) scale(1.25) }
.trip-pin.is-active span b{ color:#fff }

@media (max-width:900px){
  .trip{ grid-template-columns:1fr; max-width:700px }
  .trip-map{ order:-1; position:sticky; top:62px; height:44vh; border-left:0; border-bottom:1px solid var(--hairline); z-index:5 }
  .trip-doc{ margin:0; max-width:none; padding:28px 22px 54px }
  .trip-stop:not(.is-active){ opacity:1 }
}
