/* ============================================================
   BITCOIN ASSET GROUP — SHARED STYLESHEET
   ============================================================ */

:root{
  /* Vault Brand Tokens — Treasury Bronze
     See: 00_Strategie/Brand/Brand_Decision_Vault.md + assets/brand/tokens.css */
  --ink:#0E1116;
  --ink-2:#13171D;
  --ink-3:#1A1F26;
  --ink-4:#222831;
  --ink-5:#2A323D;
  --line:rgba(245,242,236,0.10);
  --line-2:rgba(245,242,236,0.18);
  --line-3:rgba(245,242,236,0.28);
  --txt:#F5F2EC;
  --txt-2:#A8A39A;
  --txt-3:#6F6A62;
  --txt-4:#52524E;
  --btc:#B8893A;
  --btc-soft:#D4B07A;
  --btc-deep:#7A5C28;
  --btc-glow:rgba(184,137,58,0.15);
  --btc-glow-2:rgba(184,137,58,0.30);
  --gold:#D4B07A;
  --green:#3B7D5A;
  --red:#A84135;
  --radius:0;
  --radius-lg:0;
  --radius-xl:2px;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
  --max:1320px;
  --font-serif:'Newsreader',Georgia,'Times New Roman',serif;
  --font-sans:'Inter Tight','Inter',system-ui,-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  font-family:var(--font-sans);
  font-size:16px;line-height:1.6;
  color:var(--txt);background:var(--ink);
  overflow-x:hidden;
  cursor:auto;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font-family:inherit}

::selection{background:var(--btc);color:var(--ink)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--ink-2)}
::-webkit-scrollbar-thumb{background:var(--ink-4);border-radius:8px;border:2px solid var(--ink-2)}
::-webkit-scrollbar-thumb:hover{background:var(--btc-deep)}

/* ============================================================
   GLOBAL EFFECTS — noise + grid + bitcoin pattern
   ============================================================ */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:1;
  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='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.045 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  opacity:0.5;mix-blend-mode:overlay;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
.display{font-family:var(--font-serif);letter-spacing:-0.025em;line-height:0.96;font-weight:400}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;letter-spacing:-0.01em}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.16em;color:var(--btc);
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--btc)}

.gradient-text{color:var(--btc-soft);font-style:italic;background:none;-webkit-background-clip:initial;background-clip:initial;-webkit-text-fill-color:currentColor}

.container{max-width:var(--max);margin:0 auto;padding:0 28px;position:relative}
@media(max-width:768px){.container{padding:0 20px}}

/* ============================================================
   TICKER STRIP (Bitcoin block height + price-style)
   ============================================================ */
.ticker{
  position:fixed;top:0;left:0;right:0;z-index:99;
  background:var(--ink);border-bottom:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;font-size:11px;
  color:var(--txt-3);overflow:hidden;height:30px;
  display:flex;align-items:center;
}
.ticker-track{
  display:flex;animation:ticker 60s linear infinite;
  white-space:nowrap;gap:48px;padding-left:48px;
}
.ticker-item{display:inline-flex;align-items:center;gap:8px}
.ticker-item .label{color:var(--txt-4);text-transform:uppercase;letter-spacing:0.1em;font-size:10px}
.ticker-item .val{color:var(--btc);font-weight:500}
.ticker-item .dot{width:5px;height:5px;border-radius:50%;background:var(--btc);animation:pulse 2s ease-in-out infinite}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}

/* ============================================================
   NAV
   ============================================================ */
nav.top{
  position:fixed;top:30px;left:0;right:0;z-index:100;
  padding:14px 0;
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  background:rgba(8,8,10,0.65);
  border-bottom:1px solid transparent;
  transition:border-color 300ms var(--ease),padding 240ms var(--ease);
}
nav.top.scrolled{border-bottom-color:var(--line);padding:10px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto;padding:0 28px}
.logo{display:flex;align-items:center;gap:12px}
.logo-mark{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--btc) 0%,var(--btc-deep) 100%);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:20px;color:var(--ink);
  box-shadow:0 4px 14px var(--btc-glow);
  position:relative;overflow:hidden;
}
.logo-mark::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 30%,rgba(255,255,255,0.3) 50%,transparent 70%);
  transform:translateX(-100%);transition:transform 600ms var(--ease);
}
.logo:hover .logo-mark::before{transform:translateX(100%)}
.logo-text{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:16px;letter-spacing:-0.01em}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{color:var(--txt-2);font-size:14px;font-weight:500;transition:color 200ms var(--ease);position:relative}
.nav-links a:hover,.nav-links a.active{color:var(--txt)}
.nav-links a::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--btc);transform:scaleX(0);transform-origin:left;
  transition:transform 280ms var(--ease);
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-cta{
  padding:10px 18px;background:var(--btc);color:var(--ink);
  border-radius:10px;font-weight:600;font-size:14px;
  transition:all 220ms var(--ease);
  box-shadow:0 4px 16px var(--btc-glow);
  position:relative;overflow:hidden;
}
.nav-cta:hover{background:var(--btc-soft);transform:translateY(-1px);box-shadow:0 8px 24px var(--btc-glow-2)}
@media(max-width:880px){.nav-links{display:none}}

/* ============================================================
   BUTTONS — magnetic ready
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:16px 26px;border-radius:12px;
  font-weight:600;font-size:15px;cursor:pointer;
  border:1px solid transparent;
  transition:all 240ms var(--ease);
  position:relative;overflow:hidden;
}
.btn-primary{
  background:var(--btc);color:var(--ink);
  box-shadow:0 6px 24px var(--btc-glow);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 36px var(--btc-glow-2);background:var(--btc-soft)}
.btn-primary::before{
  content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,0.25),transparent);
  transition:left 700ms var(--ease);
}
.btn-primary:hover::before{left:100%}
.btn-ghost{
  background:transparent;color:var(--txt);
  border-color:var(--line-3);
}
.btn-ghost:hover{border-color:var(--txt-3);background:rgba(255,255,255,0.03);transform:translateY(-1px)}
.btn .arr{transition:transform 240ms var(--ease)}
.btn:hover .arr{transform:translateX(4px)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;padding:200px 0 140px;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.hero-bg{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-bg::before{
  content:'';position:absolute;inset:0;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% 0%,rgba(247,147,26,0.12),transparent 60%),
    radial-gradient(ellipse 60% 40% at 100% 100%,rgba(247,147,26,0.06),transparent 60%);
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 30%,black,transparent 80%);
}
.orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.orb-1{width:520px;height:520px;background:rgba(247,147,26,0.20);top:-180px;right:-100px;animation:drift1 22s ease-in-out infinite}
.orb-2{width:380px;height:380px;background:rgba(212,169,92,0.10);bottom:-120px;left:-80px;animation:drift2 28s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(-40px,30px)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,-40px)}}

.hero-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;opacity:0.6;
}

.hero-inner{position:relative;z-index:2}
.hero-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:7px 14px;
  background:rgba(247,147,26,0.08);
  border:1px solid rgba(247,147,26,0.20);
  border-radius:100px;font-size:11px;font-weight:700;
  color:var(--btc);text-transform:uppercase;letter-spacing:0.14em;
  margin-bottom:32px;
}
.hero-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--btc);box-shadow:0 0 10px var(--btc);animation:pulse 2s ease-in-out infinite}
.hero h1{
  font-family:'Inter Tight',sans-serif;font-weight:800;
  font-size:clamp(44px,7vw,108px);
  letter-spacing:-0.035em;line-height:0.94;
  max-width:980px;margin-bottom:40px;
}
.hero p.lead{
  font-size:clamp(17px,1.6vw,22px);color:var(--txt-2);
  max-width:680px;line-height:1.55;margin-bottom:48px;
}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}

/* ============================================================
   HERO SPLIT-LAYOUT (v2.7 — Stripe/Linear-Style)
   ============================================================ */
.hero-split{padding:160px 0 100px}
.hero-split-inner{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.15fr 0.85fr;gap:80px;align-items:center;
}
.hero-left h1{font-size:clamp(40px,5.5vw,76px);margin-bottom:28px;max-width:none}
.hero-left p.lead{font-size:clamp(16px,1.3vw,19px);max-width:560px;margin-bottom:36px}
.hero-left .hero-ctas{margin-bottom:48px}
.hero-trust{
  display:flex;align-items:center;gap:32px;
  padding-top:32px;border-top:1px solid var(--line);
  max-width:520px;
}
.trust-item{display:flex;flex-direction:column;gap:4px}
.trust-item .num{
  font-family:'Inter Tight',sans-serif;font-weight:800;
  font-size:24px;color:var(--txt);letter-spacing:-0.02em;
}
.trust-item .lbl{font-size:11px;color:var(--txt-3);text-transform:uppercase;letter-spacing:0.10em;font-weight:600}
.trust-divider{width:1px;height:32px;background:var(--line)}

/* RIGHT side — Domain Stack */
.hero-right{
  position:relative;
  background:linear-gradient(180deg,var(--ink-2),rgba(20,20,22,0.4));
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  padding:24px 24px 18px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  max-height:560px;display:flex;flex-direction:column;
  box-shadow:0 24px 64px rgba(0,0,0,0.5),0 0 0 1px rgba(247,147,26,0.04);
}
.hero-stack-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:0 4px 16px;border-bottom:1px solid var(--line);margin-bottom:14px;
}
.hero-stack-head .eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-size:10px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--btc);font-weight:700;
}
.live-dot{
  width:7px;height:7px;border-radius:50%;background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,0.6);
  animation:livepulse 2s ease-in-out infinite;
}
@keyframes livepulse{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,0.6)}
  50%{box-shadow:0 0 0 6px rgba(34,197,94,0)}
}
.hero-stack-count{font-size:11px;color:var(--txt-3);font-variant-numeric:tabular-nums}
.hero-stack{
  flex:1;overflow-y:auto;
  display:flex;flex-direction:column;gap:6px;
  padding:0 4px 4px;
  scrollbar-width:thin;scrollbar-color:var(--line) transparent;
}
.hero-stack::-webkit-scrollbar{width:4px}
.hero-stack::-webkit-scrollbar-track{background:transparent}
.hero-stack::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px}
.stack-row{
  display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;
  padding:11px 14px;border-radius:10px;
  background:transparent;border:1px solid transparent;
  transition:all 200ms var(--ease);cursor:pointer;
  text-decoration:none;
}
.stack-row:hover{
  background:var(--ink-3);border-color:var(--line);
  transform:translateX(2px);
}
.stack-row .domain-name{
  font-family:'JetBrains Mono',monospace;font-size:14px;
  color:var(--txt);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.stack-row .domain-name .tld{color:var(--txt-3)}
.stack-row .stack-tier{
  font-size:9px;letter-spacing:0.12em;text-transform:uppercase;font-weight:700;
  padding:2px 6px;border-radius:4px;
}
.stack-row .stack-tier.t1{background:rgba(247,147,26,0.12);color:var(--btc)}
.stack-row .stack-tier.t2{background:rgba(212,169,92,0.10);color:#d4a95c}
.stack-row .stack-price{
  font-size:11px;color:var(--txt-2);font-weight:600;font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.hero-stack-cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px;margin-top:14px;
  background:rgba(247,147,26,0.06);
  border:1px solid rgba(247,147,26,0.16);
  border-radius:10px;
  color:var(--btc);font-size:13px;font-weight:600;letter-spacing:0.04em;
  text-decoration:none;
  transition:all 200ms var(--ease);
}
.hero-stack-cta:hover{background:rgba(247,147,26,0.10);transform:translateY(-1px)}

/* Responsive — stack moves below on tablet/mobile */
@media (max-width:980px){
  .hero-split{padding:140px 0 80px}
  .hero-split-inner{grid-template-columns:1fr;gap:48px}
  .hero-right{max-height:420px}
  .hero-trust{gap:24px;max-width:none;flex-wrap:wrap}
}
@media (max-width:640px){
  .hero-split{padding:120px 0 60px}
  .hero-left h1{font-size:clamp(32px,8vw,52px)}
  .hero-right{padding:18px 16px 14px;max-height:380px}
  .hero-trust{gap:16px}
  .trust-item .num{font-size:20px}
  .trust-divider{display:none}
}

/* ============================================================
   STATS BAND
   ============================================================ */
.stats{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink-2);padding:48px 0;position:relative;z-index:2;
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px;align-items:center}
.stat{position:relative}
.stat:not(:last-child)::after{
  content:'';position:absolute;right:-24px;top:8px;bottom:8px;width:1px;background:var(--line);
}
.stat-num{
  font-family:'Inter Tight',sans-serif;
  font-size:clamp(32px,3.4vw,48px);font-weight:800;
  color:var(--txt);letter-spacing:-0.03em;line-height:1;
  display:flex;align-items:baseline;gap:4px;
}
.stat-num .suffix{color:var(--btc);font-size:0.6em}
.stat-label{font-size:12px;color:var(--txt-3);text-transform:uppercase;letter-spacing:0.14em;margin-top:10px;font-weight:500}
@media(max-width:768px){
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:36px}
  .stat:not(:last-child)::after{display:none}
}

