/* ============================================================
   90 Seconds Homepage MVP — Static CSS
   Converted from React (parent-v26-modes-mvp-hybrid.jsx)
   ============================================================ */

/* ── Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap');

/* ── Reset ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'Lato', 'Inter', sans-serif; overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
img, video { display: block; }

/* ── Type scale variables ── */
:root {
  --t-hero:      clamp(44px, 6vw, 76px);
  --t-section:   clamp(32px, 4vw, 52px);
  --t-card:      clamp(22px, 2.5vw, 32px);
  --t-stat:      clamp(36px, 4vw, 56px);
  --t-watermark: clamp(80px, 14vw, 180px);
  --t-sub:       20px;
  --t-body:      16px;
  --t-small:     14px;
  --t-tiny:      12px;

  --w-normal:    400;
  --w-medium:    500;
  --w-semi:      600;
  --w-bold:      700;
  --w-xbold:     800;

  --ls-hero:    -0.04em;
  --ls-heading: -0.03em;
  --ls-body:     0.01em;
  --ls-label:    0.08em;

  --lh-hero:     1.05;
  --lh-section:  1.15;
  --lh-card:     1.3;
  --lh-body:     1.6;

  /* Dark palette */
  --d-bg:   #06060a;
  --d-bg2:  #0c0c12;
  --d-tx:   #ffffff;
  --d-ts:   #a0a0a8;
  --d-tf:   #606068;
  --d-brd:  #1a1a22;

  /* Light palette */
  --l-bg:   #FFFEFC;
  --l-bg2:  #F5F3ED;
  --l-bg3:  #EFEDE7;
  --l-tx:   #111118;
  --l-ts:   rgba(0,0,0,0.55);
  --l-tf:   rgba(0,0,0,0.55);
  --l-bd:   rgba(0,0,0,0.08);
}

/* ── Keyframes ── */
@keyframes gradient-shift {
  0%, 100% { background-position: 0% 50%; }
  50%       { background-position: 100% 50%; }
}
@keyframes scrollLogos {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@keyframes hp-blink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0; }
}
@keyframes hp-waveform {
  0%, 100% { transform: scaleY(1); }
  50%       { transform: scaleY(0.2); }
}
@keyframes hp-progress {
  0%   { width: 0%; }
  70%  { width: 72%; }
  100% { width: 72%; }
}
@keyframes hp-spin {
  to { transform: rotate(360deg); }
}
@keyframes hp-fade-up {
  from { opacity: 0; transform: translateY(30px); filter: blur(8px); }
  to   { opacity: 1; transform: translateY(0);    filter: blur(0); }
}

/* ── Fade-in on scroll ── */
.hp-fade { opacity: 0; transform: translateY(30px); filter: blur(8px); transition: opacity 0.7s cubic-bezier(0.21,0.47,0.32,0.98), transform 0.7s cubic-bezier(0.21,0.47,0.32,0.98), filter 0.7s cubic-bezier(0.21,0.47,0.32,0.98); }
.hp-fade.visible { opacity: 1; transform: translateY(0); filter: blur(0); }
.hp-fade.delay-1 { transition-delay: 0.1s; }
.hp-fade.delay-2 { transition-delay: 0.2s; }
.hp-fade.delay-3 { transition-delay: 0.3s; }
.hp-fade.delay-4 { transition-delay: 0.4s; }
.hp-fade.delay-5 { transition-delay: 0.5s; }

/* ── Section layout ── */
.hp-section    { padding: 120px 48px; }
.hp-section-sm { padding: 60px 48px; }
.hp-section-lg { padding: 140px 48px; }
.hp-inner      { max-width: 1400px; margin: 0 auto; }

/* ── Grids ── */
.hp-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.hp-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.hp-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }

