/* =========================================================
   Kiki's Lambo · $KIKI — styles
   Editorial-warm magazine vibe meets pump.fun warmth.
   Fonts: Fraunces (display serif), Inter (body), Caveat (hand), Fredoka (UI accents).
   ========================================================= */

:root{
  --cream:    #fff6e8;
  --cream-2:  #ffe8c7;
  --paper:    #fdf3e1;
  --peach:    #ffb37a;
  --pink:     #ff7eb6;
  --hot-pink: #ff4d9d;
  --gold:     #ffc94d;
  --gold-2:   #ffa83d;
  --mint:     #6cf0c2;
  --violet:   #9b5de5;
  --plum:     #5e3aa0;
  --ink:      #1a1226;
  --ink-soft: #3b2a4a;
  --ink-faint:#5b4870;
  --line:     rgba(26,18,38,.10);
  --shadow-1: 0 14px 40px -16px rgba(80,30,90,.30);
  --shadow-2: 0 30px 90px -20px rgba(255,77,157,.35);
  --shadow-3: 0 24px 70px -22px rgba(80,30,90,.45);
  --rad:      22px;
  --rad-sm:   14px;
  --maxw:     1200px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;background:#fff6e8}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(900px 600px at 90% -8%, #ffd9a8 0%, transparent 60%),
    radial-gradient(700px 500px at -10% 8%, #ffd1e8 0%, transparent 55%),
    radial-gradient(900px 600px at 50% 120%, #ffe6b3 0%, transparent 55%),
    linear-gradient(180deg, #fff6e8 0%, #ffeeda 60%, #ffe2ec 100%);
  min-height:100vh;
  overflow-x:hidden;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","ss02";
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
em{font-style:italic}
strong{font-weight:600}
kbd{
  font-family:ui-monospace,Menlo,monospace;
  background:#fff;border:1px solid var(--line);border-bottom-width:2px;
  padding:1px 7px;border-radius:6px;font-size:.82em;
  box-shadow:0 1px 0 rgba(0,0,0,.04);
}
code{font-family:ui-monospace,Menlo,Consolas,monospace}
::selection{background:#ff7eb6;color:#fff}

/* =====================  decorative background  ===================== */
.bg-blobs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.blob{position:absolute;filter:blur(85px);opacity:.45;border-radius:50%}
.b1{width:520px;height:520px;background:#ffb37a;top:-160px;left:-140px;animation:float 22s ease-in-out infinite}
.b2{width:600px;height:600px;background:#ff7eb6;bottom:-220px;right:-200px;animation:float 26s ease-in-out infinite reverse}
.b3{width:380px;height:380px;background:#9be7c4;top:42%;left:62%;animation:float 30s ease-in-out infinite;opacity:.3}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%{transform:translate(40px,-50px) scale(1.06)}
}
.grain{
  position:absolute;inset:0;opacity:.07;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='1.2' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.55'/></svg>");
}

/* =====================  buttons  ===================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Fredoka',system-ui;font-weight:600;font-size:15px;line-height:1;
  padding:13px 20px;border-radius:999px;border:0;cursor:pointer;
  transition:transform .15s ease, box-shadow .2s ease, filter .2s, background .2s;
  white-space:nowrap;letter-spacing:.005em;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn-xl{padding:17px 26px;font-size:16.5px}
.btn.small{padding:9px 12px;font-size:13px}
.btn-primary{
  color:#2a0e1a;
  background:linear-gradient(135deg,#ffd166 0%,#ff7eb6 50%,#ff4d9d 100%);
  box-shadow:0 12px 26px -10px rgba(255,77,157,.65), inset 0 1px 0 rgba(255,255,255,.55);
}
.btn-primary:hover{filter:brightness(1.05);box-shadow:0 16px 34px -10px rgba(255,77,157,.85)}
.btn-gold{
  color:#3a2706;
  background:linear-gradient(135deg,#fff0b3,#ffc94d 60%,#ffa83d);
  box-shadow:0 10px 22px -10px rgba(255,168,61,.7);
}
.btn-cream{
  color:var(--ink);background:#fff;
  border:1px solid rgba(26,18,38,.08);
  box-shadow:0 6px 18px -10px rgba(80,30,90,.25);
}
.btn-cream:hover{background:#fffaf0}
.btn-danger{
  color:#fff;background:linear-gradient(135deg,#ff5b6e,#ff2d6f);
  box-shadow:0 8px 20px -8px rgba(255,45,111,.7);
}

/* =====================  nav  ===================== */
.nav{
  position:sticky;top:14px;z-index:50;
  margin:14px auto 0;max-width:var(--maxw);
  display:flex;align-items:center;gap:14px;
  padding:9px 12px 9px 16px;
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(22px) saturate(1.5);
  -webkit-backdrop-filter:blur(22px) saturate(1.5);
  border:1px solid rgba(255,255,255,.85);
  border-radius:999px;
  box-shadow:0 14px 40px -16px rgba(80,30,90,.25);
}
.brand{display:inline-flex;align-items:center;gap:10px;font-family:'Fredoka',system-ui;color:var(--ink)}
.brand-mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#fff0b3,#ff9ec7);box-shadow:inset 0 1px 0 rgba(255,255,255,.6)}
.brand-name{font-weight:700;font-size:18px;letter-spacing:-.005em}
.brand-name em{font-style:normal;background:linear-gradient(135deg,#ff7eb6,#ffa83d);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-tag{
  font-family:'Fredoka',system-ui;font-weight:700;font-size:11px;
  background:#1a1226;color:#ffd166;padding:5px 10px;border-radius:999px;letter-spacing:.06em;
}
.nav-links{display:flex;gap:18px;margin-left:14px;flex:1}
.nav-links a{font-weight:500;font-size:14.5px;color:var(--ink-soft);transition:color .2s;position:relative}
.nav-links a:hover{color:var(--hot-pink)}
.nav-cta{display:flex;align-items:center;gap:10px}
.ca-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border-radius:999px;cursor:pointer;border:0;
  background:rgba(26,18,38,.06);
  font-family:ui-monospace,Menlo,monospace;font-size:12.5px;color:var(--ink);
  transition:background .2s;
}
.ca-pill:hover{background:rgba(26,18,38,.12)}
.ca-label{font-weight:700;color:var(--hot-pink);letter-spacing:.04em}
.ca-copy{display:inline-flex;align-items:center;color:var(--ink-faint)}
.ca-pill.copied{background:rgba(30,166,114,.18)}
.ca-pill.copied .ca-copy{color:#1ba672}

@media (max-width:980px){
  .nav-links{display:none}
  .ca-pill .ca-text{display:none}
}
@media (max-width:640px){
  .nav{top:8px;margin:8px;padding:8px}
  .nav-cta .btn{padding:10px 14px;font-size:14px}
}

/* =========================================================
   HERO — contained banner art, tight copy
   ========================================================= */
.hero{
  position:relative;z-index:1;
  max-width:var(--maxw);
  margin:40px auto 0;
  padding:30px 24px 70px;
}
.hero-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;
}
.hero-copy{max-width:520px}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-soft);
  background:rgba(255,255,255,.7);
  padding:7px 13px;border-radius:999px;
  border:1px solid rgba(255,255,255,.9);
  box-shadow:0 4px 14px -8px rgba(80,30,90,.2);
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#1ec97a;box-shadow:0 0 0 6px rgba(30,201,122,.18)}

.hero-title{
  font-family:'Fraunces',Georgia,serif;
  font-weight:700;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
  font-size:clamp(38px, 5.4vw, 68px);
  line-height:1.0;letter-spacing:-.022em;
  margin:18px 0 12px;color:var(--ink);
}
.hero-title em{
  font-style:italic;font-variation-settings: "SOFT" 100, "WONK" 1;
  background:linear-gradient(115deg,#ff4d9d 0%,#ff8a3d 50%,#9b5de5 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-attrib{
  font-family:'Caveat',cursive;font-size:21px;color:var(--ink-soft);
  margin:0 0 18px;line-height:1.3;
}
.hero-lede{
  font-size:16.5px;color:var(--ink-soft);max-width:480px;margin:0 0 26px;line-height:1.65;
}
.hero-lede strong{
  color:var(--ink);font-weight:700;
  background:linear-gradient(120deg,transparent 0,transparent 8%,rgba(255,201,77,.55) 8%,rgba(255,126,182,.5) 92%,transparent 92%);
  padding:0 2px;
}
.hero-ctas{display:flex;flex-wrap:wrap;gap:10px}

/* ---- raised counter ---- */
.raised-card{
  display:flex;align-items:center;gap:14px;
  margin-top:24px;padding:14px 18px;
  background:linear-gradient(135deg,#fff8ec 0%,#ffe8d4 60%,#ffd1e8 100%);
  border:1px solid rgba(255,255,255,.85);
  border-radius:18px;
  box-shadow:0 14px 36px -18px rgba(255,77,157,.45), inset 0 1px 0 rgba(255,255,255,.7);
  text-decoration:none;color:var(--ink);
  transition:transform .2s ease, box-shadow .25s ease;
  max-width:520px;
}
.raised-card:hover{transform:translateY(-2px);box-shadow:0 20px 46px -18px rgba(255,77,157,.6)}
.raised-pulse{
  position:relative;flex:0 0 auto;width:36px;height:36px;
  display:grid;place-items:center;
}
.raised-dot{
  width:12px;height:12px;border-radius:50%;
  background:#1ec97a;
  box-shadow:0 0 0 4px rgba(30,201,122,.18);
  z-index:2;position:relative;
}
.raised-ring{
  position:absolute;inset:0;border-radius:50%;
  border:2px solid rgba(30,201,122,.5);
  animation:raised-ring 2.2s ease-out infinite;
}
@keyframes raised-ring{
  0%   { transform:scale(.5); opacity:.9 }
  100% { transform:scale(1.6); opacity:0  }
}
.raised-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.raised-kicker{
  font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--hot-pink);
}
.raised-kicker em{font-style:normal;color:#1ec97a;margin-left:6px}
.raised-amount{
  font-family:'Fraunces',Georgia,serif;font-weight:700;
  font-variation-settings:"SOFT" 100, "WONK" 1, "opsz" 144;
  font-size:30px;line-height:1.05;letter-spacing:-.015em;
  color:var(--ink);
  display:inline-flex;align-items:baseline;gap:10px;flex-wrap:wrap;
}
.raised-amount em{
  font-style:normal;font-family:'Inter',system-ui;font-weight:600;
  font-size:13px;letter-spacing:.04em;color:var(--ink-soft);
  background:rgba(26,18,38,.06);padding:4px 9px;border-radius:999px;
}
.raised-sub{font-size:12px;color:var(--ink-faint);line-height:1.4;margin-top:2px}
.raised-sub u{text-decoration:none;color:var(--ink);font-weight:600;border-bottom:1px dashed rgba(26,18,38,.25)}

@media (max-width:760px){
  .raised-amount{font-size:26px}
}

.hero-art{
  margin:0;position:relative;
  border-radius:24px;overflow:hidden;
  box-shadow:0 30px 80px -28px rgba(80,30,90,.45);
  background:#ffe2c0;
  transform:rotate(-1deg);
  transition:transform .4s ease;
}
.hero-art:hover{transform:rotate(0deg)}
.hero-art img{
  width:100%;height:auto;display:block;object-fit:cover;
}
.hero-cap{
  position:absolute;left:14px;bottom:14px;
  background:rgba(26,18,38,.78);color:#ffd166;
  padding:6px 12px;border-radius:999px;
  font-family:'Caveat',cursive;font-size:16px;backdrop-filter:blur(6px);
}

@media (max-width:880px){
  .hero{padding:14px 18px 50px}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-copy{max-width:none;order:2}
  .hero-art{order:1;transform:rotate(0deg);max-width:520px;margin:0 auto}
  .hero-title{font-size:clamp(34px,8vw,52px)}
}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{
  background:#1a1226;color:#ffd166;
  padding:18px 0;overflow:hidden;
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
  position:relative;z-index:2;
}
.marquee-track{display:flex;gap:0;white-space:nowrap;animation:tick 38s linear infinite;align-items:center}
.marquee-track > span{
  font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:600;
  font-size:24px;padding:0 22px;
  font-variation-settings:"SOFT" 100, "WONK" 1;
}
.marquee-track > i{font-style:normal;color:#ff7eb6;font-size:24px}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* =========================================================
   SECTION HEADS
   ========================================================= */
section{position:relative;z-index:1}
.section-head{max-width:880px;margin:0 auto 50px;text-align:center;padding:0 24px}
.kicker{
  display:inline-flex;align-items:center;gap:6px;
  font-size:11.5px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;color:var(--hot-pink);margin-bottom:14px;
}
.section-head h2{
  font-family:'Fraunces',Georgia,serif;font-weight:700;
  font-variation-settings:"SOFT" 100, "WONK" 1, "opsz" 144;
  font-size:clamp(30px,4.5vw,52px);line-height:1.05;margin:0 0 10px;letter-spacing:-.02em;
}
.section-head h2 em{
  font-style:italic;
  background:linear-gradient(115deg,#ff4d9d,#ff8a3d 60%,#9b5de5);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-sub{color:var(--ink-soft);font-size:16px;max-width:680px;margin:0 auto;line-height:1.7}

/* =========================================================
   STORY
   ========================================================= */
.story{padding:120px 24px 60px;max-width:1080px;margin:0 auto}
.story-block{
  display:grid;grid-template-columns:1.2fr .8fr;gap:60px;
  align-items:center;
  margin-bottom:90px;
}
.story-block.reverse{grid-template-columns:.8fr 1.2fr}
.story-block.reverse .story-text{order:2}
.story-block.reverse .polaroid{order:1}

.story-text{max-width:600px}
.story-text h3{
  font-family:'Fraunces',Georgia,serif;font-weight:700;
  font-variation-settings:"SOFT" 100, "WONK" 1;
  font-size:30px;line-height:1.15;margin:0 0 14px;letter-spacing:-.015em;
}
.story-text p{font-size:17px;color:var(--ink-soft);margin:0 0 16px;line-height:1.75}
.story-text p strong{color:var(--ink);font-weight:600}
.story-text .drop{font-size:18px}
.dropcap{
  font-family:'Fraunces',Georgia,serif;font-weight:900;
  font-size:74px;float:left;line-height:.85;margin:6px 10px 0 0;
  background:linear-gradient(135deg,#ff4d9d,#ffa83d);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  font-variation-settings:"SOFT" 100, "WONK" 1;
}
.quote-pull{
  font-family:'Fraunces',Georgia,serif;font-style:italic;font-weight:500;
  font-size:26px;line-height:1.25;color:var(--ink);
  border-left:4px solid var(--hot-pink);
  padding:6px 0 6px 18px;
  margin:18px 0;
  font-variation-settings:"SOFT" 100, "WONK" 1;
}
.quote-pull.soft{border-color:#ffa83d;font-size:22px;font-weight:400}
.quote-pull .cite{
  font-style:normal;font-family:'Caveat',cursive;font-size:18px;color:var(--ink-faint);
  margin-left:8px;
}

/* polaroid */
.polaroid{
  margin:0;background:#fff;padding:14px 14px 50px;
  border-radius:6px;
  box-shadow:0 25px 50px -22px rgba(80,30,90,.45), 0 4px 10px -4px rgba(0,0,0,.15);
  position:relative;
  max-width:440px;justify-self:center;
}
.polaroid img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:2px}
.polaroid figcaption{
  position:absolute;left:0;right:0;bottom:14px;
  text-align:center;font-family:'Caveat',cursive;font-size:22px;color:var(--ink-soft);
}
.polaroid .tape{
  position:absolute;width:120px;height:32px;
  background:linear-gradient(180deg,rgba(255,231,160,.6),rgba(255,200,100,.35));
  border:1px solid rgba(255,200,100,.4);
  top:-14px;left:50%;transform:translateX(-50%) rotate(-3deg);
  box-shadow:0 6px 14px -6px rgba(0,0,0,.2);
}
.pol-1{transform:rotate(-3deg)}
.pol-2{transform:rotate(2.4deg)}
.pol-3{transform:rotate(-1.6deg)}
.pol-charity{transform:rotate(2deg);max-width:380px}

@media (max-width:880px){
  .story-block, .story-block.reverse{grid-template-columns:1fr;gap:40px;margin-bottom:60px}
  .story-block.reverse .story-text{order:0}
  .story-block.reverse .polaroid{order:0}
  .polaroid{transform:none !important;margin:0 auto}
}

/* =========================================================
   QUOTE WALL
   ========================================================= */
.quote-wall{
  padding:80px 24px;
  background:linear-gradient(180deg,#1a1226,#2a1340);
  color:#fff6e8;margin-top:40px;
  border-radius:48px 48px 0 0;
  position:relative;overflow:hidden;
}
.quote-wall::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(800px 400px at 20% 0%, rgba(255,126,182,.25), transparent 60%),
    radial-gradient(800px 400px at 80% 100%, rgba(255,201,77,.18), transparent 60%);
  pointer-events:none;
}
.qw-head{
  font-family:'Fraunces',Georgia,serif;font-weight:700;
  text-align:center;font-size:clamp(24px,3.4vw,38px);max-width:700px;margin:0 auto 50px;
  letter-spacing:-.015em;color:#fff6e8;
  font-variation-settings:"SOFT" 100, "WONK" 1;
  position:relative;
}
.qw-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
  max-width:1080px;margin:0 auto;position:relative;
}
.qw{
  margin:0;padding:30px 26px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:20px;backdrop-filter:blur(8px);
  position:relative;
}
.qw::before{
  content:"\201C";position:absolute;top:-12px;left:18px;
  font-family:'Fraunces',Georgia,serif;font-size:90px;line-height:1;
  color:#ff7eb6;opacity:.35;
}
.qw p{
  font-family:'Fraunces',Georgia,serif;font-style:italic;
  font-size:22px;line-height:1.35;margin:0 0 16px;color:#fff6e8;
  font-variation-settings:"SOFT" 100, "WONK" 1;
}
.qw.center p{font-size:26px}
.qw cite{
  font-style:normal;font-family:'Caveat',cursive;font-size:22px;color:#ffd166;
}
@media (max-width:880px){.qw-grid{grid-template-columns:1fr;gap:18px}}

/* =========================================================
   CHARITY
   ========================================================= */
.charity{padding:90px 24px;max-width:1080px;margin:0 auto}
.charity-card{
  display:grid;grid-template-columns:1.3fr .9fr;gap:60px;align-items:center;
  padding:50px;
  background:#fff8ec;
  border-radius:32px;
  box-shadow:0 30px 80px -30px rgba(80,30,90,.30);
  position:relative;
  border:1px solid rgba(255,255,255,.8);
}
.charity-card::before{
  content:"";position:absolute;inset:0;border-radius:32px;
  background:radial-gradient(800px 400px at 100% 0%, rgba(255,126,182,.18), transparent 50%);
  pointer-events:none;
}
.charity-text h2{
  font-family:'Fraunces',Georgia,serif;font-weight:700;
  font-size:clamp(34px,4.4vw,52px);line-height:1.05;margin:8px 0 14px;letter-spacing:-.02em;
  font-variation-settings:"SOFT" 100, "WONK" 1;
}
.charity-text .lede{font-size:17px;color:var(--ink-soft);margin:0 0 14px;line-height:1.7}
.charity-text .lede strong{color:var(--ink)}
.charity-text .muted{font-size:15.5px;color:var(--ink-faint);margin:0 0 22px;line-height:1.7}
.charity-cta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.receipt-note{
  font-size:13.5px;color:var(--ink-faint);
  background:rgba(255,201,77,.18);
  border-left:3px solid #ffa83d;
  padding:10px 14px;border-radius:0 8px 8px 0;
  margin:0;
}
.charity-art{display:flex;justify-content:center}
@media (max-width:860px){.charity-card{grid-template-columns:1fr;padding:32px;gap:36px}}

/* =========================================================
   TOKEN  (slim: just CA)
   ========================================================= */
.token-slim{
  max-width:920px;margin:60px auto;padding:0 24px;
}
.ca-block{
  background:#fff;border-radius:22px;
  padding:24px 26px;border:1px solid rgba(26,18,38,.06);
  box-shadow:0 18px 44px -22px rgba(80,30,90,.28);
}
.ca-kicker{
  display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--hot-pink);margin-bottom:12px;
}
.ca-row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.ca-row code{
  flex:1;min-width:240px;
  background:#1a1226;color:#ffd166;padding:13px 16px;border-radius:11px;
  font-size:13.5px;letter-spacing:.02em;
  word-break:break-all;line-height:1.5;
}
.ca-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'Fredoka',system-ui;font-weight:600;font-size:13px;
  padding:7px 13px;border-radius:999px;
  background:rgba(26,18,38,.06);color:var(--ink-soft);
  border:1px solid rgba(26,18,38,.05);
  transition:background .2s,color .2s;
}
.chip:hover{background:rgba(255,77,157,.12);color:var(--hot-pink)}

/* =========================================================
   GAME
   ========================================================= */
.game{padding:90px 24px;max-width:1080px;margin:0 auto}
.game-frame{
  position:relative;padding:18px;
  background:#fff;
  border-radius:28px;
  border:1px solid rgba(26,18,38,.06);
  box-shadow:0 30px 80px -30px rgba(80,30,90,.40);
}
.game-hud{
  display:flex;gap:22px;flex-wrap:wrap;
  padding:8px 14px 16px;
}
.hud-item{display:flex;flex-direction:column;gap:2px;min-width:78px}
.hud-item span{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-faint);font-weight:700}
.hud-item strong{font-family:'Fraunces',Georgia,serif;font-size:24px;color:var(--ink);font-weight:700;letter-spacing:-.01em}
#gameCanvas{
  width:100%;display:block;border-radius:18px;
  background:linear-gradient(180deg,#9be7c4 0%,#7ad6ff 65%,#5cb5ff 100%);
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.06);
  touch-action:none;
}
.game-overlay{
  position:absolute;inset:18px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(26,18,38,.55);backdrop-filter:blur(10px);
  border-radius:18px;transition:opacity .25s ease;
}
.game-overlay.hidden{opacity:0;pointer-events:none}
.overlay-card{
  text-align:center;color:#fff;max-width:480px;padding:34px;
  background:linear-gradient(140deg,rgba(255,255,255,.18),rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.3);border-radius:22px;
  backdrop-filter:blur(12px);
}
.overlay-card h3{
  font-family:'Fraunces',Georgia,serif;font-weight:700;font-size:34px;margin:0 0 8px;
  letter-spacing:-.015em;font-variation-settings:"SOFT" 100, "WONK" 1;
}
.overlay-card p{margin:0 0 20px;color:rgba(255,255,255,.85);font-size:15px}
.controls{display:flex;flex-direction:column;gap:6px;margin-top:16px;font-size:13px;color:rgba(255,255,255,.85)}
.controls kbd{margin-right:6px;background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);color:#fff}

/* =========================================================
   LEADERBOARD
   ========================================================= */
.leaderboard{
  margin-top:24px;
  background:#fff;
  border:1px solid rgba(26,18,38,.06);
  border-radius:24px;
  padding:26px;
  box-shadow:0 18px 44px -22px rgba(80,30,90,.28);
}
.lb-head{margin-bottom:18px}
.lb-head h3{
  font-family:'Fraunces',Georgia,serif;font-weight:700;
  font-variation-settings:"SOFT" 100, "WONK" 1;
  font-size:30px;line-height:1.1;margin:6px 0 10px;letter-spacing:-.015em;
}
.lb-head h3 em{
  font-style:italic;
  background:linear-gradient(115deg,#ff4d9d,#ff8a3d 60%,#9b5de5);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.lb-note{
  margin:0;color:var(--ink-soft);font-size:14px;line-height:1.65;max-width:680px;
}
.lb-note strong{color:var(--ink);font-weight:600}

.lb-list{
  list-style:none;margin:18px 0 0;padding:0;
  display:flex;flex-direction:column;gap:8px;
  counter-reset:lb;
}
.lb-list li{
  display:grid;grid-template-columns:42px 1fr auto auto;gap:14px;align-items:center;
  padding:12px 14px;border-radius:14px;
  background:#fdf7ec;
  border:1px solid rgba(26,18,38,.05);
}
.lb-list li.lb-empty{
  display:block;text-align:center;color:var(--ink-faint);font-style:italic;background:transparent;border:0;
}
.lb-rank{
  font-family:'Fraunces',Georgia,serif;font-weight:700;font-size:22px;
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  background:#1a1226;color:#ffd166;
  font-variation-settings:"SOFT" 100, "WONK" 1;
}
.lb-list li:nth-child(1) .lb-rank{background:linear-gradient(135deg,#ffd166,#ffa83d);color:#3a2706}
.lb-list li:nth-child(2) .lb-rank{background:linear-gradient(135deg,#e6e9ee,#a8b0ba);color:#1a1226}
.lb-list li:nth-child(3) .lb-rank{background:linear-gradient(135deg,#e6a47c,#c47c4a);color:#3a1a08}

.lb-wallet{
  font-family:ui-monospace,Menlo,monospace;font-size:13.5px;
  color:var(--ink);
  display:inline-flex;align-items:center;gap:8px;
  text-decoration:none;
  word-break:break-all;
}
.lb-wallet:hover{color:var(--hot-pink)}
.lb-score{
  font-family:'Fraunces',Georgia,serif;font-weight:700;font-size:20px;
  font-variation-settings:"SOFT" 100, "WONK" 1;
  color:var(--ink);min-width:60px;text-align:right;
}
.lb-coins{
  display:inline-flex;align-items:center;gap:5px;
  font-family:'Fredoka',system-ui;font-weight:600;font-size:13px;
  color:#a85b00;background:rgba(255,201,77,.22);
  padding:3px 9px;border-radius:999px;white-space:nowrap;
}
.lb-coins::before{
  content:"";width:11px;height:11px;border-radius:50%;
  background:linear-gradient(135deg,#fff0b3,#ffa83d);
  box-shadow:inset 0 0 0 1px #a85b00;
}

@media (max-width:640px){
  .lb-list li{grid-template-columns:36px 1fr auto;gap:10px;padding:10px 12px}
  .lb-coins{display:none}
  .lb-wallet{font-size:12.5px}
  .lb-score{font-size:18px}
}

/* ---- submit form (rendered into the game-over overlay) ---- */
.lb-submit{
  display:flex;flex-direction:column;gap:8px;margin-top:14px;text-align:left;
}
.lb-submit label{
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  color:rgba(255,255,255,.85);
}
.lb-submit-row{display:flex;gap:8px}
.lb-submit input[type=text]{
  flex:1;min-width:0;
  font-family:ui-monospace,Menlo,monospace;font-size:13px;
  padding:11px 13px;border-radius:10px;border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.12);color:#fff;
}
.lb-submit input[type=text]::placeholder{color:rgba(255,255,255,.45)}
.lb-submit input[type=text]:focus{outline:none;border-color:rgba(255,255,255,.6);background:rgba(255,255,255,.18)}
.lb-submit .btn{padding:11px 16px;font-size:14px}
.lb-msg{
  font-size:12.5px;color:rgba(255,255,255,.78);min-height:16px;
}
.lb-msg.ok{color:#9be7c4}
.lb-msg.err{color:#ffb3b3}

/* =========================================================
   STUDIO
   ========================================================= */
.studio{padding:90px 24px 60px;max-width:1180px;margin:0 auto}
.studio-frame{
  display:grid;grid-template-columns:340px 1fr;gap:18px;
  padding:18px;
  background:#fff;
  border-radius:28px;
  border:1px solid rgba(26,18,38,.06);
  box-shadow:0 30px 80px -30px rgba(80,30,90,.40);
}
.studio-tools{
  display:flex;flex-direction:column;gap:14px;
  max-height:1080px;overflow:auto;padding:6px 8px 6px 0;
  scrollbar-width:thin;
}
.studio-tools::-webkit-scrollbar{width:6px}
.studio-tools::-webkit-scrollbar-thumb{background:rgba(26,18,38,.15);border-radius:3px}
.tool-group{
  background:#fdf7ec;border:1px solid rgba(26,18,38,.06);
  border-radius:16px;padding:14px;
}
.tool-group h4{
  font-family:'Fredoka',system-ui;margin:0 0 10px;font-size:13px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink-soft);font-weight:700;
  display:flex;align-items:baseline;gap:8px;
}
.tool-group h4 small{font-weight:500;text-transform:none;letter-spacing:0;color:var(--ink-faint);font-size:12px}
.tool-actions{display:flex;flex-direction:column;gap:8px;margin-top:6px}

.base-picker, .bg-picker{display:grid;grid-template-columns:repeat(6,1fr);gap:7px}
.base-btn{
  position:relative;
  aspect-ratio:1/1;border-radius:10px;border:2px solid transparent;cursor:pointer;
  background-size:cover;background-position:center;background-color:#fff;
  transition:transform .15s,border-color .2s, box-shadow .2s;
  overflow:hidden;
}
.base-btn.no-base{
  background:repeating-linear-gradient(45deg,#e8d8c0 0 6px,#fff 6px 12px);
  display:grid;place-items:center;color:#888;font-weight:700;font-size:18px;
}
.base-btn.base-illust{
  background:linear-gradient(135deg,#fff0d8,#ffe1ee);
  display:grid;place-items:center;
}
.base-btn.base-illust img{width:92%;height:92%;object-fit:contain}
.base-btn:hover{transform:scale(1.05)}
.base-btn.active{border-color:var(--hot-pink);box-shadow:0 0 0 3px rgba(255,77,157,.22)}
.base-btn .base-tag{
  position:absolute;bottom:2px;left:2px;right:2px;
  font-family:'Fredoka',system-ui;font-size:8.5px;font-weight:700;letter-spacing:.06em;
  background:rgba(26,18,38,.85);color:#ffd166;padding:2px 4px;border-radius:5px;
  text-transform:uppercase;
}

.bg-btn{
  aspect-ratio:1/1;border-radius:10px;border:2px solid transparent;cursor:pointer;
  transition:transform .15s,border-color .2s;
}
.bg-btn:hover{transform:scale(1.05)}
.bg-btn.active{border-color:var(--ink);box-shadow:0 0 0 3px rgba(26,18,38,.15)}

/* sticker tabs */
.sticker-tabs{display:flex;gap:4px;background:rgba(26,18,38,.05);border-radius:10px;padding:3px;margin-bottom:10px}
.sticker-tab{
  flex:1;border:0;background:transparent;cursor:pointer;
  padding:7px 8px;border-radius:8px;
  font-family:'Fredoka',system-ui;font-weight:600;font-size:12px;color:var(--ink-soft);
  transition:background .2s,color .2s;
}
.sticker-tab.active{background:#fff;color:var(--ink);box-shadow:0 2px 6px -2px rgba(80,30,90,.2)}

.sticker-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;max-height:260px;overflow:auto;padding-right:4px}
.sticker-grid::-webkit-scrollbar{width:5px}
.sticker-grid::-webkit-scrollbar-thumb{background:rgba(26,18,38,.15);border-radius:3px}
.sticker-grid button{
  aspect-ratio:1/1;border-radius:9px;border:1px solid rgba(26,18,38,.05);
  background:#fff;cursor:pointer;font-size:22px;display:grid;place-items:center;
  transition:transform .12s,background .2s,border-color .2s;
  padding:0;
}
.sticker-grid button:hover{transform:scale(1.08);background:#fff7e0;border-color:rgba(255,201,77,.5)}
.sticker-grid button.text-sticker{
  font-family:'Fredoka',system-ui;font-weight:700;font-size:11px;color:#7d3aa6;
}
.sticker-grid .add-text-row{
  grid-column:1/-1;display:flex;gap:6px;margin-top:4px;
}
.sticker-grid .add-text-row input{
  flex:1;padding:8px 10px;border-radius:8px;border:1px solid rgba(26,18,38,.1);
  font-family:Inter,system-ui;font-size:13px;
}
.sticker-grid .add-text-row button{
  aspect-ratio:auto;padding:8px 12px;font-size:12px;font-family:'Fredoka',system-ui;
  font-weight:600;color:var(--ink);background:#fff7e0;
}

.selected-controls .hint{margin:0;color:var(--ink-faint);font-size:13.5px}
.sliders{display:flex;flex-direction:column;gap:10px}
.sliders label{display:flex;flex-direction:column;font-size:11px;color:var(--ink-faint);font-weight:700;letter-spacing:.08em;text-transform:uppercase;gap:4px}
.sliders input[type=range]{width:100%;accent-color:#ff4d9d}
.sliders .row{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.sliders .row .btn{flex:1;min-width:80px}

.studio-canvas-wrap{
  background:repeating-conic-gradient(#f0e4cf 0% 25%, #fff6e8 0% 50%) 50% / 22px 22px;
  border-radius:18px;padding:14px;display:flex;flex-direction:column;align-items:center;gap:8px;
  border:1px solid rgba(26,18,38,.06);
}
#pfpCanvas{
  width:100%;max-width:660px;aspect-ratio:1/1;height:auto;
  border-radius:14px;background:#fff;
  box-shadow:0 24px 60px -22px rgba(80,30,90,.35);
  touch-action:none;cursor:crosshair;
}
.canvas-hint{margin:0;font-size:12.5px;color:var(--ink-faint);text-align:center;font-style:italic}

@media (max-width:880px){
  .studio-frame{grid-template-columns:1fr}
  .studio-tools{max-height:none}
  .sticker-grid{grid-template-columns:repeat(8,1fr)}
}

/* =========================================================
   ROADMAP
   ========================================================= */
.roadmap{padding:80px 24px;max-width:1080px;margin:0 auto}
.road-list{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  position:relative;
}
.road-list::before{
  content:"";position:absolute;left:0;right:0;top:36px;height:3px;
  background:repeating-linear-gradient(90deg,#1a1226 0 14px,transparent 14px 26px);
  opacity:.18;border-radius:2px;
}
.road-stop{
  background:#fff;border:1px solid rgba(26,18,38,.06);
  border-radius:22px;padding:28px;
  box-shadow:0 14px 40px -20px rgba(80,30,90,.3);
  position:relative;
}
.road-dot{
  display:grid;place-items:center;
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,#ffd166,#ff7eb6 60%,#ff4d9d);
  color:#1a1226;font-family:'Fraunces',Georgia,serif;font-weight:700;font-size:22px;
  box-shadow:0 10px 24px -8px rgba(255,77,157,.6);
  margin-bottom:18px;
}
.road-stop h3{font-family:'Fraunces',Georgia,serif;font-weight:700;font-size:22px;margin:0 0 10px;letter-spacing:-.015em}
.road-stop p{margin:0;color:var(--ink-soft);font-size:14.5px;line-height:1.7}
@media (max-width:880px){
  .road-list{grid-template-columns:1fr}
  .road-list::before{display:none}
}

/* =========================================================
   FOOTER
   ========================================================= */
.foot{
  margin-top:60px;
  background:linear-gradient(180deg,#1a1226 0%,#2a1340 100%);
  color:#f6e6c8;padding:70px 24px 30px;
}
.foot-inner{
  max-width:var(--maxw);margin:0 auto;
  display:grid;grid-template-columns:1.3fr 1.7fr;gap:50px;
}
.brand.light{color:#fff6e8}
.brand.light .brand-name em{background:linear-gradient(135deg,#ffd166,#ff7eb6);-webkit-background-clip:text;background-clip:text;color:transparent}
.foot p{color:rgba(246,230,200,.7);max-width:380px;font-size:14px;margin-top:14px;line-height:1.7}
.foot .ack{font-size:12.5px;color:rgba(246,230,200,.5);margin-top:10px}
.foot .ack a{color:#ffd166;text-decoration:underline;text-underline-offset:2px}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.foot-cols h5{font-family:'Fredoka',system-ui;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#ffd166;margin:0 0 14px;font-weight:700}
.foot-cols a{display:block;font-size:14px;padding:5px 0;color:rgba(246,230,200,.85);transition:color .2s}
.foot-cols a:hover{color:#fff}
.copy{
  text-align:center;color:rgba(246,230,200,.5);font-size:12.5px;
  margin:50px auto 0;padding-top:22px;max-width:var(--maxw);
  border-top:1px solid rgba(255,255,255,.08);font-family:'Caveat',cursive;font-size:18px;
}
@media (max-width:760px){
  .foot-inner{grid-template-columns:1fr}
}

/* =====================  reveal animation  ===================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease, transform .9s ease}
.reveal.visible{opacity:1;transform:none}
