/* ════════════════════════════════════════════════════════
   COMPONENTS.CSS — All reusable UI components
   ════════════════════════════════════════════════════════ */

/* ─── BUTTONS ─── */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-body); font-weight: 600; font-size: .88rem;
  letter-spacing: .02em; padding: .85rem 1.75rem;
  border-radius: var(--radius); border: none; cursor: pointer;
  position: relative; overflow: hidden; text-decoration: none;
  transition: transform .18s ease, box-shadow .28s ease, background .28s ease, border-color .28s ease;
}
.btn::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 40%, rgba(255,255,255,.15) 50%, transparent 60%);
  transform: translateX(-100%); transition: transform .5s;
}
.btn:hover::after { transform: translateX(100%); }
.btn-fill  { background: var(--accent); color: #fff; box-shadow: 0 4px 22px var(--accent-glow); }
.btn-fill:hover  { transform: translateY(-2px); box-shadow: 0 10px 34px var(--accent-glow); }
.btn-ghost { background: transparent; color: var(--text-primary); border: 1.5px solid var(--line2); }
.btn-ghost:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-dim); }
.btn-sm  { font-size: .8rem;  padding: .55rem 1.1rem;  border-radius: 10px; }
.btn-lg  { font-size: .95rem; padding: 1rem 2.2rem;    border-radius: 14px; }
.btn-xl  { font-size: 1rem;   padding: 1.2rem 2.6rem;  border-radius: 14px; }

