/* ============================================================
   RAZVMARKET  ·  brutalist monochrome FiveM marketplace (demo)
   Build by Razv.dev
   ============================================================ */

:root{
  /* ink scale (dark) */
  --ink:#0A0A0A; --ink-raise:#101010; --ink-sink:#070707;
  /* paper scale (inverted slabs) */
  --paper:#FAFAFA; --paper-sink:#EDEDEC;
  /* text on dark */
  --text-hi:#FAFAFA; --text-mid:#B5B5BA; --text-lo:#909098;
  /* text on paper */
  --text-inv-hi:#0A0A0A; --text-inv-mid:#3A3A3C;
  /* lines on dark */
  --line-hair:rgba(250,250,250,.10);
  --line-mid:rgba(250,250,250,.22);
  --line-hi:rgba(250,250,250,.55);
  --line-solid:#FAFAFA;
  --line-inv:rgba(10,10,10,.16);
  /* tier fills */
  --fill-001:rgba(250,250,250,.04);
  --fill-002:rgba(250,250,250,.08);
  --fill-003:rgba(250,250,250,.14);
  --ghost:rgba(250,250,250,.09);

  --max:1240px;
  --ease:cubic-bezier(.16,1,.3,1);
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  background:var(--ink);
  color:var(--text-hi);
  font-family:'Hanken Grotesk',system-ui,sans-serif;
  font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select{font-family:inherit}
img,svg{display:block;max-width:100%}
ol,ul{list-style:none}

.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

.skip{position:absolute;left:-999px;top:0;z-index:200;background:var(--paper);color:var(--ink);padding:10px 16px;font-weight:700}
.skip:focus{left:8px;top:8px}

:focus-visible{outline:2px solid var(--line-solid);outline-offset:2px}

/* ============ DISPLAY TYPE ============ */
.hero-h,.sec-h,.cta-h,.how-h{
  font-family:'Clash Display','Hanken Grotesk',sans-serif;
  font-weight:700;text-transform:uppercase;letter-spacing:-.03em;line-height:.96;
}

/* ============ PROMO ============ */
.promo{
  background:var(--paper);color:var(--ink);
  text-align:center;font-size:12.5px;font-weight:600;letter-spacing:.01em;
  padding:9px 16px;
}
.promo .mono{font-size:11px;letter-spacing:.08em}
.promo b{font-weight:800}

/* ============ NAV ============ */
.nav{position:sticky;top:0;z-index:100;background:rgba(10,10,10,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-hair);transition:border-color .2s,background .2s}
.nav.stuck{border-bottom:2px solid var(--line-mid);background:rgba(10,10,10,.94)}
.nav-row{display:flex;align-items:center;gap:22px;height:66px}

.brand{font-family:'Clash Display',sans-serif;font-weight:700;font-size:21px;letter-spacing:-.02em;color:var(--text-hi);white-space:nowrap}
.brand .dot{display:inline-block;width:.34em;height:.34em;background:currentColor;margin-left:1px;vertical-align:baseline}

.nav-links{display:flex;gap:24px;margin-left:6px}
.nav-links a{font-size:14px;font-weight:500;color:var(--text-mid);padding:6px 0;border-bottom:1px solid transparent;transition:color .15s,border-color .15s}
.nav-links a:hover{color:var(--text-hi);border-bottom-color:var(--line-hi)}

.nav-search{display:flex;align-items:center;gap:9px;flex:1;max-width:340px;margin-left:auto;
  background:var(--ink-sink);border:1px solid var(--line-hair);padding:9px 13px}
.nav-search svg{width:15px;height:15px;flex-shrink:0;stroke:var(--text-lo);fill:none;stroke-width:2}
.nav-search input{width:100%;background:none;border:0;color:var(--text-hi);font-family:'JetBrains Mono',monospace;font-size:12px;outline:none}
.nav-search input::placeholder{color:var(--text-lo)}

.nav-right{display:flex;align-items:center;gap:14px}
.signin{font-size:14px;font-weight:500;color:var(--text-mid)}
.signin:hover{color:var(--text-hi)}
.cart-pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line-mid);
  padding:9px 14px;font-size:12px;transition:border-color .15s,border-width .15s}
