/* ===================================================
   MACAGNO DÍAZ V4 — Épica
   =================================================== */

/* ── Variables ──────────────────────────────────── */
:root {
  --ink:    #0F0E0C;
  --ink2:   #1A1917;
  --ink3:   #080807;
  --cream:  #F5F0E8;
  --orange: #D4530F;
  --green:  #22C55E;
  --wsp:    #25D366;

  --ff-display: 'Bebas Neue', sans-serif;
  --ff-serif:   'Fraunces', serif;
  --ff-sans:    'Bricolage Grotesque', sans-serif;
  --ff-mono:    'DM Mono', monospace;

  --nav-h:      150px;
  --px:         clamp(24px, 6vw, 100px);
  --py:         clamp(80px, 10vh, 128px);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--ff-sans);
  background: var(--ink);
  color: var(--cream);
  cursor: none;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
*, a, button, input, select, textarea { cursor: none !important; }
img { display: block; max-width: 100%; }
ul  { list-style: none; }
a   { color: inherit; text-decoration: none; }

/* ── Noise ──────────────────────────────────────── */
.noise {
  position: fixed; inset: 0;
  pointer-events: none;
  z-index: 9980;
  opacity: 0.035;
  mix-blend-mode: overlay;
}

/* ── Scroll Progress ────────────────────────────── */
.scroll-bar {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  background: var(--orange);
  z-index: 9000;
  width: 0%;
  transition: width 0.1s linear;
  box-shadow: 0 0 8px rgba(212,83,15,0.6);
}

/* ── Cursor Trail ───────────────────────────────── */
.cursor-dot {
  position: fixed;
  width: 7px; height: 7px;
  background: var(--orange);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%,-50%);
  will-change: left, top;
}
.cursor-trail {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  z-index: 9997;
  transform: translate(-50%,-50%);
  will-change: left, top;
  background: var(--orange);
}

/* ── ════════════════════════════════════════════════
   INTRO
═══════════════════════════════════════════════ */
.intro {
  position: fixed;
  inset: 0;
  z-index: 9500;
  background: var(--ink3);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  overflow: hidden;
}
.intro.gone { display: none; }

.intro-msgs-wrap {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.intro-msg {
  position: absolute;
  text-align: center;
  opacity: 0;
  pointer-events: none;
  padding: 0 clamp(24px, 8vw, 140px);
}
.intro-msg .im-word {
  font-family: var(--ff-display);
  font-size: clamp(52px, 10vw, 128px);
  line-height: 0.92;
  letter-spacing: -0.01em;
  color: var(--cream);
  display: block;
}
.intro-msg .im-sub {
  font-family: var(--ff-mono);
  font-size: clamp(11px, 1.2vw, 14px);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.3);
  display: block;
  margin-top: 16px;
}
.intro-msg.accent .im-word {
  font-family: var(--ff-serif);
  font-style: italic;
  font-weight: 300;
  color: var(--orange);
  font-size: clamp(56px, 10vw, 140px);
}
.intro-msg.bold-accent .im-word {
  color: var(--orange);
  -webkit-text-stroke: 0;
}

/* Intro logo */
.intro-logo-wrap {
  position: absolute;
  text-align: center;
  opacity: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 0 clamp(24px, 8vw, 140px);
}
/* Animated logo: sun + text side by side */
.intro-logo-animated {
  display: flex;
  align-items: center;
  gap: clamp(18px, 3vw, 36px);
}
.intro-sun {
  width:  250px;
  height: 250px;
  flex-shrink: 0;
  overflow: visible;
}
.sun-spin {
  animation: none;
  transform-box: fill-box;
  transform-origin: center;
}
@keyframes sunSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
.intro-logo-text-block { text-align: left; }
.intro-logo-name {
  font-family: 'Bebas Neue', sans-serif;
  font-size: clamp(48px, 7.5vw, 96px);
  line-height: 0.88;
  letter-spacing: -0.01em;
  color: var(--cream);
}
.intro-logo-agency {
  font-family: var(--ff-mono);
  font-size: clamp(10px, 1.1vw, 13px);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.38);
  margin-top: 10px;
}
.intro-logo-sub {
  font-family: var(--ff-mono);
  font-size: clamp(11px, 1.1vw, 13px);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.35);
  opacity: 0;
}
.intro-enter {
  margin-top: 12px;
  font-family: var(--ff-sans);
  font-size: 16px;
  font-weight: 700;
  padding: 14px 32px;
  background: var(--orange);
  color: var(--cream);
  border: none;
  border-radius: 4px;
  opacity: 0;
  box-shadow: 0 0 0 rgba(212,83,15,0);
}
/* Intro logo img */
.intro-logo-img {
  width: clamp(240px, 32vw, 360px);
  height: auto;
  object-fit: contain;
  display: block;
}
/* Nav logo image */
.nav-logo-img {
  height: 120px;
  width: auto;
  display: block;
  object-fit: contain;
}

/* Intro progress line */
.intro-progress {
  position: absolute;
  bottom: 0; left: 0;
  height: 2px;
  background: var(--orange);
  width: 0%;
  opacity: 0.6;
  box-shadow: 0 0 8px rgba(212,83,15,0.5);
}

/* Skip */
.intro-skip {
  position: absolute;
  bottom: 28px; right: 28px;
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.28);
  background: transparent;
  border: none;
  padding: 8px;
  transition: color 0.2s;
}
.intro-skip:hover { color: rgba(245,240,232,0.7); }