/* ============================================================
   SECTIONS / BLOCKS
   ============================================================ */
section.block{padding:140px 0;position:relative}
.block-head{margin-bottom:80px;max-width:780px}
.block-head h2{
  font-family:'Inter Tight',sans-serif;font-weight:800;
  font-size:clamp(36px,5vw,72px);letter-spacing:-0.03em;line-height:1.0;
  margin:18px 0 24px;
}
.block-head p{font-size:18px;color:var(--txt-2);line-height:1.65;max-width:600px}

/* ============================================================
   BUNDLES
   ============================================================ */
.bundles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:1024px){.bundles-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.bundles-grid{grid-template-columns:1fr}}
.bundle-card{
  position:relative;padding:36px;border-radius:var(--radius-lg);
  background:var(--ink-2);border:1px solid var(--line);
  transition:all 320ms var(--ease);overflow:hidden;cursor:pointer;
  display:block;color:inherit;
}
.bundle-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--btc),transparent);
  opacity:0;transition:opacity 320ms var(--ease);
}
.bundle-card:hover{transform:translateY(-4px);border-color:var(--line-2);background:var(--ink-3)}
.bundle-card:hover::before{opacity:1}
.bundle-card.flagship{border-color:rgba(247,147,26,0.25);background:linear-gradient(180deg,rgba(247,147,26,0.05),var(--ink-2))}
.bundle-flag{
  position:absolute;top:0;right:0;
  background:var(--btc);color:var(--ink);
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.14em;
  padding:6px 14px;border-radius:0 var(--radius-lg) 0 var(--radius-lg);
}
.bundle-num{
  font-family:'JetBrains Mono',monospace;
  font-size:11px;color:var(--btc);text-transform:uppercase;letter-spacing:0.18em;
  font-weight:600;margin-bottom:18px;
}
.bundle-card h3{
  font-family:'Inter Tight',sans-serif;font-weight:700;
  font-size:24px;letter-spacing:-0.015em;margin-bottom:14px;line-height:1.2;
}
.bundle-card p{font-size:14px;color:var(--txt-2);line-height:1.6;margin-bottom:24px;min-height:80px}
.bundle-meta{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:20px;border-top:1px solid var(--line);
  font-size:13px;
}
.bundle-meta .count{color:var(--txt-3)}
.bundle-meta .price{color:var(--txt);font-weight:600}

/* ============================================================
   PORTFOLIO BROWSER (big improvement: live counts, clear empty state, reset)
   ============================================================ */
.browser-controls{
  position:sticky;top:108px;z-index:30;
  background:rgba(8,8,10,0.92);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  padding:20px 0;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  margin-bottom:32px;
}
.search-box{position:relative;margin-bottom:18px}
.search-box svg{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--txt-3);pointer-events:none}
.search-box input{
  width:100%;padding:18px 20px 18px 50px;
  background:var(--ink-2);
  border:1px solid var(--line);
  border-radius:14px;color:var(--txt);font-size:15px;font-weight:500;
  transition:all 200ms var(--ease);
}
.search-box input:focus{outline:none;border-color:var(--btc);background:var(--ink-3);box-shadow:0 0 0 4px rgba(247,147,26,0.12)}
.search-box input::placeholder{color:var(--txt-4)}
.search-clear{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  width:28px;height:28px;border-radius:8px;background:var(--ink-3);
  display:none;align-items:center;justify-content:center;color:var(--txt-3);
}
.search-clear.show{display:flex}
.search-clear:hover{background:var(--ink-4);color:var(--txt)}

.filter-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:8px}
.filter-label{font-size:10px;text-transform:uppercase;letter-spacing:0.14em;color:var(--txt-3);font-weight:700;margin-right:8px;min-width:64px}
.chip{
  padding:7px 13px;border-radius:10px;
  background:var(--ink-2);border:1px solid var(--line);
  color:var(--txt-2);font-size:13px;font-weight:500;
  transition:all 180ms var(--ease);
  display:inline-flex;align-items:center;gap:6px;
  position:relative;
}
.chip:hover:not(.disabled){border-color:var(--line-2);color:var(--txt)}
.chip.active{background:var(--btc);color:var(--ink);border-color:var(--btc);font-weight:600}
.chip.disabled{opacity:0.35;cursor:not-allowed;color:var(--txt-4)}
.chip .count{
  font-variant-numeric:tabular-nums;font-size:11px;
  padding:1px 6px;border-radius:5px;background:rgba(255,255,255,0.06);
  color:inherit;opacity:0.8;
}
.chip.active .count{background:rgba(0,0,0,0.18);opacity:1}
.chip.disabled .count{background:rgba(255,255,255,0.03)}

.results-bar{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:24px;flex-wrap:wrap;gap:12px;
}
.results-count{font-size:14px;color:var(--txt-3);font-weight:500}
.results-count strong{color:var(--txt);font-weight:700;font-variant-numeric:tabular-nums}
.results-actions{display:flex;align-items:center;gap:12px}
.reset-btn{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;color:var(--btc);font-weight:500;
  padding:6px 12px;border-radius:8px;background:rgba(247,147,26,0.08);
  border:1px solid rgba(247,147,26,0.2);
  transition:all 180ms var(--ease);
}
.reset-btn:hover{background:rgba(247,147,26,0.12);border-color:rgba(247,147,26,0.4)}
.reset-btn.hide{display:none}
.sort-dropdown{
  background:var(--ink-2);border:1px solid var(--line);
  color:var(--txt-2);font-size:13px;padding:8px 14px;border-radius:10px;
}
.sort-dropdown:focus{outline:none;border-color:var(--btc)}

.domain-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.domain-card{
  position:relative;padding:20px 22px;
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--radius);cursor:pointer;
  transition:all 220ms var(--ease);
  display:flex;flex-direction:column;gap:14px;min-height:120px;
  text-align:left;width:100%;
  transform-style:preserve-3d;
}
.domain-card:hover{transform:translateY(-2px);border-color:var(--btc);background:var(--ink-3)}
.domain-card .name{
  font-family:'JetBrains Mono',monospace;font-weight:500;
  font-size:16px;color:var(--txt);
  word-break:break-all;letter-spacing:-0.01em;
}
.domain-card .name .tld{color:var(--txt-3)}
.domain-card .meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:auto}
.tier-badge{
  display:inline-flex;align-items:center;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;
  padding:3px 8px;border-radius:6px;
}
.tier-1{background:rgba(247,147,26,0.15);color:var(--btc-soft)}
.tier-2{background:rgba(212,169,92,0.10);color:var(--gold)}
.tier-3{background:rgba(255,255,255,0.05);color:var(--txt-2)}
.tier-4{background:rgba(255,255,255,0.03);color:var(--txt-3)}
.cat-badge{font-size:11px;color:var(--txt-3);font-weight:500;padding:3px 8px;border-radius:6px;background:rgba(255,255,255,0.04)}
.bundle-pill{
  font-size:10px;color:var(--btc);font-weight:600;
  padding:3px 7px;border-radius:5px;background:rgba(247,147,26,0.08);
  font-family:'JetBrains Mono',monospace;
}

.empty-state{
  text-align:center;padding:80px 20px;color:var(--txt-3);
  background:var(--ink-2);border-radius:var(--radius-lg);border:1px dashed var(--line-2);
  grid-column:1/-1;
}
.empty-state .icon{
  width:64px;height:64px;margin:0 auto 24px;border-radius:50%;
  background:rgba(247,147,26,0.08);display:flex;align-items:center;justify-content:center;color:var(--btc);
}
.empty-state h3{font-family:'Inter Tight',sans-serif;color:var(--txt);margin-bottom:10px;font-weight:700;font-size:22px}
.empty-state p{margin-bottom:24px;color:var(--txt-3);font-size:15px}

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay{
  position:fixed;inset:0;background:rgba(8,8,10,0.88);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  z-index:200;opacity:0;pointer-events:none;
  transition:opacity 240ms var(--ease);
  display:flex;align-items:center;justify-content:center;padding:24px;
}
.modal-overlay.open{opacity:1;pointer-events:auto}
.modal{
  background:var(--ink-2);border:1px solid var(--line-2);
  border-radius:var(--radius-xl);
  max-width:600px;width:100%;
  overflow:hidden;
  transform:translateY(20px) scale(0.96);
  transition:transform 360ms var(--ease-out);
  max-height:90vh;overflow-y:auto;
}
.modal-overlay.open .modal{transform:translateY(0) scale(1)}
.modal-header{
  position:relative;padding:48px 40px 32px;
  background:linear-gradient(180deg,rgba(247,147,26,0.06),transparent);
  border-bottom:1px solid var(--line);
}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:44px;height:44px;border-radius:12px;
  background:var(--ink-3);border:1px solid var(--line);
  color:var(--txt);
  display:flex;align-items:center;justify-content:center;
  transition:background 200ms var(--ease),color 200ms var(--ease);
  z-index:50;cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  pointer-events:auto;
}
.modal-close:hover{background:var(--ink-4);color:var(--btc)}
.modal-close:active{transform:scale(0.94)}
.modal-close svg{pointer-events:none}
.modal-domain{
  font-family:'Inter Tight',sans-serif;font-weight:800;
  font-size:clamp(28px,4vw,44px);letter-spacing:-0.03em;line-height:1;
  margin-bottom:16px;word-break:break-all;
}
.modal-domain .tld{color:var(--txt-3)}
.modal-tags{display:flex;gap:8px;flex-wrap:wrap}
.modal-body{padding:32px 40px}
.modal-section{margin-bottom:28px}
.modal-section h4{
  font-size:11px;text-transform:uppercase;letter-spacing:0.14em;color:var(--txt-3);
  margin-bottom:10px;font-weight:700;
}
.modal-section p{color:var(--txt-2);font-size:15px;line-height:1.65}
.modal-section .price-range{
  font-family:'Inter Tight',sans-serif;font-weight:800;font-size:28px;color:var(--btc);
  letter-spacing:-0.02em;margin-top:8px;
}
.modal-cta{display:flex;gap:12px;padding:24px 40px;border-top:1px solid var(--line);background:var(--ink-3)}
.modal-cta .btn{flex:1;justify-content:center}

/* ============================================================
   FOOTER
   ============================================================ */
footer{padding:60px 0 40px;border-top:1px solid var(--line);background:var(--ink);position:relative;z-index:2}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px}
@media(max-width:768px){.foot{grid-template-columns:1fr 1fr;gap:32px}}
.foot-col h5{
  font-family:'Inter Tight',sans-serif;font-weight:700;font-size:13px;
  text-transform:uppercase;letter-spacing:0.14em;color:var(--txt);margin-bottom:18px;
}
.foot-col a{color:var(--txt-3);font-size:14px;display:block;padding:6px 0;transition:color 180ms var(--ease)}
.foot-col a:hover{color:var(--btc)}
.foot-brand{font-size:14px;color:var(--txt-3);line-height:1.6;margin-top:12px;max-width:280px}
.foot-bottom{
  margin-top:48px;padding-top:24px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:12px;color:var(--txt-4);
}

/* ============================================================
   ARTICLE / BLOG
   ============================================================ */
.article{padding:160px 0 80px}
.article-head{max-width:780px;margin:0 auto 48px}
.article-meta{display:flex;align-items:center;gap:14px;font-size:13px;color:var(--txt-3);margin-bottom:24px}
.article-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--txt-4)}
.article-tag{padding:4px 10px;border-radius:6px;background:rgba(247,147,26,0.08);color:var(--btc);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.12em}
.article-head h1{
  font-family:'Inter Tight',sans-serif;font-weight:800;
  font-size:clamp(36px,5.5vw,72px);letter-spacing:-0.03em;line-height:1.05;margin-bottom:24px;
}
.article-head .excerpt{font-size:20px;color:var(--txt-2);line-height:1.55;max-width:680px}
.article-body{max-width:720px;margin:0 auto;font-size:18px;line-height:1.8;color:var(--txt-2)}
.article-body h2{
  font-family:'Inter Tight',sans-serif;font-weight:700;font-size:32px;
  letter-spacing:-0.02em;color:var(--txt);margin:56px 0 18px;line-height:1.2;
}
.article-body h3{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:22px;color:var(--txt);margin:36px 0 12px;line-height:1.3}
.article-body p{margin-bottom:22px}
.article-body strong{color:var(--txt);font-weight:600}
.article-body a{color:var(--btc);text-decoration:underline;text-decoration-color:rgba(247,147,26,0.4);text-underline-offset:3px}
.article-body a:hover{text-decoration-color:var(--btc)}
.article-body ul,.article-body ol{margin:18px 0 24px 24px}
.article-body li{margin-bottom:8px}
.article-body blockquote{
  border-left:3px solid var(--btc);padding:8px 0 8px 24px;
  margin:32px 0;font-style:italic;color:var(--txt);
  background:rgba(247,147,26,0.04);border-radius:0 8px 8px 0;
}
.article-body code{font-family:'JetBrains Mono',monospace;background:var(--ink-3);padding:2px 8px;border-radius:5px;font-size:0.9em;color:var(--btc)}
.article-body figure{margin:36px 0}
.article-body .callout{
  padding:24px 28px;background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);margin:32px 0;font-size:16px;line-height:1.65;
}
.article-body .callout strong{color:var(--btc)}