.cart-pill:hover{border-color:var(--line-hi)}
.cart-pill.pulse{animation:pulse .45s var(--ease)}
@keyframes pulse{0%{outline:1px solid var(--line-hi);outline-offset:0}100%{outline:1px solid transparent;outline-offset:6px}}
.cart-sum{color:var(--text-hi);font-weight:700}
.cart-count{background:var(--paper);color:var(--ink);font-weight:700;font-size:11px;padding:1px 7px;min-width:20px;text-align:center}

.hamburger{display:none;flex-direction:column;gap:5px;width:42px;height:38px;border:1px solid var(--line-mid);align-items:center;justify-content:center}
.hamburger span{width:18px;height:2px;background:var(--text-hi);transition:.2s}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.drawer{display:none;flex-direction:column;border-top:1px solid var(--line-hair);background:var(--ink-sink)}
.drawer:not([hidden]){display:flex}
.drawer a{padding:15px 28px;border-bottom:1px solid var(--line-hair);font-weight:600;color:var(--text-mid)}
.drawer a:hover{color:var(--text-hi);background:var(--ink-raise)}
.drawer .drawer-cta{color:var(--text-hi)}
.drawer-search{padding:14px 28px;border-bottom:1px solid var(--line-hair)}
.drawer-search input{width:100%;background:var(--ink-raise);border:1px solid var(--line-mid);color:var(--text-hi);font-family:'JetBrains Mono',monospace;font-size:13px;padding:11px 13px;outline:none}
.drawer-search input:focus{border-color:var(--line-hi)}
.drawer-search input::placeholder{color:var(--text-lo)}

/* ============ SLAB SYSTEM ============ */
.slab{position:relative;padding:96px 0;border-top:2px solid var(--line-mid);overflow:hidden}
.slab.inv{background:var(--paper);color:var(--text-inv-hi);border-top:3px solid var(--line-solid)}
.slab.inv .sec-sub{color:var(--text-inv-mid)}

.ghost-num{position:absolute;left:-14px;top:24px;font-family:'Clash Display',sans-serif;font-weight:700;
  font-size:clamp(7rem,16vw,13rem);line-height:.8;color:var(--ghost);pointer-events:none;user-select:none;z-index:0}
.ghost-num.inv{color:rgba(10,10,10,.075)}

.sec-head{position:relative;z-index:1;max-width:760px;margin-bottom:52px}
.placard{font-size:11px;letter-spacing:.18em;color:var(--text-lo);margin-bottom:16px}
.slab.inv .placard{color:var(--text-inv-mid)}
.sec-h{font-size:clamp(2rem,6vw,4.2rem)}
.sec-sub{margin-top:18px;font-size:1.05rem;color:var(--text-mid);max-width:600px}

/* ============ BUTTONS ============ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;font-size:15px;letter-spacing:.01em;padding:15px 28px;border:2px solid var(--line-solid);
  transition:background .18s var(--ease),color .18s var(--ease),transform .18s var(--ease)}
.btn-solid{background:var(--paper);color:var(--ink)}
.btn-solid:hover{background:transparent;color:var(--text-hi)}
.btn-ghost{background:transparent;color:var(--text-hi)}
.btn-ghost:hover{background:var(--paper);color:var(--ink)}
.btn-invsolid{background:var(--ink);color:var(--paper);border-color:var(--ink);font-family:'JetBrains Mono',monospace;font-size:15px}
.btn-invsolid:hover{background:transparent;color:var(--ink)}
.btn:active{transform:translateY(1px)}

/* ============ 01 HERO ============ */
.hero{padding:84px 0 70px;border-top:0}
.hero-grid{display:grid;grid-template-columns:1.55fr .95fr;gap:48px;align-items:end;position:relative;z-index:1}
.kicker{font-size:12px;letter-spacing:.16em;color:var(--text-lo);margin-bottom:22px}
.hero-h{font-size:clamp(2.7rem,9vw,8rem);line-height:.9;margin-bottom:26px}
.hero-h .line{display:block;overflow:hidden}
.hero-h .line-in{display:block;transform:translateY(102%);animation:wipeUp .8s var(--ease) forwards}
.hero-h .line:nth-child(2) .line-in{animation-delay:.12s}
@keyframes wipeUp{to{transform:translateY(0)}}
.hero-sub{max-width:560px;color:var(--text-mid);font-size:1.08rem;line-height:1.65}
.hero-cta{display:flex;gap:14px;margin:30px 0 26px;flex-wrap:wrap}
.paychips{display:flex;gap:8px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;border:1px solid var(--line-hair);color:var(--text-lo);
  font-size:10.5px;letter-spacing:.1em;padding:6px 10px}

