/* ============================================================
   HOLY HUNDRED — design system
   Illuminated manuscript × modern editorial
   ============================================================ */
:root{
  --bg:#faf7f0; --bg2:#f4ecdd; --bg3:#ece0c9;
  --ink:#16110a; --ink2:#43372617; --ink-2:#473b29; --ink-3:#766a55;
  --gold:#8c5f10; --gold-l:#b8831e; --gold-d:#5e3d08; --gold-soft:rgba(140,95,16,.14);
  --crim:#6e1818; --night:#14110b; --night2:#1d1810;
  --line:rgba(22,17,10,.12); --rule:rgba(140,95,16,.30);
  --sans:"Helvetica Neue","HelveticaNeue",Helvetica,Arial,sans-serif;
  --mono:"Courier New",Courier,monospace;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --max:1180px; --pad:clamp(20px,5vw,72px);
  --r:4px; --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:#fff}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}

.wrap{max-width:var(--max);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.eyebrow{font-family:var(--mono);font-weight:700;letter-spacing:.34em;text-transform:uppercase;font-size:11px;color:var(--gold-d)}
h1,h2,h3,h4{font-family:var(--sans);font-weight:700;line-height:1.04;letter-spacing:-.01em;text-wrap:balance}
.serif{font-family:var(--sans)} .mono{font-family:var(--mono)}
p{text-wrap:pretty}
.lead{font-size:clamp(18px,2.2vw,23px);line-height:1.5;color:var(--ink-2)}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:14px var(--pad);transition:background .4s var(--ease),box-shadow .4s,padding .4s}
.nav.scrolled{background:rgba(250,247,240,.86);backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);box-shadow:0 1px 0 var(--rule);padding-top:10px;padding-bottom:10px}
.brand{font-family:var(--sans);font-weight:700;font-size:19px;letter-spacing:.02em;display:flex;align-items:center;gap:9px}
.brand .mk{color:var(--gold)}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);
  padding:8px 13px;border-radius:30px;transition:color .25s,background .25s}
.nav-links a:hover{color:var(--gold-d)} .nav-links a.active{color:#fff;background:var(--gold)}
.nav-cta{border:1px solid var(--rule)!important}
.burger{display:none;width:40px;height:40px;border:1px solid var(--rule);border-radius:50%;background:none;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:16px;height:1.6px;background:var(--ink);position:relative;transition:.3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:16px;height:1.6px;background:var(--ink);transition:.3s}
.burger span::before{top:-5px}.burger span::after{top:5px}
.open .burger span{background:transparent}.open .burger span::before{top:0;transform:rotate(45deg)}.open .burger span::after{top:0;transform:rotate(-45deg)}
@media(max-width:820px){
  .burger{display:inline-flex}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);flex-direction:column;align-items:flex-start;gap:4px;
    background:var(--bg);padding:88px 26px;transform:translateX(100%);transition:transform .45s var(--ease);box-shadow:-20px 0 60px -30px rgba(0,0,0,.5)}
  .open .nav-links{transform:none}
  .nav-links a{font-size:14px;padding:11px 14px;width:100%}
}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:14px 26px;border-radius:40px;border:1px solid var(--gold);color:var(--gold-d);background:none;cursor:pointer;
  transition:transform .3s var(--ease),background .3s,color .3s,box-shadow .3s}
.btn:hover{transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#fff;border-color:var(--gold);box-shadow:0 10px 30px -12px rgba(140,95,16,.6)}
.btn-gold:hover{background:var(--gold-d);box-shadow:0 16px 40px -14px rgba(140,95,16,.7)}
.btn-ghost:hover{background:var(--gold-soft)}
.btn .ar{transition:transform .3s var(--ease)} .btn:hover .ar{transform:translateX(4px)}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;
  background:radial-gradient(120% 90% at 50% -10%,#fffdf8,var(--bg) 55%,var(--bg2))}
#grain{position:absolute;inset:0;z-index:0;opacity:.55;pointer-events:none}
.hero .wrap{position:relative;z-index:2;text-align:center;padding-top:120px;padding-bottom:70px}
.hero h1{font-family:"Fraunces",Georgia,serif;font-size:clamp(56px,15vw,184px);letter-spacing:-.025em;line-height:.92}
.hero h1 .amp{color:var(--gold);font-style:italic;font-weight:400}
.hero .tag{font-family:var(--sans);font-style:italic;font-size:clamp(18px,3vw,30px);color:var(--ink-2);margin-top:6px}
.hero .sub{max-width:640px;margin:26px auto 0;font-size:clamp(16px,2vw,20px);color:var(--ink-2)}
.hero .cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:38px}
.scrollcue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;font-family:var(--mono);font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-3);display:flex;flex-direction:column;align-items:center;gap:8px}
.scrollcue .ln{width:1px;height:34px;background:linear-gradient(var(--gold),transparent);animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(.2);transform-origin:bottom}}

