:root{
  --bg:#FAF6EF; --bg-alt:#F2EADC; --bg-card:#FFFFFF;
  --text:#1F2A2E; --text-soft:#5A6669; --title:#0F1A1E;
  --accent:#C8581F; --accent-hover:#9E4214; --accent-soft:#F5E0D4;
  --olive:#5C6B3F; --bordeaux:#7B1E2F;
  --border:#E5DCC8; --border-soft:#EFE7D5;
  --error:#A4271C; --success:#3F6B3A;
  --shadow-sm:0 1px 2px rgba(15,26,30,.06);
  --shadow-md:0 6px 16px rgba(15,26,30,.08);
  --shadow-lg:0 14px 40px rgba(15,26,30,.12);
  --radius:14px; --radius-sm:8px;
  --wrap:1180px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--accent);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px}
a:hover{color:var(--accent-hover)}
h1,h2,h3,h4{font-family:'Fraunces','Georgia',serif;color:var(--title);font-weight:600;line-height:1.2;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.5vw,3.4rem);letter-spacing:-.01em}
h2{font-size:clamp(1.5rem,3vw,2.2rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 1.25rem}
.skip{position:absolute;left:-9999px;top:-9999px}
.skip:focus{position:static;background:var(--accent);color:#fff;padding:.5rem 1rem;display:inline-block}
*:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}

/* Header */
.site-header{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50;backdrop-filter:saturate(1.4) blur(6px);background:rgba(250,246,239,.9)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-top:.75rem;padding-bottom:.75rem}
.logo{display:inline-flex;align-items:baseline;gap:.15rem;text-decoration:none;color:var(--title);font-family:'Fraunces',serif;font-weight:700;font-size:1.6rem;line-height:1}
.logo-mark{color:var(--accent);font-size:1.9rem}
.logo:hover .logo-text{color:var(--accent)}
nav.primary ul{list-style:none;display:flex;gap:1.25rem;margin:0;padding:0;align-items:center;flex-wrap:wrap}
nav.primary a{color:var(--text);text-decoration:none;font-weight:500;font-size:.95rem}
nav.primary a:hover{color:var(--accent)}
nav.primary a.cta-link{background:var(--accent);color:#fff;padding:.45rem .9rem;border-radius:999px}
nav.primary a.cta-link:hover{background:var(--accent-hover);color:#fff}
.nav-toggle{display:none;background:none;border:1px solid var(--border);color:var(--text);font-weight:500;padding:.4rem .8rem;border-radius:6px;cursor:pointer}
@media (max-width:880px){
  /* Mobile burger icon — clean hamburger that morphs to X when open */
  .nav-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    width:44px;height:44px;
    background:none;border:1px solid var(--border);border-radius:8px;
    color:transparent;font-size:0;line-height:0;
    cursor:pointer;position:relative
  }
  .nav-toggle::before{
    content:"";display:block;width:20px;height:2px;background:var(--text);
    box-shadow:0 -6px 0 var(--text), 0 6px 0 var(--text);transition:transform .2s,box-shadow .2s,background .2s
  }
  .nav-toggle[aria-expanded="true"]::before{
    background:transparent;box-shadow:0 0 0 transparent;transform:rotate(45deg)
  }
  .nav-toggle[aria-expanded="true"]::after{
    content:"";position:absolute;display:block;width:20px;height:2px;background:var(--text);transform:rotate(-45deg)
  }

  /* Mobile menu — clean vertical dropdown anchored to the top-right */
  nav.primary ul{
    display:none;
    position:absolute;
    top:calc(100% + .5rem);right:1rem;
    background:var(--bg-card);
    border:1px solid var(--border);border-radius:14px;
    padding:.5rem;
    flex-direction:column !important;
    align-items:stretch;
    gap:.15rem;
    box-shadow:var(--shadow-lg);
    min-width:240px;max-width:calc(100vw - 2rem);
    z-index:60;
    flex-wrap:nowrap
  }
  nav.primary ul.open{display:flex !important}
  nav.primary li{margin:0;width:100%}
  nav.primary li a{
    display:block;
    padding:.8rem 1rem;
    border-radius:8px;
    font-size:1rem;font-weight:500;
    color:var(--text);
    min-height:44px;
    line-height:1.3
  }
  nav.primary li a:hover,nav.primary li a:focus{background:var(--bg-alt);color:var(--accent)}
  /* CTA Contact button - full-width orange */
  nav.primary a.cta-link{
    background:var(--accent);color:#fff;text-align:center;font-weight:600;margin-top:.4rem
  }
  nav.primary a.cta-link:hover,nav.primary a.cta-link:focus{background:var(--accent-hover);color:#fff}
  /* Visual separators between groups */
  nav.primary li:nth-child(5){border-top:1px solid var(--border);margin-top:.4rem;padding-top:.4rem}
  /* Language toggle: centred pill at the bottom */
  nav.primary li:last-child{margin-top:.5rem;border-top:1px solid var(--border);padding-top:.5rem;text-align:center}
  nav.primary li:last-child a.lang-toggle{
    display:inline-block;background:transparent;border:1px solid var(--border);
    padding:.45rem 1rem;border-radius:999px;font-size:.85rem;font-weight:600;letter-spacing:.05em;
    width:auto;margin:0 auto;min-height:auto
  }
}

/* Hero */
.hero{padding:4rem 0 3rem;background:linear-gradient(180deg,var(--bg-alt) 0%,var(--bg) 100%)}
.hero-inner{display:grid;grid-template-columns:1.2fr 1fr;gap:3rem;align-items:center}
@media (max-width:880px){.hero-inner{grid-template-columns:1fr}}
.hero h1{margin-bottom:.5rem}
.hero .lead{font-size:1.15rem;color:var(--text-soft);max-width:42ch}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.5rem}
.btn{display:inline-block;background:var(--accent);color:#fff;padding:.75rem 1.4rem;border-radius:999px;text-decoration:none;font-weight:600;border:1px solid var(--accent);transition:background .15s,transform .1s}
.btn:hover{background:var(--accent-hover);color:#fff}
.btn:active{transform:translateY(1px)}
.btn-ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}
.btn-ghost:hover{background:var(--accent);color:#fff}
.hero-figure{aspect-ratio:4/3;background:var(--bg-card) center/cover no-repeat;border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;position:relative}
.hero-figure img{width:100%;height:100%;object-fit:cover}
.hero-stat{position:absolute;bottom:1rem;left:1rem;right:1rem;background:rgba(255,255,255,.92);border-radius:10px;padding:.65rem .9rem;display:flex;justify-content:space-around;gap:.5rem;font-size:.9rem;color:var(--title);font-weight:500;backdrop-filter:blur(4px)}
.hero-stat strong{font-family:'Fraunces',serif;color:var(--accent);font-size:1.1rem;display:block}

/* Sections */
section.section{padding:3rem 0}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.78rem;color:var(--accent);font-weight:600;margin:0}

/* Universe tiles */
.univers-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media (max-width:880px){.univers-grid{grid-template-columns:repeat(2,1fr)}}
.univ-tile{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1.25rem;text-decoration:none;color:var(--text);display:block;transition:transform .15s,box-shadow .15s,border-color .15s}
.univ-tile:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent);color:var(--text)}
.univ-tile .icon{font-size:2rem;display:block;margin-bottom:.25rem}
.univ-tile h3{margin:.25rem 0;color:var(--title)}
.univ-tile p{font-size:.92rem;color:var(--text-soft);margin:0}
.univ-tile .count{display:inline-block;margin-top:.75rem;font-size:.85rem;color:var(--accent);font-weight:600}

/* Cards grid */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media (max-width:880px){.cards{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.cards{grid-template-columns:1fr}}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.card-media{display:block;position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--bg-alt)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.card:hover .card-media img{transform:scale(1.04)}
.card-univers{position:absolute;top:.75rem;left:.75rem;background:rgba(255,255,255,.92);padding:.25rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600;color:var(--title);backdrop-filter:blur(4px)}
.card-body{padding:1rem 1.1rem 1.25rem;flex:1;display:flex;flex-direction:column}
.card-cat{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0 0 .25rem;font-weight:600}
.card-title{margin:0 0 .35rem;font-size:1.2rem;line-height:1.25}
.card-title a{color:var(--title);text-decoration:none}
.card-title a:hover{color:var(--accent)}
.card-tagline{color:var(--text-soft);font-size:.95rem;margin:0 0 .5rem;font-style:italic}
.card-loc{font-size:.88rem;color:var(--text-soft);margin:auto 0 0}

/* Fiche detail */
.fiche-hero{position:relative;height:50vh;min-height:340px;max-height:520px;overflow:hidden;background:var(--bg-alt)}
.fiche-hero img{width:100%;height:100%;object-fit:cover}
.fiche-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,26,30,.65) 100%)}
.fiche-hero-content{position:absolute;left:0;right:0;bottom:2rem;color:#fff;z-index:1}
.fiche-hero-content .wrap{display:flex;flex-direction:column;gap:.3rem}
.fiche-hero-content h1{color:#fff;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.fiche-hero-content .meta{display:flex;gap:.75rem;flex-wrap:wrap;font-weight:500}
.fiche-hero-content .badge{background:rgba(255,255,255,.16);padding:.2rem .6rem;border-radius:999px;backdrop-filter:blur(4px);font-size:.85rem}
.fiche-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:3rem;padding:3rem 0}
@media (max-width:880px){.fiche-grid{grid-template-columns:1fr;gap:2rem}}
.fiche-main h2{margin-top:2rem}
.fiche-main h2:first-child{margin-top:0}
.fiche-main p{font-size:1.05rem}
.fiche-aside{position:sticky;top:5rem;align-self:start}
.fiche-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow-sm)}
.fiche-card h3{margin:0 0 .75rem;font-size:1.1rem}
.fiche-info{list-style:none;padding:0;margin:0;display:grid;gap:.6rem}
.fiche-info li{display:flex;gap:.5rem;align-items:flex-start;font-size:.95rem}
.fiche-info .ico{flex:0 0 1.5rem;text-align:center;color:var(--accent)}
.fiche-info a{word-break:break-word}
.fiche-actions{display:flex;flex-direction:column;gap:.6rem;margin-top:1.25rem}
.fiche-map-mini{height:220px;border-radius:var(--radius-sm);overflow:hidden;margin-top:1rem;border:1px solid var(--border)}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin:2rem 0}
.gallery a{display:block;aspect-ratio:1;background:var(--bg-alt);border-radius:var(--radius-sm);overflow:hidden}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery a:hover img{transform:scale(1.05)}
.crumb{font-size:.9rem;color:var(--text-soft);margin:1.5rem 0 0}
.crumb a{color:var(--text-soft);text-decoration:none}
.crumb a:hover{color:var(--accent)}