/* ─── CHIPS ─── */
.chip {
  display: inline-block; font-size: .7rem; font-weight: 600; color: var(--text-muted);
  padding: .26rem .72rem;
  background: linear-gradient(135deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid var(--line2); border-radius: 5px; letter-spacing: .04em;
  transition: border-color .28s, color .28s, background .28s, transform .18s;
}
.chip:hover { border-color: var(--accent); color: var(--text-primary); background: var(--accent-dim); transform: translateY(-1px); }
.chip-row { display: flex; flex-wrap: wrap; gap: .5rem; }

.tag {
  display: inline-block; font-size: .6rem; font-weight: 600; padding: .18rem .55rem;
  border-radius: 4px; text-transform: uppercase; letter-spacing: .05em;
  background: rgba(255,255,255,.04); border: 1px solid var(--line2); color: var(--text-dim);
  transition: border-color .28s, color .28s;
}

/* ─── NAV ─── */
.topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500; padding: .85rem 0;
  border-bottom: 1px solid transparent;
  transition: background .45s, padding .3s, border-color .28s, box-shadow .28s;
}
.topbar.stuck {
  background: rgba(14,13,22,.94); backdrop-filter: blur(22px) saturate(1.5);
  border-color: var(--line2); box-shadow: 0 2px 40px rgba(0,0,0,.35);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.logo { font-family: var(--font-display); font-size: 1.4rem; font-weight: 800; color: var(--text-primary); letter-spacing: -.03em; flex-shrink: 0; }
.logo em { font-style: normal; color: var(--accent); transition: color .28s; }
.logo sup { font-size: .42rem; color: var(--text-dim); vertical-align: super; font-family: var(--font-body); font-weight: 400; letter-spacing: .08em; }
.nav-links {
  display: flex; align-items: center; gap: .2rem;
  background: rgba(255,255,255,.04); border: 1px solid var(--line2); border-radius: 40px;
  padding: .3rem; backdrop-filter: blur(10px);
}
.nav-links li { list-style: none; }
.nav-links a { font-family: var(--font-body); font-size: .78rem; font-weight: 500; color: var(--text-muted); padding: .38rem .9rem; border-radius: 30px; display: block; transition: color .18s, background .18s; }
.nav-links a:hover  { color: var(--text-primary); background: var(--line1); }
.nav-links a.active { color: var(--text-primary); background: var(--bg4); }
.nav-right { display: flex; align-items: center; gap: .6rem; flex-shrink: 0; }
.hamburger { display: none; flex-direction: column; gap: 4px; background: none; border: none; padding: .4rem; cursor: pointer; }
.hamburger span { display: block; width: 20px; height: 1.5px; background: var(--text-primary); border-radius: 2px; transition: all .3s; }

/* ─── TICKER ─── */
.ticker {
  overflow: hidden;
  background: linear-gradient(90deg, var(--bg2), var(--bg3), var(--bg2));
  border-top: 1px solid var(--line2); border-bottom: 1px solid var(--line2);
  padding: .85rem 0; position: relative;
}
.ticker::before, .ticker::after {
  content: ''; position: absolute; top: 0; bottom: 0; width: 80px; z-index: 1;
}
.ticker::before { left: 0;  background: linear-gradient(90deg, var(--bg2), transparent); }
.ticker::after  { right: 0; background: linear-gradient(-90deg, var(--bg2), transparent); }
.ticker-track { display: flex; gap: 3rem; white-space: nowrap; animation: tickerRoll 26s linear infinite; }
.t-item { display: inline-flex; align-items: center; gap: .65rem; font-size: .7rem; font-weight: 600; color: var(--text-dim); text-transform: uppercase; letter-spacing: .12em; }
.t-sep { display: inline-block; width: 4px; height: 4px; border-radius: 50%; background: var(--accent); opacity: .55; }

/* ─── TRUST PILL ─── */
.trust-pill {
  display: inline-flex; align-items: center; gap: .65rem;
  padding: .42rem .9rem .42rem .6rem;
  background: linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border: 1px solid var(--line3); border-radius: 40px;
  font-size: .76rem; font-weight: 500; color: var(--text-muted);
  margin-bottom: 2.25rem; backdrop-filter: blur(8px);
}
.trust-dot { width: 7px; height: 7px; border-radius: 50%; background: #4ade80; flex-shrink: 0; box-shadow: 0 0 0 3px rgba(74,222,128,.2); animation: pulseDot 2.5s ease-in-out infinite; }
.trust-pill strong { color: var(--text-primary); }

/* ─── SERVICE CARDS ─── */
.svc-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.2rem; }
.svc-card {
  background: linear-gradient(145deg, var(--bg3), var(--bg2));
  border: 1px solid var(--line2); border-radius: var(--radius-lg);
  padding: 2rem; position: relative; overflow: hidden;
  box-shadow: 0 2px 20px rgba(0,0,0,.25);
  transition: border-color .38s, transform .28s, box-shadow .38s;
}
.svc-card::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse 130% 90% at 50% -10%, var(--accent-dim), transparent 60%);
  opacity: 0; transition: opacity .4s;
}
.svc-card::after {
  content: ''; position: absolute; top: 0; left: 15%; right: 15%; height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  opacity: 0; transition: opacity .4s;
}
.svc-card:hover { transform: translateY(-5px); border-color: var(--line3); box-shadow: 0 18px 52px rgba(0,0,0,.3); }
.svc-card:hover::before { opacity: 1; }
.svc-card:hover::after  { opacity: 1; }
.svc-wide { grid-column: span 2; background: linear-gradient(135deg, var(--bg4), var(--bg3)); }
.hot-badge {
  position: absolute; top: 1.2rem; right: 1.2rem;
  font-family: var(--font-body); font-size: .6rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase;
  color: var(--accent); background: var(--accent-dim); border: 1px solid var(--accent-glow); padding: .2rem .65rem; border-radius: 20px;
}
.svc-num { font-size: .62rem; font-weight: 700; color: var(--text-dim); letter-spacing: .12em; text-transform: uppercase; margin-bottom: 1.2rem; position: relative; }
.svc-icon { width: 46px; height: 46px; border-radius: 11px; border: 1px solid var(--line2); display: flex; align-items: center; justify-content: center; font-size: 1.25rem; margin-bottom: 1.2rem; background: rgba(255,255,255,.03); position: relative; transition: border-color .28s, background .28s; }
.svc-card:hover .svc-icon { border-color: var(--accent); background: var(--accent-dim); }
.svc-card h3 { font-size: 1.15rem; font-weight: 700; margin-bottom: .55rem; letter-spacing: -.022em; position: relative; }
.svc-card p  { font-size: .83rem; color: var(--text-muted); line-height: 1.75; margin-bottom: 1.4rem; position: relative; }
.svc-tags { display: flex; flex-wrap: wrap; gap: .35rem; margin-bottom: 1.2rem; position: relative; }
.svc-more { font-size: .78rem; font-weight: 600; color: var(--accent); display: inline-flex; align-items: center; gap: .4rem; opacity: 0; transform: translateY(4px); transition: opacity .25s, transform .25s; position: relative; }
.svc-card:hover .svc-more { opacity: 1; transform: translateY(0); }
.svc-filters { display: flex; gap: .45rem; flex-wrap: wrap; margin-bottom: 2.5rem; }
.filter-btn { font-family: var(--font-body); font-size: .76rem; font-weight: 500; letter-spacing: .04em; padding: .42rem 1rem; border-radius: 30px; border: 1px solid var(--line2); background: transparent; color: var(--text-muted); cursor: pointer; transition: all .25s; }
.filter-btn:hover { color: var(--text-primary); }
.filter-btn.active { background: var(--accent-dim); border-color: var(--accent); color: var(--accent); }