.article-share{
  margin-top:64px;padding-top:32px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
  max-width:720px;margin-left:auto;margin-right:auto;
}
.share-label{font-size:12px;color:var(--txt-3);text-transform:uppercase;letter-spacing:0.14em;font-weight:600}
.share-links{display:flex;gap:8px}
.share-links a{
  width:36px;height:36px;border-radius:8px;background:var(--ink-2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--txt-3);
  transition:all 200ms var(--ease);
}
.share-links a:hover{color:var(--btc);border-color:var(--btc);background:var(--ink-3)}

/* ============================================================
   AD SLOT (Adsense / Sponsorship-ready)
   ============================================================ */
.ad-slot{
  margin:48px auto;padding:24px;
  background:var(--ink-2);border:1px dashed var(--line-2);
  border-radius:var(--radius);text-align:center;
  max-width:728px;
  font-size:13px;color:var(--txt-4);
}
.ad-slot::before{content:'Sponsor / advertisement';display:block;font-size:10px;text-transform:uppercase;letter-spacing:0.16em;color:var(--txt-4);margin-bottom:8px;font-weight:600}

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact{padding:140px 0 100px;background:linear-gradient(180deg,var(--ink),var(--ink-2));position:relative;overflow:hidden;border-top:1px solid var(--line)}
.contact::before{
  content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:800px;height:400px;background:radial-gradient(ellipse,rgba(247,147,26,0.08),transparent 70%);
  filter:blur(60px);pointer-events:none;
}
.contact-inner{max-width:680px;margin:0 auto;position:relative}
.contact-form{
  background:var(--ink-2);border:1px solid var(--line-2);
  border-radius:var(--radius-xl);padding:48px;margin-top:48px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
@media(max-width:640px){.form-row{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:11px;color:var(--txt-3);text-transform:uppercase;letter-spacing:0.14em;font-weight:700}
.field input,.field textarea,.field select{
  padding:14px 16px;background:var(--ink);
  border:1px solid var(--line-2);border-radius:10px;
  color:var(--txt);font-size:15px;
  transition:all 180ms var(--ease);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--btc);background:var(--ink-3)}
.field textarea{resize:vertical;min-height:96px}
.contact-form .btn{width:100%;justify-content:center;padding:18px;position:relative}
.contact-form .btn .btn-spinner{
  display:none;animation:spinrot 0.8s linear infinite;margin-left:6px;
}
.contact-form .btn.loading .btn-text,
.contact-form .btn.loading .arr{opacity:0.4}
.contact-form .btn.loading .btn-spinner{display:inline-flex;align-items:center}
@keyframes spinrot{to{transform:rotate(360deg)}}
.email-line{text-align:center;margin-top:24px;font-size:13px;color:var(--txt-3)}
.email-line a{color:var(--btc)}
.form-status{
  margin-top:18px;padding:14px 18px;border-radius:12px;
  font-size:14px;line-height:1.5;display:none;
}
.form-status.success{
  display:block;background:rgba(34,197,94,0.08);
  border:1px solid rgba(34,197,94,0.25);color:#86efac;
}
.form-status.error{
  display:block;background:rgba(239,68,68,0.08);
  border:1px solid rgba(239,68,68,0.25);color:#fca5a5;
}

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:900px){.process-grid{grid-template-columns:1fr}}
.process-step{
  padding:40px;border-radius:var(--radius-lg);
  background:var(--ink-2);border:1px solid var(--line);
  position:relative;overflow:hidden;
}
.process-step .num{
  font-family:'Inter Tight',sans-serif;font-weight:900;
  font-size:120px;line-height:1;color:rgba(247,147,26,0.08);
  position:absolute;top:-20px;right:20px;letter-spacing:-0.05em;
}
.process-step h4{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:22px;margin-bottom:12px;position:relative;z-index:2}
.process-step p{color:var(--txt-2);font-size:14px;line-height:1.65;position:relative;z-index:2}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:center}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:48px}}
.about-text p{color:var(--txt-2);font-size:17px;line-height:1.75;margin-bottom:20px}
.about-text p strong{color:var(--txt);font-weight:600}
.about-card{
  padding:48px;border-radius:var(--radius-xl);
  background:linear-gradient(180deg,rgba(247,147,26,0.06),var(--ink-2));
  border:1px solid var(--line);position:relative;overflow:hidden;
}
.about-card::before{
  content:'₿';position:absolute;top:-30px;right:-20px;
  font-size:280px;font-weight:900;color:rgba(247,147,26,0.04);
  font-family:'Inter Tight',sans-serif;line-height:1;
}
.principles{display:flex;flex-direction:column;gap:24px;position:relative;z-index:2}
.principle{padding-left:24px;border-left:2px solid var(--btc)}
.principle h5{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:17px;margin-bottom:6px}
.principle p{color:var(--txt-2);font-size:14px;line-height:1.55}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:8px}
.faq-item{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;
  transition:border-color 240ms var(--ease);
}
.faq-item.open{border-color:var(--line-2)}
.faq-q{
  width:100%;padding:24px 28px;display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:'Inter Tight',sans-serif;font-size:18px;font-weight:600;color:var(--txt);
  text-align:left;
}
.faq-icon{width:24px;height:24px;border-radius:6px;background:rgba(247,147,26,0.08);display:flex;align-items:center;justify-content:center;color:var(--btc);transition:transform 240ms var(--ease);flex-shrink:0}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height 320ms var(--ease);
  color:var(--txt-2);font-size:15px;line-height:1.7;
}
.faq-item.open .faq-a{max-height:600px}
.faq-a-inner{padding:0 28px 24px}

/* ============================================================
   POSTS GRID
   ============================================================ */
.posts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:700px){.posts-grid{grid-template-columns:1fr}}
.post-card{
  display:flex;flex-direction:column;
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;
  transition:all 280ms var(--ease);text-decoration:none;color:inherit;
  padding:36px;
}
.post-card:hover{transform:translateY(-3px);border-color:var(--line-2);background:var(--ink-3)}
.post-card .article-tag{align-self:flex-start;margin-bottom:18px}
.post-card h3{font-family:'Inter Tight',sans-serif;font-weight:700;font-size:24px;letter-spacing:-0.02em;line-height:1.25;margin-bottom:12px}
.post-card p{color:var(--txt-2);font-size:14px;line-height:1.6;margin-bottom:24px}
.post-card .meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--txt-4);margin-top:auto}

/* ============================================================
   REVEAL ANIMATION (JS-driven)
   ============================================================ */
.reveal{opacity:0;transform:translateY(24px)}
.reveal.in{opacity:1;transform:translateY(0);transition:opacity 800ms var(--ease-out),transform 800ms var(--ease-out)}

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

/* ============================================================
   UTILITIES
   ============================================================ */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mt-2{margin-top:16px}
.mt-3{margin-top:24px}
.mt-4{margin-top:32px}

/* ============================================================
   MEGA MENU
   ============================================================ */
.nav-links{position:relative}
.nav-item{position:relative;display:flex;align-items:center;gap:4px;padding:8px 0}
.nav-item .caret{
  width:10px;height:10px;display:inline-flex;
  transition:transform 240ms var(--ease);opacity:0.6;
}
.nav-item.has-mega:hover .caret,
.nav-item.has-mega:focus-within .caret{transform:rotate(180deg);opacity:1}

.mega-panel{
  position:absolute;top:calc(100% + 12px);left:50%;transform:translateX(-50%) translateY(-8px);
  background:rgba(14,14,17,0.96);
  backdrop-filter:blur(24px) saturate(150%);
  -webkit-backdrop-filter:blur(24px) saturate(150%);
  border:1px solid var(--line-2);border-radius:var(--radius-lg);
  padding:28px;
  min-width:560px;max-width:760px;
  opacity:0;pointer-events:none;
  transition:opacity 220ms var(--ease),transform 220ms var(--ease);
  box-shadow:0 24px 60px -12px rgba(0,0,0,0.6),0 0 0 1px rgba(247,147,26,0.04);
  z-index:120;
}
.nav-item.has-mega:hover .mega-panel,
.nav-item.has-mega:focus-within .mega-panel{
  opacity:1;pointer-events:auto;
  transform:translateX(-50%) translateY(0);
}
.mega-panel::before{
  content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%) rotate(45deg);
  width:12px;height:12px;background:rgba(14,14,17,0.96);
  border-top:1px solid var(--line-2);border-left:1px solid var(--line-2);
}

/* Bridge invisible area to keep menu open between trigger and panel */
.nav-item.has-mega::after{
  content:'';position:absolute;top:100%;left:-20px;right:-20px;height:14px;
}

.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mega-grid.three-col{grid-template-columns:1fr 1fr 1fr}
.mega-link{
  display:flex;flex-direction:column;gap:4px;
  padding:12px 14px;border-radius:10px;
  transition:background 180ms var(--ease);
  color:var(--txt);text-decoration:none;
}
.mega-link:hover{background:rgba(247,147,26,0.06)}
.mega-link::after{display:none}
.mega-link .ml-title{
  font-family:'Inter Tight',sans-serif;font-weight:600;font-size:14px;
  letter-spacing:-0.01em;color:var(--txt);
  display:flex;align-items:center;gap:8px;
}
.mega-link:hover .ml-title{color:var(--btc)}
.mega-link .ml-desc{font-size:12px;color:var(--txt-3);line-height:1.4}
.mega-link.featured{background:linear-gradient(135deg,rgba(247,147,26,0.08),transparent);border:1px solid rgba(247,147,26,0.18)}
.mega-link .ml-tag{
  display:inline-flex;align-items:center;
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;
  padding:2px 6px;border-radius:4px;
  background:rgba(247,147,26,0.18);color:var(--btc-soft);
}

.mega-section-title{
  grid-column:1/-1;
  font-size:10px;text-transform:uppercase;letter-spacing:0.16em;
  color:var(--txt-3);font-weight:700;
  padding:4px 14px 8px;border-bottom:1px solid var(--line);margin-bottom:4px;
}