/* hero feed */
.hero-feed{border:1px solid var(--line-mid);background:var(--ink-raise);align-self:stretch}
.feed-head{font-size:11px;letter-spacing:.12em;color:var(--text-lo);padding:13px 16px;border-bottom:1px solid var(--line-hair)}
.blink{animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.feed-list{display:flex;flex-direction:column}
.feed-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid var(--line-hair)}
.feed-item:last-child{border-bottom:0}
.feed-item .fi-name{font-size:13px;font-weight:600;color:var(--text-hi);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.feed-item .fi-fw{font-size:10px;letter-spacing:.08em;color:var(--text-lo);margin-top:2px}
.feed-item .fi-price{font-size:13px;font-weight:700;color:var(--text-hi);white-space:nowrap}

/* ============ TICKER ============ */
.ticker{background:var(--ink-sink);border-top:2px solid var(--line-mid);border-bottom:2px solid var(--line-mid);
  overflow:hidden;white-space:nowrap;padding:11px 0}
.ticker-track{display:inline-flex;gap:0;will-change:transform;animation:marq 60s linear infinite}
.ticker:hover .ticker-track{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-50%)}}
.tk{display:inline-flex;align-items:center;gap:10px;padding:0 26px;font-family:'JetBrains Mono',monospace;font-size:12.5px;color:var(--text-mid);border-right:1px solid var(--line-hair)}
.tk b{color:var(--text-hi);font-weight:700}
.tk .up{font-size:13px;color:var(--text-hi)}
.tk .fw{color:var(--text-lo);letter-spacing:.06em}

/* ============ 02 STATS ============ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-hair);
  border:1px solid var(--line-hair)}
.stat{background:var(--ink);padding:36px 28px;display:flex;flex-direction:column;gap:12px}
.stat-cap{font-size:10.5px;letter-spacing:.14em;color:var(--text-lo)}
.stat-num{font-size:clamp(2rem,4.5vw,3.4rem);font-weight:700;line-height:1;color:var(--text-hi)}

/* ============ 03 ESTIMATOR / TERMINAL ============ */
.term{position:relative;z-index:1;border:2px solid var(--line-mid);background:var(--ink-raise)}
.term-bar{display:flex;align-items:center;gap:16px;padding:0 16px;border-bottom:2px solid var(--line-mid);height:52px}
.brackets{width:14px;height:14px;border:2px solid var(--line-hi);border-right:0;border-bottom:0;flex-shrink:0}
.tabs{display:flex;gap:0;height:100%}
.tab{font-size:12px;letter-spacing:.06em;color:var(--text-lo);padding:0 18px;height:100%;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.tab:hover{color:var(--text-mid)}
.tab.on{color:var(--text-hi);border-bottom-color:var(--line-solid);box-shadow:inset 0 -3px 0 var(--line-solid)}
.term-dot{margin-left:auto;font-size:10.5px;letter-spacing:.08em;color:var(--text-lo)}
.term-body{padding:30px}

.est-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.est-controls{display:flex;flex-direction:column;gap:26px}
.field{display:flex;flex-direction:column;gap:11px}
.field-lab{font-size:11px;letter-spacing:.1em;color:var(--text-lo);display:flex;justify-content:space-between;align-items:center}
.field-lab b{color:var(--text-hi);font-size:13px;font-weight:700}
select,.audit-in input{appearance:none;background:var(--ink-sink);border:1px solid var(--line-mid);color:var(--text-hi);
  padding:12px 14px;font-size:14px;font-weight:600;outline:none;transition:border-color .15s}
select{background-image:linear-gradient(45deg,transparent 50%,var(--text-lo) 50%),linear-gradient(135deg,var(--text-lo) 50%,transparent 50%);
  background-position:calc(100% - 18px) 18px,calc(100% - 13px) 18px;background-size:5px 5px;background-repeat:no-repeat}
select:focus,.audit-in input:focus{border-color:var(--line-hi)}

.seg{display:inline-flex;border:1px solid var(--line-mid)}
.seg-wrap{flex-wrap:wrap;gap:0}
.seg-btn{font-size:12px;font-weight:600;padding:10px 15px;color:var(--text-lo);border-right:1px solid var(--line-mid);transition:.15s}
.seg-btn:last-child{border-right:0}
.seg-btn:hover{color:var(--text-hi)}
.seg-btn.on{background:var(--paper);color:var(--ink)}

input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:2px;background:var(--line-mid);outline:none;cursor:pointer}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:24px;background:var(--paper);border:0;cursor:pointer}
input[type=range]::-moz-range-thumb{width:16px;height:24px;background:var(--paper);border:0;border-radius:0;cursor:pointer}

