/* ==========================================================================
   A PROFOUND JOURNEY — design system v2 · "The Expedition Ledger"
   Bright cartographic editorial: cream paper, ink, sienna contours,
   OS-magenta system accent, pale grid blue.
   Archivo (display) · Spectral (body) · Fragment Mono (instrument labels)
   Sole public stylesheet. Fonts are self-hosted under /fonts/.
   Per-section tailoring via body.section-{specifier} custom properties.
   ========================================================================== */

/* ---- Fonts (self-hosted, latin subsets) --------------------------------- */
@font-face{font-family:'Archivo';font-style:normal;font-weight:100 900;font-stretch:62% 125%;font-display:swap;src:url(/fonts/archivo-100-900.woff2) format('woff2')}
@font-face{font-family:'Archivo';font-style:italic;font-weight:100 900;font-stretch:62% 125%;font-display:swap;src:url(/fonts/archivo-100-900-italic.woff2) format('woff2')}
@font-face{font-family:'Spectral';font-style:normal;font-weight:300;font-display:swap;src:url(/fonts/spectral-300.woff2) format('woff2')}
@font-face{font-family:'Spectral';font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/spectral-400.woff2) format('woff2')}
@font-face{font-family:'Spectral';font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/spectral-500.woff2) format('woff2')}
@font-face{font-family:'Spectral';font-style:italic;font-weight:300;font-display:swap;src:url(/fonts/spectral-300-italic.woff2) format('woff2')}
@font-face{font-family:'Spectral';font-style:italic;font-weight:400;font-display:swap;src:url(/fonts/spectral-400-italic.woff2) format('woff2')}
@font-face{font-family:'Fragment Mono';font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/fragmentmono-400.woff2) format('woff2')}
@font-face{font-family:'Fragment Mono';font-style:italic;font-weight:400;font-display:swap;src:url(/fonts/fragmentmono-400-italic.woff2) format('woff2')}

