/* =====================================================================
   The Odyssey Guide — "Liquid Glass" design system
   Frosted glass over an immersive wine-dark-sea backdrop.
   ===================================================================== */
:root{
  --glass-blur: 22px;
  --glass-tint: 0.7;            /* frosted reading-card opacity */
  --radius: 24px;

  --sea-1:#0a1733;              /* deep night sea */
  --sea-2:#123b54;             /* petrol */
  --sea-3:#caa24f;             /* dawn-gold horizon */

  --gold: oklch(0.82 0.11 56);
  --gold-deep: oklch(0.70 0.12 56);
  --aqua: oklch(0.84 0.07 215);
  --cream:#f4efe6;
  --ink:#101a2e;
  --ink-soft:#3b4760;
  --ink-faint:#6b768c;

  --display:"Spectral",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--body);
  color:var(--cream);
  -webkit-font-smoothing:antialiased;
  line-height:1.58;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}

/* ——— the sea: fixed immersive backdrop the glass refracts over ——— */
.sea{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(120% 90% at 78% 8%, rgba(255,255,255,.10), transparent 45%),
    radial-gradient(95% 70% at 50% 118%, var(--sea-3), transparent 58%),
    radial-gradient(120% 100% at 18% 92%, color-mix(in oklab, var(--sea-3) 55%, transparent), transparent 55%),
    linear-gradient(168deg, var(--sea-1) 8%, var(--sea-2) 62%, color-mix(in oklab,var(--sea-2) 50%, var(--sea-3)) 100%);
}
.sea::before,.sea::after{content:"";position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;}
.sea::before{width:50vw;height:50vw;left:-10vw;top:-12vw;
  background:radial-gradient(circle, color-mix(in oklab,var(--aqua) 60%, transparent), transparent 70%);}
.sea::after{width:46vw;height:46vw;right:-8vw;bottom:-10vw;
  background:radial-gradient(circle, color-mix(in oklab,var(--gold) 50%, transparent), transparent 70%);}