/* ─── METRICS ─── */
.metrics-row { display: grid; grid-template-columns: repeat(4,1fr); background: linear-gradient(135deg, var(--bg3), var(--bg2)); border: 1px solid var(--line2); border-radius: var(--radius-lg); overflow: hidden; }
.metric { padding: 2.75rem 2rem; border-right: 1px solid var(--line2); text-align: center; transition: background .28s; }
.metric:last-child { border-right: none; }
.metric:hover { background: rgba(255,255,255,.025); }
.metric-num { font-family: var(--font-display); font-size: clamp(2.8rem,5vw,4.8rem); font-weight: 800; color: var(--text-primary); line-height: 1; letter-spacing: -.05em; margin-bottom: .4rem; }
.metric-num em { font-style: normal; color: var(--accent); transition: color .28s; }
.metric p { font-size: .8rem; color: var(--text-dim); line-height: 1.6; max-width: 130px; margin: 0 auto; }

/* ─── PROCESS STEPS ─── */
.process-row { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--line2); border: 1px solid var(--line2); border-radius: var(--radius-lg); overflow: hidden; }
.pstep { background: linear-gradient(160deg, var(--bg3), var(--bg2)); padding: 2.25rem 1.75rem; position: relative; overflow: hidden; transition: background .28s; }
.pstep::after { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--accent-dim), transparent); opacity: 0; transition: opacity .4s; }
.pstep:hover { background: linear-gradient(160deg, var(--bg4), var(--bg3)); }
.pstep:hover::after { opacity: 1; }
.pstep-num { font-family: var(--font-display); font-size: 4.8rem; font-weight: 800; color: transparent; -webkit-text-stroke: 1.5px var(--line3); line-height: 1; margin-bottom: 1.2rem; letter-spacing: -.04em; transition: -webkit-text-stroke-color .28s; }
.pstep:hover .pstep-num { -webkit-text-stroke-color: var(--accent); }
.pstep h3 { font-size: 1.1rem; font-weight: 700; margin-bottom: .5rem; letter-spacing: -.02em; }
.pstep p  { font-size: .82rem; color: var(--text-muted); line-height: 1.75; margin-bottom: .9rem; }
.pbadge { display: inline-block; font-family: var(--font-body); font-size: .62rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--accent); background: var(--accent-dim); border: 1px solid var(--accent-glow); padding: .2rem .65rem; border-radius: 20px; }

/* ─── WHY ITEMS ─── */
.why-list { display: flex; flex-direction: column; gap: 1rem; margin-top: 2.25rem; }
.why-item { display: flex; gap: 1rem; align-items: flex-start; padding: 1.2rem; border: 1px solid var(--line2); border-radius: var(--radius); background: linear-gradient(135deg, rgba(255,255,255,.03), rgba(255,255,255,.01)); transition: border-color .28s, background .28s, transform .28s, box-shadow .28s; }
.why-item:hover { border-color: var(--line3); transform: translateX(4px); background: linear-gradient(135deg, rgba(255,255,255,.055), rgba(255,255,255,.02)); box-shadow: -4px 0 18px var(--accent-dim); }
.why-ico { width: 40px; height: 40px; border-radius: 8px; flex-shrink: 0; background: var(--accent-dim); border: 1px solid var(--accent-glow); display: flex; align-items: center; justify-content: center; font-size: 1.05rem; }
.why-item h4 { font-size: 1rem; font-weight: 700; margin-bottom: .25rem; letter-spacing: -.02em; }
.why-item p  { font-size: .82rem; color: var(--text-muted); line-height: 1.7; }