/* ---- Tokens -------------------------------------------------------------- */
:root{
    --paper:    #f7f2e4;
    --paper-2:  #efe8d3;
    --white:    #fdfbf4;
    --ink:      #23251d;
    --ink-soft: #3c3e33;
    --mute:     #7c7a6a;
    --mute-2:   #a09d8a;
    --contour:  #c08a55;   /* sienna contour brown  */
    --magenta:  #c81e6e;   /* OS Landranger magenta — the SYSTEM accent */
    --blue:     #4d87a1;   /* grid / water blue     */
    --phos:     #b7e3a4;   /* CRT phosphor (dark objects only) */
    --hair:     rgba(35,37,29,.16);
    --hair-2:   rgba(35,37,29,.34);
    --disp:     "Archivo","Helvetica Neue",sans-serif;
    --serif:    "Spectral",Georgia,serif;
    --mono:     "Fragment Mono",ui-monospace,monospace;
    /* Section tint — tailored per area, defaults to the travel sienna/blue. */
    --sec-accent: var(--contour);
    --sec-tint:   var(--blue);
}
/* One chassis, six instruments: tints colour the instruments, never the chrome. */
body.section-travel    { --sec-accent:#c08a55; --sec-tint:#4d87a1 }
body.section-technology{ --sec-accent:#5d7a55; --sec-tint:#46603f }
body.section-reviews,
body.section-apj_reviews{ --sec-accent:#a8333a; --sec-tint:#c08a55 }
body.section-diary     { --sec-accent:#56688a; --sec-tint:#7c7a6a }
body.section-projects  { --sec-accent:#4d87a1; --sec-tint:#56688a }
body.section-about     { --sec-accent:#3c3e33; --sec-tint:#7c7a6a }

/* ---- Base ----------------------------------------------------------------- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{background:var(--paper);color:var(--ink)}
body{
    font-family:var(--serif);font-weight:300;line-height:1.7;font-size:17.5px;
    margin:0;padding:0;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%}
a{color:var(--magenta)}
::selection{background:var(--magenta);color:var(--paper)}

h1,h2,h3,h4,.site-name{
    font-family:var(--disp);font-weight:800;font-stretch:115%;
    text-transform:uppercase;letter-spacing:-.005em;line-height:1.05;
}
.mono,.eyebrow,
.article-card time,.hero-cat,.tag-pill,.breadcrumbs,.page-freshness{
    font-family:var(--mono);
}

.container{width:90%;max-width:1280px;margin:0 auto}

/* ---- Promo banner → instrument strip -------------------------------------- */
.promo-banner{
    background:var(--ink);color:var(--paper);text-align:center;
    padding:9px 14px;font-family:var(--mono);font-size:10.5px;
    letter-spacing:.16em;text-transform:uppercase;
}

/* ---- Header ---------------------------------------------------------------- */
.header{
    background:rgba(247,242,228,.92);backdrop-filter:blur(12px);
    border-bottom:1px solid var(--hair-2);
    padding:12px 0;position:sticky;top:0;z-index:100;
}
.header .container{display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo-link{display:flex;align-items:center;gap:11px;text-decoration:none;color:inherit}
.logo-link img{display:block;height:34px;width:auto}
.site-name{
    font-size:.95rem;letter-spacing:.05em;margin:0;white-space:nowrap;color:var(--ink);
}
.site-name .accent{color:var(--magenta)}
.head-utc{
    font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--mute);
    white-space:nowrap;font-variant-numeric:tabular-nums;display:none;
}
.head-utc b{color:var(--magenta);font-weight:400;animation:apj-blink 1.2s steps(1) infinite}
@keyframes apj-blink{50%{opacity:0}}
.head-est{
    font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--magenta);
    border:1px solid var(--magenta);padding:6px 11px;border-radius:999px;white-space:nowrap;
}
.nav-links{display:flex;flex-wrap:wrap;gap:24px;align-items:center}
.nav-links a{
    color:var(--mute);text-decoration:none;
    font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    padding:4px 0;position:relative;
}
.nav-links a::after{
    content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
    background:var(--magenta);transition:width .35s cubic-bezier(.65,0,.35,1);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--ink)}

/* Pure-CSS mobile nav toggle (no-JS friendly) */
.nav-toggle{display:none}
.nav-button{
    display:none;font-size:1.5rem;line-height:1;cursor:pointer;
    color:var(--ink);background:none;border:0;padding:4px 8px;
}

/* ---- Marquee (magenta section band) ---------------------------------------- */
.marquee{background:var(--magenta);color:var(--paper);overflow:hidden}
.marquee-track{display:flex;width:max-content;animation:apj-slide 36s linear infinite;padding:12px 0}
@keyframes apj-slide{to{transform:translateX(-50%)}}
.marquee-track span{
    font-family:var(--serif);font-style:italic;font-weight:400;
    font-size:clamp(15px,1.8vw,20px);white-space:nowrap;padding:0 18px;
    display:flex;align-items:center;gap:36px;
}
.marquee-track span::after{content:"✳";font-style:normal;opacity:.7;font-size:.8em}

/* ---- Hero grid (home, transitional until Phase 2) -------------------------- */
.hero{width:100%;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--ink)}
.hero-item{position:relative;overflow:hidden}
.hero-item img{
    width:100%;height:440px;object-fit:cover;display:block;
    filter:sepia(.15) contrast(1.03);transition:transform .5s ease,filter .5s ease;
}
.hero-item:hover img{transform:scale(1.04);filter:none}
.hero-item::after{
    content:'';position:absolute;inset:0;
    background:linear-gradient(to top,rgba(35,37,29,.72),rgba(35,37,29,0) 55%);
    pointer-events:none;
}
.hero-text{position:absolute;bottom:22px;left:22px;right:22px;z-index:2;color:#fff}
.hero-text a{color:#fff;text-decoration:none}
.hero-text .hero-title{
    display:block;font-size:1.45rem;font-family:var(--disp);font-weight:800;
    font-stretch:112%;text-transform:uppercase;line-height:1.12;
}
.hero-text .hero-cat{
    display:inline-block;font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;
    background:var(--magenta);color:var(--paper);padding:4px 9px;margin-bottom:10px;
}

/* ---- Hero panel (section / listing headers) -------------------------------- */
.hero-panel{
    background:var(--paper);color:var(--ink);
    padding:56px 0 40px;border-bottom:1px solid var(--hair-2);
}
.hero-panel .container{max-width:1280px}
.hero-panel .eyebrow{
    display:inline-flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.18em;
    text-transform:uppercase;color:var(--magenta);margin-bottom:14px;
}
.hero-panel .eyebrow::before{content:"";width:34px;height:1px;background:var(--magenta)}
.hero-panel h1{font-size:clamp(2.1rem,5.5vw,4.4rem);margin:0 0 12px;font-weight:900;font-stretch:122%}
.hero-panel p{
    margin:0;font-family:var(--serif);font-style:italic;font-size:1.15rem;
    color:var(--ink-soft);max-width:680px;
}

/* ---- Section bands ---------------------------------------------------------- */
.band{padding:56px 0}
.band-alt{background:var(--white);border-block:1px solid var(--hair)}
.band h2{font-size:clamp(1.5rem,3vw,2.2rem);margin:0 0 26px}
.section-lead{color:var(--mute);margin:-14px 0 30px;max-width:720px;font-style:italic}

/* ---- Section tiles (home chapters) ------------------------------------------ */
.tile-grid{
    display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:0;border:1px solid var(--hair-2);border-right:0;background:var(--white);
}
.section-tile{
    display:flex;flex-direction:column;gap:8px;text-decoration:none;color:inherit;
    background:var(--white);border-right:1px solid var(--hair-2);
    padding:26px 24px 30px;position:relative;overflow:hidden;
    transition:color .4s ease;
}
.section-tile::before{
    content:"";position:absolute;inset:0;background:var(--ink);
    transform:translateY(101%);transition:transform .5s cubic-bezier(.76,0,.24,1);
}
.section-tile:hover::before{transform:translateY(0)}
.section-tile>*{position:relative;z-index:1}
.section-tile:hover{color:var(--paper)}
.section-tile h3{margin:0;font-size:1.2rem;display:flex;gap:10px;align-items:baseline}
.section-tile h3::after{content:"→";color:var(--magenta);font-size:.8em;transition:transform .4s ease}
.section-tile:hover h3::after{transform:translateX(6px)}
.section-tile p{margin:0;color:var(--mute);font-size:.92rem;transition:color .4s ease}
.section-tile:hover p{color:var(--mute-2)}

/* ---- Article cards (listings) ----------------------------------------------- */
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:28px}
.article-card{
    display:flex;flex-direction:column;background:var(--white);
    border:1px solid var(--hair-2);overflow:hidden;
    box-shadow:5px 5px 0 var(--hair);
    transition:box-shadow .25s ease,transform .25s ease;
}
.article-card:hover{box-shadow:8px 8px 0 var(--hair);transform:translate(-2px,-2px)}
.article-card a{text-decoration:none;color:inherit}
.article-card .card-media{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--paper-2);border-bottom:1px solid var(--hair)}
.article-card .card-media img{width:100%;height:100%;object-fit:cover;filter:sepia(.15) contrast(1.02);transition:filter .4s ease}
.article-card:hover .card-media img{filter:none}
.article-card .card-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.article-card time{font-size:.68rem;text-transform:uppercase;letter-spacing:.14em;color:var(--mute-2)}
.article-card h3{margin:8px 0 10px;font-size:1.08rem;line-height:1.2}
.article-card h3 a:hover{color:var(--magenta)}
.article-card p{margin:0 0 14px;color:var(--mute);font-size:.93rem}
.article-card .read-more{
    margin-top:auto;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
    text-transform:uppercase;color:var(--magenta);text-decoration:none;
}

/* ---- Tag pills ---------------------------------------------------------------- */
.tag-pills{margin-top:14px;font-size:.85rem}
.tag-pill{
    display:inline-block;background:var(--white);border:1px solid var(--hair-2);
    border-radius:999px;padding:4px 12px;margin:0 4px 6px 0;color:var(--mute);
    text-decoration:none;font-size:10px;letter-spacing:.14em;text-transform:uppercase;
}
.tag-pill:hover{background:var(--magenta);color:var(--paper);border-color:var(--magenta)}

/* ---- Breadcrumbs ---------------------------------------------------------------- */
.breadcrumbs{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);margin:0 0 18px}
.breadcrumb-list{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0}
.breadcrumb-item+.breadcrumb-item::before{content:"/";margin-right:8px;color:var(--mute-2)}
.breadcrumb-item a{color:var(--mute);text-decoration:none}
.breadcrumb-item a:hover{color:var(--magenta)}
.breadcrumb-current span{color:var(--ink-soft)}

/* ---- Pagination ----------------------------------------------------------------- */
.pagination{display:flex;align-items:center;justify-content:center;gap:20px;padding:36px 0 10px}
.pagination a{
    padding:12px 24px;border-radius:999px;text-decoration:none;
    font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    transition:background .3s ease,color .3s ease;
}
.pagination a.prev{border:1px solid var(--hair-2);color:var(--ink-soft)}
.pagination a.prev:hover{border-color:var(--ink);color:var(--ink)}
.pagination a.next{border:1px solid var(--magenta);color:var(--magenta)}
.pagination a.next:hover{background:var(--magenta);color:var(--paper)}
.pagination .page-info{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--mute)}
.filter-info{color:var(--mute);font-size:.95rem}

/* ---- Article page ------------------------------------------------------------------ */
.article-hero{
    position:relative;width:100%;height:440px;background:var(--ink);color:#fff;
    display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;
}
.article-hero img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
    filter:brightness(58%) sepia(.12);
}
.article-hero .article-hero-text{position:relative;z-index:1;padding:0 20px;max-width:920px}
.article-hero .article-hero-text h1{
    font-size:clamp(2rem,5vw,3.4rem);margin:0 0 12px;font-weight:900;font-stretch:120%;
    text-shadow:0 2px 10px rgba(0,0,0,.55);
}
.article-hero .article-hero-text p{
    font-family:var(--serif);font-style:italic;font-size:1.15rem;margin:0;
    text-shadow:0 1px 5px rgba(0,0,0,.6);
}