.est-out{border:1px solid var(--line-mid);background:var(--ink-sink);padding:26px;display:flex;flex-direction:column}
.est-out-cap{font-size:11px;letter-spacing:.14em;color:var(--text-lo)}
.flap{display:flex;gap:3px;margin:14px 0 8px}
.flap-cell{min-width:.72em;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:clamp(2.2rem,6vw,3.4rem);line-height:1;
  background:var(--ink-raise);border:1px solid var(--line-mid);padding:8px 3px;text-align:center;color:var(--text-hi)}
.flap-cell.sep{background:none;border:0;padding:8px 0}
.flap-cell.flip{animation:flip .32s var(--ease)}
@keyframes flip{0%{transform:rotateX(-80deg);opacity:.3}100%{transform:rotateX(0);opacity:1}}
.est-out-sub{font-size:10.5px;letter-spacing:.1em;color:var(--text-lo)}
.gauge{margin-top:auto;padding-top:22px;display:flex;flex-direction:column;gap:10px}
.gauge-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-mid);padding-bottom:10px;border-bottom:1px solid var(--line-hair)}
.gauge-row.total{color:var(--text-hi);font-weight:700;border-bottom:0;padding-top:4px}
.gauge-row.total span:last-child{font-size:16px}

/* audit tab */
.audit-in{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.audit-in input{flex:1;min-width:240px;font-family:'JetBrains Mono',monospace;font-size:12.5px;font-weight:400}
.audit-note{font-size:11px;letter-spacing:.08em;color:var(--text-lo);margin-bottom:16px}
.audit-out{background:var(--ink-sink);border:1px solid var(--line-mid);padding:22px;font-size:12.5px;line-height:1.9;
  color:var(--text-mid);min-height:200px;white-space:pre-wrap;word-break:break-word}
.audit-out .ok{color:var(--text-hi)}
.audit-out .warn{color:var(--text-hi);border-bottom:1px dashed var(--line-hi)}
.audit-out .grade{font-weight:700;color:var(--ink);background:var(--paper);padding:1px 8px}

/* ============ CATEGORIES ============ */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-hair);border:1px solid var(--line-hair)}
.cat-tile{position:relative;background:var(--ink);padding:20px;display:flex;flex-direction:column;gap:16px;
  border:1px solid transparent;transition:border-color .18s,background .18s;cursor:pointer}
.cat-tile:hover{border-color:var(--line-hi);background:var(--ink-raise)}
.cat-thumb{aspect-ratio:16/9}
.cat-meta{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.cat-name{font-size:15px;font-weight:700;color:var(--text-hi)}
.cat-sub{font-size:11.5px;color:var(--text-lo);margin-top:3px}
.cat-count{font-family:'JetBrains Mono',monospace;font-size:12px;font-weight:700;color:var(--text-mid)}

/* ============ PROCEDURAL PLATE ============ */
.plate{position:relative;aspect-ratio:4/3;background:var(--ink-raise);overflow:hidden;
  background-image:radial-gradient(var(--line-hair) 1px,transparent 1px);background-size:16px 16px}
.plate svg.motif{position:absolute;inset:0;width:100%;height:100%}
.plate svg.motif [stroke]{stroke:var(--line-hi)}
.plate::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 48%,transparent 30%,rgba(0,0,0,.66) 100%);pointer-events:none;z-index:2}
.plate::after{content:"";position:absolute;inset:0;background-image:var(--grain);background-size:180px 180px;
  opacity:.62;mix-blend-mode:overlay;pointer-events:none;z-index:3}