/* ─── DEMO WIDGET ─── */
.demo-widget { background: linear-gradient(160deg, var(--bg3), var(--bg2)); border: 1px solid var(--line3); border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 28px 70px rgba(0,0,0,.5); }
.demo-titlebar { background: var(--bg3); border-bottom: 1px solid var(--line2); padding: .7rem 1.2rem; display: flex; align-items: center; gap: .42rem; }
.dot { width: 10px; height: 10px; border-radius: 50%; }
.dot-red    { background: #ff5f57; }
.dot-yellow { background: #febc2e; }
.dot-green  { background: #28c840; }
.demo-name { font-size: .7rem; color: var(--text-muted); margin-left: .4rem; font-family: 'Courier New', monospace; letter-spacing: .04em; }
.live-badge { margin-left: auto; font-size: .62rem; font-weight: 600; color: #4ade80; text-transform: uppercase; letter-spacing: .08em; }
.demo-body { padding: 1.4rem; }
.demo-caption { font-size: .7rem; color: var(--text-dim); text-align: center; margin-top: .7rem; }
.chat-thread { display: flex; flex-direction: column; gap: .7rem; }
.msg { padding: .75rem 1rem; border-radius: 11px; font-size: .82rem; max-width: 88%; line-height: 1.6; color: #e0ddf8; animation: msgIn .35s ease both; }
.msg-bot  { background: var(--accent-dim); border: 1px solid var(--accent-glow); border-radius: 11px 11px 11px 2px; align-self: flex-start; }
.msg-user { background: var(--bg4); border: 1px solid var(--line2); border-radius: 11px 11px 2px 11px; align-self: flex-end; }
.typing { display: flex; gap: 4px; align-items: center; padding: .75rem 1rem; animation: msgIn .35s ease both; }
.typing-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--accent); animation: typingBounce .9s ease-in-out infinite; }
.typing-dot:nth-child(2) { animation-delay: .15s; }
.typing-dot:nth-child(3) { animation-delay: .30s; }

/* ─── FLOW WIDGET ─── */
.flow-body { padding: 1.6rem; display: flex; flex-direction: column; gap: .5rem; }
.flow-step { display: flex; align-items: center; gap: .8rem; padding: .85rem 1rem; background: rgba(255,255,255,.03); border: 1px solid var(--line2); border-radius: 10px; }
.flow-step-accent { background: var(--accent-dim); border-color: var(--accent-glow); }
.flow-step-done   { background: rgba(74,222,128,.06); border-color: rgba(74,222,128,.2); }
.flow-step-mini   { flex: 1; flex-direction: column; gap: .3rem; text-align: center; }
.flow-split { display: grid; grid-template-columns: 1fr 1fr; gap: .5rem; }
.flow-icon  { font-size: 1rem; flex-shrink: 0; }
.flow-info  { flex: 1; }
.flow-title { font-size: .73rem; font-weight: 600; color: var(--text-primary); font-family: var(--font-body); }
.flow-sub   { font-size: .63rem; color: var(--text-dim); font-family: var(--font-body); }
.flow-status { font-size: .6rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; font-family: var(--font-body); padding: .12rem .45rem; border-radius: 4px; }
.status-green { color: #4ade80; background: rgba(74,222,128,.1); border: 1px solid rgba(74,222,128,.2); }
.flow-connector { width: 1px; height: 16px; background: var(--line2); margin: 0 auto; }

/* ─── PAIN GRID ─── */
.pain-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--line2); border: 1px solid var(--line2); border-radius: var(--radius-lg); overflow: hidden; box-shadow: 0 4px 40px rgba(0,0,0,.2); }
.pain-cell { padding: 2.75rem; background: linear-gradient(150deg, var(--bg3), var(--bg2)); transition: background .28s; }
.pain-cell:hover { background: linear-gradient(150deg, var(--bg4), var(--bg3)); }
.pain-ico { width: 42px; height: 42px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; margin-bottom: 1.1rem; }
.ico-red   { background: rgba(239,68,68,.1);  border: 1px solid rgba(239,68,68,.22); }
.ico-green { background: rgba(74,222,128,.08); border: 1px solid rgba(74,222,128,.2); }
.pain-cell h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: .6rem; letter-spacing: -.025em; }

/* ─── SEGMENTS ─── */
.seg-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.2rem; }
.seg-card { border-radius: var(--radius-lg); padding: 2.5rem; border: 1px solid var(--line2); position: relative; overflow: hidden; background: linear-gradient(150deg, var(--bg3), var(--bg2)); transition: border-color .38s, box-shadow .38s, transform .28s; }
.seg-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--accent), hsl(232,85%,80%)); transition: background .38s; }
.seg-card:hover { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent-dim), 0 22px 60px rgba(0,0,0,.3); transform: translateY(-3px); }
.seg-type { font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--accent); margin-bottom: .9rem; font-family: var(--font-body); }
.seg-card h3 { font-size: 1.45rem; font-weight: 700; margin-bottom: .7rem; letter-spacing: -.03em; }
.seg-card > p { font-size: .84rem; color: var(--text-muted); line-height: 1.8; }
.seg-list { margin-top: 1.6rem; display: flex; flex-direction: column; gap: .6rem; }
.seg-list li { font-size: .83rem; color: var(--text-secondary); display: flex; align-items: flex-start; gap: .55rem; line-height: 1.5; }
.seg-list li::before { content: '✓'; color: #4ade80; font-weight: 700; flex-shrink: 0; }

/* ─── TESTIMONIALS ─── */
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.2rem; }
.testi { background: linear-gradient(150deg, var(--bg3), var(--bg2)); border: 1px solid var(--line2); border-radius: var(--radius-lg); padding: 1.85rem; display: flex; flex-direction: column; box-shadow: 0 2px 16px rgba(0,0,0,.2); transition: border-color .38s, transform .28s, box-shadow .38s; }
.testi:hover { border-color: var(--line3); transform: translateY(-4px); box-shadow: 0 14px 42px rgba(0,0,0,.3); }
.stars { font-size: .85rem; margin-bottom: .9rem; }
.testi-body { font-size: .85rem; color: var(--text-secondary); line-height: 1.8; font-style: italic; flex: 1; margin-bottom: 1.4rem; }
.testi-author { display: flex; align-items: center; gap: .7rem; }
.avatar { width: 36px; height: 36px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: .78rem; font-weight: 700; color: #fff; }
.av-blue   { background: linear-gradient(135deg, hsl(232,85%,66%), hsl(232,85%,42%)); }
.av-purple { background: linear-gradient(135deg, hsl(268,78%,68%), hsl(332,88%,55%)); }
.av-green  { background: linear-gradient(135deg, hsl(158,72%,48%), hsl(192,88%,42%)); }
.author-name { font-size: .82rem; font-weight: 700; color: var(--text-primary); }
.author-role { font-size: .7rem;  color: var(--text-muted); }

/* ─── FAQ ─── */
.faq-list { max-width: 760px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid var(--line2); transition: background .18s; }
.faq-item:hover { background: rgba(255,255,255,.012); }
.faq-question { width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 1.3rem 0; font-family: var(--font-display); font-size: 1.05rem; font-weight: 700; color: var(--text-primary); background: transparent; border: none; text-align: left; gap: 1rem; cursor: pointer; letter-spacing: -.018em; }
.faq-icon { width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--line2); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: .9rem; font-weight: 400; color: var(--text-muted); transition: transform .28s, border-color .28s, background .28s, color .28s; }
.faq-item.open .faq-icon { transform: rotate(45deg); border-color: var(--accent); background: var(--accent-dim); color: var(--accent); }
.faq-answer { display: none; padding-bottom: 1.3rem; }
.faq-answer p { font-size: .86rem; color: var(--text-muted); line-height: 1.85; }
.faq-item.open .faq-answer { display: block; }