.article-plain-header{padding:48px 0 8px}
.article-plain-header h1{font-size:clamp(2rem,5vw,3.2rem);margin:0 0 8px;font-weight:900;font-stretch:120%}

.article-meta{
    color:var(--mute);font-family:var(--mono);font-size:10.5px;
    letter-spacing:.14em;text-transform:uppercase;margin:16px 0 0;
}
.article-meta .meta-author{margin-right:16px}

/* Two-column layout for mini-site cluster pages */
.article-layout{padding:40px 0 10px}
.article-layout.has-cluster{
    display:grid;grid-template-columns:230px minmax(0,1fr);
    gap:clamp(28px,4vw,56px);align-items:start;
}
.article-body{min-width:0}
.article-body .entry{font-size:1.02rem;max-width:70ch}
.article-body .entry>*:first-child{margin-top:0}
.entry h2{font-size:clamp(1.4rem,2.6vw,1.9rem);margin:1.8em 0 .5em}
.entry h3{font-size:1.15rem;margin:1.5em 0 .4em}
.entry p{margin:0 0 1.15em;color:var(--ink-soft)}
.entry strong{font-weight:500;color:var(--ink)}
.entry img{
    height:auto;margin:1.4em 0;background:var(--white);
    border:1px solid var(--hair-2);padding:9px;box-shadow:6px 6px 0 var(--hair);
}
.entry ul,.entry ol{margin:0 0 1.15em;padding-left:1.4em;color:var(--ink-soft)}
.entry li{margin-bottom:.4em}
.entry blockquote{
    margin:1.8em 0;padding:4px 0 4px 24px;border-left:3px solid var(--magenta);
    background:none;font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:1.18em;line-height:1.5;color:var(--ink);
}
.entry a{color:var(--magenta)}
.entry table{width:100%;border-collapse:collapse;margin:1.4em 0;background:var(--white);border:1px solid var(--ink);box-shadow:6px 6px 0 var(--hair);font-size:.92em}
.entry th{
    font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;
    font-weight:400;color:var(--mute);text-align:left;
}
.entry th,.entry td{border-bottom:1px solid var(--hair);padding:10px 14px}
.entry tr:hover td{background:rgba(200,30,110,.03)}
.entry pre{
    background:#11140d;color:var(--phos);padding:16px;overflow-x:auto;
    border:4px solid var(--ink);border-radius:8px;
    text-shadow:0 0 8px rgba(140,220,120,.3);
}
.entry code{font-family:var(--mono);font-size:.88em}
.entry :not(pre)>code{background:var(--white);border:1px solid var(--hair);padding:1px 6px;color:var(--ink-soft)}

/* ---- Mini-site "Contents" navigation ------------------------------------------- */
.cluster-nav{
    position:sticky;top:84px;border:1px solid var(--hair-2);
    background:var(--white);padding:16px 0;box-shadow:6px 6px 0 var(--hair);
}
.cluster-nav .cluster-title{
    font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.2em;
    color:var(--magenta);margin:0 18px 12px;padding-bottom:12px;border-bottom:1px solid var(--hair);
}
.cluster-nav ul{list-style:none;margin:0;padding:0}
.cluster-nav li{margin:0}
.cluster-nav a{
    display:block;padding:8px 18px;text-decoration:none;color:var(--mute);
    font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
    line-height:1.4;border-left:2px solid transparent;transition:all .25s ease;
}
.cluster-nav a:hover{color:var(--ink)}
.cluster-nav a.active{color:var(--magenta);border-left-color:var(--magenta);background:rgba(200,30,110,.05)}
.cluster-nav .cluster-all{
    display:block;margin-top:14px;padding:8px 18px;border-left:2px solid transparent;
    color:var(--magenta);font-family:var(--mono);font-size:11px;letter-spacing:.1em;
    text-transform:uppercase;text-decoration:none;
}
.cluster-nav .cluster-all:hover{border-left-color:var(--magenta);background:rgba(200,30,110,.05)}

/* ---- Article categories + related ------------------------------------------------ */
.article-categories{
    margin-top:20px;font-family:var(--mono);font-size:10.5px;
    letter-spacing:.14em;text-transform:uppercase;color:var(--mute);
}
.article-categories a{
    color:var(--mute);border:1px solid var(--hair-2);border-radius:999px;
    padding:5px 12px;text-decoration:none;
}
.article-categories a:hover{color:var(--magenta);border-color:var(--magenta)}
.related-articles{margin-top:56px;padding-top:36px;border-top:1px solid var(--hair-2)}
.related-articles h2{font-size:1.4rem;margin:0 0 24px}

/* ---- Freshness / about ------------------------------------------------------------- */
.page-freshness{margin-top:36px;padding-top:14px;border-top:1px solid var(--hair);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--mute-2)}
.about-article{max-width:820px;margin:0 auto}
.about-article h1{font-size:clamp(2rem,5vw,3rem);margin:0 0 18px}