.plate .reg{position:absolute;width:11px;height:11px;border:1.5px solid var(--line-hi);z-index:4;transition:.2s var(--ease)}
.plate .reg.tl{top:8px;left:8px;border-right:0;border-bottom:0}
.plate .reg.tr{top:8px;right:8px;border-left:0;border-bottom:0}
.plate .reg.bl{bottom:8px;left:8px;border-right:0;border-top:0}
.plate .reg.br{bottom:8px;right:8px;border-left:0;border-top:0}
.plate .grade{position:absolute;top:8px;right:8px;z-index:5;font-family:'JetBrains Mono',monospace;font-weight:700;font-size:11px;
  width:22px;height:22px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-hi);background:var(--ink-sink);color:var(--text-hi)}
.plate .ptag{position:absolute;bottom:8px;left:8px;z-index:5;font-family:'JetBrains Mono',monospace;font-size:9.5px;letter-spacing:.06em;color:var(--text-lo)}
.cat-thumb .reg,.cat-thumb .grade,.cat-thumb .ptag{display:none}

/* ============ FEATURED (inverted) ============ */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.feat-card{background:var(--paper);color:var(--ink);border:1px solid var(--line-inv);display:flex;flex-direction:column;position:relative}
.feat-card .placard-no{position:absolute;top:14px;right:16px;z-index:6;font-family:'JetBrains Mono',monospace;font-size:11px;color:rgba(10,10,10,.3);letter-spacing:.08em}
.feat-card .plate{background:#111;border-bottom:1px solid var(--line-inv)}
.feat-body{padding:20px;display:flex;flex-direction:column;gap:14px;flex:1}
.feat-stamp{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:.06em;color:var(--text-inv-mid)}
.feat-title{font-size:1.2rem;font-weight:700;line-height:1.2;color:var(--ink)}
.feat-spec{display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-family:'JetBrains Mono',monospace;font-size:11.5px}
.feat-spec dt{color:var(--text-inv-mid);letter-spacing:.06em}
.feat-spec dd{color:var(--ink);text-align:right;font-weight:700}
.feat-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:14px;border-top:1px solid var(--line-inv)}
.feat-price{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:1.3rem;color:var(--ink)}
.feat-add{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:12px;border:2px solid var(--ink);padding:9px 14px;background:var(--ink);color:var(--paper);transition:.16s}
.feat-add:hover{background:transparent;color:var(--ink)}
.feat-add.added{background:transparent;color:var(--ink)}

/* ============ CATALOG ============ */
.catalog-wrap{display:grid;grid-template-columns:230px 1fr;gap:32px;align-items:start;position:relative;z-index:1}
.filters{position:sticky;top:84px;border:1px solid var(--line-mid);background:var(--ink-raise)}
.filters-head{font-size:11px;letter-spacing:.16em;color:var(--text-lo);padding:16px;border-bottom:1px solid var(--line-hair)}
.facet{padding:16px;border-bottom:1px solid var(--line-hair)}
.facet-lab{font-size:10.5px;letter-spacing:.1em;color:var(--text-lo);display:flex;justify-content:space-between;margin-bottom:12px}
.facet-lab b{color:var(--text-hi);font-size:12px}
.facet .seg-wrap{border:0;gap:6px}
.facet .seg-btn{border:1px solid var(--line-mid);font-size:11px;padding:7px 11px}
.filters-reset{width:100%;padding:14px;font-size:11px;letter-spacing:.1em;color:var(--text-lo);transition:color .15s}
.filters-reset:hover{color:var(--text-hi)}

