*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0a0a0a;
  --surface:#111;
  --surface2:#1a1a1a;
  --border:#222;
  --text:#e8e4de;
  --muted:#807a6f;
  --muted-strong:#b9b1a4;
  --muted-soft:#9c9589;
  --accent:#c9a84c;
  --accent2:#dfc06a;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Outfit',system-ui,sans-serif;
}
html{scroll-behavior:smooth;scroll-padding-top:5rem;scrollbar-color:rgba(201,168,76,.25) transparent;scrollbar-width:thin}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

/* ── SKIP LINK ──────────────────────────── */
.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
  z-index:200;
  font-family:var(--sans);
  font-size:.9rem;
  font-weight:500;
  color:var(--bg);
  background:var(--accent);
  padding:.75rem 1.5rem;
  text-decoration:none;
  border-radius:0 0 3px 3px;
}
.skip-link:focus{
  position:fixed;
  left:1rem;
  top:0;
  width:auto;
  height:auto;
  overflow:visible;
}

/* ── NAV ─────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1.25rem 2rem;
  display:flex;align-items:center;justify-content:space-between;
  background:rgba(10,10,10,.85);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:background .3s;
}
nav .logo{
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:700;
  letter-spacing:.03em;
  color:var(--text);
}
nav .logo span{color:var(--accent)}
nav .play-link{
  font-size:.9rem;
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--accent);
  text-decoration:none;
  padding:.5rem 1.25rem;
  border:1px solid var(--accent);
  border-radius:2px;
  transition:all .2s;
}
nav .play-link:hover{background:var(--accent);color:var(--bg)}

/* ── HERO ────────────────────────────────── */
.hero{
  min-height:100vh;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  text-align:center;
  padding:6rem 2rem 2rem;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 45%, rgba(201,168,76,.06) 0%, transparent 70%),
    radial-gradient(ellipse 80% 60% at 50% 100%, rgba(201,168,76,.03) 0%, transparent 50%);
  pointer-events:none;
}
.hero-canvas{
  position:absolute;inset:0;
  pointer-events:none;
  opacity:.7;
}
.hero-overtitle{
  font-size:.84rem;
  font-weight:500;
  letter-spacing:.25em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1.5rem;
  position:relative;
}
.hero h1{
  font-family:var(--serif);
  font-size:clamp(3rem, 8vw, 6.5rem);
  font-weight:700;
  line-height:1.05;
  letter-spacing:-.02em;
  margin-bottom:1.5rem;
  position:relative;
}
.hero h1 em{
  font-style:italic;
  color:var(--accent);
}
.hero-sub{
  font-size:clamp(1rem, 2.5vw, 1.25rem);
  color:var(--muted);
  max-width:540px;
  margin-bottom:2.5rem;
  position:relative;
}
.hero-cta{
  display:inline-block;
  font-family:var(--sans);
  font-size:.94rem;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--bg);
  background:var(--accent);
  padding:.9rem 2.5rem;
  border:none;
  border-radius:2px;
  text-decoration:none;
  cursor:pointer;
  position:relative;
  transition:all .25s;
}
.hero-cta:hover{background:var(--accent2);transform:translateY(-1px)}
.hero-wallet-note{
  font-family:var(--sans);
  font-size:.82rem;
  color:var(--muted);
  letter-spacing:.06em;
  margin-top:.75rem;
  opacity:.82;
}
.hero-scroll{
  position:absolute;
  bottom:1.5rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.35rem;
  color:var(--muted);
  opacity:.5;
  transition:opacity .3s;
}
.hero-scroll:hover{opacity:.8}
.hero-scroll-chevron{
  width:20px;
  height:20px;
  border-right:1.5px solid var(--muted);
  border-bottom:1.5px solid var(--muted);
  transform:rotate(45deg);
  animation:scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce{
  0%,100%{transform:rotate(45deg) translateY(0);opacity:.4}
  50%{transform:rotate(45deg) translateY(5px);opacity:.9}
}

/* ── SECTIONS ────────────────────────────── */
section{padding:6rem 2rem}
.container{max-width:960px;margin:0 auto}
.origin-container{position:relative}

.section-label{
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.3em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1rem;
}
.section-title{
  font-family:var(--serif);
  font-size:clamp(2rem, 5vw, 3.2rem);
  font-weight:600;
  line-height:1.15;
  margin-bottom:1.5rem;
}
.section-body{
  color:var(--muted);
  font-size:1.05rem;
  max-width:620px;
}

/* ── ORIGIN ─────────────────────────────── */
.origin{border-top:1px solid var(--border)}
.origin-year{
  font-family:var(--serif);
  font-size:clamp(6rem, 15vw, 12rem);
  font-weight:700;
  color:rgba(201,168,76,.06);
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  line-height:1;
  user-select:none;
  pointer-events:none;
  white-space:nowrap;
  z-index:0;
}
.origin .section-label,
.origin .section-title,
.origin-body,
.origin-accent{position:relative;z-index:1}
.origin-body{
  color:var(--muted);
  font-size:1.05rem;
  max-width:620px;
}
.origin-accent{
  width:40px;height:1px;
  background:var(--accent);
  margin-top:2rem;
  opacity:.5;
}

/* ── THEORY ──────────────────────────────── */
.theory{border-top:1px solid var(--border)}
.theory-quote{
  font-family:var(--serif);
  font-size:clamp(1.4rem, 3.5vw, 2rem);
  font-weight:400;
  font-style:italic;
  line-height:1.5;
  color:var(--text);
  max-width:700px;
  margin:3rem 0 1rem;
  position:relative;
  padding-left:2rem;
}
.theory-quote::before{
  content:'';
  position:absolute;
  left:0;top:0;bottom:0;
  width:2px;
  background:var(--accent);
}
.theory-attrib{
  font-size:.92rem;
  color:var(--muted);
  padding-left:2rem;
}

/* ── CONCEPT (The Rules) ─────────────────── */
.concept{border-top:1px solid var(--border)}
.concept-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3rem;
  margin-top:3rem;
}
.concept-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:3px;
  padding:2rem;
  transition:border-color .3s;
}
.concept-card:hover{border-color:var(--accent)}
.concept-card .num{
  font-family:var(--serif);
  font-size:2.5rem;
  font-weight:700;
  color:rgba(223,192,106,.58);
  line-height:1;
  margin-bottom:.75rem;
}
.concept-card h3{
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:600;
  margin-bottom:.5rem;
}
.concept-card p{color:var(--muted-strong);font-size:.98rem}

