/* ──────────────────────────────────────────────────────────
   Hallmark — Glass Concierge skin
   Deep midnight base · frosted-glass tablets · champagne brass
   ────────────────────────────────────────────────────────── */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&display=swap");

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
img,svg{display:block;max-width:100%}
a{color:inherit}
button{font:inherit;cursor:pointer}
:focus-visible{outline:1px solid var(--brass); outline-offset:3px}

:root{
  /* surfaces */
  --night:        #0a0d14;
  --night-2:      #0d111b;
  --velvet:       #11172a;
  --inkwell:      #060810;

  /* ink (warm cream) */
  --cream:        #f4ede0;
  --cream-2:      #d6cfbf;
  --cream-3:      #9a937f;
  --cream-4:      #686254;

  /* brass accent */
  --brass:        #c9a96a;
  --brass-soft:   #d8c197;
  --brass-deep:   #8a7240;
  --brass-glow:   rgba(201,169,106,.18);

  /* glass */
  --glass:        rgba(255,255,255,.038);
  --glass-2:      rgba(255,255,255,.058);
  --glass-bd:     rgba(255,255,255,.09);
  --glass-bd-2:   rgba(255,255,255,.14);
  --glass-hi:     rgba(255,255,255,.22);
  --glass-shadow: 0 30px 60px -28px rgba(0,0,0,.65), 0 1px 0 inset var(--glass-hi);

  --hairline:     rgba(244,237,224,.10);
  --hairline-2:   rgba(244,237,224,.06);

  --font-display: "Cormorant Garamond", "Cormorant", "Adobe Garamond", "EB Garamond", Garamond, "Times New Roman", serif;
  --font-body:    "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --container:     1240px;
  --container-pad: clamp(18px, 4vw, 44px);
}

/* ── deep base + ambient light, fixed behind everything ─── */
html{background:var(--inkwell)}
body{
  position:relative;
  background:
    radial-gradient(ellipse 90% 60% at 50% -10%, rgba(201,169,106,.12), transparent 60%),
    radial-gradient(ellipse 80% 70% at 90% 110%, rgba(120,80,200,.08), transparent 55%),
    radial-gradient(ellipse 80% 70% at 5% 95%, rgba(80,140,200,.07), transparent 55%),
    linear-gradient(180deg, var(--night-2), var(--night) 40%, var(--inkwell));
  background-attachment: fixed;
  color:var(--cream);
  font-family:var(--font-body);
  font-size:16px; line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  min-height:100vh;
  overflow-x:hidden;
}
/* fine luminance grain */
body::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:-2;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(244,237,224,.02) 1px, transparent 0);
  background-size: 3px 3px;
  mix-blend-mode: screen;
}
/* large soft ambient blobs to give backdrop-blur something to bite */
body::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:-1;
  background:
    radial-gradient(circle at 18% 22%, rgba(201,169,106,.13), transparent 28%),
    radial-gradient(circle at 82% 70%, rgba(120,80,200,.12), transparent 30%),
    radial-gradient(circle at 60% 30%, rgba(80,140,200,.10), transparent 28%);
  filter: blur(60px);
  opacity:.95;
}
body > *{position:relative; z-index:1}

/* containers */
.container{max-width:var(--container); margin:0 auto; padding:0 var(--container-pad)}
.container-wide{max-width:1340px; margin:0 auto; padding:0 var(--container-pad)}

/* ── type rhythm ────────────────────────────────────────── */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:400;
  letter-spacing:-.005em;
  color:var(--cream); margin:0;
  line-height:1.05;
}
h1{font-size:clamp(44px, 7.6vw, 108px); font-weight:300; letter-spacing:-.015em}
h2{font-size:clamp(30px, 3.6vw, 52px); font-weight:400; letter-spacing:-.01em; text-wrap:balance}
h3{font-size:clamp(22px, 2.2vw, 30px); font-weight:400; letter-spacing:-.005em}
p{margin:0 0 .9em}
em{
  font-style:italic; color:var(--brass);
  font-family:var(--font-display); font-weight:300;
}
strong{font-weight:600; color:var(--cream)}

.mono{font-family:var(--font-mono); font-feature-settings:"tnum" 1, "zero" 1}
.uc{text-transform:uppercase; letter-spacing:.18em; font-size:11px}

/* ── glass primitive ────────────────────────────────────── */
.glass{
  background:var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(28px) saturate(140%);
  -webkit-backdrop-filter: blur(28px) saturate(140%);
  box-shadow: var(--glass-shadow);
  position:relative;
}
.glass::before{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0) 30%);
  pointer-events:none;
}

/* ── header ─────────────────────────────────────────────── */
.site-header{
  position:sticky; top:14px; z-index:60;
  margin: 14px auto 0;
  max-width:1340px;
  padding: 0 var(--container-pad);
}
.header-inner{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:center;
  gap:24px;
  min-height:64px;
  padding: 8px 14px 8px 18px;
  background: rgba(10,13,20,.55);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
  border-radius: 999px;
  box-shadow: 0 20px 60px -30px rgba(0,0,0,.7), 0 1px 0 inset var(--glass-hi);
}
.brand{
  display:inline-flex; align-items:center; gap:12px;
  text-decoration:none; color:var(--cream);
}
.brand-mark{
  display:inline-grid; place-items:center;
  width:36px; height:36px; flex-shrink:0;
  background: linear-gradient(160deg, rgba(255,255,255,.10), rgba(255,255,255,.02));
  border:1px solid var(--glass-bd-2);
  border-radius:10px;
  box-shadow: 0 1px 0 inset var(--glass-hi);
}
.brand-mark svg{width:18px; height:18px}
.brand-word{
  font-family:var(--font-display);
  font-size:24px; font-weight:400; letter-spacing:-.005em;
  line-height:1; color:var(--cream);
}
.brand-word sup{
  font-family:var(--font-mono);
  font-size:9px; color:var(--brass); margin-left:8px;
  letter-spacing:.06em; font-weight:400; top:-1em;
}