/* Univers page */
.univ-head{padding:3rem 0 1rem;background:var(--bg-alt);border-bottom:1px solid var(--border)}
.univ-head .icon{font-size:3rem;line-height:1}
.univ-head p.lead{font-size:1.15rem;color:var(--text-soft);max-width:55ch;margin-top:.5rem}
.univ-filter{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.univ-filter button{background:#fff;border:1px solid var(--border);padding:.4rem .9rem;border-radius:999px;font-size:.9rem;color:var(--text);cursor:pointer;font-family:inherit}
.univ-filter button:hover{border-color:var(--accent);color:var(--accent)}
.univ-filter button.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Map page */
.map-shell{display:grid;grid-template-columns:1fr 380px;gap:0;height:calc(100vh - 64px);min-height:520px}
@media (max-width:880px){.map-shell{grid-template-columns:1fr;height:auto}.map-list{max-height:60vh}}
#map{width:100%;height:100%;min-height:420px;background:var(--bg-alt)}
.map-list{overflow-y:auto;background:var(--bg);border-left:1px solid var(--border);padding:1rem}
.map-list h2{font-size:1.2rem;margin-bottom:.75rem}
.map-list .mini-card{display:flex;gap:.75rem;align-items:center;padding:.6rem;border-radius:var(--radius-sm);text-decoration:none;color:var(--text);border:1px solid transparent;margin-bottom:.4rem}
.map-list .mini-card:hover,.map-list .mini-card:focus{background:var(--bg-alt);border-color:var(--border)}
.map-list .mini-thumb{flex:0 0 56px;width:56px;height:56px;border-radius:8px;background:var(--bg-alt) center/cover}
.map-list .mini-card strong{color:var(--title);display:block;font-size:.95rem;line-height:1.25}
.map-list .mini-card span{color:var(--text-soft);font-size:.82rem}

/* Form */
form.contact{display:grid;gap:1rem;max-width:560px}
form.contact label{font-weight:500;font-size:.95rem;display:block;margin-bottom:.25rem}
form.contact input,form.contact select,form.contact textarea{
  width:100%;padding:.75rem .9rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:1rem;background:#fff;color:var(--text)
}
form.contact textarea{min-height:160px;resize:vertical}
form.contact input:focus,form.contact select:focus,form.contact textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,88,31,.18)}
form.contact .hp{position:absolute;left:-9999px}
form.contact button{justify-self:start}

