/* =========================================================================
   XRP YEARBOOK — prototype styles
   Palette sampled straight from the book-artifact render.
   Rule: stay warm, stay matte. No pure white, no cool blue, no chrome.
   ========================================================================= */
:root{
  --ink:#0B0B0B;          /* base — the void the gold floats on */
  --leather:#1A1410;      /* warm near-black (brown-black, not blue-black) */
  --oxblood:#3D2A1A;      /* deep binding brown */
  --gold:#C9A24E;         /* antique gold — the foil, the workhorse */
  --gold-bright:#FFC80A;  /* candle gold — a seasoning, used sparingly */
  --parchment:#F4ECD6;    /* the "white" — warm cream, never #FFFFFF */
  --parchment-dim:#A89C82;
  --serif:"Playfair Display", Georgia, "Times New Roman", serif;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --maxw:1200px;
}

*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--parchment);
  font-family:var(--sans);
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit; text-decoration:none}
em{font-style:italic}

/* film grain over everything ------------------------------------------------ */
.grain{
  position:fixed; inset:0; z-index:80; pointer-events:none; opacity:.06;
  mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================== HERO ============================== */
.hero{
  position:relative; width:100%; height:100vh; min-height:660px;
  display:flex; flex-direction:column; overflow:hidden;
}

/* the moving memory-flow */
.flow{position:absolute; inset:0; z-index:0}
.flow .layer{
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:0; transition:opacity 3s ease-in-out; will-change:opacity, transform;
  /* one grade over every photo so mismatched shots become one memory reel */
  filter:sepia(.45) saturate(1.15) brightness(.5) contrast(1.04) hue-rotate(-12deg);
  animation:kenburns 22s ease-in-out infinite alternate;
}
.flow .layer.is-visible{opacity:1}
@keyframes kenburns{from{transform:scale(1.03)} to{transform:scale(1.15)}}

/* oxblood wash + legibility scrim */
.flow-grade{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    radial-gradient(120% 90% at 72% 22%, rgba(61,42,26,.40), transparent 60%),
    linear-gradient(180deg, rgba(11,11,11,.55) 0%, rgba(11,11,11,.30) 38%, rgba(11,11,11,.82) 100%);
}
.vignette{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:radial-gradient(115% 80% at 50% 42%, transparent 42%, rgba(0,0,0,.66) 100%);
}

/* top bar */
.topbar{
  position:relative; z-index:10;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:26px clamp(20px,5vw,64px);
}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{width:38px; height:38px; object-fit:contain; filter:drop-shadow(0 1px 6px rgba(0,0,0,.7))}
.brand-word{font-weight:600; letter-spacing:.22em; font-size:13px; color:var(--parchment)}
.nav-links{display:flex; gap:34px; list-style:none; font-size:13px; letter-spacing:.04em; color:var(--parchment-dim)}
.nav-links a{transition:color .2s}
.nav-links a:hover{color:var(--gold)}
.nav-cta{
  font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold);
  border:1px solid rgba(201,162,78,.40); padding:9px 16px; border-radius:2px; transition:background .2s;
}
.nav-cta:hover{background:rgba(201,162,78,.10)}

/* hero copy */
.hero-content{
  position:relative; z-index:10; margin:auto 0;
  padding:0 clamp(20px,5vw,64px); width:100%; max-width:var(--maxw);
}
.eyebrow{font-size:12px; letter-spacing:.34em; text-transform:uppercase; color:var(--gold); margin-bottom:22px}
.headline{
  font-family:var(--serif); font-weight:500; line-height:1.02; letter-spacing:-.01em;
  font-size:clamp(44px, 8vw, 104px); color:var(--parchment);
  text-shadow:0 2px 34px rgba(0,0,0,.55);
}
.subhead{
  margin-top:26px; max-width:560px; font-size:clamp(15px,1.4vw,19px);
  line-height:1.6; color:var(--parchment); opacity:.86;
}
.cta-row{display:flex; gap:16px; margin-top:38px; flex-wrap:wrap}

/* scroll hint */
.scroll-hint{
  position:relative; z-index:10; display:flex; flex-direction:column; align-items:center; gap:10px;
  padding-bottom:30px; color:var(--parchment-dim); font-size:11px; letter-spacing:.24em; text-transform:uppercase;
}
.scroll-arrow{width:1px; height:34px; background:linear-gradient(var(--gold), transparent); animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3} 50%{opacity:1}}

/* ============================ BUTTONS ============================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--sans); font-weight:500; font-size:14px; letter-spacing:.04em;
  padding:15px 30px; border-radius:3px; cursor:pointer; border:1px solid transparent;
  transition:all .25s ease;
}
.btn-gold{background:var(--gold); color:#1a1206; box-shadow:0 6px 24px rgba(201,162,78,.18)}
.btn-gold:hover{background:var(--gold-bright); box-shadow:0 8px 30px rgba(255,200,10,.28); transform:translateY(-1px)}
.btn-ghost{background:transparent; color:var(--parchment); border-color:rgba(244,236,214,.35)}
.btn-ghost:hover{border-color:var(--gold); color:var(--gold)}
.btn-sm{padding:11px 22px; font-size:13px}

/* ========================= SIGN THE LEDGER ========================= */
.sign{
  position:relative; z-index:5; text-align:center;
  padding:clamp(70px,12vh,140px) clamp(20px,5vw,64px) clamp(50px,8vh,90px);
  max-width:980px; margin:0 auto;
}
.sign-title{font-family:var(--serif); font-weight:500; font-size:clamp(34px,5vw,60px); color:var(--parchment); margin-top:10px}
.sign-sub{margin:18px auto 0; max-width:540px; color:var(--parchment); opacity:.78; line-height:1.6; font-size:16px}
.pad-wrap{margin-top:48px}