.mega-footer{
  margin-top:18px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.mega-footer .ml-cta{
  display:inline-flex;align-items:center;gap:6px;
  font-size:13px;font-weight:600;color:var(--btc);
}

/* Mobile mega — converts to stacked accordion */
@media(max-width:880px){
  .mega-panel{
    position:fixed;top:auto;left:0;right:0;bottom:0;transform:none;
    min-width:0;max-width:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;
    max-height:80vh;overflow-y:auto;
  }
  .nav-item.has-mega:hover .mega-panel{transform:none}
}

/* ============================================================
   MOBILE MENU TOGGLE
   ============================================================ */
.menu-toggle{
  display:none;width:40px;height:40px;
  border:1px solid var(--line-2);border-radius:10px;
  background:var(--ink-2);color:var(--txt);
  align-items:center;justify-content:center;
}
.menu-toggle:hover{border-color:var(--btc);color:var(--btc)}
.menu-toggle svg{transition:transform 240ms var(--ease)}
.menu-toggle.active svg{transform:rotate(90deg)}
@media(max-width:880px){
  .menu-toggle{display:inline-flex}
  .nav-cta{display:none}
}
.mobile-drawer{
  position:fixed;top:0;right:-100%;bottom:0;
  width:min(90vw,400px);
  background:var(--ink);border-left:1px solid var(--line-2);
  z-index:150;padding:80px 24px 24px;
  transition:right 320ms var(--ease);overflow-y:auto;
  display:flex;flex-direction:column;gap:8px;
}
.mobile-drawer.open{right:0}
.mobile-drawer a{padding:14px 16px;border-radius:10px;font-size:16px;font-weight:500;color:var(--txt)}
.mobile-drawer a:hover{background:var(--ink-2)}
.mobile-drawer-overlay{
  position:fixed;inset:0;background:rgba(8,8,10,0.7);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;pointer-events:none;z-index:140;
  transition:opacity 280ms var(--ease);
}
.mobile-drawer-overlay.open{opacity:1;pointer-events:auto}

/* ============================================================
   CAROUSEL — Premium Domains Showcase
   ============================================================ */
.carousel-section{
  padding:120px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,var(--ink) 0%,var(--ink-2) 50%,var(--ink) 100%);
  position:relative;overflow:hidden;
}
.carousel-section::before{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(ellipse 80% 50% at 50% 50%,rgba(247,147,26,0.06),transparent 70%);
  pointer-events:none;
}
.carousel-wrap{position:relative;margin-top:48px}
.carousel-viewport{overflow:hidden;border-radius:var(--radius-lg);position:relative}
.carousel-viewport::before,
.carousel-viewport::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:5;pointer-events:none;
}
.carousel-viewport::before{left:0;background:linear-gradient(90deg,var(--ink),transparent)}
.carousel-viewport::after{right:0;background:linear-gradient(-90deg,var(--ink),transparent)}
.carousel-track{
  display:flex;gap:14px;
  transition:transform 720ms var(--ease-out);
  will-change:transform;
}
.carousel-card{
  flex:0 0 calc(33.333% - 10px);
  min-width:0;
  background:linear-gradient(180deg,var(--ink-2),var(--ink-3));
  border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:36px;text-align:left;
  transition:all 360ms var(--ease);
  cursor:pointer;text-decoration:none;color:inherit;
  display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
}
@media(max-width:900px){.carousel-card{flex-basis:calc(50% - 7px)}}
@media(max-width:640px){.carousel-card{flex-basis:calc(100% - 0px)}}
.carousel-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--btc),transparent);
  opacity:0;transition:opacity 360ms var(--ease);
}
.carousel-card:hover::before{opacity:1}
.carousel-card:hover{
  border-color:rgba(247,147,26,0.4);transform:translateY(-4px);
  box-shadow:0 20px 50px -20px var(--btc-glow);
}
.carousel-card .cc-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.14em;
  color:var(--btc);
}
.carousel-card .cc-tag .dot{width:5px;height:5px;border-radius:50%;background:var(--btc);box-shadow:0 0 6px var(--btc)}
.carousel-card .cc-name{
  font-family:'JetBrains Mono',monospace;font-weight:500;
  font-size:clamp(20px,2.4vw,28px);color:var(--txt);
  word-break:break-all;letter-spacing:-0.015em;line-height:1.15;
}
.carousel-card .cc-name .tld{color:var(--txt-3)}
.carousel-card .cc-pitch{font-size:13px;color:var(--txt-2);line-height:1.55;flex:1}
.carousel-card .cc-meta{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:16px;border-top:1px solid var(--line);
  font-size:12px;color:var(--txt-3);
}
.carousel-card .cc-meta .cc-price{color:var(--btc);font-weight:600;font-family:'Inter Tight',sans-serif;font-size:15px}

.carousel-controls{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:32px;flex-wrap:wrap;gap:20px;
}
.carousel-dots{display:flex;gap:8px}
.carousel-dot{
  width:32px;height:4px;border-radius:2px;
  background:var(--ink-4);
  transition:background 240ms var(--ease),width 240ms var(--ease);
}
.carousel-dot.active{background:var(--btc);width:44px}
.carousel-dot:hover{background:var(--btc-deep)}
.carousel-arrows{display:flex;gap:8px}
.carousel-arrow{
  width:44px;height:44px;border-radius:50%;
  background:var(--ink-2);border:1px solid var(--line-2);
  color:var(--txt-2);
  display:flex;align-items:center;justify-content:center;
  transition:all 220ms var(--ease);
}
.carousel-arrow:hover{background:var(--ink-3);border-color:var(--btc);color:var(--btc);transform:scale(1.05)}
.carousel-arrow:disabled{opacity:0.3;cursor:not-allowed}

/* ============================================================
   PARTNER LOGOS STRIP
   ============================================================ */
.partners{
  padding:60px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink);position:relative;overflow:hidden;
}
.partners-label{
  text-align:center;font-size:11px;text-transform:uppercase;letter-spacing:0.18em;
  color:var(--txt-3);font-weight:600;margin-bottom:32px;
}
.partners-track{
  display:flex;align-items:center;justify-content:center;
  gap:60px;flex-wrap:wrap;opacity:0.55;
  transition:opacity 320ms var(--ease);
}
.partners:hover .partners-track{opacity:0.85}
.partner-logo{
  font-family:'Inter Tight',sans-serif;font-weight:700;font-size:18px;
  color:var(--txt-3);letter-spacing:-0.01em;
  display:flex;align-items:center;gap:8px;
  transition:color 240ms var(--ease);
}
.partner-logo:hover{color:var(--txt)}
.partner-logo .pl-mark{
  width:24px;height:24px;border-radius:6px;
  background:var(--ink-3);border:1px solid var(--line-2);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;color:var(--btc);
}

/* ============================================================
   CUSTOM CURSOR (subtle dot follower)
   Activated by JS adding body.has-cursor — failsafe: default
   cursor stays if JS doesn't run
   ============================================================ */
.cursor-dot, .cursor-ring{display:none}
body.has-cursor .cursor-dot{
  position:fixed;top:0;left:0;width:8px;height:8px;
  border-radius:50%;background:var(--btc);
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%);
  transition:width 200ms var(--ease),height 200ms var(--ease),background 200ms var(--ease);
  mix-blend-mode:screen;
  display:block;
}
body.has-cursor .cursor-ring{
  position:fixed;top:0;left:0;width:36px;height:36px;
  border-radius:50%;border:1.5px solid rgba(247,147,26,0.55);
  pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:width 280ms var(--ease),height 280ms var(--ease),border-color 200ms var(--ease),background 200ms var(--ease);
  display:block;
}
body.has-cursor .cursor-ring.hover{
  width:64px;height:64px;border-color:var(--btc);
  background:rgba(247,147,26,0.08);
}
body.has-cursor .cursor-dot.hover{width:0;height:0}
@media(hover:hover) and (pointer:fine){
  body.has-cursor{cursor:none}
  body.has-cursor a, body.has-cursor button, body.has-cursor input,
  body.has-cursor textarea, body.has-cursor select, body.has-cursor .chip,
  body.has-cursor [data-magnetic], body.has-cursor [data-tilt]{cursor:none}
}

/* ============================================================
   SCROLL PROGRESS BAR
   ============================================================ */
.scroll-progress{
  position:fixed;top:30px;left:0;height:2px;width:0%;
  background:linear-gradient(90deg,var(--btc),var(--btc-soft));
  z-index:101;transition:width 60ms linear;
  box-shadow:0 0 12px rgba(247,147,26,0.4);
}

/* ============================================================
   PAGE TRANSITION FADE
   ============================================================ */
.page-transition{
  position:fixed;inset:0;background:var(--ink);
  z-index:9000;pointer-events:none;
  opacity:0;transition:opacity 320ms var(--ease);
}
.page-transition.fade-in{opacity:1;pointer-events:auto}

/* ============================================================
   FLOATING ACTION (Quick-Inquiry Bubble after scroll)
   ============================================================ */
.floating-action{
  position:fixed;bottom:24px;right:24px;
  display:flex;align-items:center;gap:10px;
  padding:14px 22px;
  background:var(--btc);color:var(--ink);
  border-radius:999px;font-weight:700;font-size:14px;
  box-shadow:0 12px 32px var(--btc-glow-2);
  z-index:90;
  opacity:0;pointer-events:none;transform:translateY(20px) scale(0.9);
  transition:all 320ms var(--ease);
}
.floating-action.show{opacity:1;pointer-events:auto;transform:none}
.floating-action:hover{background:var(--btc-soft);transform:translateY(-2px) scale(1.02);box-shadow:0 16px 40px var(--btc-glow-2)}
.floating-action .fa-mark{
  width:24px;height:24px;border-radius:50%;background:var(--ink);
  display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;color:var(--btc);
}

/* ============================================================
   LANGUAGE SWITCHER
   ============================================================ */
.lang-switcher{
  display:inline-flex;align-items:center;gap:2px;
  border:1px solid var(--line-2);border-radius:8px;padding:2px;
  background:var(--ink-2);font-family:'JetBrains Mono',monospace;
}
.lang-switcher a{
  padding:5px 10px;font-size:11px;font-weight:600;
  color:var(--txt-3);border-radius:6px;letter-spacing:0.05em;
  transition:all 180ms var(--ease);
}
.lang-switcher a:hover{color:var(--txt)}
.lang-switcher a.active{background:var(--btc);color:var(--ink)}
.lang-switcher a::after{display:none}

/* ============================================================
   MOBILE POLISH (v2.3) — Top-1-Premium Mobile Experience
   ============================================================ */

/* Touch-target minimum 44px (Apple HIG) for all interactive elements */
@media (hover: none) and (pointer: coarse) {
  .chip { min-height: 44px; padding: 10px 14px; }
  .btn { min-height: 48px; padding: 14px 22px; }
  .nav-cta { min-height: 44px; padding: 12px 18px; }
  .menu-toggle { width: 44px; height: 44px; }
  .carousel-arrow { width: 48px; height: 48px; }
  .carousel-dot { height: 8px; padding: 8px 0; background-clip: content-box; }
  .modal-close { width: 44px; height: 44px; }
  .faq-q { padding: 22px 24px; min-height: 64px; }
  .domain-card { min-height: 130px; }
  /* Disable hover-only effects on touch */
  [data-tilt] { transform: none !important; }
  [data-magnetic] { transform: none !important; }
}

/* Mobile-first hero adjustments */
@media (max-width: 880px) {
  .hero { padding: 140px 0 80px; }
  .hero h1 {
    font-size: clamp(36px, 9vw, 56px);
    margin-bottom: 24px;
    line-height: 1.0;
  }
  .hero p.lead {
    font-size: 16px;
    margin-bottom: 32px;
  }
  .hero-pill {
    font-size: 10px;
    padding: 6px 12px;
    margin-bottom: 24px;
  }
  .hero-ctas { flex-direction: column; align-items: stretch; gap: 10px; }
  .hero-ctas .btn { width: 100%; justify-content: center; }
  .orb-1 { width: 280px; height: 280px; }
  .orb-2 { width: 220px; height: 220px; }
}

/* Stats more compact on mobile */
@media (max-width: 768px) {
  .stats { padding: 32px 0; }
  .stats-grid { gap: 24px; }
  .stat-num { font-size: 32px; }
  .stat-label { font-size: 10px; letter-spacing: 0.10em; }
}

/* Section padding reduced on mobile */
@media (max-width: 880px) {
  section.block { padding: 80px 0; }
  .block-head { margin-bottom: 40px; }
  .block-head h2 {
    font-size: clamp(28px, 7vw, 42px);
    margin: 14px 0 18px;
  }
  .block-head p { font-size: 15px; }
  .eyebrow { font-size: 10px; }
}

/* Sticky filter bar — make compact on mobile */
@media (max-width: 880px) {
  .browser-controls {
    top: 100px;
    padding: 14px 0;
    margin-bottom: 24px;
  }
  .search-box input {
    padding: 14px 18px 14px 46px;
    font-size: 14px;
  }
  .search-box svg { left: 16px; width: 18px; height: 18px; }
  .filter-row { gap: 6px; margin-top: 6px; }
  .filter-label {
    width: 100%;
    margin-right: 0;
    margin-bottom: 4px;
    font-size: 9px;
  }
  .chip {
    font-size: 12px;
    padding: 8px 11px;
  }
  .chip .count {
    font-size: 10px;
    padding: 1px 5px;
  }
}