/* Prose */
.prose{max-width:68ch;margin:0 auto;padding:3rem 0}
.prose h2{margin-top:2rem}
.prose blockquote{border-left:3px solid var(--accent);padding-left:1rem;color:var(--text-soft);font-style:italic;margin:1.5rem 0}

/* Footer */
.site-footer{background:var(--title);color:#E0DBD0;padding:3rem 0 1.5rem;margin-top:4rem}
.site-footer a{color:#F2EADC}
.site-footer a:hover{color:#fff}
.foot-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.4fr;gap:2rem}
@media (max-width:880px){.foot-cols{grid-template-columns:1fr 1fr;gap:1.5rem}}
@media (max-width:560px){.foot-cols{grid-template-columns:1fr}}
.site-footer h4{color:#fff;margin:0 0 .5rem;font-size:1rem;font-family:'Fraunces',serif}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.3rem 0}
.foot-brand{margin:0;font-size:1.1rem}
.foot-brand strong{color:#fff;font-family:'Fraunces',serif}
.foot-brand span{color:#A8A39A;font-size:.92rem}
.foot-meta{border-top:1px solid #2A363B;margin-top:2rem;padding-top:1rem;color:#A8A39A;font-size:.85rem}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}


/* === Hero v2 with stacked banner + search form ============================ */
.hero-inner-stack{display:grid;grid-template-columns:1fr;gap:2rem;justify-items:center;text-align:center;max-width:880px;margin:0 auto}
.hero-text{max-width:680px}
.hero-figure-wide{width:100%;max-width:880px;aspect-ratio:16/9;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow-lg);background:var(--bg-card)}
.hero-figure-wide img{width:100%;height:100%;object-fit:cover}
.hero-search{width:100%;max-width:880px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;box-shadow:var(--shadow-md)}
.hero-search .hs-row{display:grid;grid-template-columns:1.6fr 1fr auto;gap:.75rem;align-items:end}
@media (max-width:760px){.hero-search .hs-row{grid-template-columns:1fr}}
.hero-search .hs-field{display:flex;flex-direction:column;gap:.25rem;text-align:left}
.hero-search .hs-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);font-weight:600}
.hero-search input[type="text"],
.hero-search select{padding:.85rem 1rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:1rem;background:#fff;color:var(--text);width:100%}
.hero-search input[type="text"]:focus,
.hero-search select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,88,31,.18)}
.hero-search .hs-submit{padding:.85rem 1.5rem;background:var(--accent);color:#fff;border:0;border-radius:var(--radius-sm);font-family:inherit;font-size:1rem;font-weight:600;cursor:pointer;height:100%;transition:background .15s}
.hero-search .hs-submit:hover{background:var(--accent-hover)}
.hero-search .hs-helper{font-size:.85rem;color:var(--text-soft);margin:.75rem 0 0;text-align:center}
.hero-stats{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;font-size:.95rem;color:var(--text-soft);margin:0}
.hero-stats strong{font-family:'Fraunces',serif;color:var(--accent);font-size:1.4rem;display:block;line-height:1}
.hero-inner{display:none}

/* === Map page filter banner =============================================== */
.map-filter{display:flex;gap:.5rem;align-items:center;margin-top:1rem;flex-wrap:wrap}
.map-filter input[type="text"],.map-filter select{padding:.55rem .8rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:inherit;font-size:.95rem;background:#fff;color:var(--text);min-width:0}
.map-filter input[type="text"]{flex:2 1 240px}
.map-filter select{flex:1 1 180px}
.map-filter button{padding:.55rem 1.1rem;background:var(--accent);color:#fff;border:0;border-radius:var(--radius-sm);font-family:inherit;font-weight:600;cursor:pointer}
.map-filter button:hover{background:var(--accent-hover)}
.map-filter input:focus,.map-filter select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(200,88,31,.18)}
.map-filter .flt-count{margin-left:.5rem;color:var(--text-soft);font-size:.9rem}
.map-filter .flt-count strong{color:var(--accent);font-family:'Fraunces',serif;font-weight:600}


/* === Category pills on universe pages ===================================== */
.cat-strip{background:var(--bg);border-bottom:1px solid var(--border);padding:1rem 0 1.25rem}
.cat-pills{display:flex;flex-wrap:wrap;gap:.5rem}
.cat-pill{display:inline-flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--border);border-radius:999px;padding:.45rem .9rem;text-decoration:none;color:var(--text);font-size:.92rem;font-weight:500;transition:border-color .15s,transform .1s,box-shadow .15s}
.cat-pill:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow-sm)}
.cat-pill-icon{font-size:1.05rem;line-height:1}
.cat-pill-label{line-height:1}
.cat-pill-count{background:var(--bg-alt);color:var(--text-soft);padding:.1rem .55rem;border-radius:999px;font-size:.8rem;font-weight:600;font-family:'Fraunces',serif;margin-left:.15rem}
.cat-pill:hover .cat-pill-count{background:var(--accent);color:#fff}


/* === Journal index grid =================================================== */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:1rem}
@media (max-width:880px){.journal-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.journal-grid{grid-template-columns:1fr}}
.journal-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem;transition:box-shadow .15s,transform .15s}
.journal-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.journal-card h3{margin:.25rem 0 .5rem;font-size:1.15rem;line-height:1.3}
.journal-card h3 a:hover{color:var(--accent)}
.journal-card p{margin:.5rem 0;font-size:.95rem}
.journal-card .btn-ghost{padding:.4rem .9rem;font-size:.9rem}
.journal-nav .cat-pill{padding:.35rem .8rem;font-size:.85rem}