.pad{
  position:relative; width:100%; aspect-ratio:16/7; min-height:240px; overflow:hidden;
  border-radius:8px; cursor:crosshair;
  background:radial-gradient(120% 140% at 50% 0%, #241a12, #130e09 72%);
  border:1px solid rgba(201,162,78,.22);
  box-shadow:inset 0 0 90px rgba(0,0,0,.6), 0 30px 60px -30px rgba(0,0,0,.85);
}
.pad-ring{
  position:absolute; inset:0; margin:auto; width:auto; height:88%; object-fit:contain;
  opacity:.10; pointer-events:none; filter:saturate(1.3) brightness(1.5);
}
.pad canvas{position:absolute; inset:0; width:100%; height:100%; touch-action:none}
.pad-placeholder{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  color:var(--parchment-dim); font-style:italic; letter-spacing:.1em; font-size:14px;
  pointer-events:none; opacity:.45;
}
.pad.is-drawn .pad-placeholder{display:none}
@keyframes nudge{0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)}}
.pad.nudge{animation:nudge .4s}

.pad-controls{display:flex; align-items:center; justify-content:space-between; gap:18px; margin-top:22px; flex-wrap:wrap}
.inks{display:flex; gap:12px}
.ink{
  width:26px; height:26px; border-radius:50%; background:var(--swatch);
  border:2px solid rgba(255,255,255,.15); cursor:pointer; transition:transform .15s, box-shadow .15s;
}
.ink:hover{transform:scale(1.12)}
.ink.is-active{box-shadow:0 0 0 2px var(--ink), 0 0 0 4px var(--swatch)}
.pad-actions{display:flex; gap:12px}
.pad-note{margin-top:20px; color:var(--parchment-dim); font-size:13px; line-height:1.5}

/* ============================= LOOP ============================= */
.loop{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:rgba(201,162,78,.14);
  border-top:1px solid rgba(201,162,78,.14); border-bottom:1px solid rgba(201,162,78,.14);
}
.loop-step{background:var(--ink); padding:44px clamp(20px,4vw,48px)}
.loop-k{font-family:var(--serif); font-size:13px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:12px}
.loop-step p{color:var(--parchment); opacity:.78; font-size:15px; line-height:1.55}

/* ============================ FOOTER ============================ */
.foot{text-align:center; padding:84px 24px 72px}
.foot-line{font-family:var(--serif); font-size:clamp(20px,3vw,30px); color:var(--parchment)}
.foot-line em{color:var(--gold)}
.foot-sub{margin-top:18px; color:var(--parchment-dim); font-size:12px; letter-spacing:.14em; text-transform:uppercase}

/* =========================== RESPONSIVE =========================== */
@media (max-width:680px){
  .nav-links{display:none}
  .loop{grid-template-columns:1fr}
  .pad{aspect-ratio:4/3}
}
@media (prefers-reduced-motion:reduce){
  .flow .layer{animation:none}
  .scroll-arrow{animation:none}
}

/* =========================================================================
   SUBPAGES (Your Page + Roadmap)
   ========================================================================= */
.topbar--solid{
  position:sticky; top:0; z-index:50;
  background:rgba(11,11,11,.9); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(201,162,78,.14);
}
.page-wrap{max-width:1080px; margin:0 auto; padding:clamp(40px,7vh,90px) clamp(20px,5vw,56px) 40px}

/* ----- personal page ----- */
.profile{display:grid; grid-template-columns:minmax(0,360px) 1fr; gap:clamp(28px,5vw,64px); align-items:center}
.portrait{
  position:relative; aspect-ratio:4/5; border-radius:10px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:radial-gradient(120% 120% at 50% 0%, #241a12, #110c08 75%);
  border:1px solid rgba(201,162,78,.22); box-shadow:0 30px 60px -30px rgba(0,0,0,.85);
}
.portrait-mark{width:74%; height:auto; opacity:.5; filter:saturate(1.1)}
.portrait-cap{position:absolute; bottom:16px; left:0; right:0; text-align:center;
  color:var(--parchment-dim); font-size:12px; letter-spacing:.18em; text-transform:uppercase}
.pmeta .eyebrow{margin-bottom:14px}
.pname{font-family:var(--serif); font-weight:500; font-size:clamp(36px,5vw,60px); line-height:1.04; color:var(--parchment)}
.phandle{color:var(--gold); font-size:15px; letter-spacing:.04em; margin-top:8px}
.pbadges{display:flex; gap:10px; flex-wrap:wrap; margin-top:18px}
.badge{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--parchment);
  border:1px solid rgba(201,162,78,.35); padding:6px 12px; border-radius:999px}
.pquote{font-family:var(--serif); font-style:italic; font-size:clamp(19px,2.2vw,26px); line-height:1.4;
  color:var(--parchment); opacity:.92; margin-top:26px; max-width:30ch}