/* Domain grid: tighter on mobile */
@media (max-width: 640px) {
  .domain-grid {
    grid-template-columns: 1fr;
    gap: 8px;
  }
  .domain-card {
    padding: 16px 18px;
    min-height: 100px;
    gap: 10px;
  }
  .domain-card .name { font-size: 15px; }
  .results-bar {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .results-actions { width: 100%; justify-content: space-between; }
}

/* Bundle cards: more padding-friendly mobile */
@media (max-width: 640px) {
  .bundle-card {
    padding: 24px;
  }
  .bundle-card h3 { font-size: 20px; }
  .bundle-card p { min-height: auto; }
}

/* Carousel cards: full-width on mobile, smaller gap */
@media (max-width: 640px) {
  .carousel-section { padding: 80px 0; }
  .carousel-track { gap: 10px; }
  .carousel-card {
    padding: 24px;
    flex-basis: calc(100% - 0px);
  }
  .carousel-card .cc-name { font-size: 22px; }
  .carousel-viewport::before,
  .carousel-viewport::after { width: 30px; }
  .carousel-controls { flex-direction: row; justify-content: space-between; gap: 12px; }
  .carousel-arrow { width: 40px; height: 40px; }
}

/* Ticker smaller on mobile */
@media (max-width: 768px) {
  .ticker { height: 26px; font-size: 10px; }
  .ticker-track { gap: 32px; padding-left: 32px; }
  .ticker-item .label { display: none; }
}

/* Nav layout on mobile — adjusted spacing */
@media (max-width: 880px) {
  nav.top { padding: 10px 0; top: 26px; }
  .nav-inner { padding: 0 16px; }
  .logo-mark { width: 32px; height: 32px; font-size: 18px; }
  .logo-text { font-size: 14px; }
  .lang-switcher { display: none; }
  .scroll-progress { top: 26px; }
}

/* Mobile drawer: better spacing */
@media (max-width: 880px) {
  .mobile-drawer { padding: 60px 18px 24px; }
  .mobile-drawer a {
    padding: 16px 18px;
    font-size: 16px;
    min-height: 52px;
    display: flex;
    align-items: center;
  }
}

/* Modal: bottom-sheet on mobile with proper internal scrolling.
   Pattern: outer .modal is flex column with overflow:hidden, only .modal-body
   scrolls internally. Header and CTA stay anchored top/bottom via flex sizing. */
@media (max-width: 640px) {
  .modal-overlay {
    padding: 0;
    align-items: flex-end;
    background: rgba(8,8,10,0.96);
  }
  .modal {
    max-height: 88vh;
    height: 88vh; /* fixed height so internal flex layout has a frame */
    width: 100%;
    border-radius: 20px 20px 0 0;
    transform: translateY(100%);
    background: var(--ink-2);
    display: flex;
    flex-direction: column;
    overflow: hidden !important; /* override desktop's overflow-y:auto */
  }
  .modal-overlay.open .modal { transform: translateY(0); }
  /* Header: anchored top, never scrolls, never shrinks */
  .modal-header {
    padding: 28px 24px 18px;
    background: linear-gradient(180deg, rgba(247,147,26,0.10), var(--ink-2) 80%);
    flex: 0 0 auto;
    position: relative; /* keep modal-close anchored here */
  }
  .modal-domain { font-size: 22px; line-height: 1.1; }
  /* Body: takes remaining space and scrolls */
  .modal-body {
    padding: 20px 24px 24px;
    flex: 1 1 auto;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior: contain; /* don't chain scroll to page below */
    min-height: 0; /* allow flex-shrink under content */
  }
  /* CTA: anchored bottom, never scrolls, never shrinks */
  .modal-cta {
    padding: 14px 18px calc(14px + env(safe-area-inset-bottom, 0px));
    flex-direction: column;
    gap: 8px;
    flex: 0 0 auto;
    background: var(--ink-3);
    border-top: 1px solid var(--line);
  }
  .modal-cta .btn { width: 100%; min-height: 50px; }
  /* Close button stays in header */
  .modal-close { top: 14px; right: 14px; }
}

/* When modal is open, lock the page beneath so it can't peek through */
body.modal-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
  height: 100%;
}

/* Article body — responsive typography */
@media (max-width: 640px) {
  .article { padding: 120px 0 60px; }
  .article-head h1 {
    font-size: clamp(28px, 8vw, 40px);
  }
  .article-head .excerpt { font-size: 16px; }
  .article-body { font-size: 16px; line-height: 1.7; }
  .article-body h2 { font-size: 24px; margin: 36px 0 14px; }
  .article-body h3 { font-size: 18px; margin: 24px 0 10px; }
  .article-body .callout { padding: 18px 22px; font-size: 15px; }
  .article-meta { font-size: 12px; flex-wrap: wrap; gap: 10px; }
}

/* Contact form: spacing on mobile */
@media (max-width: 640px) {
  .contact { padding: 80px 0 60px; }
  .contact-form { padding: 28px 22px; margin-top: 32px; border-radius: 18px; }
  .contact h2.display { font-size: clamp(28px, 7vw, 42px); }
}

/* Process steps: compact on mobile */
@media (max-width: 640px) {
  .process-step { padding: 28px; }
  .process-step .num { font-size: 80px; top: -10px; right: 14px; }
  .process-step h4 { font-size: 18px; }
}

/* About card: less aggressive watermark on mobile */
@media (max-width: 640px) {
  .about-card { padding: 32px 24px; }
  .about-card::before { font-size: 180px; top: -20px; right: -10px; }
}

/* Footer: simpler stack */
@media (max-width: 480px) {
  .foot { grid-template-columns: 1fr; gap: 28px; }
  .foot-bottom { flex-direction: column; align-items: flex-start; }
}

/* Floating action: better placement on mobile */
@media (max-width: 640px) {
  .floating-action {
    bottom: 16px;
    right: 16px;
    padding: 12px 18px;
    font-size: 13px;
  }
}

/* Disable hero canvas particles on small screens (perf) */
@media (max-width: 640px) {
  .hero-canvas { opacity: 0.3; }
}

/* Reduce parallax intensity on mobile (kann sonst seekrank machen) */
@media (max-width: 880px) {
  .orb-1, .orb-2, .hero-canvas { transform: none !important; transition: none !important; }
}

/* iOS bottom-bar safe-area for floating action */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .floating-action { bottom: calc(16px + env(safe-area-inset-bottom)); }
  .modal { padding-bottom: env(safe-area-inset-bottom); }
}

/* Smooth font rendering on mobile */
@media (max-width: 880px) {
  body {
    -webkit-text-size-adjust: 100%;
    -webkit-tap-highlight-color: transparent;
  }
}

/* Prevent horizontal scroll on overflow elements */
@media (max-width: 640px) {
  html, body { overflow-x: hidden; max-width: 100vw; }
  .domain-card .name { word-break: break-word; }
}

/* ============================================================
   DOMAIN DETAIL PAGE (v2.7) — responsive hero + specs
   ============================================================ */
.detail-hero-grid{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(0,0.9fr);
  gap:60px;
  align-items:center;
}
.detail-hero-grid > div, .detail-hero-grid > aside{ min-width:0 }
.detail-hero-name{
  font-family:'JetBrains Mono',monospace;
  letter-spacing:-0.02em;line-height:1.05;margin-bottom:28px;
  /* Long domain names (bitcoinlearningplatform.com, bitcoinassetgroup.com etc.)
     must wrap, not truncate. Default: prefer breaking at <wbr> (between name and TLD).
     Fallback: break-word for cases where even the name alone overflows.
     NOTE: font-size is set inline per-domain (length-aware) — don't !important here. */
  word-break:keep-all;overflow-wrap:break-word;hyphens:none;
  white-space:normal;max-width:100%;
  overflow:visible;text-overflow:clip;
}
.detail-hero-name .tld{ white-space:nowrap; display:inline-block; }
.detail-hero-name .tld{color:var(--txt-3)}
.detail-specs{
  background:var(--ink-2);border:1px solid var(--line);
  border-radius:var(--radius-xl);padding:32px 36px;
}
.detail-specs h2{
  font-size:11px;color:var(--txt-3);
  letter-spacing:0.14em;text-transform:uppercase;
  font-weight:700;margin-bottom:18px;
}
.detail-specs dl{
  display:grid;grid-template-columns:auto 1fr;
  gap:12px 18px;font-size:14px;
}
.detail-specs dt{color:var(--txt-3)}
.detail-specs dd{color:var(--txt);word-break:break-word;overflow-wrap:anywhere}
.detail-specs dd.mono{font-family:'JetBrains Mono',monospace}
.detail-bundle-pill{
  display:inline-block;max-width:100%;
  padding:5px 12px;border-radius:6px;
  background:rgba(247,147,26,0.10);color:var(--btc);
  font-size:13px;font-weight:600;
  white-space:normal;line-height:1.4;
}

@media (max-width:980px){
  .detail-hero-grid{
    grid-template-columns:1fr;
    gap:40px;
  }
  .detail-specs{padding:24px 28px}
}
@media (max-width:640px){
  .detail-hero-name{
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
    word-break:break-word !important;
    overflow-wrap:anywhere !important;
    font-size:clamp(28px,8vw,44px) !important;
    line-height:1.05 !important;
    margin-bottom:22px !important;
  }
  .detail-specs{padding:20px 22px}
  .detail-specs dl{font-size:13px;gap:10px 14px}
  .detail-bundle-pill{font-size:12px;padding:5px 10px}
}

/* ============================================================
   PHASE 3 POLISH — Tablet, Snap, Sticky-Filter, Landscape (v2.4)
   ============================================================ */

/* ---------- 1. TABLET MEGA-MENU (881-1024px) ---------- */
@media (min-width: 881px) and (max-width: 1024px) {
  .mega-panel {
    min-width: 480px;
    max-width: calc(100vw - 60px);
    padding: 24px;
  }
  .mega-grid.three-col {
    grid-template-columns: 1fr 1fr;
  }
  .nav-links { gap: 24px; }
  .nav-cta { padding: 9px 14px; font-size: 13px; }
  .lang-switcher a { padding: 4px 8px; }
  .mega-panel { max-height: calc(100vh - 140px); overflow-y: auto; }
}
@media (min-width: 881px) and (max-width: 1100px) {
  .nav-item.has-mega:nth-child(2) .mega-panel,
  .nav-item.has-mega:nth-child(3) .mega-panel {
    left: auto;
    right: 0;
    transform: translateX(0) translateY(-8px);
  }
  .nav-item.has-mega:nth-child(2):hover .mega-panel,
  .nav-item.has-mega:nth-child(2):focus-within .mega-panel,
  .nav-item.has-mega:nth-child(3):hover .mega-panel,
  .nav-item.has-mega:nth-child(3):focus-within .mega-panel {
    transform: translateX(0) translateY(0);
  }
  .nav-item.has-mega:nth-child(2) .mega-panel::before,
  .nav-item.has-mega:nth-child(3) .mega-panel::before {
    left: auto;
    right: 30px;
    transform: translateX(0) rotate(45deg);
  }
}

/* ---------- 2. CAROUSEL SCROLL-SNAP ---------- */
@media (max-width: 900px) {
  .carousel-viewport {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scroll-padding: 16px;
    scrollbar-width: none;
  }
  .carousel-viewport::-webkit-scrollbar { display: none; }
  .carousel-track {
    transform: none !important;
    transition: none !important;
  }
  .carousel-card {
    scroll-snap-align: center;
    scroll-snap-stop: always;
  }
  .carousel-viewport::after {
    background: linear-gradient(-90deg, var(--ink), transparent);
    width: 24px;
  }
  .carousel-viewport::before {
    background: linear-gradient(90deg, var(--ink), transparent);
    width: 24px;
  }
}

/* ---------- 4. MODAL LANDSCAPE FIX ---------- */
@media (max-height: 600px) and (orientation: landscape) {
  .modal-overlay { padding: 12px; align-items: center; }
  .modal {
    max-height: calc(100vh - 24px);
    border-radius: var(--radius-xl);
    transform: translateY(0) scale(0.96);
  }
  .modal-overlay.open .modal {
    transform: translateY(0) scale(1);
  }
  .modal-header {
    padding: 24px 32px 18px;
    position: sticky;
    top: 0;
    background: var(--ink-2);
    z-index: 2;
    border-bottom: 1px solid var(--line);
  }
  .modal-domain {
    font-size: 22px;
    margin-bottom: 10px;
  }
  .modal-body { padding: 20px 32px; }
  .modal-section { margin-bottom: 18px; }
  .modal-section .price-range { font-size: 22px; margin-top: 4px; }
  .modal-cta {
    padding: 14px 24px;
    flex-direction: row;
    position: sticky;
    bottom: 0;
    z-index: 2;
  }
  .modal-cta .btn { flex: 1; }
}

/* On very narrow phones (<360px) */
@media (max-width: 360px) {
  .container { padding: 0 14px; }
  .hero h1 { font-size: clamp(28px, 8vw, 36px); }
  .hero p.lead { font-size: 14px; }
  .stat-num { font-size: 24px; }
  .stat-label { font-size: 9px; }
  .chip { font-size: 11px; padding: 6px 9px; }
  .domain-card { padding: 14px 16px; }
  .domain-card .name { font-size: 14px; }
}

/* ---------- BONUS: Better focus-states for keyboard nav ---------- */
*:focus-visible {
  outline: 2px solid var(--btc);
  outline-offset: 3px;
  border-radius: 4px;
}
.btn:focus-visible,
.chip:focus-visible,
.nav-cta:focus-visible {
  outline-offset: 4px;
}

/* ============================================================
   COOKIE BANNER (DSGVO/TTDSG, Stripe-style minimal)
   ============================================================ */