/* ── MECHANICS ───────────────────────────── */
.mechanics{border-top:1px solid var(--border)}
.mech-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2rem;
  margin-top:3rem;
}
.mech-step{position:relative;padding-left:0}
.mech-step .icon{
  font-size:1.8rem;
  margin-bottom:.75rem;
  display:block;
  filter:grayscale(.3);
}
.mech-step h3{
  font-family:var(--serif);
  font-size:1.15rem;
  font-weight:600;
  margin-bottom:.4rem;
}
.mech-step p{color:var(--muted);font-size:.95rem}

/* ── EXAMPLE ─────────────────────────────── */
.example{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.example-layout{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:3rem;
  align-items:start;
}
.example-left{position:sticky;top:6rem}
.example-left .section-title{margin-bottom:1.5rem}
.example-demo{}
.example-question{
  font-family:var(--serif);
  font-size:1.6rem;
  font-weight:600;
  margin-bottom:1.5rem;
  line-height:1.3;
}
.example-options{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:.6rem;
}
.example-opt{
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:3px;
  padding:.6rem .5rem;
  font-family:var(--sans);
  font-size:.96rem;
  font-weight:400;
  color:var(--text);
  cursor:pointer;
  transition:all .2s;
  text-align:center;
}
.example-opt:hover{border-color:var(--accent);color:var(--accent)}
.example-opt .vote-bar{
  display:none;
  height:5px;
  border-radius:2.5px;
  background:var(--accent);
  margin-top:.4rem;
  width:0;
  transition:width .6s ease;
}
.example-opt .vote-pct{
  display:none;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.05em;
  color:var(--muted-strong);
  margin-top:.2rem;
}
.example-layout.revealed .example-opt .vote-bar,
.example-layout.revealed .example-opt .vote-pct{display:block}
/* Dim all options in revealed state, then un-dim popular and my-pick */
.example-layout.revealed .example-opt{
  opacity:1;
  cursor:default;
  background:#151515;
  border-color:#38332a;
  color:var(--muted-strong);
}
.example-layout.revealed .example-opt.popular,
.example-layout.revealed .example-opt.my-pick{opacity:1}
.example-opt.popular{position:relative}
.example-layout.revealed .example-opt.popular{
  border:2px solid var(--accent2);
  background:rgba(223,192,106,.18);
  color:var(--accent2);
  font-weight:600;
  box-shadow:0 0 16px rgba(223,192,106,.18),0 0 4px rgba(223,192,106,.12);
}
.example-opt.popular::after{
  content:'focal point';
  display:none;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  opacity:.6;
  margin-top:.15rem;
}
.example-layout.revealed:not(.has-tally) .example-opt.popular::after{display:block}
/* User's own pick */
.example-opt.my-pick{position:relative}
.example-layout.revealed .example-opt.my-pick{
  border:2px solid var(--text);
  background:rgba(232,228,222,.08);
  color:var(--text);
  font-weight:500;
}
.example-layout.revealed .example-opt.my-pick::before{
  content:'your pick';
  display:block;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--text);
  white-space:nowrap;
  opacity:.7;
  margin-bottom:.15rem;
}
/* When the user picked the popular option, gold wins */
.example-layout.revealed .example-opt.my-pick.popular{
  border-color:var(--accent);
  color:var(--accent);
}
/* Hide the absolutely-positioned ::before; it overlaps the cell above */
.example-layout.revealed .example-opt.my-pick.popular::before{
  display:none;
}
/* Repurpose ::after to say "your pick" instead of "focal point" */
.example-layout.revealed .example-opt.my-pick.popular::after{
  content:'your pick \b7  focal point';
  display:block;
}
.example-layout.revealed .example-insight{display:block}
.example-insight{
  margin-top:1.5rem;
  font-size:.92rem;
  color:var(--muted-strong);
  display:none;
  font-style:italic;
  padding-left:1rem;
  border-left:2px solid var(--accent);
}
.example-vote-status{
  min-height:1.5rem;
  margin:.85rem 0 1rem;
  font-size:.88rem;
  color:var(--muted);
}
.example-vote-status.pending{color:var(--accent)}
.example-vote-status.error{color:#d9a29a}
.example-vote-status.success{color:var(--muted-strong)}
.example-turnstile{
  min-height:66px;
  margin:0 0 1rem;
}
.example-turnstile[hidden]{display:none}
.example-layout.verifying .example-opt,
.example-layout.demo-disabled .example-opt{
  pointer-events:none;
}
.example-layout.verifying .example-opt{
  opacity:.72;
}
.example-layout.demo-disabled .example-opt{
  cursor:not-allowed;
  opacity:.55;
}
.example-layout.demo-disabled .example-opt:hover{
  border-color:var(--border);
  color:var(--text);
}

/* ── LEARN (Educational) ────────────────── */
.learn{border-top:1px solid var(--border)}
.learn-subsection{margin-top:4rem}
.learn-subsection:first-child{margin-top:0}

.learn-callout{
  background:linear-gradient(135deg, rgba(201,168,76,.04) 0%, rgba(17,17,17,.6) 100%);
  border:1px solid rgba(201,168,76,.12);
  border-left:3px solid var(--accent);
  border-radius:0 3px 3px 0;
  padding:2rem 2.5rem;
  margin:2rem 0;
  font-family:var(--serif);
  font-size:clamp(1.1rem, 2.5vw, 1.35rem);
  font-style:italic;
  line-height:1.6;
  color:var(--text);
}
.learn-callout-attrib{
  font-family:var(--sans);
  font-style:normal;
  font-size:.86rem;
  color:var(--muted);
  margin-top:.75rem;
  letter-spacing:.03em;
}

.learn-steps{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
  margin-top:2rem;
}
.learn-step{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:3px;
  padding:1.75rem;
  transition:border-color .3s;
}
.learn-step:hover{border-color:var(--accent)}
.learn-step .num{
  font-family:var(--serif);
  font-size:2rem;
  font-weight:700;
  color:rgba(223,192,106,.58);
  line-height:1;
  margin-bottom:.5rem;
}
.learn-step h3{
  font-family:var(--serif);
  font-size:1.15rem;
  font-weight:600;
  margin-bottom:.4rem;
}
.learn-step p{color:var(--muted-strong);font-size:.96rem}

.learn-apps{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1.5rem;
  margin-top:2rem;
}
.learn-app{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:3px;
  padding:1.75rem;
  transition:border-color .3s;
}
.learn-app:hover{border-color:var(--accent)}
.learn-app-label{
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:.5rem;
}
.learn-app h3{
  font-family:var(--serif);
  font-size:1.1rem;
  font-weight:600;
  margin-bottom:.4rem;
}
.learn-app p{color:var(--muted-strong);font-size:.95rem}
.learn-app a{
  color:var(--accent);
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:.16em;
  transition:color .2s,text-decoration-color .2s;
}
.learn-app a:hover{color:var(--accent2);text-decoration-color:var(--accent2)}

.learn-ethereum{
  position:relative;
  background:linear-gradient(180deg, rgba(201,168,76,.03) 0%, transparent 100%);
  border:1px solid rgba(201,168,76,.1);
  border-radius:3px;
  padding:2.5rem;
  margin-top:2rem;
}
.learn-ethereum p{
  color:var(--muted);
  font-size:1rem;
  max-width:680px;
}
.learn-ethereum strong{color:var(--text);font-weight:500}

.learn-reading{
  margin-top:3rem;
  border:1px solid var(--border);
  border-radius:3px;
  background:var(--surface);
}
.learn-reading summary{
  padding:1.25rem 1.75rem;
  font-family:var(--serif);
  font-size:1.1rem;
  font-weight:600;
  color:var(--text);
  cursor:pointer;
  list-style:none;
  display:flex;
  align-items:center;
  gap:.75rem;
  transition:color .2s;
}
.learn-reading summary:hover{color:var(--accent)}
.learn-reading summary::-webkit-details-marker{display:none}
.learn-reading summary::before{
  content:'+';
  font-family:var(--sans);
  font-size:1.2rem;
  font-weight:300;
  color:var(--accent);
  width:1.5rem;
  text-align:center;
  transition:transform .2s;
}
.learn-reading[open] summary::before{content:'\2212'}
.learn-reading-list{
  padding:0 1.75rem 1.5rem;
  border-top:1px solid var(--border);
}
.learn-reading-list li{
  list-style:none;
  padding:.6rem 0;
  border-bottom:1px solid rgba(34,34,34,.6);
  font-size:.92rem;
  color:var(--muted);
}
.learn-reading-list li:last-child{border-bottom:none}
.learn-reading-list a{
  color:var(--accent);
  text-decoration:none;
  transition:color .2s;
}
.learn-reading-list a:hover{color:var(--accent2)}
.learn-reading-list .reading-year{
  font-size:.82rem;
  color:#555;
  margin-left:.5rem;
}

/* ── SOCIAL PROOF ───────────────────────── */
.social-proof{border-top:1px solid var(--border)}
.social-proof-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem;
  margin-top:3rem;
}
.social-card{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(201,168,76,.06), rgba(17,17,17,.96));
  border:1px solid var(--border);
  border-radius:3px;
  padding:1.5rem;
}
.social-card::before{
  content:'';
  position:absolute;
  inset:0 auto auto 0;
  width:100%;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(201,168,76,.5), transparent);
}
.social-value{
  font-family:var(--serif);
  font-size:clamp(2.6rem, 6vw, 4rem);
  font-weight:600;
  line-height:1;
  color:var(--accent);
  margin-bottom:.75rem;
}
.social-label{
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text);
  margin-bottom:.5rem;
}
.social-copy{
  color:var(--muted);
  font-size:.96rem;
  max-width:24ch;
}
.social-proof-note{
  color:var(--muted);
  font-size:.95rem;
  margin-top:1.25rem;
}

