/* ZNS Connect — pixel-faithful clone. Tokens extracted live from zns.bio (2026-05-29). */

:root {
  --background: 240 10% 4%;
  --foreground: 0 0% 98%;
  --card: 240 10% 6%;
  --card-foreground: 0 0% 98%;
  --popover: 240 10% 6%;
  --primary: 68 100% 50%;            /* lime / chartreuse signature */
  --primary-foreground: 240 10% 4%;
  --secondary: 174 72% 46%;          /* teal */
  --secondary-foreground: 240 10% 4%;
  --muted: 240 6% 12%;
  --muted-foreground: 240 5% 55%;
  --accent: 240 6% 14%;
  --accent-foreground: 0 0% 98%;
  --destructive: 0 72% 51%;
  --border: 240 6% 16%;
  --input: 240 6% 12%;
  --ring: 68 100% 50%;
  --radius: 1rem;

  --bg: hsl(var(--background));
  --fg: hsl(var(--foreground));
  --card-bg: hsl(var(--card));
  --lime: hsl(var(--primary));
  --teal: hsl(var(--secondary));
  --muted-bg: hsl(var(--muted));
  --muted-fg: hsl(var(--muted-foreground));
  --accent-bg: hsl(var(--accent));
  --border-c: hsl(var(--border));
  --red: hsl(var(--destructive));

  --maxw: 1200px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--bg);
  color: var(--fg);
  font-family: "Poppins", ui-sans-serif, system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
h1, h2, h3, .display { font-family: "Space Grotesk", "Poppins", sans-serif; letter-spacing: -0.02em; }
.num, .mono { font-family: "Inter", ui-sans-serif, sans-serif; font-variant-numeric: tabular-nums; }
img { display: block; max-width: 100%; }
.lime { color: var(--lime); }
.teal { color: var(--teal); }
.muted { color: var(--muted-fg); }

/* ---- background ambient glows ---- */
.glow-wrap { position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }
.glow { position: absolute; border-radius: 9999px; filter: blur(120px); opacity: 0.5; }
.glow.lime { width: 600px; height: 600px; background: hsl(68 100% 50% / 0.10); bottom: -200px; left: 50%; transform: translateX(-50%); }
.glow.green { width: 700px; height: 500px; background: hsl(140 60% 30% / 0.18); top: -150px; right: -150px; }
.glow.purple { width: 500px; height: 500px; background: hsl(270 60% 35% / 0.10); bottom: 10%; right: 5%; }

main, .page { position: relative; z-index: 1; }

/* ---- container ---- */
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