/* Rocket animation */
.intro-rocket {
  animation: rocketLaunch 2.8s ease-in-out infinite;
  filter: drop-shadow(0 0 24px rgba(212,83,15,0.6));
}
@keyframes rocketLaunch {
  0%   { transform: translateY(0)     rotate(-4deg); }
  40%  { transform: translateY(-28px) rotate(2deg); }
  70%  { transform: translateY(-14px) rotate(-2deg); }
  100% { transform: translateY(0)     rotate(-4deg); }
}
@keyframes flamePulse {
  from { opacity: 0.6; transform: scaleX(0.85); }
  to   { opacity: 1;   transform: scaleX(1.15); }
}

/* Intro decorative corner lines */
.intro-corner {
  position: absolute;
  width: 48px; height: 48px;
  pointer-events: none;
  opacity: 0.15;
}
.intro-corner.tl { top: 28px; left: 28px;
  border-top: 1px solid var(--cream); border-left: 1px solid var(--cream); }
.intro-corner.tr { top: 28px; right: 28px;
  border-top: 1px solid var(--cream); border-right: 1px solid var(--cream); }
.intro-corner.bl { bottom: 28px; left: 28px;
  border-bottom: 1px solid var(--cream); border-left: 1px solid var(--cream); }
.intro-corner.br { bottom: 28px; right: 28px;
  border-bottom: 1px solid var(--cream); border-right: 1px solid var(--cream); }

/* ── ════════════════════════════════════════════════
   NAV
═══════════════════════════════════════════════ */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 800;
  height: var(--nav-h);
  padding: 0 var(--px);
  display: flex; align-items: center;
  transition: background 0.4s, border-bottom 0.4s;
}
.nav.scrolled {
  background: rgba(15,14,12,0.92);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(245,240,232,0.06);
}
.nav-inner { display: flex; align-items: center; width: 100%; gap: 36px; }
.nav-logo {
  font-family: var(--ff-serif);
  font-size: 20px; font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--cream); flex-shrink: 0;
}
.nav-logo .dot { color: var(--orange); }
.nav-links { display: flex; gap: 36px; flex: 1; padding-left: 20px; }
.nav-links a {
  font-family: var(--ff-sans);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.6);
  transition: color 0.2s;
}
.nav-links a:hover { color: var(--cream); }

/* ── Buttons ─────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--ff-sans); font-size: 15px; font-weight: 600;
  border-radius: 5px; padding: 14px 26px; border: none;
  white-space: nowrap; letter-spacing: 0.01em;
  position: relative; will-change: transform;
  transition: box-shadow 0.3s, background 0.3s;
}
.btn-primary { background: var(--orange); color: var(--cream); }
.btn-primary:hover { background: #c44810; box-shadow: 0 10px 36px rgba(212,83,15,0.45); }
.btn-ghost {
  background: transparent; color: var(--cream);
  border: 1.5px solid rgba(245,240,232,0.22);
}
.btn-ghost:hover { border-color: rgba(245,240,232,0.65); background: rgba(245,240,232,0.05); }
.btn-nav {
  font-size: 16px;
  font-weight: 700;
  padding: 16px 30px;
  background: var(--orange);
  color: var(--cream);
  margin-left: auto;
  border-radius: 5px;
  letter-spacing: 0.01em;
  white-space: nowrap;
}
.btn-nav:hover { background: #c44810; box-shadow: 0 8px 28px rgba(212,83,15,0.4); }

/* ── ════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════ */
.hero {
  min-height: 100vh;
  display: flex; flex-direction: column;
  position: relative; overflow: hidden;
  padding-top: var(--nav-h);
  background: var(--ink);
}

/* Canvas bg */
.hero-canvas {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  z-index: 1;
}

/* Top strip */
.hero-strip {
  background: var(--orange);
  overflow: hidden; padding: 9px 0;
  flex-shrink: 0; position: relative; z-index: 3;
}
.strip-inner {
  display: inline-flex; gap: 20px;
  white-space: nowrap;
  animation: marqueeX 20s linear infinite;
}
.strip-inner span {
  font-family: var(--ff-mono);
  font-size: 11px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--cream); flex-shrink: 0;
}
.strip-inner .sep { opacity: 0.45; }

@keyframes marqueeX {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Content */
.hero-content {
  flex: 1; display: flex; flex-direction: column;
  justify-content: center;
  padding: clamp(40px,6vh,80px) var(--px);
  position: relative; z-index: 2;
  max-width: 1440px; margin: 0 auto; width: 100%;
}

/* 3D Parallax Layers */
.hero-3d {
  position: relative;
  perspective: 1000px;
  perspective-origin: center center;
  margin-bottom: 36px;
}
.h-layer {
  transition: transform 0.08s linear;
  will-change: transform;
}
.h-layer-back  { position: absolute; top: 0; left: 0; width: 100%; }
.h-layer-front { position: relative; }

/* Headline */
.hero-hl {
  font-family: var(--ff-display);
  font-size: clamp(80px, 13.5vw, 185px);
  line-height: 0.875;
  letter-spacing: -0.01em;
  display: flex; flex-direction: column;
  gap: 4px;
  user-select: none;
}
.hl-line { display: block; overflow: hidden; line-height: 1; }
.hl-inner { display: block; }
.hero-hl em {
  font-family: var(--ff-serif);
  font-style: italic; font-weight: 300;
  font-size: 0.85em; vertical-align: baseline;
}
.outline-word {
  -webkit-text-stroke: 2.5px var(--orange);
  color: transparent;
}
/* Interactive word hover */
.iword {
  display: inline-block;
  transition: color 0.22s, transform 0.22s;
  position: relative;
}
.iword:hover { color: var(--orange); transform: skewX(-4deg); }
.outline-word.iword:hover {
  -webkit-text-stroke-color: var(--orange);
  color: rgba(212,83,15,0.12);
}

/* Badge */
.hero-badge {
  display: inline-flex; align-items: center; gap: 10px;
  border: 1px solid rgba(245,240,232,0.12);
  border-radius: 100px; padding: 8px 18px;
  width: fit-content; margin-bottom: 32px;
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.06em; color: rgba(245,240,232,0.55);
}
.badge-sep { width: 1px; height: 12px; background: rgba(245,240,232,0.18); flex-shrink: 0; }

/* Sub */
.hero-sub {
  max-width: 540px;
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.78; color: rgba(245,240,232,0.55);
  margin-bottom: 36px; text-wrap: pretty;
}
/* Interactive words in sub */
.hero-sub .hw {
  color: rgba(245,240,232,0.9);
  border-bottom: 1px solid rgba(212,83,15,0.35);
  transition: color 0.2s, border-color 0.2s;
  display: inline;
}
.hero-sub .hw:hover { color: var(--orange); border-color: var(--orange); }

/* CTAs */
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 44px; }