/* ── FINAL CTA ───────────────────────────── */
.final-cta{
  text-align:center;
  padding:8rem 2rem;
  border-top:1px solid var(--border);
  position:relative;
}
.final-cta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 50% 60% at 50% 60%, rgba(201,168,76,.05) 0%, transparent 70%);
  pointer-events:none;
}
.final-cta .section-title{margin-bottom:1rem;position:relative}
.final-cta p{color:var(--muted);margin-bottom:2.5rem;position:relative}
.final-cta .hero-cta{position:relative}

/* ── FOOTER ──────────────────────────────── */
footer{
  padding:2.5rem 2rem;
  border-top:1px solid var(--border);
  font-size:.82rem;
  color:var(--muted-soft);
  letter-spacing:.03em;
}
.footer-inner{
  max-width:960px;
  margin:0 auto;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:2rem;
  flex-wrap:wrap;
}
.footer-brand{
  font-family:var(--serif);
  font-size:1rem;
  font-weight:700;
  color:var(--muted);
  letter-spacing:.03em;
}
.footer-brand span{color:var(--accent)}
.footer-desc{
  color:var(--muted-soft);
  font-size:.78rem;
  margin-top:.25rem;
}
.footer-links{
  display:flex;
  gap:1.5rem;
  align-items:center;
}
.footer-links a{
  color:var(--muted);
  text-decoration:none;
  transition:color .2s;
}
.footer-links a:hover{color:var(--accent)}
.footer-meta{
  display:flex;
  align-items:center;
  gap:1rem;
  font-family:'SF Mono',SFMono-Regular,Consolas,'Liberation Mono',Menlo,monospace;
  font-size:.74rem;
  color:var(--muted-soft);
}