.primary-nav{
  display:flex; gap:2px; justify-self:end;
  padding: 2px;
}
.nav-link{
  position:relative;
  display:inline-flex; align-items:baseline; gap:6px;
  text-decoration:none; color:var(--cream-2);
  padding:10px 14px;
  font-size:13.5px; font-weight:400;
  letter-spacing:.005em;
  border-radius:999px;
  transition: color .2s, background .25s;
}
.nav-link .nav-no{
  font-family:var(--font-mono); font-size:9.5px;
  color:var(--cream-4); letter-spacing:.06em;
  transform: translateY(-1px);
  transition: color .2s;
}
.nav-link:hover{color:var(--cream)}
.nav-link:hover .nav-no{color:var(--brass)}
.nav-link.is-active{
  color:var(--cream);
  background: rgba(255,255,255,.06);
  box-shadow: 0 1px 0 inset rgba(255,255,255,.10);
}
.nav-link.is-active .nav-no{color:var(--brass)}

.header-issue{
  display:none;
  font-family:var(--font-mono); font-size:10.5px; color:var(--cream-3);
  letter-spacing:.08em;
}

.burger{
  display:none; appearance:none;
  border:1px solid var(--glass-bd-2);
  background: var(--glass-2);
  width:42px; height:42px; padding:0; position:relative;
  border-radius:999px;
  backdrop-filter: blur(20px);
}
.burger span{
  position:absolute; left:11px; right:11px; height:1.5px;
  background:var(--cream);
  transition: transform .2s, opacity .2s, top .2s;
}
.burger span:nth-child(1){top:15px}
.burger span:nth-child(2){top:20px}
.burger span:nth-child(3){top:25px}
.burger[aria-expanded="true"] span:nth-child(1){top:20px; transform:rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){top:20px; transform:rotate(-45deg)}

/* ── mobile drawer ─────────────────────────────────────── */
.menu-backdrop{
  position:fixed; inset:0; z-index:80;
  background: rgba(6,8,16,.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  opacity:0; pointer-events:none;
  transition: opacity .3s;
}
.menu-backdrop.open{opacity:1; pointer-events:auto}

.mobile-menu{
  position:fixed; top:0; right:0; bottom:0;
  width: min(88vw, 420px);
  z-index:82;
  background: rgba(10,13,20,.88);
  border-left:1px solid var(--glass-bd-2);
  backdrop-filter: blur(32px) saturate(160%);
  -webkit-backdrop-filter: blur(32px) saturate(160%);
  box-shadow: -40px 0 80px -20px rgba(0,0,0,.7);
  transform: translateX(105%);
  transition: transform .42s cubic-bezier(.2,.85,.25,1);
  display:flex; flex-direction:column;
  pointer-events:none;
}
.mobile-menu.open{transform: translateX(0); pointer-events:auto}
.mm-head{
  display:flex; align-items:center; justify-content:space-between;
  padding: 18px 20px 14px;
  border-bottom:1px solid var(--hairline-2);
  flex-shrink:0;
}
.mm-eyebrow{
  margin:0;
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--cream-3);
}
.mm-eyebrow span{color:var(--brass)}
.mm-close{
  appearance:none; border:1px solid var(--glass-bd-2);
  background: var(--glass-2);
  width:36px; height:36px; border-radius:50%;
  color: var(--cream);
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition: border-color .2s, color .2s;
}
.mm-close svg{width:14px; height:14px}
.mm-close:hover{border-color: var(--brass); color: var(--brass)}
.mm-scroll{
  flex:1; overflow:auto;
  padding: 18px 20px 28px;
  display:flex; flex-direction:column; gap:24px;
}
.mm-group{display:flex; flex-direction:column; gap:4px}
.mm-group-label{
  margin:0 0 6px;
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--brass); font-weight:500;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--hairline-2);
}
.mm-link{
  display:grid;
  grid-template-columns: 36px 1fr auto;
  align-items:center; gap:14px;
  padding: 14px 4px 14px 0;
  text-decoration:none; color:var(--cream);
  border-bottom:1px solid var(--hairline-2);
  position:relative;
  transition: padding-left .2s, color .2s;
}
.mm-link:last-child{border-bottom:0}
.mm-link:hover{padding-left:8px}
.mm-no{
  font-family:var(--font-mono); font-size:11px;
  color:var(--cream-4); letter-spacing:.04em;
  align-self:start; padding-top:4px;
}
.mm-text{display:flex; flex-direction:column; gap:2px; min-width:0}
.mm-label{
  font-family:var(--font-display);
  font-size: 24px; font-weight:400;
  letter-spacing:-.01em; line-height:1.1;
  color:var(--cream);
}
.mm-sub{
  font-family:var(--font-body);
  font-size:12px; color:var(--cream-3);
  letter-spacing:.005em; line-height:1.3;
}
.mm-arrow{
  font-family:var(--font-display); font-size:26px;
  font-weight:300; color:var(--cream-4);
  transition: color .2s, transform .2s;
  align-self:center;
}
.mm-link:hover .mm-arrow{color: var(--brass); transform: translateX(3px)}
.mm-link.is-active{padding-left:8px}
.mm-link.is-active .mm-no{color:var(--brass)}
.mm-link.is-active .mm-label{color:var(--brass-soft)}
.mm-link.is-active .mm-arrow{color:var(--brass)}

.mm-foot{
  margin-top: 8px;
  padding: 18px 16px;
  background: rgba(255,255,255,.03);
  border:1px solid var(--glass-bd);
  border-radius: 14px;
}
.mm-foot-k{
  margin:0 0 6px;
  font-family:var(--font-mono); font-size:10px;
  letter-spacing:.16em; text-transform:uppercase;
  color: var(--brass);
}
.mm-foot a{
  font-family:var(--font-display); font-size:22px;
  color: var(--cream); text-decoration:none;
  letter-spacing:-.015em; font-weight:400;
  word-break:break-all;
}
.mm-foot a:hover{color:var(--brass)}

/* ── masthead / homepage hero ───────────────────────────── */
.masthead{
  padding: clamp(20px, 3.5vw, 56px) 0 clamp(16px, 3vw, 48px);
  position:relative;
}