/* ── Gradient text ── */
.hp-gradient-text {
  background: linear-gradient(135deg, #fff 0%, #e0d0ff 25%, #c8dcff 50%, #e0d0ff 75%, #fff 100%);
  background-size: 300% 300%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradient-shift 6s ease infinite;
}

/* ── Watermark label ── */
.hp-watermark {
  font-size: var(--t-watermark);
  font-weight: var(--w-bold);
  line-height: 0.85;
  letter-spacing: var(--ls-hero);
  background-image: linear-gradient(180deg, rgba(0,0,0,0.12) 0%, rgba(0,0,0,0.03) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  user-select: none;
  pointer-events: none;
}

/* ── Pill badge ── */
.hp-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 20px;
  font-size: var(--t-tiny);
  font-weight: var(--w-semi);
  letter-spacing: var(--ls-label);
  text-transform: uppercase;
}

/* ── Glass card (light) ── */
.hp-glass-card {
  background: #FFFEFC;
  border: 1px solid rgba(0,0,0,0.04);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 2px 4px rgba(0,0,0,0.02), 0 8px 24px rgba(0,0,0,0.04), 0 24px 64px rgba(0,0,0,0.06);
  transition: all 0.5s cubic-bezier(0.21,0.47,0.32,0.98);
}
.hp-glass-card:hover {
  border-color: rgba(0,0,0,0.08);
  box-shadow: 0 4px 8px rgba(0,0,0,0.03), 0 16px 40px rgba(0,0,0,0.06), 0 32px 80px rgba(0,0,0,0.08);
  transform: translateY(-4px);
}

/* ── Primary button (dark) ── */
.hp-btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 16px 32px; border-radius: 50px;
  background: var(--l-tx); color: #fff;
  font-size: var(--t-body); font-weight: var(--w-semi);
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
  transition: all 0.3s ease;
}
.hp-btn-primary:hover { transform: translateY(-2px); box-shadow: 0 4px 20px rgba(0,0,0,0.18); color: #fff;}
.hp-btn-primary:hover .btn-arrow { transform: translateX(4px); }

/* ── Glass button (dark bg) ── */
.hp-btn-glass {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px; border-radius: 50px;
  background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.12);
  color: #fff; font-size: var(--t-small); font-weight: var(--w-semi);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  transition: all 0.3s ease;
}
.hp-btn-glass:hover { background: rgba(255,255,255,0.18); border-color: rgba(255,255,255,0.3); transform: translateY(-1px); color: #fff}
.hp-btn-glass:hover .btn-arrow { transform: translateX(4px); }

/* ── Outline button (light) ── */
.hp-btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px; border-radius: 50px;
  border: 1px solid rgba(0,0,0,0.12); color: var(--l-tx);
  font-size: var(--t-small); font-weight: var(--w-semi);
  transition: all 0.2s ease;
}
.hp-btn-outline:hover { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.15); transform: translateY(-1px); }

/* ── Arrow icon ── */
.btn-arrow { display: inline-block; transition: transform 0.3s cubic-bezier(0.16,1,0.3,1); }

/* ── Logo carousel ── */
.hp-logo-track {
  display: flex;
  animation: scrollLogos 30s linear infinite;
  width: max-content;
}
.hp-logo-track:hover { animation-play-state: paused; }
.hp-logo-item {
  padding: 0 32px;
  display: flex; align-items: center; justify-content: center;
  height: 48px; flex-shrink: 0;
}
.hp-logo-item img { height: 24px; opacity: 0.4; filter: grayscale(1); }

/* ── SVG icon helpers ── */
.hp-icon { display: inline-block; vertical-align: middle; flex-shrink: 0; }

/* ============================================================
   SECTION 1 — HERO (light: #F5F3ED)
   ============================================================ */
.hp-hero {
  background: var(--l-bg2);
  position: relative;
  overflow: hidden;
  padding: 120px 48px 0;
}
.hp-hero-inner { max-width: 1438px; margin: 0 auto; width: 100%; position: relative; z-index: 1; padding: 0 24px; }

.hp-hero-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
  opacity: 0.2;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.hp-hero-split.ready { opacity: 1; transform: translateY(0); }

.hp-hero-h1 {
  font-size: var(--t-hero);
  font-weight: var(--w-xbold);
  line-height: var(--lh-hero);
  letter-spacing: var(--ls-hero);
  margin-bottom: 24px;
}
.hp-hero-h1 .line1 { display: block; color: var(--l-tx); }
.hp-hero-h1 .line2 {
  display: block;
  background-image: linear-gradient(to right, rgba(0,0,0,0.85), rgba(0,0,0,0.35));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hp-hero-sub { font-size: var(--t-sub); color: var(--l-ts); max-width: 460px; line-height: var(--lh-body); margin-bottom: 36px; }

.hp-hero-stats { display: flex; gap: 24px; }
.hp-hero-stat-val { font-size: 22px; font-weight: var(--w-bold); color: var(--l-tx); letter-spacing: -0.02em; }
.hp-hero-stat-label { font-size: 10px; color: var(--l-tf); letter-spacing: 0.05em; text-transform: uppercase; margin-top: 2px; }

/* Video mosaic */
.hp-hero-mosaic-wrap { position: relative; perspective: 1200px; }
.hp-hero-mosaic-deco {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%) scale(1.3);
  width: 110%; opacity: 0.18; filter: blur(60px);
  pointer-events: none; z-index: 0;
}
.hp-hero-mosaic {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 10px;
  height: 420px;
  transition: transform 0.15s ease-out;
  transform-style: preserve-3d;
  position: relative; z-index: 1;
}
.hp-mosaic-main { grid-row: 1 / 3; grid-column: 1 / 2; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,0.06); position: relative; }
.hp-mosaic-cell { border-radius: 14px; overflow: hidden; box-shadow: 0 2px 12px rgba(0,0,0,0.05); position: relative; }
.hp-mosaic-main video,
.hp-mosaic-cell video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; display: block; transform: scale(1.35); }