/* Live counter */
.live-counter {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding: 36px 0 0;
  border-top: 1px solid rgba(245,240,232,0.08);
  max-width: 680px;
}
.live-counter-top {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}
.live-main {
  font-family: var(--ff-mono);
  font-size: clamp(10px, 0.9vw, 12px);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.5);
  font-weight: 400;
}
.live-number {
  font-family: var(--ff-display);
  font-size: clamp(100px, 16vw, 210px);
  line-height: 0.85;
  color: var(--cream);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.03em;
  display: block;
  transition: text-shadow 0.15s ease;
  will-change: text-shadow;
}
.live-number.tick {
  text-shadow: 0 0 80px rgba(212,83,15,0.55), 0 0 30px rgba(212,83,15,0.3);
}
.live-sub {
  font-family: var(--ff-mono);
  font-size: clamp(9px, 0.75vw, 11px);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.28);
  margin-top: 10px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.live-sub::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: rgba(212,83,15,0.4);
  flex-shrink: 0;
}

/* Pulse dot */
.pulse-dot {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; flex-shrink: 0; position: relative;
  background: var(--cream);
}
.pulse-dot::after {
  content: ''; position: absolute; inset: -4px;
  border-radius: 50%; background: inherit;
  opacity: 0.32; animation: pulse 2.2s ease-in-out infinite;
}
.pulse-dot.green { background: var(--green); }
@keyframes pulse {
  0%,100% { transform: scale(1); opacity: 0.32; }
  50%      { transform: scale(2.8); opacity: 0; }
}

/* Scroll indicator */
.scroll-hint {
  display: flex; align-items: center; gap: 10px;
  margin-top: 56px;
  font-family: var(--ff-mono); font-size: 10px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(245,240,232,0.22);
}
.scroll-line {
  width: 36px; height: 1px;
  background: rgba(245,240,232,0.2);
  position: relative; overflow: hidden;
}
.scroll-line::after {
  content: '';
  position: absolute; top: 0; left: 0;
  height: 100%; width: 100%;
  background: var(--orange);
  animation: scrollSlide 2.4s ease-in-out infinite;
}
@keyframes scrollSlide {
  0%   { transform: translateX(-100%); }
  50%  { transform: translateX(0); }
  100% { transform: translateX(100%); }
}

/* ── Orbs ────────────────────────────────────────── */
.orb {
  position: absolute; border-radius: 50%;
  pointer-events: none; filter: blur(100px); z-index: 0;
}
.orb-1 { width: 720px; height: 720px; right: -100px; top: 0%;
  background: radial-gradient(circle, rgba(212,83,15,0.14) 0%, transparent 70%);
  animation: floatA 10s ease-in-out infinite; }
.orb-2 { width: 380px; height: 380px; left: 10%; bottom: 5%;
  background: radial-gradient(circle, rgba(212,83,15,0.08) 0%, transparent 70%);
  animation: floatB 13s ease-in-out infinite; }
@keyframes floatA { 0%,100%{transform:translateY(0) scale(1)} 50%{transform:translateY(-52px) scale(1.07)} }
@keyframes floatB { 0%,100%{transform:translateY(0)} 50%{transform:translateY(40px)} }

/* ── ════════════════════════════════════════════════
   SECTION HELPERS
═══════════════════════════════════════════════ */
.mono-tag {
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--orange); display: block; margin-bottom: 14px;
}
.mono-tag-dark {
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: rgba(15,14,12,0.38); display: block; margin-bottom: 14px;
}
.display-h2 {
  font-family: var(--ff-display);
  font-size: clamp(52px, 7.5vw, 96px);
  line-height: 0.9; letter-spacing: -0.01em;
  color: var(--cream);
}
.serif-h2 {
  font-family: var(--ff-serif);
  font-size: clamp(28px, 3.5vw, 48px);
  font-weight: 600; line-height: 1.2;
  letter-spacing: -0.025em; color: var(--ink);
  text-wrap: pretty; margin-bottom: 24px;
}
.body-txt {
  font-size: 16px; line-height: 1.8;
  color: rgba(15,14,12,0.62); margin-bottom: 16px;
  text-wrap: pretty;
}

/* ── Clip-path Reveal ────────────────────────────── */
.clip-reveal {
  clip-path: inset(0 0 100% 0);
  transition: clip-path 0.9s cubic-bezier(0.22,1,0.36,1);
}
.clip-reveal.visible { clip-path: inset(0 0 0% 0); }

.fade-up {
  opacity: 0; transform: translateY(36px);
  transition: opacity 0.75s ease, transform 0.75s ease;
}
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* Scramble heading wrapper */
.scramble-wrap { position: relative; }