.catalog-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.result-count{font-size:12px;color:var(--text-mid);letter-spacing:.04em}
.sort{display:flex;align-items:center;gap:10px}
.sort .mono{font-size:11px;letter-spacing:.1em;color:var(--text-lo)}
.sort select{padding:9px 34px 9px 12px;font-size:13px;background-position:calc(100% - 16px) 15px,calc(100% - 11px) 15px}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.card{border:1px solid var(--line-hair);background:var(--ink);display:flex;flex-direction:column;transition:border-color .18s}
.card[data-tier="A"]{border-width:1.5px;border-color:var(--line-mid)}
.card[data-tier="S"]{border-width:2px;border-color:var(--line-hi)}
.card:hover{border-color:var(--line-hi)}
.card:hover .plate .reg{width:8px;height:8px}
.card:hover .plate .motif{filter:contrast(1.3)}
.card .plate{border-bottom:1px solid var(--line-hair)}
.card-body{padding:16px;display:flex;flex-direction:column;gap:12px;flex:1}
.card-stamp{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.05em;color:var(--text-lo);display:flex;gap:8px;flex-wrap:wrap}
.card-title{font-size:1.02rem;font-weight:700;line-height:1.25;color:var(--text-hi)}
.card-spec{display:grid;grid-template-columns:auto 1fr;gap:5px 12px;font-family:'JetBrains Mono',monospace;font-size:11px}
.card-spec dt{color:var(--text-lo);letter-spacing:.04em}
.card-spec dd{color:var(--text-mid);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:13px;border-top:1px solid var(--line-hair)}
.card-rating{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--text-mid)}
.card-rating .star{color:var(--text-hi)}
.card-price{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:1.18rem;color:var(--text-hi)}
.add{font-family:'JetBrains Mono',monospace;font-weight:700;font-size:11.5px;border:1px solid var(--line-hi);padding:9px 13px;color:var(--text-hi);transition:.16s;white-space:nowrap}
.add:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.add.added{background:var(--paper);color:var(--ink);border-color:var(--paper)}

.card.skel .card-body>*,.card.skel .plate .motif{opacity:0}
.card.skel{border-color:var(--line-hair)}
.card.skel .plate{background:var(--ink-raise)}

.empty{text-align:center;padding:60px 0;color:var(--text-lo);letter-spacing:.1em;font-size:13px}

/* ============ HOW ============ */
.how-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;position:relative;z-index:1}
.how-h{font-size:1.4rem;margin-bottom:30px;padding-bottom:16px;border-bottom:2px solid var(--line-mid)}
.steps{display:flex;flex-direction:column;gap:26px}
.steps li{display:flex;gap:18px;padding-left:20px;border-left:2px solid var(--line-hair)}
.step-n{font-size:13px;color:var(--text-lo);padding-top:3px;flex-shrink:0;width:24px}
.steps b{display:block;font-size:1.05rem;font-weight:700;margin-bottom:5px;color:var(--text-hi)}
.steps p{color:var(--text-mid);font-size:.95rem;line-height:1.6}

/* ============ VAULT ============ */
.vault-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-hair);border:1px solid var(--line-hair);position:relative;z-index:1}
.guard{background:var(--ink);padding:30px 24px;display:flex;flex-direction:column;gap:12px}
.guard-n{font-size:13px;color:var(--text-lo)}
.guard h4{font-size:1.1rem;font-weight:700;color:var(--text-hi)}
.guard p{font-size:.92rem;color:var(--text-mid);line-height:1.6;flex:1}
.tick{font-size:10.5px;letter-spacing:.1em;color:var(--text-hi);border:1px solid var(--line-mid);padding:6px 10px;align-self:flex-start}

/* ============ PROOF ============ */
.logo-wall{border:1px solid var(--line-hair);padding:32px;margin-bottom:32px;text-align:center}
.logo-cap{display:block;font-size:11px;letter-spacing:.16em;color:var(--text-lo);margin-bottom:24px}
.logos{display:flex;flex-wrap:wrap;justify-content:center;gap:14px 40px}
.logos span{font-size:15px;font-weight:700;letter-spacing:.04em;color:var(--text-lo);transition:color .2s}
.logos span:hover{color:var(--text-hi)}
.tcards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{position:relative;border:1px solid var(--line-hair);padding:30px 26px;overflow:hidden}
.tcard .quote{position:absolute;top:6px;right:14px;font-family:'Clash Display',sans-serif;font-weight:700;font-size:5rem;color:var(--ghost);line-height:1}
.tcard blockquote{font-size:1rem;line-height:1.6;color:var(--text-hi);font-style:italic;position:relative;z-index:1}
.tcard figcaption{margin-top:18px;font-size:11px;letter-spacing:.06em;color:var(--text-lo)}

/* ============ FAQ ============ */
.faq-wrap{display:grid;grid-template-columns:.7fr 1.3fr;gap:48px;align-items:start;position:relative;z-index:1}
.acc{border-top:1px solid var(--line-hair)}
.acc-item{border-bottom:1px solid var(--line-hair)}
.acc-q{display:flex;align-items:center;gap:16px;width:100%;text-align:left;padding:22px 4px;font-size:1.05rem;font-weight:600;color:var(--text-hi)}
.acc-q .qn{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--text-lo);flex-shrink:0}
.acc-q .caret{margin-left:auto;font-family:'JetBrains Mono',monospace;color:var(--text-lo);transition:transform .25s var(--ease)}
.acc-item.open .acc-q .caret{transform:rotate(90deg)}
.acc-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.acc-a p{padding:0 4px 24px 44px;color:var(--text-mid);font-size:.97rem;line-height:1.7;max-width:640px}