/* ---- Search / contact forms ---------------------------------------------------------- */
.page-head{padding:48px 0 0}
.page-head h1{font-size:clamp(1.9rem,4.5vw,2.8rem);margin:0 0 6px}
.search-form,.header-search-form{display:flex;gap:0;max-width:560px}
.search-form input[type="search"],.search-form input[type="text"],
.header-search-input{
    flex:1;border:1px solid var(--ink);background:var(--white);color:var(--ink);
    font-family:var(--mono);font-size:13px;padding:13px 16px;outline:none;
}
.search-form input:focus,.header-search-input:focus{border-color:var(--magenta);box-shadow:3px 3px 0 var(--hair)}
.search-form button,.header-search-button,.submit-button{
    border:1px solid var(--magenta);background:var(--magenta);color:var(--paper);
    font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    padding:13px 26px;cursor:pointer;transition:background .3s ease,color .3s ease;
}
.search-form button:hover,.submit-button:hover{background:transparent;color:var(--magenta)}
.autocomplete-item{padding:10px 14px;cursor:pointer;background:var(--white);border-bottom:1px solid var(--hair)}
.autocomplete-item:hover{background:var(--paper-2)}
.contact-form{max-width:640px}
.form-group{margin-bottom:20px}
.form-group.hidden{display:none}
.form-group label{
    display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;
    text-transform:uppercase;color:var(--mute);margin-bottom:8px;
}
.form-group input,.form-group textarea{
    width:100%;border:1px solid var(--ink);background:var(--white);color:var(--ink);
    font-family:var(--serif);font-size:16px;padding:12px 14px;outline:none;
}
.form-group input:focus,.form-group textarea:focus{border-color:var(--magenta);box-shadow:3px 3px 0 var(--hair)}
.success-message{border:1px solid var(--ink);background:var(--white);box-shadow:6px 6px 0 var(--hair);padding:18px 22px;margin:20px 0}
.error-message{border:1px solid #a8333a;background:#fdf4f4;color:#a8333a;padding:14px 18px;margin:16px 0}

/* ---- Footer ------------------------------------------------------------------------------ */
.footer{
    background:var(--paper-2);color:var(--ink-soft);
    border-top:2px solid var(--ink);padding:54px 0 0;margin-top:64px;
}
.footer .inner{width:90%;max-width:1280px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:36px}
.footer-heading{
    font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
    color:var(--magenta);margin:0 0 16px;font-weight:400;
}
.footer-description{font-size:.92rem;color:var(--mute);margin:0 0 10px;max-width:32ch}
.footer-tagline{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-2)}
.footer-links{list-style:none;padding:0;margin:0}
.footer-links li{margin-bottom:9px}
.footer-links a{color:var(--ink-soft);text-decoration:none;font-size:.92rem}
.footer-links a:hover{color:var(--magenta)}
/* The closing identity band: the ORIGINAL apj globe logo — the BLACK
   version (siteimages/apj_logo_v1.svg), as on the original HTML site.
   Do not swap it for the square mark or a white variant. */
.footer-bottom{margin-top:48px;padding:44px 0 36px;border-top:1px solid var(--hair-2);text-align:center}
.footer-bottom .inner{width:90%;max-width:1280px;margin:0 auto}
.footer-bottom .apj-footer-brand img{height:150px;width:auto;margin-inline:auto}
.footer-bottom .copyright{margin-top:18px;font-size:.85rem;color:var(--mute)}
.footer-bottom .copyright a{color:var(--ink-soft)}
.footer-bottom .footer-meta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-2);margin-top:8px}

/* ---- Motion --------------------------------------------------------------------------------- */
@media (prefers-reduced-motion:reduce){
    html{scroll-behavior:auto}
    .marquee-track{animation:none}
    .head-utc b{animation:none}
    *{transition:none!important}
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width:900px){
    .hero-grid{grid-template-columns:1fr}
    .hero-item img{height:320px}
    .hero-text .hero-title{font-size:1.3rem}

    /* Cluster: sidebar becomes a horizontal scrollable sub-nav above body */
    .article-layout.has-cluster{display:block}
    .cluster-nav{position:static;margin-bottom:24px;padding:8px;display:flex;box-shadow:none}
    .cluster-nav .cluster-title{display:none}
    .cluster-nav ul{display:flex;gap:4px;overflow-x:auto;-webkit-overflow-scrolling:touch}
    .cluster-nav li{flex:0 0 auto}
    .cluster-nav a{white-space:nowrap;border-left:0;border-bottom:2px solid transparent;padding:8px 12px}
    .cluster-nav a.active{border-bottom-color:var(--magenta);background:none}
}

@media (max-width:760px){
    .header .container{flex-wrap:wrap}
    .nav-button{display:inline-block}
    .head-utc,.head-est{display:none!important}
    .nav-links{
        flex-basis:100%;flex-direction:column;align-items:flex-start;gap:0;
        max-height:0;overflow:hidden;transition:max-height .3s ease;
    }
    .nav-toggle:checked ~ .nav-links{max-height:560px;padding-top:10px}
    .nav-links a{
        width:100%;padding:12px 0;border-bottom:1px solid var(--hair);
        font-size:13px;
    }
    .nav-links a::after{display:none}
    .article-hero .article-hero-text h1{font-size:1.7rem}
    .hero-panel h1{font-size:1.9rem}
    .band{padding:40px 0}
    .tile-grid{grid-template-columns:1fr;border-right:1px solid var(--hair-2)}
    .section-tile{border-right:0;border-bottom:1px solid var(--hair-2)}
    .section-tile:last-child{border-bottom:0}
}

/* ==========================================================================
   Home page — "the expedition ledger" (Phase 2)
   ========================================================================== */
.kicker{display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--magenta)}
.kicker::before{content:"";width:34px;height:1px;background:var(--magenta);flex:none}
.grain{position:relative}
.grain::after{
    content:"";position:absolute;inset:0;pointer-events:none;opacity:.35;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='.9' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .18 0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* hero */
.home-hero{position:relative;min-height:calc(100svh - 110px);display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--paper)}
#terrain{position:absolute;inset:0;width:100%;height:100%;display:block}
#terrainFeatures{position:absolute;inset:0;width:100%;height:100%;display:block;z-index:1;pointer-events:none}
.hero-veil{position:absolute;inset:0;pointer-events:none;background:
    linear-gradient(180deg,rgba(247,242,228,.6),rgba(247,242,228,0) 18%),
    linear-gradient(0deg,rgba(247,242,228,.92) 4%,rgba(247,242,228,.45) 26%,rgba(247,242,228,0) 52%)}