/* ─── CTA BOX ─── */
.cta-box { border-radius: var(--radius-xl); padding: 5rem; text-align: center; position: relative; overflow: hidden; background: linear-gradient(135deg, var(--bg4), var(--bg3), var(--bg2)); border: 1px solid var(--line3); box-shadow: 0 0 100px -20px var(--accent-glow), inset 0 1px 0 var(--line3); }
.cta-orb { position: absolute; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle, var(--accent-glow), transparent 65%); top: 50%; left: 50%; transform: translate(-50%,-50%); pointer-events: none; transition: background .45s; }
.cta-h2  { font-size: clamp(2.6rem,5.5vw,4.3rem); margin-bottom: 1rem; margin-top: .5rem; position: relative; letter-spacing: -.04em; }
.cta-sub { max-width: 520px; margin: 0 auto 2.5rem; font-size: .98rem; line-height: 1.8; position: relative; }
.email-row { display: flex; gap: .7rem; max-width: 450px; margin: 0 auto 1.5rem; position: relative; }
.email-input { flex: 1; background: rgba(255,255,255,.06); border: 1.5px solid var(--line2); border-radius: var(--radius); padding: .88rem 1.2rem; color: var(--text-primary); font-family: var(--font-body); font-size: .88rem; outline: none; transition: border-color .18s, background .18s; }
.email-input::placeholder { color: var(--text-dim); }
.email-input:focus { border-color: var(--accent); background: rgba(255,255,255,.08); }
.cta-reassure { display: flex; align-items: center; justify-content: center; gap: 1.75rem; flex-wrap: wrap; position: relative; margin-bottom: 1.5rem; }
.cta-reassure span { font-size: .74rem; color: var(--text-dim); }
.cta-contact-links { font-size: .8rem; color: var(--text-dim); position: relative; }
.cta-contact-links a { color: var(--accent); font-weight: 600; }
.whatsapp-link { color: #4ade80 !important; }

/* ─── FOOTER ─── */
.footer { border-top: 1px solid var(--line2); padding: 3rem 0 2rem; background: linear-gradient(180deg, var(--bg2), var(--bg)); }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; margin-bottom: 2.5rem; }
.footer-brand .logo { display: inline-block; margin-bottom: .7rem; }
.footer-brand p { font-size: .8rem; color: var(--text-muted); line-height: 1.75; max-width: 250px; }
.footer-col h5 { font-family: var(--font-body); font-size: .68rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--text-primary); margin-bottom: .85rem; }
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: .5rem; }
.footer-col a  { font-size: .8rem; color: var(--text-muted); transition: color .18s; }
.footer-col a:hover { color: var(--text-primary); }
.footer-bottom { border-top: 1px solid var(--line2); padding-top: 1.5rem; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.footer-bottom p { font-size: .75rem; color: var(--text-dim); }
.footer-legal { display: flex; gap: 1.5rem; }
.footer-legal a { font-size: .75rem; color: var(--text-dim); transition: color .18s; }
.footer-legal a:hover { color: var(--text-muted); }

/* ─── HERO STAT CARDS ─── */
.hero-stats { position: absolute; right: 0; top: 50%; transform: translateY(-50%); display: flex; flex-direction: column; gap: .8rem; z-index: 2; }
.fstat { background: linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.03)); border: 1px solid var(--line2); border-radius: var(--radius); padding: 1rem 1.4rem; text-align: right; backdrop-filter: blur(14px); box-shadow: 0 4px 24px rgba(0,0,0,.22); transition: border-color .38s, transform .28s; }
.fstat:hover { border-color: var(--line3); transform: translateX(-4px); }
.fstat-num { font-family: var(--font-display); font-size: 2.1rem; font-weight: 800; color: var(--text-primary); letter-spacing: -.04em; line-height: 1; }
.fstat-num span { color: var(--accent); transition: color .28s; }
.fstat-label { font-size: .65rem; color: var(--text-dim); font-weight: 500; text-transform: uppercase; letter-spacing: .06em; margin-top: .18rem; max-width: 125px; line-height: 1.4; }

/* ─── MISC ─── */
.accent-text { font-style: italic; color: var(--accent); transition: color .28s; }
.compat-block { margin-top: 2rem; }
.compat-label { font-size: .66rem; font-weight: 600; letter-spacing: .18em; text-transform: uppercase; color: var(--text-dim); margin-bottom: .75rem; }
.tech-stack { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; padding-top: 2.25rem; border-top: 1px solid var(--line1); }
.stack-label { font-size: .68rem; color: var(--text-dim); font-weight: 500; white-space: nowrap; }