#bag-cookie-banner{
  position:fixed;left:16px;right:16px;bottom:16px;
  z-index:9000;
  background:var(--ink-2);border:1px solid var(--line-2);
  border-radius:14px;padding:14px 18px;
  box-shadow:0 24px 64px rgba(0,0,0,0.55);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transform:translateY(120%);opacity:0;
  transition:transform 320ms cubic-bezier(0.22,1,0.36,1),opacity 240ms;
  max-width:1200px;margin:0 auto;
}
#bag-cookie-banner.show{transform:translateY(0);opacity:1}
.cb-inner{
  display:flex;align-items:center;gap:18px;
  flex-wrap:wrap;justify-content:space-between;
}
.cb-text{
  font-size:13px;color:var(--txt-2);line-height:1.55;
  flex:1 1 380px;min-width:280px;
}
.cb-link{color:var(--btc);text-decoration:none;white-space:nowrap}
.cb-link:hover{text-decoration:underline}
.cb-actions{display:flex;gap:8px;flex-wrap:wrap}
.cb-btn{
  padding:10px 18px;border-radius:10px;
  font-size:13px;font-weight:600;font-family:inherit;
  cursor:pointer;transition:all 200ms var(--ease);
  -webkit-tap-highlight-color:transparent;min-height:42px;
}
.cb-essential{
  background:transparent;color:var(--txt-2);
  border:1px solid var(--line-2);
}
.cb-essential:hover{background:var(--ink-3);color:var(--txt)}
.cb-accept{
  background:var(--btc);color:var(--ink);border:1px solid var(--btc);
}
.cb-accept:hover{background:#ffae3d;transform:translateY(-1px)}

@media (max-width:640px){
  #bag-cookie-banner{left:8px;right:8px;bottom:8px;padding:14px 16px}
  .cb-inner{gap:12px}
  .cb-text{font-size:12.5px;flex:1 1 100%}
  .cb-actions{width:100%}
  .cb-btn{flex:1;justify-content:center;display:flex;align-items:center}
}

/* ============================================================
   FILTER BOTTOM-SHEET — Mobile only (RESTORED v2.9.1)
   ============================================================ */
/* Desktop: hide the filter-toggle button entirely */
@media (min-width: 641px) {
  .filter-toggle-btn { display: none !important; }
}
/* Mobile: hide the inline filter-rows, show only the toggle button */
@media (max-width: 640px) {
  .browser-controls .filter-row { display: none !important; }
  .browser-controls.sheet-open .filter-row { display: flex !important; }
  .filter-toggle-btn {
    display: flex; align-items: center; justify-content: center; gap: 6px;
    width: 100%; padding: 12px 16px; margin-top: 8px;
    background: var(--ink-3); border: 1px solid var(--line);
    border-radius: 12px; color: var(--btc);
    font-size: 13px; font-weight: 600; letter-spacing: 0.04em;
    text-transform: uppercase; cursor: pointer;
    -webkit-tap-highlight-color: transparent;
  }
  .filter-toggle-btn .filter-count {
    background: var(--btc); color: var(--ink); border-radius: 999px;
    padding: 1px 8px; font-size: 11px; margin-left: 4px;
  }
}

/* Filter bottom-sheet overlay + sheet itself (mobile only) */
.filter-sheet-overlay {
  position: fixed; inset: 0;
  background: rgba(10,10,11,0.7);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  z-index: 998; opacity: 0; visibility: hidden;
  transition: opacity 240ms ease, visibility 240ms;
}
.filter-sheet-overlay.open { opacity: 1; visibility: visible; }
.filter-sheet {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 999; background: var(--ink-2);
  border-top-left-radius: 24px; border-top-right-radius: 24px;
  border-top: 1px solid var(--line);
  padding: 16px 20px env(safe-area-inset-bottom, 24px);
  max-height: 85vh; overflow-y: auto;
  transform: translateY(100%);
  transition: transform 320ms cubic-bezier(0.22,1,0.36,1);
  box-shadow: 0 -20px 60px rgba(0,0,0,0.5);
}
.filter-sheet.open { transform: translateY(0); }
.filter-sheet-handle {
  width: 40px; height: 4px; background: var(--line);
  border-radius: 2px; margin: 0 auto 16px;
}
.filter-sheet-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px;
}
.filter-sheet-title {
  font-family: var(--font-display, 'Inter Tight', sans-serif);
  font-size: 18px; font-weight: 700;
}
.filter-sheet-close {
  background: transparent; border: 1px solid var(--line);
  border-radius: 50%; width: 32px; height: 32px;
  color: var(--txt-2); font-size: 18px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.filter-sheet-section { margin-bottom: 18px; }
.filter-sheet-section .section-label {
  font-size: 11px; font-weight: 600; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--txt-3); margin-bottom: 8px;
}
.filter-sheet-section .chip-row {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.filter-sheet-actions {
  display: flex; gap: 12px;
  position: sticky; bottom: 0; background: var(--ink-2);
  padding-top: 12px; margin: 0 -4px;
}
.filter-sheet-actions .btn { flex: 1; }
@media (min-width: 641px) {
  .filter-sheet-overlay, .filter-sheet { display: none; }
}

/* ======================== Inline Mini-Make-Offer Form ======================== */
/* Placed directly after detail-hero on domain pages — low-friction quick-offer CTA. */
.inline-offer-card {
  background: linear-gradient(135deg, rgba(247,147,26,0.06) 0%, rgba(247,147,26,0.02) 100%);
  border: 1px solid rgba(247,147,26,0.22);
  border-radius: 18px;
  padding: 22px 24px;
  margin: 28px 0 12px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 18px;
  align-items: center;
}
.inline-offer-head {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Inter Tight', sans-serif; font-weight: 700;
  font-size: 17px; letter-spacing: -0.01em; color: var(--txt);
  margin-bottom: 4px;
}
.inline-offer-head::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--btc); box-shadow: 0 0 0 4px rgba(247,147,26,0.18);
}
.inline-offer-sub {
  color: var(--txt-2); font-size: 14px; line-height: 1.55;
}
.inline-offer-form {
  display: grid;
  grid-template-columns: 1fr 1.4fr auto;
  gap: 8px; margin-top: 14px;
}
.inline-offer-form input[type="email"],
.inline-offer-form input[type="number"] {
  background: var(--ink); border: 1px solid var(--line);
  color: var(--txt); padding: 12px 14px; border-radius: 10px;
  font-size: 14px; font-family: inherit;
  transition: border-color 0.15s, background-color 0.15s;
}
.inline-offer-form input:focus {
  outline: none; border-color: var(--btc); background: var(--ink-2);
}
.inline-offer-form button {
  background: var(--btc); color: var(--ink); border: 0;
  padding: 12px 22px; border-radius: 10px;
  font-family: inherit; font-size: 14px; font-weight: 700;
  cursor: pointer; transition: transform 0.12s, box-shadow 0.12s;
  white-space: nowrap;
}
.inline-offer-form button:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(247,147,26,0.28);
}
.inline-offer-foot {
  font-size: 12px; color: var(--txt-3); margin-top: 10px;
}
.inline-offer-foot a { color: var(--btc); text-decoration: none; }
.inline-offer-foot a:hover { text-decoration: underline; }
.inline-offer-success, .inline-offer-error {
  margin-top: 10px; padding: 10px 14px; border-radius: 10px;
  font-size: 13px; line-height: 1.5;
}
.inline-offer-success {
  background: rgba(34,197,94,0.08); color: rgba(134,239,172,0.95);
  border: 1px solid rgba(34,197,94,0.2);
}
.inline-offer-error {
  background: rgba(239,68,68,0.08); color: rgba(252,165,165,0.95);
  border: 1px solid rgba(239,68,68,0.2);
}
@media (max-width: 760px) {
  .inline-offer-card { grid-template-columns: 1fr; }
  .inline-offer-form { grid-template-columns: 1fr; }
  .inline-offer-form button { width: 100%; }
}
/* ====================== /Inline Mini-Make-Offer Form ====================== */

/* ======================== Comparable Sales Module (Homepage) ======================== */
.comparables-section { padding: 100px 0; }
.comparables-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 18px;
  margin-top: 48px;
}
.comparable-card {
  background: var(--ink);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px 26px 24px;
  transition: border-color 0.18s, transform 0.18s;
  display: flex; flex-direction: column;
}
.comparable-card:hover {
  border-color: rgba(247,147,26,0.45);
  transform: translateY(-2px);
}
.comp-price {
  font-family: 'Inter Tight', 'Inter', sans-serif;
  font-weight: 800; font-size: clamp(28px, 4vw, 40px);
  letter-spacing: -0.025em; color: var(--btc);
  line-height: 1; margin-bottom: 8px;
}
.comp-domain {
  font-family: 'JetBrains Mono', monospace;
  font-size: 17px; font-weight: 500; color: var(--txt);
  margin-bottom: 14px; word-break: break-all;
}
.comp-meta {
  display: flex; flex-wrap: wrap; gap: 6px 12px;
  font-size: 12px; color: var(--txt-3);
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 14px; font-weight: 600;
}
.comp-meta .comp-year { color: var(--txt-2); }
.comp-meta .comp-buyer::before { content: "·"; margin-right: 12px; color: var(--txt-3); }
.comp-meta .comp-cat::before { content: "·"; margin-right: 12px; color: var(--txt-3); }
.comp-note {
  color: var(--txt-2); font-size: 13.5px; line-height: 1.55;
  margin-top: auto;
}
.comp-disclaimer {
  margin-top: 36px; font-size: 12.5px; color: var(--txt-3);
  line-height: 1.55; max-width: 760px; padding: 14px 18px;
  background: rgba(255,255,255,0.02); border: 1px dashed var(--line);
  border-radius: 10px;
}
@media (max-width: 768px) {
  .comparables-section { padding: 64px 0; }
  .comparables-grid { gap: 12px; }
  .comparable-card { padding: 22px 20px; }
}
/* ====================== /Comparable Sales Module ====================== */

/* ======================== Trust-Stats / Track-Record Cards (About) ======================== */
.trust-card {
  background: var(--ink);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 28px 26px 24px;
  transition: transform 0.18s, border-color 0.18s;
  display: flex; flex-direction: column;
}
.trust-card:hover {
  transform: translateY(-2px);
  border-color: rgba(247,147,26,0.4);
}
.trust-num {
  font-family: 'Inter Tight', 'Inter', sans-serif;
  font-weight: 900; font-size: clamp(36px, 5vw, 56px);
  letter-spacing: -0.03em; color: var(--btc);
  line-height: 1; margin-bottom: 10px;
}
.trust-label {
  font-family: 'Inter Tight', 'Inter', sans-serif;
  font-weight: 700; font-size: 16px; color: var(--txt);
  margin-bottom: 8px; letter-spacing: -0.01em;
}
.trust-note {
  color: var(--txt-2); font-size: 13.5px; line-height: 1.55;
  margin-top: auto;
}
/* ===================== /Trust-Stats Cards ===================== */

/* ======================== Newsletter Signup (Footer, JS-injected) ======================== */
.newsletter-row { padding: 24px 0 32px; margin-bottom: 32px; border-bottom: 1px solid var(--line); }
.newsletter-card {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  align-items: center;
  background: linear-gradient(135deg, rgba(247,147,26,0.05) 0%, rgba(247,147,26,0.01) 100%);
  border: 1px solid rgba(247,147,26,0.18);
  border-radius: 18px;
  padding: 28px 32px;
}
.newsletter-text .eyebrow { color: var(--btc); margin-bottom: 6px; }
.newsletter-h {
  font-family: 'Inter Tight', sans-serif;
  font-weight: 800;
  font-size: clamp(20px, 2.4vw, 26px);
  letter-spacing: -0.02em;
  margin: 4px 0 8px;
  color: var(--txt);
}
.newsletter-sub {
  color: var(--txt-2);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
}
.newsletter-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  align-self: start;
}
.newsletter-form input[type="email"] {
  background: var(--ink);
  border: 1px solid var(--line);
  color: var(--txt);
  padding: 12px 14px;
  border-radius: 10px;
  font-size: 14px;
  font-family: inherit;
  transition: border-color 0.15s, background-color 0.15s;
}
.newsletter-form input:focus {
  outline: none;
  border-color: var(--btc);
  background: var(--ink-2);
}
.newsletter-form button {
  background: var(--btc);
  color: var(--ink);
  border: 0;
  padding: 12px 22px;
  border-radius: 10px;
  font-family: inherit;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.12s, box-shadow 0.12s;
  white-space: nowrap;
}
.newsletter-form button:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(247,147,26,0.28);
}
.newsletter-note {
  grid-column: 1 / -1;
  font-size: 11.5px;
  color: var(--txt-3);
  margin-top: 4px;
  line-height: 1.4;
}
.newsletter-msg {
  grid-column: 1 / -1;
  font-size: 13px;
  line-height: 1.5;
  padding: 0;
  margin-top: 4px;
}
.newsletter-msg.success { color: rgba(134,239,172,0.95); }
.newsletter-msg.error { color: rgba(252,165,165,0.95); }
@media (max-width: 760px) {
  .newsletter-card { grid-template-columns: 1fr; padding: 22px; }
  .newsletter-form { grid-template-columns: 1fr; }
  .newsletter-form button { width: 100%; }
}
/* ===================== /Newsletter Signup ===================== */


