/* =============================================================
   Smooth Power Corporate — 2026 Design System
   Inspired by: Anthropic · Linear · Vercel · Stripe · Apple
   Typography: Geist Sans + Fraunces + Geist Mono
   ============================================================= */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700;800;900&family=Geist+Mono:wght@400;500;600&family=Fraunces:ital,wght@0,500;0,700;1,400;1,500;1,700&display=swap');

:root{
  /* Colors — warm dim palette (softened from pitch-black) */
  --bg-0:     #1a1a1f;   /* warm charcoal — lighter than pure black */
  --bg-1:     #222228;   /* surface */
  --bg-2:     #2b2b32;   /* elevated surface */
  --bg-3:     #34343d;

  --ink-0:    #faf7f2;   /* warm off-white, slightly brighter */
  --ink-1:    #eae6de;
  --ink-2:    #b8b3aa;
  --ink-3:    #7e7a72;
  --ink-4:    #4d4b46;

  --line-0:   rgba(255,255,255,.08);
  --line-1:   rgba(255,255,255,.13);
  --line-2:   rgba(255,255,255,.2);

  /* Light mode */
  --bg-light-0: #ffffff;
  --bg-light-1: #fafaf8;
  --bg-light-2: #f5f3ee;
  --ink-light-0: #0a0a0b;
  --ink-light-1: #1c1c1f;
  --ink-light-2: #5a5753;
  --ink-light-3: #8b8680;
  --line-light-0: rgba(0,0,0,.08);
  --line-light-1: rgba(0,0,0,.12);

  /* Accent — Smooth Power red + warm amber */
  --red:       #DC1E2A;
  --red-2:     #FF3B44;
  --red-soft:  #FFD4D7;

  --amber:     #FF9F43;
  --amber-2:   #FFB866;

  --violet:    #8B5CF6;
  --cyan:      #06B6D4;
  --emerald:   #10B981;

  /* Transitions */
  --t-fast: 180ms cubic-bezier(.4,0,.2,1);
  --t:      320ms cubic-bezier(.4,0,.2,1);
  --t-slow: 600ms cubic-bezier(.25,.46,.45,.94);
  --t-spring: 420ms cubic-bezier(.34,1.56,.64,1);

  /* Spacing / radii */
  --r-sm: 8px;
  --r:    14px;
  --r-md: 18px;
  --r-lg: 24px;
  --r-xl: 32px;

  /* Shadows — subtle, warm */
  --shadow-sm: 0 1px 2px rgba(0,0,0,.2);
  --shadow:    0 8px 24px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.08);
  --shadow-lg: 0 24px 60px -12px rgba(0,0,0,.4), 0 4px 12px rgba(0,0,0,.06);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  background:var(--bg-0);
  color-scheme: dark;
}
body{
  font-family:'Geist',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--ink-0);
  background:var(--bg-0);
  line-height:1.55;
  font-size:16px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:'ss01','ss02','ss03','cv11';
  overflow-x:hidden;
  letter-spacing:-.01em;
}

img,svg,video{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; font-family:inherit; }

/* =============================================================
   Scroll Progress Bar
   ============================================================= */
.scroll-progress{
  position:fixed; top:0; left:0; right:0; height:2px;
  z-index:200; pointer-events:none;
  background:linear-gradient(90deg,var(--red) 0%,var(--amber) 50%,var(--violet) 100%);
  transform-origin:left;
  animation: scroll-progress linear;
  animation-timeline: scroll(root);
  transform: scaleX(0);
}
@keyframes scroll-progress { to { transform: scaleX(1); } }

/* =============================================================
   Grain / Noise overlay
   ============================================================= */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.04; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* =============================================================
   Layout
   ============================================================= */
.container{ max-width:1400px; margin:0 auto; padding:0 40px; position:relative; z-index:2; }
.container-narrow{ max-width:1040px; margin:0 auto; padding:0 40px; position:relative; z-index:2; }
.section{ padding:120px 0; position:relative; }
.section-sm{ padding:80px 0; position:relative; }
.section-lg{ padding:160px 0; position:relative; }
@media(max-width:768px){
  .container,.container-narrow{ padding:0 22px; }
  .section{ padding:72px 0; }
  .section-sm{ padding:52px 0; }
  .section-lg{ padding:96px 0; }
}

/* =============================================================
   Typography
   ============================================================= */

/* Mono — for specs, year numbers, technical callouts */
.mono{
  font-family:'Geist Mono','SF Mono',Menlo,monospace;
  letter-spacing:-.01em;
  font-feature-settings:'ss01','ss03','zero';
}

/* Serif italic — editorial accents */
.serif-it{
  font-family:'Fraunces',Georgia,serif;
  font-style:italic;
  font-weight:500;
  letter-spacing:-.02em;
  font-feature-settings:'ss01';
}
.serif{
  font-family:'Fraunces',Georgia,serif;
  font-weight:500;
  letter-spacing:-.025em;
}

/* Eyebrow — small caps label */
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:'Geist Mono',monospace;
  font-size:11px; font-weight:500;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-2); margin-bottom:24px;
}
.eyebrow::before{
  content:''; width:20px; height:1px;
  background:linear-gradient(90deg,var(--red),transparent);
}
.eyebrow.red{ color:var(--red-2); }
.eyebrow.amber{ color:var(--amber); }

/* Headings */
h1,h2,h3,h4,h5,h6{
  font-family:'Geist',-apple-system,sans-serif;
  letter-spacing:-.03em; line-height:1.04; font-weight:700;
  color:var(--ink-0);
}

.h-monumental{
  font-size:clamp(72px,14vw,220px);
  font-weight:800; letter-spacing:-.055em; line-height:.88;
}
.h-display{
  font-size:clamp(56px,8vw,128px);
  font-weight:800; letter-spacing:-.045em; line-height:.94;
}
.h-1{
  font-size:clamp(40px,5.5vw,80px);
  font-weight:700; letter-spacing:-.035em; line-height:1.02;
}
.h-2{
  font-size:clamp(30px,4vw,56px);
  font-weight:700; letter-spacing:-.025em; line-height:1.08;
}
.h-3{
  font-size:clamp(22px,2.2vw,34px);
  font-weight:600; letter-spacing:-.02em; line-height:1.2;
}
.h-4{ font-size:20px; font-weight:600; letter-spacing:-.015em; line-height:1.3; }

.lead{
  font-size:clamp(17px,1.3vw,21px); font-weight:400; line-height:1.55;
  color:var(--ink-2); max-width:640px;
}
.lead-lg{ font-size:clamp(20px,1.6vw,26px); line-height:1.5; }