/* ── ════════════════════════════════════════════════
   STATS BAND
═══════════════════════════════════════════════ */
.stats-band {
  background: var(--orange);
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  align-items: center;
  padding: clamp(64px,9vh,110px) var(--px);
  position: relative; overflow: hidden;
}
/* Stat item animation */
.stat-item {
  opacity: 0;
  transform: translateY(40px);
}
.stat-item.stat-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1);
}
.stat-item.stat-visible .stat-num {
  animation: statLineReveal 0.6s cubic-bezier(0.22,1,0.36,1) both;
}
.stat-item.stat-visible .stat-label {
  animation: statFadeIn 0.5s ease both;
  animation-delay: 0.22s;
}
@keyframes statLineReveal {
  from { clip-path: inset(0 0 100% 0); opacity: 0; }
  to   { clip-path: inset(0 0 0% 0);   opacity: 1; }
}
@keyframes statFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.stat-item { display: flex; flex-direction: column; gap: 14px; padding: 0 clamp(18px,2.5vw,48px); }
.stat-item:first-child { padding-left: 0; }
.stat-item:last-child  { padding-right: 0; }
.stat-num {
  font-family: var(--ff-display);
  font-size: clamp(26px,2.8vw,42px);
  line-height: 0.95; color: var(--cream);
  letter-spacing: -0.01em;
}
.stat-label {
  font-family: var(--ff-sans);
  font-size: clamp(14px,1.2vw,17px);
  font-weight: 700;
  line-height: 1.45;
  color: var(--cream);
  max-width: 220px;
  padding-top: 8px;
  border-top: 1.5px solid rgba(245,240,232,0.4);
}
.stat-divider { width: 1px; background: rgba(245,240,232,0.2); align-self: stretch; }

/* ── ════════════════════════════════════════════════
   MIRROR
═══════════════════════════════════════════════ */
.mirror-section {
  background: var(--cream); color: var(--ink);
  padding: var(--py) var(--px);
}
.mirror-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px; max-width: 1440px; margin: 0 auto; align-items: start;
}
.mirror-left { display: flex; flex-direction: column; }
.checklist { display: flex; flex-direction: column; gap: 14px; margin-top: 36px; }
.check-item {
  display: flex; align-items: flex-start; gap: 16px;
  padding: 20px 22px;
  background: rgba(15,14,12,0.04);
  border-radius: 8px; border-left: 3px solid var(--orange);
}
.check-emoji { font-size: 22px; flex-shrink: 0; margin-top: 1px; }
.check-item strong { display: block; font-size: 15px; font-weight: 700; margin-bottom: 4px; color: var(--ink); }
.check-note { font-family: var(--ff-mono); font-size: 11px; color: rgba(15,14,12,0.4); }
/* Before/After */
.mirror-right { position: sticky; top: 100px; }
.ba-tabs { display: flex; border: 1.5px solid rgba(15,14,12,0.12); border-radius: 8px; overflow: hidden; }
.ba-tab { flex: 1; padding: 13px; font-family: var(--ff-sans); font-size: 13px; font-weight: 600; background: transparent; border: none; color: rgba(15,14,12,0.4); transition: all 0.3s; }
.ba-tab.active { background: var(--ink); color: var(--cream); }
.ba-pane { display: none; background: var(--ink); border-radius: 0 0 12px 12px; padding: 32px; color: var(--cream); }
.ba-pane.active { display: block; }
.ba-big { display: flex; align-items: baseline; gap: 12px; margin-bottom: 28px; }
.ba-num { font-family: var(--ff-display); font-size: 72px; line-height: 1; }
.ba-num.orange { color: var(--orange); }
.ba-unit { font-size: 13px; color: rgba(245,240,232,0.4); line-height: 1.4; max-width: 110px; }
.ba-bars { display: flex; flex-direction: column; gap: 18px; }
.bar-row { display: flex; flex-direction: column; gap: 8px; }
.bar-row > span { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; color: rgba(245,240,232,0.38); }
.bar-track { height: 4px; background: rgba(245,240,232,0.07); border-radius: 3px; overflow: hidden; }
.bar-fill { height: 100%; background: rgba(245,240,232,0.2); border-radius: 3px; transition: width 1.1s cubic-bezier(0.22,1,0.36,1); }
.bar-fill.accent { background: var(--orange); }

/* ═══════════════════════════════════════════════
   ESCENAS — Mientras vos cerrás
═══════════════════════════════════════════════ */
.escenas-section {
  background: var(--ink);
  padding: var(--py) var(--px);
  position: relative;
  overflow: hidden;
}
.escenas-section::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(212,83,15,0.08) 0%, transparent 70%);
  pointer-events: none;
}
.escenas-inner { max-width: 1440px; margin: 0 auto; }

.escenas-header {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: end;
  margin-bottom: 64px;
}
.escenas-title {
  font-family: var(--ff-display);
  font-size: clamp(56px, 8vw, 112px);
  line-height: 0.88;
  letter-spacing: -0.02em;
  color: var(--cream);
  grid-column: 1;
}
.escenas-title-accent { color: var(--orange); }
.escenas-sub {
  font-size: clamp(15px, 1.3vw, 18px);
  line-height: 1.75;
  color: rgba(245,240,232,0.5);
  grid-column: 2;
  align-self: end;
  padding-bottom: 8px;
  text-wrap: pretty;
}

.escenas-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 56px;
}

