/* SeaHop Shuttle — shared article styles (Pacific NW travel-poster system) */
@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400..900;1,9..144,400..600&family=Hanken+Grotesk:wght@400..800&display=swap");

:root{
  --fog:#F4EEE1; --fog-2:#ECE2CF; --ink:#18241E; --ink-soft:#3A4A40; --ink-mute:#6E7C72;
  --evergreen:#123A2E; --evergreen-deep:#0B271E; --sage:#6F9079; --mist:#BDD0C5;
  --amber:#E8843A; --amber-deep:#CF6A23; --amber-soft:#F6C9A1; --sea-deep:#1E5350;
  --r-lg:20px; --r-md:14px;
  --sh-sm:0 1px 2px rgba(16,40,30,.06),0 2px 4px rgba(16,40,30,.05);
  --sh-md:0 2px 4px rgba(16,40,30,.06),0 8px 18px -6px rgba(16,40,30,.16);
  --sh-lg:0 4px 10px rgba(16,40,30,.07),0 24px 48px -12px rgba(16,40,30,.28);
  --ease:cubic-bezier(.2,0,0,1); --ease-out:cubic-bezier(.16,1,.3,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Hanken Grotesk",system-ui,sans-serif;background:var(--fog);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
h1,h2,h3{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.08;letter-spacing:-.01em;text-wrap:balance}
p{text-wrap:pretty}
a{color:var(--amber-deep);text-decoration:none}
a:hover{text-decoration:underline}
:focus-visible{outline:3px solid var(--amber);outline-offset:3px;border-radius:6px}
.wrap{width:min(720px,92vw);margin-inline:auto}
.tnum{font-variant-numeric:tabular-nums}

/* top bar */
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);background:color-mix(in srgb,var(--fog) 84%,transparent);box-shadow:0 1px 0 rgba(18,58,46,.08)}
.topbar .row{width:min(1080px,92vw);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;padding:.8rem 0}
.brand{display:inline-flex;align-items:center;gap:.55rem;font-family:"Fraunces";font-weight:700;font-size:1.35rem}
.brand .mark{width:34px;height:34px;flex:none}
.brand .sfx{font-family:"Hanken Grotesk";font-weight:700;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}
.book-btn{font-family:"Hanken Grotesk";font-weight:700;background:var(--amber);color:#2a1607;border:none;cursor:pointer;padding:.6rem 1.15rem;min-height:44px;border-radius:999px;box-shadow:var(--sh-md);transition:transform .2s var(--ease),background-color .2s var(--ease)}
.book-btn:hover{background:var(--amber-deep);color:#fff;transform:translateY(-2px);text-decoration:none}
.book-btn:active{transform:scale(.96)}

/* hero */
.article-hero{padding:2.4rem 0 1.4rem}
.crumbs{font-size:.85rem;color:var(--ink-mute);margin-bottom:1rem}
.crumbs a{color:var(--ink-mute)}
.article-hero h1{font-size:clamp(2rem,5.5vw,3.2rem);color:var(--evergreen-deep);margin-bottom:.8rem}
.meta-line{display:flex;flex-wrap:wrap;gap:.4rem .9rem;color:var(--ink-mute);font-size:.92rem;font-weight:600}
.hero-img{width:min(1080px,92vw);margin:1.4rem auto 0;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md);outline:1px solid rgba(0,0,0,.1)}
.hero-img img{width:100%;height:clamp(220px,40vw,420px);object-fit:cover;display:block}

/* quick answer (GEO/AEO citable block) */
.answer{background:#fff;border-radius:var(--r-lg);padding:1.4rem 1.5rem;box-shadow:var(--sh-sm);margin:1.8rem 0;border-left:5px solid var(--amber)}
.answer h2{font-size:1.05rem;font-family:"Hanken Grotesk";font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--sea-deep);margin-bottom:.5rem}
.answer p{font-size:1.08rem}

/* prose */
.prose{padding-bottom:1rem}
.prose h2{font-size:clamp(1.5rem,3.4vw,2rem);color:var(--evergreen-deep);margin:2.2rem 0 .8rem}
.prose h3{font-size:1.25rem;margin:1.6rem 0 .5rem}
.prose p{margin:.7rem 0;font-size:1.07rem;color:var(--ink-soft)}
.prose ul,.prose ol{margin:.7rem 0 .7rem 1.3rem}
.prose li{margin:.45rem 0;font-size:1.06rem;color:var(--ink-soft)}
.prose strong{color:var(--ink)}
.prose blockquote{margin:1.2rem 0;padding:.6rem 1.2rem;border-left:4px solid var(--sage);background:var(--fog-2);border-radius:0 var(--r-md) var(--r-md) 0;font-style:italic;color:var(--ink-soft)}
.tip{display:flex;gap:.7rem;background:var(--amber-soft);border-radius:var(--r-md);padding:.9rem 1.1rem;margin:1.3rem 0;font-size:.98rem;color:#5a3417}
.tip svg{flex:none}

/* FAQ */
.faq{margin:2.2rem 0}
.faq h2{font-size:clamp(1.5rem,3.4vw,2rem);color:var(--evergreen-deep);margin-bottom:1rem}
.faq details{background:#fff;border-radius:var(--r-md);box-shadow:var(--sh-sm);margin-bottom:.6rem;overflow:hidden}
.faq summary{cursor:pointer;padding:1rem 1.2rem;font-weight:700;list-style:none;display:flex;justify-content:space-between;gap:1rem;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:"Fraunces";font-size:1.4rem;color:var(--amber-deep);transition:transform .2s var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 1.2rem 1.1rem;color:var(--ink-soft)}

/* related + CTA */
.related{margin:2.4rem 0}
.related h2{font-size:1.4rem;margin-bottom:1rem}
.rel-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.8rem}
.rel-card{background:#fff;border-radius:var(--r-md);padding:1rem 1.1rem;box-shadow:var(--sh-sm);font-weight:700;display:block;transition:transform .2s var(--ease),box-shadow .2s var(--ease)}
.rel-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);text-decoration:none}
.rel-card small{display:block;color:var(--amber-deep);font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:.25rem}
.cta-foot{background:var(--evergreen-deep);color:var(--fog);text-align:center;padding:3rem 1.2rem;margin-top:2.5rem}
.cta-foot h2{color:var(--fog);font-size:clamp(1.6rem,4vw,2.4rem);max-width:18ch;margin:0 auto .7rem}
.cta-foot p{color:color-mix(in srgb,var(--fog) 78%,transparent);max-width:42ch;margin:0 auto 1.4rem}
footer{background:#08201A;color:color-mix(in srgb,var(--fog) 70%,transparent);padding:2rem 0;font-size:.9rem}
footer .row{width:min(1080px,92vw);margin-inline:auto;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem}
footer a{color:color-mix(in srgb,var(--fog) 70%,transparent)}
@media (prefers-reduced-motion:reduce){*{transition-duration:.001ms!important;scroll-behavior:auto!important}}
