/* ============================================================
   FANNYDEALS shared stylesheet: "Midnight Neon" (dark)
   Used by store pages + blog. Mobile-first. Matches the homepage.
   Same class names as before; restyled dark.
   ============================================================ */

:root{
  --bg:#0B0E12;
  --bg-2:#0F141B;
  --panel:#141B24;
  --panel-2:#1A222D;
  --line:#26313F;
  --line-2:#33415270;
  --text:#EDF1F0;
  --muted:#8B98A8;
  --dim:#5C6776;

  --lime:#C6F135;
  --lime-deep:#A6D11A;
  --cyan:#36E0E0;
  --magenta:#FF4D8D;
  --amber:#FFC24B;

  /* legacy aliases mapped to neon palette so old rules keep working */
  --coral:var(--lime); --coral-deep:var(--lime-deep); --coral-soft:var(--cyan); --coral-tint:#1c2a16;
  --ink:var(--text); --ink-2:var(--text); --ink-3:var(--muted);
  --paper:var(--bg); --paper-2:var(--bg-2); --card:var(--panel);
  --blue:var(--cyan); --success:var(--lime); --warn:var(--amber); --error:var(--magenta);
  --n-100:var(--bg); --n-200:var(--line); --n-300:var(--line); --n-400:var(--dim);
  --n-500:var(--dim); --n-600:var(--muted); --n-700:var(--muted); --n-800:var(--text); --n-900:var(--text);

  --glow-lime:0 0 0 1px rgba(198,241,53,.35), 0 8px 30px rgba(198,241,53,.22);
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow-md:0 10px 30px rgba(0,0,0,.45);
  --shadow-lg:0 20px 60px rgba(0,0,0,.5);
  --shadow-coral:var(--glow-lime);

  --ui:"Plus Jakarta Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono:"Space Mono", ui-monospace, monospace;
  --display:var(--ui);
  --body:var(--ui);

  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-xl:30px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.8,.2,1);
  --tabbar-h:64px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--ui); color:var(--text); background:var(--bg);
  line-height:1.5; font-size:16px; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