.route{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.route #routePath{animation:apj-ants 14s linear infinite}
@keyframes apj-ants{to{stroke-dashoffset:-1}}
.home-hero-inner{position:relative;z-index:2;padding:0 clamp(18px,3vw,44px) clamp(28px,5vh,60px)}
.home-hero h1{
    font-weight:900;font-stretch:122%;line-height:.88;letter-spacing:-.012em;
    font-size:clamp(46px,9.6vw,148px);margin:clamp(16px,2.5vh,26px) 0 0;
}
.home-hero h1 .l{display:block}
.home-hero h1 .ol{color:transparent;-webkit-text-stroke:2.5px var(--ink)}
.home-hero h1 .mg{color:var(--magenta)}
.hero-foot{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-top:clamp(24px,4vh,44px);border-top:1px solid var(--hair-2);padding-top:22px;flex-wrap:wrap}
.hero-sub{max-width:440px;color:var(--ink-soft);font-size:17px;line-height:1.6;margin:0}
.hero-sub b{font-weight:500}
.hero-stats{display:flex;gap:clamp(22px,4vw,56px)}
.stat .n{font-family:var(--disp);font-weight:800;font-stretch:115%;font-size:clamp(28px,3.4vw,44px);line-height:1}
.stat .n sup{font-size:.4em;color:var(--magenta);font-weight:600}
.stat .t{margin-top:8px;color:var(--mute);font-size:10px;letter-spacing:.16em;text-transform:uppercase}
.map-legend{
    position:absolute;z-index:2;top:24px;right:clamp(18px,3vw,44px);text-align:right;
    display:flex;flex-direction:column;gap:5px;color:var(--ink-soft);
    background:rgba(253,251,244,.72);backdrop-filter:blur(3px);
    border:1px solid var(--hair-2);padding:12px 14px;
}
.map-legend .lg-title{color:var(--magenta)}
.map-legend span{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.map-legend .lg-row{display:flex;align-items:center;justify-content:flex-end;gap:10px}
.map-legend .compass{width:34px;height:34px;color:var(--ink-soft);flex:none}
.map-legend .needle{transform-origin:50% 50%;animation:apj-sway 9s ease-in-out infinite}
@keyframes apj-sway{0%,100%{transform:rotate(-8deg)}50%{transform:rotate(11deg)}}
.map-legend .gps b{color:var(--magenta);font-weight:400;font-variant-numeric:tabular-nums}
.map-legend .lg-open{
    font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--magenta);text-decoration:none;border-top:1px solid var(--hair);
    padding-top:8px;margin-top:4px;display:block;
}
.map-legend .lg-open:hover{color:var(--ink)}
/* invisible click target sitting on the terrain marker (same screen anchor
   the shader pins the site to); keyboard-focusable, links to the piece */
.hero-mark-link{
    position:absolute;z-index:3;width:84px;height:84px;border-radius:50%;
    left:calc(66% - 42px);top:calc(38% - 42px);
}
.hero-mark-link:hover,.hero-mark-link:focus-visible{
    outline:2px dashed var(--magenta);outline-offset:4px;
}
.scroll-cue{
    position:absolute;z-index:2;bottom:clamp(28px,5vh,60px);right:clamp(18px,3vw,44px);
    color:var(--mute);writing-mode:vertical-rl;display:flex;align-items:center;gap:10px;
    font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin:0;
}
.scroll-cue::after{content:"";width:1px;height:46px;background:linear-gradient(var(--magenta),transparent);animation:apj-cue 2.2s ease-in-out infinite}
@keyframes apj-cue{0%{transform:scaleY(.2);transform-origin:top}55%{transform:scaleY(1)}100%{transform:scaleY(.2);transform-origin:bottom}}

/* shared section head + display heading */
.sect-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:clamp(40px,6vh,70px);flex-wrap:wrap}
.sect-head .mono{color:var(--mute);letter-spacing:.14em;line-height:2;text-align:right;font-size:11px;text-transform:uppercase}
h2.disp{font-family:var(--disp);font-weight:900;font-stretch:118%;text-transform:uppercase;line-height:.95;letter-spacing:-.01em;font-size:clamp(34px,5vw,76px);margin:0}
h2.disp em{font-family:var(--serif);font-style:italic;font-weight:400;text-transform:none;color:var(--magenta);letter-spacing:0;font-size:.92em}

/* chapters */
.chapters{background:var(--paper);padding:clamp(70px,11vh,130px) 0 clamp(80px,12vh,150px)}
.chap-grid{display:grid;grid-template-columns:repeat(12,1fr);border-top:1px solid var(--hair-2);background:var(--white)}
.chap{
    grid-column:span 4;border-bottom:1px solid var(--hair-2);border-right:1px solid var(--hair-2);
    padding:clamp(22px,2.6vw,38px);min-height:clamp(200px,22vw,280px);
    display:flex;flex-direction:column;justify-content:space-between;gap:26px;
    position:relative;overflow:hidden;transition:color .4s ease;text-decoration:none;color:inherit;
}
.chap:nth-child(3n){border-right:0}
.chap::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s cubic-bezier(.76,0,.24,1)}
.chap:hover::before{transform:translateY(0)}
.chap>*{position:relative;z-index:1}
.chap:hover{color:var(--paper)}
.chap-top{display:flex;justify-content:space-between;align-items:baseline}
.chap-no{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--magenta);transition:color .4s ease}
.chap:hover .chap-no{color:var(--contour)}
.chap-count{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute-2)}
.chap h3{font-size:clamp(21px,2.1vw,30px);line-height:1.05;display:flex;align-items:baseline;gap:14px;margin:0}
.chap h3 .arr{font-size:.7em;transition:transform .4s ease;display:inline-block;color:var(--magenta)}
.chap:hover h3 .arr{transform:translateX(8px)}
.chap p{font-size:15px;color:var(--mute);max-width:30ch;line-height:1.55;transition:color .4s ease;margin:0}
.chap:hover p{color:var(--mute-2)}