/* Mode cards */
.hp-hero-modes {
  margin-top: 100px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  opacity: 0.2;
  transform: translateY(12px);
  transition: opacity 0.5s ease 0.15s, transform 0.5s ease 0.15s;
}
.hp-hero-modes.ready { opacity: 1; transform: translateY(0); }

.hp-mode-card {
  display: block;
  padding: 24px;
  border-radius: 16px;
  background: #FFFEFC;
  border: 1.5px solid rgba(0,0,0,0.06);
  box-shadow: 0 2px 4px rgba(0,0,0,0.02), 0 8px 24px rgba(0,0,0,0.04);
  transition: all 0.4s cubic-bezier(0.16,1,0.3,1);
  cursor: pointer;
}
.hp-mode-card:hover { transform: translateY(-4px); }

.hp-mode-icon-wrap {
  width: 40px; height: 40px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.3s;
}
.hp-mode-tagline { font-size: 10px; font-weight: var(--w-semi); letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.7; transition: opacity 0.3s; }
.hp-mode-card:hover .hp-mode-tagline { opacity: 1; }
.hp-mode-title { font-size: clamp(20px, 2vw, 24px); font-weight: var(--w-xbold); line-height: 1.2; letter-spacing: -0.02em; color: var(--l-tx); margin-bottom: 8px; }
.hp-mode-desc { font-size: var(--t-small); color: var(--l-tf); line-height: 1.5; margin-bottom: 14px; }
.hp-mode-cta { font-size: var(--t-small); font-weight: var(--w-semi); display: inline-flex; align-items: center; gap: 6px; opacity: 0.8; transition: opacity 0.3s; }
.hp-mode-card:hover .hp-mode-cta { opacity: 1; }
.hp-mode-card:hover .hp-mode-arrow { transform: translateX(4px); }
.hp-mode-arrow { transition: transform 0.3s cubic-bezier(0.16,1,0.3,1); }