/* === VAULT EDITORIAL HELPERS — appended by vault_rollout.py === */
/* Editorial section numbering (§ 02 · ...) — used in Phase 2 high-impact pages */
.bag-section-num{font-family:var(--font-mono);font-size:11px;color:var(--btc);letter-spacing:0.20em;text-transform:uppercase}
/* Anchor diamond marker for featured/Tier-1 domains */
.bag-anchor::before{content:"\25C6";color:var(--btc);margin-right:8px;font-size:0.9em}
/* Tier badge (Tier 1 = bronze, others = mute) */
.bag-tier{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:10px;letter-spacing:0.10em;text-transform:uppercase;padding:2px 8px;border:1px solid var(--line);color:var(--txt-2)}
.bag-tier-1{color:var(--btc);border-color:rgba(184,137,58,0.35)}
/* Vault-style serif headlines (use on any h1/h2 without .display) */
.bag-serif{font-family:var(--font-serif);font-weight:400;letter-spacing:-0.02em;line-height:1.05}
.bag-italic{font-style:italic;color:var(--btc-soft)}
/* Tabular numbers — apply to any element containing numerals (prices/stats) */
.bag-tabular,.tabular,[data-count]{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1}
/* Override existing block-head h2 to use Newsreader serif globally */
.block-head h2{font-family:var(--font-serif)!important;font-weight:400!important;letter-spacing:-0.025em!important;line-height:1.05!important}
/* Hero h1 — Newsreader applies via .display, but ensure all hero headlines do too */
.hero h1,.hero h2{font-family:var(--font-serif);font-weight:400;letter-spacing:-0.025em}
/* Bigger stat numbers as Newsreader serif (editorial register) */
.stat-num,.trust-item .num,.comp-price,.bundle-price{font-family:var(--font-serif)!important;font-weight:400!important;font-variant-numeric:tabular-nums}


/* === VAULT PHASE 2 — HERO EDITORIAL UPGRADE (2026-05-12) === */
/* Kill the bright-Bitcoin-era hero canvas + orbs (animated background).
   Vault is restraint — Editorial brands don't animate the canvas. */
.hero-canvas,.orb{display:none!important}
/* Subtle stronger radial — bronze tone, already swapped from orange */
.hero-bg::before{
  background-image:
    radial-gradient(ellipse 80% 50% at 50% 0%,rgba(184,137,58,0.10),transparent 65%),
    radial-gradient(ellipse 40% 30% at 80% 20%,rgba(184,137,58,0.05),transparent 70%)!important;
}

/* Editorial eyebrow row — bronze rule line + mono uppercase label */
.hero-vol{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:0.20em;text-transform:uppercase;
  color:var(--btc);
  margin-bottom:36px;
}
.hero-vol::before{
  content:'';display:inline-block;
  width:32px;height:1px;background:var(--btc);
}
.hero-vol .vol-sep{color:var(--btc-deep);margin:0 2px}
.hero-vol .vol-meta{color:var(--txt-2);letter-spacing:0.14em}

/* Hide the old orange pill — replaced by .hero-vol */
.hero-pill{display:none}

/* H1 italic accent: ensure .gradient-text reads as italic editorial bronze */
.hero h1 .gradient-text{font-style:italic;font-weight:400}

/* Lead text — slight color adjustment to bone */
.hero p.lead{color:var(--txt);opacity:0.78}

/* Make-offer footer line below trust row */
.hero-bottom-meta{
  margin-top:32px;padding-top:18px;
  border-top:1px solid rgba(184,137,58,0.35);
  display:flex;justify-content:space-between;align-items:baseline;flex-wrap:wrap;gap:18px;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:0.16em;text-transform:uppercase;
  color:var(--txt-2);
  max-width:680px;
}
.hero-bottom-meta .bm-strong{color:var(--btc);letter-spacing:0.18em}

/* Trust-item polish — labels in mono, numbers in Newsreader serif (already overridden above) */
.hero-trust{
  margin-top:48px;padding-top:32px;
  border-top:1px solid var(--line);
  max-width:680px;
}
.trust-item .lbl{
  font-family:var(--font-mono)!important;
  font-size:10px!important;
  letter-spacing:0.16em!important;
  color:var(--txt-2)!important;
  font-weight:400!important;
}
.trust-item .num{font-size:clamp(38px,4.2vw,52px)!important;line-height:0.9!important;letter-spacing:-0.02em}
.trust-divider{background:var(--line)!important;width:1px;height:40px}

/* Mobile: stack trust row, hide bottom-meta if too tight */
@media(max-width:760px){
  .hero-vol{font-size:10px;gap:10px;margin-bottom:24px}
  .hero-vol::before{width:24px}
  .hero-trust{flex-wrap:wrap;gap:20px}
  .trust-divider{display:none}
  .hero-bottom-meta{font-size:10px}
}
/* === /VAULT PHASE 2 HERO === */


/* === VAULT PHASE 2.3 + 2.4 — BUNDLES + JOURNAL EDITORIAL (2026-05-12) === */

/* --- Editorial eyebrow + Bronze rule (reusable on bundle + article heroes) --- */
.bag-eyebrow-line{
  display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:0.20em;text-transform:uppercase;
  color:var(--btc);
  margin-bottom:28px;
  line-height:1.6;
}
.bag-eyebrow-line::before{
  content:'';display:inline-block;
  width:32px;height:1px;background:var(--btc);
  flex-shrink:0;
}
.bag-eyebrow-line .e-sep{color:var(--btc-deep);margin:0 2px}
.bag-eyebrow-line .e-meta{color:var(--txt-2);letter-spacing:0.14em}
.bag-eyebrow-line .e-strong{color:var(--btc);letter-spacing:0.22em}

/* --- Lot tag chip — small bronze pill marker --- */
.bag-lot-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:0.18em;text-transform:uppercase;
  color:var(--btc);
  padding:3px 9px;
  border:1px solid rgba(184,137,58,0.45);
  border-radius:0;
}

/* --- Journal masthead — NYT-style double-rule with branded review name --- */
.bag-masthead{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;
  font-family:var(--font-mono);font-size:10px;
  letter-spacing:0.20em;text-transform:uppercase;
  color:var(--txt-2);
  padding:14px 0;
  border-top:3px double var(--txt);
  border-bottom:1px solid var(--txt);
  margin-bottom:32px;
}
.bag-masthead .mh-brand{color:var(--btc);letter-spacing:0.22em;font-weight:500}
.bag-masthead .mh-side{color:var(--txt-3);letter-spacing:0.16em}

/* --- Anchor callout strengthening (bundle pages have .callout for anchor) --- */
.callout strong{font-family:var(--font-mono);font-size:11px!important;letter-spacing:0.16em;text-transform:uppercase}
.callout strong::before{content:"\25C6 ";color:var(--btc);margin-right:6px}

/* --- Sticky-sidebar bundle-card eyebrow upgrade --- */
.bundle-side-eyebrow{
  font-family:var(--font-mono)!important;
  font-size:10px!important;
  color:var(--btc)!important;
  letter-spacing:0.20em!important;
  text-transform:uppercase!important;
  font-weight:400!important;
  margin-bottom:14px;
  display:flex;align-items:center;gap:10px;
}
.bundle-side-eyebrow::before{
  content:'';display:inline-block;
  width:18px;height:1px;background:var(--btc);
}
.bundle-side-eyebrow .lt{color:var(--txt-2);letter-spacing:0.16em}

/* --- Volume eyebrow for bundles/index.html intro --- */
.bag-volume-eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--btc);
  margin-bottom:24px;
}
.bag-volume-eyebrow::before{
  content:'';display:inline-block;width:32px;height:1px;background:var(--btc);
}

/* --- Article meta polish — make breadcrumb mono editorial register --- */
.article-meta{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--txt-2);
}
.article-meta a{color:var(--btc)!important;text-decoration:none}
.article-meta .dot{
  width:3px;height:3px;background:var(--btc-deep);border-radius:50%;
  margin:0 6px;display:inline-block;vertical-align:middle;
}
.article-tag{
  color:var(--btc);
  border:1px solid rgba(184,137,58,0.35);
  padding:2px 8px;
  letter-spacing:0.12em;
}

/* --- Mobile --- */
@media(max-width:760px){
  .bag-eyebrow-line{font-size:10px;gap:10px}
  .bag-eyebrow-line::before{width:24px}
  .bag-masthead{font-size:9px;gap:8px}
  .bag-masthead .mh-side{display:none}
}
/* === /VAULT PHASE 2.3 + 2.4 === */


/* === VAULT PHASE 2.2 — WHOIS SPECIMEN (2026-05-13) === */
/* Augmented .detail-specs panel — WHOIS-style register for Tier-1 anchor pages */
.detail-specs.bag-specimen{
  background:var(--ink-2);
  border:1px solid var(--line);
  padding:28px 28px 24px;
  font-family:var(--font-sans);
}
.bag-specimen .bag-specimen-eyebrow{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.20em;
  text-transform:uppercase;
  color:var(--btc);
  padding-bottom:14px;
  margin-bottom:14px;
  border-bottom:1px solid var(--btc-deep);
}
.bag-specimen .bag-specimen-eyebrow .e-sep{color:var(--btc-deep);margin:0 2px}
.bag-specimen .bag-specimen-divider{
  font-family:var(--font-mono);
  font-size:10px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--txt-2);
  margin:18px 0 10px;
  padding-top:14px;
  border-top:1px solid var(--line);
}
.bag-specimen dl{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:8px 18px;
  margin:0;
}
.bag-specimen dt{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:0.06em;
  color:var(--txt-2);
  text-transform:none;
  font-weight:400;
}
.bag-specimen dd{
  font-family:var(--font-mono);
  font-size:12px;
  color:var(--txt);
  margin:0;
  text-align:right;
}
.bag-specimen dd.mono{font-family:var(--font-mono);color:var(--txt)}
/* Sticky behavior on wide screens */
@media(min-width:1100px){
  .detail-specs.bag-specimen{position:sticky;top:120px}
}
@media(max-width:760px){
  .bag-specimen dd{text-align:left}
}
/* === /VAULT PHASE 2.2 === */


/* === VAULT PHASE 4 — NEWSLETTER + SPONSOR SLOTS (2026-05-13) === */

/* Newsletter signup capture card — Vault-themed */
.bag-newsletter{
  background: linear-gradient(180deg, var(--ink-2) 0%, var(--ink) 100%);
  border: 1px solid var(--btc-deep);
  padding: 40px 44px;
  margin: 60px 0;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 36px;
  align-items: center;
}
.bag-newsletter .nl-head{
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--btc);
  margin-bottom: 14px;
}
.bag-newsletter h3{
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--txt);
  margin: 0 0 14px;
}
.bag-newsletter h3 em{ font-style: italic; color: var(--btc-soft); }
.bag-newsletter .nl-desc{
  font-family: var(--font-sans);
  font-size: 14px;
  line-height: 1.55;
  color: var(--txt-2);
  margin: 0;
}
.bag-newsletter form{
  display: flex; flex-direction: column; gap: 10px;
}
.bag-newsletter input[type="email"]{
  background: var(--ink);
  border: 1px solid var(--line-2);
  color: var(--txt);
  font-family: var(--font-mono);
  font-size: 13px;
  padding: 14px 16px;
  letter-spacing: 0.02em;
}
.bag-newsletter input[type="email"]:focus{
  outline: none;
  border-color: var(--btc);
}
.bag-newsletter button{
  background: var(--btc);
  color: var(--ink);
  border: none;
  font-family: var(--font-sans);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.04em;
  padding: 12px 22px;
  cursor: pointer;
  transition: background 160ms var(--ease);
}
.bag-newsletter button:hover{ background: var(--btc-soft); }
.bag-newsletter .nl-foot{
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.10em;
  color: var(--txt-3);
  margin-top: 4px;
}
.newsletter-msg{
  font-family: var(--font-mono);
  font-size: 11px;
  margin-top: 6px;
}
.newsletter-msg.success{ color: rgba(134,239,172,0.92); }
.newsletter-msg.error{ color: rgba(252,165,165,0.92); }
@media (max-width: 760px){
  .bag-newsletter{ grid-template-columns: 1fr; padding: 28px; gap: 22px; }
}

/* Sponsor slot — clearly marked, Vault-themed */
.bag-sponsor{
  margin: 50px auto;
  max-width: 1100px;
  padding: 22px 28px;
  background: var(--ink-2);
  border: 1px dashed var(--btc-deep);
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.bag-sponsor .sp-eyebrow{
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--btc-deep);
  flex-shrink: 0;
}
.bag-sponsor .sp-body{
  font-family: var(--font-sans);
  font-size: 14px;
  color: var(--txt-2);
  flex: 1;
  min-width: 240px;
}
.bag-sponsor .sp-body strong{ color: var(--txt); }
.bag-sponsor .sp-cta{
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--btc);
  text-decoration: none;
  border: 1px solid var(--btc-deep);
  padding: 8px 14px;
  letter-spacing: 0.04em;
}
.bag-sponsor .sp-cta:hover{ background: var(--btc); color: var(--ink); }
/* === /VAULT PHASE 4 === */