/* travel rail */
.travel{position:relative;background:var(--paper-2);border-block:1px solid var(--hair-2)}
.travel-pin{overflow:hidden;position:relative}
.travel-track{display:flex;height:100svh;width:max-content;align-items:stretch}
.t-intro{
    width:min(560px,86vw);flex:none;display:flex;flex-direction:column;justify-content:center;gap:26px;
    padding:0 clamp(22px,4vw,64px);border-right:1px solid var(--hair-2);
}
.t-intro h2{font-size:clamp(38px,4.8vw,72px);line-height:.92;margin:0;font-weight:900;font-stretch:120%}
.t-intro h2 em{font-family:var(--serif);font-style:italic;font-weight:400;text-transform:none;color:var(--magenta);font-size:.9em}
.t-intro p{color:var(--ink-soft);max-width:38ch;margin:0}
.t-intro .mono{color:var(--mute);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.t-card{
    width:min(620px,88vw);flex:none;border-right:1px solid var(--hair-2);
    padding:clamp(70px,11vh,110px) clamp(24px,3vw,52px) clamp(28px,5vh,56px);
    display:flex;flex-direction:column;justify-content:flex-end;gap:18px;position:relative;
}
.t-card .t-idx{
    position:absolute;top:84px;left:clamp(24px,3vw,52px);
    font-family:var(--disp);font-weight:900;font-stretch:122%;font-size:clamp(56px,7vw,96px);
    color:transparent;-webkit-text-stroke:1.5px var(--contour);line-height:1;opacity:.85;
}
.t-plate{border:1px solid var(--hair-2);padding:10px;background:var(--white);width:fit-content;max-width:100%;box-shadow:6px 6px 0 var(--hair);position:relative;margin:0}
.t-plate img{filter:sepia(.18) contrast(1.03);transition:filter .5s ease;max-height:300px;width:auto}
.t-card:hover .t-plate img{filter:none}
.t-plate figcaption{display:flex;justify-content:space-between;gap:18px;padding:9px 2px 1px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.t-plate::after{
    content:"";position:absolute;top:-26px;right:-26px;width:92px;height:92px;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 120'%3E%3Cdefs%3E%3Cpath id='c' d='M60,14 a46,46 0 1,1 -0.01,0'/%3E%3C/defs%3E%3Ccircle cx='60' cy='60' r='56' fill='none' stroke='%23c81e6e' stroke-width='2.5'/%3E%3Ccircle cx='60' cy='60' r='38' fill='none' stroke='%23c81e6e' stroke-width='1.2' stroke-dasharray='3 3'/%3E%3Ctext font-family='monospace' font-size='10.5' letter-spacing='1.5' fill='%23c81e6e'%3E%3CtextPath href='%23c'%3EA PROFOUND JOURNEY %C2%B7 APJ.CO.UK %C2%B7 EST 1995 %C2%B7%3C/textPath%3E%3C/text%3E%3Ctext x='60' y='66' text-anchor='middle' font-family='monospace' font-size='15' letter-spacing='2' fill='%23c81e6e'%3EAPJ%3C/text%3E%3C/svg%3E");
    background-size:contain;opacity:.5;mix-blend-mode:multiply;transform:rotate(12deg);pointer-events:none;
}
.t-card:nth-child(odd) .t-plate::after{transform:rotate(-9deg);top:-22px;right:-18px}
.t-card h3{font-size:clamp(24px,2.8vw,38px);line-height:1.02;margin:0}
.t-card h3 a{text-decoration:none;color:inherit}
.t-card h3 a:hover{color:var(--magenta)}
.t-card p{color:var(--ink-soft);font-size:15.5px;max-width:46ch;margin:0}
.t-end{width:min(420px,80vw);flex:none;display:flex;align-items:center;justify-content:center}
.t-end a{font-family:var(--serif);font-style:italic;font-size:clamp(22px,2.4vw,30px);border-bottom:1px solid var(--magenta);padding-bottom:6px;color:var(--magenta);text-decoration:none}
.t-progress{position:absolute;left:0;bottom:0;height:3px;background:var(--magenta);width:0;z-index:5}

/* technology: the machine room */
.tech{background:var(--paper);padding:clamp(70px,11vh,130px) 0}
.tech-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,90px);align-items:center}
.tech h2.disp{margin:18px 0 22px;font-size:clamp(40px,5vw,76px);line-height:1}
.tech .lede{color:var(--ink-soft);max-width:48ch;margin-bottom:30px}
.tech .lede b{font-weight:500}
.clusters{display:flex;flex-direction:column;border-top:1px solid var(--hair-2)}
.clusters a{display:flex;justify-content:space-between;align-items:baseline;gap:18px;padding:16px 4px;border-bottom:1px solid var(--hair-2);transition:padding .3s ease,background .3s ease;text-decoration:none;color:inherit}
.clusters a:hover{background:rgba(200,30,110,.05);padding-left:14px}
.clusters .nm{font-family:var(--disp);font-weight:700;font-stretch:110%;font-size:clamp(17px,1.8vw,21px);text-transform:uppercase}
.clusters .ct{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;color:var(--mute);text-transform:uppercase}
.crt{
    background:#11140d;border:6px solid var(--ink);border-radius:10px;padding:26px 26px 30px;position:relative;overflow:hidden;
    box-shadow:10px 10px 0 var(--hair), inset 0 0 80px rgba(140,220,120,.05);
}
.crt::before{content:"";position:absolute;inset:0;pointer-events:none;background:repeating-linear-gradient(0deg,rgba(255,255,255,.035) 0 1px,transparent 1px 3px)}
.crt::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(90% 80% at 50% 50%,transparent 55%,rgba(0,0,0,.5))}
.crt-bar{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.16em;color:#5d7a55;margin-bottom:18px;text-transform:uppercase}
.crt pre{font-family:var(--mono);font-size:clamp(13px,1.4vw,15px);line-height:1.9;color:var(--phos);text-shadow:0 0 8px rgba(140,220,120,.35);white-space:pre-wrap;min-height:11.5em;margin:0;background:none;border:0;padding:0;border-radius:0}
.crt pre .cur{display:inline-block;width:.65em;height:1.1em;background:var(--phos);vertical-align:text-bottom;animation:apj-blink 1s steps(1) infinite}
.crt-foot{margin-top:16px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:#46603f;text-transform:uppercase}

/* dispatch ledger */
.ledger{padding:clamp(70px,11vh,130px) 0;background:var(--white);border-block:1px solid var(--hair-2)}
.ledger-sub{color:var(--mute)}
.ledger-rows{border-top:1px solid var(--hair-2)}
.lhead,.lrow{
    display:grid;grid-template-columns:70px 1fr 110px 110px 24px;align-items:center;gap:clamp(14px,3vw,40px);
}
.lhead{padding:10px 6px;border-bottom:1px solid var(--hair-2);color:var(--mute-2);font-size:10px;letter-spacing:.16em;text-transform:uppercase}
.lrow{padding:18px 6px;border-bottom:1px solid var(--hair);position:relative;transition:background .3s ease;text-decoration:none;color:inherit}
.lrow:hover{background:var(--paper)}
.lrow .no{font-family:var(--mono);font-size:11px;color:var(--mute-2);letter-spacing:.14em}
.lrow .ti{font-family:var(--disp);font-weight:700;font-stretch:110%;text-transform:uppercase;font-size:clamp(17px,2vw,25px);line-height:1.2;transition:transform .35s cubic-bezier(.65,0,.35,1)}
.lrow:hover .ti{transform:translateX(10px);color:var(--magenta)}
.lrow .ref{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--blue);font-variant-numeric:tabular-nums}
.lrow .sec{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--mute);border:1px solid var(--hair-2);border-radius:999px;padding:6px 12px;white-space:nowrap;text-align:center}
.lrow .go{font-family:var(--mono);color:var(--mute-2);transition:transform .35s ease,color .35s ease}
.lrow:hover .go{transform:translateX(6px);color:var(--magenta)}
.ledger-foot{margin-top:34px;display:flex;justify-content:center}
.ledger-foot a{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--magenta);border:1px solid var(--magenta);border-radius:999px;padding:14px 28px;text-decoration:none;transition:background .3s ease,color .3s ease}
.ledger-foot a:hover{background:var(--magenta);color:var(--paper)}