/* ---- nav ---- */
.nav-outer { position: sticky; top: 0; z-index: 50; padding: 12px 0; backdrop-filter: blur(8px); }
.nav {
  max-width: 1320px; margin: 0 auto; padding: 8px 14px;
  display: flex; align-items: center; gap: 6px;
  background: hsl(240 10% 7% / 0.85);
  border: 1px solid var(--border-c);
  border-radius: 9999px;
}
.nav-logo { display: flex; align-items: center; gap: 8px; padding: 0 8px; }
.nav-logo img { width: 34px; height: 34px; border-radius: 9px; }
.nav-items { display: flex; align-items: center; gap: 2px; margin-left: 6px; }
.nav-item {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 12px; border-radius: 9999px; font-size: 14px; font-weight: 500;
  color: hsl(0 0% 88%); white-space: nowrap; cursor: pointer; transition: background .15s, color .15s;
}
.nav-item:hover { background: var(--accent-bg); }
.nav-item.active { color: var(--lime); }
.nav-item .ico { width: 15px; height: 15px; opacity: .8; }
.nav-item .caret { font-size: 10px; opacity: .6; }
.nav-badge { font-size: 9px; font-weight: 700; padding: 2px 6px; border-radius: 9999px; text-transform: uppercase; letter-spacing: .04em; line-height: 1.2; }
.nav-badge.hot { background: hsl(25 95% 55%); color: #1a1a1a; }
.nav-badge.new { background: hsl(290 80% 60%); color: #fff; }
.nav-badge.live { background: var(--lime); color: hsl(var(--primary-foreground)); }
.nav-badge.soon { background: var(--muted-bg); color: var(--muted-fg); }
.nav-dd-wrap { position: relative; display: inline-flex; }
.nav-dd { position: absolute; top: 100%; left: 0; margin-top: 10px; min-width: 196px; background: hsl(240 10% 7% / 0.98); border: 1px solid var(--border-c); border-radius: 14px; padding: 6px; display: none; flex-direction: column; gap: 2px; box-shadow: 0 14px 34px rgba(0,0,0,.5); z-index: 60; }
.nav-dd::before { content: ""; position: absolute; top: -10px; left: 0; right: 0; height: 10px; }
.nav-dd-wrap:hover .nav-dd, .nav-dd-wrap.open .nav-dd { display: flex; }
.nav-dd-item { display: flex; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 10px; font-size: 13px; font-weight: 500; color: hsl(0 0% 88%); white-space: nowrap; }
.nav-dd-item:hover { background: var(--accent-bg); color: var(--lime); }
.nav-dd-item .ico { width: 15px; height: 15px; opacity: .8; }
.nav-right { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.btn-register { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border-radius: 9999px; border: 1px solid var(--lime); color: var(--fg); font-weight: 600; font-size: 14px; }
.btn-register .ico { width: 15px; height: 15px; }
.nav-cart { width: 20px; height: 20px; color: hsl(0 0% 80%); }
.nav-cart-btn { display: inline-grid; place-items: center; width: 38px; height: 38px; border-radius: 9999px; border: 1px solid var(--border-c); background: var(--card-bg); }

/* ---- Spice Flow AccountDisplay (Phase 2 — replaces ZNS "Connect Wallet" / connected dropdown) ---- */
#nav-account { position: relative; }
.ad-trigger { display: inline-flex; align-items: center; gap: 8px; padding: 6px 8px 6px 14px; border-radius: 9999px; border: 1px solid var(--border-c); background: var(--card-bg); cursor: pointer; color: var(--fg); font-family: inherit; transition: border-color .15s, background .15s; }
.ad-trigger:hover { border-color: hsl(68 100% 50% / 0.4); }
.ad-trigger.is-open { border-color: hsl(68 100% 50% / 0.55); }
.ad-trigger .ad-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 8px hsl(68 100% 50% / 0.7); }
.ad-trigger .ad-label { font-size: 14px; font-weight: 600; }
.ad-trigger .ad-sep { color: var(--muted-fg); }
.ad-trigger .ad-total { font-size: 14px; font-weight: 700; letter-spacing: .01em; }
.ad-trigger .ad-chev { display: grid; place-items: center; width: 24px; height: 24px; border-radius: 50%; background: var(--muted-bg); }
.ad-trigger .ad-chev .ico { width: 14px; height: 14px; color: var(--muted-fg); }

.ad-pop { position: absolute; top: calc(100% + 12px); right: 0; width: 360px; max-height: 78vh; overflow-y: auto; background: hsl(240 10% 5%); border: 1px solid var(--border-c); border-radius: 18px; box-shadow: 0 24px 64px hsl(0 0% 0% / 0.55); z-index: 60; }
.ad-pop[hidden], .sf-overlay[hidden], .ad-howto-body[hidden], .sf-tile-pop[hidden] { display: none; }
.ad-head { padding: 18px 18px 14px; }
.ad-name-row { display: flex; align-items: center; gap: 9px; margin-bottom: 10px; }
.ad-name { font-weight: 700; font-size: 14.5px; }
.ad-active { display: inline-flex; align-items: center; gap: 5px; padding: 2px 9px; border-radius: 9999px; background: hsl(68 100% 50% / 0.12); color: var(--lime); font-size: 11px; font-weight: 700; }
.ad-active i { width: 6px; height: 6px; border-radius: 50%; background: var(--lime); }
.ad-total-big { font-size: 30px; font-weight: 700; letter-spacing: -0.5px; line-height: 1.1; margin-bottom: 4px; }
.ad-breakdown { font-size: 12.5px; color: var(--muted-fg); margin-bottom: 13px; }
.ad-breakdown b { color: hsl(0 0% 80%); font-weight: 600; }
.ad-addr { display: inline-flex; align-items: center; gap: 7px; padding: 6px 12px; border-radius: 9999px; border: 1px solid var(--border-c); background: var(--muted-bg); color: hsl(0 0% 82%); font-family: inherit; font-size: 12.5px; cursor: pointer; }
.ad-addr:hover { background: var(--accent-bg); }
.ad-addr .ico { width: 13px; height: 13px; color: var(--muted-fg); }

.ad-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; padding: 0 18px 14px; }
.ad-actions button { display: inline-flex; align-items: center; justify-content: center; gap: 6px; height: 42px; border-radius: 12px; font-family: inherit; font-weight: 700; font-size: 13.5px; cursor: pointer; border: 1px solid transparent; }
.ad-actions .ico { width: 16px; height: 16px; }
.ad-deposit { background: var(--lime); color: hsl(var(--primary-foreground)); }
.ad-deposit:hover { filter: brightness(1.06); }
.ad-withdraw { background: var(--muted-bg); border-color: var(--border-c); color: var(--fg); }
.ad-withdraw:hover { background: var(--accent-bg); }

.ad-howto { display: flex; align-items: center; gap: 8px; width: 100%; padding: 11px 18px; border: none; border-top: 1px solid var(--border-c); background: none; color: var(--muted-fg); font-family: inherit; font-size: 12.5px; font-weight: 500; cursor: pointer; }
.ad-howto .ico { width: 15px; height: 15px; }
.ad-howto .ad-howto-chev { margin-left: auto; transition: transform .2s; }
.ad-howto.open .ad-howto-chev { transform: rotate(180deg); }
.ad-howto-body { padding: 0 18px 14px; font-size: 12.5px; line-height: 1.5; color: hsl(0 0% 72%); }

.ad-sec-head { display: flex; align-items: center; justify-content: space-between; padding: 11px 18px 6px; border-top: 1px solid var(--border-c); font-size: 10.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--muted-fg); }
.ad-sec-head .ct { font-weight: 600; letter-spacing: .02em; text-transform: none; }
.ad-list { padding: 0 8px 8px; }
.ad-row { display: flex; align-items: center; gap: 12px; width: 100%; padding: 9px 10px; border: none; border-radius: 12px; background: none; color: var(--fg); font-family: inherit; text-align: left; cursor: pointer; }
.ad-row:hover { background: var(--muted-bg); }
.ad-row.static { cursor: default; }
.ad-row.static:hover { background: none; }
.ad-row.is-selected { background: hsl(68 100% 50% / 0.08); }
.ad-ic { position: relative; width: 32px; height: 32px; flex-shrink: 0; }
.ad-ic .t { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; background: var(--muted-bg); }
.ad-ic .c { position: absolute; right: -3px; bottom: -3px; width: 15px; height: 15px; border-radius: 50%; border: 2px solid hsl(240 10% 5%); object-fit: cover; background: #fff; }
.ad-ic.dom { display: grid; place-items: center; }
.ad-ic .c.solo { position: static; width: 30px; height: 30px; border: none; }
.ad-row-info { flex: 1; min-width: 0; }
.ad-row-sym { display: flex; align-items: center; gap: 4px; font-weight: 700; font-size: 13.5px; }
.ad-tld { color: var(--lime); font-weight: 700; }
.ad-row-sub { font-size: 11.5px; color: var(--muted-fg); }
.ad-row-right { text-align: right; }
.ad-row-amt { font-weight: 700; font-size: 13.5px; }
.ad-row-usd { font-size: 11.5px; color: var(--muted-fg); }
.ad-pin { font-size: 10.5px; font-weight: 700; color: var(--lime); background: hsl(68 100% 50% / 0.12); padding: 3px 9px; border-radius: 9999px; }
.ad-tick .ico { width: 16px; height: 16px; color: var(--lime); }

/* ---- account-level Deposit / Withdraw modals ---- */
.sf-overlay { position: fixed; inset: 0; background: hsl(0 0% 0% / 0.62); backdrop-filter: blur(5px); display: grid; place-items: center; z-index: 200; padding: 24px; }
.sf-modal { width: 100%; max-width: 430px; background: hsl(240 10% 6%); border: 1px solid var(--border-c); border-radius: 20px; padding: 24px; position: relative; box-shadow: 0 24px 64px hsl(0 0% 0% / 0.5); }
.sf-modal h2 { font-size: 21px; margin-bottom: 6px; }
.sf-sub { color: var(--muted-fg); font-size: 13px; line-height: 1.45; margin-bottom: 18px; }
.sf-close { position: absolute; top: 16px; right: 16px; display: grid; place-items: center; width: 30px; height: 30px; border-radius: 50%; border: none; background: var(--muted-bg); color: var(--muted-fg); cursor: pointer; }
.sf-close:hover { background: var(--accent-bg); color: var(--fg); }
.sf-close .ico { width: 16px; height: 16px; }
.sf-label { font-size: 11px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--muted-fg); margin-bottom: 7px; }
.sf-tile { position: relative; display: flex; align-items: center; gap: 12px; padding: 12px 14px; border-radius: 14px; border: 1px solid var(--border-c); background: var(--muted-bg); cursor: pointer; margin-bottom: 12px; transition: border-color .15s; }
.sf-tile:hover { border-color: hsl(68 100% 50% / 0.4); }
.sf-tile.slim { padding: 11px 14px; }
.sf-tile-info { flex: 1; min-width: 0; }
.sf-tile-info .top { display: flex; align-items: center; gap: 7px; font-weight: 700; font-size: 14px; }
.sf-tile-info .top .chip { padding: 1px 8px; border-radius: 9999px; background: hsl(240 6% 18%); border: 1px solid var(--border-c); font-size: 11px; font-weight: 600; color: hsl(0 0% 78%); }
.sf-tile-info .bot { font-size: 11.5px; color: var(--muted-fg); margin-top: 2px; }
.sf-tile-info .name { font-weight: 700; font-size: 14px; }
.sf-tile-info .deliver { font-size: 11.5px; color: var(--muted-fg); }
.sf-tile-info .deliver b { color: hsl(0 0% 82%); }
.sf-chain-only { width: 26px; height: 26px; border-radius: 50%; object-fit: cover; background: #fff; flex-shrink: 0; }
.sf-tile-chev { display: grid; place-items: center; color: var(--muted-fg); }
.sf-tile-chev .ico { width: 18px; height: 18px; }
.sf-tile-pop { position: absolute; top: calc(100% + 6px); left: 0; right: 0; background: hsl(240 10% 7%); border: 1px solid var(--border-c); border-radius: 14px; box-shadow: 0 18px 44px hsl(0 0% 0% / 0.55); z-index: 10; padding: 6px; max-height: 260px; overflow-y: auto; }
.sf-amount { display: flex; align-items: center; gap: 10px; padding: 14px 16px; border-radius: 14px; border: 1px solid var(--border-c); background: var(--muted-bg); margin-bottom: 12px; }
.sf-amount input { flex: 1; min-width: 0; background: none; border: none; outline: none; color: var(--fg); font-family: "Inter", sans-serif; font-weight: 700; font-size: 26px; letter-spacing: -0.5px; }
.sf-amount .denom { font-weight: 700; font-size: 14px; }
.sf-amount .sf-max { padding: 6px 12px; border-radius: 9px; border: none; background: hsl(68 100% 50% / 0.14); color: var(--lime); font-family: inherit; font-size: 11px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; cursor: pointer; }
.sf-amount .sf-max:hover { background: hsl(68 100% 50% / 0.22); }
.sf-receive { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: hsl(0 0% 78%); margin: -2px 0 16px; }
.sf-receive .ico { width: 16px; height: 16px; color: var(--muted-fg); flex-shrink: 0; }
.sf-receive b { color: var(--fg); font-weight: 700; }
.sf-cta { display: flex; align-items: center; justify-content: center; gap: 7px; width: 100%; height: 46px; border-radius: 12px; border: none; background: var(--lime); color: hsl(var(--primary-foreground)); font-family: inherit; font-weight: 700; font-size: 14.5px; cursor: pointer; }
.sf-cta:hover { filter: brightness(1.06); }
.sf-cta .ico { width: 17px; height: 17px; }

/* ---- buttons ---- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; border-radius: 9999px; font-weight: 600; cursor: pointer; border: 1px solid transparent; transition: filter .15s, background .15s; font-family: inherit; }
.btn-primary { background: var(--lime); color: hsl(var(--primary-foreground)); padding: 13px 26px; font-size: 15px; }
.btn-primary:hover { filter: brightness(1.05); }
.btn-ghost { background: var(--muted-bg); color: var(--fg); border-color: var(--border-c); padding: 11px 20px; }
.btn-ghost:hover { background: var(--accent-bg); }
.btn-disabled { background: var(--muted-bg); color: var(--muted-fg); cursor: not-allowed; }

/* ---- chips / pills ---- */
.pill { display: inline-flex; align-items: center; gap: 8px; padding: 7px 16px; border-radius: 9999px; border: 1px solid var(--border-c); background: hsl(240 10% 8% / 0.6); font-size: 13px; font-weight: 500; }
.pill .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--lime); }
.eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 7px 16px; border-radius: 9999px; border: 1px solid hsl(68 100% 50% / 0.3); background: hsl(68 100% 50% / 0.06); color: var(--lime); font-size: 13px; font-weight: 600; }