/* ── RESPONSIVE ──────────────────────────── */
@media(max-width:700px){
  .concept-grid{grid-template-columns:1fr}
  .mech-steps{grid-template-columns:1fr}
  .example-layout{grid-template-columns:1fr}
  .learn-steps{grid-template-columns:1fr}
  .learn-apps{grid-template-columns:1fr}
  .learn-callout{padding:1.5rem}
  .social-proof-grid{grid-template-columns:1fr}
  .example-left{position:static}
  .example-options{grid-template-columns:repeat(3,1fr)}
  nav{padding:1rem 1.25rem}
  section{padding:4rem 1.25rem}
  .hero{padding:5rem 1.25rem 2rem}
  .footer-inner{flex-direction:column;text-align:center;gap:1rem}
}

/* ── HERO ENTRANCE ────────────────────────── */
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.hero-anim{animation:heroIn .7s ease forwards;opacity:0}
.ha-1{animation-delay:.15s}
.ha-2{animation-delay:.3s}
.ha-3{animation-delay:.45s}

/* ── SCROLL ANIMATIONS ───────────────────── */
@keyframes revealUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
.reveal{animation:revealUp .5s ease both}
.reveal-delay-1{animation-delay:.08s}
.reveal-delay-2{animation-delay:.16s}
.reveal-delay-3{animation-delay:.24s}
.reveal-delay-4{animation-delay:.32s}