/* closing */
.closing{background:var(--paper);padding:clamp(80px,13vh,160px) 0}
.closing-grid{display:grid;grid-template-columns:.9fr 1.4fr;gap:clamp(40px,6vw,100px);align-items:center}
.c-plate{border:1px solid var(--hair-2);padding:10px;background:var(--white);transform:rotate(-1.6deg);width:fit-content;box-shadow:10px 10px 0 var(--hair);margin:0}
.c-plate img{filter:sepia(.25) contrast(1.02)}
.c-plate figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--mute);padding:9px 2px 1px;display:flex;justify-content:space-between}
.closing blockquote{font-family:var(--serif);font-weight:300;font-size:clamp(26px,3.3vw,46px);line-height:1.25;letter-spacing:-.005em;margin:0}
.closing blockquote em{font-style:italic;color:var(--magenta)}
.closing .attr{margin-top:26px;color:var(--mute);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.closing .cta{
    margin-top:40px;display:inline-flex;align-items:center;gap:14px;
    font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
    border:1px solid var(--ink);border-radius:999px;padding:16px 30px;color:var(--ink);
    text-decoration:none;transition:background .3s ease,color .3s ease;
}
.closing .cta:hover{background:var(--ink);color:var(--paper)}

/* reveal gating: only hide when JS is confirmed present */
html.js-on .rv{opacity:0;transform:translateY(34px)}
@media (prefers-reduced-motion:reduce){
    html.js-on .rv{opacity:1;transform:none}
    .route #routePath,.map-legend .needle,.scroll-cue::after{animation:none}
}

/* home responsive */
@media (max-width:1080px){
    .chap{grid-column:span 6}
    .chap:nth-child(3n){border-right:1px solid var(--hair-2)}
    .chap:nth-child(2n){border-right:0}
}
@media (max-width:880px){
    .map-legend,.scroll-cue{display:none}
    .hero-mark-link{left:calc(60% - 36px);top:calc(64% - 36px);width:72px;height:72px}
    .tech-grid{grid-template-columns:1fr}
    .closing-grid{grid-template-columns:1fr}
    .c-plate{margin-inline:auto}
    .travel-track{height:auto;overflow-x:auto;width:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
    .t-intro,.t-card,.t-end{scroll-snap-align:start;padding-top:140px;padding-bottom:48px}
    .t-card .t-idx{top:64px}
    .t-card{width:86vw;min-height:70svh}
    .lhead{display:none}
    .lrow{grid-template-columns:44px 1fr auto}
    .lrow .go,.lrow .ref{display:none}
    .home-hero{min-height:calc(100svh - 92px)}
}
@media (max-width:560px){
    .chap{grid-column:span 12;border-right:0!important;min-height:0}
    .hero-foot{flex-direction:column;align-items:flex-start}
    .lrow .sec{display:none}
}

/* ==========================================================================
   Section pages — mini-site cards + section ledger (Phase 4, first cut)
   ========================================================================== */
.enc-grid{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--hair-2);border-left:1px solid var(--hair-2);background:var(--white)}
.enc{
    border-right:1px solid var(--hair-2);border-bottom:1px solid var(--hair-2);
    padding:22px 24px;display:flex;flex-direction:column;gap:8px;
    position:relative;overflow:hidden;transition:color .35s ease;text-decoration:none;color:inherit;
}
.enc::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .45s cubic-bezier(.76,0,.24,1)}
.enc:hover::before{transform:translateY(0)}
.enc>*{position:relative;z-index:1}
.enc:hover{color:var(--paper)}
.enc .e-no{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--sec-accent)}
.enc:hover .e-no{color:var(--contour)}
.enc h3{font-size:clamp(17px,1.8vw,22px);display:flex;gap:10px;align-items:baseline;margin:0}
.enc h3 .arr{color:var(--magenta);font-size:.75em;transition:transform .35s ease}
.enc:hover h3 .arr{transform:translateX(6px)}
.enc p{font-size:14px;color:var(--mute);line-height:1.5;transition:color .35s ease;margin:0}
.enc:hover p{color:var(--mute-2)}

/* section ledger thumbnail column */
.lrow .sec-thumb{width:64px;height:40px;overflow:hidden;border:1px solid var(--hair);background:var(--paper-2)}
.lrow .sec-thumb:empty{border:0;background:none}
.lrow .sec-thumb img{width:100%;height:100%;object-fit:cover;filter:sepia(.18);transition:filter .3s ease}
.lrow:hover .sec-thumb img{filter:none}

@media (max-width:640px){
    .enc-grid{grid-template-columns:1fr}
    .lrow .sec-thumb{display:none}
}

/* ============================================================ *
 *  TRAVEL-SCROLLY ARTICLE  (section 45 stories with waypoints) *
 *  Immersive cartographic layout: split hero, ledger, a sticky *
 *  contour map that advances through route waypoints on scroll.*
 * ============================================================ */
.travel-page main{overflow-x:clip}

/* ---- hero ------------------------------------------------- */
.travel-hero{padding:46px 0 30px;border-bottom:1px solid var(--hair)}
.travel-crumbs{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
    text-transform:uppercase;color:var(--mute);margin-bottom:26px}
