/* =====================================================================
   A KNIGHT IN BATTERED ARMOR — bespoke series microsite
   High-fantasy fated-mates romance: midnight teal & candlelit gold,
   copper-rose accents, ornate serif. A cinematic banner, the prophecy,
   the queen's impossible choice between two knights, and the trilogy.
   ===================================================================== */
@font-face{font-family:'Fraunces';font-style:normal;font-weight:400;font-display:swap;src:url('/assets/fonts/fraunces-400.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:600;font-display:swap;src:url('/assets/fonts/fraunces-600.woff2') format('woff2');}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/fraunces-400-italic.woff2') format('woff2');}

body[data-page="knight"]{
  --bg:#091317; --panel:#0e1d22; --panel-2:#122831; --line:rgba(217,184,95,.20);
  --ink:#f3ece0; --muted:#a9b6b3; --gold:#d9b85f; --gold-2:#f0d692; --rose:#e08a64; --teal:#5fb8b0;
  --serif:'Fraunces',Georgia,serif; --sans:'Archivo',system-ui,sans-serif;
  background:var(--bg); color:var(--ink); padding-top:var(--nav-h); font-family:var(--sans);
  line-height:1.75; overflow-x:hidden;
}
body[data-page="knight"]::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(60vw 55vh at 75% -8%,rgba(217,184,95,.12),transparent 60%),
    radial-gradient(50vw 50vh at 10% 30%,rgba(95,184,176,.10),transparent 60%),var(--bg);
}
.kn{max-width:1140px;margin-inline:auto;padding-inline:clamp(18px,4vw,44px)}
.kn-narrow{max-width:740px}
body[data-page="knight"] h1,body[data-page="knight"] h2,body[data-page="knight"] h3{font-family:var(--serif);font-weight:600;line-height:1.1}
.kn-kicker{font-family:var(--sans);text-transform:uppercase;letter-spacing:.28em;font-size:.72rem;color:var(--gold);font-weight:600}
.kn-rule{display:flex;align-items:center;gap:.8rem;color:var(--gold);justify-content:center}
.kn-rule::before,.kn-rule::after{content:"";height:1px;width:50px;background:linear-gradient(90deg,transparent,var(--gold))}
.kn-rule::after{background:linear-gradient(90deg,var(--gold),transparent)}
.kn-em{color:var(--rose)}

/* ---- HERO ---------------------------------------------------------- */
.kn-hero{position:relative;min-height:min(88vh,800px);display:flex;align-items:flex-end;overflow:hidden}
.kn-hero .bg{position:absolute;inset:0;z-index:-1}
.kn-hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.kn-hero .bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(0deg,var(--bg) 4%,rgba(9,19,23,.45) 45%,rgba(9,19,23,.15) 100%)}
.kn-hero .inner{position:relative;z-index:1;padding-block:clamp(36px,6vw,72px);max-width:640px}
.kn-hero .crumb a{color:var(--gold-2);font-weight:600;font-size:.85rem}
.kn-hero h1{font-size:clamp(2.4rem,6vw,4.4rem);margin:.4rem 0 .2rem;text-shadow:0 4px 30px rgba(0,0,0,.7)}
.kn-hero .logline{font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2.6vw,1.9rem);color:var(--gold-2);margin-top:.6rem}
.kn-hero .cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}
.btn-crown{display:inline-flex;align-items:center;gap:.5em;background:linear-gradient(180deg,var(--gold-2),var(--gold));color:#1a1205;font-weight:700;
  padding:.95em 1.7em;border-radius:4px;box-shadow:0 14px 40px -14px rgba(217,184,95,.6);transition:transform .18s,box-shadow .18s}
.btn-crown:hover{transform:translateY(-2px);box-shadow:0 22px 54px -16px rgba(217,184,95,.8)}
.btn-vow{display:inline-flex;align-items:center;gap:.5em;border:1px solid var(--line);color:var(--ink);font-weight:600;padding:.95em 1.6em;border-radius:4px;transition:.18s}
.btn-vow:hover{border-color:var(--gold);color:var(--gold-2)}

/* ---- PREMISE ------------------------------------------------------- */
.kn-premise{padding:clamp(56px,8vw,120px) 0;text-align:center}
.kn-premise h2{font-size:clamp(1.9rem,4.4vw,3.1rem);margin:1rem auto;max-width:22ch}
.kn-premise p{color:var(--muted);max-width:60ch;margin:0 auto;font-size:1.1rem}