/* Animated gradient text */
.grad-text{
  background:linear-gradient(135deg,var(--ink-0) 0%,var(--ink-2) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
}
.grad-aurora{
  background:linear-gradient(90deg,#FF3B44 0%,#FF9F43 30%,#8B5CF6 65%,#06B6D4 100%);
  background-size:200% auto;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  animation: shift-grad 8s linear infinite;
}
@keyframes shift-grad{
  0%{ background-position:0% center; }
  100%{ background-position:200% center; }
}
.grad-amber{
  background:linear-gradient(135deg,#FF9F43 0%,#FFB866 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
}

/* Selection */
::selection{ background:var(--red); color:#fff; }

/* =============================================================
   Aurora gradient background (for hero + dark sections)
   ============================================================= */
.aurora{
  position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0;
}
.aurora::before, .aurora::after{
  content:''; position:absolute; border-radius:50%; filter:blur(120px);
  animation: drift 24s ease-in-out infinite alternate;
}
.aurora::before{
  width:700px; height:700px; top:-200px; right:-100px;
  background:radial-gradient(circle,rgba(220,30,42,.5) 0%,transparent 70%);
}
.aurora::after{
  width:600px; height:600px; bottom:-200px; left:-100px;
  background:radial-gradient(circle,rgba(139,92,246,.4) 0%,transparent 70%);
  animation-delay:-12s;
}
.aurora-orb{
  position:absolute; width:400px; height:400px; border-radius:50%;
  filter:blur(100px); pointer-events:none;
  animation: drift 20s ease-in-out infinite alternate;
}
.aurora-orb.amber{
  background:radial-gradient(circle,rgba(255,159,67,.3) 0%,transparent 70%);
  top:40%; left:30%;
}
.aurora-orb.cyan{
  background:radial-gradient(circle,rgba(6,182,212,.25) 0%,transparent 70%);
  bottom:20%; right:20%; animation-delay:-8s;
}
@keyframes drift{
  0%{ transform:translate(0,0) scale(1); }
  100%{ transform:translate(80px,-60px) scale(1.15); }
}

/* Grid pattern overlay */
.grid-overlay{
  position:absolute; inset:0; pointer-events:none; z-index:1;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,#000 30%,transparent 80%);
}

/* =============================================================
   Buttons
   ============================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding:13px 22px; border-radius:100px;
  font-size:14px; font-weight:500; letter-spacing:-.005em;
  transition: all var(--t);
  white-space:nowrap; position:relative; overflow:hidden;
  border:1px solid transparent;
}
.btn-lg{ padding:15px 26px; font-size:14.5px; }
.btn-xl{ padding:17px 30px; font-size:15px; }

.btn-primary{
  background:var(--ink-0); color:var(--bg-0);
  font-weight:600;
}
.btn-primary:hover{
  transform:translateY(-1px);
  box-shadow:0 10px 30px -6px rgba(245,242,237,.25);
}

.btn-red{
  background:linear-gradient(135deg,var(--red) 0%,var(--red-2) 100%); color:#fff;
  font-weight:600;
  box-shadow:0 1px 0 rgba(255,255,255,.15) inset, 0 8px 22px -6px rgba(220,30,42,.4);
}
.btn-red:hover{
  transform:translateY(-2px);
  box-shadow:0 1px 0 rgba(255,255,255,.2) inset, 0 16px 34px -8px rgba(220,30,42,.55);
}

.btn-ghost{
  background:rgba(255,255,255,.04); color:var(--ink-0); border-color:var(--line-1);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{
  background:rgba(255,255,255,.08); border-color:var(--line-2);
}

.btn-outline{
  background:transparent; color:var(--ink-0); border-color:var(--line-2);
}
.btn-outline:hover{
  background:rgba(255,255,255,.04); border-color:var(--ink-0);
}

.btn .arrow{ transition:transform var(--t); }
.btn:hover .arrow{ transform:translateX(3px); }

/* Magnetic button wrapper */
.magnet{ display:inline-block; }

/* Pill */
.pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 14px 6px 6px;
  background:rgba(255,255,255,.04); border:1px solid var(--line-1); border-radius:100px;
  font-size:12.5px; font-weight:500; color:var(--ink-1);
  backdrop-filter:blur(12px);
  position:relative; overflow:hidden;
}
.pill-tag{
  display:inline-block; padding:3px 9px;
  background:linear-gradient(135deg,var(--red),var(--red-2)); color:#fff;
  border-radius:100px; font-size:10.5px; font-weight:700; letter-spacing:.04em; text-transform:uppercase;
}
.pill-tag.amber{ background:linear-gradient(135deg,var(--amber),var(--amber-2)); color:var(--bg-0); }
.pill-tag.violet{ background:linear-gradient(135deg,var(--violet),#A78BFA); color:#fff; }

/* =============================================================
   Navigation
   ============================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  backdrop-filter:blur(16px) saturate(180%); -webkit-backdrop-filter:blur(16px) saturate(180%);
  background:rgba(10,10,11,.72);
  border-bottom:1px solid var(--line-0);
  transition: all var(--t);
}
.nav.scrolled{
  background:rgba(10,10,11,.9);
  border-bottom-color:var(--line-1);
}
.nav-inner{
  max-width:1400px; margin:0 auto; padding:0 40px;
  height:66px; display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.nav-logo{
  display:flex; align-items:center; gap:10px;
  font-size:16.5px; font-weight:700; letter-spacing:-.02em; color:var(--ink-0);
}
.nav-logo-mark{
  width:28px; height:28px;
  background:linear-gradient(135deg,var(--red) 0%,var(--red-2) 100%);
  border-radius:7px; display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 12px rgba(220,30,42,.35), inset 0 1px 0 rgba(255,255,255,.18);
  position:relative; overflow:hidden;
}

.nav-links{
  display:flex; align-items:center; gap:2px;
}
.nav-links a{
  padding:8px 14px; font-size:13.5px; font-weight:500;
  color:var(--ink-2); border-radius:100px;
  transition:all var(--t-fast); position:relative;
}
.nav-links a:hover{ background:rgba(255,255,255,.04); color:var(--ink-0); }
.nav-links a.active{ background:rgba(255,255,255,.06); color:var(--ink-0); }

.nav-cta{ display:flex; align-items:center; gap:8px; }
.nav-toggle{ display:none; padding:10px; border-radius:10px; }
.nav-toggle svg{ width:20px; height:20px; stroke:var(--ink-0); }

@media(max-width:1024px){
  .nav-links{ display:none; }
  .nav-toggle{ display:flex; }
  .nav-cta .btn:not(:last-child){ display:none; }
  .nav-inner{ padding:0 22px; }
}

/* Mobile menu */
.mobile-menu{
  position:fixed; inset:66px 0 0 0; z-index:99;
  background:var(--bg-0); padding:28px 22px;
  transform:translateX(100%); transition:transform var(--t);
  overflow-y:auto;
}
.mobile-menu.open{ transform:translateX(0); }
.mobile-menu a{
  display:block; padding:18px 0; border-bottom:1px solid var(--line-0);
  font-size:20px; font-weight:600; letter-spacing:-.02em; color:var(--ink-0);
}
.mobile-menu .btn{ margin-top:24px; width:100%; }

/* =============================================================
   HERO — Monumental typography
   ============================================================= */
.hero{
  position:relative; padding:180px 0 96px;
  background:var(--bg-0); overflow:hidden;
}
.hero-inner{ position:relative; z-index:2; }

.hero-pill{ margin-bottom:40px; }

.hero h1{
  font-size:clamp(64px,11.5vw,188px);
  font-weight:800; letter-spacing:-.055em; line-height:.88;
  margin-bottom:40px;
  color:var(--ink-0);
}
.hero h1 .line{ display:block; }
.hero h1 em{
  font-family:'Fraunces',serif; font-style:italic; font-weight:500;
  background:linear-gradient(90deg,#FF3B44 0%,#FF9F43 50%,#8B5CF6 100%);
  background-size:200% auto;
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
  animation: shift-grad 10s linear infinite;
  letter-spacing:-.03em;
}

.hero-sub{
  font-size:clamp(17px,1.4vw,21px); font-weight:400;
  color:var(--ink-2); max-width:560px; line-height:1.55;
  margin-bottom:48px;
}

.hero-cta{ display:flex; gap:12px; flex-wrap:wrap; }

.hero-metrics{
  margin-top:88px; padding-top:48px; border-top:1px solid var(--line-0);
  display:grid; grid-template-columns:repeat(4,1fr); gap:40px;
}
.hero-metric .num{
  font-family:'Geist',sans-serif;
  font-size:clamp(36px,4.2vw,56px); font-weight:700; letter-spacing:-.035em; line-height:1;
  color:var(--ink-0); margin-bottom:10px;
}
.hero-metric .num sup{ font-size:.55em; color:var(--ink-3); margin-left:2px; font-weight:500; }
.hero-metric .lbl{
  font-family:'Geist Mono',monospace;
  font-size:11px; font-weight:500;
  color:var(--ink-3); letter-spacing:.14em; text-transform:uppercase;
}
@media(max-width:768px){
  .hero{ padding:130px 0 72px; }
  .hero-metrics{ grid-template-columns:repeat(2,1fr); gap:28px 24px; margin-top:56px; padding-top:32px; }
}

/* =============================================================
   MARQUEE — Infinite scrolling strip
   ============================================================= */
.marquee{
  position:relative;
  padding:32px 0;
  border-top:1px solid var(--line-0);
  border-bottom:1px solid var(--line-0);
  background:var(--bg-1);
  overflow:hidden;
}
.marquee::before,.marquee::after{
  content:''; position:absolute; top:0; bottom:0; width:120px; z-index:2; pointer-events:none;
}
.marquee::before{ left:0; background:linear-gradient(90deg,var(--bg-1),transparent); }
.marquee::after{ right:0; background:linear-gradient(270deg,var(--bg-1),transparent); }

.marquee-track{
  display:flex; gap:64px; width:max-content;
  animation: marquee 50s linear infinite;
  font-family:'Geist Mono',monospace;
  font-size:14px; font-weight:500;
  color:var(--ink-3); letter-spacing:-.01em;
  white-space:nowrap;
}
.marquee-track:hover{ animation-play-state:paused; }
.marquee-item{
  display:inline-flex; align-items:center; gap:12px; flex-shrink:0;
}
.marquee-dot{ color:var(--ink-4); opacity:.6; }
.marquee-item strong{ color:var(--ink-0); font-weight:600; }
@keyframes marquee{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}

/* =============================================================
   BENTO GRID
   ============================================================= */
.bento{
  display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:minmax(240px,auto);
  gap:16px;
}
.bento-card{
  position:relative; padding:32px; border-radius:24px;
  background:var(--bg-1);
  border:1px solid var(--line-0);
  overflow:hidden;
  transition:all var(--t); cursor:pointer;
  display:flex; flex-direction:column; justify-content:space-between;
}
.bento-card::before{
  content:''; position:absolute; inset:0; border-radius:24px;
  padding:1px;
  background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,rgba(255,255,255,0) 50%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  pointer-events:none; opacity:.6;
}
.bento-card:hover{
  transform:translateY(-2px); background:var(--bg-2);
  border-color:var(--line-2);
}
.bento-card:hover::before{ opacity:1; }

.bento-card .b-eyebrow{
  font-family:'Geist Mono',monospace; font-size:10.5px; font-weight:500;
  color:var(--ink-3); letter-spacing:.14em; text-transform:uppercase;
}
.bento-card h3{
  font-size:clamp(22px,2.2vw,30px); font-weight:600; letter-spacing:-.025em; line-height:1.12;
  margin-top:12px; color:var(--ink-0);
}
.bento-card p{
  font-size:14.5px; color:var(--ink-2); line-height:1.55; margin-top:12px;
  max-width:480px;
}
.bento-card .b-footer{
  display:flex; justify-content:space-between; align-items:flex-end; margin-top:24px;
}
.bento-card .b-link{
  display:inline-flex; align-items:center; gap:6px;
  font-size:13.5px; font-weight:500; color:var(--ink-0);
}
.bento-card .b-link .arrow{ transition:transform var(--t); }
.bento-card:hover .b-link .arrow{ transform:translateX(3px); }

/* Bento sizes */
.bento-6 { grid-column: span 6; }
.bento-5 { grid-column: span 5; }
.bento-4 { grid-column: span 4; }
.bento-3 { grid-column: span 3; }
.bento-2 { grid-column: span 2; }
.bento-tall { grid-row: span 2; }

/* Hero / Large bento cards */
.bento-card.hero-card{
  padding:48px; grid-row:span 2;
  background:linear-gradient(135deg,var(--bg-1) 0%,var(--bg-2) 100%);
}
.bento-card.hero-card::after{
  content:''; position:absolute; top:-50%; right:-20%; width:600px; height:600px;
  background:radial-gradient(circle,rgba(220,30,42,.18) 0%,transparent 60%);
  filter:blur(60px); pointer-events:none;
}
.bento-card.hero-card h3{ font-size:clamp(30px,3vw,44px); }

.bento-card.accent-red{
  background:linear-gradient(135deg,#1a0608 0%,#0a0a0b 100%);
  border-color:rgba(220,30,42,.2);
}
.bento-card.accent-amber{
  background:linear-gradient(135deg,#1a1204 0%,#0a0a0b 100%);
  border-color:rgba(255,159,67,.2);
}
.bento-card.accent-violet{
  background:linear-gradient(135deg,#14091a 0%,#0a0a0b 100%);
  border-color:rgba(139,92,246,.2);
}

.bento-stat{
  font-family:'Geist',sans-serif;
  font-size:clamp(56px,7vw,96px); font-weight:700; letter-spacing:-.05em; line-height:.95;
  color:var(--ink-0);
}
.bento-stat.amber{
  background:linear-gradient(135deg,#FF9F43,#FFB866);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
}
.bento-stat.red{
  background:linear-gradient(135deg,#FF3B44,#DC1E2A);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; color:transparent;
}

@media(max-width:1024px){
  .bento{ grid-template-columns:repeat(2,1fr); }
  .bento-card{ grid-column:span 1; grid-row:span 1; }
  .bento-card.hero-card{ grid-column:span 2; padding:36px; }
  .bento-6, .bento-5, .bento-4{ grid-column:span 2; }
  .bento-tall{ grid-row:span 1; }
}
@media(max-width:640px){
  .bento{ grid-template-columns:1fr; }
  .bento-card{ grid-column:span 1; padding:28px; }
  .bento-card.hero-card{ grid-column:span 1; padding:32px; }
  .bento-6, .bento-5, .bento-4, .bento-3, .bento-2{ grid-column:span 1; }
}

/* =============================================================
   Sticky Scroll Showcase
   ============================================================= */
.sticky-section{
  display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start;
  padding:80px 0;
}
.sticky-media{
  position:sticky; top:100px; aspect-ratio:1/1; border-radius:32px;
  background:linear-gradient(135deg,var(--bg-1) 0%,var(--bg-2) 100%);
  border:1px solid var(--line-0);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.sticky-media::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 400px 300px at 30% 40%, rgba(220,30,42,.25) 0%, transparent 60%);
}
.sticky-media-inner{ position:relative; z-index:2; padding:56px; text-align:center; }
.sticky-steps{ display:flex; flex-direction:column; gap:120px; padding:40px 0; }
.sticky-step h3{ font-size:clamp(30px,3.4vw,48px); font-weight:600; letter-spacing:-.03em; line-height:1.08; margin-bottom:20px; }
.sticky-step p{ color:var(--ink-2); font-size:17px; line-height:1.6; max-width:460px; }
.sticky-step .step-num{
  font-family:'Geist Mono',monospace; font-size:12px; font-weight:500;
  color:var(--red-2); letter-spacing:.16em; text-transform:uppercase; margin-bottom:16px; display:block;
}

@media(max-width:1024px){
  .sticky-section{ grid-template-columns:1fr; gap:40px; padding:40px 0; }
  .sticky-media{ position:static; aspect-ratio:4/3; }
  .sticky-steps{ gap:56px; padding:0; }
}

/* =============================================================
   Category Grid (new)
   ============================================================= */
.cat-head{ text-align:center; max-width:740px; margin:0 auto 64px; }
.cat-head .eyebrow{ justify-content:center; }
.cat-head h2{ margin-bottom:20px; }
.cat-head .lead{ margin:0 auto; color:var(--ink-2); }

.cat-grid-new{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px;
}
.cat-card-new{
  position:relative; padding:32px; border-radius:22px;
  background:var(--bg-1); border:1px solid var(--line-0);
  min-height:300px; display:flex; flex-direction:column;
  transition:all var(--t); cursor:pointer; overflow:hidden;
}
.cat-card-new::before{
  content:''; position:absolute; top:0; right:0; width:200px; height:200px;
  background:radial-gradient(circle at top right,rgba(220,30,42,.08),transparent 70%);
  opacity:0; transition:opacity var(--t);
}
.cat-card-new:hover{
  transform:translateY(-3px); background:var(--bg-2); border-color:var(--line-1);
}
.cat-card-new:hover::before{ opacity:1; }

.cat-card-new .c-tag{
  display:inline-flex; align-items:center; gap:6px;
  padding:4px 10px; border-radius:100px;
  font-family:'Geist Mono',monospace; font-size:10px; font-weight:500;
  letter-spacing:.14em; text-transform:uppercase;
  background:rgba(220,30,42,.12); color:var(--red-2); margin-bottom:16px; align-self:flex-start;
}
.cat-card-new .c-tag.amber{ background:rgba(255,159,67,.12); color:var(--amber); }
.cat-card-new .c-tag.violet{ background:rgba(139,92,246,.12); color:#B794F4; }
.cat-card-new .c-tag.emerald{ background:rgba(16,185,129,.12); color:#6EE7B7; }

.cat-card-new h3{
  font-size:20px; font-weight:600; letter-spacing:-.02em; line-height:1.25;
  color:var(--ink-0); margin-bottom:10px;
}
.cat-card-new p{
  font-size:14px; color:var(--ink-2); line-height:1.55; flex:1; margin-bottom:20px;
}
.cat-card-new .c-meta{
  font-family:'Geist Mono',monospace; font-size:11px;
  color:var(--ink-3); letter-spacing:.06em; text-transform:uppercase;
  padding-top:16px; border-top:1px solid var(--line-0);
  display:flex; justify-content:space-between; align-items:center;
}
.cat-card-new .c-meta .arrow{
  color:var(--ink-0); transition:transform var(--t);
}
.cat-card-new:hover .c-meta .arrow{ transform:translateX(4px); }

.cat-card-new.featured{
  grid-column:span 2; min-height:360px;
  background:linear-gradient(135deg,#1a0608 0%,#0a0a0b 50%);
  border-color:rgba(220,30,42,.25);
}
.cat-card-new.featured h3{
  font-size:clamp(28px,2.6vw,38px); margin-bottom:14px;
}
.cat-card-new.featured p{ font-size:16px; max-width:480px; }

@media(max-width:1024px){
  .cat-grid-new{ grid-template-columns:repeat(2,1fr); }
  .cat-card-new.featured{ grid-column:span 2; }
}
@media(max-width:640px){
  .cat-grid-new{ grid-template-columns:1fr; }
  .cat-card-new.featured{ grid-column:span 1; }
}

/* =============================================================
   Editorial / Split / Pull quote
   ============================================================= */
.editorial{
  display:grid; grid-template-columns:0.5fr 1fr; gap:80px; align-items:start;
}
.editorial .ed-side{
  position:sticky; top:120px;
}
.editorial .ed-label{
  font-family:'Geist Mono',monospace; font-size:11px; font-weight:500;
  color:var(--ink-3); letter-spacing:.16em; text-transform:uppercase;
}
.editorial h2.ed-quote{
  font-family:'Fraunces',Georgia,serif;
  font-weight:500; font-style:italic;
  font-size:clamp(32px,3.6vw,54px); line-height:1.15; letter-spacing:-.025em;
  color:var(--ink-0);
}
.editorial h2.ed-quote em{
  color:var(--amber); font-style:italic;
}
.editorial .ed-body p{
  font-size:17px; color:var(--ink-1); line-height:1.65; margin-bottom:20px;
  max-width:620px;
}
.editorial .ed-body strong{ color:var(--ink-0); font-weight:600; }

@media(max-width:900px){
  .editorial{ grid-template-columns:1fr; gap:32px; }
  .editorial .ed-side{ position:static; }
}

/* =============================================================
   Testimonials
   ============================================================= */
.testim-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:16px;
}
.testim-card{
  padding:36px; background:var(--bg-1); border:1px solid var(--line-0);
  border-radius:22px; position:relative;
  transition:all var(--t);
}
.testim-card:hover{
  border-color:var(--line-1); transform:translateY(-2px);
}
.testim-card q{
  font-family:'Fraunces',Georgia,serif; font-style:italic;
  font-size:20px; color:var(--ink-0); font-weight:500; line-height:1.45; quotes:none;
  display:block; margin-bottom:28px; letter-spacing:-.015em;
}
.testim-card .author{
  display:flex; align-items:center; gap:14px;
}
.testim-card .avatar{
  width:42px; height:42px; border-radius:50%;
  background:linear-gradient(135deg,var(--red),var(--red-2));
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px; color:#fff; letter-spacing:-.02em;
}
.testim-card .avatar.amber{ background:linear-gradient(135deg,var(--amber),var(--amber-2)); color:var(--bg-0); }
.testim-card .avatar.violet{ background:linear-gradient(135deg,var(--violet),#A78BFA); }
.testim-card .avatar.emerald{ background:linear-gradient(135deg,var(--emerald),#34D399); color:var(--bg-0); }
.testim-card .name{ font-size:14px; font-weight:600; color:var(--ink-0); letter-spacing:-.01em; }
.testim-card .role{ font-size:12.5px; color:var(--ink-3); margin-top:2px; }
@media(max-width:768px){ .testim-grid{ grid-template-columns:1fr; } }

/* =============================================================
   CTA band
   ============================================================= */
.cta-band{
  position:relative; border-radius:32px;
  padding:96px 56px; text-align:center;
  background:linear-gradient(135deg,var(--bg-1) 0%,var(--bg-2) 100%);
  border:1px solid var(--line-0); overflow:hidden;
}
.cta-band::before{
  content:''; position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse 700px 400px at 50% 100%, rgba(220,30,42,.2) 0%, transparent 60%),
    radial-gradient(ellipse 500px 300px at 20% 0%, rgba(139,92,246,.12) 0%, transparent 60%);
}
.cta-band-inner{ position:relative; z-index:2; max-width:760px; margin:0 auto; }
.cta-band h2{ margin-bottom:20px; }
.cta-band .lead{ color:var(--ink-2); margin:0 auto 36px; }
.cta-band-actions{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

@media(max-width:640px){ .cta-band{ padding:64px 28px; border-radius:22px; } }

/* =============================================================
   Footer — mega with typography
   ============================================================= */
.footer{
  background:var(--bg-0); padding:80px 0 32px;
  border-top:1px solid var(--line-0);
  position:relative; overflow:hidden;
}
.footer-mega{
  padding-bottom:64px; border-bottom:1px solid var(--line-0); margin-bottom:32px;
}
.footer-mega-text{
  font-size:clamp(44px,9vw,144px); font-weight:800; letter-spacing:-.05em; line-height:.92;
  color:var(--ink-0); margin-bottom:32px;
}
.footer-mega-text em{
  font-family:'Fraunces',serif; font-style:italic; font-weight:500;
  background:linear-gradient(90deg,#FF3B44,#FF9F43,#8B5CF6);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  letter-spacing:-.035em;
}
.footer-mega-actions{ display:flex; gap:12px; flex-wrap:wrap; }

.footer-grid{
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1fr; gap:40px;
  padding-bottom:48px; border-bottom:1px solid var(--line-0);
}
.footer-col h4{
  font-family:'Geist Mono',monospace;
  font-size:11px; font-weight:500; color:var(--ink-3);
  letter-spacing:.14em; text-transform:uppercase; margin-bottom:18px;
}
.footer-col a{
  display:block; font-size:14.5px; padding:6px 0;
  color:var(--ink-1); transition:color var(--t-fast);
}
.footer-col a:hover{ color:var(--ink-0); }
.footer-brand-col p{ font-size:14px; color:var(--ink-2); line-height:1.6; margin-bottom:24px; max-width:340px; }
.footer-social{ display:flex; gap:8px; }
.footer-social a{
  width:36px; height:36px; border-radius:10px; background:rgba(255,255,255,.04);
  display:flex; align-items:center; justify-content:center; transition:all var(--t);
  border:1px solid var(--line-0);
}
.footer-social a:hover{ background:rgba(255,255,255,.08); border-color:var(--line-1); transform:translateY(-2px); }
.footer-social svg{ width:15px; height:15px; fill:var(--ink-1); }

.footer-bottom{
  padding-top:28px; display:flex; justify-content:space-between;
  align-items:center; flex-wrap:wrap; gap:12px;
  font-family:'Geist Mono',monospace; font-size:12px;
  color:var(--ink-3); letter-spacing:.04em;
}

@media(max-width:900px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .footer-brand-col{ grid-column:span 2; }
  .footer-mega-text{ font-size:clamp(36px,11vw,80px); }
}

/* =============================================================
   Page-specific (non-home) overrides
   ============================================================= */
.page-head{
  padding:160px 0 80px; position:relative; overflow:hidden;
  background:var(--bg-0); border-bottom:1px solid var(--line-0);
}
.page-head-inner{ position:relative; z-index:2; max-width:880px; }
.page-head h1{ margin-bottom:20px; }
.page-head .breadcrumb{
  display:flex; gap:8px; align-items:center; font-size:12px;
  color:var(--ink-3); margin-bottom:24px;
  font-family:'Geist Mono',monospace; letter-spacing:.06em; text-transform:uppercase;
}
.page-head .breadcrumb a{ color:var(--ink-3); }
.page-head .breadcrumb a:hover{ color:var(--ink-0); }

/* =============================================================
   Products page carryovers (dark mode)
   ============================================================= */
.prod-hero{
  padding:160px 0 72px;
  background:var(--bg-0); border-bottom:1px solid var(--line-0);
  position:relative; overflow:hidden;
}
.prod-hero-inner{ max-width:940px; position:relative; z-index:2; }
.prod-hero h1{ color:var(--ink-0); }

.cat-section{ padding:96px 0 48px; scroll-margin-top:90px; }
.cat-section-head{
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:40px; gap:32px; flex-wrap:wrap;
}
.cat-section-head .copy{ max-width:680px; }
.cat-section-head h2{ margin-bottom:12px; }
.cat-section-head p{ color:var(--ink-2); font-size:15px; line-height:1.55; max-width:580px; }

.badge-row{ display:flex; gap:8px; flex-wrap:wrap; }
.cat-badge{
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 13px; background:var(--bg-1); border:1px solid var(--line-0); border-radius:100px;
  font-family:'Geist Mono',monospace; font-size:11px; font-weight:500;
  color:var(--ink-2); letter-spacing:.04em;
}
.cat-badge.red{ background:rgba(220,30,42,.08); color:var(--red-2); border-color:rgba(220,30,42,.2); }
.cat-badge.amber{ background:rgba(255,159,67,.08); color:var(--amber); border-color:rgba(255,159,67,.2); }
.cat-badge.emerald{ background:rgba(16,185,129,.08); color:#34D399; border-color:rgba(16,185,129,.2); }
.cat-badge.violet{ background:rgba(139,92,246,.08); color:#B794F4; border-color:rgba(139,92,246,.2); }

/* Product cards — dark theme */
.prod-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
}
.prod-card{
  background:var(--bg-1); border:1px solid var(--line-0); border-radius:18px;
  overflow:hidden; transition:all var(--t); cursor:pointer;
  display:flex; flex-direction:column;
}
.prod-card:hover{
  transform:translateY(-3px); border-color:var(--line-1); background:var(--bg-2);
}
.prod-img{
  aspect-ratio:4/3; background:linear-gradient(135deg,#1e1e24 0%,#17171c 100%);
  display:flex; align-items:center; justify-content:center;
  overflow:hidden; position:relative;
}
.prod-img img{
  width:100%; height:100%; object-fit:contain; padding:26px;
  transition:transform var(--t-slow);
}
.prod-card:hover .prod-img img{ transform:scale(1.08); }
.prod-body{ padding:18px 20px 20px; flex:1; display:flex; flex-direction:column; }
.prod-name{
  font-size:15px; font-weight:600; letter-spacing:-.015em; line-height:1.3;
  margin-bottom:6px; color:var(--ink-0);
}
.prod-spec{
  font-family:'Geist Mono',monospace; font-size:11.5px;
  color:var(--ink-3); letter-spacing:-.005em; margin-bottom:16px; flex:1;
}
.prod-footer{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:14px; border-top:1px solid var(--line-0);
}
.prod-cat-tag{
  font-family:'Geist Mono',monospace; font-size:10.5px; font-weight:500;
  color:var(--ink-3); text-transform:uppercase; letter-spacing:.08em;
}
.prod-enquire{
  font-size:12px; font-weight:600; color:var(--red-2);
  display:inline-flex; align-items:center; gap:3px;
}
.prod-enquire .arrow{ transition:transform var(--t); }
.prod-card:hover .prod-enquire .arrow{ transform:translateX(3px); }

.prod-badge{
  position:absolute; top:10px; left:10px; z-index:2;
  padding:4px 10px; border-radius:100px;
  font-family:'Geist Mono',monospace; font-size:10px; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase;
  background:var(--bg-0); color:var(--ink-0);
}
.prod-badge.new{ background:linear-gradient(135deg,var(--red),var(--red-2)); color:#fff; }
.prod-badge.sensor{ background:linear-gradient(135deg,var(--violet),var(--cyan)); color:#fff; }
.prod-badge.ups{ background:linear-gradient(135deg,var(--emerald),#34D399); color:var(--bg-0); }

@media(max-width:1024px){ .prod-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:768px){ .prod-grid{ grid-template-columns:repeat(2,1fr); gap:10px; } }

/* =============================================================
   Anchor nav (products)
   ============================================================= */
.anchor-nav{
  position:sticky; top:66px; z-index:50;
  background:rgba(10,10,11,.88); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-0);
  padding:12px 0;
}
.anchor-nav-inner{
  display:flex; gap:4px; overflow-x:auto; -webkit-overflow-scrolling:touch;
  padding:0 40px;
}
.anchor-nav-inner::-webkit-scrollbar{ display:none; }
.anchor-link{
  padding:7px 13px; border-radius:100px; font-size:13px; font-weight:500;
  color:var(--ink-2); white-space:nowrap; transition:all var(--t-fast);
}
.anchor-link:hover{ background:rgba(255,255,255,.06); color:var(--ink-0); }

/* =============================================================
   About / Why-us / Contact page styling (dark mode)
   ============================================================= */
.about-hero{
  padding:160px 0 80px;
  background:var(--bg-0);
  position:relative; overflow:hidden;
  border-bottom:1px solid var(--line-0);
}
.about-hero-inner{ position:relative; z-index:2; max-width:780px; }
.about-hero h1{ color:var(--ink-0); margin-bottom:24px; }
.about-hero .lead{ color:var(--ink-2); }

/* About Stats */
.about-stats{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px; text-align:left;
}
.about-stat{
  padding:36px 32px; background:var(--bg-1); border:1px solid var(--line-0); border-radius:22px;
}
.about-stat-num{
  font-size:clamp(44px,5vw,68px); font-weight:700; letter-spacing:-.04em; line-height:1; margin-bottom:12px;
  color:var(--ink-0);
}
.about-stat-label{ font-size:15px; font-weight:600; color:var(--ink-0); margin-bottom:6px; }
.about-stat-sub{ font-family:'Geist Mono',monospace; font-size:11px; color:var(--ink-3); letter-spacing:.06em; text-transform:uppercase; }
@media(max-width:768px){ .about-stats{ grid-template-columns:1fr; } }

/* Timeline */
.timeline{ position:relative; padding:24px 0 24px 40px; }
.timeline::before{
  content:''; position:absolute; left:16px; top:24px; bottom:24px; width:1px;
  background:linear-gradient(180deg,var(--red) 0%,var(--amber) 50%,var(--violet) 100%);
  opacity:.3;
}
.tl-item{ position:relative; padding:24px 0; display:flex; flex-direction:column; }
.tl-item::before{
  content:''; position:absolute; left:-34px; top:32px; width:12px; height:12px;
  background:var(--red); border-radius:50%;
  box-shadow:0 0 0 6px rgba(220,30,42,.12);
}
.tl-year{
  font-family:'Geist Mono',monospace; font-size:11px; font-weight:500;
  color:var(--red-2); letter-spacing:.14em; text-transform:uppercase; margin-bottom:10px;
}
.tl-title{ font-size:22px; font-weight:600; margin-bottom:10px; letter-spacing:-.02em; color:var(--ink-0); }
.tl-desc{ color:var(--ink-2); font-size:15px; line-height:1.6; max-width:620px; }

/* Certifications */
.certs{
  display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px;
}
.cert-card{
  padding:24px; background:var(--bg-1); border:1px solid var(--line-0); border-radius:18px;
  display:flex; align-items:center; gap:14px;
  transition:all var(--t);
}
.cert-card:hover{ border-color:var(--line-1); background:var(--bg-2); }
.cert-mark{
  width:44px; height:44px; border-radius:12px; background:var(--bg-2);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  border:1px solid var(--line-0);
}
.cert-mark svg{ stroke:var(--red-2); stroke-width:1.8; fill:none; width:20px; height:20px; }
.cert-name{ font-size:14.5px; font-weight:600; margin-bottom:2px; color:var(--ink-0); }
.cert-sub{ font-family:'Geist Mono',monospace; font-size:11px; color:var(--ink-3); letter-spacing:.04em; }

/* Why-Us pillar sections */
.pillar-section{
  display:grid; grid-template-columns:0.8fr 1.2fr; gap:80px;
  padding:96px 0; align-items:center;
  border-bottom:1px solid var(--line-0);
}
.pillar-section:last-child{ border-bottom:none; }
.pillar-section.reverse{ direction:rtl; }
.pillar-section.reverse > *{ direction:ltr; }
.pillar-label{
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 13px; border-radius:100px;
  background:rgba(220,30,42,.08); color:var(--red-2);
  font-family:'Geist Mono',monospace; font-size:11px; font-weight:500;
  letter-spacing:.12em; text-transform:uppercase;
  margin-bottom:20px; border:1px solid rgba(220,30,42,.2);
}
.pillar-label .num{
  width:20px; height:20px; border-radius:50%;
  background:var(--red); color:#fff; font-weight:700;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:10px;
}
.pillar-label.amber{ background:rgba(255,159,67,.08); color:var(--amber); border-color:rgba(255,159,67,.2); }
.pillar-label.amber .num{ background:var(--amber); color:var(--bg-0); }
.pillar-label.violet{ background:rgba(139,92,246,.08); color:#B794F4; border-color:rgba(139,92,246,.2); }
.pillar-label.violet .num{ background:var(--violet); }
.pillar-label.emerald{ background:rgba(16,185,129,.08); color:#34D399; border-color:rgba(16,185,129,.2); }
.pillar-label.emerald .num{ background:var(--emerald); color:var(--bg-0); }
.pillar-label.blue{ background:rgba(6,182,212,.08); color:#67E8F9; border-color:rgba(6,182,212,.2); }
.pillar-label.blue .num{ background:var(--cyan); color:var(--bg-0); }

.pillar-visual{
  aspect-ratio:4/3; border-radius:24px; overflow:hidden;
  background:linear-gradient(135deg,var(--bg-1) 0%,var(--bg-2) 100%);
  border:1px solid var(--line-0); position:relative;
  display:flex; align-items:center; justify-content:center;
}
.pillar-visual::before{
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 300px 200px at 30% 40%, rgba(220,30,42,.15) 0%, transparent 60%),
    radial-gradient(ellipse 300px 200px at 80% 80%, rgba(139,92,246,.1) 0%, transparent 60%);
}
.pillar-visual-inner{ position:relative; z-index:2; padding:40px; text-align:center; }
.pillar-feature-list{
  list-style:none; padding:0; margin-top:32px;
  display:flex; flex-direction:column; gap:14px;
}
.pillar-feature-list li{
  display:flex; gap:14px; align-items:flex-start;
  font-size:15.5px; color:var(--ink-1); line-height:1.55;
}
.pillar-feature-list .check{
  flex-shrink:0; width:20px; height:20px; border-radius:50%;
  background:rgba(220,30,42,.15); display:flex; align-items:center; justify-content:center;
  margin-top:2px;
}
.pillar-feature-list .check svg{ stroke:var(--red-2); stroke-width:3; width:10px; height:10px; fill:none; }
.pillar-feature-list strong{ color:var(--ink-0); font-weight:600; }
.big-stat{
  font-size:clamp(60px,8vw,120px); font-weight:800; letter-spacing:-.055em; line-height:.95;
  background:linear-gradient(135deg,var(--ink-0) 0%,var(--ink-2) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
@media(max-width:960px){
  .pillar-section{ grid-template-columns:1fr; gap:40px; padding:64px 0; }
  .pillar-section.reverse{ direction:ltr; }
}

/* VS Table (why us) */
.vs-table{
  background:var(--bg-1); border:1px solid var(--line-0); border-radius:22px; overflow:hidden;
}
.vs-head{
  display:grid; grid-template-columns:1.4fr 1fr 1fr;
  background:var(--bg-2); border-bottom:1px solid var(--line-0);
}
.vs-head > div{
  padding:22px 28px; font-family:'Geist Mono',monospace; font-size:11.5px; font-weight:500;
  color:var(--ink-2); letter-spacing:.1em; text-transform:uppercase;
}
.vs-head > div.us{ background:var(--red); color:#fff; }
.vs-row{
  display:grid; grid-template-columns:1.4fr 1fr 1fr;
  border-bottom:1px solid var(--line-0);
}
.vs-row:last-child{ border-bottom:none; }
.vs-row > div{ padding:20px 28px; font-size:14.5px; color:var(--ink-2); line-height:1.5; }
.vs-row > div:first-child{ font-weight:500; color:var(--ink-0); background:var(--bg-2); }
.vs-row > div.us{ font-weight:500; color:var(--ink-0); }
.vs-yes{ color:#6EE7B7; font-weight:500; }
.vs-no{ color:var(--ink-3); }
@media(max-width:768px){
  .vs-head, .vs-row{ grid-template-columns:1fr 1fr; }
  .vs-head > div:first-child, .vs-row > div:first-child{ grid-column:span 2; padding:12px 20px; border-bottom:1px solid var(--line-0); font-size:11px; }
  .vs-head > div, .vs-row > div{ padding:14px 20px; font-size:13.5px; }
}

/* Contact page */
.contact-grid{ display:grid; grid-template-columns:1fr 1.2fr; gap:24px; align-items:start; }
.info-card{
  padding:36px; background:linear-gradient(135deg,var(--bg-1) 0%,var(--bg-2) 100%);
  border:1px solid var(--line-0); border-radius:24px; position:relative; overflow:hidden;
}
.info-card::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 300px 200px at 90% 30%, rgba(220,30,42,.15) 0%, transparent 60%);
}
.info-card-inner{ position:relative; z-index:2; }
.info-card h3{ color:var(--ink-0); font-size:20px; font-weight:600; margin-bottom:28px; letter-spacing:-.02em; }
.info-block{ padding:18px 0; border-bottom:1px solid var(--line-0); }
.info-block:last-child{ border-bottom:none; padding-bottom:0; }
.info-block:first-child{ padding-top:0; }
.info-label{
  font-family:'Geist Mono',monospace; font-size:10.5px; font-weight:500; color:var(--ink-3);
  letter-spacing:.14em; text-transform:uppercase; margin-bottom:8px;
}
.info-val{ font-size:15px; color:var(--ink-0); line-height:1.6; }
.info-val a{ color:var(--ink-0); }
.info-val a:hover{ color:var(--red-2); }

.contact-channels{
  display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:48px;
}
.channel-card{
  padding:28px; background:var(--bg-1); border:1px solid var(--line-0); border-radius:20px;
  transition:all var(--t); display:flex; flex-direction:column; align-items:flex-start;
}
.channel-card:hover{ transform:translateY(-2px); border-color:var(--line-1); background:var(--bg-2); }
.channel-icon{
  width:44px; height:44px; border-radius:12px;
  background:rgba(220,30,42,.08); display:flex; align-items:center; justify-content:center; margin-bottom:20px;
  border:1px solid rgba(220,30,42,.15);
}
.channel-icon svg{ stroke:var(--red-2); stroke-width:1.8; fill:none; width:20px; height:20px; }
.channel-icon.wa{ background:rgba(37,211,102,.08); border-color:rgba(37,211,102,.15); }
.channel-icon.wa svg{ stroke:#25D366; }
.channel-icon.phone{ background:rgba(6,182,212,.08); border-color:rgba(6,182,212,.15); }
.channel-icon.phone svg{ stroke:var(--cyan); }
.channel-title{ font-family:'Geist Mono',monospace; font-size:10.5px; font-weight:500; color:var(--ink-3); letter-spacing:.12em; text-transform:uppercase; margin-bottom:8px; }
.channel-value{ font-size:18px; font-weight:600; color:var(--ink-0); margin-bottom:6px; letter-spacing:-.015em; }
.channel-sub{ font-size:13px; color:var(--ink-3); }
@media(max-width:900px){ .contact-channels{ grid-template-columns:1fr; } }

.form-card{
  padding:40px; background:var(--bg-1); border:1px solid var(--line-0); border-radius:24px;
}
.form-card h2{ font-size:28px; font-weight:600; margin-bottom:10px; letter-spacing:-.025em; color:var(--ink-0); }
.form-card .form-sub{ color:var(--ink-2); margin-bottom:32px; font-size:15px; }

.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-grid .full{ grid-column:span 2; }
.form-label{
  display:block; font-size:12.5px; font-weight:500; color:var(--ink-0); margin-bottom:7px;
  letter-spacing:-.005em;
}
.form-label .req{ color:var(--red-2); }
.form-input,.form-select,.form-textarea{
  width:100%; padding:12px 14px;
  border:1px solid var(--line-0); border-radius:10px;
  font:inherit; font-size:14.5px; color:var(--ink-0);
  background:var(--bg-2);
  transition:all var(--t-fast);
}
.form-input::placeholder,.form-textarea::placeholder{ color:var(--ink-3); }
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none; border-color:var(--red-2); background:var(--bg-2);
  box-shadow:0 0 0 4px rgba(220,30,42,.12);
}
.form-select{ cursor:pointer; color:var(--ink-0); }
.form-select option{ background:var(--bg-2); color:var(--ink-0); }
.form-textarea{ min-height:120px; resize:vertical; }
.form-submit{ grid-column:span 2; margin-top:8px; }

@media(max-width:900px){
  .contact-grid{ grid-template-columns:1fr; }
  .form-grid{ grid-template-columns:1fr; }
  .form-grid .full, .form-submit{ grid-column:span 1; }
}

.success-msg{
  background:linear-gradient(135deg,rgba(16,185,129,.1) 0%,rgba(16,185,129,.04) 100%);
  border:1px solid rgba(16,185,129,.3); border-radius:16px;
  padding:32px; text-align:center; display:none;
}
.success-msg.show{ display:block; }
.success-icon{
  width:56px; height:56px; margin:0 auto 20px;
  background:var(--emerald); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
}
.success-msg h3{ font-size:20px; color:#6EE7B7; margin-bottom:10px; }
.success-msg p{ color:var(--ink-1); }

/* =============================================================
   Utility classes
   ============================================================= */
.text-center{ text-align:center; }
.text-red{ color:var(--red-2); }
.text-amber{ color:var(--amber); }
.text-muted{ color:var(--ink-2); }
.mt-0{ margin-top:0 !important; }
.mt-8{ margin-top:8px; } .mt-16{ margin-top:16px; } .mt-24{ margin-top:24px; } .mt-32{ margin-top:32px; } .mt-48{ margin-top:48px; } .mt-64{ margin-top:64px; }
.mb-0{ margin-bottom:0 !important; }
.mb-8{ margin-bottom:8px; } .mb-16{ margin-bottom:16px; } .mb-24{ margin-bottom:24px; } .mb-32{ margin-bottom:32px; } .mb-48{ margin-bottom:48px; }
.hide-mobile{ }
@media(max-width:640px){ .hide-mobile{ display:none !important; } }

/* =============================================================
   Reveal animations (scroll-triggered)
   ============================================================= */
.reveal{
  opacity:0; transform:translateY(24px);
  transition:opacity .8s ease, transform .8s cubic-bezier(.25,.46,.45,.94);
}
.reveal.in{ opacity:1; transform:translateY(0); }
.reveal-fade{ opacity:0; transition:opacity 1.2s ease; }
.reveal-fade.in{ opacity:1; }

/* WhatsApp float */
.wa-float{
  position:fixed; bottom:24px; right:24px; z-index:80;
  width:54px; height:54px; border-radius:50%;
  background:#25D366; display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 20px rgba(37,211,102,.35), 0 1px 0 rgba(255,255,255,.1) inset;
  transition:transform var(--t);
}
.wa-float:hover{ transform:scale(1.08) rotate(4deg); }
.wa-float svg{ width:26px; height:26px; fill:#fff; }

/* Cursor-follow glow (light effect) */
.cursor-glow{
  position:fixed; top:0; left:0; width:400px; height:400px;
  border-radius:50%; pointer-events:none; z-index:3;
  background:radial-gradient(circle, rgba(220,30,42,.08) 0%, transparent 70%);
  transform:translate(-50%,-50%); filter:blur(20px);
  transition:opacity var(--t);
  opacity:0;
}
@media(hover:hover){ .cursor-glow{ opacity:1; } }