.escena-card {
  background: rgba(245,240,232,0.04);
  border: 1px solid rgba(245,240,232,0.08);
  border-radius: 14px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: border-color 0.3s, background 0.3s, transform 0.3s;
  position: relative;
  overflow: hidden;
}
.escena-card::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--orange);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.4s cubic-bezier(0.22,1,0.36,1);
}
.escena-card:hover {
  background: rgba(245,240,232,0.07);
  border-color: rgba(212,83,15,0.3);
  transform: translateY(-4px);
}
.escena-card:hover::after { transform: scaleX(1); }

.escena-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.escena-rubro {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.5);
}
.escena-time {
  font-family: var(--ff-display);
  font-size: 28px;
  line-height: 1;
  color: var(--orange);
  letter-spacing: -0.02em;
  animation: timePulse 3s ease-in-out infinite;
}
@keyframes timePulse {
  0%,100% { opacity: 1; }
  50%      { opacity: 0.55; }
}
.escena-search {
  font-family: var(--ff-mono);
  font-size: 13px;
  line-height: 1.5;
  color: rgba(245,240,232,0.75);
  padding: 12px 14px;
  background: rgba(245,240,232,0.05);
  border-radius: 8px;
  border-left: 2px solid rgba(212,83,15,0.4);
  flex: 1;
}
.escena-search::before {
  content: '🔍 ';
  opacity: 0.6;
}
.escena-status-wrap {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.escena-status {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
}
.escena-status.closed { color: rgba(245,240,232,0.35); }
.escena-status.open   { color: var(--green); }
.escena-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.escena-dot.closed { background: rgba(245,240,232,0.25); }
.escena-dot.open   { background: var(--green); animation: pulse 2s ease-in-out infinite; }

.escenas-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 32px 40px;
  background: rgba(212,83,15,0.08);
  border: 1px solid rgba(212,83,15,0.2);
  border-radius: 14px;
  gap: 24px;
  flex-wrap: wrap;
}
.escenas-cta-txt {
  font-size: clamp(16px, 1.5vw, 20px);
  font-weight: 600;
  color: var(--cream);
  max-width: 560px;
  line-height: 1.4;
}