/* ---- quote band ---------------------------------------------------- */
.kn-band{padding:clamp(48px,8vw,110px) 0;text-align:center;background:linear-gradient(180deg,var(--panel),var(--bg));border-block:1px solid var(--line)}
.kn-band blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3.6vw,2.6rem);line-height:1.3;max-width:24ch;margin:0 auto}
.kn-band cite{display:block;font-family:var(--sans);font-style:normal;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-top:1.2rem}

/* ---- THE CHOICE ---------------------------------------------------- */
.kn-choice{padding:clamp(56px,8vw,120px) 0}
.kn-head{text-align:center;max-width:680px;margin:0 auto clamp(28px,4vw,48px)}
.kn-head h2{font-size:clamp(2rem,4.6vw,3.4rem);margin:.8rem 0}
.kn-head p{color:var(--muted)}
.queen-card{max-width:620px;margin:0 auto clamp(20px,3vw,34px);text-align:center;background:linear-gradient(180deg,var(--panel-2),var(--panel));
  border:1px solid var(--line);border-radius:10px;padding:clamp(24px,3.5vw,40px);position:relative}
.queen-card .role{font-family:var(--sans);text-transform:uppercase;letter-spacing:.2em;font-size:.7rem;color:var(--rose)}
.queen-card h3{font-size:clamp(1.6rem,3vw,2.2rem);margin:.3rem 0 .6rem}
.queen-card p{color:var(--muted)}
.suitors{display:grid;grid-template-columns:1fr auto 1fr;gap:clamp(14px,2.5vw,28px);align-items:stretch}
@media(max-width:720px){.suitors{grid-template-columns:1fr}}
.suitor{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:clamp(22px,3vw,34px);transition:transform .3s,border-color .3s,box-shadow .3s}
.suitor:hover{transform:translateY(-5px)}
.suitor.paragon{border-top:3px solid var(--gold)}
.suitor.paragon:hover{border-color:var(--gold);box-shadow:0 24px 50px -28px rgba(217,184,95,.5)}
.suitor.battered{border-top:3px solid var(--teal)}
.suitor.battered:hover{border-color:var(--teal);box-shadow:0 24px 50px -28px rgba(95,184,176,.5)}
.suitor .role{font-family:var(--sans);text-transform:uppercase;letter-spacing:.18em;font-size:.7rem;color:var(--gold-2)}
.suitor.battered .role{color:var(--teal)}
.suitor h3{font-size:clamp(1.4rem,2.6vw,1.9rem);margin:.3rem 0 .6rem}
.suitor p{color:var(--muted);font-size:.96rem}
.kn-vs{display:grid;place-items:center;font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.4rem}
@media(max-width:720px){.kn-vs{padding:.4rem 0}}

/* ---- TRILOGY ------------------------------------------------------- */
.kn-books{padding:clamp(56px,8vw,120px) 0;background:linear-gradient(180deg,var(--panel),var(--bg));border-block:1px solid var(--line)}
.kn-shelf{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,3vw,34px)}
@media(max-width:720px){.kn-shelf{grid-template-columns:1fr;max-width:360px;margin-inline:auto}}
.kn-book{text-align:center}
.kn-book .cv{position:relative;border-radius:5px;overflow:hidden;box-shadow:0 24px 50px -22px rgba(0,0,0,.8);aspect-ratio:2/3;transition:transform .3s}
.kn-book:hover .cv{transform:translateY(-6px)}
.kn-book .cv img{width:100%;height:100%;object-fit:cover}
.kn-book .num{font-family:var(--sans);text-transform:uppercase;letter-spacing:.16em;font-size:.7rem;color:var(--gold);margin-top:1rem}
.kn-book h3{font-family:var(--serif);font-size:1.3rem;margin:.2rem 0 .4rem}
.kn-book .tl{font-family:var(--serif);font-style:italic;color:var(--gold-2);font-size:.95rem;margin-bottom:.8rem}
.kn-book .badge{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:.3em .7em;border-radius:3px}
.kn-book .badge.live{background:var(--gold);color:#1a1205}
.kn-book .badge.soon{background:transparent;border:1px solid var(--teal);color:var(--teal)}
.kn-book .amz{display:block;margin-top:.7rem;font-weight:700;font-size:.84rem;color:var(--gold-2)}
.kn-book .amz:hover{color:var(--rose)}

/* ---- CTA ----------------------------------------------------------- */
.kn-cta{padding:clamp(60px,9vw,130px) 0;text-align:center}
.kn-cta h2{font-size:clamp(2rem,5vw,3.2rem);margin:1rem 0}
.kn-cta p{color:var(--muted);max-width:50ch;margin:0 auto 2rem}
.kn-cta .cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}