body::before{
  content:""; position:fixed; inset:0; z-index:-3;
  background:
    radial-gradient(50% 40% at 82% -5%, rgba(54,224,224,.15), transparent 60%),
    radial-gradient(55% 45% at 5% 8%, rgba(198,241,53,.10), transparent 60%),
    var(--bg);
}
body::after{
  content:""; position:fixed; inset:0; z-index:-2; pointer-events:none; opacity:.5;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:54px 54px;
  -webkit-mask-image:radial-gradient(120% 80% at 50% 0%, #000 30%, transparent 78%);
          mask-image:radial-gradient(120% 80% at 50% 0%, #000 30%, transparent 78%);
}
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
:focus-visible{ outline:2px solid var(--cyan); outline-offset:3px; border-radius:6px; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:16px; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* type primitives */
.eyebrow{ font-family:var(--mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--lime); display:inline-flex; align-items:center; gap:.55em; }
.eyebrow::before{ content:""; width:10px; height:10px; border-radius:50%; background:var(--lime); box-shadow:0 0 12px var(--lime); }
h1,h2,h3{ font-family:var(--ui); font-weight:800; line-height:1.04; letter-spacing:-.02em; margin:0; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:1rem; margin:0 0 1.2rem; flex-wrap:wrap; }
.section-head h2{ font-size:clamp(1.4rem,5.5vw,2rem); }
.section-head .link-all{ font-family:var(--mono); font-weight:400; font-size:.82rem; color:var(--muted); display:inline-flex; align-items:center; gap:.4em; transition:color .2s,gap .2s; }
.section-head .link-all:hover{ color:var(--lime); gap:.7em; }

/* buttons */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-weight:700; font-size:.92rem; padding:.7rem 1.15rem; border-radius:12px; transition:transform .18s var(--ease),box-shadow .2s,background .2s,color .2s; white-space:nowrap; }
.btn-primary{ background:var(--lime); color:#0B0E12; box-shadow:var(--glow-lime); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 0 0 1px rgba(198,241,53,.5),0 12px 36px rgba(198,241,53,.32); }
.btn-primary:active{ transform:translateY(0); }
.btn-ghost{ border:1px solid var(--line); color:var(--text); }
.btn-ghost:hover{ border-color:var(--cyan); color:var(--cyan); transform:translateY(-2px); }
.btn-block{ width:100%; }

/* ---------- header ---------- */
header.site{ position:sticky; top:0; z-index:50; background:rgba(11,14,18,.72); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); }
.topbar{ display:flex; align-items:center; gap:.8rem; height:58px; }
.brand{ display:flex; align-items:center; gap:.5rem; font-family:var(--ui); font-weight:800; font-size:1.18rem; letter-spacing:-.03em; flex:none; }
.brand .mark{ width:28px; height:28px; border-radius:8px; flex:none; background:var(--lime); color:#0B0E12; display:grid; place-items:center; font-weight:800; box-shadow:0 0 16px rgba(198,241,53,.5); transform:rotate(-6deg); }
.brand .mark span{ transform:rotate(6deg); }
.brand b{ color:var(--lime); }
.store-switch{ display:flex; gap:.5rem; align-items:center; margin-left:auto; overflow-x:auto; scrollbar-width:none; -webkit-overflow-scrolling:touch; padding:.2rem; }
.store-switch::-webkit-scrollbar{ display:none; }
.store-pill{ display:inline-flex; align-items:center; gap:.45rem; padding:.4rem .7rem; border-radius:999px; border:1px solid var(--line); background:var(--panel); font-weight:700; font-size:.85rem; color:var(--muted); white-space:nowrap; transition:transform .15s var(--ease),border-color .2s,color .2s; flex:none; }
.store-pill:hover{ transform:translateY(-2px); border-color:var(--cyan); color:var(--text); }
.store-pill[aria-current="page"]{ background:var(--lime); color:#0B0E12; border-color:var(--lime); }
.store-pill .logo{ width:18px; height:18px; border-radius:5px; display:grid; place-items:center; font-size:.62rem; color:#fff; font-weight:800; flex:none; }
.store-pill.more{ border-style:dashed; color:var(--dim); }

/* ---------- hero (store/blog) ---------- */
.hero{ padding:clamp(1.8rem,6vw,3.4rem) 0 clamp(1.4rem,4vw,2.2rem); }
.hero h1{ font-size:clamp(2rem,9vw,3.4rem); }
.hero h1 .save{ color:var(--lime); }
.hero .ital{ font-style:italic; font-weight:500; }
.hero .lead{ font-size:1.05rem; color:var(--muted); max-width:48ch; margin:.9rem 0 1.3rem; }
.trust-row{ display:flex; align-items:center; gap:1rem 1.4rem; flex-wrap:wrap; margin-top:1.2rem; }
.trust-row .item{ display:flex; align-items:center; gap:.5rem; font-size:.86rem; color:var(--muted); font-weight:600; }
.trust-row .ic{ width:30px; height:30px; border-radius:8px; display:grid; place-items:center; background:var(--bg-2); border:1px solid var(--line); color:var(--lime); flex:none; }
.trust-row .num{ font-family:var(--ui); font-weight:800; font-size:1.05rem; color:var(--text); }

.store-hero{ display:flex; align-items:center; gap:1rem; padding:clamp(1.4rem,5vw,2.4rem) 0 1rem; }
.store-hero .store-logo-lg{ width:64px; height:64px; border-radius:18px; display:grid; place-items:center; font-family:var(--ui); font-weight:800; font-size:1.6rem; color:#fff; flex:none; box-shadow:var(--shadow-md); }
.store-hero .h-meta h1{ font-size:clamp(1.7rem,7vw,2.6rem); }
.store-hero .h-meta .sub{ color:var(--muted); font-size:.95rem; margin-top:.3rem; display:flex; align-items:center; gap:.6rem; flex-wrap:wrap; }
.store-hero .h-meta .sub .rating{ color:var(--amber); font-weight:700; }

/* page tabs (Coupons / How to use) */
.page-tabs{ display:flex; gap:.4rem; border-bottom:1px solid var(--line); margin-bottom:1.6rem; overflow-x:auto; scrollbar-width:none; }
.page-tabs::-webkit-scrollbar{ display:none; }
.page-tabs a{ padding:.7rem .2rem; margin-right:1.2rem; font-weight:700; font-size:.96rem; color:var(--muted); border-bottom:3px solid transparent; white-space:nowrap; transition:color .2s,border-color .2s; }
.page-tabs a:hover{ color:var(--text); }
.page-tabs a[aria-current="page"]{ color:var(--lime); border-color:var(--lime); }

/* search */
.search-shell{ position:relative; max-width:680px; margin-top:1.4rem; }
.search-box{ display:flex; align-items:center; gap:.5rem; background:var(--panel); border:1px solid var(--line); border-radius:15px; padding:.5rem .5rem .5rem .95rem; transition:border-color .2s,box-shadow .25s,transform .2s; }
.search-box:focus-within{ border-color:var(--lime); box-shadow:var(--glow-lime); transform:translateY(-2px); }
.search-box .glass{ color:var(--dim); flex:none; }
.search-box input{ flex:1; border:none; outline:none; background:none; color:var(--text); font-family:var(--mono); font-size:1rem; min-width:0; padding:.5rem 0; }
.search-box input::placeholder{ color:var(--dim); }
.search-box .go{ background:var(--lime); color:#0B0E12; font-weight:700; padding:.6rem 1.1rem; border-radius:11px; transition:transform .15s; flex:none; }
.search-box .go:hover{ transform:translateY(-2px); }
.search-tags{ display:flex; align-items:center; gap:.5rem; margin-top:.8rem; flex-wrap:wrap; }
.search-tags .lbl{ font-family:var(--mono); font-size:.72rem; color:var(--dim); }
.chip{ display:inline-flex; align-items:center; gap:.4rem; padding:.34rem .72rem; border-radius:999px; background:var(--panel); border:1px solid var(--line); font-size:.83rem; font-weight:600; color:var(--muted); transition:transform .15s var(--ease),border-color .2s,color .2s; }
.chip:hover{ transform:translateY(-2px); border-color:var(--cyan); color:var(--cyan); }
.chip .logo{ width:16px; height:16px; border-radius:5px; display:grid; place-items:center; font-size:.58rem; color:#fff; font-weight:800; }
.ac{ position:absolute; top:calc(100% + 8px); left:0; right:0; background:var(--panel); border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-lg); padding:.45rem; z-index:40; display:none; }
.ac.open{ display:block; animation:acIn .16s var(--ease); }
@keyframes acIn{ from{opacity:0;transform:translateY(-6px);} to{opacity:1;transform:none;} }
.ac .grp{ font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--dim); padding:.5rem .6rem .3rem; }
.ac .row{ display:flex; align-items:center; gap:.7rem; padding:.55rem .6rem; border-radius:10px; cursor:pointer; }
.ac .row:hover,.ac .row[aria-selected="true"]{ background:var(--panel-2); }
.ac .row .logo{ width:28px; height:28px; border-radius:8px; display:grid; place-items:center; color:#fff; font-weight:800; font-size:.78rem; flex:none; }
.ac .row .t{ font-weight:600; font-size:.92rem; }
.ac .row .c{ margin-left:auto; font-family:var(--mono); font-size:.74rem; color:var(--dim); }

/* sections */
section.block{ padding:clamp(2rem,6vw,3.4rem) 0; }

/* store feature cards (homepage of stores listing, if used) */
.store-cards{ display:grid; gap:1rem; grid-template-columns:1fr; }
.store-feature{ position:relative; display:flex; gap:1rem; align-items:center; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.1rem; box-shadow:var(--shadow-sm); overflow:hidden; transition:transform .25s var(--ease),box-shadow .25s,border-color .25s; }
.store-feature:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--cyan); }
.store-feature .store-logo-lg{ width:58px; height:58px; border-radius:16px; display:grid; place-items:center; font-family:var(--ui); font-weight:800; font-size:1.4rem; color:#fff; flex:none; transition:transform .25s var(--ease); }
.store-feature:hover .store-logo-lg{ transform:scale(1.06) rotate(-4deg); }
.store-feature .sf-body{ flex:1; min-width:0; }
.store-feature .sf-name{ font-weight:800; font-size:1.15rem; display:flex; align-items:center; gap:.4rem; }
.store-feature .sf-tag{ font-size:.82rem; color:var(--muted); margin:.15rem 0 .5rem; }
.store-feature .sf-stats{ display:flex; gap:.9rem; font-family:var(--mono); font-size:.76rem; color:var(--dim); flex-wrap:wrap; }
.store-feature .sf-stats b{ color:var(--text); }
.store-feature .sf-best{ margin-left:auto; text-align:center; flex:none; }
.store-feature .sf-best b{ font-family:var(--ui); font-size:1.5rem; color:var(--lime); display:block; line-height:1; }
.store-feature .sf-best span{ font-family:var(--mono); font-size:.66rem; color:var(--dim); text-transform:uppercase; }

/* ---------- coupon cards ---------- */
.grid{ display:grid; gap:1rem; grid-template-columns:1fr; }
.card{ position:relative; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.15rem; box-shadow:var(--shadow-sm); overflow:hidden; transition:transform .25s var(--ease),box-shadow .25s,border-color .25s; display:flex; flex-direction:column; }
.card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--cyan); }
.ribbon{ position:absolute; top:14px; right:-34px; transform:rotate(45deg); background:var(--lime); color:#0B0E12; font-size:.64rem; font-weight:800; letter-spacing:.06em; text-transform:uppercase; padding:.28rem 2.6rem; box-shadow:var(--shadow-sm); }
.card-top{ display:flex; align-items:center; gap:.7rem; margin-bottom:.8rem; }
.store-logo{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; font-family:var(--ui); font-weight:800; font-size:1.1rem; color:#fff; flex:none; transition:transform .25s var(--ease); }
.card:hover .store-logo{ transform:scale(1.06) rotate(-3deg); }
.card-top .meta .name{ font-weight:700; font-size:.98rem; display:flex; align-items:center; gap:.35rem; flex-wrap:wrap; }
.card-top .meta .cat{ font-family:var(--mono); font-size:.72rem; color:var(--dim); }
.fav{ margin-left:auto; width:36px; height:36px; border-radius:50%; display:grid; place-items:center; color:var(--dim); border:1px solid var(--line); transition:transform .2s,color .2s,border-color .2s; flex:none; }
.fav:hover{ color:var(--magenta); border-color:var(--magenta); transform:scale(1.1); }
.fav.on{ color:var(--magenta); border-color:var(--magenta); }
.fav.on svg{ fill:currentColor; animation:pop .3s var(--ease); }
@keyframes pop{ 0%{transform:scale(.6);} 60%{transform:scale(1.25);} 100%{transform:scale(1);} }
.discount{ font-family:var(--ui); font-weight:800; font-size:1.9rem; line-height:1; letter-spacing:-.03em; color:var(--text); margin:.15rem 0; }
.discount em{ font-style:normal; color:var(--lime); }
.deal-desc{ font-size:.9rem; color:var(--muted); margin:.3rem 0 .9rem; }
.verified-badge{ display:inline-flex; align-items:center; gap:.35rem; font-family:var(--mono); font-size:.66rem; font-weight:700; color:var(--lime); border:1px solid rgba(198,241,53,.4); padding:.16rem .5rem; border-radius:999px; text-transform:uppercase; letter-spacing:.04em; }
.verified-badge svg{ width:12px; height:12px; }
.card-stats{ display:flex; gap:.9rem; margin-bottom:.9rem; font-family:var(--mono); font-size:.74rem; color:var(--dim); flex-wrap:wrap; }
.card-stats .s{ display:flex; align-items:center; gap:.3rem; }
.card-stats .s b{ color:var(--text); font-weight:700; }

/* prominent "how to use" notice inside each coupon */
.how-note{ display:flex; align-items:center; gap:.55rem; margin-bottom:.7rem; padding:.65rem .75rem; border-radius:11px; background:rgba(255,194,75,.12); border:1px solid rgba(255,194,75,.5); color:var(--amber); font-size:.84rem; font-weight:600; line-height:1.3; }
.how-note b{ color:#FFE0A3; }
.how-note .how-ic{ flex:none; width:20px; height:20px; border-radius:50%; background:var(--amber); color:#0B0E12; display:grid; place-items:center; font-weight:800; font-size:.8rem; }

/* store-site visit button inside a coupon */
.store-link{ display:flex; align-items:center; justify-content:center; gap:.45rem; margin-bottom:.7rem; padding:.6rem; border:1px solid var(--line); border-radius:11px; background:var(--bg-2); color:var(--cyan); font-family:var(--mono); font-weight:700; font-size:.84rem; transition:border-color .2s,color .2s,transform .15s,background .2s; }
.store-link:hover{ border-color:var(--cyan); transform:translateY(-2px); }
.store-link svg{ width:14px; height:14px; }

.reveal{ margin-top:auto; position:relative; display:flex; align-items:stretch; border-radius:12px; overflow:hidden; border:1px dashed var(--line); background:var(--bg-2); }
.reveal .codepart{ flex:1; display:grid; place-items:center; padding:.75rem; font-family:var(--mono); font-weight:700; font-size:1rem; letter-spacing:.1em; color:var(--text); }
.reveal .codepart .blur{ filter:blur(5px); user-select:none; transition:filter .25s; }
.reveal.shown .codepart .blur{ filter:none; }
.reveal .getbtn{ background:var(--lime); color:#0B0E12; font-weight:700; font-size:.85rem; padding:0 1.1rem; display:grid; place-items:center; transition:background .2s; white-space:nowrap; }
.reveal .getbtn:hover{ background:var(--cyan); }
.reveal.copied .getbtn{ background:var(--cyan); }

/* categories */
.cat-grid{ display:grid; gap:.7rem; grid-template-columns:repeat(2,1fr); }
.cat-card{ position:relative; border-radius:var(--r-md); padding:1rem; overflow:hidden; background:var(--panel); border:1px solid var(--line); box-shadow:var(--shadow-sm); transition:transform .22s var(--ease),box-shadow .22s,border-color .2s; display:flex; flex-direction:column; gap:.5rem; min-height:108px; }
.cat-card:hover{ transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--cyan); }
.cat-card .emoji{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center; font-size:1.25rem; background:var(--bg-2); border:1px solid var(--line); transition:transform .25s var(--ease); }
.cat-card:hover .emoji{ transform:scale(1.12) rotate(-6deg); }
.cat-card .ct{ font-weight:700; font-size:.95rem; }
.cat-card .cn{ font-family:var(--mono); font-size:.72rem; color:var(--dim); margin-top:auto; }

/* stat band */
.statband{ background:var(--panel); border:1px solid var(--line); color:var(--text); border-radius:var(--r-xl); padding:clamp(1.6rem,5vw,2.4rem); position:relative; overflow:hidden; }
.statband::before{ content:""; position:absolute; inset:0; background:radial-gradient(60% 120% at 100% 0%,rgba(54,224,224,.18),transparent 55%),radial-gradient(50% 90% at 0% 100%,rgba(198,241,53,.14),transparent 55%); }
.statband .inner{ position:relative; display:grid; grid-template-columns:repeat(2,1fr); gap:1.4rem; text-align:center; }
.statband .stat b{ font-family:var(--ui); font-weight:800; font-size:clamp(1.7rem,7vw,2.6rem); display:block; line-height:1; color:var(--lime); }
.statband .stat span{ font-family:var(--mono); font-size:.7rem; color:var(--muted); margin-top:.45rem; display:block; text-transform:uppercase; letter-spacing:.05em; }

/* guide / prose */
.prose{ max-width:720px; }
.prose h2{ font-size:clamp(1.4rem,5vw,1.9rem); margin:2rem 0 .8rem; }
.prose h3{ font-size:1.15rem; margin:1.6rem 0 .5rem; font-family:var(--ui); font-weight:700; }
.prose p{ color:var(--muted); margin:.6rem 0; }
.prose a{ color:var(--cyan); text-decoration:underline; text-underline-offset:2px; }
.prose ol,.prose ul{ color:var(--muted); padding-left:1.2rem; margin:.6rem 0; }
.prose li{ margin:.5rem 0; }
.steps{ counter-reset:step; list-style:none; padding:0; display:grid; gap:.8rem; }
.steps li{ position:relative; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-md); padding:1rem 1rem 1rem 3.2rem; box-shadow:var(--shadow-sm); color:var(--muted); }
.steps li::before{ counter-increment:step; content:counter(step); position:absolute; left:.9rem; top:1rem; width:28px; height:28px; border-radius:9px; background:var(--lime); color:#0B0E12; font-family:var(--ui); font-weight:800; display:grid; place-items:center; font-size:.95rem; box-shadow:var(--glow-lime); }
.steps li b{ display:block; margin-bottom:.15rem; color:var(--text); }

/* newsletter + faq */
.news{ background:linear-gradient(135deg,var(--panel),var(--bg-2)); border:1px solid var(--line); border-radius:var(--r-xl); padding:clamp(1.6rem,5vw,2.4rem); position:relative; overflow:hidden; box-shadow:var(--shadow-md); }
.news::before{ content:""; position:absolute; right:-60px; top:-60px; width:240px; height:240px; border-radius:50%; background:radial-gradient(circle,rgba(54,224,224,.2),transparent 70%); }
.news h2{ font-size:clamp(1.4rem,5vw,2rem); position:relative; }
.news p{ color:var(--muted); margin:.6rem 0 1rem; max-width:42ch; position:relative; }
.news-form{ display:flex; gap:.5rem; background:var(--bg-2); border:1px solid var(--line); border-radius:13px; padding:.45rem; position:relative; transition:border-color .2s,box-shadow .2s; }
.news-form:focus-within{ border-color:var(--lime); box-shadow:var(--glow-lime); }
.news-form input{ flex:1; border:none; background:none; outline:none; color:var(--text); font-family:var(--mono); font-size:.95rem; padding:.5rem .6rem; min-width:0; }
.news .fine{ font-family:var(--mono); font-size:.7rem; color:var(--dim); margin-top:.7rem; position:relative; }
.faq{ display:grid; gap:.6rem; max-width:760px; }
.faq details{ background:var(--panel); border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--shadow-sm); transition:border-color .2s; }
.faq details[open]{ border-color:var(--cyan); }
.faq summary{ list-style:none; cursor:pointer; padding:1rem; font-weight:700; font-size:.98rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .pm{ width:26px; height:26px; border-radius:8px; background:var(--bg-2); border:1px solid var(--line); color:var(--lime); display:grid; place-items:center; font-weight:800; flex:none; transition:transform .25s var(--ease); }
.faq details[open] summary .pm{ transform:rotate(135deg); }
.faq .answer{ padding:0 1rem 1rem; color:var(--muted); font-size:.94rem; }

/* footer */
footer.site{ margin-top:2.4rem; background:var(--bg-2); border-top:1px solid var(--line); color:var(--muted); padding:2.4rem 0 calc(1.6rem + var(--tabbar-h)); }
footer .brand{ color:var(--text); margin-bottom:.7rem; }
footer .blurb{ font-size:.88rem; max-width:38ch; }
.foot-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.6rem; margin-top:1.6rem; }
footer h4{ color:var(--dim); font-family:var(--mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; margin:0 0 .9rem; font-weight:700; }
footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; }
footer ul a{ font-size:.9rem; transition:color .2s; }
footer ul a:hover{ color:var(--lime); }
.foot-bottom{ border-top:1px solid var(--line); margin-top:1.8rem; padding-top:1.2rem; font-family:var(--mono); font-size:.74rem; color:var(--dim); }

/* mobile bottom tab bar */
.tabbar{ position:fixed; left:0; right:0; bottom:0; z-index:60; height:var(--tabbar-h); background:rgba(15,20,27,.94); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px); border-top:1px solid var(--line); display:flex; padding-bottom:env(safe-area-inset-bottom); }
.tabbar a{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.15rem; font-family:var(--mono); font-size:.62rem; color:var(--dim); transition:color .2s; }
.tabbar a svg{ width:21px; height:21px; }
.tabbar a[aria-current="page"]{ color:var(--lime); }
.tabbar a.cta{ color:var(--lime); }
.tabbar a.cta .ico{ width:46px; height:46px; margin-top:-22px; border-radius:50%; background:var(--lime); box-shadow:0 0 18px rgba(198,241,53,.5); display:grid; place-items:center; border:4px solid var(--bg); }
.tabbar a.cta span{ color:var(--lime); margin-top:.1rem; }

/* toast */
.toast{ position:fixed; left:50%; bottom:calc(var(--tabbar-h) + 18px); transform:translateX(-50%) translateY(160%); background:var(--lime); color:#0B0E12; padding:.8rem 1.1rem; border-radius:12px; font-family:var(--mono); font-weight:700; font-size:.86rem; box-shadow:0 0 30px rgba(198,241,53,.4); z-index:90; display:flex; align-items:center; gap:.55rem; max-width:90vw; transition:transform .35s var(--ease); }
.toast.show{ transform:translateX(-50%) translateY(0); }
.toast .ic{ display:grid; place-items:center; flex:none; }

/* scroll reveal */
.fx{ opacity:0; transform:translateY(20px); transition:opacity .6s var(--ease),transform .6s var(--ease); }
.fx.in{ opacity:1; transform:none; }

/* responsive scale-up */
@media (min-width:640px){
  .grid{ grid-template-columns:repeat(2,1fr); }
  .cat-grid{ grid-template-columns:repeat(3,1fr); }
  .statband .inner{ grid-template-columns:repeat(4,1fr); }
  .foot-grid{ grid-template-columns:1fr 1fr 1fr; }
}
@media (min-width:900px){
  .wrap{ padding-inline:22px; }
  .topbar{ height:64px; }
  .grid{ grid-template-columns:repeat(3,1fr); }
  .cat-grid{ grid-template-columns:repeat(5,1fr); }
  .news .news-grid{ display:grid; grid-template-columns:1.2fr .8fr; gap:2rem; align-items:center; }
  .foot-grid{ grid-template-columns:1.4fr 1fr 1fr 1fr; }
  .tabbar{ display:none; }
  footer.site{ padding-bottom:2rem; }
  .toast{ bottom:24px; }
  .desktop-nav{ display:flex !important; }
}
@media (min-width:1100px){ .store-cards{ grid-template-columns:1fr 1fr; } }

.desktop-nav{ display:none; gap:1.2rem; align-items:center; }
.desktop-nav a{ font-weight:600; font-size:.92rem; color:var(--muted); }
.desktop-nav a:hover{ color:var(--lime); }

@media (prefers-reduced-motion:reduce){ *{ animation:none !important; transition:none !important; } .fx{ opacity:1; transform:none; } }