/* ============ CTA BAND ============ */
.cta-in{text-align:center;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:26px}
.cta-h{font-size:clamp(1.9rem,5.5vw,4.2rem);max-width:14ch;color:var(--ink)}
.cta-sub{font-size:11.5px;letter-spacing:.12em;color:var(--text-inv-mid)}

/* ============ FOOTER ============ */
.footer{background:var(--ink-sink);border-top:2px solid var(--line-mid)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:40px;padding:64px 28px 48px}
.foot-brand .brand{font-size:24px;margin-bottom:16px;display:inline-block}
.foot-tag{color:var(--text-mid);font-size:.92rem;max-width:280px;line-height:1.6}
.socials{display:flex;gap:12px;margin-top:22px}
.socials a{width:38px;height:38px;border:1px solid var(--line-mid);display:flex;align-items:center;justify-content:center;transition:.16s}
.socials a:hover{border-color:var(--line-hi);background:var(--ink-raise)}
.socials svg{width:18px;height:18px;fill:var(--text-mid)}
.socials a:hover svg{fill:var(--text-hi)}
.foot-col{display:flex;flex-direction:column;gap:13px}
.foot-h{font-size:10.5px;letter-spacing:.14em;color:var(--text-lo);margin-bottom:4px}
.foot-col a{font-size:.92rem;color:var(--text-mid);transition:color .15s}
.foot-col a:hover{color:var(--text-hi)}
.foot-bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:24px 28px;border-top:1px solid var(--line-hair);flex-wrap:wrap}
.pay-row{display:flex;gap:8px;flex-wrap:wrap}
.foot-fine{font-size:10px;letter-spacing:.08em;color:var(--text-lo)}

/* ============ REVEAL ============ */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}
.slab .sec-head{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.slab.in .sec-head{opacity:1;transform:none}

/* ============ RESPONSIVE ============ */
@media (max-width:1080px){
  .hero-grid{grid-template-columns:1fr;gap:36px;align-items:start}
  .hero-feed{max-width:480px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:repeat(2,1fr)}
  .catalog-wrap{grid-template-columns:1fr}
  .filters{position:static;display:grid;grid-template-columns:repeat(2,1fr)}
  .filters-head{grid-column:1/-1}
  .filters-reset{grid-column:1/-1}
  .vault-grid{grid-template-columns:repeat(2,1fr)}
  .tcards{grid-template-columns:1fr}
  .faq-wrap{grid-template-columns:1fr;gap:28px}
}
@media (max-width:860px){
  .slab{padding:72px 0}
  .nav-links,.nav-search,.signin{display:none}
  .hamburger{display:flex}
  .nav-right{margin-left:auto}
  .est-grid{grid-template-columns:1fr;gap:28px}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .how-grid{grid-template-columns:1fr;gap:48px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px}
  .foot-brand{grid-column:1/-1}
  .ticker-track{animation-duration:42s}
}
@media (max-width:560px){
  .wrap{padding:0 18px}
  .cat-grid{grid-template-columns:1fr}
  .feat-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .filters{grid-template-columns:1fr}
  .vault-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;align-items:flex-start}
  .term-body{padding:16px}
  .hero{padding:54px 0 50px}
  .hero-feed{display:none}
  .tk{padding:0 16px;gap:8px;font-size:12px}
  .ticker-track{animation-duration:35s}
  .audit-in input{min-width:140px}
  .flap-cell{font-size:1.8rem;padding:6px 3px}
  .flap{gap:2px}
  .facet .seg-btn{padding:10px 12px}
  .ghost-num{font-size:clamp(3rem,13vw,5rem);left:-6px}
  .plate::after{background-image:none}
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .ticker-track{animation:none;transform:none}
  .hero-h .line-in{transform:none;animation:none}
  .reveal{opacity:1;transform:none}
  .slab .sec-head{opacity:1;transform:none}
  .blink{animation:none}
}