.mast-top{
  display:flex; justify-content:space-between; align-items:baseline;
  flex-wrap:wrap;
  gap: 10px 24px;
  padding: 12px 20px;
  margin-bottom: clamp(28px, 5vw, 64px);
  background: var(--glass);
  border:1px solid var(--glass-bd);
  border-radius: 999px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  font-family:var(--font-mono);
}
.mast-top .mast-issue{
  font-size: 11.5px; color:var(--cream-2);
  letter-spacing:.04em;
}
.mast-top .mast-issue strong{color:var(--cream); font-weight:500}
.mast-tags{
  display:flex; gap:12px 22px; flex-wrap:wrap;
  font-size: 10.5px; color:var(--cream-3);
  letter-spacing:.12em; text-transform:uppercase;
}
.mast-tags span{display:inline-flex; align-items:center; gap:8px}
.mast-tags .dot{
  width:6px; height:6px; background:var(--brass); border-radius:50%;
  box-shadow:0 0 0 4px var(--brass-glow);
}

.mast-headline{
  font-family:var(--font-display);
  font-size: clamp(32px, 6vw, 88px);
  font-weight:300;
  line-height: .98;
  letter-spacing:-.02em;
  margin:0;
  color:var(--cream);
  text-wrap:balance;
}
.mast-headline .line{
  display:block; overflow:hidden;
  padding: 0 0 .06em;
}
.mast-headline .line > span{
  display:inline-block;
  transform: translateY(110%);
  animation: lineUp 1.1s cubic-bezier(.2,.85,.25,1) forwards;
}
.mast-headline .line:nth-child(1) > span{animation-delay:.05s}
.mast-headline .line:nth-child(2) > span{animation-delay:.22s}
.mast-headline .line:nth-child(3) > span{animation-delay:.38s}
.mast-headline em{
  color:var(--brass);
  font-style:italic;
  font-weight:400;
  font-family:var(--font-display);
}

.mast-body{
  display:grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
  gap: 48px clamp(32px, 4vw, 56px);
  align-items: stretch;
  margin-top: clamp(36px, 5vw, 64px);
}
@media (max-width:880px){
  .mast-body{grid-template-columns:1fr; align-items: start}
  .mast-spec{height:auto; justify-content:flex-start}
  .mast-spec dl{align-content: start}
  .mast-lede{font-size: clamp(16px, 4.2vw, 18px); line-height: 1.6}
}

.mast-lede{
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.7;
  color:var(--cream-2);
  max-width: 50ch;
  font-weight:400;
}
.mast-lede::first-letter{
  font-family:var(--font-display);
  font-size: 3.6em; line-height:.8;
  float:left; padding: 8px 14px 0 0;
  color:var(--brass); font-weight:300; font-style:italic;
}

.mast-spec{
  padding: 22px 26px;
  background: var(--glass-2);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(28px) saturate(140%);
  -webkit-backdrop-filter: blur(28px) saturate(140%);
  border-radius: 18px;
  box-shadow: var(--glass-shadow);
  display:flex; flex-direction:column; gap:14px;
  justify-content: space-between;
  height:100%;
  position:relative;
}
.mast-spec::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.06), transparent 30%);
  border-radius: inherit;
}
.mast-spec h4{
  font-family:var(--font-mono); font-size:10.5px; color:var(--brass);
  letter-spacing:.16em; text-transform:uppercase; font-weight:500;
}
.mast-spec dl{margin:0; display:grid; grid-template-columns:1fr auto; gap:9px 18px; align-content: space-between; flex:1 1 auto}
.mast-spec dt{font-size:13.5px; color:var(--cream-2); font-weight:400}
.mast-spec dd{
  margin:0; font-family:var(--font-mono); font-size:12.5px;
  color:var(--cream); text-align:right;
}
.mast-spec dd .ok{color:var(--brass)}

/* ── chapter heads ──────────────────────────────────────── */
.chap-head{
  display:grid;
  grid-template-columns: auto 1fr auto;
  align-items:end; gap:28px;
  padding-bottom:22px;
  border-bottom:1px solid var(--hairline);
  margin-bottom: clamp(32px, 4vw, 52px);
}
.chap-tag{
  font-family:var(--font-mono); font-size:10.5px; color:var(--cream-3);
  letter-spacing:.16em; text-transform:uppercase;
}
.chap-tag strong{color:var(--brass); font-weight:500; letter-spacing:.1em}
.chap-title{
  font-family:var(--font-display);
  font-size: clamp(32px, 4.2vw, 60px);
  font-weight:300; line-height: 1;
  letter-spacing:-.015em;
  align-self:end;
}
.chap-note{
  font-family:var(--font-mono); font-size:11.5px; color:var(--cream-3);
  text-align:right; max-width:32ch; line-height:1.6;
  letter-spacing:.01em;
}
@media (max-width:760px){
  .chap-head{grid-template-columns:1fr; gap:14px; align-items:stretch; padding-bottom:18px; margin-bottom: 24px}
  .chap-tag, .chap-title, .chap-note{width:100%; max-width:none}
  .chap-note{text-align:left}
}

/* ── ledger (casino list) — glass tablets ───────────────── */
.ledger-section{padding: clamp(8px, 1.2vw, 20px) 0 clamp(36px, 5vw, 80px)}

.ledger{
  list-style:none; margin:0; padding:0;
  counter-reset: rank;
  display:flex; flex-direction:column; gap:14px;
}

.ledger-row{
  counter-increment: rank;
  position:relative;
  border-radius: 18px;
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(28px) saturate(140%);
  -webkit-backdrop-filter: blur(28px) saturate(140%);
  box-shadow: var(--glass-shadow);
  overflow:hidden;
  transition: transform .35s cubic-bezier(.16,1,.3,1), border-color .25s, background .25s, box-shadow .35s;
}
.ledger-row::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.05), transparent 22%);
  border-radius: inherit;
}
.ledger-row::after{
  content:""; position:absolute; left:0; top:14%; bottom:14%; width:2px;
  background: var(--brass);
  opacity:0;
  transition: opacity .35s, width .35s;
  box-shadow: 0 0 16px var(--brass-glow);
}
.ledger-row:hover{
  transform: translateY(-2px);
  border-color: var(--glass-bd-2);
  background: var(--glass-2);
  box-shadow: 0 36px 80px -30px rgba(0,0,0,.75), 0 1px 0 inset var(--glass-hi);
}
.ledger-row:hover::after{opacity:1; width:3px}

.ledger-main{
  display:grid;
  grid-template-columns: 110px minmax(280px,1fr) 130px 130px 180px;
  align-items:center;
  gap:26px;
  padding: 26px 28px;
  position:relative;
}