@media (max-width: 900px) {
  .escenas-header { grid-template-columns: 1fr; }
  .escenas-sub { grid-column: 1; }
  .escenas-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 580px) {
  .escenas-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════
   TABLA COMPARATIVA
══════════════════════════════════════════════════ */
.tabla-section {
  background: var(--ink);
  padding: var(--py) var(--px);
  position: relative;
  overflow: hidden;
}
.tabla-section::before {
  content: '';
  position: absolute;
  top: -300px; right: -200px;
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(212,83,15,0.07) 0%, transparent 70%);
  pointer-events: none;
}
.tabla-inner { max-width: 1200px; margin: 0 auto; }
.tabla-header { margin-bottom: 56px; }
.tabla-title {
  font-family: var(--ff-display);
  font-size: clamp(52px,7.5vw,96px);
  line-height: 0.9; letter-spacing: -0.01em;
  color: var(--cream); margin-top: 14px;
}
.tabla-accent { color: var(--orange); }
.tabla-wrap {
  border-radius: 16px; overflow: hidden;
  border: 1px solid rgba(245,240,232,0.08);
  margin-bottom: 56px;
}
.comp-table { width: 100%; border-collapse: collapse; }
.comp-table thead tr { background: rgba(245,240,232,0.04); }
.comp-table th {
  padding: 24px 20px; text-align: left;
  border-bottom: 1px solid rgba(245,240,232,0.08);
  vertical-align: top;
}
.col-feature { width: 38%; }
.col-solo    { width: 27%; }
.col-online  { width: 35%; }
.th-inner { display: flex; flex-direction: column; gap: 6px; }
.th-icon { font-size: 24px; display: block; }
.th-label {
  font-family: var(--ff-display);
  font-size: 18px; letter-spacing: 0.01em;
  color: var(--cream); display: block;
}
.th-badge {
  display: inline-block;
  font-family: var(--ff-mono);
  font-size: 10px; letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 3px 8px;
  background: rgba(212,83,15,0.2);
  color: var(--orange);
  border-radius: 4px; width: fit-content;
}
.featured-col.col-online {
  background: rgba(212,83,15,0.08);
  border-left: 1px solid rgba(212,83,15,0.2);
}
.tabla-row {
  border-bottom: 1px solid rgba(245,240,232,0.05);
  opacity: 0;
  transform: translateX(-12px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.tabla-row.row-visible { opacity: 1; transform: translateX(0); }
.tabla-row:last-child { border-bottom: none; }
.tabla-row:hover { background: rgba(245,240,232,0.025); }
.comp-table td { padding: 18px 20px; vertical-align: middle; }
.feat-cell { display: flex; align-items: center; gap: 12px; }
.feat-icon {
  font-size: 20px; flex-shrink: 0;
  display: inline-block;
  transition: transform 0.3s;
}
.tabla-row:hover .feat-icon { transform: scale(1.25) rotate(-6deg); }
.feat-txt {
  font-size: 14px; font-weight: 600;
  color: rgba(245,240,232,0.8);
  line-height: 1.35;
}
.solo-cell { font-size: 13px; color: rgba(245,240,232,0.32); line-height: 1.4; }
.online-cell { font-size: 13px; font-weight: 600; line-height: 1.4; }
.online-cell.featured-col {
  background: rgba(212,83,15,0.05);
  border-left: 1px solid rgba(212,83,15,0.12);
}
.cell-x   { color: rgba(245,240,232,0.22); font-family: var(--ff-mono); font-size: 12px; letter-spacing: 0.05em; }
.cell-no  { color: rgba(245,240,232,0.32); }
.cell-check { color: var(--green); font-weight: 700; }
.cell-yes   { color: var(--cream); }
.tabla-conclusion {
  text-align: center;
  display: flex; flex-direction: column;
  align-items: center; gap: 16px;
  padding: 48px 40px;
  background: rgba(212,83,15,0.06);
  border: 1px solid rgba(212,83,15,0.15);
  border-radius: 16px;
}
.conclusion-main {
  font-family: var(--ff-serif);
  font-size: clamp(22px,2.5vw,32px);
  font-weight: 300; line-height: 1.35;
  color: var(--cream); max-width: 600px;
}
.conclusion-main strong { font-weight: 700; color: var(--orange); }
.conclusion-sub {
  font-size: 15px; line-height: 1.7;
  color: rgba(245,240,232,0.5);
  max-width: 520px; text-wrap: pretty;
}
@media (max-width: 768px) {
  .col-feature { width: 45%; } .col-solo { width: 25%; } .col-online { width: 30%; }
  .feat-txt { font-size: 12px; }
  .comp-table td, .comp-table th { padding: 12px 10px; }
}

.typo-marquee-section {
  background: var(--cream);
  border-top: 1px solid rgba(15,14,12,0.07);
  border-bottom: 1px solid rgba(15,14,12,0.07);
  overflow: hidden; padding: 4px 0;
}
.typo-inner {
  display: inline-flex; align-items: center; gap: 32px;
  white-space: nowrap; animation: marqueeX 28s linear infinite; padding: 6px 0;
}
.typo-inner > span {
  font-family: var(--ff-display);
  font-size: clamp(64px,8.5vw,108px);
  line-height: 1; color: var(--ink); flex-shrink: 0;
}
.typo-inner .tsep { color: var(--orange); font-size: clamp(48px,6vw,80px); }

/* ── ════════════════════════════════════════════════
   TIMELINE
═══════════════════════════════════════════════ */
.timeline-section { background: var(--ink); padding: var(--py) var(--px); }
.tl-header { max-width: 1440px; margin: 0 auto 60px; }
.tl-layout {
  display: grid; grid-template-columns: 1fr 48px 1fr;
  max-width: 1440px; margin: 0 auto; align-items: stretch;
}
.tl-steps { display: flex; flex-direction: column; }
.tl-step {
  display: flex; align-items: center; gap: 14px;
  padding: 22px 0; padding-right: 28px;
  border-bottom: 1px solid rgba(245,240,232,0.05);
  transition: all 0.3s; position: relative;
}
.tl-step:last-child { border-bottom: none; }
.tl-num {
  font-family: var(--ff-mono); font-size: 11px;
  letter-spacing: 0.1em; color: rgba(245,240,232,0.22);
  min-width: 30px; flex-shrink: 0; transition: color 0.3s;
}
.tl-name {
  font-family: var(--ff-sans); font-size: 15px; font-weight: 500;
  color: rgba(245,240,232,0.28); transition: color 0.3s, transform 0.35s;
  text-wrap: pretty;
}
.tl-step.active .tl-num  { color: var(--orange); }
.tl-step.active .tl-name { color: var(--cream); font-weight: 700; }
.tl-step:not(.active):hover .tl-name { color: rgba(245,240,232,0.65); transform: translateX(6px); }
.tl-line-wrap { display: flex; justify-content: center; position: relative; }
.tl-line-track { position: absolute; top: 0; bottom: 0; width: 1px; background: rgba(245,240,232,0.07); }
.tl-line-fill {
  position: absolute; top: 0; width: 2px;
  background: var(--orange); height: 0%;
  transition: height 0.55s cubic-bezier(0.22,1,0.36,1);
  box-shadow: 0 0 12px rgba(212,83,15,0.5);
}
.tl-detail { padding-left: 48px; position: sticky; top: calc(var(--nav-h) + 24px); align-self: start; }
.detail-card {
  background: rgba(245,240,232,0.04);
  border: 1px solid rgba(245,240,232,0.08);
  border-radius: 12px; padding: 32px;
}
@keyframes fadeSlide { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }
.detail-card { animation: fadeSlide 0.4s ease; }
.dc-num { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--orange); display: block; margin-bottom: 12px; }
.dc-title { font-family: var(--ff-display); font-size: 36px; color: var(--cream); line-height: 1; margin-bottom: 14px; }
.dc-body { font-size: 15px; line-height: 1.75; color: rgba(245,240,232,0.58); margin-bottom: 22px; text-wrap: pretty; }
.dc-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.dc-tag { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.07em; text-transform: uppercase; padding: 5px 10px; border-radius: 4px; background: rgba(212,83,15,0.12); color: var(--orange); border: 1px solid rgba(212,83,15,0.2); }

/* ── ════════════════════════════════════════════════
   PLANS — 3D Tilt
═══════════════════════════════════════════════ */
.plans-section { background: var(--cream); color: var(--ink); padding: var(--py) var(--px); }
.plans-header { max-width: 1440px; margin: 0 auto 52px; }
.plans-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; max-width: 1440px; margin: 0 auto; align-items: stretch; }
.plan-card {
  border-radius: 14px; padding: 36px 28px;
  display: flex; flex-direction: column; gap: 18px;
  position: relative;
  transform-style: preserve-3d;
  will-change: transform;
  transition: box-shadow 0.4s;
}
.plan-card:hover { box-shadow: 0 32px 72px rgba(0,0,0,0.18); }
.plan-card.light { background: rgba(15,14,12,0.04); border: 1.5px solid rgba(15,14,12,0.1); }
.plan-card.dark  { background: var(--ink); border: 1.5px solid rgba(245,240,232,0.07); color: var(--cream); }
.plan-badge-top { position: absolute; top: 20px; right: 20px; font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.07em; text-transform: uppercase; padding: 5px 10px; background: var(--orange); color: var(--cream); border-radius: 4px; }
.plan-name { font-family: var(--ff-display); font-size: 34px; line-height: 1; }
.plan-price { display: flex; flex-direction: column; gap: 3px; }
.plan-price-main { font-family: var(--ff-display); font-size: 36px; line-height: 1; color: var(--orange); }
.plan-price-sub { font-family: var(--ff-mono); font-size: 11px; opacity: 0.38; letter-spacing: 0.06em; text-transform: uppercase; }
.plan-price-monthly { font-family: var(--ff-mono); font-size: 12px; opacity: 0.5; }
.plan-divider { height: 1px; background: currentColor; opacity: 0.1; }
.plan-feats { display: flex; flex-direction: column; gap: 10px; flex: 1; }
.plan-feats li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.4; }
.plan-feats li::before { content: '→'; color: var(--orange); flex-shrink: 0; font-size: 12px; margin-top: 1px; }
.plan-cta { width: 100%; justify-content: center; padding: 14px; font-size: 14px; }
.plans-note { max-width: 1440px; margin: 36px auto 0; text-align: center; font-size: 16px; color: rgba(15,14,12,0.65); padding: 20px; border-top: 1px solid rgba(15,14,12,0.1); }
.plans-note strong { color: var(--orange); font-weight: 700; }