.grain{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.05;
  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.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ——— glass materials ——— */
.glass{
  background:linear-gradient(140deg, rgba(255,255,255,.16), rgba(255,255,255,.05) 60%);
  backdrop-filter:blur(var(--glass-blur)) saturate(160%);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(160%);
  border:1px solid rgba(255,255,255,.22);
  border-radius:var(--radius);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.5), inset 0 -1px 1px rgba(255,255,255,.06), 0 24px 60px -28px rgba(2,8,23,.8);
  position:relative;
}
.frost{
  background:linear-gradient(150deg, color-mix(in oklab,var(--cream) calc(var(--glass-tint)*100%), transparent), color-mix(in oklab,var(--cream) calc(var(--glass-tint)*80%), transparent));
  backdrop-filter:blur(var(--glass-blur)) saturate(150%);
  -webkit-backdrop-filter:blur(var(--glass-blur)) saturate(150%);
  border:1px solid rgba(255,255,255,.5);
  border-radius:var(--radius);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9), 0 30px 70px -30px rgba(2,8,23,.78);
  color:var(--ink);
  position:relative;
}
.sheen::before{
  content:"";position:absolute;left:0;right:0;top:0;height:46%;
  border-radius:inherit;pointer-events:none;
  background:linear-gradient(180deg, rgba(255,255,255,.26), transparent);
  -webkit-mask:linear-gradient(180deg,#000,transparent);mask:linear-gradient(180deg,#000,transparent);
  opacity:.65;
}
/* on the pill nav, give the sheen full height so its clamped radius matches the pill (no squarish double-edge) */
.nav.sheen::before{height:100%;}
/* fallback where backdrop-filter is unsupported — use opaque surfaces */
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){
  .glass{background:rgba(20,34,58,.92);}
  .frost{background:#f1ebe0;}
}

/* ——— layout primitives ——— */
.shell{max-width:1180px;margin:0 auto;padding:0 28px;}
.eyebrow{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;font-weight:700;}
.serif{font-family:var(--display);}
a{color:var(--gold);}

/* ——— nav ——— */
.nav-wrap{position:sticky;top:18px;z-index:60;padding:18px 28px 0;}
.nav{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;
  gap:18px;padding:12px 14px 12px 24px;border-radius:999px;}
.brand{font-weight:700;letter-spacing:.01em;font-size:1.04rem;display:flex;align-items:center;gap:10px;color:var(--cream);text-decoration:none;}
.brand .mk{width:11px;height:11px;border-radius:50%;background:var(--gold);box-shadow:0 0 14px var(--gold);}
.brand em{font-family:var(--display);font-style:italic;font-weight:500;}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-links a{font-size:.82rem;font-weight:500;color:rgba(244,239,230,.82);text-decoration:none;padding:9px 14px;border-radius:999px;transition:.18s;}
.nav-links a:hover{color:#fff;background:rgba(255,255,255,.12);}
.nav-cta{font-size:.82rem;font-weight:600;color:var(--sea-1);background:var(--gold);padding:10px 18px;border-radius:999px;text-decoration:none;transition:.18s;white-space:nowrap;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.6), 0 8px 22px -8px var(--gold-deep);}
.nav-cta:hover{background:#fff;}

/* ——— buttons ——— */
.btn{font-size:.92rem;font-weight:600;text-decoration:none;padding:15px 26px;border-radius:999px;transition:.18s;cursor:pointer;display:inline-flex;align-items:center;gap:8px;border:0;}
.btn small{font-weight:400;opacity:.7;font-size:.8em;}
.btn-gold{background:var(--gold);color:var(--sea-1);box-shadow:inset 0 1px 0 rgba(255,255,255,.6),0 14px 34px -12px var(--gold-deep);}
.btn-gold:hover{background:#fff;transform:translateY(-1px);}
.btn-glass{color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);}
.btn-glass:hover{background:rgba(255,255,255,.2);}

/* ——— hero ——— */
.hero{padding:54px 0 40px;display:grid;grid-template-columns:1.25fr .75fr;gap:46px;align-items:center;}
.hero > *{min-width:0;}   /* keep fr tracks from blowing out on long words (Safari/Chrome differ otherwise) */
.hero-kick{color:var(--gold);margin-bottom:22px;}
.hero h1{font-weight:800;font-size:clamp(3.2rem,6vw,5.4rem);line-height:1.02;letter-spacing:-.02em;text-wrap:balance;margin-bottom:24px;}
.hero h1 em{font-family:var(--display);font-style:italic;font-weight:500;background:linear-gradient(100deg,var(--gold),#fff 70%);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero .deck{font-size:1.18rem;line-height:1.5;color:rgba(244,239,230,.88);max-width:44ch;margin-bottom:34px;}
.hero .deck b{color:#fff;font-weight:600;}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap;}
/* porthole emblem */
.porthole{position:relative;border-radius:50%;padding:14px;justify-self:center;width:100%;max-width:360px;
  background:linear-gradient(140deg,rgba(255,255,255,.18),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.3);
  box-shadow:inset 0 2px 0 rgba(255,255,255,.5), 0 40px 80px -30px rgba(2,8,23,.9);}
/* real <img>, not a background — sizes identically across browsers (Safari mis-sizes bg+aspect-ratio) */
.porthole .plate{display:block;width:100%;height:auto;border-radius:50%;}
.porthole .ring{position:absolute;inset:14px;border-radius:50%;pointer-events:none;z-index:2;box-shadow:inset 0 0 0 1px rgba(255,255,255,.35), inset 0 12px 30px -10px rgba(255,255,255,.5);}
.porthole .cap{position:absolute;left:50%;bottom:-14px;transform:translateX(-50%);white-space:nowrap;font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;color:var(--sea-1);
  background:var(--gold);padding:7px 16px;border-radius:999px;box-shadow:0 10px 24px -10px rgba(2,8,23,.7);}

/* ——— film banner ——— */
.film{margin:8px 0 0;padding:18px 26px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.film .flag{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--sea-1);background:var(--gold);padding:7px 13px;border-radius:999px;white-space:nowrap;}
.film p{font-size:1.02rem;color:rgba(244,239,230,.9);flex:1;min-width:240px;}
.film p em{font-family:var(--display);font-style:italic;}
.film a{color:#fff;font-weight:600;text-decoration:none;border-bottom:1.5px solid var(--gold);padding-bottom:1px;white-space:nowrap;}

/* ——— companion strip (quick links to the reading guides) ——— */
.companion{margin:14px 0 0;padding:15px 26px;display:flex;align-items:center;gap:12px 20px;flex-wrap:wrap;}
.companion .lbl{font-family:var(--display);font-weight:600;color:#fff;font-size:1rem;display:flex;align-items:center;gap:10px;}
.companion .lbl::before{content:"✦";color:var(--gold);}
.companion .links{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap;}
.companion a{font-weight:600;font-size:.85rem;text-decoration:none;padding:9px 17px;border-radius:999px;transition:.16s;white-space:nowrap;}
.companion a.solid{background:var(--gold);color:var(--sea-1);box-shadow:inset 0 1px 0 rgba(255,255,255,.5);}
.companion a.ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.28);}
.companion a:hover{filter:brightness(1.07);transform:translateY(-1px);}
@media(max-width:680px){.companion .links{margin-left:0;width:100%;}.companion a{flex:1;text-align:center;}}

/* ——— section heads ——— */
.sec{padding:68px 0 0;}
.sec-head{display:flex;align-items:baseline;gap:18px;margin-bottom:30px;}
.sec-head .n{color:var(--gold);font-weight:700;font-size:.9rem;}
.sec-head h2{font-weight:800;font-size:clamp(1.9rem,3.4vw,2.7rem);letter-spacing:-.02em;}
.sec-head h2 em{font-family:var(--display);font-style:italic;font-weight:500;}
.sec-head .line{flex:1;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.3),transparent);}

/* ——— ten-second router ——— */
.router{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.chip{padding:24px 24px 22px;border-radius:calc(var(--radius)*.8);transition:.2s;cursor:pointer;text-decoration:none;display:block;}
.chip:hover{transform:translateY(-3px);}
.chip .q{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:rgba(244,239,230,.7);margin-bottom:14px;}
.chip .a{font-family:var(--display);font-size:1.5rem;line-height:1.1;color:#fff;margin-bottom:6px;}
.chip .a em{font-style:italic;}
.chip .s{font-size:.9rem;color:rgba(244,239,230,.74);}
.chip .arrow{margin-top:14px;color:var(--gold);font-weight:700;font-size:.85rem;}

/* ——— recommendation spotlight ——— */
.spot{padding:40px;display:grid;grid-template-columns:1fr 320px;gap:44px;align-items:start;}
.spot .pick{display:inline-flex;align-items:center;gap:8px;color:#8a5511;font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:18px;}
.spot .pick .star{color:var(--gold);}
.spot h3{font-family:var(--display);font-weight:600;font-size:3rem;line-height:1;margin-bottom:6px;color:var(--ink);}
.spot .meta{color:var(--ink-soft);font-size:.95rem;font-weight:500;margin-bottom:26px;}
.spot blockquote{font-family:var(--display);font-style:italic;font-size:1.7rem;line-height:1.3;color:var(--ink);margin-bottom:24px;padding-left:22px;border-left:3px solid var(--gold);text-wrap:pretty;}
.spot p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:16px;max-width:56ch;}
.spot p b{color:var(--ink);font-weight:600;}
.buycard{align-self:start;padding:26px;border-radius:calc(var(--radius)*.85);
  background:linear-gradient(155deg, rgba(255,255,255,.6), rgba(255,255,255,.34));border:1px solid rgba(255,255,255,.7);box-shadow:inset 0 1px 0 #fff, 0 20px 44px -22px rgba(2,8,23,.5);}
.buycard .cover{width:100%;aspect-ratio:3/4;border-radius:12px;overflow:hidden;margin-bottom:18px;box-shadow:0 16px 34px -16px rgba(2,8,23,.6);position:relative;
  background:radial-gradient(120% 60% at 50% 0, rgba(255,255,255,.18), transparent 60%), linear-gradient(150deg, var(--sea-2), color-mix(in oklab,var(--sea-1) 70%, #000));}
.buycard .cover::after{content:"";position:absolute;inset:0;opacity:.4;background:repeating-linear-gradient(52deg, transparent, transparent 11px, rgba(255,255,255,.05) 11px, rgba(255,255,255,.05) 12px);}
.buycard .cover .ct{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:22px;gap:10px;z-index:2;}
.buycard .cover .ct .tt{font-family:var(--display);font-style:italic;font-size:1.7rem;line-height:1.05;color:#fff;}
.buycard .cover .ct .au{font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:var(--gold);}
.buycard .price{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;}
.buycard .price .p{font-family:var(--display);font-size:2.4rem;color:var(--ink);line-height:1;}
.buycard .price .u{color:var(--ink-soft);font-size:.82rem;}
.buycard .pub{color:var(--ink-soft);font-size:.86rem;margin-bottom:18px;}
.buy-btn{display:block;text-align:center;background:var(--ink);color:var(--cream);font-weight:600;font-size:.9rem;padding:14px;border-radius:999px;text-decoration:none;transition:.18s;box-shadow:0 12px 26px -12px rgba(2,8,23,.7);}
.buy-btn:hover{background:var(--gold-deep);}
.buycard .disc{font-size:.74rem;color:var(--ink-soft);margin-top:13px;line-height:1.45;}

/* ——— translations list ——— */
.filters{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;}
.pill{font-size:.78rem;font-weight:600;color:rgba(244,239,230,.82);padding:9px 18px;border-radius:999px;cursor:pointer;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);transition:.16s;display:inline-flex;align-items:center;gap:8px;font-family:inherit;}
.pill:hover{background:rgba(255,255,255,.16);}
.pill:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.pill.on{background:var(--cream);color:var(--sea-1);border-color:transparent;}
.pill .dot{width:8px;height:8px;border-radius:50%;}
.list{display:flex;flex-direction:column;gap:16px;}
/* cards are frosted-light (dark ink) — siblings of the recommendation panel */
.card{padding:28px 30px;display:grid;grid-template-columns:1fr auto;gap:8px 24px;transition:.2s;color:var(--ink);}
.card:hover{transform:translateY(-2px);}
.card[hidden]{display:none;}
.card .top{grid-column:1;display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;}
.card h4{font-family:var(--display);font-size:1.7rem;color:var(--ink);line-height:1;}
.card .yr{color:var(--ink-soft);font-style:italic;font-size:1rem;}
.badge{justify-self:end;align-self:start;grid-column:2;grid-row:1;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:6px 12px;border-radius:999px;white-space:nowrap;}
.badge.free{background:color-mix(in oklab,var(--aqua) 22%, white);color:#1f6b6b;border:1px solid color-mix(in oklab,var(--aqua) 55%, transparent);}
.badge.copy{background:color-mix(in oklab,var(--gold) 18%, white);color:var(--gold-deep);border:1px solid color-mix(in oklab,var(--gold) 50%, transparent);}
.badge.top{background:var(--gold);color:var(--sea-1);}
.card .specs{grid-column:1;color:var(--ink-faint);font-size:.82rem;letter-spacing:.02em;margin-top:2px;text-transform:uppercase;font-weight:600;}
.card .body{grid-column:1 / -1;margin-top:14px;display:grid;gap:10px;}
.card .body .ln{font-family:var(--display);font-style:italic;color:var(--ink);font-size:1.2rem;line-height:1.3;padding-left:18px;border-left:3px solid var(--gold);}
.card .body p{color:var(--ink-soft);font-size:1rem;max-width:64ch;}
.card .body em{font-style:italic;}
.card .foot{grid-column:1 / -1;margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:16px;border-top:1px solid rgba(16,26,46,.12);}
.card .for{font-size:.92rem;color:var(--ink-soft);}
.card .for b{color:var(--ink);font-weight:600;}
.card .go{font-size:.85rem;font-weight:600;color:var(--cream);background:var(--ink);padding:11px 20px;border-radius:999px;text-decoration:none;white-space:nowrap;transition:.16s;box-shadow:0 10px 22px -12px rgba(2,8,23,.6);}
.card .go:hover{background:var(--gold-deep);color:#231806;}

/* ——— tiers (paid vs free groups within §3) ——— */
.tier + .tier{margin-top:44px;}
.tier[hidden]{display:none;}
.tier-h{font-family:var(--display);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--gold);margin:6px 0 18px;display:flex;align-items:center;gap:14px;}
.tier-h::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(216,175,99,.45),transparent);}
/* free tiles — frosted-light, roomy; flex-centered so 5 reads as a balanced 3 + 2 */
.freegrid{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;}
.ftile{flex:1 1 320px;max-width:368px;display:flex;flex-direction:column;text-decoration:none;padding:32px 34px 30px;border-radius:calc(var(--radius)*.85);transition:.2s;color:var(--ink);}
.ftile:hover{transform:translateY(-3px);}
.ftile .t{font-family:var(--display);font-size:1.55rem;color:var(--ink);line-height:1;}
.ftile .y{color:var(--ink-soft);font-style:italic;font-size:.9rem;margin-top:6px;}
.ftile .ln{font-family:var(--display);font-style:italic;color:var(--ink);font-size:1.16rem;line-height:1.38;margin-top:18px;padding-left:16px;border-left:3px solid var(--gold);}
.ftile .b{color:var(--ink-soft);font-size:.95rem;margin-top:14px;}
.ftile .go{margin-top:auto;padding-top:20px;color:#8a5511;font-weight:700;font-size:.84rem;}
.ftile:hover .go{color:#623a08;}

/* ——— at-a-glance table ——— */
.tablewrap{margin-top:8px;overflow-x:auto;border-radius:var(--radius);}
table{border-collapse:collapse;width:100%;font-size:.94rem;}
th,td{padding:13px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.12);}
th{font-size:.68rem;text-transform:uppercase;letter-spacing:.1em;color:var(--gold);font-weight:700;}
td{color:rgba(244,239,230,.85);}
tbody tr:last-child td{border-bottom:none;}
tbody tr:hover td{background:rgba(255,255,255,.05);}
td a{color:#fff;text-decoration:none;border-bottom:1px solid var(--gold);}
td .pd{color:var(--aqua);font-weight:700;}
td .cp{color:var(--gold);font-weight:700;}
/* light (frost) table variant — dark ink on the parchment panel */
.tablewrap.frost{padding:6px 12px;}
.tablewrap.frost th{color:var(--gold-deep);}
.tablewrap.frost td{color:var(--ink-soft);}
.tablewrap.frost th,.tablewrap.frost td{border-bottom-color:rgba(16,26,46,.12);}
.tablewrap.frost tbody tr:hover td{background:rgba(16,26,46,.045);}
.tablewrap.frost td a{color:var(--ink);border-bottom-color:var(--gold-deep);}
.tablewrap.frost td .pd{color:#2c7a64;}
.tablewrap.frost td .cp{color:var(--gold-deep);}

/* ——— FAQ ——— */
.faq{padding:8px 34px;}
details{border-bottom:1px solid rgba(255,255,255,.14);padding:18px 0;}
details:last-child{border-bottom:none;}
summary{cursor:pointer;font-family:var(--display);font-weight:600;font-size:1.14rem;color:#fff;list-style:none;display:flex;gap:12px;align-items:baseline;}
summary::-webkit-details-marker{display:none;}
summary::before{content:"+";color:var(--gold);font-weight:700;}
details[open] summary::before{content:"–";}
details .ans{margin:12px 0 2px;color:rgba(244,239,230,.84);font-size:1.02rem;}

/* ——— free library grid ——— */
.libgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;}
.libcard{display:block;text-decoration:none;padding:24px 24px 22px;border-radius:calc(var(--radius)*.8);transition:.2s;}
.libcard:hover{transform:translateY(-3px);}
.libcard .t{font-family:var(--display);font-size:1.4rem;color:#fff;line-height:1;}
.libcard .y{color:rgba(244,239,230,.6);font-style:italic;font-size:.9rem;margin-top:4px;}
.libcard .b{color:rgba(244,239,230,.78);font-size:.92rem;margin-top:12px;}
.libcard .go{margin-top:14px;color:var(--gold);font-weight:700;font-size:.82rem;display:inline-block;}

/* ——— ad slot ——— */
.ad{margin-top:18px;padding:24px 30px;display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:center;border-style:dashed!important;}
.ad .tag{writing-mode:vertical-rl;transform:rotate(180deg);font-size:.62rem;letter-spacing:.24em;text-transform:uppercase;font-weight:700;color:rgba(244,239,230,.55);}
.ad .mid .h{font-family:var(--display);font-size:1.4rem;color:#fff;}
.ad .mid p{font-size:.92rem;color:rgba(244,239,230,.66);}
.ad .dim{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;color:rgba(244,239,230,.55);}
.ad[hidden]{display:none;}   /* the .ad display rule overrides the UA [hidden] rule, so restore it explicitly */

/* ——— footer ——— */
footer.shell{margin:96px auto 44px;}
.foot{padding:30px 36px 28px;display:flex;flex-direction:column;gap:0;}
.foot-top{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.foot .b{font-weight:700;display:flex;align-items:center;gap:10px;}
.foot .b em{font-family:var(--display);font-style:italic;font-weight:500;}
.foot .b .mk{width:9px;height:9px;border-radius:50%;background:var(--gold);}
.foot small{color:rgba(244,239,230,.62);font-size:.82rem;}
.foot small a{color:rgba(244,239,230,.62);text-decoration:none;}
.foot small a:hover{color:#fff;}
.foot .disc{color:rgba(244,239,230,.55);font-size:.74rem;font-style:italic;line-height:1.55;max-width:none;margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);}

/* =====================================================================
   EDITION PAGES
   ===================================================================== */
.ed-hero{padding:50px 0 8px;}
.ed-hero .panel{padding:44px 46px;text-align:center;}
.ed-hero .badge-pd{display:inline-block;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--aqua);
  background:color-mix(in oklab,var(--aqua) 22%, transparent);border:1px solid color-mix(in oklab,var(--aqua) 40%, transparent);padding:7px 15px;border-radius:999px;margin-bottom:22px;}
.ed-hero h1{font-weight:800;font-size:clamp(2.2rem,4.6vw,3.4rem);letter-spacing:-.02em;line-height:1.04;}
.ed-hero h1 em{font-family:var(--display);font-style:italic;font-weight:500;color:var(--gold);}
.ed-hero .years{color:rgba(244,239,230,.7);font-size:1rem;margin-top:12px;}
.ed-hero blockquote{font-family:var(--display);font-style:italic;font-size:1.5rem;line-height:1.34;color:#fff;max-width:600px;margin:26px auto 0;text-wrap:pretty;}

/* download CTA strip */
.dl-cta{margin-top:18px;padding:30px 34px;text-align:center;}
.dl-cta h2{font-family:var(--display);font-size:1.5rem;color:#fff;margin-bottom:4px;}
.dl-cta p{font-size:.94rem;color:rgba(244,239,230,.74);margin-bottom:20px;}
.dl-cta .files{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.dl-cta .dl-note{font-size:.82rem;line-height:1.5;color:rgba(244,239,230,.62);margin:16px auto 0;max-width:540px;}
.dl-cta .dl-note a{color:var(--gold-bright);text-decoration:none;border-bottom:1px solid rgba(216,175,99,.45);}
.dl-cta .dl-note a:hover{border-color:var(--gold-bright);}

/* reading panel (long-form prose — dark ink on light frost for legibility) */
.read{padding:44px 48px;margin-top:0;}
.read h2{font-family:var(--display);font-weight:600;font-size:1.5rem;color:var(--ink);margin:30px 0 8px;}
.read h2:first-child{margin-top:0;}
.read p{color:var(--ink-soft);font-size:1.08rem;margin-bottom:6px;}

/* facts */
.facts{padding:30px 34px;}
.facts dl{display:grid;grid-template-columns:auto 1fr;gap:12px 22px;margin:0;}
.facts dt{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:#8a5511;align-self:center;}
.facts dd{margin:0;font-size:1rem;color:var(--ink-soft);}

/* compare grid */
.compare{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;}
.cmp{display:block;text-decoration:none;padding:22px 24px;border-radius:calc(var(--radius)*.8);transition:.2s;}
.cmp:hover{transform:translateY(-3px);}
.cmp .t{font-family:var(--display);font-size:1.3rem;color:var(--ink);line-height:1;}
.cmp .y{color:var(--ink-soft);font-style:italic;font-size:.86rem;margin-top:4px;}
.cmp .b{color:var(--ink-soft);font-size:.9rem;margin-top:10px;}
.cmp .go{margin-top:12px;color:#8a5511;font-weight:700;font-size:.8rem;display:inline-block;}

/* breadcrumb back-link in nav */
.nav .back{font-size:.82rem;font-weight:500;color:rgba(244,239,230,.82);text-decoration:none;padding:9px 14px;border-radius:999px;transition:.18s;}
.nav .back:hover{color:#fff;background:rgba(255,255,255,.12);}

/* ——— book cover on edition hero ——— */
.ed-hero .panel{padding:38px 42px;display:grid;grid-template-columns:172px 1fr;gap:38px;align-items:center;text-align:left;}
.ed-hero .cover{width:172px;height:auto;border-radius:8px;display:block;box-shadow:0 20px 44px -18px rgba(2,8,23,.75), 0 0 0 1px rgba(255,255,255,.12);}
.ed-hero blockquote{margin:20px 0 0;}
@media(max-width:680px){.ed-hero .panel{grid-template-columns:1fr;justify-items:center;text-align:center;gap:24px;}.ed-hero blockquote{margin:18px auto 0;}}

/* ——— guide pages (cast of characters, how to read) ——— */
.guide-hero{padding:50px 0 8px;}
.guide-hero .panel{padding:42px 44px;text-align:center;}
.guide-hero .kick{font-family:var(--display);font-weight:600;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);}
.guide-hero h1{font-weight:800;font-size:clamp(2.1rem,4.6vw,3.3rem);margin:14px 0 0;}
.guide-hero h1 em{font-family:var(--display);font-style:italic;font-weight:500;color:var(--gold);}
.guide-hero .lede{color:rgba(244,239,230,.82);max-width:640px;margin:16px auto 0;font-size:1.06rem;}
.guide-hero .pdf{margin-top:26px;}
.read .intro{font-size:1.1rem;color:var(--ink-soft);}
.read .char-group{font-family:var(--display);font-weight:600;font-size:1.4rem;color:var(--ink);margin:38px 0 16px;padding-bottom:8px;border-bottom:1px solid rgba(16,26,46,.14);}
.read .char-group:first-of-type{margin-top:4px;}
.char{margin:0 0 16px;}
.char .nm{font-family:var(--display);font-weight:600;font-size:1.14rem;color:var(--ink);}
.char .pr{font-size:.8rem;color:#8a5511;font-weight:600;letter-spacing:.02em;}
.char p{margin:3px 0 0;color:var(--ink-soft);font-size:1rem;line-height:1.55;}
.callout{background:rgba(31,58,77,.05);border-left:3px solid var(--gold);border-radius:0 6px 6px 0;padding:16px 20px;margin:24px 0;}
.callout .h{font-family:var(--display);font-weight:700;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:#8a5511;margin-bottom:6px;}
.callout p{margin:0;color:var(--ink-soft);font-size:.98rem;}
.read h3.movement{font-family:var(--display);font-weight:600;font-size:1.25rem;color:var(--ink);margin:26px 0 6px;}
.read h3.movement .bk{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#8a5511;font-family:var(--body);margin-left:10px;}
.tips{list-style:none;margin:10px 0 0;padding:0;}
.tips li{position:relative;padding-left:26px;margin:14px 0;color:var(--ink-soft);}
.tips li::before{content:"✦";position:absolute;left:0;top:2px;color:var(--gold);font-size:.9rem;}
.tips li b{color:var(--ink);}
.miniwho{margin:8px 0 0;}
.miniwho .row{display:grid;grid-template-columns:150px 1fr;gap:10px 18px;padding:9px 0;border-bottom:1px solid rgba(16,26,46,.09);}
.miniwho .row:last-child{border-bottom:none;}
.miniwho .row .n{font-family:var(--display);font-weight:600;color:var(--ink);}
.miniwho .row .w{color:var(--ink-soft);font-size:.98rem;}

/* ——— "going deeper" cards (homepage) ——— */
.guidegrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.gcard{display:block;text-decoration:none;padding:30px 32px;border-radius:calc(var(--radius)*.8);transition:.2s;}
.gcard:hover{transform:translateY(-3px);}
.gcard .k{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--gold);}
.gcard .t{font-family:var(--display);font-size:1.6rem;color:#fff;margin:10px 0 6px;}
.gcard .d{color:rgba(244,239,230,.78);font-size:.98rem;}
.gcard .go{margin-top:16px;color:var(--gold);font-weight:700;font-size:.84rem;display:inline-block;}
@media(max-width:680px){.guidegrid{grid-template-columns:1fr;}}

/* ——— responsive ——— */
@media(max-width:880px){
  .hero{grid-template-columns:1fr;gap:36px;}
  .porthole{max-width:300px;}
  .router{grid-template-columns:1fr;}
  .spot{grid-template-columns:1fr;gap:30px;padding:30px;}
  .ad{grid-template-columns:1fr;}
  .ad .tag{writing-mode:horizontal-tb;transform:none;}
  .nav-links{display:none;}
  .read{padding:32px 26px;}
  .ed-hero .panel{padding:34px 26px;}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto;transition:none!important;}}

/* ——— print / Save-as-PDF: clean paper layout ——— */
@media print{
  body{background:#fff;color:#14110c;-webkit-print-color-adjust:exact;print-color-adjust:exact;}
  .sea,.grain,.nav-wrap,footer,.ad,.dl-cta,.hero-actions,.filters,.porthole,.film,.btn,.buy-btn,.cta,.no-print{display:none !important;}
  .shell{max-width:none;padding:0;}
  .glass,.frost{background:#fff !important;border:1px solid #d8cbb0 !important;box-shadow:none !important;
    backdrop-filter:none !important;-webkit-backdrop-filter:none !important;color:#14110c !important;}
  .glass *,.frost *{color:#14110c !important;}
  .sheen::before{display:none !important;}
  a{color:#14110c;text-decoration:none;}
  h1,h2,h3,summary{color:#14110c !important;}
  .sec{padding:0;margin:20px 0;break-inside:avoid;}
  .sec-head .line{display:none;}
  details{break-inside:avoid;}
}

/* Wilson buy-card: real cover image */
.buycard .cover-img{display:block;width:100%;height:auto;border-radius:12px;margin-bottom:18px;box-shadow:0 16px 34px -16px rgba(2,8,23,.6);}
.brand{white-space:nowrap;}

/* ——— mobile-only refinements (desktop layout unchanged) ——— */
@media(max-width:700px){
  /* keep the nav brand on one line beside the CTA */
  .nav-wrap{padding:14px 16px 0;}
  .nav{padding:11px 14px 11px 18px;}
  .brand{font-size:.94rem;}
  .nav-cta{font-size:.76rem;padding:9px 14px;}
  /* tidy the in-copyright cards: drop the long "Best for…" line, trim padding */
  .card{padding:22px 22px;}
  .card .for{display:none;}
  .card .foot{padding-top:14px;justify-content:flex-end;}
  /* compact the recommendation block */
  .spot{padding:26px 22px;gap:22px;}
  .spot h3{font-size:2.3rem;}
  .spot blockquote{font-size:1.3rem;line-height:1.32;}
  .spot p{font-size:1rem;}
  .buycard{padding:22px;}
  .buycard .cover-img{max-width:230px;margin-left:auto;margin-right:auto;}
}