/* ---- cards ---- */
.card { background: var(--card-bg); border: 1px solid var(--border-c); border-radius: var(--radius); }
.tile { background: var(--card-bg); border: 1px solid var(--border-c); border-radius: var(--radius); padding: 22px; }
.icon-tile { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; }
.icon-tile.lime { background: hsl(68 100% 50% / 0.12); color: var(--lime); }
.icon-tile.teal { background: hsl(174 72% 46% / 0.12); color: var(--teal); }
.icon-tile.purple { background: hsl(270 70% 60% / 0.14); color: hsl(270 80% 72%); }
.icon-tile.blue { background: hsl(210 90% 60% / 0.14); color: hsl(210 90% 70%); }

/* ---- section headers ---- */
.section { padding: 60px 0; }
.section-head { text-align: center; margin-bottom: 40px; }
.section-head h2 { font-size: 40px; font-weight: 700; }
.section-head p { color: var(--muted-fg); margin-top: 12px; font-size: 16px; }

/* ---- tags ---- */
.tag { display: inline-flex; align-items: center; gap: 5px; padding: 4px 10px; border-radius: 9999px; font-size: 11px; font-weight: 600; }
.tag.lime-soft { background: hsl(68 100% 50% / 0.10); color: var(--lime); border: 1px solid hsl(68 100% 50% / 0.25); }
.tag.green { background: hsl(140 60% 45% / 0.14); color: hsl(140 70% 60%); }
.tag.muted { background: var(--muted-bg); color: var(--muted-fg); }