/* ── ════════════════════════════════════════════════
   WHY — Color invert on hover
═══════════════════════════════════════════════ */
.why-section { background: var(--ink2); color: var(--cream); padding: var(--py) var(--px); }
.why-header { max-width: 1440px; margin: 0 auto 52px; }
.why-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; max-width: 1440px; margin: 0 auto; }
.why-card {
  padding: 40px 32px; border-radius: 12px;
  border: 1.5px solid rgba(245,240,232,0.07);
  background: rgba(245,240,232,0.025);
  transition: background 0.38s, border-color 0.38s, color 0.38s;
}
.why-card:hover { background: var(--cream); border-color: var(--cream); color: var(--ink); }
.why-icon { font-size: 34px; margin-bottom: 20px; display: block; }
.why-title { font-size: 19px; font-weight: 700; line-height: 1.3; margin-bottom: 12px; transition: color 0.38s; }
.why-body { font-size: 14px; line-height: 1.75; color: rgba(245,240,232,0.52); transition: color 0.38s; text-wrap: pretty; }
.why-card:hover .why-body { color: rgba(15,14,12,0.62); }

/* ── ════════════════════════════════════════════════
   PORTFOLIO
═══════════════════════════════════════════════ */
.portfolio-section { background: var(--cream); color: var(--ink); padding: var(--py) var(--px); }
.portfolio-header { max-width: 1440px; margin: 0 auto 44px; }
.portfolio-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 1440px; margin: 0 auto; }
.port-card { border-radius: 16px; overflow: hidden; min-height: 320px; display: flex; flex-direction: column; justify-content: space-between; padding: 44px; transition: transform 0.4s ease; }
.port-card:hover { transform: translateY(-5px); }
.port-card.existing { background: var(--ink); color: var(--cream); }
.port-card.empty    { background: #1D3A2A; color: var(--cream); border: 2px dashed rgba(245,240,232,0.12); }
.port-plan { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--orange); display: block; margin-bottom: 10px; }
.port-name { font-family: var(--ff-display); font-size: 52px; line-height: 0.95; margin-bottom: 8px; }
.port-cat  { font-size: 14px; color: rgba(245,240,232,0.4); }
.port-link { font-family: var(--ff-mono); font-size: 12px; color: var(--orange); letter-spacing: 0.05em; transition: opacity 0.2s; }
.port-link:hover { opacity: 0.7; text-decoration: underline; }
.port-empty-label { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(245,240,232,0.32); display: block; margin-bottom: 12px; }
.port-empty-title { font-family: var(--ff-display); font-size: 52px; line-height: 0.95; color: rgba(245,240,232,0.7); }
.port-empty-sub { font-size: 14px; color: rgba(245,240,232,0.35); }