/* Hero logo carousel */
.hp-hero-logos { margin-top: 60px; padding-bottom: 50px; opacity: 0.2; transition: opacity 0.5s ease 0.3s; }
.hp-hero-logos.ready { opacity: 1; }
.hp-hero-logos-wrap { overflow: hidden; position: relative; }
.hp-hero-logos-fade-l { position: absolute; left: 0; top: 0; bottom: 0; width: 100px; background: linear-gradient(to right, #F5F3ED, transparent); z-index: 2; pointer-events: none; }
.hp-hero-logos-fade-r { position: absolute; right: 0; top: 0; bottom: 0; width: 100px; background: linear-gradient(to left, #F5F3ED, transparent); z-index: 2; pointer-events: none; }

/* ============================================================
   SECTION 2 — PRODUCT BANNERS (light: #FFFEFC)
   ============================================================ */
.hp-products { background: var(--l-bg); }
.hp-products-list { display: flex; flex-direction: column; gap: 24px; }

.hp-product-banner {
  display: block;
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  min-height: 480px;
  cursor: pointer;
  transition: transform 0.5s ease, box-shadow 0.5s ease;
}
.hp-product-banner:hover { transform: translateY(-4px); box-shadow: 0 20px 60px rgba(0,0,0,0.15); }
.hp-product-banner:hover .hp-prod-bg { transform: scale(1.03); }
.hp-product-banner:hover .hp-banner-arrow { transform: translateX(4px); }

.hp-prod-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.7s ease;
}
.hp-prod-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.55) 45%, rgba(0,0,0,0.15) 100%); }
.hp-prod-overlay2 { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.4) 0%, transparent 40%); }
.hp-prod-accent { position: absolute; top: 0; left: 10%; right: 10%; height: 1px; z-index: 2; }
.hp-prod-content {
  position: relative; z-index: 1;
  padding: 56px 60px;
  min-height: 480px;
  display: flex; flex-direction: column; justify-content: center;
  max-width: 560px;
}
.hp-prod-label { font-size: var(--t-tiny); font-weight: var(--w-semi); letter-spacing: var(--ls-label); text-transform: uppercase; color: rgba(255,255,255,0.4); margin-bottom: 24px; }
.hp-prod-title { font-size: var(--t-section); font-weight: var(--w-bold); letter-spacing: var(--ls-heading); line-height: var(--lh-section); color: #fff; margin-bottom: 16px; white-space: pre-line; }
.hp-prod-desc { font-size: var(--t-body); color: rgba(255,255,255,0.5); line-height: var(--lh-body); margin-bottom: 32px; max-width: 420px; }
.hp-prod-stats { display: flex; gap: 40px; margin-bottom: 36px; }
.hp-prod-stat-val { font-size: var(--t-card); font-weight: var(--w-bold); color: #fff; letter-spacing: var(--ls-heading); line-height: var(--lh-hero); }
.hp-prod-stat-label { font-size: 10px; color: rgba(255,255,255,0.3); letter-spacing: var(--ls-label); text-transform: uppercase; margin-top: 4px; }

/* Self-serve catalog section */
.hp-catalog-section { text-align: center; padding: 100px 0 40px; }
.hp-catalog-title { font-size: var(--t-section); font-weight: var(--w-xbold); letter-spacing: var(--ls-heading); margin-bottom: 16px; line-height: var(--lh-section); color: var(--l-tx); }
.hp-catalog-desc { font-size: var(--t-body); color: var(--l-ts); line-height: var(--lh-body); max-width: 500px; margin: 0 auto 32px; }
.hp-catalog-stats { display: flex; gap: 48px; justify-content: center; }
.hp-catalog-stat-val { font-size: var(--t-card); font-weight: var(--w-bold); color: var(--l-tx); letter-spacing: var(--ls-heading); line-height: var(--lh-hero); }
.hp-catalog-stat-label { font-size: 10px; color: var(--l-tf); letter-spacing: var(--ls-label); text-transform: uppercase; margin-top: 4px; }

/* Card stack */
.hp-card-stack { position: relative; width: 340px; height: 440px; margin: 0 auto 48px; }
.hp-stack-card {
  position: absolute; inset: 0;
  border-radius: 16px; overflow: hidden;
  transition: all 0.7s cubic-bezier(0.33,1,0.68,1);
}
.hp-stack-card img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hp-stack-card-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.75), rgba(0,0,0,0.2) 50%, transparent); }
.hp-stack-card-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 20px; }
.hp-stack-card-cat { display: inline-block; padding: 4px 10px; border-radius: 20px; font-size: 9px; font-weight: var(--w-semi); letter-spacing: var(--ls-label); color: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.15); background: rgba(0,0,0,0.3); backdrop-filter: blur(8px); margin-bottom: 12px; }
.hp-stack-card-name { font-size: var(--t-sub); font-weight: var(--w-semi); color: #fff; letter-spacing: var(--ls-heading); line-height: var(--lh-section); margin-bottom: 6px; }
.hp-stack-card-price { font-size: var(--t-body); font-weight: var(--w-semi); color: rgba(255,255,255,0.7); }
.hp-stack-dots { position: absolute; bottom: -32px; left: 50%; transform: translateX(-50%); display: flex; gap: 6px; }
.hp-stack-dot { height: 4px; border-radius: 2px; background: rgba(0,0,0,0.1); transition: all 0.5s ease; width: 6px; }
.hp-stack-dot.active { width: 16px; background: rgba(0,0,0,0.4); }

/* ============================================================
   SECTION 3 — SPLIT SECTION (light: #F5F3ED)
   ============================================================ */
.hp-split { background: var(--l-bg2); }

/* Editorial spread (dark) */
.hp-editorial {
  display: grid; grid-template-columns: 1fr 1fr;
  border-radius: 28px; overflow: hidden;
  background: #09090f; position: relative;
}
.hp-editorial-seam {
  position: absolute; top: 0; bottom: 0; left: 50%;
  transform: translateX(-50%);
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,0.06) 20%, rgba(255,255,255,0.1) 50%, rgba(255,255,255,0.06) 80%, transparent);
  z-index: 2; pointer-events: none;
}
.hp-editorial-half {
  padding: 56px 56px 48px;
  position: relative;
}
.hp-editorial-bg-img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  opacity: 0.15; filter: grayscale(100%);
}
.hp-editorial-bg-grad1 { position: absolute; inset: 0; background: linear-gradient(135deg, #09090f 0%, transparent 40%, transparent 60%, #09090f 100%); }
.hp-editorial-bg-grad2 { position: absolute; inset: 0; background: linear-gradient(to top, #09090f, transparent 50%); }
.hp-editorial-bg-grad3 { position: absolute; inset: 0; background: linear-gradient(to bottom, #09090f, transparent 30%); }
.hp-editorial-content { position: relative; z-index: 1; }
.hp-editorial-icon-row { display: flex; align-items: center; gap: 12px; margin-bottom: 32px; }
.hp-editorial-icon { width: 36px; height: 36px; border-radius: 10px; display: flex; align-items: center; justify-content: center; }
.hp-editorial-title { font-size: var(--t-card); font-weight: var(--w-bold); color: #fff; letter-spacing: var(--ls-heading); line-height: var(--lh-section); margin-bottom: 12px; }
.hp-editorial-desc { font-size: var(--t-body); color: rgba(255,255,255,0.45); line-height: var(--lh-body); margin-bottom: 40px; max-width: 360px; }
.hp-editorial-list-item {
  padding: 16px 0;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: space-between;
}
.hp-editorial-list-item:first-child { border-top: 1px solid rgba(255,255,255,0.06); }
.hp-editorial-list-item span { font-size: var(--t-body); font-weight: var(--w-medium); color: rgba(255,255,255,0.7); letter-spacing: var(--ls-body); }
.hp-editorial-dot { width: 6px; height: 6px; border-radius: 50%; opacity: 0.5; }
.hp-editorial-stats { margin-top: 36px; display: flex; gap: 40px; }
.hp-editorial-stat-val { font-size: var(--t-card); font-weight: var(--w-bold); color: #fff; letter-spacing: var(--ls-heading); }
.hp-editorial-stat-label { font-size: var(--t-tiny); color: rgba(255,255,255,0.35); letter-spacing: var(--ls-label); text-transform: uppercase; margin-top: 4px; }
.hp-editorial-bottom {
  grid-column: 1 / -1; padding: 28px 56px;
  background: linear-gradient(90deg, rgba(78,219,160,0.04), rgba(255,255,255,0.02) 50%, rgba(201,160,255,0.04));
  border-top: 1px solid rgba(255,255,255,0.06);
  display: flex; align-items: center; justify-content: center; gap: 16px;
}
.hp-editorial-bottom-line { height: 1px; flex: 1; }
.hp-editorial-bottom-text { font-size: var(--t-small); font-weight: var(--w-semi); color: rgba(255,255,255,0.5); letter-spacing: var(--ls-label); text-transform: uppercase; white-space: nowrap; }

/* Cities grid */
.hp-city-card {
  border-radius: 20px; overflow: hidden; position: relative;
  min-height: 280px; display: block; cursor: pointer;
  transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.hp-city-card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(0,0,0,0.15); }
.hp-city-card:hover img { transform: scale(1.05); }
.hp-city-img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform 0.7s ease; }
.hp-city-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.25) 50%, rgba(0,0,0,0.05) 100%); }
.hp-city-region { position: absolute; top: 14px; left: 14px; font-size: 9px; font-weight: var(--w-semi); letter-spacing: var(--ls-label); color: rgba(255,255,255,0.6); background: rgba(0,0,0,0.4); backdrop-filter: blur(12px); padding: 4px 10px; border-radius: 20px; border: 1px solid rgba(255,255,255,0.1); }
.hp-city-info { position: absolute; bottom: 0; left: 0; right: 0; padding: 16px; }
.hp-city-name { font-size: var(--t-body); font-weight: var(--w-semi); color: #fff; display: block; letter-spacing: var(--ls-heading); margin-bottom: 4px; }
.hp-city-meta { font-size: var(--t-tiny); color: rgba(255,255,255,0.45); }

/* Stats row */
.hp-stats-row { display: grid; grid-template-columns: repeat(4, 1fr); }
.hp-stat-cell { padding: 40px 36px; }
.hp-stat-cell + .hp-stat-cell { border-left: 1px solid; }
.hp-stat-val-lg { font-size: var(--t-stat); font-weight: var(--w-semi); letter-spacing: var(--ls-heading); line-height: var(--lh-hero); }
.hp-stat-label { font-size: var(--t-small); font-weight: var(--w-medium); margin-top: 12px; letter-spacing: var(--ls-body); }

/* ============================================================
   SECTION 4 — AI SECTION (dark: #09090f)
   ============================================================ */
.hp-ai-section { background: #09090f; position: relative; overflow: hidden; }
.hp-ai-grid-bg {
  position: absolute; inset: 0; pointer-events: none; opacity: 0.02;
  background-image: linear-gradient(rgba(255,255,255,0.15) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.15) 1px, transparent 1px);
  background-size: 48px 48px;
}
.hp-ai-tools { display: flex; gap: 48px; align-items: stretch; }
.hp-ai-tool-list { flex: 0 0 320px; display: flex; flex-direction: column; gap: 4px; }
.hp-ai-tool-btn {
  padding: 16px 20px; border-radius: 12px; cursor: pointer;
  background: transparent; border: 1px solid transparent;
  transition: all 0.3s ease;
  display: flex; align-items: center; gap: 14px;
  text-align: left; width: 100%;
}
.hp-ai-tool-btn.active { background: rgba(255,255,255,0.05); border-color: rgba(255,255,255,0.08); }
.hp-ai-tool-bar { width: 4px; height: 32px; border-radius: 2px; flex-shrink: 0; background: rgba(255,255,255,0.06); transition: all 0.3s; }
.hp-ai-tool-btn.active .hp-ai-tool-bar { box-shadow: 0 0 8px currentColor; }
.hp-ai-tool-name { font-size: var(--t-body); font-weight: var(--w-semi); color: rgba(255,255,255,0.4); transition: color 0.3s; margin-bottom: 2px; }
.hp-ai-tool-btn.active .hp-ai-tool-name { color: #fff; }
.hp-ai-tool-desc { font-size: var(--t-small); color: rgba(255,255,255,0.15); transition: color 0.3s; line-height: var(--lh-body); }
.hp-ai-tool-btn.active .hp-ai-tool-desc { color: rgba(255,255,255,0.4); }

.hp-ai-viz-panel {
  flex: 1; border-radius: 16px;
  background: rgba(255,255,255,0.02); border: 1px solid rgba(255,255,255,0.06);
  position: relative; overflow: hidden; min-height: 380px;
}
.hp-ai-viz-corner-tl { position: absolute; top: 8px; left: 8px; width: 16px; height: 16px; border-top: 1px solid; border-left: 1px solid; border-radius: 4px 0 0 0; z-index: 2; transition: border-color 0.5s; }
.hp-ai-viz-corner-br { position: absolute; bottom: 8px; right: 8px; width: 16px; height: 16px; border-bottom: 1px solid; border-right: 1px solid; border-radius: 0 0 4px 0; z-index: 2; transition: border-color 0.5s; }
.hp-ai-viz-content { position: absolute; inset: 24px; }

/* AI viz panels */
.hp-ai-viz { position: absolute; inset: 0; display: flex; flex-direction: column; gap: 16px; opacity: 0; pointer-events: none; transition: opacity 0.45s ease; }
.hp-ai-viz.active { opacity: 1; pointer-events: auto; }

/* Mobile AI carousel */
.hp-ai-mobile { display: none; }
.hp-ai-desktop { display: flex; }

/* Result stats */
.hp-ai-result-stats { display: grid; grid-template-columns: repeat(4, 1fr); }
.hp-ai-result-stat { padding: 36px 32px; text-align: center; }
.hp-ai-result-stat + .hp-ai-result-stat { border-left: 1px solid rgba(255,255,255,0.06); }
.hp-ai-result-val { font-size: var(--t-stat); font-weight: var(--w-bold); letter-spacing: var(--ls-heading); line-height: var(--lh-hero); color: #fff; }
.hp-ai-result-label { font-size: var(--t-tiny); font-weight: var(--w-medium); color: rgba(255,255,255,0.3); margin-top: 10px; letter-spacing: var(--ls-label); text-transform: uppercase; }

/* ============================================================
   SECTION 5 — TRUSTED BY (light: #FFFEFC)
   ============================================================ */
.hp-trusted { background: var(--l-bg); overflow: hidden; }
.hp-trusted-logos-fade-l { position: absolute; top: 0; left: 0; bottom: 0; width: 80px; background: linear-gradient(to right, var(--l-bg), transparent); z-index: 2; pointer-events: none; }
.hp-trusted-logos-fade-r { position: absolute; top: 0; right: 0; bottom: 0; width: 80px; background: linear-gradient(to left, var(--l-bg), transparent); z-index: 2; pointer-events: none; }

/* ============================================================
   SECTION 6 — TEAMS (light: #FFFEFC)
   ============================================================ */
.hp-teams { background: var(--l-bg); }
.hp-team-card {
  position: relative; display: block;
  padding: 40px 36px;
  border-radius: 20px;
  background: #FFFEFC;
  border: 1px solid rgba(0,0,0,0.04);
  box-shadow: 0 2px 4px rgba(0,0,0,0.02), 0 8px 24px rgba(0,0,0,0.04);
  transition: all 0.4s cubic-bezier(0.16,1,0.3,1);
  cursor: pointer;
  overflow: hidden;
}
.hp-team-card:hover { transform: translateY(-4px); box-shadow: 0 4px 8px rgba(0,0,0,0.03), 0 16px 40px rgba(0,0,0,0.06), 0 32px 80px rgba(0,0,0,0.08); }
.hp-team-card:hover .seg-arrow { transform: translateX(4px); }
.seg-arrow { transition: transform 0.3s cubic-bezier(0.16,1,0.3,1); display: inline-block; }
.hp-team-card-bg { position: absolute; inset: 0; border-radius: 20px; pointer-events: none; }
.hp-team-card-title { font-size: var(--t-card); font-weight: var(--w-bold); color: var(--l-tx); margin-bottom: 12px; letter-spacing: var(--ls-heading); position: relative; }
.hp-team-card-desc { font-size: var(--t-body); color: var(--l-ts); line-height: var(--lh-body); margin-bottom: 24px; flex: 1; position: relative; }
.hp-team-card-cta { font-size: var(--t-body); font-weight: var(--w-semi); display: inline-flex; align-items: center; gap: 6px; position: relative; }

/* ============================================================
   SECTION 7 — CTA (light: #F5F3ED)
   ============================================================ */
.hp-cta-section { background: var(--l-bg2); position: relative; overflow: hidden; }
.hp-cta-image-wrap {
  position: relative; border-radius: 24px; overflow: hidden; aspect-ratio: 16/9;
  opacity: 0; transform: translateY(30px);
  transition: opacity 0.8s cubic-bezier(0.21,0.47,0.32,0.98), transform 0.8s cubic-bezier(0.21,0.47,0.32,0.98);
}
.hp-cta-image-wrap.visible { opacity: 1; transform: translateY(0); }
.hp-cta-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(1.15) brightness(0.95); }
.hp-cta-overlay1 { position: absolute; inset: 0; background: linear-gradient(to top, rgba(6,6,10,0.9) 0%, rgba(6,6,10,0.5) 40%, rgba(6,6,10,0.25) 100%); }
.hp-cta-overlay2 { position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(6,6,10,0.35) 0%, transparent 50%); }
.hp-cta-overlay3 { position: absolute; inset: 0; background: rgba(6,6,10,0.15); }
.hp-cta-ring { position: absolute; inset: 0; border-radius: 24px; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08); }
.hp-cta-bracket-tl { position: absolute; top: 16px; left: 16px; width: 32px; height: 32px; border-top: 1px solid rgba(255,255,255,0.12); border-left: 1px solid rgba(255,255,255,0.12); border-radius: 8px 0 0 0; }
.hp-cta-bracket-tr { position: absolute; top: 16px; right: 16px; width: 32px; height: 32px; border-top: 1px solid rgba(255,255,255,0.12); border-right: 1px solid rgba(255,255,255,0.12); border-radius: 0 8px 0 0; }
.hp-cta-text {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  z-index: 1; padding: 40px 24px; text-align: center;
}
.hp-cta-h2 { font-size: var(--t-hero); font-weight: var(--w-bold); line-height: var(--lh-hero); letter-spacing: var(--ls-hero); color: #fff; margin-bottom: 24px; text-shadow: 0 0 60px rgba(0,0,0,0.6); }
.hp-cta-h2 span { background: linear-gradient(to right, rgba(255,255,255,0.8), rgba(255,255,255,0.3)); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.hp-cta-sub { font-size: var(--t-sub); color: rgba(255,255,255,0.55); max-width: 550px; margin: 0 auto 40px; line-height: var(--lh-body); }

/* CTA white button */
.hp-btn-white {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 18px 36px; border-radius: 999px;
  background: #FFFEFC; color: #09090f;
  font-size: var(--t-body); font-weight: var(--w-semi);
  box-shadow: 0 0 30px rgba(255,255,255,0.15);
  transition: all 0.3s ease;
}
.hp-btn-white:hover { box-shadow: 0 0 40px rgba(255,255,255,0.25); transform: translateY(-1px); }
.hp-btn-white:hover .btn-arrow { transform: translateX(4px); }

/* CTA cards overlapping image */
.hp-cta-cards-wrap { position: relative; margin-top: -64px; z-index: 2; padding: 0 32px; }
.hp-cta-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.hp-cta-card {
  padding: 24px; border-radius: 16px;
  background: rgba(6,6,10,0.7); backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 8px 32px rgba(0,0,0,0.2);
}
.hp-cta-card-icon { width: 32px; height: 32px; border-radius: 8px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.08); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.4); }
.hp-cta-card-statement { font-size: var(--t-body); font-weight: var(--w-semi); color: #fff; margin-bottom: 6px; letter-spacing: var(--ls-heading); }
.hp-cta-card-desc { font-size: var(--t-small); line-height: var(--lh-body); color: rgba(255,255,255,0.3); }

/* Logo strip */
.hp-cta-logo-strip { text-align: center; padding: 48px 0 0; }
.hp-cta-logo-list { display: flex; align-items: center; justify-content: center; gap: 40px; flex-wrap: wrap; }
.hp-cta-logo-list img { height: 22px; opacity: 0.35; }

/* ============================================================
   AI VIZ — simplified static panels
   ============================================================ */
.hp-viz-box { padding: 16px 20px; border-radius: 12px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.06); }
.hp-viz-label { font-size: 10px; color: rgba(255,255,255,0.3); letter-spacing: 0.05em; text-transform: uppercase; margin-bottom: 8px; }
.hp-viz-text { font-size: 13px; color: rgba(255,255,255,0.7); line-height: 1.5; }
.hp-viz-img-wrap { flex: 1; border-radius: 12px; overflow: hidden; position: relative; min-height: 160px; }
.hp-viz-img-wrap img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hp-viz-img-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,0.7), rgba(0,0,0,0.2) 50%, transparent); }
.hp-viz-waveform { flex: 1; display: flex; align-items: center; justify-content: center; gap: 2.5px; padding: 0 4px; }
.hp-viz-waveform-bar { width: 3.5px; border-radius: 2px; background: rgba(107,159,255,0.4); }
.hp-viz-chips { display: flex; gap: 6px; }
.hp-viz-chip { flex: 1; padding: 8px 0; border-radius: 8px; text-align: center; font-size: 10px; font-weight: 600; border: 1px solid; }
.hp-viz-split-wrap { flex: 1; border-radius: 12px; overflow: hidden; position: relative; }
.hp-viz-progress-wrap { display: flex; align-items: center; gap: 12px; }
.hp-viz-progress-bar { flex: 1; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.04); overflow: hidden; }
.hp-viz-progress-fill { height: 100%; border-radius: 2px; }
.hp-viz-formats { display: flex; gap: 6px; justify-content: center; }
.hp-viz-format-btn { padding: 6px 14px; border-radius: 6px; font-size: 10px; font-weight: 600; border: 1px solid; cursor: pointer; transition: all 0.3s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .hp-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .hp-editorial-seam { display: none; }
  .hp-stats-row { grid-template-columns: repeat(2, 1fr); }
  .hp-stats-row .hp-stat-cell:nth-child(3) { border-left: none; }
}

