:root{
  --bg:#060806;
  --bg-2:#0b0f0b;
  --panel:#0d120d;
  --panel-2:#0f150f;
  --line:rgba(159,195,154,.14);
  --glow:#9fc39a;          /* desaturated sage/mint */
  --glow-hi:#c7e3c1;
  --glow-dim:rgba(159,195,154,.30);
  --text:#d3ddce;
  --muted:#7f8d7a;
  --ink:#050605;
  --radius:18px;
  --maxw:1080px;
}

*{box-sizing:border-box}
/* the HTML `hidden` attribute must always win over author display rules */
[hidden]{display:none !important}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(1200px 700px at 50% -10%, rgba(159,195,154,.10), transparent 60%),
    radial-gradient(900px 600px at 80% 110%, rgba(159,195,154,.06), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:"Space Grotesk", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

/* drifting fog layer */
.fog{
  position:fixed; inset:-20% -20% -20% -20%; z-index:0; pointer-events:none;
  background:
    radial-gradient(420px 300px at 20% 30%, rgba(159,195,154,.05), transparent 70%),
    radial-gradient(520px 360px at 75% 60%, rgba(159,195,154,.04), transparent 70%);
  animation:drift 26s ease-in-out infinite alternate;
}
@keyframes drift{from{transform:translate3d(-2%, -1%,0)}to{transform:translate3d(2%, 2%,0)}}

section, header, footer, main{position:relative; z-index:1}
.section-title{
  font-family:"Archivo Black", system-ui, sans-serif;
  font-weight:400; letter-spacing:.5px;
  font-size:clamp(1.6rem, 3.5vw, 2.4rem);
  margin:0 0 .3em; color:#e7efe3;
}
.section-sub{color:var(--muted); margin:0 0 1.6em; font-size:1.02rem}

/* horns svg color */
[data-horns] svg{display:block}
[data-horns] .horn{fill:#10160f; stroke:var(--glow); stroke-width:2.2;
  filter:drop-shadow(0 0 6px var(--glow-dim));}

/* ---------- NAV ---------- */
.nav{
  display:flex; align-items:center; justify-content:space-between;
  max-width:var(--maxw); margin:0 auto; padding:20px 24px;
}
.brand{display:flex; align-items:center; gap:10px; text-decoration:none; color:#eaf2e6}
.brand-mark{width:34px; height:34px; display:block}
.brand-mark.small{width:24px;height:24px}
.brand-avatar{width:36px; height:36px; border-radius:50%; object-fit:cover;
  border:1px solid var(--glow-dim); box-shadow:0 0 14px -2px var(--glow-dim)}
.brand-name{font-family:"Archivo Black",sans-serif; letter-spacing:2px; font-size:1.15rem}
.nav-links{display:flex; gap:22px}
.nav-links a{color:var(--muted); text-decoration:none; font-weight:500; font-size:.95rem; transition:color .2s}
.nav-links a:hover{color:var(--glow-hi)}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 22px; border-radius:999px; font:inherit; font-weight:700;
  letter-spacing:.3px; cursor:pointer; text-decoration:none; border:1px solid transparent;
  transition:transform .12s ease, box-shadow .2s ease, background .2s, color .2s;
  user-select:none;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:linear-gradient(180deg, #b6d9ac, #7fae76);
  color:#0a1109; box-shadow:0 0 0 1px rgba(159,195,154,.5), 0 12px 40px -12px var(--glow-dim);
}
.btn-primary:hover{box-shadow:0 0 0 1px var(--glow), 0 18px 50px -14px rgba(159,195,154,.55)}
.btn-primary:disabled{opacity:.4; cursor:not-allowed; box-shadow:none}
.btn-ghost{background:rgba(159,195,154,.06); color:var(--glow-hi); border-color:var(--line)}
.btn-ghost:hover{background:rgba(159,195,154,.12); border-color:var(--glow-dim)}
.btn-text{background:none; color:var(--muted); padding:13px 10px}
.btn-text:hover{color:var(--glow-hi)}

/* ---------- HERO ---------- */
.hero{max-width:var(--maxw); margin:0 auto; padding:70px 24px 40px; text-align:center}
.hero-glow{
  position:absolute; left:50%; top:40%; width:640px; height:640px; transform:translate(-50%,-50%);
  background:radial-gradient(circle, rgba(159,195,154,.18), transparent 62%);
  filter:blur(20px); z-index:-1; pointer-events:none;
}
.sr-only{position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0 0 0 0); white-space:nowrap; border:0}
.live-badge{
  display:inline-flex; align-items:center; gap:9px; margin:0 auto 20px;
  padding:8px 18px; border-radius:999px; text-decoration:none;
  font-weight:700; font-size:.82rem; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--glow-hi); background:rgba(159,195,154,.08);
  border:1px solid var(--glow-dim);
  box-shadow:0 0 26px -6px var(--glow-dim); transition:background .2s, box-shadow .2s;
}
.live-badge:hover{background:rgba(159,195,154,.15); box-shadow:0 0 34px -6px var(--glow-dim)}
.live-dot{width:9px; height:9px; border-radius:50%; background:#7fe07a;
  box-shadow:0 0 0 0 rgba(127,224,122,.7); animation:pulse 1.6s ease-out infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(127,224,122,.65)}
  70%{box-shadow:0 0 0 10px rgba(127,224,122,0)}
  100%{box-shadow:0 0 0 0 rgba(127,224,122,0)}
}
.kicker{
  text-transform:uppercase; letter-spacing:4px; font-size:.78rem; font-weight:700;
  color:var(--glow); margin:0 0 24px;
}
.hero-mascot{
  width:clamp(120px, 22vw, 168px); aspect-ratio:1/1; border-radius:50%; object-fit:cover;
  display:block; margin:0 auto 26px; border:1px solid var(--glow-dim);
  box-shadow:0 0 60px -10px var(--glow-dim), inset 0 0 40px rgba(159,195,154,.1);
}
.hero-wordmark{
  width:min(560px, 88%); height:auto; display:block; margin:0 auto 10px;
  filter:drop-shadow(0 0 34px rgba(159,195,154,.28));
}
.tagline{
  font-family:"Archivo Black", sans-serif; letter-spacing:3px; text-transform:uppercase;
  font-size:clamp(1rem, 3vw, 1.35rem); color:#eef5ea; margin:0 0 22px;
}
.lede{max-width:620px; margin:0 auto 30px; color:#b8c6b3; font-size:1.12rem}
.lede em{color:var(--glow-hi); font-style:normal; font-weight:700}
.hero-cta{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}

/* ---------- TOOL ---------- */
.tool{max-width:var(--maxw); margin:0 auto; padding:40px 24px}
.tool-card{
  background:linear-gradient(180deg, var(--panel), var(--bg-2));
  border:1px solid var(--line); border-radius:calc(var(--radius) + 6px);
  padding:clamp(24px, 4vw, 48px); text-align:center;
  box-shadow:0 40px 120px -60px rgba(159,195,154,.25), inset 0 1px 0 rgba(255,255,255,.02);
}
.stage{display:flex; align-items:center; gap:22px; justify-content:center; flex-wrap:wrap; margin:14px 0 26px}
.slot{flex:1 1 300px; max-width:360px}
.arrow{color:var(--glow-dim); font-size:2rem; font-weight:700}

.dropzone{
  display:flex; align-items:center; justify-content:center; aspect-ratio:1/1; width:100%;
  border:1.5px dashed var(--glow-dim); border-radius:var(--radius); cursor:pointer;
  background:radial-gradient(circle at 50% 40%, rgba(159,195,154,.05), transparent 70%), var(--ink);
  overflow:hidden; transition:border-color .2s, background .2s;
}
.dropzone.drag{border-color:var(--glow); background:rgba(159,195,154,.08)}
.dz-empty{display:flex; flex-direction:column; align-items:center; gap:10px; color:var(--muted); padding:20px}
.dz-icon{width:52px; height:52px; opacity:.9}
.dz-text{font-size:.98rem}
.dz-text u{color:var(--glow-hi); text-decoration-color:var(--glow-dim)}
.dz-hint{font-size:.75rem; letter-spacing:1.5px; text-transform:uppercase; color:#5f6c5b}
.dz-preview{width:100%; height:100%; object-fit:cover; display:block}

.result{
  position:relative; aspect-ratio:1/1; width:100%; border-radius:var(--radius);
  background:radial-gradient(circle at 50% 45%, rgba(159,195,154,.10), transparent 65%), var(--ink);
  border:1px solid var(--line); overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.result-empty{color:#4f5b4c; font-size:.95rem; padding:20px}
.result-img{width:100%; height:100%; object-fit:cover; display:block;
  box-shadow:inset 0 0 60px rgba(159,195,154,.14)}
.result:has(.result-img:not([hidden])){box-shadow:0 0 44px -6px var(--glow-dim)}

.loader{position:absolute; inset:0; display:flex; flex-direction:column; gap:14px;
  align-items:center; justify-content:center; background:rgba(6,8,6,.72); backdrop-filter:blur(2px)}
.loader-ring{width:46px; height:46px; border-radius:50%;
  border:3px solid rgba(159,195,154,.18); border-top-color:var(--glow);
  animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-text{color:var(--glow); font-size:.9rem; letter-spacing:1px}

.tool-actions{display:flex; gap:12px; justify-content:center; flex-wrap:wrap}
.tool-note{min-height:1.2em; margin:14px 0 0; color:var(--muted); font-size:.9rem}
.tool-note.err{color:#e0a3a3}

/* ---------- HOW ---------- */
.how{max-width:var(--maxw); margin:0 auto; padding:70px 24px; text-align:center}
.steps{display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:18px; margin-top:30px}
.step{
  background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:28px 22px; text-align:left;
}
.step-n{font-family:"Archivo Black",sans-serif; color:var(--glow); font-size:.9rem; letter-spacing:2px}
.step h3{margin:.4em 0 .2em; color:#e7efe3; font-size:1.25rem}
.step p{margin:0; color:var(--muted); font-size:.96rem}

/* ---------- TOKEN ---------- */
.token{max-width:760px; margin:0 auto; padding:40px 24px 80px; text-align:center}
.token-inner{
  background:linear-gradient(180deg, var(--panel-2), var(--bg));
  border:1px solid var(--line); border-radius:calc(var(--radius) + 6px);
  padding:clamp(28px,5vw,56px);
  box-shadow:0 40px 120px -60px rgba(159,195,154,.22);
}
.token-mark{display:inline-block; width:64px; height:64px; margin-bottom:6px}
.ca{display:inline-flex; align-items:center; gap:10px; margin:6px 0 4px;
  background:var(--ink); border:1px solid var(--line); border-radius:12px; padding:8px 8px 8px 16px}
.ca code{color:var(--glow-hi); font-size:.9rem; word-break:break-all}
.ca-soon{color:var(--muted); font-size:.95rem; margin:6px 0 22px}
.token-cta{display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:8px}

/* ---------- FOOTER ---------- */
.foot{max-width:var(--maxw); margin:0 auto; padding:34px 24px 60px; display:flex;
  align-items:center; gap:14px; justify-content:center; text-align:center; color:#5c685a; flex-wrap:wrap}
.foot p{margin:0; font-size:.85rem}

@media (max-width:640px){
  .arrow{transform:rotate(90deg)}
  .nav-links{gap:16px}
  .nav-links a:not([data-x]){display:none}
}