/* ---------- SECTIONS ---------- */
section{position:relative}
.band{padding:clamp(64px,10vw,140px) 0}
.band.dark{background:var(--night);color:#efe6d4}
.band.dark .eyebrow{color:var(--gold-l)} .band.dark h2{color:#fbf5e9} .band.dark .lead{color:#cfc3aa}
.band.tone{background:linear-gradient(180deg,var(--bg),var(--bg2))}
.sec-head{max-width:780px;margin-bottom:clamp(34px,5vw,60px)}
.sec-head h2{font-size:clamp(32px,5.2vw,62px);margin:14px 0}
.divider{height:1px;background:linear-gradient(90deg,var(--rule),transparent)}

/* scales 100 vs 66 */
.scales{display:flex;align-items:center;justify-content:center;gap:clamp(20px,5vw,60px);flex-wrap:wrap;margin:10px 0}
.scl{text-align:center} .scl .num{font-family:var(--mono);font-weight:700;font-size:clamp(58px,12vw,120px);line-height:1}
.scl.king .num{color:var(--gold)} .scl.beast .num{color:var(--crim)}
.scl .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);margin-top:8px}
.scl .lbl b{display:block;font-family:var(--sans);font-size:18px;letter-spacing:0;text-transform:none;color:inherit;color:var(--ink)}
.band.dark .scl .lbl b{color:#fbf5e9}
.vs{font-family:var(--sans);font-style:italic;font-size:clamp(20px,3vw,30px);color:var(--ink-3)}

/* three-up */
.three{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,2vw,26px)}
@media(max-width:780px){.three{grid-template-columns:1fr}}
.feat{padding:30px 28px;border:1px solid var(--line);border-radius:var(--r);background:var(--bg);transition:transform .4s var(--ease),box-shadow .4s,border-color .4s}
.feat:hover{transform:translateY(-4px);border-color:var(--rule);box-shadow:0 24px 60px -36px rgba(22,17,10,.5)}
.feat .ic{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--gold-soft);margin-bottom:16px}
.feat .ic svg{width:24px;height:24px;fill:var(--gold-d)}
.feat h3{font-size:23px;margin-bottom:8px} .feat p{font-size:15.5px;color:var(--ink-2)}
.feat .tag{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-d);display:block;margin-bottom:10px}

/* ---------- FILTER BAR ---------- */
.toolbar{position:sticky;top:62px;z-index:20;display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:space-between;
  padding:14px 0;background:rgba(250,247,240,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--rule)}
.search{flex:1;min-width:180px;max-width:340px;display:flex;align-items:center;gap:8px;border:1px solid var(--rule);border-radius:30px;padding:9px 16px;background:var(--bg)}
.search input{border:none;background:none;outline:none;font-family:var(--sans);font-size:14px;width:100%;color:var(--ink)}
.search svg{width:15px;height:15px;fill:var(--ink-3);flex:none}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding:7px 12px;border-radius:30px;border:1px solid var(--line);color:var(--ink-2);background:var(--bg);cursor:pointer;transition:.25s}
.chip:hover{border-color:var(--rule)} .chip.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.count{font-family:var(--mono);font-size:11px;color:var(--ink-3);letter-spacing:.1em}

/* ---------- CARD GRID ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:clamp(12px,1.6vw,20px);padding:34px 0 60px}
.card{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;background:linear-gradient(160deg,var(--bg2),var(--bg));
  border:1px solid var(--line);aspect-ratio:63/88;display:flex;flex-direction:column;justify-content:space-between;padding:13px;
  transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;will-change:transform}
.card::before{content:"";position:absolute;inset:0;border:1px solid transparent;border-radius:8px;
  background:linear-gradient(160deg,rgba(184,131,30,.5),transparent 40%) border-box;-webkit-mask:linear-gradient(#000 0 0) padding-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.35s}
.card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -30px rgba(22,17,10,.55);border-color:var(--rule)}
.card:hover::before{opacity:1}
.card .top{display:flex;justify-content:space-between;align-items:flex-start}
.card .score{font-family:var(--mono);font-weight:700;font-size:23px;line-height:1;color:var(--gold-d)}
.card .tier{font-family:var(--mono);font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);text-align:right}
.card .glyph{align-self:center;font-family:var(--sans);font-size:40px;color:var(--gold);opacity:.34;line-height:1}
.card .nm{font-family:var(--sans);font-weight:700;font-size:16px;line-height:1.1}
.card .orig{font-size:9.5px;color:var(--ink-3);margin-top:3px;min-height:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card .cat{font-family:var(--mono);font-size:8px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-d);margin-top:6px}
.card.col-0{opacity:.5;filter:grayscale(.5)}
.card .own{position:absolute;top:9px;right:9px;width:18px;height:18px;border-radius:50%;border:1px solid var(--rule);display:flex;align-items:center;justify-content:center;background:var(--bg)}
.card.have .own{background:var(--gold);border-color:var(--gold)} .card.have .own svg{fill:#fff}
.card .own svg{width:10px;height:10px;fill:transparent}

/* ---------- MODAL ---------- */
.modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(20,17,11,.55);backdrop-filter:blur(6px)}
.modal.show{display:flex}
.modal-card{position:relative;max-width:430px;width:100%;background:var(--bg);border:1px solid var(--rule);border-radius:12px;padding:34px;box-shadow:0 40px 90px -30px rgba(0,0,0,.6)}
.modal-card .x{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:none;cursor:pointer;font-size:18px;color:var(--ink-2)}
.modal-card .mscore{font-family:var(--mono);font-weight:700;font-size:46px;color:var(--gold-d);line-height:1}
.modal-card h3{font-size:30px;margin:6px 0 2px} .modal-card .morig{font-size:13px;color:var(--ink-3)}
.modal-card .mcat{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-d);margin:14px 0 6px}
.modal-card .mability{font-family:var(--sans);font-weight:700;font-size:18px;margin-bottom:6px}
.modal-card .mtext{font-size:15px;color:var(--ink-2)}