.lg-rank{
  display:flex; flex-direction:column; gap:4px;
}
.lg-rank .n{
  font-family:var(--font-display);
  font-size: 64px; font-weight:300;
  line-height: .85;
  color:var(--brass);
  letter-spacing:-.04em;
  font-feature-settings:"lnum" 1, "tnum" 1;
}
.lg-rank .n::before{content:counter(rank, decimal-leading-zero)}
.lg-rank .lbl{
  color:var(--cream-3); font-family:var(--font-mono);
  font-size:9.5px; letter-spacing:.16em; text-transform:uppercase;
}

/* tags column collapses on desktop into a metadata strip under name */
.lg-tags{display:none}

.lg-id{display:flex; flex-direction:row; align-items:center; gap:20px; min-width:0}
.lg-id-text{display:flex; flex-direction:column; gap:8px; min-width:0; flex:1 1 auto}

/* logo "plate" — a hallmark tile housing each operator's mark */
.lg-logo{
  flex:0 0 auto;
  width: 88px; height: 88px;
  border-radius: 14px;
  background: var(--cream, #f4ede0);
  border:1px solid var(--glass-bd-2, rgba(244,237,224,.18));
  display:grid; place-items:center;
  padding: 10px;
  overflow:hidden;
  position:relative;
  box-shadow: 0 1px 0 inset rgba(255,255,255,.5), 0 8px 18px -10px rgba(0,0,0,.55);
}
.lg-logo::after{
  content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.35), transparent 40%);
}
.lg-logo img{
  max-width:100%; max-height:100%;
  width:auto; height:auto;
  object-fit:contain;
  display:block;
}
.lg-logo--dark{
  background: linear-gradient(180deg, #1a1f2e, #0d111b);
  border-color: rgba(244,237,224,.12);
  box-shadow: 0 1px 0 inset rgba(255,255,255,.06), 0 8px 18px -10px rgba(0,0,0,.7);
}
.lg-logo--dark::after{
  background: linear-gradient(180deg, rgba(255,255,255,.08), transparent 45%);
}

.lg-logo--fallback{
  background: linear-gradient(180deg, #1a1611, #100d09);
  color: var(--brass);
  font-family: var(--font-display);
  font-size: 14px; letter-spacing:-.01em;
  text-align:center; padding: 8px;
  border-color: var(--brass);
}
.lg-logo--fallback span{display:block; line-height:1.05}
.lg-name{
  font-family:var(--font-display);
  font-size:clamp(26px, 2.4vw, 34px);
  line-height:1; font-weight:400;
  letter-spacing:-.015em; color:var(--cream);
  margin:0;
}
.lg-desc{
  font-size:14px; line-height:1.55; color:var(--cream-2);
  margin:0; max-width:60ch;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical;
  overflow:hidden;
  font-weight:400;
}

.lg-stars{
  display:flex; flex-direction:column; gap:6px;
  align-items:flex-start;
}
.lg-stars .row{display:inline-flex; gap:4px; color:var(--brass)}
.lg-stars .row .s{width:13px; height:13px; display:inline-block}
.lg-stars .row .s.empty{color:rgba(244,237,224,.18)}
.lg-stars .lbl{
  font-family:var(--font-mono); font-size:10px; color:var(--cream-3);
  letter-spacing:.1em; text-transform:uppercase;
}

.lg-score{
  display:flex; flex-direction:column; align-items:flex-end; gap:6px;
}
.lg-score .v{
  font-family:var(--font-display);
  font-size: 56px; line-height:.9; color:var(--cream);
  font-weight:300; letter-spacing:-.025em;
  font-feature-settings:"tnum" 1, "lnum" 1;
}
.lg-score .v small{font-size:18px; color:var(--cream-3); font-weight:300; margin-left:2px; letter-spacing:0}
.lg-score .lbl{
  font-family:var(--font-mono); font-size:10px; color:var(--brass);
  letter-spacing:.14em; text-transform:uppercase;
}

.lg-cta{justify-self:end}
.btn-visit{
  display:inline-flex; align-items:center; gap:10px;
  background: var(--glass-2);
  color: var(--cream);
  border:1px solid var(--glass-bd-2);
  padding:14px 22px;
  border-radius:999px;
  font-family:var(--font-mono); font-size:11.5px; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase;
  text-decoration:none;
  position:relative; overflow:hidden;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: border-color .25s, color .2s, transform .2s, box-shadow .3s;
}
.btn-visit::before{
  content:""; position:absolute; inset:0;
  background: radial-gradient(ellipse 80% 100% at 50% 120%, var(--brass-glow), transparent 70%);
  opacity:0; transition: opacity .3s;
}
.btn-visit span, .btn-visit svg{position:relative; z-index:1}
.btn-visit:hover{
  border-color: var(--brass);
  color: var(--brass-soft);
  transform: translateY(-1px);
  box-shadow: 0 14px 30px -14px rgba(201,169,106,.45);
}
.btn-visit:hover::before{opacity:1}
.btn-visit svg{width:13px; height:13px}

.lg-disclaim{
  padding: 14px 28px 18px;
  border-top:1px solid var(--hairline-2);
  font-family:var(--font-mono); font-size:10.5px;
  color:var(--cream-3); line-height:1.6;
  letter-spacing:.01em;
}

/* mobile ledger row */
@media (max-width: 1100px){
  .ledger-main{
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "rank   score"
      "name   name"
      "stars  stars"
      "cta    cta";
    gap:16px; padding:22px 22px;
  }
  .lg-rank{grid-area:rank; flex-direction:row; align-items:baseline; gap:12px}
  .lg-rank .n{font-size: 48px}
  .lg-rank .lbl{display:none}
  .lg-id{grid-area:name; gap:14px; align-items:flex-start}
  .lg-id-text{gap:6px}
  .lg-logo{width:64px; height:64px; border-radius:11px; padding:7px}
  .lg-name{font-size: 24px}
  .lg-desc{-webkit-line-clamp:4}
  .lg-tags{display:none}
  .lg-stars{grid-area:stars; flex-direction:row; gap:12px; align-items:center}
  .lg-score{grid-area:score; flex-direction:row; align-items:baseline; justify-self:end; gap:8px}
  .lg-score .v{font-size:44px}
  .lg-cta{grid-area:cta; justify-self:stretch}
  .btn-visit{width:100%; justify-content:center; padding:16px}
  .lg-disclaim{padding:14px 22px 18px}
}

/* ── editorial body (long-form) — on glass plate ────────── */
.editorial{
  padding: clamp(56px, 8vw, 112px) 0;
  position:relative;
}
.editorial-grid{
  display:grid;
  grid-template-columns: 250px minmax(0,1fr);
  gap: clamp(28px, 5vw, 96px);
}
.toc{
  position:sticky; top:96px; align-self:start;
  padding: 22px 22px;
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-radius: 16px;
  box-shadow: var(--glass-shadow);
}
.toc-label{
  font-family:var(--font-mono); font-size:10.5px;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--brass); margin:0 0 14px;
  padding-bottom:12px; border-bottom:1px solid var(--hairline);
  font-weight:500;
}
.toc ol{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column;
  counter-reset: toc;
}
.toc ol li{counter-increment: toc; position:relative}
.toc ol li::before{
  content:counter(toc, decimal-leading-zero);
  position:absolute; left:0; top:14px;
  font-family:var(--font-mono); font-size:9.5px;
  color:var(--cream-4); letter-spacing:.08em;
}
.toc a{
  text-decoration:none; color:var(--cream-2);
  display:block; padding:11px 0 11px 32px;
  font-size:13.5px; line-height:1.35;
  border-bottom:1px solid var(--hairline-2);
  transition: color .2s, padding-left .2s;
}
.toc a:hover{color:var(--brass); padding-left:36px}
.toc ol li:last-child a{border-bottom:0}

.editorial-body article{
  padding: 36px 38px;
  margin-bottom: 18px;
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border-radius: 18px;
  box-shadow: var(--glass-shadow);
  display:grid;
  grid-template-columns: 80px 1fr;
  gap: 24px;
  position:relative;
}
.editorial-body article::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.04), transparent 25%);
  border-radius: inherit;
}
.editorial-body article:last-child{margin-bottom:0}
.editorial-body article > .art-no{
  font-family:var(--font-mono); font-size:10.5px; color:var(--cream-3);
  letter-spacing:.14em; text-transform:uppercase;
  padding-top:10px;
}
.editorial-body article > .art-no strong{
  color:var(--brass); font-weight:500;
  display:block; font-family:var(--font-display); font-size:32px;
  font-weight:300; margin-bottom:8px; letter-spacing:-.02em;
  text-transform:none;
}
.editorial-body article > .art-body{min-width:0}
.editorial-body h3{
  margin:0 0 16px;
  font-size:clamp(26px, 2.6vw, 34px);
  font-weight:400; letter-spacing:-.01em;
}
.editorial-body p{
  font-size:16px; line-height:1.72; color:var(--cream-2);
  max-width:64ch; font-weight:400;
}