/* === PHASE 5 — UX REFINEMENTS (2026-05-13 evening) === */
/* Tobias-Feedback iteration. Targeted polish, no structural changes. */

/* 1. Hero h1 .gradient-text — switch from italic to bold for stronger confidence.
   Italic stays the default for in-body and section headlines; only the
   primary hero gets this bolder treatment. */
.hero.hero-split .hero-left h1 .gradient-text,
section.hero.hero-split h1.display .gradient-text{
  font-style: normal !important;
  font-weight: 600 !important;
  color: var(--btc) !important;
}

/* 2. Reduce excessive vertical spacing between sections.
   section.block was 140px 0 → 84px 0. .article was 140px 0 60px → 120px 0 40px. */
section.block{ padding: 84px 0 !important; }
section.article{ padding: 120px 0 40px !important; }
/* Domain detail pages have an inline-offer-card directly after article hero — tighten that gap */
section.block + section.block{ padding-top: 56px !important; }
/* Reveal-block-head margins were 80px — reduce */
.block-head{ margin-bottom: 48px !important; }

/* 3. Specimen panel: tighter internal spacing + slight inline-padding reduction.
   Right-alignment of values stays (treasury convention) — but the gap pulls tighter. */
.detail-specs.bag-specimen{ padding: 24px 24px 22px !important; }
.bag-specimen dl{ gap: 6px 14px !important; }
.bag-specimen .bag-specimen-divider{ margin: 14px 0 8px !important; padding-top: 12px !important; }
/* Standard detail-specs (Tier-2/3/4) also tighten */
.detail-specs:not(.bag-specimen){ padding: 24px 26px !important; }
.detail-specs:not(.bag-specimen) dl{ gap: 9px 14px !important; }

/* 4. Quick-offer + newsletter cards — reduce internal padding to match new density */
.bag-newsletter{ padding: 32px 36px !important; margin: 36px 0 !important; }
.inline-offer-card{ padding: 22px 28px !important; }

/* 5. Reveal-class gentler intro — avoid feeling like the page is empty on load */
.reveal{ opacity: 0.85; transform: translateY(8px) !important; }
.reveal.in{ opacity: 1; transform: none; transition: opacity 360ms var(--ease-out), transform 360ms var(--ease-out) !important; }
/* === /PHASE 5 === */


/* === PHASE 5.1 — BODY-SECTION ALIGNMENT FIX (2026-05-13) === */
/* Below-specimen sections (narrative, etymology, use-cases, FAQ) shouldn't
   be full-width while hero is 2-column. Constrain them to match editorial
   reading width — feels like a continuation of the hero-left flow. */
section.block > .container > .block-head,
section.block > .container > [style*="grid-template-columns:1.4fr 1fr"] {
  max-width: 980px;
}
/* Use-cases 3-card grid stays wider for the card layout to breathe */
section.block > .container > [style*="auto-fit,minmax(280px,1fr)"] {
  max-width: 1100px;
}
/* === /PHASE 5.1 === */


/* === PHASE 5.2 — SOFT BITCOIN ORANGE HERO ACCENT (Tobias-Choice v4, 2026-05-13) === */
/* Tobias chose v4: Soft Bitcoin Orange #E69A3D for the "Bitcoin domain" hero accent.
   Wärmer/Bitcoin-erkennbarer als die Bronze-Tokens, ohne die Treasury-Konsistenz zu brechen.
   New token `--btc-bright` definiert für zukünftige Verwendungen.
   Wirkt NUR auf Homepage-Hero h1 .gradient-text — alle anderen .gradient-text-Stellen
   bleiben Bronze-30-italic (editorial Vault). */
:root {
  --btc-bright: #E69A3D;
}
.hero.hero-split .hero-left h1 .gradient-text,
section.hero.hero-split h1.display .gradient-text {
  color: #E69A3D !important;
  font-style: normal !important;
  font-weight: 600 !important;
}
/* DE mirror — same selector — Hero markup is identical, no extra rule needed */
/* === /PHASE 5.2 === */


/* === PHASE 5.4 — VIDEO BUG FIXES (2026-05-13) === */

/* Bug 1: Carousel-card domain names break in 2 lines (".com" widow)
   bitcoinwealthoffice.com → "bitcoinwealthoffice." / "com" — fix by:
   1. lower max font-size  
   2. word-break:normal (keep tld inline)
   3. nowrap on the .tld span so it stays attached to base name */
.carousel-card .cc-name{
  font-size: clamp(17px, 1.55vw, 22px) !important;
  word-break: normal !important;
  overflow-wrap: anywhere !important;
  letter-spacing: -0.012em;
}
.carousel-card .cc-name .tld{
  white-space: nowrap;
}

/* Bug 2: Specimen-panel + Bundle-side eyebrow tokens wrap individually
   (VOL./I, BUNDLE/#01, LOT/01) when container is narrow.
   Fix: allow flex-wrap, but each token block stays nowrap. */
.bundle-side-eyebrow,
.bag-eyebrow-line{
  flex-wrap: wrap !important;
  row-gap: 4px;
}
.bundle-side-eyebrow > *,
.bag-eyebrow-line > *{
  white-space: nowrap;
}
/* The text nodes between spans (e.g. "Vol. I", "Bundle №01", "Lot 01") 
   are anonymous flex items — wrap them via implicit child:
   actually simpler: just make the whole container nowrap on wider 
   containers, and only allow wrap on narrow ones. */
.bundle-side-eyebrow{
  white-space: nowrap;
}
@media (max-width: 480px){
  .bundle-side-eyebrow{
    white-space: normal;
  }
}

/* === /PHASE 5.4 === */


/* === PHASE 5.5 — PORTFOLIO FILTER REDESIGN (2026-05-14) === */

/* Filter container becomes a clear card with breathing padding */
.browser-controls{
  background: var(--ink-3) !important;
  border: 1px solid var(--line) !important;
  border-radius: 16px !important;
  padding: 32px 36px 24px !important;
  margin-bottom: 36px !important;
  /* sticky behavior preserved */
}

/* Search box more prominent */
.browser-controls .search-box{
  margin-bottom: 28px;
}
.browser-controls .search-box input{
  padding: 20px 22px 20px 56px !important;
  font-size: 16px !important;
  border-radius: 12px;
}
.browser-controls .search-box svg{
  left: 20px;
  width: 22px;
  height: 22px;
}

/* Filter rows: Label oberhalb, Chips darunter */
.browser-controls .filter-row{
  display: block !important;
  margin-top: 24px !important;
  padding-top: 22px;
  border-top: 1px solid var(--line);
}
.browser-controls .filter-row:first-of-type{
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}
.browser-controls .filter-label{
  display: block !important;
  font-family: var(--font-mono);
  font-size: 11px !important;
  letter-spacing: 0.22em !important;
  color: var(--btc) !important;
  font-weight: 500 !important;
  margin-bottom: 14px !important;
  margin-right: 0 !important;
  min-width: 0 !important;
  text-transform: uppercase;
}

/* Chip group: flex+wrap with bigger gap */
.chip-group{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

/* Chips bigger and more clickable */
.browser-controls .chip{
  padding: 11px 18px !important;
  font-size: 14px !important;
  border-radius: 11px !important;
  background: var(--ink-2);
  border: 1px solid var(--line);
}
.browser-controls .chip:hover:not(.disabled){
  border-color: var(--btc-soft);
  background: var(--ink);
}
.browser-controls .chip.active{
  background: var(--btc) !important;
  color: var(--ink) !important;
  border-color: var(--btc) !important;
  box-shadow: 0 4px 12px rgba(184,137,58,0.25);
}
.browser-controls .chip .count{
  font-size: 12px !important;
  padding: 2px 8px !important;
}

/* Results bar more prominent */
.results-bar{
  margin-bottom: 28px !important;
  padding: 18px 22px;
  background: rgba(184,137,58,0.04);
  border: 1px solid rgba(184,137,58,0.15);
  border-radius: 12px;
}
.results-count{
  font-size: 15px !important;
}
.results-count strong{
  font-size: 22px;
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--btc) !important;
  margin-right: 4px;
}
.sort-dropdown{
  padding: 10px 16px !important;
  font-size: 14px !important;
}

/* Mobile: keep filter card but reduce padding */
@media (max-width: 640px){
  .browser-controls{
    padding: 22px 18px !important;
  }
  .browser-controls .filter-row{
    margin-top: 18px !important;
    padding-top: 16px;
  }
}

/* === /PHASE 5.5 === */


/* === PHASE 5.6 — FILTER FLOATING BAR (2026-05-14) === */

/* Override Phase 5.5 sticky behavior — Filter-Card stays in-page, 
   floating bar takes over on scroll-past */
.browser-controls{
  position: static !important;
  top: auto !important;
  z-index: auto !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Floating filter bar — appears only after scroll past .browser-controls */
.filter-floating-bar{
  position: fixed;
  top: 96px;
  left: 0;
  right: 0;
  z-index: 55;
  background: rgba(13, 13, 15, 0.92);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-bottom: 1px solid rgba(184,137,58,0.18);
  padding: 12px 0;
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
  transition: transform 380ms cubic-bezier(0.22,1,0.36,1),
              opacity 240ms ease-out;
  box-shadow: 0 8px 28px -12px rgba(0,0,0,0.5);
}
.filter-floating-bar.show{
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.filter-floating-bar .ffb-inner{
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 32px;
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: nowrap;
}
.filter-floating-bar .ffb-count{
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 500;
  color: var(--btc);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.filter-floating-bar .ffb-count .ffb-count-label{
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--txt-3);
  margin-left: 8px;
  vertical-align: 2px;
}
.filter-floating-bar .ffb-pills{
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.filter-floating-bar .ffb-pills::-webkit-scrollbar{ display: none; }
.filter-floating-bar .ffb-pill{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: rgba(184,137,58,0.12);
  border: 1px solid rgba(184,137,58,0.28);
  border-radius: 8px;
  color: var(--btc);
  font-size: 12px;
  font-weight: 500;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  white-space: nowrap;
}
.filter-floating-bar .ffb-pill .ffb-pill-label{
  font-size: 10px;
  color: var(--txt-3);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  margin-right: 4px;
}
.filter-floating-bar .ffb-pill.ffb-none{
  background: transparent;
  border-color: var(--line);
  color: var(--txt-3);
}
.filter-floating-bar .ffb-actions{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}
.filter-floating-bar .ffb-sort{
  background: var(--ink-2);
  border: 1px solid var(--line);
  color: var(--txt-2);
  font-size: 12px;
  padding: 7px 12px;
  border-radius: 8px;
  font-family: inherit;
}
.filter-floating-bar .ffb-edit{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: var(--btc);
  color: var(--ink);
  border: none;
  border-radius: 9px;
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 180ms var(--ease);
}
.filter-floating-bar .ffb-edit:hover{
  background: var(--btc-bright, #E69A3D);
  transform: translateY(-1px);
}
.filter-floating-bar .ffb-edit svg{
  width: 12px; height: 12px;
}

/* Mobile compact */
@media (max-width: 720px){
  .filter-floating-bar .ffb-inner{
    padding: 0 16px;
    gap: 10px;
  }
  .filter-floating-bar .ffb-count{
    font-size: 18px;
  }
  .filter-floating-bar .ffb-count .ffb-count-label,
  .filter-floating-bar .ffb-sort{
    display: none;
  }
  .filter-floating-bar .ffb-edit{
    padding: 7px 11px;
    font-size: 11px;
  }
  .filter-floating-bar .ffb-edit-label{
    display: none;
  }
}

/* Add some breathing room when floating bar is visible — push nav down a bit */
body.filter-bar-active .top{
  /* Nav stays where it is, but it's invisible behind the floating bar */
}

/* === /PHASE 5.6 === */


/* === PHASE 5.6.2 — Bar/Nav coexistence === */
body.filter-bar-active .top{
  background: rgba(13,13,15,0.65) !important;
  border-bottom: none !important;
  opacity: 0.72;
  transition: opacity 280ms ease-out, background 280ms ease-out;
}
body.filter-bar-active .top:hover{
  opacity: 1;
  background: rgba(13,13,15,0.92) !important;
}
/* Hide in-page results-bar when floating bar is active to avoid duplicate */
body.filter-bar-active .results-bar{
  opacity: 0;
  pointer-events: none;
  height: 0;
  margin: 0;
  padding: 0;
  border: none;
  overflow: hidden;
  transition: opacity 200ms ease-out;
}
.filter-floating-bar{
  transform: translateY(calc(-100% - 80px));
}
.filter-floating-bar.show{
  transform: translateY(0);
}
/* === /PHASE 5.6.2 === */