.plinks{display:flex; gap:18px; margin-top:24px; flex-wrap:wrap}
.plinks a{color:var(--parchment-dim); font-size:14px; border-bottom:1px solid rgba(201,162,78,.3); padding-bottom:2px; transition:color .2s}
.plinks a:hover{color:var(--gold)}

/* ----- signature wall ----- */
.wallsec{margin-top:clamp(50px,9vh,100px)}
.wall-head{text-align:center}
.wall-title{font-family:var(--serif); font-weight:500; font-size:clamp(26px,4vw,40px); color:var(--parchment)}
.wall-title span{color:var(--gold)}
.wall-sub{color:var(--parchment-dim); margin-top:10px; font-size:15px}
.wall{display:grid; grid-template-columns:repeat(auto-fill, minmax(140px,1fr)); gap:12px; margin-top:34px}
.sigtile{
  position:relative; aspect-ratio:3/2; border-radius:8px; overflow:hidden; padding:10px;
  background:var(--leather); border:1px solid rgba(201,162,78,.16);
  display:flex; align-items:center; justify-content:center;
}
.sig-name{font-family:"Caveat", cursive; font-size:26px; color:var(--gold); opacity:.92; transform:rotate(-4deg)}
.sigtile--mark{background:radial-gradient(120% 140% at 50% 0%, #241a12, #130e09 72%); border-color:rgba(201,162,78,.4)}
.sigtile--mark img{width:100%; height:100%; object-fit:contain}
.sig-you{position:absolute; bottom:6px; right:8px; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold)}
@keyframes pop{from{transform:scale(.6); opacity:0} to{transform:scale(1); opacity:1}}
.sigtile.is-new{animation:pop .45s ease-out; box-shadow:0 0 0 1px var(--gold), 0 0 24px rgba(201,162,78,.3)}
.wall-cta{text-align:center; margin-top:34px}

/* ----- inline sign pad (revealed) ----- */
.sign-inline{
  max-width:780px; margin:0 auto; text-align:center;
  max-height:0; opacity:0; overflow:hidden; margin-top:0;
  transition:max-height .5s ease, opacity .5s ease, margin .5s ease;
}
.sign-inline.is-open{max-height:1400px; opacity:1; margin-top:clamp(40px,7vh,80px)}
.sign-inline .sign-head{margin-bottom:30px}
.sign-inline .sign-title span{color:var(--gold)}

/* ----- roadmap ----- */
.rm-head{max-width:720px; margin:0 auto clamp(40px,7vh,80px); text-align:center}
.rm-title{font-family:var(--serif); font-weight:500; font-size:clamp(34px,5vw,58px); color:var(--parchment); margin-top:12px}
.rm-sub{color:var(--parchment); opacity:.8; margin-top:18px; line-height:1.6; font-size:16px}
.timeline{max-width:780px; margin:0 auto}
.tl-item{display:grid; grid-template-columns:24px 1fr; gap:24px; padding-bottom:48px}
.tl-rail{position:relative; display:flex; justify-content:center}
.tl-rail::before{content:""; position:absolute; top:6px; bottom:-48px; width:1px; background:rgba(201,162,78,.25)}
.tl-item:last-child .tl-rail::before{display:none}
.tl-node{width:14px; height:14px; border-radius:50%; background:var(--ink); border:2px solid var(--gold); margin-top:4px}
.tl-now .tl-node{background:var(--gold); box-shadow:0 0 0 5px rgba(201,162,78,.18)}
.tl-yearrow{display:flex; align-items:center; gap:16px; flex-wrap:wrap}
.tl-year{font-family:var(--serif); font-weight:500; font-size:clamp(24px,3.4vw,36px); color:var(--parchment)}
.tl-tag{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--parchment-dim);
  border:1px solid rgba(201,162,78,.3); padding:5px 11px; border-radius:999px}