.criteria{margin:8px 0 0; display:grid; gap:0}
.criteria > div{
  display:grid; grid-template-columns: 220px 1fr; gap:24px;
  padding:18px 0; border-top:1px solid var(--hairline-2);
}
.criteria > div:first-child{border-top:1px solid var(--hairline)}
.criteria dt{
  font-family:var(--font-display); font-size:20px; color:var(--cream);
  margin:0; font-weight:400; letter-spacing:-.005em;
}
.criteria dd{
  margin:0; color:var(--cream-2); font-size:15px; line-height:1.6;
}

@media (max-width: 980px){
  .editorial-grid{grid-template-columns:1fr}
  .toc{position:static; margin-bottom:18px}
  .toc ol{flex-direction:row; flex-wrap:wrap}
  .toc ol li{flex:1 1 180px}
  .editorial-body article{grid-template-columns:1fr; gap:10px; padding:26px 24px}
  .editorial-body article > .art-no{padding-top:0; display:flex; gap:14px; align-items:baseline}
  .editorial-body article > .art-no strong{font-size:22px; margin:0}
  .criteria > div{grid-template-columns:1fr; gap:6px}
}

/* ── FAQ ────────────────────────────────────────────────── */
.faq{padding: clamp(56px, 7vw, 112px) 0}
.faq-list{
  display:flex; flex-direction:column; gap:10px;
}
.faq-list details{
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border-radius: 16px;
  overflow:hidden;
  box-shadow: var(--glass-shadow);
  transition: background .25s, border-color .25s;
  position:relative;
}
.faq-list details::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.04), transparent 30%);
  border-radius: inherit;
}
.faq-list details[open]{background: var(--glass-2); border-color:var(--glass-bd-2)}
.faq-list summary{
  list-style:none; cursor:pointer;
  display:grid; grid-template-columns:auto 1fr auto; align-items:start;
  gap:24px;
  padding: 26px 30px;
  font-family:var(--font-display);
  font-size:clamp(20px, 2.1vw, 28px);
  color:var(--cream);
  line-height:1.2; letter-spacing:-.015em; font-weight:400;
  transition: color .2s;
  position:relative;
}
.faq-list summary:hover{color:var(--brass-soft)}
.faq-list summary::-webkit-details-marker{display:none}
.faq-q-no{
  font-family:var(--font-mono); font-size:10.5px;
  color:var(--brass); letter-spacing:.14em;
  padding-top:14px; min-width:40px; font-weight:500;
}
.chev{
  width:32px; height:32px; flex-shrink:0; position:relative;
  border:1px solid var(--glass-bd-2); border-radius:50%;
  background: var(--glass);
  transition: background .25s, border-color .25s, transform .35s cubic-bezier(.16,1,.3,1);
  margin-top:4px;
}
.chev::before, .chev::after{
  content:""; position:absolute; left:50%; top:50%; width:11px; height:1.2px;
  background:var(--cream); transform-origin:center;
}
.chev::before{transform: translate(-50%,-50%)}
.chev::after{transform: translate(-50%,-50%) rotate(90deg); transition: transform .3s}
details[open] .chev{background: var(--brass); border-color: var(--brass); transform: rotate(180deg)}
details[open] .chev::before, details[open] .chev::after{background: var(--night)}
details[open] .chev::after{transform: translate(-50%,-50%) rotate(0)}
.faq-body{
  padding: 0 30px 28px 94px; max-width:74ch;
}
.faq-body p{margin:0; color:var(--cream-2); font-size:15.5px; line-height:1.7}