/* ---- chain avatar ---- */
.chain-av { width: 28px; height: 28px; border-radius: 50%; object-fit: cover; background: var(--muted-bg); border: 1px solid var(--border-c); }

/* ---- footer ---- */
.footer { border-top: 1px solid var(--border-c); margin-top: 80px; padding: 50px 0 36px; position: relative; z-index: 1; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; }
.footer-brand { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.footer-brand img { width: 36px; height: 36px; border-radius: 9px; }
.footer-brand b { font-family: "Space Grotesk", sans-serif; font-size: 18px; }
.footer p { color: var(--muted-fg); font-size: 14px; max-width: 320px; }
.footer h4 { font-size: 13px; text-transform: uppercase; letter-spacing: .06em; color: var(--muted-fg); margin-bottom: 14px; }
.footer ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer li a { color: hsl(0 0% 82%); font-size: 14px; }
.footer li a:hover { color: var(--lime); }
.footer-bottom { max-width: var(--maxw); margin: 36px auto 0; padding: 22px 24px 0; border-top: 1px solid var(--border-c); display: flex; justify-content: space-between; color: var(--muted-fg); font-size: 13px; }

/* ---- utility ---- */
.row { display: flex; align-items: center; }
.gap8 { gap: 8px; } .gap12 { gap: 12px; } .gap16 { gap: 16px; } .gap24 { gap: 24px; }
.wrap { flex-wrap: wrap; }
.center { text-align: center; }
.grid { display: grid; }
.hidden { display: none; }
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}.mt40{margin-top:40px}