/* Footer logo */
.foot-logo{max-width:140px;width:auto;height:auto;display:block;margin-top:.75rem;opacity:.9}
.foot-logo:hover{opacity:1}

/* Home category pills grid */
.home-cats{justify-content:flex-start;gap:.6rem}
.home-cats .cat-pill{padding:.55rem 1rem;font-size:.95rem}
.home-cats .cat-pill-count{font-size:.85rem}

/* Article hero image */
.article-hero{margin:1.25rem 0 1.5rem;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);background:var(--bg-alt)}
.article-hero img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}


/* Journal card with image */
.journal-card{padding:0;display:flex;flex-direction:column;overflow:hidden}
.journal-card-media{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--bg-alt)}
.journal-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.journal-card:hover .journal-card-media img{transform:scale(1.04)}
.journal-card-body{padding:1.25rem;flex:1;display:flex;flex-direction:column}
.journal-card-body h3{margin:.4rem 0 .5rem}
.journal-card-body .btn-ghost{margin-top:auto;align-self:flex-start}


/* === Language toggle ===================================================== */
.lang-toggle{margin-left:.5rem;padding:.4rem .65rem;border:1px solid var(--border);border-radius:6px;text-decoration:none;color:var(--text);font-size:.85rem;font-weight:600;letter-spacing:.05em;background:#fff}
.lang-toggle:hover{border-color:var(--accent);color:var(--accent)}
@media (max-width:880px){.lang-toggle{margin-left:0}}


/* === Home category tiles on mobile ======================================= */
@media (max-width:760px){
  .home-cats{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-top:.5rem}
  .home-cats .cat-pill{
    flex-direction:column;align-items:flex-start;gap:.3rem;
    padding:.85rem .9rem;border-radius:12px;
    background:#fff;border:1px solid var(--border);
    text-align:left;min-height:96px;justify-content:space-between
  }
  .home-cats .cat-pill-icon{font-size:1.6rem;line-height:1}
  .home-cats .cat-pill-label{font-size:.95rem;font-weight:600;line-height:1.2;display:block;width:100%}
  .home-cats .cat-pill-count{margin-left:0;align-self:flex-start;font-size:.78rem}
  .home-cats .cat-pill:hover{transform:translateY(-1px);border-color:var(--accent)}

  /* Same upgrade for cat-strip on universe pages */
  .cat-pills{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
  .cat-strip .cat-pill{
    flex-direction:column;align-items:flex-start;
    padding:.85rem .9rem;border-radius:12px;min-height:80px;justify-content:space-between
  }
}

/* === Header tightening on mobile ========================================= */
@media (max-width:880px){
  .site-header .wrap{padding-top:.6rem;padding-bottom:.6rem;position:relative}
  .logo{font-size:1.4rem}
  .logo-mark{font-size:1.65rem}
}

/* === Hero search on mobile is generous enough already; tighten stats ===== */
@media (max-width:560px){
  .hero{padding:2.5rem 0 2rem}
  .hero h1{font-size:2.1rem}
  .hero-stats{gap:1.2rem;font-size:.85rem}
  .hero-stats strong{font-size:1.15rem}
}

/* === Section heading spacing on mobile =================================== */
@media (max-width:760px){
  .section-head{flex-direction:column;align-items:flex-start;gap:.5rem}
  section.section{padding:2rem 0}
}





/* === Home poster slider (v2 — arrows + edge fades + image-based) ========= */
.poster-ribbon{background:var(--bg-alt);padding:2.5rem 0}
.poster-slider{position:relative;margin-top:1rem}
.poster-rail{
  display:flex;gap:1.1rem;
  overflow-x:auto;
  padding:1rem .25rem 1.25rem;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
  -webkit-mask-image:linear-gradient(to right, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
          mask-image:linear-gradient(to right, transparent 0, #000 32px, #000 calc(100% - 32px), transparent 100%);
}
.poster-rail::-webkit-scrollbar{height:6px}
.poster-rail::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.poster-rail::-webkit-scrollbar-track{background:transparent}
.poster-rail-item{
  flex:0 0 auto;width:180px;text-decoration:none;color:#fff;
  scroll-snap-align:start;
  position:relative;display:block;
  aspect-ratio:2/3;
  border-radius:var(--radius-sm);overflow:hidden;
  background:var(--bg-card);
  box-shadow:var(--shadow-sm);
  transition:transform .2s ease,box-shadow .2s ease;
}
.poster-rail-item:hover,
.poster-rail-item:focus-visible{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.poster-rail-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.poster-rail-item:hover img,
.poster-rail-item:focus-visible img{transform:scale(1.04)}
.poster-rail-caption{
  position:absolute;left:0;right:0;bottom:0;
  padding:1.6rem .85rem .7rem;
  font-family:'Fraunces',serif;font-weight:600;font-size:1rem;line-height:1.15;
  color:#fff;
  background:linear-gradient(to top, rgba(15,26,30,.78) 0%, rgba(15,26,30,.45) 60%, rgba(15,26,30,0) 100%);
  pointer-events:none;
}
.poster-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:42px;height:42px;border-radius:50%;
  background:#fff;border:1px solid var(--border);color:var(--title);
  display:none;align-items:center;justify-content:center;cursor:pointer;
  box-shadow:var(--shadow-md);
  transition:background .15s,color .15s,transform .1s;
  z-index:2;
}
.poster-arrow:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.poster-arrow:active{transform:translateY(-50%) scale(.95)}
.poster-arrow:focus-visible{outline:3px solid var(--accent);outline-offset:2px}
.poster-arrow[hidden]{display:none !important}
.poster-arrow-prev{left:-12px}
.poster-arrow-next{right:-12px}
@media (min-width:880px){.poster-arrow{display:inline-flex}}
@media (max-width:560px){
  .poster-rail-item{width:150px}
  .poster-rail-caption{font-size:.92rem;padding:1.4rem .7rem .55rem}
}