@media (max-width:600px){
  .faq-list summary{padding:22px 22px; gap:14px; font-size:19px}
  .faq-body{padding:0 22px 24px 22px}
  .faq-q-no{padding-top:8px; min-width:32px; font-size:10px}
}

/* ── contact (home) ─────────────────────────────────────── */
.contact{
  padding: clamp(56px, 7vw, 96px) 0;
  position:relative;
}
.contact-grid{
  display:grid; grid-template-columns: minmax(0,1fr) minmax(0,1.05fr);
  gap: clamp(28px, 5vw, 80px);
  align-items:start;
}
.contact-text h2{margin:14px 0 18px}
.contact-text p{font-size:16.5px; color:var(--cream-2); max-width:46ch; line-height:1.6}
.contact-mail{
  margin-top:32px;
  display:flex; flex-direction:column; gap:8px;
  padding:24px 28px;
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-radius: 16px;
  box-shadow: var(--glass-shadow);
}
.contact-mail .k{
  font-family:var(--font-mono); font-size:10.5px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--brass);
}
.contact-mail a{
  font-family:var(--font-display);
  font-size:clamp(22px, 2.4vw, 32px); color:var(--cream); text-decoration:none;
  letter-spacing:-.015em; font-weight:400;
}
.contact-mail a:hover{color:var(--brass)}

.contact-form{
  display:flex; flex-direction:column; gap:18px;
  background: var(--glass);
  padding: clamp(28px, 3.5vw, 40px);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(28px) saturate(140%);
  -webkit-backdrop-filter: blur(28px) saturate(140%);
  border-radius: 18px;
  box-shadow: var(--glass-shadow);
  position:relative;
}
.contact-form::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.04), transparent 25%);
  border-radius:inherit;
}
.contact-form > *{position:relative}
.contact-form .form-row{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.contact-form label{
  display:flex; flex-direction:column; gap:8px;
  font-family:var(--font-mono); font-size:10px;
  color:var(--cream-3);
  letter-spacing:.16em; text-transform:uppercase;
}
.contact-form input, .contact-form textarea{
  font:inherit; font-family:var(--font-body); font-size:15px;
  text-transform:none; letter-spacing:0;
  padding:14px 16px;
  background: rgba(255,255,255,.03);
  color:var(--cream);
  border:1px solid var(--glass-bd);
  border-radius:10px;
  width:100%;
  transition: border-color .2s, background .2s;
}
.contact-form input:focus, .contact-form textarea:focus{
  outline:none; border-color:var(--brass);
  background: rgba(255,255,255,.06);
}
.contact-form textarea{resize:vertical; min-height:130px}
.contact-form .form-foot{display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-top:8px}
.contact-form button{
  background: var(--brass);
  color: var(--night);
  border:0;
  padding:14px 26px;
  border-radius: 999px;
  font-family:var(--font-mono); font-size:11.5px; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase;
  transition: background .2s, transform .2s, box-shadow .3s;
}
.contact-form button:hover{
  background: var(--brass-soft);
  transform: translateY(-1px);
  box-shadow: 0 14px 30px -10px var(--brass-glow);
}
.thanks{
  font-family:var(--font-mono); font-size:11px;
  color:var(--brass); margin:0; letter-spacing:.06em;
}

@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr}
  .contact-form .form-row{grid-template-columns:1fr}
}