@media (max-width: 768px) {
  .hp-hero { padding: 60px 20px 0; }
  .hp-section { padding: 80px 20px; }
  .hp-section-sm { padding: 60px 20px; }
  .hp-section-lg { padding: 80px 20px; }
  .hp-hero-split { grid-template-columns: 1fr !important; gap: 40px !important; }
  .hp-hero-mosaic { height: 300px !important; }
  .hp-hero-modes { grid-template-columns: 1fr !important; }
  .hp-grid-3 { grid-template-columns: 1fr; }
  .hp-grid-2 { grid-template-columns: 1fr; }
  .hp-grid-4 { grid-template-columns: repeat(2, 1fr); }
  .hp-editorial { grid-template-columns: 1fr !important; }
  .hp-editorial-half { padding: 36px 24px 32px !important; }
  .hp-editorial-seam { display: none; }
  .hp-editorial-bottom { padding: 20px 24px !important; grid-column: 1 !important; }
  .hp-ai-desktop { display: none !important; }
  .hp-ai-mobile { display: block !important; }
  .hp-cta-image-wrap { aspect-ratio: 3/4 !important; border-radius: 16px !important; }
  .hp-cta-cards-wrap { padding: 0 12px !important; margin-top: -40px !important; }
  .hp-cta-cards { grid-template-columns: 1fr !important; gap: 12px !important; }
  .hp-stats-row { grid-template-columns: repeat(2, 1fr); }
  .hp-ai-result-stats { grid-template-columns: repeat(2, 1fr); }
  .hp-ai-result-stat:nth-child(3) { border-left: none; }
}

@media (max-width: 480px) {
  .hp-grid-4 { grid-template-columns: 1fr; }
  .hp-hero-stats { flex-wrap: wrap; gap: 16px; }
}