.tl-tag--live{color:#1a1206; background:var(--gold); border-color:var(--gold)}
.tl-lead{color:var(--gold); opacity:.9; margin-top:10px; font-size:15px; font-style:italic}
.tl-list{list-style:none; margin-top:16px; display:flex; flex-direction:column; gap:9px}
.tl-list li{position:relative; padding-left:18px; color:var(--parchment); opacity:.82; font-size:15px; line-height:1.5}
.tl-list li::before{content:""; position:absolute; left:0; top:9px; width:5px; height:5px; border-radius:50%; background:var(--gold); opacity:.7}
.tl-list li b{opacity:1; font-weight:600}
.tl-list--grid{display:grid; grid-template-columns:1fr 1fr; gap:9px 24px}
.tl-now .tl-body{
  background:linear-gradient(180deg, rgba(201,162,78,.06), transparent);
  border:1px solid rgba(201,162,78,.16); border-radius:10px; padding:18px 20px; margin:-6px -6px 0;
}
.rm-foot{max-width:640px; margin:30px auto 0; text-align:center; color:var(--parchment-dim); font-size:14px; line-height:1.6; font-style:italic}

@media (max-width:680px){
  .profile{grid-template-columns:1fr}
  .tl-list--grid{grid-template-columns:1fr}
}

/* =========================================================================
   VERIFY (Proof of Class)
   ========================================================================= */
.selftest{font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:7px 12px; border-radius:999px; white-space:nowrap}
.selftest.ok{color:var(--gold); border:1px solid rgba(201,162,78,.4); background:rgba(201,162,78,.08)}
.selftest.bad{color:#E7A79B; border:1px solid rgba(192,67,47,.5); background:rgba(192,67,47,.12)}

.vf-head{max-width:760px; margin:0 auto clamp(34px,6vh,60px); text-align:center}
.vf-title{font-family:var(--serif); font-weight:500; font-size:clamp(30px,4.6vw,52px); color:var(--parchment); margin-top:12px; line-height:1.06}
.vf-sub{color:var(--parchment); opacity:.8; margin-top:18px; line-height:1.6; font-size:16px}

.vf-panel{max-width:820px; margin:0 auto 22px; padding:26px clamp(18px,3vw,34px);
  background:var(--leather); border:1px solid rgba(201,162,78,.16); border-radius:12px}
.vf-label{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:14px}

.vf-stat-row{display:flex; gap:14px; flex-wrap:wrap; margin-bottom:26px}
.vf-stat{flex:1; min-width:120px; text-align:center; padding:16px; border:1px solid rgba(201,162,78,.14); border-radius:8px; background:rgba(0,0,0,.25)}
.vf-stat span{display:block; font-family:var(--serif); font-size:34px; color:var(--parchment)}
.vf-stat label{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--parchment-dim)}

.mono{font-family:ui-monospace,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace}
.rootbox{word-break:break-all; line-height:1.6; font-size:14px; color:var(--gold);
  background:#0d0a07; border:1px solid rgba(201,162,78,.28); border-radius:8px; padding:16px}
.anchor-tx{margin-top:10px; font-size:12px; letter-spacing:.06em; color:var(--parchment-dim)}

.vf-area{width:100%; resize:vertical; min-height:240px; font-size:13px; line-height:1.55;
  color:var(--parchment); background:#0d0a07; border:1px solid rgba(201,162,78,.2); border-radius:8px; padding:16px}
.vf-area:focus{outline:none; border-color:var(--gold)}
.vf-actions{display:flex; gap:12px; margin-top:16px; flex-wrap:wrap; align-items:center}

.banner{margin-top:18px; padding:18px 20px; border-radius:8px; font-size:15px; line-height:1.5}
.banner .mono{display:inline-block; margin-top:8px; font-size:12px; word-break:break-all}
.banner--ok{background:rgba(201,162,78,.10); border:1px solid var(--gold); color:var(--parchment)}
.banner--ok b{color:var(--gold)}
.banner--bad{background:rgba(192,67,47,.12); border:1px solid #C0432F; color:#F0D8D2}
.banner--bad b{color:#E7705C}

.vf-select{flex:1; min-width:200px; background:#0d0a07; color:var(--parchment); font-size:14px;
  border:1px solid rgba(201,162,78,.25); border-radius:6px; padding:11px 12px}
.proof-out{margin-top:16px}
.proof-ok{color:var(--gold); font-size:15px}
.proof-bad{color:#E7705C; font-size:15px}
.proof{list-style:none; margin-top:12px; display:flex; flex-direction:column; gap:8px}
.proof li{display:flex; align-items:center; gap:10px; font-size:13px; color:var(--parchment); opacity:.85}
.proof-i{display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px; border-radius:50%;
  background:rgba(201,162,78,.15); color:var(--gold); font-size:12px}
.proof-side{color:var(--gold); text-transform:uppercase; letter-spacing:.1em; font-size:11px}

/* =========================================================================
   SIGNATURE STUDIO (toolbar: pen / eraser / colors / stamps / undo / clear)
   ========================================================================= */
.studio{margin-top:18px}
.stamp-tray{display:none; flex-wrap:wrap; gap:8px; justify-content:center; padding:12px; margin-bottom:12px;
  background:var(--leather); border:1px solid rgba(201,162,78,.18); border-radius:10px}
.stamp-tray.is-open{display:flex}
.stamp{width:42px; height:42px; border-radius:8px; line-height:1; cursor:pointer; font-size:20px;
  background:rgba(0,0,0,.3); border:1px solid rgba(201,162,78,.2); color:var(--parchment);
  transition:transform .12s, border-color .12s, box-shadow .12s}
.stamp:hover{transform:scale(1.12)}
.stamp.is-active{border-color:var(--gold); box-shadow:0 0 0 2px rgba(201,162,78,.35)}

.toolbar{display:flex; align-items:center; gap:14px; flex-wrap:wrap; justify-content:space-between;
  padding:12px 14px; background:var(--leather); border:1px solid rgba(201,162,78,.2); border-radius:12px}
.tb-tools,.tb-actions{display:flex; align-items:center; gap:8px}
.tb-btn{min-width:38px; height:38px; padding:0 12px; border-radius:8px; cursor:pointer; font-size:15px;
  font-family:var(--sans); background:rgba(0,0,0,.3); border:1px solid rgba(201,162,78,.2);
  color:var(--parchment); transition:all .15s}
.tb-btn:hover{border-color:var(--gold); color:var(--gold)}
.tb-btn.is-active{background:var(--gold); color:#1a1206; border-color:var(--gold)}
.ink-strip{display:flex; gap:7px; flex-wrap:wrap; flex:1; justify-content:center; min-width:170px}
.chip{width:24px; height:24px; border-radius:50%; background:var(--c); cursor:pointer;
  border:2px solid rgba(255,255,255,.18); transition:transform .12s, box-shadow .12s}
.chip:hover{transform:scale(1.18)}
.chip.is-active{box-shadow:0 0 0 2px var(--ink), 0 0 0 4px var(--c)}
@media (max-width:680px){
  .toolbar{justify-content:center}
  .ink-strip{order:3; width:100%}
}

.tb-size{-webkit-appearance:none; appearance:none; width:84px; height:4px; border-radius:999px;
  background:rgba(201,162,78,.3); cursor:pointer; margin:0 4px}
.tb-size::-webkit-slider-thumb{-webkit-appearance:none; appearance:none; width:14px; height:14px; border-radius:50%; background:var(--gold); border:none; cursor:pointer}
.tb-size::-moz-range-thumb{width:14px; height:14px; border-radius:50%; background:var(--gold); border:none; cursor:pointer}

/* =========================================================================
   PROOF OF NON-ASSET
   ========================================================================= */
.na-panel{margin-top:30px}
.na-title{font-family:var(--serif); font-weight:500; font-size:clamp(24px,3.4vw,38px); color:var(--parchment); margin-bottom:10px}
.na-sub{color:var(--parchment); opacity:.8; line-height:1.55; font-size:15px; margin-bottom:22px}
.na-rows{display:flex; flex-direction:column; gap:8px}
.na-row{display:grid; grid-template-columns:1fr auto; gap:4px 14px; padding:12px 16px;
  border:1px solid rgba(201,162,78,.14); border-radius:8px; background:rgba(0,0,0,.22);
  opacity:.32; transition:opacity .35s ease, border-color .35s ease}
.na-row.cleared{opacity:1; border-color:rgba(201,162,78,.3)}
.na-vector{grid-column:1; grid-row:1; font-weight:500; color:var(--parchment); font-size:15px}
.na-why{grid-column:1; grid-row:2; color:var(--parchment-dim); font-size:13px; line-height:1.45}
.na-status{grid-column:2; grid-row:1 / span 2; align-self:center; justify-self:end; white-space:nowrap;
  font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--parchment-dim);
  border:1px solid rgba(201,162,78,.25); border-radius:999px; padding:5px 12px}
.na-row.cleared .na-status{color:var(--gold); border-color:var(--gold); background:rgba(201,162,78,.08)}
.na-cert{margin-top:22px; padding:24px; text-align:center; border:1px solid var(--gold); border-radius:10px;
  background:rgba(201,162,78,.08); opacity:0; transform:translateY(8px); transition:opacity .5s ease, transform .5s ease}
.na-cert.show{opacity:1; transform:none}
.na-cert-badge{display:inline-block; font-family:var(--serif); letter-spacing:.08em; color:var(--gold); font-size:21px; margin-bottom:8px}
.na-cert p{max-width:540px; margin:0 auto; color:var(--parchment); opacity:.9; font-size:14px; line-height:1.5}

/* =========================================================================
   CLASS RAFFLE
   ========================================================================= */
.rf-live{font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold)}
.rf-head{max-width:760px; margin:0 auto clamp(34px,6vh,56px); text-align:center}
.rf-title{font-family:var(--serif); font-weight:500; font-size:clamp(32px,5vw,56px); color:var(--parchment); margin-top:12px}
.rf-sub{max-width:620px; margin:16px auto 0; color:var(--parchment); opacity:.8; line-height:1.6; font-size:15px}

.rf-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:24px; align-items:start}

.rf-prize{background:var(--leather); border:1px solid rgba(201,162,78,.18); border-radius:14px; overflow:hidden}
.rf-prize-img{aspect-ratio:16/10; overflow:hidden; background:#0d0a07}
.rf-prize-img img{width:100%; height:100%; object-fit:cover; filter:saturate(1.05)}
.rf-prize-meta{padding:22px 24px}
.rf-prize-meta h2{font-family:var(--serif); font-weight:500; font-size:24px; color:var(--parchment); margin:12px 0 8px}
.rf-prize-meta p{color:var(--parchment-dim); font-size:14px; line-height:1.5}
.rf-prize-stats{display:flex; gap:12px; margin-top:22px}
.rf-prize-stats div{flex:1; text-align:center; padding:14px 8px; border:1px solid rgba(201,162,78,.14); border-radius:8px; background:rgba(0,0,0,.25)}
.rf-prize-stats span{display:block; font-family:var(--serif); font-size:23px; color:var(--gold)}
.rf-prize-stats label{font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--parchment-dim)}

.rf-enter{background:var(--leather); border:1px solid rgba(201,162,78,.18); border-radius:14px; padding:24px}
.rf-tasks{display:flex; flex-direction:column; gap:10px; margin-bottom:20px}
.rf-task{display:flex; align-items:center; gap:14px; width:100%; text-align:left; cursor:pointer;
  padding:14px 16px; border-radius:10px; background:rgba(0,0,0,.25); border:1px solid rgba(201,162,78,.16);
  color:var(--parchment); transition:border-color .15s, background .15s}
.rf-task:hover{border-color:rgba(201,162,78,.4)}
.rf-check{flex:none; width:22px; height:22px; border-radius:50%; border:2px solid rgba(201,162,78,.4); transition:all .15s}
.rf-task.is-done .rf-check{background:var(--gold); border-color:var(--gold); box-shadow:inset 0 0 0 3px var(--leather)}
.rf-task-main{flex:1; display:flex; flex-direction:column; gap:2px}
.rf-task-main b{font-weight:500; font-size:15px}
.rf-task-main i{font-style:normal; color:var(--parchment-dim); font-size:12px}
.rf-task-pts{flex:none; font-family:var(--serif); color:var(--gold); font-size:16px}
.rf-task.is-locked{opacity:.6; pointer-events:none}

.rf-yourbar{display:flex; align-items:center; justify-content:space-between; margin-bottom:14px;
  padding:14px 16px; border-radius:10px; background:rgba(201,162,78,.08); border:1px solid rgba(201,162,78,.25)}
.rf-yourbar span:first-child{font-size:13px; letter-spacing:.06em; text-transform:uppercase; color:var(--parchment-dim)}
.rf-yourcount{font-family:var(--serif); font-size:26px; color:var(--gold)}
#rfEnterBtn{width:100%}
#rfEnterBtn:disabled{opacity:.5; cursor:default}
.rf-note{margin-top:14px; color:var(--parchment-dim); font-size:13px; line-height:1.5}

.rf-draw{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
  margin-top:22px; padding-top:18px; border-top:1px solid rgba(201,162,78,.14)}
.rf-seed{font-size:12px; color:var(--parchment-dim)}
.rf-winner{margin-top:16px}
.rf-rolling{font-family:var(--serif); font-size:22px; color:var(--parchment); text-align:center; opacity:.7}
.rf-won{text-align:center; padding:20px; border:1px solid var(--gold); border-radius:10px; background:rgba(201,162,78,.08)}
.rf-won-badge{font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold)}
.rf-won-name{font-family:var(--serif); font-size:30px; color:var(--parchment); margin:6px 0 10px}
.rf-won-name.is-you{color:var(--gold)}
.rf-won p{max-width:420px; margin:0 auto; color:var(--parchment-dim); font-size:13px; line-height:1.5}

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

/* ---- Class Draw: ink bar, splash, sides, ceremony, seal ---- */
.rf-inkbar{position:relative; margin-bottom:18px}
.rf-inkbar-track{height:8px; border-radius:999px; background:rgba(0,0,0,.35); overflow:hidden; border:1px solid rgba(201,162,78,.18)}
.rf-inkbar-fill{height:100%; width:0; border-radius:999px; background:linear-gradient(90deg,var(--gold),var(--gold-bright)); transition:width .5s ease; box-shadow:0 0 12px rgba(201,162,78,.4)}
.rf-inkbar-label{display:block; margin-top:8px; font-size:12px; color:var(--parchment-dim); letter-spacing:.04em}
.rf-inkbar-label #yourInk{color:var(--gold); font-family:var(--serif); font-size:16px}
.rf-splash{position:absolute; right:0; top:-4px; color:var(--gold); font-size:14px; font-weight:600; pointer-events:none; animation:rfsplash .9s ease-out forwards}
.rf-splash.neg{color:#E7705C}
@keyframes rfsplash{0%{opacity:0; transform:translateY(6px)} 20%{opacity:1} 100%{opacity:0; transform:translateY(-24px)}}

.rf-sides{display:flex; gap:10px; margin-top:18px}
.rf-side{flex:1; padding:12px; border:1px dashed rgba(201,162,78,.3); border-radius:8px; text-align:center}
.rf-side b{display:block; color:var(--parchment); font-size:13px; font-weight:500}
.rf-side i{font-style:normal; color:var(--parchment-dim); font-size:11px}

.rf-ceremony{max-width:820px; margin:32px auto 0; text-align:center}
.rf-cer-title{font-family:var(--serif); font-weight:500; font-size:clamp(26px,4vw,42px); color:var(--parchment); margin-top:8px}
.rf-stage{display:flex; align-items:center; justify-content:center; min-height:170px; margin:26px auto; padding:24px;
  background:radial-gradient(120% 140% at 50% 0%, #241a12, #130e09 72%);
  border:1px solid rgba(201,162,78,.22); border-radius:12px; overflow:hidden}
.rf-stage-idle{color:var(--parchment-dim); font-style:italic}
.rf-page{display:flex; flex-direction:column; gap:6px; transition:transform .12s ease}
.rf-page-name{font-family:var(--serif); font-size:30px; color:var(--parchment)}
.rf-page-ink{font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold)}
.rf-page.is-winner{transform:scale(1.12)}

.rf-seal{max-width:520px; margin:18px auto 0; text-align:center}
.rf-sealbadge{font-family:var(--sans); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold);
  background:rgba(201,162,78,.08); border:1px solid rgba(201,162,78,.4); border-radius:999px; padding:9px 18px; cursor:pointer; transition:background .15s}
.rf-sealbadge:hover{background:rgba(201,162,78,.16)}
.rf-sealbody{display:none; margin-top:14px; text-align:left; padding:18px; border:1px solid rgba(201,162,78,.2); border-radius:10px; background:rgba(0,0,0,.25)}
.rf-sealbody.show{display:block}
.rf-sealrow{display:flex; justify-content:space-between; gap:14px; padding:7px 0; border-bottom:1px solid rgba(201,162,78,.1)}
.rf-sealrow span:first-child{color:var(--parchment-dim); text-transform:uppercase; letter-spacing:.12em; font-size:11px}
.rf-sealrow .mono{color:var(--gold); font-size:13px}
.rf-sealbody p{margin-top:12px; color:var(--parchment-dim); font-size:13px; line-height:1.5}

/* ---- Class Draw: groups, community pool, modals, guide ---- */
.rf-head .btn{margin-top:18px}
.rf-group-label{font-size:12px; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin:6px 0 10px}
.rf-group-label span{color:var(--parchment-dim); letter-spacing:.04em; text-transform:none}
.rf-tasks + .rf-group-label{margin-top:18px}

.rf-pool{max-width:1080px; margin:28px auto 0}
.rf-pool-head{display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin-bottom:16px}
.rf-pool-sub{color:var(--parchment-dim); font-size:13px; margin-top:4px}
.rf-pool-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:12px}
.rf-pool-card{padding:16px; border:1px solid rgba(201,162,78,.18); border-radius:10px; background:var(--leather)}
.rf-pc-name{font-family:var(--serif); color:var(--parchment); font-size:17px}
.rf-pc-coll{color:var(--gold); font-size:12px; letter-spacing:.08em; margin-top:4px}
.rf-pc-by{color:var(--parchment-dim); font-size:11px; margin-top:8px}
.rf-pool-card.is-new{animation:pop .45s ease-out; box-shadow:0 0 0 1px var(--gold), 0 0 24px rgba(201,162,78,.3)}

.rf-modal{position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center; padding:24px;
  background:rgba(5,4,3,.78); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px)}
.rf-modal[hidden]{display:none}
.rf-modal-card{position:relative; width:100%; max-width:560px; max-height:86vh; overflow:auto;
  padding:30px clamp(20px,4vw,36px); border-radius:14px; background:#16110c;
  border:1px solid rgba(201,162,78,.3); box-shadow:0 40px 90px -30px rgba(0,0,0,.9)}
.rf-modal-x{position:absolute; top:12px; right:16px; background:none; border:none; color:var(--parchment-dim); font-size:26px; line-height:1; cursor:pointer}
.rf-modal-x:hover{color:var(--gold)}
.rf-modal-title{font-family:var(--serif); font-weight:500; font-size:clamp(24px,3.5vw,34px); color:var(--parchment); margin:8px 0 6px}
.rf-modal-sub{color:var(--parchment-dim); font-size:14px; line-height:1.5; margin-bottom:18px}
.rf-stages{list-style:none; counter-reset:st; margin:18px 0 0; padding:0; display:flex; flex-direction:column; gap:14px}
.rf-stages li{counter-increment:st; position:relative; padding-left:46px}
.rf-stages li::before{content:counter(st); position:absolute; left:0; top:0; width:30px; height:30px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-family:var(--serif); color:var(--gold);
  background:rgba(201,162,78,.1); border:1px solid rgba(201,162,78,.4)}
.rf-stages b{display:block; color:var(--parchment); font-size:15px; margin-bottom:3px}
.rf-stages p{color:var(--parchment-dim); font-size:13px; line-height:1.5}

.rf-field{display:block; margin-bottom:14px}
.rf-field span{display:block; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--parchment-dim); margin-bottom:6px}
.rf-field input{width:100%; padding:12px 14px; border-radius:8px; background:#0d0a07; color:var(--parchment); font-size:14px; font-family:var(--sans); border:1px solid rgba(201,162,78,.25)}
.rf-field input:focus{outline:none; border-color:var(--gold)}
.rf-field-note{color:var(--parchment-dim); font-size:12px; margin-top:8px}
#contribSubmit{width:100%}

/* ---- Class Draw: Contribution Board + multi-winner reveal ---- */
.rf-board{max-width:1080px; margin:28px auto 0}
.rf-board-head{margin-bottom:16px}
.rf-board-sub{color:var(--parchment-dim); font-size:13px; margin-top:4px}
.rf-board-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.rf-board-col{background:var(--leather); border:1px solid rgba(201,162,78,.18); border-radius:12px; padding:18px 20px}
.rf-board-col h3{font-family:var(--serif); font-weight:500; font-size:18px; color:var(--parchment); margin-bottom:10px}
.rf-brow{display:flex; align-items:center; gap:10px; padding:9px 0; border-bottom:1px solid rgba(201,162,78,.1); font-size:14px}
.rf-brow:last-child{border-bottom:none}
.rf-brow-rank{flex:none; width:22px; color:var(--gold); font-family:var(--serif)}
.rf-brow-who{color:var(--parchment); font-weight:500}
.rf-brow-what{margin-left:auto; color:var(--parchment-dim); font-size:13px}
.rf-brow-ink{margin-left:auto; color:var(--gold); font-size:13px}
.rf-brow.is-you{margin:0 -20px; padding-left:20px; padding-right:20px; background:rgba(201,162,78,.08); border-radius:6px}
.rf-brow.is-you .rf-brow-who{color:var(--gold)}
@media (max-width:760px){ .rf-board-grid{grid-template-columns:1fr} }

.rf-winners{width:100%; text-align:center}
.rf-winners-title{font-family:var(--serif); font-size:24px; color:var(--parchment)}
.rf-winners-sub{color:var(--parchment-dim); font-size:13px; margin:4px 0 18px}
.rf-wgrid{display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:10px; text-align:left}
.rf-wcard{padding:12px 14px; border:1px solid rgba(201,162,78,.18); border-radius:8px; background:rgba(0,0,0,.25)}
.rf-wcard.is-grand{border-color:var(--gold); background:rgba(201,162,78,.1)}
.rf-wcard.is-you{box-shadow:0 0 0 1px var(--gold)}
.rf-wname{font-family:var(--serif); color:var(--parchment); font-size:17px}
.rf-wprize{color:var(--gold); font-size:12px; margin-top:3px}
.rf-announce{margin-top:18px}

/* ---- Class Draw: prize art, upload, winner thumbs ---- */
.rf-pc-img{aspect-ratio:1; margin-bottom:10px; border-radius:8px; overflow:hidden; position:relative;
  background:radial-gradient(120% 120% at 50% 0%, #241a12, #130e09 75%); border:1px solid rgba(201,162,78,.14);
  display:flex; align-items:center; justify-content:center}
.rf-pc-img img{width:100%; height:100%; object-fit:cover}
.rf-img-ph{display:flex; flex-direction:column; align-items:center; gap:8px; padding:8px; text-align:center;
  color:var(--parchment-dim); font-size:10px; letter-spacing:.14em; text-transform:uppercase}
.rf-ph-mark{width:46%; opacity:.28; filter:saturate(1.2) brightness(1.4)}

.rf-field input[type=file]{padding:9px; font-size:13px; color:var(--parchment-dim)}
.rf-field input[type=file]::file-selector-button{margin-right:12px; padding:8px 14px; border-radius:6px; cursor:pointer;
  border:1px solid rgba(201,162,78,.4); background:rgba(201,162,78,.1); color:var(--gold); font-family:var(--sans)}
.rf-preview{margin-bottom:14px}
.rf-preview img{max-width:120px; border-radius:8px; border:1px solid rgba(201,162,78,.3)}

.rf-wcard{display:flex; align-items:center; gap:11px}
.rf-wthumb{flex:none; width:42px; height:42px; border-radius:6px; object-fit:cover; background:#130e09; border:1px solid rgba(201,162,78,.2)}
.rf-wtext{min-width:0}

/* ---- Class Draw: contribute XRP ---- */
.rf-xrp{margin:8px 0 18px; padding:16px; border:1px dashed rgba(201,162,78,.3); border-radius:10px; background:rgba(0,0,0,.2)}
.rf-xrp-text b{display:block; color:var(--parchment); font-size:14px}
.rf-xrp-text span{color:var(--parchment-dim); font-size:12px}
.rf-xrp-row{display:flex; gap:10px; margin-top:12px}
.rf-xrp-row select{flex:1; background:#0d0a07; color:var(--parchment); border:1px solid rgba(201,162,78,.25); border-radius:8px; padding:10px 12px; font-size:13px}

/* =========================================================================
   CLASS MERCH STORE
   ========================================================================= */
.mc-cart{font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--gold); border:1px solid rgba(201,162,78,.4); border-radius:999px; padding:7px 14px; white-space:nowrap}
.mc-hero{display:grid; grid-template-columns:1fr 1fr; gap:30px; align-items:center; margin-bottom:40px}
.mc-hero-img{border-radius:14px; overflow:hidden; border:1px solid rgba(201,162,78,.2)}
.mc-hero-img img{width:100%; display:block}
.mc-hero h1{font-family:var(--serif); font-weight:500; font-size:clamp(34px,5vw,56px); color:var(--parchment)}
.mc-hero p{color:var(--parchment); opacity:.8; margin-top:14px; line-height:1.6}
.mc-grid{display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:18px}
.mc-card{background:var(--leather); border:1px solid rgba(201,162,78,.18); border-radius:12px; overflow:hidden}
.mc-card-img{aspect-ratio:1; display:flex; align-items:center; justify-content:center; background:radial-gradient(120% 120% at 50% 0%, #241a12, #130e09 75%)}
.mc-card-body{padding:18px}
.mc-card-body h3{font-family:var(--serif); font-weight:500; font-size:19px; color:var(--parchment)}
.mc-desc{color:var(--parchment-dim); font-size:13px; margin:4px 0 14px}
.mc-card-foot{display:flex; align-items:center; justify-content:space-between}
.mc-price{font-family:var(--serif); color:var(--gold); font-size:20px}
.mc-checkout{position:sticky; bottom:0; margin-top:30px; padding:16px 20px; display:flex; align-items:center; justify-content:space-between;
  background:rgba(11,11,11,.92); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px); border:1px solid rgba(201,162,78,.2); border-radius:12px}
.mc-checkout-total{color:var(--parchment)}
.mc-checkout-total b{font-family:var(--serif); color:var(--gold); font-size:20px}
.mc-count{color:var(--parchment-dim); font-size:13px}
.mc-note{text-align:center; color:var(--parchment-dim); font-size:12px; margin-top:14px}
@media (max-width:760px){ .mc-hero{grid-template-columns:1fr} }