/* ── footer ─────────────────────────────────────────────── */
.site-footer{
  margin-top: clamp(56px, 6vw, 96px);
  padding: clamp(48px, 6vw, 80px) var(--container-pad) clamp(28px, 4vw, 48px);
  background: rgba(6,8,16,.55);
  border-top:1px solid var(--hairline);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.site-footer .container-wide{padding:0}
.footer-top{
  display:grid; grid-template-columns: 1fr 1fr; gap:32px;
  padding-bottom:40px; border-bottom:1px solid var(--hairline);
  align-items:start;
}
.brand-footer{align-self:start}
.brand-footer .brand-mark{width:42px; height:42px; border-radius:12px}
.brand-footer .brand-mark svg{width:22px; height:22px}
.brand-footer .brand-word{font-size:28px}
.footer-tag{
  font-family:var(--font-display); font-style:italic;
  font-size:18px; color:var(--cream-2);
  margin-top:18px; max-width:36ch; line-height:1.5;
  font-weight:300;
}
.footer-nav-wrap{
  display:grid; grid-template-columns:1fr 1fr; gap:28px;
}
.footer-nav-wrap h5{
  font-family:var(--font-mono); font-size:10px; color:var(--brass);
  letter-spacing:.18em; text-transform:uppercase;
  margin:0 0 16px; font-weight:500;
}
.footer-nav{display:flex; flex-direction:column; gap:6px}
.footer-nav a{
  text-decoration:none; color:var(--cream-2);
  padding:5px 0; font-size:14px;
  transition: color .2s;
  align-self:start;
}
.footer-nav a:hover{color:var(--brass)}

.footer-disclosure{padding:36px 0; border-bottom:1px solid var(--hairline-2)}
.footer-disclosure h3{
  font-size:14px; margin:0 0 16px;
  font-family:var(--font-mono); letter-spacing:.16em;
  text-transform:uppercase; font-weight:500; color:var(--brass);
}
.footer-disclosure p{
  font-size:13.5px; color:var(--cream-3);
  line-height:1.7; max-width:88ch;
}
.footer-disclosure p + p{margin-top:12px}
.footer-disclosure strong{color:var(--cream)}

.footer-partners{
  display:flex; flex-wrap:wrap; gap:14px; align-items:center;
  padding: 32px 0;
  border-bottom:1px solid var(--hairline-2);
}
.footer-partner-logo{
  display:flex; align-items:center; justify-content:center;
  height:60px; min-width:96px;
  padding: 10px 18px;
  background:#ffffff;
  border:1px solid var(--glass-bd);
  border-radius:10px;
}
.footer-partner-logo img{max-height:38px; width:auto; display:block}
.footer-partner-logo a{display:inline-flex; align-items:center; height:100%}
.footer-partner-logo:has(img[src*="18plus"]){background:transparent; border:0; padding:0; min-width:60px}
.footer-partner-logo:has(img[src*="18plus"]) img{max-height:60px}

.footer-base{
  display:flex; justify-content:space-between; gap:16px;
  flex-wrap:wrap; padding-top:28px;
  font-family:var(--font-mono); font-size:11px; color:var(--cream-3);
  letter-spacing:.06em;
}
.footer-base p{margin:0}
.footer-base strong{color:var(--cream); font-weight:500}

@media (max-width:760px){
  .footer-top{grid-template-columns:1fr; gap:28px}
  .footer-nav-wrap{grid-template-columns:1fr 1fr; gap:18px}
  .footer-base{flex-direction:column; gap:6px}
}
@media (max-width:980px){
  .primary-nav{display:none}
  .burger{display:inline-flex; align-items:center; justify-content:center}
}

/* ── mobile hero compression (≤ 720px) ────────────────────── */
@media (max-width:720px){
  .masthead{padding: 18px 0 8px}
  .mast-top{
    padding: 9px 14px;
    margin-bottom: 18px;
    gap: 4px 14px;
  }
  .mast-top .mast-issue{font-size:10.5px; flex:1 1 100%}
  .mast-tags{font-size:9.5px; gap:6px 14px; flex:1 1 100%}
  .mast-headline{
    font-size: clamp(28px, 7vw, 44px);
    line-height:1.02;
    letter-spacing:-.015em;
  }
  .mast-body{
    margin-top: 20px !important;
    gap: 18px;
  }
  .mast-lede{font-size:15.5px; line-height:1.55}
  .mast-lede::first-letter{font-size:2.4em; padding:4px 10px 0 0}
  .mast-spec{padding: 16px 18px; gap:10px; border-radius:14px}
  .mast-spec h4{font-size:9.5px; letter-spacing:.14em}
  .mast-spec dl{gap:8px 14px}
  .mast-spec dt{font-size:12.5px}
  .mast-spec dd{font-size:11.5px}

  /* tighten inner-page hero too */
  .page-hero{padding: 18px 0 24px}
  .page-hero-top{
    margin-bottom: 22px; padding: 9px 14px;
    flex-wrap:wrap; gap: 4px 14px;
  }
  .page-hero-top > *{flex:1 1 100%}
  .page-hero h1{
    font-size: clamp(34px, 9.5vw, 56px);
    line-height: 1.02; margin: 0 0 16px;
  }
  .page-hero .lede{font-size: 15.5px; line-height: 1.55; margin-bottom: 18px}
  .page-hero .meta-strip{margin-top: 18px}
  .page-hero .meta-strip > div{padding: 14px 16px; font-size:11.5px}
  .category-points{padding: 28px 0}
}

@media (max-width:480px){
  .site-header{top:8px; margin-top:8px}
  .header-inner{min-height:56px; grid-template-columns:auto auto; padding:6px 10px 6px 14px}
  .brand-word{font-size:20px}
  .brand-word sup{display:none}
  /* drop the noisier marketing tags on very small phones */
  .mast-tags span:not(:first-child){display:none}
}

body.menu-open{overflow:hidden}

/* ────────────────────────────────────────────────────────
   INNER PAGES — page hero, info, category
   ──────────────────────────────────────────────────────── */
.page-hero{
  padding: clamp(48px, 7vw, 96px) 0 clamp(36px, 5vw, 64px);
  position:relative;
}
.page-hero-top{
  display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap;
  align-items:center;
  padding: 12px 22px;
  background: var(--glass);
  border:1px solid var(--glass-bd);
  border-radius:999px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  margin-bottom: clamp(32px, 5vw, 56px);
  font-family:var(--font-mono); font-size:11px; color:var(--cream-3);
  letter-spacing:.06em;
}
.page-hero-top .crumbs a{color:var(--cream-2); text-decoration:none}
.page-hero-top .crumbs a:hover{color:var(--brass)}
.page-hero-top .crumbs span{margin:0 10px; color:var(--cream-4)}
.page-hero-top .crumbs strong{color:var(--cream); font-weight:500}
.page-hero-top .meta-r strong{color:var(--brass); font-weight:500; margin-right:8px}

.page-hero h1{
  font-family:var(--font-display);
  font-size:clamp(48px, 8vw, 124px); font-weight:300;
  line-height:.96; letter-spacing:-.02em;
  margin:0 0 28px; max-width:18ch; text-wrap:balance;
}
.page-hero h1 em{
  color:var(--brass); font-style:italic; font-weight:400;
  font-family:var(--font-display);
}
.page-hero .lede{
  font-size:clamp(17px, 1.4vw, 20px); color:var(--cream-2);
  max-width:62ch; line-height:1.6; margin-bottom:28px;
}
.page-hero .meta-strip{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:0;
  background: var(--glass);
  border:1px solid var(--glass-bd);
  border-radius: 16px;
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  box-shadow: var(--glass-shadow);
  margin-top:36px;
  overflow:hidden;
}
.page-hero .meta-strip > div{
  padding:22px 24px;
  border-right:1px solid var(--hairline-2);
  font-family:var(--font-mono); font-size:12px;
  color:var(--cream); letter-spacing:.02em;
}
.page-hero .meta-strip > div:last-child{border-right:0}
.page-hero .meta-strip .k{
  display:block; color:var(--brass);
  font-size:10px; letter-spacing:.16em; text-transform:uppercase;
  margin-bottom:8px; font-weight:500;
}

@media (max-width:760px){
  .page-hero .meta-strip{grid-template-columns:1fr}
  .page-hero .meta-strip > div{border-right:0; border-bottom:1px solid var(--hairline-2)}
  .page-hero .meta-strip > div:last-child{border-bottom:0}
}

/* ── info page (legal/long-form) — TOC + glass prose plate ── */
.info-page{padding: clamp(36px, 5vw, 72px) 0}
.info-grid{
  display:grid;
  grid-template-columns: 250px minmax(0,1fr);
  gap: clamp(28px, 5vw, 96px);
}
.info-prose{
  padding: clamp(32px, 4vw, 56px);
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(28px) saturate(140%);
  -webkit-backdrop-filter: blur(28px) saturate(140%);
  border-radius: 22px;
  box-shadow: var(--glass-shadow);
  position:relative;
}
.info-prose::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.04), transparent 30%);
  border-radius:inherit;
}
.info-prose > *{position:relative}
.info-prose h2{
  font-family:var(--font-display);
  font-size:clamp(28px, 3vw, 40px);
  font-weight:300;
  margin: clamp(36px, 4vw, 56px) 0 18px;
  scroll-margin-top: 110px;
  display:flex; align-items:baseline; gap:16px;
  letter-spacing:-.015em;
}
.info-prose h2::before{
  content:"§"; font-family:var(--font-display); font-size:22px;
  color:var(--brass); font-weight:300; font-style:italic;
}
.info-prose h2:first-child{margin-top:0}
.info-prose h3{font-size:20px; margin: 24px 0 10px; font-weight:400}
.info-prose p, .info-prose li{
  font-size:16px; line-height:1.75; color:var(--cream-2); max-width:70ch;
  font-weight:400;
}
.info-prose ul, .info-prose ol{padding-left:1.4em; margin: 0 0 1em}
.info-prose li{margin-bottom:.5em}
.info-prose li::marker{color:var(--brass)}
.info-prose strong{color:var(--cream)}
.info-prose a{
  color:var(--brass); text-decoration:none;
  border-bottom:1px solid var(--brass-glow);
  transition: border-color .2s, color .2s;
}
.info-prose a:hover{color:var(--brass-soft); border-bottom-color: var(--brass)}
.info-prose hr{border:0; border-top:1px solid var(--hairline); margin:40px 0}
.info-prose .callout{
  background: rgba(201,169,106,.06);
  border:1px solid rgba(201,169,106,.22);
  border-radius:14px;
  padding:22px 26px; margin: 24px 0;
  position:relative;
}
.info-prose .callout::before{
  content:""; position:absolute; top:-1px; left:18px; width:42px; height:2px;
  background: var(--brass);
}
.info-prose .callout p{margin:0; color:var(--cream-2); font-size:14.5px}
.info-prose code{
  font-family:var(--font-mono); font-size:.88em;
  background: rgba(255,255,255,.05);
  border:1px solid var(--glass-bd);
  padding:2px 8px; color:var(--brass-soft);
  border-radius:6px;
}

