/* ==========================================================================
   PUSAKA AJWA — "Manuscript Archive" theme
   Scholarly heirloom: plum/aubergine ink on warm parchment, ruled hairlines,
   drop-caps, citation-style blocks, an authenticity certificate, restrained
   ornament. Structurally distinct from greendiamond (warm-gold ecommerce) and
   the wave-1 sacred-minimal Ajwa cousin (green minimalism).
   Palette baked from skins.json["ajwa.co.id"]; fonts Cormorant + Montserrat.
   ========================================================================== */

:root{
  --ink:#241326; --ink-2:#3d2240; --gold:#6b3a68; --gold-d:#4a2545; --gold-l:#956090;
  --brown:#533052; --brown-2:#6f486e; --cream:#F7F1F7; --cream-2:#EBDDEB; --line:#dcc6dc;
  --green:#533052; --muted:#84708a;
  --wa:#1faf54; --wa-d:#178a43;
  --paper:#FBF7FB; --paper-edge:#efe3ef; --ink-soft:#5a4660;
  --serif:'Cormorant',Georgia,serif; --sans:'Montserrat',system-ui,-apple-system,sans-serif;
  --rule:1px solid var(--line);
  --rule-strong:1.5px solid var(--ink);
  --shadow:0 14px 40px rgba(36,19,38,.10);
  --shadow-lg:0 28px 70px rgba(36,19,38,.16);
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink-soft);line-height:1.7;font-size:16.5px;
  background:
    repeating-linear-gradient(0deg, transparent, transparent 31px, rgba(108,58,104,.035) 31px, rgba(108,58,104,.035) 32px),
    var(--cream);
}
img{max-width:100%;display:block}
a{color:var(--gold-d);text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);line-height:1.08;margin:0 0 .35em;font-weight:700;letter-spacing:.002em}
h1{font-size:clamp(2.35rem,5.2vw,4.1rem)}
h2{font-size:clamp(1.85rem,3.6vw,2.8rem)}
h3{font-size:1.32rem}
p{margin:0 0 1.05em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.muted{color:var(--muted)}
.center{text-align:center}
.skip-link{position:absolute;left:-999px}.skip-link:focus{left:8px;top:8px;background:#fff;padding:8px;z-index:200}

/* shared small ornaments ------------------------------------------------- */
.kicker{font-family:var(--sans);text-transform:uppercase;letter-spacing:.26em;font-size:.72rem;font-weight:700;color:var(--gold);margin:0 0 1.1em;display:flex;align-items:center;gap:11px}
.kicker-no{font-family:var(--serif);font-style:italic;text-transform:none;letter-spacing:0;font-size:1.05rem;color:var(--ink);font-weight:600}
.rule-orn{display:flex;align-items:center;justify-content:center;gap:14px;color:var(--gold-l);font-size:1.05rem;margin:1.1em 0 1.3em}
.rule-orn span{height:1px;width:78px;background:linear-gradient(90deg,transparent,var(--line),var(--gold-l))}
.rule-orn span:last-child{background:linear-gradient(90deg,var(--gold-l),var(--line),transparent)}
.rule-orn.rule-left{justify-content:flex-start}
.rule-orn.rule-left span:first-child{width:54px;background:linear-gradient(90deg,var(--gold-l),var(--line),transparent)}
.rule-orn.rule-left span:last-child{display:none}

/* section register headers ----------------------------------------------- */
.reg-head{max-width:720px;margin:0 0 40px;border-bottom:var(--rule-strong);padding-bottom:14px}
.reg-head .reg-ey{font-family:var(--sans);text-transform:uppercase;letter-spacing:.24em;font-size:.68rem;font-weight:700;color:var(--gold);display:block;margin-bottom:.7em}
.reg-head h2{margin:0}
.reg-head .reg-sub{font-family:var(--serif);font-size:1.32rem;font-style:italic;color:var(--ink-2);margin:.5em 0 0;line-height:1.4}
.reg-cta{margin-top:38px}

/* buttons ---------------------------------------------------------------- */
.btn{display:inline-flex;align-items:center;gap:9px;padding:13px 26px;border-radius:2px;font-family:var(--sans);font-weight:600;font-size:.9rem;letter-spacing:.04em;text-transform:uppercase;border:1.5px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn:hover{text-decoration:none}
.btn-lg{padding:16px 32px;font-size:.95rem}
.btn-sm{padding:9px 16px;font-size:.78rem}
.btn-ink{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.btn-ink:hover{background:var(--gold-d);border-color:var(--gold-d);color:#fff}
.btn-ghost{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--cream)}
.btn-wa{background:var(--wa);color:#fff;border-color:var(--wa)}
.btn-wa:hover{background:var(--wa-d);border-color:var(--wa-d);color:#fff}
.wa-ic{font-size:1.05em}

/* ===================== HEADER (masthead) ================================= */
.site-header{background:var(--paper);border-bottom:var(--rule-strong);position:relative;z-index:60}
.folio-strip{background:var(--ink);color:var(--cream-2)}
.folio-strip-in{display:flex;align-items:center;gap:14px;min-height:38px;font-size:.74rem;letter-spacing:.04em;flex-wrap:wrap;padding-top:5px;padding-bottom:5px}
.folio-tag{font-weight:600;color:#e8d8e8}
.folio-sep{color:var(--gold-l)}
.folio-loc{color:#cdb6cd}
.folio-fill{flex:1;min-width:8px}
.folio-strip a{color:#e8d8e8}
.folio-strip a:hover{color:#fff;text-decoration:none}
.lang-toggle{font-weight:700;letter-spacing:.08em;border:1px solid #5a3d5a;border-radius:2px;padding:3px 10px;font-size:.7rem;text-transform:uppercase}
.lang-toggle:hover{border-color:var(--gold-l);color:#fff}
.folio-wa{font-weight:600;border-left:1px solid #5a3d5a;padding-left:14px;margin-left:2px}

.masthead{display:flex;align-items:center;justify-content:center;gap:16px;padding:22px 26px 18px;position:relative}
.brand{display:inline-flex;align-items:center;gap:14px;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand-logo{width:46px;height:auto;display:block;flex:none}
.brand-block{display:flex;flex-direction:column;align-items:center;text-align:center}
.brand-text{font-family:var(--serif);font-weight:700;font-size:2.05rem;line-height:.95;letter-spacing:.01em;color:var(--ink)}
.brand-rule{display:block;width:100%;max-width:240px;height:0;border-top:var(--rule);margin:6px 0 5px;position:relative}
.brand-rule::before{content:"❧";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--paper);padding:0 8px;color:var(--gold-l);font-size:.8rem}
.brand-sub{font-family:var(--sans);font-weight:500;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.nav-toggle{display:none;position:absolute;right:26px;top:50%;transform:translateY(-50%);background:none;border:1.5px solid var(--ink);border-radius:2px;font-size:1.2rem;line-height:1;padding:7px 12px;cursor:pointer;color:var(--ink)}

.main-nav{border-top:var(--rule);background:var(--paper)}
.nav-in{display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap;min-height:50px;padding-top:6px;padding-bottom:6px}
.main-nav a{font-family:var(--sans);text-transform:uppercase;letter-spacing:.14em;font-size:.74rem;font-weight:600;color:var(--ink-2);position:relative;padding:4px 0}
.main-nav a:hover{color:var(--gold-d);text-decoration:none}
.main-nav a::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--gold);transform:scaleX(0);transition:.2s;transform-origin:center}
.main-nav a:hover::after{transform:scaleX(1)}
.nav-wa{color:var(--gold-d)!important;font-weight:700!important}
.nav-wa::after{background:var(--gold)}

/* ===================== FRONTISPIECE / HERO ============================== */
.frontis{border-bottom:var(--rule-strong);background:linear-gradient(180deg,var(--paper),var(--cream))}
.frontis-in{display:grid;grid-template-columns:1.06fr .94fr;gap:0;align-items:stretch}
.frontis-text{padding:64px 56px 70px 0;border-right:var(--rule)}
.frontis-title{margin:0 0 .1em;font-size:clamp(2.5rem,4.8vw,4rem)}
.frontis-lead{font-family:var(--serif);font-size:1.5rem;line-height:1.5;color:var(--ink-2);max-width:30em;margin:.4em 0 0}
.frontis-actions{display:flex;gap:14px;flex-wrap:wrap;margin:34px 0 30px}
.frontis-facts{display:grid;grid-template-columns:repeat(3,auto);gap:0 30px;margin:0;padding-top:24px;border-top:var(--rule)}
.frontis-facts div{padding-right:24px}
.frontis-facts div + div{border-left:var(--rule);padding-left:24px}
.frontis-facts dt{font-family:var(--sans);text-transform:uppercase;letter-spacing:.14em;font-size:.62rem;font-weight:700;color:var(--gold);margin-bottom:4px}
.frontis-facts dd{margin:0;font-family:var(--serif);font-size:1.1rem;color:var(--ink);line-height:1.25}

.frontis-plate{margin:0;padding:54px 0 54px 56px;display:flex;flex-direction:column;justify-content:center}
.plate-frame{position:relative;border:1px solid var(--ink);padding:10px;background:var(--paper)}
.plate-frame::after{content:"";position:absolute;inset:4px;border:1px solid var(--line);pointer-events:none}
.plate-frame img{width:100%;height:auto;aspect-ratio:4/4.6;object-fit:cover;filter:saturate(.96)}
.frontis-plate figcaption{font-family:var(--serif);font-style:italic;font-size:.96rem;color:var(--muted);margin-top:14px;text-align:center}
.plate-no{font-family:var(--sans);font-style:normal;text-transform:uppercase;letter-spacing:.14em;font-size:.6rem;font-weight:700;color:var(--gold);margin-right:6px}
.wax-seal{position:absolute;right:-22px;bottom:-22px;width:108px;height:108px;border-radius:50%;
  background:radial-gradient(circle at 38% 32%,var(--gold-l),var(--gold) 46%,var(--gold-d) 100%);
  box-shadow:0 10px 24px rgba(36,19,38,.32), inset 0 2px 6px rgba(255,255,255,.25), inset 0 -6px 14px rgba(36,19,38,.4);
  display:flex;align-items:center;justify-content:center;border:2px dashed rgba(255,255,255,.5)}
.wax-in{font-family:var(--serif);font-weight:700;color:#fff;text-align:center;line-height:1;letter-spacing:.06em;font-size:1.15rem;text-shadow:0 1px 2px rgba(36,19,38,.5)}
.wax-in small{display:block;font-family:var(--sans);font-weight:600;font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;margin-top:5px;opacity:.92}

/* ===================== DEFINITION ENTRY ================================= */
.entry{border-bottom:var(--rule)}
.entry-in{display:grid;grid-template-columns:.34fr .66fr;gap:50px;padding:62px 0}
.entry-headword{border-right:var(--rule);padding-right:40px}
.headword{font-size:clamp(3rem,6vw,4.4rem);font-style:italic;margin:0;line-height:.9}
.pronunc{font-family:var(--serif);font-size:1.12rem;color:var(--muted);margin:.6em 0 0}
.def-lead{font-family:var(--serif);font-size:1.45rem;line-height:1.55;color:var(--ink-2);margin:0 0 1em}
.def-note{font-size:.92rem;color:var(--muted);border-left:2px solid var(--gold-l);padding-left:16px;margin:0;font-style:italic}

/* drop cap (manuscript) -------------------------------------------------- */
.has-cap > p:first-of-type::first-letter,
.def-lead.has-cap::first-letter{
  font-family:var(--serif);font-weight:700;float:left;font-size:4.4rem;line-height:.72;
  padding:.06em .12em 0 0;margin:.04em 0 -.02em 0;color:var(--gold-d)}

/* ===================== CATALOGUE (specimen list) ======================== */
.catalogue{padding:72px 0;border-bottom:var(--rule)}
.catalogue-page{padding-top:48px}
.spec-list{list-style:none;margin:0;padding:0;counter-reset:spec}
.spec-list > li{border-top:var(--rule)}
.spec-list > li:last-child{border-bottom:var(--rule)}
.pcard{display:block;color:inherit}
.pcard:hover{text-decoration:none}
.spec-list .pcard{display:grid;grid-template-columns:54px 132px 1fr;gap:26px;align-items:center;padding:26px 8px;transition:.18s}
.spec-list .pcard:hover{background:var(--paper)}
.spec-no{font-family:var(--serif);font-style:italic;font-size:1.9rem;color:var(--gold-l);text-align:center;line-height:1}
.spec-thumb{width:132px;height:132px;border:1px solid var(--ink);padding:5px;background:var(--paper);position:relative;overflow:visible}
.spec-thumb::after{content:"";position:absolute;inset:2px;border:1px solid var(--line);pointer-events:none}
.spec-thumb img{width:100%;height:100%;object-fit:cover}
.spec-entry{display:block}
.spec-top{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.spec-name{font-family:var(--serif);font-weight:700;font-size:1.5rem;color:var(--ink);line-height:1.12}
.spec-mark{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:.58rem;font-weight:700;color:var(--gold-d);border:1px solid var(--gold-l);padding:3px 9px;border-radius:2px;white-space:nowrap}
.spec-origin{display:block;font-family:var(--sans);font-size:.74rem;letter-spacing:.04em;color:var(--gold);text-transform:uppercase;font-weight:600;margin:.5em 0 .4em}
.spec-desc{display:block;color:var(--ink-soft);font-size:.98rem;max-width:60ch}
.spec-foot{display:flex;align-items:baseline;gap:20px;margin-top:.7em;flex-wrap:wrap}
.price{font-family:var(--serif);color:var(--gold-d);font-weight:700;font-size:1.4rem}
.price small{font-family:var(--sans);font-weight:600;color:var(--muted);font-size:.62em}
.pcard-link{font-family:var(--sans);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:var(--gold-d)}
.pcard-tag{display:inline-block}

/* ===================== CERTIFICATE OF AUTHENTICITY ===================== */
.certificate{padding:80px 0;background:var(--ink);
  background-image:radial-gradient(circle at 50% 0%,rgba(149,96,144,.22),transparent 60%);}
.cert-card{position:relative;max-width:920px;margin:0 auto;background:var(--paper);
  border:1.5px solid var(--gold-l);padding:60px 56px 50px;box-shadow:var(--shadow-lg)}
.cert-card::after{content:"";position:absolute;inset:10px;border:1px solid var(--line);pointer-events:none}
.cert-corner{position:absolute;width:30px;height:30px;border:2px solid var(--gold);}
.cert-tl{top:18px;left:18px;border-right:0;border-bottom:0}
.cert-tr{top:18px;right:18px;border-left:0;border-bottom:0}
.cert-bl{bottom:18px;left:18px;border-right:0;border-top:0}
.cert-br{bottom:18px;right:18px;border-left:0;border-top:0}
.cert-eyebrow{text-align:center;font-family:var(--sans);text-transform:uppercase;letter-spacing:.3em;font-size:.66rem;font-weight:700;color:var(--gold);margin:0 0 .9em}
.cert-title{text-align:center;margin:0 0 .4em;font-size:clamp(1.8rem,3.4vw,2.5rem)}
.cert-intro{text-align:center;font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--ink-2);max-width:38em;margin:0 auto 2em}
.cert-clauses{display:grid;grid-template-columns:1fr 1fr;gap:0;margin:0 0 2em;border-top:var(--rule)}
.cert-clauses .clause{padding:22px 24px;border-bottom:var(--rule)}
.cert-clauses .clause:nth-child(odd){border-right:var(--rule)}
.clause dt{font-family:var(--serif);font-weight:700;font-size:1.18rem;color:var(--ink);margin-bottom:.3em;display:flex;align-items:baseline;gap:9px}
.clause-no{font-style:italic;color:var(--gold-l);font-size:1rem}
.clause dd{margin:0;font-size:.95rem;color:var(--ink-soft)}
.cert-foot{display:flex;align-items:center;justify-content:space-between;gap:30px;border-top:var(--rule-strong);padding-top:26px;flex-wrap:wrap}
.cert-stat{display:flex;flex-direction:column}
.cert-num{font-family:var(--serif);font-weight:700;font-size:3rem;color:var(--gold-d);line-height:1}
.cert-lbl{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;font-weight:600;color:var(--muted);margin-top:4px}
.cert-sign{text-align:right;min-width:220px}
.sign-line{display:block;border-top:1.5px solid var(--ink);width:200px;margin-left:auto;margin-bottom:7px}
.sign-name{display:block;font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--ink)}
.sign-role{display:block;font-family:var(--sans);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:3px}

/* ===================== MARGINALIA / NOTES =============================== */
.marginalia{padding:76px 0;border-bottom:var(--rule)}
.notes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:var(--rule)}
.note{padding:30px 34px 30px 0;border-bottom:var(--rule);position:relative}
.note:nth-child(odd){border-right:var(--rule);padding-right:34px;padding-left:0}
.note:nth-child(even){padding-left:34px}
.note-glyph{font-family:var(--serif);font-size:1.7rem;color:var(--gold-l);float:left;margin:-2px 14px 0 0;line-height:1}
.note h3{font-size:1.28rem;margin:0 0 .35em}
.note p{margin:0;font-size:.96rem;color:var(--ink-soft)}

/* ===================== FOLIO PROSE COLUMN ============================== */
.folio{padding:76px 0;border-bottom:var(--rule)}
.folio-record{background:linear-gradient(180deg,var(--paper),var(--cream))}
.folio-in{display:grid;grid-template-columns:.26fr .74fr;gap:48px;align-items:start}
.folio-margin{border-right:var(--rule-strong);padding-right:30px;position:sticky;top:24px}
.folio-margin-no{display:block;font-family:var(--serif);font-style:italic;font-size:2.1rem;color:var(--gold-l);line-height:1;margin-bottom:.3em}
.folio-margin-lbl{display:block;font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:.66rem;font-weight:700;color:var(--gold)}
.folio-col{max-width:none}

/* ===================== INDEX / TABLE OF CONTENTS ====================== */
.index-sec{padding:76px 0;border-bottom:var(--rule)}
.toc{list-style:none;margin:0;padding:0}
.toc-row{border-top:var(--rule)}
.toc-row:last-child{border-bottom:var(--rule)}
.toc-row a{display:flex;align-items:baseline;gap:14px;padding:18px 6px;color:var(--ink)}
.toc-row a:hover{text-decoration:none;background:var(--paper)}
.toc-row a:hover .toc-title{color:var(--gold-d)}
.toc-cat{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;font-weight:700;color:var(--gold);border:1px solid var(--line);padding:4px 9px;border-radius:2px;white-space:nowrap;flex:none}
.toc-title{font-family:var(--serif);font-size:1.32rem;font-weight:600;line-height:1.2;flex:0 1 auto}
.toc-leader{flex:1;border-bottom:1.5px dotted var(--line);transform:translateY(-4px);min-width:18px}
.toc-go{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;font-weight:700;color:var(--gold-d);flex:none}

/* ===================== LEAF HEAD (inner page headers) ================= */
.leaf-head{border-bottom:var(--rule-strong);background:linear-gradient(180deg,var(--paper),var(--cream));padding:54px 0 46px}
.leaf-head .rule-orn{justify-content:flex-start}
.leaf-head .rule-orn span:first-child{display:none}
.leaf-sub{font-family:var(--serif);font-size:1.4rem;font-style:italic;color:var(--ink-2);max-width:42em;line-height:1.45;margin:.2em 0 0}

/* breadcrumbs ----------------------------------------------------------- */
.crumbs{padding:16px 0;color:var(--muted);font-size:.8rem;font-family:var(--sans);letter-spacing:.04em;text-transform:uppercase}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--gold-d)}
.cr-sep{margin:0 8px;color:var(--line)}

/* ===================== PRODUCT RECORD ================================== */
.record{padding:46px 0 72px;border-bottom:var(--rule)}
.record-in{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:start}
.record-plate{margin:0;position:sticky;top:24px}
.record-plate .plate-frame img{aspect-ratio:4/4.4}
.plate-ph{aspect-ratio:4/4.4;display:flex;align-items:center;justify-content:center;font-size:4rem;color:var(--gold-l);background:var(--cream-2)}
.record-plate figcaption{font-family:var(--serif);font-style:italic;font-size:.94rem;color:var(--muted);margin-top:14px;text-align:center}
.record-title{margin:.1em 0 .2em;font-size:clamp(2rem,3.6vw,2.9rem)}
.record-lead{font-family:var(--serif);font-size:1.4rem;line-height:1.45;color:var(--ink-2);margin:0 0 1.1em}
.ledger{margin:0 0 30px;border-top:var(--rule-strong)}
.ledger > div{display:grid;grid-template-columns:.32fr .68fr;gap:18px;padding:15px 2px;border-bottom:var(--rule);align-items:baseline}
.ledger dt{margin:0;font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.66rem;font-weight:700;color:var(--gold)}
.ledger dd{margin:0;color:var(--ink-soft);font-size:.98rem;display:flex;flex-wrap:wrap;gap:8px;align-items:baseline}
.chip{font-family:var(--sans);background:var(--paper);border:1px solid var(--line);border-radius:2px;padding:5px 12px;font-weight:600;font-size:.82rem;color:var(--ink-2)}
.ledger-price dd{align-items:baseline}
.record-price{font-family:var(--serif);font-size:1.9rem;color:var(--gold-d);font-weight:700;line-height:1}
.price-note{display:block;flex-basis:100%;font-size:.86rem;margin-top:4px}
.record-actions{display:flex;gap:14px;flex-wrap:wrap}

/* benefits (numbered observations) -------------------------------------- */
.benefits{padding:70px 0;border-bottom:var(--rule)}
.ben-list{list-style:none;margin:0;padding:0;counter-reset:ben;columns:2;column-gap:48px}
.ben-list li{break-inside:avoid;display:flex;gap:16px;padding:14px 0;border-bottom:var(--rule);align-items:baseline}
.ben-no{flex:none;width:30px}
.ben-no::before{counter-increment:ben;content:counter(ben,decimal-leading-zero);font-family:var(--serif);font-style:italic;font-size:1.05rem;color:var(--gold-l)}
.ben-text{color:var(--ink-soft);font-size:.98rem}

/* ===================== CODEX (article) ================================ */
.codex{padding:36px 0 64px}
.codex-wrap{max-width:780px;margin:0 auto}
.codex-head{margin-bottom:14px}
.codex-cat{font-family:var(--sans);text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;font-weight:700;color:var(--gold);margin:0 0 1em;padding-bottom:.7em;border-bottom:var(--rule)}
.codex-head h1{font-size:clamp(2.1rem,4.4vw,3.4rem);margin:0 0 .25em}
.codex-standfirst{font-family:var(--serif);font-size:1.5rem;font-style:italic;line-height:1.45;color:var(--ink-2);margin:.3em 0 .9em}
.codex-byline{font-family:var(--sans);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.codex-byline .by-name{color:var(--gold-d);font-weight:700}
.codex-byline .by-dot{color:var(--line)}
.codex-plate{margin:18px 0 36px}
.codex-plate img{width:100%;border:1px solid var(--ink);padding:8px;background:var(--paper)}
.codex-plate figcaption{font-family:var(--serif);font-style:italic;font-size:.86rem;color:var(--muted);margin-top:10px;text-align:center}
.codex-faq{margin-top:48px;border-top:var(--rule-strong);padding-top:30px}
.codex-faq h2{margin-bottom:18px}
.codex-cta{margin-top:44px;border-top:var(--rule);padding-top:34px;text-align:center}
.codex-cta-orn{display:block;color:var(--gold-l);font-size:1.5rem;margin-bottom:10px}
.codex-cta-lead{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--ink-2);max-width:34em;margin:0 auto 1.2em}

/* ===================== PROSE (shared rich text) ======================= */
.prose{max-width:760px;font-size:1.07rem;color:var(--ink-soft);line-height:1.78}
.prose h2{font-size:1.7rem;margin:1.7em 0 .45em;color:var(--ink);padding-bottom:.25em;border-bottom:var(--rule)}
.prose h3{font-size:1.32rem;margin:1.4em 0 .35em;color:var(--ink)}
.prose p{margin:0 0 1.1em}
.prose strong{color:var(--ink);font-weight:700}
.prose em{font-style:italic}
.prose a{color:var(--gold-d);border-bottom:1px solid var(--line)}
.prose a:hover{border-color:var(--gold)}
.prose ul,.prose ol{padding-left:1.4em;margin:0 0 1.2em}
.prose li{margin-bottom:.5em}
.prose blockquote{border-left:3px solid var(--gold-l);background:var(--paper);padding:14px 22px;margin:1.4em 0;font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--ink-2)}
.prose hr{border:0;border-top:var(--rule);margin:2em 0;position:relative;overflow:visible}
.prose hr::after{content:"❧";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:var(--cream);padding:0 14px;color:var(--gold-l)}
.prose figure{margin:1.6em 0}
.prose img{border:1px solid var(--ink);padding:6px;background:var(--paper)}
/* citation-style tables (ledger ruling) */
.prose table,.article-body table{width:100%;border-collapse:collapse;margin:1.6em 0;font-family:var(--sans);font-size:.92rem;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.prose thead th,.article-body thead th{background:transparent;border-bottom:1.5px solid var(--ink);font-family:var(--serif);font-size:1.02rem;font-weight:700;color:var(--ink)}
.prose th,.prose td,.article-body th,.article-body td{padding:9px 14px;text-align:left;vertical-align:top;border-bottom:var(--rule)}
.prose tbody tr:nth-child(even),.article-body tbody tr:nth-child(even){background:rgba(108,58,104,.035)}
.prose caption,.article-body caption{caption-side:bottom;font-style:italic;font-size:.82rem;color:var(--muted);padding-top:8px;text-align:left}

/* article-body specifics ------------------------------------------------- */
.article-body{max-width:none;font-size:1.1rem;line-height:1.85}
.article-body h2{font-size:1.72rem;margin:1.7em 0 .5em}
.article-body h3{font-size:1.34rem;margin:1.4em 0 .35em}
.article-body p{margin:0 0 1.15em}
.article-body strong{color:var(--ink)}
.article-body ul,.article-body ol{padding-left:1.5em;margin:0 0 1.2em}
.article-body li{margin-bottom:.55em}
.article-body blockquote{border-left:3px solid var(--gold-l);background:var(--paper);padding:16px 24px;margin:1.5em 0;font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--ink-2)}

/* ===================== FAQ (queries) ================================== */
.qsec{padding:70px 0;border-bottom:var(--rule)}
.faq{max-width:780px}
.faq details{border-bottom:var(--rule);background:transparent}
.faq details:first-child{border-top:var(--rule-strong)}
.faq summary{cursor:pointer;font-family:var(--serif);font-weight:600;font-size:1.22rem;color:var(--ink);padding:18px 36px 18px 0;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:16px;font-size:1.4rem;color:var(--gold);font-weight:300}
.faq details[open] summary::after{content:"–"}
.faq details p{margin:0 0 20px;color:var(--ink-soft);font-size:.98rem}

/* ===================== ARCHIVE HUB (article cards) ==================== */
.archive-sec{padding:54px 0 76px}
.entry-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:0;border-top:var(--rule)}
.ecard{display:flex;flex-direction:column;border-bottom:var(--rule);padding:0;color:inherit;transition:.18s}
.ecard:nth-child(odd){border-right:var(--rule)}
.ecard:hover{background:var(--paper)}
.ecard-media{position:relative;aspect-ratio:3/2;overflow:hidden;margin:22px 22px 0;border:1px solid var(--ink)}
.ecard-media img{width:100%;height:100%;object-fit:cover;transition:.4s}
.ecard:hover .ecard-media img{transform:scale(1.04)}
.ecard-fol{position:absolute;top:0;left:0;background:var(--ink);color:var(--cream);font-family:var(--serif);font-style:italic;font-size:1.05rem;padding:4px 12px}
.ecard-body{padding:18px 22px 24px;display:flex;flex-direction:column;gap:7px;flex:1}
.ecard-cat{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:.6rem;font-weight:700;color:var(--gold)}
.ecard-title{font-family:var(--serif);font-weight:700;font-size:1.34rem;line-height:1.18;color:var(--ink)}
.ecard:hover .ecard-title{color:var(--gold-d)}
.ecard-desc{font-size:.92rem;color:var(--ink-soft);flex:1}
.ecard-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:6px;padding-top:12px;border-top:var(--rule)}
.ecard-min{font-family:var(--sans);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

.related-sec{padding:64px 0;border-top:var(--rule);background:linear-gradient(180deg,var(--cream),var(--paper))}

/* ===================== CORRESPONDENCE (contact) ====================== */
.corr{padding:54px 0 78px}
.corr-in{display:grid;grid-template-columns:1fr 1.06fr;gap:0;align-items:start;border:1px solid var(--ink);background:var(--paper)}
.corr-card{padding:44px 46px;border-right:var(--rule)}
.corr-prose{max-width:none;font-size:1rem;margin-bottom:24px}
.corr-list{margin:0 0 26px;border-top:var(--rule-strong)}
.corr-list > div{display:grid;grid-template-columns:.34fr .66fr;gap:16px;padding:14px 2px;border-bottom:var(--rule)}
.corr-list dt{margin:0;font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;font-size:.64rem;font-weight:700;color:var(--gold)}
.corr-list dd{margin:0;color:var(--ink-soft);font-size:.96rem}
.corr-list a{color:var(--gold-d)}
.corr-form{padding:44px 46px;position:relative}
.corr-form-orn{position:absolute;right:40px;top:34px;font-size:1.5rem;color:var(--gold-l)}
.corr-form h2{font-size:1.7rem;margin:0 0 .2em}
.corr-form-note{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--ink-2);margin:0 0 1.2em}
.corr-form label{display:block;font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);margin:18px 0 6px}
.corr-form input,.corr-form textarea{width:100%;padding:12px 14px;border:1px solid var(--ink);border-radius:2px;font:inherit;font-size:1rem;background:var(--cream);color:var(--ink)}
.corr-form input:focus,.corr-form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(149,96,144,.18)}
.corr-submit{margin-top:22px;width:100%;justify-content:center}
.hp{position:absolute;left:-9999px;height:0;width:0;opacity:0}
.alert-ok{background:#eaf7ef;border:1px solid #b6e2c4;color:#176b38;padding:13px 15px;border-radius:2px;margin-bottom:14px;font-size:.95rem}
.err{color:#b3261e;font-size:.84rem;display:block;margin-top:4px}

/* ===================== CLOSING CTA ==================================== */
.closing{background:var(--ink);color:var(--cream);
  background-image:radial-gradient(circle at 50% 120%,rgba(149,96,144,.28),transparent 55%);}
.closing-in{padding:74px 26px;text-align:center;max-width:720px;margin:0 auto}
.closing-orn{display:block;font-size:1.8rem;color:var(--gold-l);margin-bottom:14px}
.closing h2{color:#fff;font-size:clamp(1.9rem,3.6vw,2.7rem)}
.closing p{color:#dcc6dc;font-family:var(--serif);font-size:1.3rem;font-style:italic;max-width:34em;margin:.4em auto 1.6em}

/* ===================== FOOTER (colophon) ============================= */
.site-footer{background:var(--paper);color:var(--ink-soft);border-top:var(--rule-strong);padding:58px 0 24px}
.colophon{display:grid;grid-template-columns:1.6fr .9fr 1.25fr;gap:48px}
.footer-brand{margin-bottom:14px}
.site-footer .brand-text{font-size:1.55rem}
.col-statement{font-family:var(--serif);font-style:italic;font-size:1.18rem;color:var(--ink-2);margin:0 0 .8em;max-width:34em}
.col-imprint{font-size:.92rem;color:var(--muted);max-width:38em;margin:0 0 1.1em}
.col-seals{display:flex;flex-wrap:wrap;gap:8px}
.seal-pill{font-family:var(--sans);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;border:1px solid var(--line);color:var(--ink-2);padding:5px 12px;border-radius:2px}
.site-footer h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin:0 0 16px;padding-bottom:10px;border-bottom:var(--rule)}
.col-nav{display:flex;flex-direction:column}
.col-nav a{font-family:var(--serif);font-size:1.08rem;color:var(--ink-2);padding:7px 0;border-bottom:var(--rule)}
.col-nav a:hover{color:var(--gold-d);text-decoration:none}
.col-addr,.col-line{font-size:.94rem;color:var(--muted);margin:0 0 .7em;line-height:1.5}
.col-line a{color:var(--gold-d)}
.col-contact .btn{margin-top:10px}
.email-link{color:var(--gold-d)}
.col-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;border-top:var(--rule);margin-top:38px;padding-top:20px;font-size:.8rem;letter-spacing:.04em}
.col-folio-no{font-family:var(--sans);text-transform:uppercase;letter-spacing:.1em;font-size:.66rem}

/* ===================== FLOATING WHATSAPP ============================= */
.wa-float{position:fixed;right:22px;bottom:22px;z-index:80;display:inline-flex;align-items:center;gap:10px;
  background:var(--wa);color:#fff;padding:14px 20px;border-radius:2px;box-shadow:0 12px 30px rgba(31,175,84,.45);font-family:var(--sans);font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;border:1.5px solid rgba(255,255,255,.25)}
.wa-float:hover{background:var(--wa-d);color:#fff;text-decoration:none}
.wa-glyph{width:24px;height:24px;display:block;flex:none}

/* ========================================================================
   RESPONSIVE
   ======================================================================== */
@media(max-width:1000px){
  .frontis-in,.entry-in,.record-in,.folio-in,.corr-in{grid-template-columns:1fr}
  .frontis-text{border-right:0;border-bottom:var(--rule);padding:52px 0 44px}
  .frontis-plate{padding:44px 0;max-width:460px;margin:0 auto}
  .entry-headword{border-right:0;border-bottom:var(--rule);padding:0 0 28px;display:flex;align-items:baseline;gap:20px}
  .entry-headword .pronunc{margin-top:0}
  .folio-margin{border-right:0;border-bottom:var(--rule-strong);padding:0 0 18px;position:static;display:flex;align-items:baseline;gap:16px}
  .folio-margin-no{margin-bottom:0}
  .record-plate{position:static;max-width:440px}
  .corr-card{border-right:0;border-bottom:var(--rule)}
}
@media(max-width:860px){
  .nav-toggle{display:block}
  .masthead{justify-content:flex-start;padding:18px 26px}
  .brand-block{align-items:flex-start;text-align:left}
  .brand-rule{margin-left:0}
  .brand-rule::before{left:30px}
  .main-nav{display:none;border-top:var(--rule)}
  .site-header.nav-open .main-nav{display:block}
  .nav-in{flex-direction:column;align-items:stretch;gap:0;padding:4px 26px 12px;min-height:0}
  .main-nav a{padding:14px 0;border-bottom:var(--rule);letter-spacing:.1em;font-size:.8rem}
  .main-nav a::after{display:none}
  .nav-wa{border-bottom:0!important}
  .cert-clauses{grid-template-columns:1fr}
  .cert-clauses .clause:nth-child(odd){border-right:0}
  .cert-card{padding:46px 32px 40px}
  .notes-grid{grid-template-columns:1fr}
  .note:nth-child(odd){border-right:0;padding-right:0}
  .note:nth-child(even){padding-left:0}
  .note{padding:26px 0}
  .ben-list{columns:1}
  .entry-grid{grid-template-columns:1fr}
  .ecard:nth-child(odd){border-right:0}
  .colophon{grid-template-columns:1fr 1fr;gap:34px}
  .col-mark{grid-column:1/-1}
}
@media(max-width:640px){
  .folio-strip-in{justify-content:center;font-size:.68rem;gap:9px 12px;padding:7px 0}
  .folio-fill{display:none}
  .folio-tag{flex-basis:100%;text-align:center}
  .folio-wa{border-left:0;padding-left:0;margin-left:0}
  .frontis-facts{grid-template-columns:1fr;gap:0}
  .frontis-facts div{padding:12px 0;border-bottom:var(--rule)}
  .frontis-facts div + div{border-left:0;padding-left:0}
  .spec-list .pcard{grid-template-columns:40px 1fr;gap:14px 16px;padding:22px 4px}
  .spec-thumb{grid-row:span 2;width:100%;height:auto;aspect-ratio:1}
  .spec-no{font-size:1.3rem;text-align:left}
  .spec-name{font-size:1.28rem}
  .spec-desc{font-size:.92rem}
  .colophon{grid-template-columns:1fr;gap:30px}
  .col-foot{justify-content:flex-start}
}
@media(max-width:540px){
  .wrap{padding:0 18px}
  .masthead{padding:16px 18px}
  .nav-toggle{right:18px}
  .nav-in{padding:4px 18px 12px}
  body{font-size:16px}
  .brand-text{font-size:1.7rem}
  .frontis-text{padding:42px 0 36px}
  .frontis-lead,.def-lead,.record-lead,.codex-standfirst,.leaf-sub{font-size:1.22rem}
  .closing p,.col-statement,.codex-cta-lead{font-size:1.12rem}
  .reg-head .reg-sub{font-size:1.12rem}
  .has-cap > p:first-of-type::first-letter,.def-lead.has-cap::first-letter{font-size:3.4rem}
  .wax-seal{width:84px;height:84px;right:-12px;bottom:-12px}
  .wax-in{font-size:.92rem}
  .cert-card{padding:40px 22px 34px}
  .cert-corner{width:22px;height:22px}
  .cert-foot{flex-direction:column;align-items:flex-start;gap:24px}
  .cert-sign{text-align:left}
  .sign-line{margin-left:0}
  .corr-card,.corr-form{padding:32px 24px}
  .btn{white-space:normal}
  .btn-lg{padding:14px 24px}
  /* wide citation tables scroll instead of overflowing the page */
  .prose table,.article-body table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}
  /* floating WA collapses to a round stamp; logo fills it */
  .wa-float{padding:0;width:60px;height:60px;justify-content:center;border-radius:50%;right:16px;bottom:16px;gap:0}
  .wa-float .wa-text{display:none}
  .wa-float .wa-glyph{width:40px;height:40px}
}

/* global safety: never allow horizontal scroll */
html,body{max-width:100%;overflow-x:clip}