/* ---------- FOOTER ---------- */
.foot{background:var(--night);color:#cfc3aa;padding:clamp(54px,8vw,90px) 0 36px}
.foot .grid-f{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px}
@media(max-width:780px){.foot .grid-f{grid-template-columns:1fr}}
.foot h4{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-l);margin-bottom:14px}
.foot a{color:#cfc3aa;font-size:14px;display:block;padding:4px 0;transition:color .25s}.foot a:hover{color:#fff}
.foot .big{font-family:var(--sans);font-size:30px;color:#fbf5e9}
.foot .ffound{text-align:center;border-top:1px solid rgba(184,131,30,.3);margin-top:40px;padding-top:24px}
.foot .ffound .fh{font-family:var(--mono);letter-spacing:.28em;font-size:9px;text-transform:uppercase;color:var(--gold-l)}
.foot .ffound .fu{font-family:var(--sans);font-size:18px;color:#fbf5e9;margin-top:4px}
.foot .fc{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:#8a7f68;margin-top:16px}

/* ---------- REVEAL ---------- */
.rv{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){*{animation:none!important;scroll-behavior:auto!important}.rv{opacity:1;transform:none;transition:none}.scrollcue{display:none}}

/* ---------- RULES page bits ---------- */
.rules-hero{padding:140px 0 40px;text-align:center}
.rules-hero h1{font-size:clamp(42px,8vw,92px)}
.cascade{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:780px){.cascade{grid-template-columns:1fr}}
.gstep{border:1px solid var(--line);border-top:3px solid var(--gc,var(--gold));border-radius:var(--r);padding:24px;background:var(--bg)}
.gstep .gn{font-family:var(--sans);font-size:22px;font-weight:700;margin-bottom:6px}
.gstep .gm{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gc,var(--gold-d));font-weight:700;display:block;margin-top:10px}
.piles{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
@media(max-width:780px){.piles{grid-template-columns:repeat(2,1fr)}}
.pilec{border:1px solid var(--line);border-radius:var(--r);padding:18px;background:var(--bg)}
.pilec .pn{font-family:var(--mono);font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-d)}
.pilec .pd{font-size:13.5px;color:var(--ink-2);margin-top:6px}
.numtable{border:1px solid var(--rule);border-radius:var(--r);overflow:hidden;background:var(--bg)}
.numtable .nr{display:flex;justify-content:space-between;padding:11px 18px;border-bottom:1px solid var(--line);font-size:15px}
.numtable .nr:last-child{border:none}.numtable .nv{font-family:var(--mono);font-weight:700;color:var(--gold-d)}

/* ---------- type badges (legend / chips) ---------- */
.bdg{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;flex:none}
.bdg svg{width:15px;height:15px;fill:#fff}
.b-play{background:#8c5f10}.b-build{background:#8c5f10}.b-slay{background:#8c5f10}
.b-panem{background:#8c5f10}.b-coin{background:#8c5f10}.b-str{background:#8c5f10}

/* deck */
.deckbar{display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between;border:1px solid var(--rule);border-radius:10px;padding:18px 22px;background:var(--bg2)}
.progress{flex:1;min-width:220px}
.progress .track{height:10px;border-radius:6px;background:var(--bg3);overflow:hidden;margin-top:8px}
.progress .fill{height:100%;background:linear-gradient(90deg,var(--gold-l),var(--gold));width:0;transition:width .8s var(--ease)}
.bigcount{font-family:var(--mono);font-weight:700;font-size:34px;color:var(--gold-d);line-height:1}
.signin{border:1px solid var(--rule);border-radius:12px;padding:30px;max-width:420px;margin:40px auto;background:var(--bg)}
.signin input{width:100%;padding:12px 14px;border:1px solid var(--rule);border-radius:8px;margin:8px 0;font-family:var(--sans);font-size:15px;background:var(--bg2)}
.field-label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.hidden{display:none!important}