@media (max-width:980px){
  .info-grid{grid-template-columns:1fr}
  .info-prose{padding: 28px 24px}
}

/* ── category points (3-up glass tile grid) ─────────────── */
.category-points{
  padding: clamp(36px, 5vw, 72px) 0;
}
.points-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap:14px;
}
.point{
  padding:30px 28px;
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(24px) saturate(140%);
  -webkit-backdrop-filter: blur(24px) saturate(140%);
  border-radius: 18px;
  box-shadow: var(--glass-shadow);
  display:flex; flex-direction:column; gap:16px;
  position:relative;
  transition: transform .3s, border-color .25s, background .25s;
}
.point::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.05), transparent 30%);
  border-radius:inherit;
}
.point:hover{
  transform: translateY(-3px);
  border-color: var(--glass-bd-2);
  background: var(--glass-2);
}
.point-k{
  font-family:var(--font-mono); font-size:10.5px; color:var(--brass);
  letter-spacing:.16em; text-transform:uppercase; margin:0;
  display:flex; align-items:center; gap:10px;
  font-weight:500;
}
.point-k::before{
  content:""; width:24px; height:1px; background:var(--brass);
  display:inline-block; opacity:.6;
}
.point h3{font-size:24px; line-height:1.2; margin:0; letter-spacing:-.015em; font-weight:400}
.point p{margin:0; font-size:14.5px; color:var(--cream-2); line-height:1.65}

@media (max-width:880px){
  .points-grid{grid-template-columns:1fr}
}

/* ── contact page email card ────────────────────────────── */
.email-card{
  display:grid; grid-template-columns:1fr auto; align-items:center; gap:24px;
  padding: clamp(26px, 3vw, 38px);
  background: var(--glass);
  border:1px solid var(--glass-bd);
  backdrop-filter: blur(28px);
  -webkit-backdrop-filter: blur(28px);
  border-radius: 18px;
  box-shadow: var(--glass-shadow);
  margin-bottom:36px;
}
.email-card .k{
  font-family:var(--font-mono); font-size:10.5px; color:var(--brass);
  letter-spacing:.16em; text-transform:uppercase; margin:0 0 8px; font-weight:500;
}
.email-card a{
  font-family:var(--font-display);
  font-size:clamp(24px, 2.6vw, 34px); color:var(--cream);
  text-decoration:none; word-break:break-all;
  letter-spacing:-.015em; font-weight:400;
}
.email-card a:hover{color:var(--brass)}
.email-card .copy-btn{
  appearance:none;
  border:1px solid var(--glass-bd-2);
  background: var(--glass-2);
  color:var(--cream);
  padding:12px 18px;
  border-radius:999px;
  font-family:var(--font-mono); font-size:11px;
  letter-spacing:.12em; text-transform:uppercase;
  cursor:pointer; white-space:nowrap;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  transition: border-color .2s, color .2s, background .2s;
}
.email-card .copy-btn:hover{
  border-color: var(--brass); color:var(--brass);
  background: rgba(201,169,106,.08);
}
@media (max-width:640px){
  .email-card{grid-template-columns:1fr}
  .email-card .copy-btn{justify-self:start}
}

/* ── motion ─────────────────────────────────────────────── */
@keyframes lineUp{
  from{transform:translateY(110%); filter: blur(8px)}
  to  {transform:translateY(0); filter: blur(0)}
}
@keyframes fadeRise{
  from{opacity:0; transform: translateY(20px); filter: blur(6px)}
  to  {opacity:1; transform: translateY(0); filter: blur(0)}
}

.reveal{
  opacity:0;
  transform: translateY(20px);
  filter: blur(6px);
  transition:
    opacity .8s cubic-bezier(.16,1,.3,1),
    transform .8s cubic-bezier(.16,1,.3,1),
    filter .8s cubic-bezier(.16,1,.3,1);
}
.reveal.in{opacity:1; transform:translateY(0); filter:blur(0)}
.reveal[data-delay="1"]{transition-delay:.06s}
.reveal[data-delay="2"]{transition-delay:.12s}
.reveal[data-delay="3"]{transition-delay:.18s}
.reveal[data-delay="4"]{transition-delay:.24s}
.reveal[data-delay="5"]{transition-delay:.30s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms !important; transition-duration:.001ms !important}
  .mast-headline .line > span{transform:none}
  .reveal{opacity:1; transform:none; filter:none}
}