.travel-crumbs a{color:var(--mute);text-decoration:none}
.travel-crumbs a:hover{color:var(--magenta)}
.travel-crumbs span{margin:0 .5em;color:var(--mute-2)}
.travel-hero-title{
    font-family:var(--disp);font-weight:900;font-stretch:115%;
    font-size:clamp(3.2rem,12vw,9rem);line-height:.86;letter-spacing:-.01em;
    text-transform:uppercase;margin:0 0 .28em}
.travel-hero-title .hero-solid{display:block;color:var(--ink)}
.travel-hero-title .hero-outline{display:block;color:transparent;
    -webkit-text-stroke:2px var(--ink);text-stroke:2px var(--ink)}
.travel-standfirst{font-family:var(--serif);font-style:italic;font-weight:300;
    font-size:clamp(1.15rem,2.3vw,1.6rem);line-height:1.5;color:var(--ink-soft);
    max-width:30ch;margin:0 0 36px}
.travel-ledger{display:grid;grid-template-columns:repeat(4,auto);gap:0 48px;
    margin:0;padding-top:20px;border-top:1px solid var(--hair);
    justify-content:start}
.travel-ledger div{min-width:0}
.travel-ledger dt{font-family:var(--mono);font-size:10px;letter-spacing:.18em;
    text-transform:uppercase;color:var(--mute);margin-bottom:7px}
.travel-ledger dd{font-family:var(--mono);font-size:12.5px;letter-spacing:.04em;
    color:var(--ink);margin:0}
.travel-ledger .ledger-ref{color:var(--magenta)}

/* ---- two-column scrollytelling ---------------------------- */
.travel-scrolly{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
    gap:0;align-items:stretch;max-width:1320px;margin:0 auto;padding:0 24px}
.travel-narrative{padding:54px 56px 80px 0;font-family:var(--serif);
    font-weight:400;font-size:18px;line-height:1.75;max-width:62ch}
.travel-narrative h2,.travel-narrative h3{font-family:var(--disp);
    text-transform:uppercase;font-stretch:115%;letter-spacing:-.005em;
    margin:1.8em 0 .5em;line-height:1.05}
.travel-narrative h2{font-size:1.9rem}
.travel-narrative h3{font-size:1.35rem;color:var(--ink-soft)}
.travel-narrative p{margin:0 0 1.15em}
.travel-narrative img{max-width:100%;height:auto;border:1px solid var(--hair-2);
    margin:1.4em 0}
.travel-narrative a{color:var(--magenta)}
.travel-meta{font-family:var(--mono);font-size:11px;letter-spacing:.05em;
    color:var(--mute);display:flex;gap:22px;flex-wrap:wrap;margin-bottom:34px;
    padding-bottom:16px;border-bottom:1px solid var(--hair)}
.travel-meta strong{color:var(--ink-soft);font-weight:400}

/* ---- sticky map ------------------------------------------- */
.travel-map{position:relative;height:100%}
.travel-map-sticky{position:sticky;top:84px;padding:54px 0}
.travel-map-frame{position:relative;aspect-ratio:1/1;width:100%;
    background:var(--paper-2);border:1px solid var(--hair-2);
    box-shadow:0 1px 0 var(--white) inset,0 18px 40px -28px rgba(35,37,29,.5);
    overflow:hidden}
.travel-map-frame canvas{position:absolute;inset:0;width:100%;height:100%;
    display:block;transition:opacity .5s ease}
.travel-route{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.travel-route path{fill:none;stroke:var(--magenta);stroke-width:.7;
    stroke-dasharray:2 1.6;stroke-linecap:round;
    filter:drop-shadow(0 1px 1px rgba(255,255,255,.6))}
.travel-map-marker{position:absolute;width:16px;height:16px;margin:-8px 0 0 -8px;
    border:2px solid var(--magenta);border-radius:50%;background:rgba(200,30,110,.18);
    left:50%;top:50%;transition:left .6s cubic-bezier(.5,0,.2,1),top .6s cubic-bezier(.5,0,.2,1);
    box-shadow:0 0 0 4px rgba(200,30,110,.12)}
.travel-map-marker::after{content:"";position:absolute;inset:-9px;border:1px solid var(--magenta);
    border-radius:50%;opacity:.5;animation:apj-ping 2.4s ease-out infinite}
@keyframes apj-ping{0%{transform:scale(.5);opacity:.6}100%{transform:scale(1.5);opacity:0}}
.travel-map-grid{position:absolute;inset:0;pointer-events:none;
    background-image:linear-gradient(var(--hair) 1px,transparent 1px),
        linear-gradient(90deg,var(--hair) 1px,transparent 1px);
    background-size:11.11% 11.11%;mix-blend-mode:multiply;opacity:.5}
.travel-map-readout{display:flex;align-items:baseline;gap:12px;margin-top:14px;
    font-family:var(--mono)}
.readout-seq{font-size:11px;color:var(--magenta);letter-spacing:.1em}
.readout-label{font-size:14px;letter-spacing:.04em;color:var(--ink);
    text-transform:uppercase;font-weight:400}
.readout-gps{margin-left:auto;font-size:11px;color:var(--mute);letter-spacing:.05em}
.travel-stops{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-wrap:wrap;
    gap:6px 18px;font-family:var(--mono);font-size:11px;letter-spacing:.06em;
    color:var(--mute);text-transform:uppercase}
.travel-stops li{display:flex;align-items:center;gap:7px;transition:color .3s}
.travel-stops .stop-dot{width:6px;height:6px;border-radius:50%;
    border:1px solid var(--mute-2);transition:all .3s}
.travel-stops li.is-active{color:var(--ink)}
.travel-stops li.is-active .stop-dot{background:var(--magenta);border-color:var(--magenta);
    box-shadow:0 0 0 3px rgba(200,30,110,.15)}

/* ---- responsive: stack, map becomes a sticky top band ----- */
@media (max-width:900px){
    .travel-scrolly{grid-template-columns:1fr;padding:0 20px}
    .travel-narrative{padding:34px 0 60px;order:2;max-width:none}
    .travel-map{order:1}
    .travel-map-sticky{position:sticky;top:60px;padding:18px 0;z-index:5;
        background:linear-gradient(var(--paper) 76%,transparent)}
    .travel-map-frame{aspect-ratio:16/10;max-height:42vh}
    .travel-stops{display:none}
    .travel-ledger{grid-template-columns:1fr 1fr;gap:22px 32px}
    .travel-hero-title{font-size:clamp(2.6rem,16vw,4rem)}
}