/* ── ════════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════ */
.contact-section { background: var(--ink); color: var(--cream); padding: var(--py) var(--px); position: relative; overflow: hidden; }
.contact-bg-word {
  position: absolute; font-family: var(--ff-display);
  font-size: clamp(160px,22vw,340px);
  color: rgba(245,240,232,0.018);
  right: clamp(-60px,-3vw,-100px); top: 50%; transform: translateY(-50%);
  pointer-events: none; user-select: none;
}
.contact-inner { max-width: 920px; position: relative; z-index: 2; }
.contact-title { margin-bottom: 18px; }
.contact-sub { font-size: 17px; line-height: 1.65; color: rgba(245,240,232,0.52); max-width: 480px; margin-bottom: 48px; text-wrap: pretty; }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-field { display: flex; flex-direction: column; gap: 7px; }
.form-field.full { grid-column: 1 / -1; }
.form-field label { font-family: var(--ff-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(245,240,232,0.32); }
.form-field input,.form-field select,.form-field textarea {
  background: rgba(245,240,232,0.05);
  border: 1.5px solid rgba(245,240,232,0.1);
  border-radius: 8px; padding: 13px 14px;
  font-family: var(--ff-sans); font-size: 15px;
  color: var(--cream); outline: none;
  transition: border-color 0.3s, background 0.3s;
  width: 100%; -webkit-appearance: none;
}
.form-field input::placeholder,.form-field textarea::placeholder { color: rgba(245,240,232,0.18); }
.form-field input:focus,.form-field select:focus,.form-field textarea:focus { border-color: var(--orange); background: rgba(245,240,232,0.07); }
.form-field input.err,.form-field select.err,.form-field textarea.err { border-color: #e05353; }
.form-field select option { background: #1a1917; color: var(--cream); }
.form-field textarea { resize: vertical; min-height: 108px; }
.form-actions { grid-column: 1 / -1; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 4px; }
.btn-wsp {
  display: inline-flex; align-items: center; gap: 9px;
  background: var(--wsp); color: white;
  font-family: var(--ff-sans); font-size: 15px; font-weight: 600;
  padding: 14px 22px; border-radius: 5px;
  transition: background 0.3s, box-shadow 0.3s;
}
.btn-wsp:hover { background: #1ebc59; box-shadow: 0 8px 24px rgba(37,211,102,0.28); }
.form-success { display: none; border: 1.5px solid rgba(34,197,94,0.25); border-radius: 12px; background: rgba(34,197,94,0.04); padding: 52px 40px; text-align: center; grid-column: 1 / -1; }
.form-success.visible { display: block; }
.success-icon { font-size: 52px; display: block; margin-bottom: 14px; }
.success-title { font-family: var(--ff-display); font-size: 40px; color: var(--cream); margin-bottom: 10px; }
.success-sub { font-size: 16px; color: rgba(245,240,232,0.52); line-height: 1.6; }

/* ── Footer ──────────────────────────────────────── */
.footer { background: var(--ink3); color: var(--cream); padding: clamp(40px,5vh,60px) var(--px); border-top: 1px solid rgba(245,240,232,0.05); }
.footer-inner { display: flex; justify-content: space-between; align-items: flex-start; gap: 40px; max-width: 1440px; margin: 0 auto; flex-wrap: wrap; }
.footer-logo { font-family: var(--ff-serif); font-size: 22px; font-weight: 700; letter-spacing: -0.02em; color: var(--cream); display: block; margin-bottom: 12px; }
.footer-logo .dot { color: var(--orange); }
.footer-meta { font-family: var(--ff-mono); font-size: 11px; letter-spacing: 0.04em; color: rgba(245,240,232,0.26); line-height: 1.9; }
.footer-right { display: flex; flex-direction: column; gap: 6px; text-align: right; }
.footer-partner { font-family: var(--ff-mono); font-size: 12px; color: rgba(245,240,232,0.32); }
.footer-partner strong { color: rgba(245,240,232,0.62); }

/* ── Floating WhatsApp ───────────────────────────── */
.wsp-float { position: fixed; bottom: 28px; right: 28px; z-index: 800; display: flex; align-items: center; gap: 12px; }
.wsp-tooltip { background: var(--ink2); border: 1px solid rgba(245,240,232,0.1); border-radius: 10px; padding: 12px 16px; font-size: 13px; line-height: 1.45; color: var(--cream); width: 180px; pointer-events: none; opacity: 0; transform: translateX(8px); transition: opacity 0.3s, transform 0.3s; }
.wsp-float:hover .wsp-tooltip { opacity: 1; transform: translateX(0); }
.wsp-tooltip strong { display: block; margin-bottom: 4px; font-size: 14px; }
.wsp-tt-line { font-family: var(--ff-mono); font-size: 10px; color: rgba(245,240,232,0.36); letter-spacing: 0.05em; display: block; }
.wsp-btn { width: 56px; height: 56px; background: var(--wsp); border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 28px rgba(37,211,102,0.4); transition: transform 0.3s, box-shadow 0.3s; position: relative; flex-shrink: 0; }
.wsp-btn:hover { transform: scale(1.1); box-shadow: 0 8px 36px rgba(37,211,102,0.5); }
.wsp-pulse { position: absolute; top: -1px; right: -1px; width: 15px; height: 15px; background: var(--green); border-radius: 50%; border: 2.5px solid var(--ink3); animation: pulse 2.2s ease-in-out infinite; }

/* ── ════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════ */
@media (max-width: 768px) {
  .cursor-dot, .cursor-trail { display: none; }
  *, a, button, input, select, textarea { cursor: auto !important; }

  /* NAV mobile */
  .nav { height: 70px; }
  .nav-inner { gap: 12px; padding: 0 16px; }
  .nav-logo-img { height: 54px !important; width: auto !important; }
  .nav-links { display: none; }
  .btn-nav { padding: 8px 14px; font-size: 11px; white-space: nowrap; }

  /* STATS BAND mobile — 2x2 grid */
  .stats-band {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto auto;
    padding: 40px 20px;
    gap: 0;
  }
  .stat-item { padding: 20px 16px; }
  .stat-divider:nth-child(2) { display: none; }
  .stat-divider:nth-child(4) { grid-column: 1/-1; height: 1px; width: 100%; margin: 0; }
  .stat-divider:nth-child(6) { display: none; }
  .stat-num { font-size: clamp(18px,5vw,26px) !important; }
  .stat-label { font-size: 12px !important; max-width: 100%; }
  .mirror-inner { grid-template-columns: 1fr; gap: 40px; }
  .mirror-right { position: static; }
  .tl-layout { grid-template-columns: 1fr; }
  .tl-line-wrap { display: none; }
  .tl-detail { padding-left: 0; padding-top: 24px; position: static; }
  .plans-grid { grid-template-columns: 1fr; max-width: 100%; }
  .why-grid, .portfolio-grid { grid-template-columns: 1fr; }
  .contact-form { grid-template-columns: 1fr; }
  .form-field.full { grid-column: 1; }
  .footer-inner { flex-direction: column; }
  .footer-right { text-align: left; }
  .h-layer-back { display: none; }
}