/* ---- progress bar ---- */
.progress { height: 8px; border-radius: 9999px; background: var(--muted-bg); overflow: hidden; }
.progress > span { display: block; height: 100%; border-radius: 9999px; background: linear-gradient(90deg, hsl(25 95% 55%), var(--lime)); }

/* ---- table ---- */
.tbl { width: 100%; border-collapse: collapse; }
.tbl th { text-align: left; font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted-fg); font-weight: 600; padding: 14px 16px; border-bottom: 1px solid var(--border-c); }
.tbl td { padding: 16px; border-bottom: 1px solid var(--border-c); font-size: 14px; }
.tbl tr:hover td { background: hsl(240 10% 8% / 0.5); }

@media (max-width: 980px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .nav-items { display: none; }
}

/* Phase 2 — Spice Flow per-action funding row (added to each on-chain action; host card UX otherwise unchanged) */
.payfund { margin-bottom: 14px; }
.payfund-lbl { font-size: 10.5px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; color: var(--muted-fg); margin-bottom: 6px; }
.pay-tile { position: relative; display: flex; align-items: center; gap: 10px; width: 100%; padding: 10px 12px; border-radius: 12px; border: 1px solid var(--border-c); background: var(--muted-bg); cursor: pointer; font-family: inherit; color: var(--fg); text-align: left; transition: border-color .15s; }
.pay-tile:hover { border-color: hsl(68 100% 50% / 0.4); }
.pay-tile .ad-ic { width: 28px; height: 28px; }
.pay-tile .ad-ic .c { width: 13px; height: 13px; border-color: hsl(240 10% 6%); }
.pay-info { display: flex; align-items: center; gap: 6px; flex: 1; min-width: 0; }
.pay-sym { font-weight: 700; font-size: 13.5px; }
.pay-info .chip { padding: 1px 8px; border-radius: 9999px; background: hsl(240 6% 18%); border: 1px solid var(--border-c); font-size: 11px; font-weight: 600; color: hsl(0 0% 78%); }
.pay-avail { font-size: 11.5px; color: var(--muted-fg); white-space: nowrap; }
.pay-tile .sf-tile-chev .ico { width: 17px; height: 17px; color: var(--muted-fg); }
.pay-pop { left: 0; right: 0; }
.paycost { display: flex; align-items: center; gap: 5px; font-size: 12px; color: hsl(0 0% 74%); margin-top: 8px; }
.paycost b { color: var(--fg); font-weight: 700; }
