/* ═══════════════════════════════════════════════════════
   DESIGN TOKENS — BOSQUE AZUL THEME
═══════════════════════════════════════════════════════ */
:root {
  /* Forest Blue Palette - DARK */
  --bg-void:        #020c10;
  --bg-deep:        #041420;
  --bg-surface:     #071e2e;
  --bg-raised:      #0a2640;
  --bg-float:       #0d3050;

  --forest-teal:    #0b6b70;
  --forest-pine:    #0a4a3a;
  --forest-moss:    #1a6644;

  --cyan-electric:  #00f5e0;
  --cyan-bright:    #00d4c8;
  --cyan-mid:       #0099a0;
  --teal-glow:      #00e8ff;
  --green-bio:      #00ff9d;
  --blue-electric:  #0066ff;
  --blue-vivid:     #1a7fff;
  --amber-accent:   #ffaa00;

  --text-primary:   #e8f8ff;
  --text-secondary: #7ab8cc;
  --text-muted:     #3d6a7a;
  --text-ghost:     #1f404f;

  --glass-bg:       rgba(7, 30, 46, 0.75);
  --glass-border:   rgba(0, 245, 224, 0.12);
  --glass-border-hi:rgba(0, 245, 224, 0.35);
  --glass-glow:     rgba(0, 245, 224, 0.06);

  --shadow-deep:    0 25px 80px rgba(0, 0, 0, 0.6);
  --shadow-glow:    0 0 60px rgba(0, 245, 224, 0.15);
  --shadow-glow-sm: 0 0 25px rgba(0, 245, 224, 0.2);

  --radius-sm:  8px;
  --radius-md:  16px;
  --radius-lg:  24px;
  --radius-xl:  32px;
  --radius-pill:9999px;

  --ease-spring: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  --ease-out:    cubic-bezier(0.16, 1, 0.3, 1);
  --ease-smooth: cubic-bezier(0.4, 0, 0.2, 1);
  --dur-fast:    0.2s;
  --dur-mid:     0.4s;
  --dur-slow:    0.7s;
}

[data-theme="light"] {
  --bg-void:        #e0f4f8;
  --bg-deep:        #c8eef5;
  --bg-surface:     #b0e6f0;
  --bg-raised:      #98daea;
  --bg-float:       #80cfe0;

  --forest-teal:    #007a85;
  --forest-pine:    #005a46;
  --forest-moss:    #006838;

  --cyan-electric:  #007a6e;
  --cyan-bright:    #00686a;
  --cyan-mid:       #005562;
  --teal-glow:      #0088a0;
  --green-bio:      #009955;
  --blue-electric:  #0055cc;
  --blue-vivid:     #0066dd;
  --amber-accent:   #cc8800;

  --text-primary:   #041420;
  --text-secondary: #1a4a5a;
  --text-muted:     #2a6070;
  --text-ghost:     #5a9aaa;

  --glass-bg:       rgba(180, 230, 242, 0.75);
  --glass-border:   rgba(0, 122, 133, 0.18);
  --glass-border-hi:rgba(0, 122, 133, 0.45);
  --glass-glow:     rgba(0, 122, 133, 0.06);

  --shadow-deep:    0 25px 80px rgba(0, 50, 70, 0.15);
  --shadow-glow:    0 0 60px rgba(0, 122, 133, 0.18);
  --shadow-glow-sm: 0 0 25px rgba(0, 122, 133, 0.22);
}

/* ═══════════════════════════════════════════════════════
   RESET & BASE
═══════════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: 'Bricolage Grotesque', sans-serif;
  background: var(--bg-void);
  color: var(--text-primary);
  overflow-x: hidden;
  min-height: 100vh;
  transition: background 0.5s var(--ease-smooth), color 0.5s var(--ease-smooth);
  cursor: none;
}
[data-theme="light"] body { background: var(--bg-void); }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font-family: inherit; cursor: none; }
input, textarea { font-family: inherit; }

/* Scrollbar */
::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg-void); }
::-webkit-scrollbar-thumb { background: var(--forest-teal); border-radius: 5px; }
::-webkit-scrollbar-thumb:hover { background: var(--cyan-mid); }

/* Selection */
::selection { background: rgba(0, 245, 224, 0.2); color: var(--cyan-electric); }

/* ═══════════════════════════════════════════════════════
   CURSOR
═══════════════════════════════════════════════════════ */
.c-cursor {
  position: fixed; top: 0; left: 0; z-index: 99999;
  pointer-events: none;
  mix-blend-mode: screen;
}
.c-cursor__dot {
  position: absolute;
  width: 8px; height: 8px;
  background: var(--cyan-electric);
  border-radius: 50%;
  transform: translate(-50%,-50%);
  transition: transform 0.1s;
}
.c-cursor__ring {
  position: absolute;
  width: 40px; height: 40px;
  border: 1.5px solid var(--cyan-electric);
  border-radius: 50%;
  transform: translate(-50%,-50%);
  opacity: 0.5;
  transition: width 0.3s var(--ease-spring), height 0.3s var(--ease-spring), opacity 0.3s;
}
.c-cursor.is-hovering .c-cursor__ring { width: 60px; height: 60px; opacity: 0.8; }
.c-cursor.is-clicking .c-cursor__dot { transform: translate(-50%,-50%) scale(2); }

/* ═══════════════════════════════════════════════════════
   CANVAS (Gravity Particles)
═══════════════════════════════════════════════════════ */
#universe-canvas {
  position: fixed; inset: 0;
  z-index: 0;
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════
   NOISE OVERLAY
═══════════════════════════════════════════════════════ */
.noise-overlay {
  position: fixed; inset: 0; z-index: 1;
  pointer-events: none;
  opacity: 0.025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px;
}

/* ═══════════════════════════════════════════════════════
   LAYOUT WRAPPERS
═══════════════════════════════════════════════════════ */
.site-wrap { position: relative; z-index: 2; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 clamp(20px, 5vw, 60px); }
.section-pad { padding: clamp(80px, 12vw, 160px) 0; }

/* ═══════════════════════════════════════════════════════
   TYPOGRAPHY SYSTEM
═══════════════════════════════════════════════════════ */
.display-xl {
  font-family: 'Clash Display', sans-serif;
  font-size: clamp(3rem, 8vw, 7.5rem);
  font-weight: 700;
  line-height: 0.92;
  letter-spacing: -0.04em;
}
.display-lg {
  font-family: 'Clash Display', sans-serif;
  font-size: clamp(2.2rem, 5vw, 4.5rem);
  font-weight: 600;
  line-height: 1.0;
  letter-spacing: -0.03em;
}
.display-md {
  font-family: 'Clash Display', sans-serif;
  font-size: clamp(1.5rem, 3vw, 2.5rem);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.body-lg { font-size: clamp(1rem, 1.5vw, 1.2rem); line-height: 1.75; }
.body-md { font-size: 1rem; line-height: 1.7; }
.body-sm { font-size: 0.875rem; line-height: 1.65; }
.mono { font-family: 'JetBrains Mono', monospace; }

/* Gradient text */
.grad-cyan { background: linear-gradient(135deg, var(--cyan-electric) 0%, var(--green-bio) 60%, var(--teal-glow) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.grad-blue { background: linear-gradient(135deg, var(--blue-vivid) 0%, var(--cyan-electric) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.grad-warm { background: linear-gradient(135deg, var(--amber-accent) 0%, var(--cyan-electric) 100%); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.text-secondary { color: var(--text-secondary); }
.text-muted { color: var(--text-muted); }

/* ═══════════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════════ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 14px 28px;
  border: none; border-radius: var(--radius-pill);
  font-size: 0.95rem; font-weight: 600;
  letter-spacing: 0.01em;
  transition: all var(--dur-mid) var(--ease-spring);
  position: relative; overflow: hidden;
  white-space: nowrap;
}
.btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.15) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--dur-fast);
}
.btn:hover::before { opacity: 1; }
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0) scale(0.98); }

.btn-primary {
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  color: var(--bg-void);
  box-shadow: 0 0 30px rgba(0, 245, 224, 0.35);
}
.btn-primary:hover { box-shadow: 0 0 50px rgba(0, 245, 224, 0.55); }

.btn-secondary {
  background: var(--glass-bg);
  color: var(--cyan-electric);
  border: 1.5px solid var(--glass-border-hi);
  backdrop-filter: blur(12px);
}
.btn-secondary:hover { border-color: var(--cyan-electric); background: rgba(0, 245, 224, 0.08); }

.btn-ghost {
  background: transparent;
  color: var(--text-secondary);
  border: 1px solid var(--glass-border);
}
.btn-ghost:hover { color: var(--cyan-electric); border-color: var(--glass-border-hi); }

.btn-lg { padding: 18px 40px; font-size: 1.05rem; }
.btn-sm { padding: 10px 20px; font-size: 0.82rem; }
.btn-icon { width: 44px; height: 44px; padding: 0; border-radius: 50%; }

/* ═══════════════════════════════════════════════════════
   GLASS CARD
═══════════════════════════════════════════════════════ */
.glass {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.glass-raised {
  background: linear-gradient(145deg, rgba(10,38,64,0.9) 0%, rgba(7,30,46,0.8) 100%);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
}
[data-theme="light"] .glass { background: rgba(180,230,242,0.7); }
[data-theme="light"] .glass-raised { background: linear-gradient(145deg, rgba(160,218,232,0.88) 0%, rgba(176,230,240,0.75) 100%); }

/* ═══════════════════════════════════════════════════════
   SECTION LABELS
═══════════════════════════════════════════════════════ */
.section-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 16px;
  background: rgba(0, 245, 224, 0.07);
  border: 1px solid rgba(0, 245, 224, 0.2);
  border-radius: var(--radius-pill);
  font-size: 0.75rem; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--cyan-electric);
  margin-bottom: 24px;
}
.section-eyebrow .dot {
  width: 6px; height: 6px;
  background: var(--green-bio);
  border-radius: 50%;
  animation: breathe 2.5s ease-in-out infinite;
}
@keyframes breathe { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.3;transform:scale(0.7)} }

/* ═══════════════════════════════════════════════════════
   SCROLL REVEAL
═══════════════════════════════════════════════════════ */
.reveal {
  opacity: 0;
  transform: translateY(50px);
  transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out);
}
.reveal.in { opacity: 1; transform: translateY(0); }
.reveal-left { opacity: 0; transform: translateX(-50px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out); }
.reveal-left.in { opacity: 1; transform: translateX(0); }
.reveal-right { opacity: 0; transform: translateX(50px); transition: opacity var(--dur-slow) var(--ease-out), transform var(--dur-slow) var(--ease-out); }
.reveal-right.in { opacity: 1; transform: translateX(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }
.reveal-delay-4 { transition-delay: 0.4s; }
.reveal-delay-5 { transition-delay: 0.5s; }
.reveal-delay-6 { transition-delay: 0.6s; }

/* ═══════════════════════════════════════════════════════
   FUTURISTIC SECTION TRANSITIONS
═══════════════════════════════════════════════════════ */
.section-transition {
  position: relative;
  overflow: hidden;
}
.section-transition::before {
  content: '';
  position: absolute;
  top: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--cyan-electric), var(--green-bio), var(--blue-electric), transparent);
  animation: scanLine 3s ease-in-out infinite;
}
.section-transition::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--glass-border-hi), transparent);
}
@keyframes scanLine {
  0% { transform: scaleX(0); opacity: 0; }
  50% { transform: scaleX(1); opacity: 1; }
  100% { transform: scaleX(0); opacity: 0; }
}

/* Glitch reveal */
.reveal-glitch {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.8s var(--ease-out), transform 0.8s var(--ease-out);
  position: relative;
}
.reveal-glitch.in {
  opacity: 1;
  transform: translateY(0);
  animation: glitchIn 0.6s var(--ease-out) forwards;
}
@keyframes glitchIn {
  0% { clip-path: inset(0 0 100% 0); filter: hue-rotate(90deg); }
  20% { clip-path: inset(0 0 60% 0); filter: hue-rotate(45deg); }
  40% { clip-path: inset(0 0 30% 0); filter: hue-rotate(20deg); }
  60% { clip-path: inset(0 0 10% 0); filter: hue-rotate(10deg); }
  80% { clip-path: inset(0 0 2% 0); filter: hue-rotate(0deg); }
  100% { clip-path: inset(0 0 0 0); filter: hue-rotate(0deg); }
}

/* Holographic shimmer on sections */
.holo-shimmer::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 50%;
  height: 100%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(0, 245, 224, 0.03),
    rgba(0, 255, 157, 0.05),
    rgba(0, 102, 255, 0.03),
    transparent
  );
  animation: holoSweep 8s ease-in-out infinite;
  pointer-events: none;
  z-index: 0;
}
@keyframes holoSweep {
  0% { left: -50%; }
  100% { left: 150%; }
}

/* Cyber grid background for sections */
.cyber-grid-bg {
  position: relative;
}
.cyber-grid-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,245,224,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,245,224,0.03) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 1s ease;
  z-index: 0;
}
.cyber-grid-bg.in-view::after {
  opacity: 1;
}

/* Data stream divider between sections */
.section-divider-stream {
  height: 60px;
  position: relative;
  overflow: hidden;
}
.section-divider-stream::before {
  content: '01001010 11010110 00110101 01001010 11010110 00110101 01001010 11010110';
  position: absolute;
  white-space: nowrap;
  font-family: 'JetBrains Mono', monospace;
  font-size: 0.65rem;
  color: var(--cyan-electric);
  opacity: 0.08;
  top: 50%;
  transform: translateY(-50%);
  animation: dataStream 20s linear infinite;
}
@keyframes dataStream {
  0% { left: 100%; }
  100% { left: -100%; }
}

/* Particle burst overlay for page load */
.page-load-burst {
  position: fixed;
  inset: 0;
  z-index: 9998;
  pointer-events: none;
  background: radial-gradient(ellipse at center, rgba(0,245,224,0.15) 0%, transparent 70%);
  opacity: 1;
  animation: burstFade 2s ease-out forwards;
}
@keyframes burstFade {
  0% { opacity: 1; transform: scale(0.8); }
  50% { opacity: 0.5; transform: scale(1.2); }
  100% { opacity: 0; transform: scale(1.5); }
}

/* ═══════════════════════════════════════════════════════
   NAVBAR
═══════════════════════════════════════════════════════ */
.navbar {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  padding: 0 clamp(20px, 5vw, 60px);
  transition: all 0.5s var(--ease-smooth);
}
.navbar__inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  height: 72px;
}
.navbar.scrolled {
  background: var(--glass-bg);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--glass-border);
  box-shadow: 0 4px 30px rgba(0,0,0,0.3);
}

.nav-logo {
  display: flex; align-items: center; gap: 10px;
  font-family: 'Clash Display', sans-serif;
  font-size: 1.7rem; font-weight: 700;
  letter-spacing: -0.05em;
}
.nav-logo__mark {
  width: 34px; height: 34px;
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  box-shadow: 0 0 20px rgba(0,245,224,0.4);
}
.nav-logo__text { background: linear-gradient(135deg, var(--text-primary), var(--cyan-bright)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }

.nav-links {
  display: flex; align-items: center; gap: 0;
  list-style: none;
}
.nav-links a {
  display: block; padding: 10px 18px;
  font-size: 0.9rem; font-weight: 500;
  color: var(--text-secondary);
  border-radius: var(--radius-pill);
  transition: all var(--dur-fast) var(--ease-smooth);
  position: relative;
}
.nav-links a:hover { color: var(--cyan-electric); background: rgba(0,245,224,0.06); }

.nav-actions { display: flex; align-items: center; gap: 12px; }

/* Theme toggle */
.theme-btn {
  width: 42px; height: 42px;
  border-radius: var(--radius-pill);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  transition: all var(--dur-fast);
  cursor: none;
}
.theme-btn:hover { border-color: var(--glass-border-hi); background: rgba(0,245,224,0.06); }

/* Mobile nav */
.hamburger { display: none; flex-direction: column; gap: 5px; padding: 8px; background: none; border: none; }
.hamburger span { display: block; width: 24px; height: 2px; background: var(--text-primary); border-radius: 2px; transition: all 0.3s; }
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav {
  position: fixed; inset: 0; z-index: 999;
  background: rgba(2, 12, 16, 0.97);
  backdrop-filter: blur(30px);
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2rem;
  transform: translateX(-100%);
  transition: transform 0.5s var(--ease-out);
}
.mobile-nav.open { transform: translateX(0); }
.mobile-nav a { font-family: 'Clash Display', sans-serif; font-size: 2.2rem; font-weight: 600; color: var(--text-secondary); transition: color var(--dur-fast); }
.mobile-nav a:hover { color: var(--cyan-electric); }

/* ═══════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════ */
.hero {
  min-height: 100vh;
  display: flex; align-items: center;
  position: relative;
  overflow: hidden;
  padding-top: 72px;
}

/* Ambient blobs */
.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
}
.blob-1 {
  width: 700px; height: 700px;
  background: radial-gradient(ellipse, rgba(0,107,112,0.25) 0%, transparent 70%);
  top: -150px; left: -200px;
  animation: drift1 12s ease-in-out infinite;
}
.blob-2 {
  width: 600px; height: 600px;
  background: radial-gradient(ellipse, rgba(0,102,255,0.15) 0%, transparent 70%);
  bottom: -100px; right: -150px;
  animation: drift2 15s ease-in-out infinite;
}
.blob-3 {
  width: 400px; height: 400px;
  background: radial-gradient(ellipse, rgba(0,255,157,0.1) 0%, transparent 70%);
  top: 40%; left: 50%;
  animation: drift3 10s ease-in-out infinite;
}
@keyframes drift1 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(60px,-40px) scale(1.05)} 66%{transform:translate(-30px,50px) scale(0.97)} }
@keyframes drift2 { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(-50px,30px) scale(1.08)} 66%{transform:translate(40px,-60px) scale(0.95)} }
@keyframes drift3 { 0%,100%{transform:translate(-50%,-50%) scale(1)} 50%{transform:translate(-50%,-50%) scale(1.3) rotate(15deg)} }

.hero__content {
  position: relative; z-index: 2;
  padding: clamp(40px, 10vw, 120px) 0;
}

.hero__grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 60px; align-items: center;
}

.hero__badge {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 20px;
  background: rgba(0,245,224,0.06);
  border: 1px solid rgba(0,245,224,0.18);
  border-radius: var(--radius-pill);
  font-size: 0.78rem; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--cyan-electric);
  margin-bottom: 32px;
  animation: fadeSlideDown 1s var(--ease-out) both;
}

.hero__title {
  margin-bottom: 28px;
  animation: fadeSlideDown 1s var(--ease-out) 0.1s both;
}

.hero__subtitle {
  font-size: clamp(1rem, 1.6vw, 1.15rem);
  color: var(--text-secondary);
  line-height: 1.75;
  max-width: 520px;
  margin-bottom: 44px;
  animation: fadeSlideDown 1s var(--ease-out) 0.2s both;
}

.hero__actions {
  display: flex; gap: 14px; flex-wrap: wrap;
  animation: fadeSlideDown 1s var(--ease-out) 0.3s both;
}

.hero__proof {
  margin-top: 56px;
  padding-top: 40px;
  border-top: 1px solid var(--glass-border);
  display: flex; gap: 40px; flex-wrap: wrap;
  animation: fadeSlideDown 1s var(--ease-out) 0.5s both;
}
.hero__stat-num {
  font-family: 'Clash Display', sans-serif;
  font-size: 2.2rem; font-weight: 700;
  line-height: 1;
  margin-bottom: 4px;
}
.hero__stat-label { font-size: 0.82rem; color: var(--text-muted); letter-spacing: 0.04em; }

/* Hero visual */
.hero__visual {
  position: relative;
  animation: fadeSlideLeft 1.2s var(--ease-out) 0.2s both;
}

.hero-phone {
  width: 320px; margin: 0 auto;
  background: linear-gradient(145deg, var(--bg-raised), var(--bg-surface));
  border: 1px solid var(--glass-border);
  border-radius: 44px;
  padding: 14px;
  box-shadow: var(--shadow-deep), 0 0 80px rgba(0,245,224,0.1);
  position: relative;
  animation: floatPhone 5s ease-in-out infinite;
}
@keyframes floatPhone { 0%,100%{transform:translateY(0) rotate(-2deg)} 50%{transform:translateY(-18px) rotate(1deg)} }

.hero-phone__notch {
  width: 100px; height: 28px;
  background: var(--bg-void);
  border-radius: 14px;
  margin: 0 auto 12px;
}
.hero-phone__screen {
  background: var(--bg-deep);
  border-radius: 32px;
  overflow: hidden;
  height: 560px;
  min-height: 560px;
  display: flex;
  flex-direction: column;
}
.phone-header {
  background: linear-gradient(180deg, var(--bg-raised), var(--bg-surface));
  padding: 18px 20px 16px;
  display: flex; align-items: center; gap: 12px;
  border-bottom: 1px solid var(--glass-border);
}
.phone-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; flex-shrink: 0;
  position: relative;
  box-shadow: 0 0 15px rgba(0,245,224,0.5);
}
.phone-avatar::after {
  content: '';
  position: absolute; bottom: 1px; right: 1px;
  width: 9px; height: 9px;
  background: var(--green-bio);
  border: 2px solid var(--bg-raised);
  border-radius: 50%;
}
.phone-info-name { font-size: 0.85rem; font-weight: 600; margin-bottom: 2px; }
.phone-info-status { font-size: 0.7rem; color: var(--green-bio); }

.phone-messages {
  padding: 18px 16px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
}
.pmsg {
  display: flex; align-items: flex-end; gap: 8px;
}
.pmsg.right { flex-direction: row-reverse; }
.pmsg__avatar { width: 26px; height: 26px; border-radius: 50%; flex-shrink: 0; display: flex; align-items: center; justify-content: center; font-size: 0.7rem; }
.pmsg__gigi-av { background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio)); color: var(--bg-void); font-weight: 700; }
.pmsg__user-av { background: linear-gradient(135deg, var(--blue-vivid), var(--blue-electric)); color: white; font-weight: 700; }

.pmsg__bubble {
  max-width: 200px;
  padding: 10px 14px;
  border-radius: 18px 18px 18px 4px;
  font-size: 0.78rem; line-height: 1.55;
  color: var(--text-primary);
}
.pmsg.right .pmsg__bubble { border-radius: 18px 18px 4px 18px; }
.pmsg__bubble--gigi {
  background: rgba(0,245,224,0.1);
  border: 1px solid rgba(0,245,224,0.15);
}
.pmsg__bubble--user {
  background: linear-gradient(135deg, rgba(0,102,255,0.3), rgba(0,245,224,0.15));
  border: 1px solid rgba(0,102,255,0.3);
}
.pmsg__typing { display: flex; gap: 4px; align-items: center; padding: 12px 16px; }
.pmsg__typing span {
  width: 6px; height: 6px;
  background: var(--cyan-mid);
  border-radius: 50%;
  animation: typingDot 1.4s ease-in-out infinite;
}
.pmsg__typing span:nth-child(2) { animation-delay: 0.2s; }
.pmsg__typing span:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingDot { 0%,80%,100%{transform:scale(0.7);opacity:0.4} 40%{transform:scale(1);opacity:1} }
.pmsg__media {
  max-width: 200px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(0,245,224,0.2);
  background: rgba(0,245,224,0.06);
}
.pmsg__media picture,
.pmsg__media img { display: block; width: 100%; }
.pmsg__media img { height: 100px; object-fit: cover; background: rgba(255,255,255,0.06); }
.pmsg__media-cap {
  padding: 8px 10px;
  font-size: 0.72rem;
  line-height: 1.4;
  color: var(--text-secondary);
}
.pmsg__media-cap strong { color: var(--text-primary); font-weight: 600; }

.phone-input-bar {
  margin: 10px 16px 18px;
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-raised);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-pill);
  padding: 8px 8px 8px 16px;
}
.phone-input-bar span { flex: 1; font-size: 0.75rem; color: var(--text-muted); }
.phone-send-btn {
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  border: none;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.8rem; color: var(--bg-void);
  cursor: none;
  flex-shrink: 0;
}

/* Floating cards around phone */
.float-badge {
  position: absolute;
  background: var(--glass-bg);
  backdrop-filter: blur(16px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: 12px 16px;
  font-size: 0.78rem;
  white-space: nowrap;
  box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}
.float-badge-1 { top: 30px; right: -40px; animation: floatBadge1 4s ease-in-out infinite; }
.float-badge-2 { bottom: 80px; left: -50px; animation: floatBadge2 4.5s ease-in-out infinite 0.5s; }
@keyframes floatBadge1 { 0%,100%{transform:translateY(0) rotate(3deg)} 50%{transform:translateY(-10px) rotate(5deg)} }
@keyframes floatBadge2 { 0%,100%{transform:translateY(0) rotate(-2deg)} 50%{transform:translateY(10px) rotate(-4deg)} }
.float-badge__icon { font-size: 1.2rem; margin-bottom: 4px; }
.float-badge__label { font-weight: 600; color: var(--text-primary); }
.float-badge__sub { color: var(--text-muted); font-size: 0.7rem; }

/* Animate hero entrance */
@keyframes fadeSlideDown { from{opacity:0;transform:translateY(-30px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeSlideLeft { from{opacity:0;transform:translateX(50px)} to{opacity:1;transform:translateX(0)} }

/* ═══════════════════════════════════════════════════════
   SERVICES
═══════════════════════════════════════════════════════ */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
}
.service-card {
  padding: 36px 30px;
  border-radius: var(--radius-lg);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(16px);
  position: relative;
  overflow: hidden;
  transition: all var(--dur-mid) var(--ease-spring);
  cursor: none;
  height: 100%;
}
.service-card::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 30%, rgba(0,245,224,0.06) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--dur-mid);
}
.service-card:hover { transform: translateY(-8px); border-color: var(--glass-border-hi); box-shadow: var(--shadow-glow); }
.service-card:hover::before { opacity: 1; }

.service-card__glow {
  position: absolute; bottom: -30px; right: -30px;
  width: 120px; height: 120px;
  border-radius: 50%;
  opacity: 0;
  transition: opacity var(--dur-mid);
  filter: blur(30px);
}
.service-card:hover .service-card__glow { opacity: 0.6; }

.service-icon {
  width: 56px; height: 56px;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 20px;
  position: relative;
}
.service-icon::after {
  content: '';
  position: absolute; inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(0,245,224,0.2);
  background: linear-gradient(135deg, rgba(0,245,224,0.12), rgba(0,255,157,0.06));
}

.service-card h3 { font-family: 'Clash Display', sans-serif; font-size: 1.25rem; font-weight: 600; margin-bottom: 12px; }
.service-card p { font-size: 0.88rem; color: var(--text-secondary); line-height: 1.7; }

.service-card__tag {
  display: inline-block; margin-top: 20px;
  padding: 5px 12px;
  border-radius: var(--radius-pill);
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  background: rgba(0,245,224,0.08);
  border: 1px solid rgba(0,245,224,0.15);
  color: var(--cyan-electric);
}

/* Brochure scan proof */
/* ═══════════════════════════════════════════════════════
   GIGI SECTION
═══════════════════════════════════════════════════════ */
.gigi-section { position: relative; overflow: hidden; }
.gigi-section::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 0%, rgba(0,107,112,0.06) 50%, transparent 100%);
  pointer-events: none;
}

.gigi-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}

/* GIGI Icon / Logo */
.gigi-icon-wrap {
  display: flex; flex-direction: column; align-items: center; gap: 20px;
}
.gigi-icon-svg {
  width: 140px; height: 140px;
  position: relative;
  filter: drop-shadow(0 0 30px rgba(0,245,224,0.4));
  animation: gigiPulse 4s ease-in-out infinite;
}
@keyframes gigiPulse {
  0%,100%{filter:drop-shadow(0 0 30px rgba(0,245,224,0.4))}
  50%{filter:drop-shadow(0 0 60px rgba(0,245,224,0.7))}
}
.gigi-name-badge {
  font-family: 'Clash Display', sans-serif;
  font-size: 1.6rem; font-weight: 700;
  letter-spacing: -0.02em;
}
.gigi-online {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.75rem; color: var(--green-bio);
  padding: 5px 12px;
  background: rgba(0,255,157,0.08);
  border: 1px solid rgba(0,255,157,0.2);
  border-radius: var(--radius-pill);
}

/* Gigi chat showcase */
.gigi-showcase {
  position: relative;
}
.gigi-chat-window {
  background: linear-gradient(145deg, rgba(10,38,64,0.95), rgba(7,30,46,0.9));
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-deep), var(--shadow-glow);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  height: 560px;
  max-height: min(70vh, 620px);
  contain: layout paint;
}
.gcw-header {
  padding: 20px 24px;
  border-bottom: 1px solid var(--glass-border);
  display: flex; align-items: center; gap: 14px;
  background: rgba(10,38,64,0.8);
}
.gcw-avatar {
  width: 44px; height: 44px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  display: flex; align-items: center; justify-content: center;
  position: relative;
  box-shadow: 0 0 20px rgba(0,245,224,0.5);
}
.gcw-avatar svg { width: 24px; height: 24px; }
.gcw-name { font-family: 'Clash Display', sans-serif; font-size: 1rem; font-weight: 600; }
.gcw-status { font-size: 0.72rem; color: var(--green-bio); display:flex;align-items:center;gap:5px; }

.gcw-body {
  padding: 24px;
  display: flex; flex-direction: column; gap: 18px;
  min-height: 0;
  overflow-y: auto;
  overscroll-behavior: contain;
  scroll-behavior: smooth;
}
.gcw-body::-webkit-scrollbar { width: 8px; }
.gcw-body::-webkit-scrollbar-track { background: rgba(255,255,255,0.04); }
.gcw-body::-webkit-scrollbar-thumb {
  background: rgba(0,245,224,0.28);
  border-radius: 999px;
}
.gcw-msg { display: flex; gap: 10px; align-items: flex-end; }
.gcw-msg.right { flex-direction: row-reverse; }
.gcw-msg__av {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.7rem; font-weight: 700;
}
.gcw-msg__av--gigi { background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio)); color: var(--bg-void); }
.gcw-msg__av--user { background: linear-gradient(135deg, var(--blue-vivid), var(--cyan-mid)); color: white; }
.gcw-msg__text {
  max-width: 260px; padding: 12px 16px;
  font-size: 0.85rem; line-height: 1.6;
  border-radius: 18px 18px 18px 4px;
  word-break: break-word;
}
.gcw-msg.right .gcw-msg__text { border-radius: 18px 18px 4px 18px; }
.gcw-msg__text--gigi { background: rgba(0,245,224,0.08); border: 1px solid rgba(0,245,224,0.14); }
.gcw-msg__text--user { background: linear-gradient(135deg, rgba(0,102,255,0.25), rgba(0,245,224,0.12)); border: 1px solid rgba(0,102,255,0.25); }
.gcw-msg__media {
  width: min(260px, 100%);
  background: rgba(0, 245, 224, 0.05);
  border: 1px solid rgba(0, 245, 224, 0.18);
  border-radius: 16px;
  overflow: hidden;
}
.gcw-msg__media img {
  display: block;
  width: 100%;
  height: 132px;
  object-fit: cover;
  background: rgba(255, 255, 255, 0.06);
}
.gcw-media-caption {
  padding: 10px 12px;
  font-size: 0.78rem;
  line-height: 1.5;
  color: var(--text-secondary);
}
.gcw-media-caption strong {
  color: var(--text-primary);
  font-weight: 600;
}

.gcw-footer {
  padding: 16px 20px;
  border-top: 1px solid var(--glass-border);
  display: flex; gap: 10px; align-items: center;
  background: rgba(10,38,64,0.5);
}
.gcw-input {
  flex: 1; background: rgba(255,255,255,0.05);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-pill);
  padding: 10px 18px;
  color: var(--text-primary); font-size: 0.85rem;
  outline: none;
  transition: border-color var(--dur-fast);
}
.gcw-input:focus { border-color: var(--glass-border-hi); }
.gcw-input::placeholder { color: var(--text-muted); }
.gcw-mic, .gcw-send {
  width: 40px; height: 40px; border-radius: 50%; border: none; display: flex; align-items: center; justify-content: center; flex-shrink: 0; cursor: none; transition: all var(--dur-fast);
}
.gcw-mic { background: rgba(0,245,224,0.1); border: 1px solid var(--glass-border); color: var(--cyan-electric); font-size: 1rem; }
.gcw-mic:hover { background: rgba(0,245,224,0.18); border-color: var(--glass-border-hi); }
.gcw-send { background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio)); color: var(--bg-void); font-size: 0.9rem; box-shadow: 0 0 15px rgba(0,245,224,0.4); }
.gcw-send:hover { transform: scale(1.1); }

/* Feature list */
.gigi-features { display: flex; flex-direction: column; gap: 14px; }
.gigi-feat {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 18px 20px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  backdrop-filter: blur(12px);
  transition: all var(--dur-mid) var(--ease-spring);
  cursor: none;
}
.gigi-feat:hover { border-color: var(--glass-border-hi); transform: translateX(6px); }
.gigi-feat__icon {
  width: 44px; height: 44px; border-radius: var(--radius-sm); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem;
  background: linear-gradient(135deg, rgba(0,245,224,0.12), rgba(0,255,157,0.06));
  border: 1px solid rgba(0,245,224,0.15);
}
.gigi-feat__title { font-family: 'Clash Display', sans-serif; font-size: 0.95rem; font-weight: 600; margin-bottom: 5px; }
.gigi-feat__desc { font-size: 0.82rem; color: var(--text-secondary); line-height: 1.6; }

/* Security tags */
.security-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.sec-tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px;
  background: rgba(0,255,157,0.06);
  border: 1px solid rgba(0,255,157,0.15);
  border-radius: var(--radius-pill);
  font-size: 0.73rem; font-weight: 600; letter-spacing: 0.04em;
  color: var(--green-bio);
}

/* ═══════════════════════════════════════════════════════
   GIGI PRODUCT SECTION
═══════════════════════════════════════════════════════ */
.gigi-product-section {
  background: linear-gradient(135deg, rgba(0,245,224,0.04) 0%, rgba(0,102,255,0.04) 100%);
  border-top: 1px solid var(--glass-border);
  border-bottom: 1px solid var(--glass-border);
}

.gigi-product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px; align-items: center;
}

.gigi-product-card {
  padding: 48px 44px;
  text-align: center;
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(0,245,224,0.08) 0%, rgba(0,107,112,0.12) 100%);
  border: 1px solid rgba(0,245,224,0.2);
  box-shadow: 0 30px 90px rgba(0,0,0,0.4), 0 0 80px rgba(0,245,224,0.08);
  backdrop-filter: blur(20px);
}

.gigi-hero-icon {
  width: 120px; height: 120px; margin: 0 auto 28px;
  position: relative;
}
.gigi-orb {
  width: 100%; height: 100%;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  display: flex; align-items: center; justify-content: center;
  animation: orbPulse 3s ease-in-out infinite;
  box-shadow: 0 0 50px rgba(0,245,224,0.5), 0 0 100px rgba(0,245,224,0.2);
  position: relative;
}
@keyframes orbPulse { 0%,100%{box-shadow:0 0 50px rgba(0,245,224,0.5),0 0 100px rgba(0,245,224,0.2)} 50%{box-shadow:0 0 80px rgba(0,245,224,0.8),0 0 150px rgba(0,245,224,0.35)} }
.gigi-orb::before {
  content: '';
  position: absolute; inset: -4px; border-radius: 50%;
  background: conic-gradient(var(--cyan-electric) 0%, var(--green-bio) 25%, var(--teal-glow) 50%, var(--blue-vivid) 75%, var(--cyan-electric) 100%);
  z-index: -1; animation: spin 4s linear infinite;
  filter: blur(3px);
}
@keyframes spin { to { transform: rotate(360deg); } }

.gigi-orb-inner { font-size: 2.8rem; }

.gigi-stats-mini { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin: 28px 0; }
.gigi-stat-mini {
  padding: 18px;
  background: rgba(0,0,0,0.25);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
}
.gigi-stat-mini__val { font-family: 'Clash Display', sans-serif; font-size: 1.8rem; font-weight: 700; }
.gigi-stat-mini__lbl { font-size: 0.72rem; color: var(--text-muted); margin-top: 4px; }

.gigi-capabilities { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; margin-bottom: 32px; }
.cap-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px;
  background: rgba(0,245,224,0.08);
  border: 1px solid rgba(0,245,224,0.15);
  border-radius: var(--radius-pill);
  font-size: 0.75rem; font-weight: 500;
  color: var(--cyan-electric);
}

/* ═══════════════════════════════════════════════════════
   PRODUCTS / WHAT'S INCLUDED
═══════════════════════════════════════════════════════ */
.products-section {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, transparent 0%, rgba(0,245,224,0.03) 50%, transparent 100%);
}

.products-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 48px;
  align-items: stretch;
}

.product-item {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 22px 24px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  backdrop-filter: blur(12px);
  transition: all var(--dur-mid) var(--ease-spring);
  cursor: none;
  position: relative;
  overflow: hidden;
  height: 100%;
}
.product-item > div { flex: 1; }
.product-item::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,245,224,0.06) 0%, transparent 60%);
  opacity: 0;
  transition: opacity var(--dur-mid);
}
.product-item:hover {
  transform: translateY(-4px) translateX(4px);
  border-color: var(--glass-border-hi);
  box-shadow: var(--shadow-glow-sm);
}
.product-item:hover::before { opacity: 1; }

.product-item__icon {
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  flex-shrink: 0;
  background: linear-gradient(135deg, rgba(0,245,224,0.12), rgba(0,255,157,0.06));
  border: 1px solid rgba(0,245,224,0.18);
}
.product-item h4 {
  font-family: 'Clash Display', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  margin-bottom: 5px;
}
.product-item p {
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.6;
}

/* Logistics cards */
.logistics-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 32px;
  align-items: stretch;
}
.logistics-card {
  text-align: center;
  padding: 28px 20px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(14px);
  transition: all var(--dur-mid) var(--ease-spring);
  cursor: none;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.logistics-card:hover {
  transform: translateY(-6px);
  border-color: var(--glass-border-hi);
  box-shadow: var(--shadow-glow);
}
.logistics-card__logo {
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  border: 2px solid var(--glass-border-hi);
  background: linear-gradient(135deg, rgba(0,245,224,0.08), rgba(0,102,255,0.06));
}
.logistics-card__name {
  font-family: 'Clash Display', sans-serif;
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 6px;
}
.logistics-card__price {
  font-family: 'Clash Display', sans-serif;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 4px;
}
.logistics-card__desc {
  font-size: 0.78rem;
  color: var(--text-muted);
}

/* Benefits compact row */
.benefits-row {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 40px;
  justify-content: center;
}
.benefit-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  background: rgba(0,245,224,0.06);
  border: 1px solid rgba(0,245,224,0.15);
  border-radius: var(--radius-pill);
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--cyan-electric);
  transition: all var(--dur-fast);
}
.benefit-chip:hover {
  background: rgba(0,245,224,0.12);
  border-color: var(--glass-border-hi);
  transform: translateY(-2px);
}

/* Packaging badge */
.packaging-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  background: linear-gradient(135deg, rgba(255,170,0,0.08), rgba(0,245,224,0.06));
  border: 1px solid rgba(255,170,0,0.25);
  border-radius: var(--radius-pill);
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--amber-accent);
  margin-top: 24px;
}

/* ═══════════════════════════════════════════════════════
   PRICING
═══════════════════════════════════════════════════════ */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px; align-items: start;
  margin-top: 60px;
}

.pricing-card {
  border-radius: var(--radius-xl);
  padding: 40px 36px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(20px);
  position: relative; overflow: hidden;
  transition: all var(--dur-mid) var(--ease-spring);
  cursor: none;
}
.pricing-card:hover { transform: translateY(-12px); }

.pricing-card--featured {
  background: linear-gradient(145deg, rgba(0,245,224,0.1) 0%, rgba(0,107,112,0.12) 100%);
  border-color: rgba(0,245,224,0.3);
  box-shadow: 0 0 80px rgba(0,245,224,0.12);
}
.pricing-card--featured:hover { box-shadow: 0 0 120px rgba(0,245,224,0.2), var(--shadow-deep); }
.pricing-card--gigi {
  background: linear-gradient(145deg, rgba(0,102,255,0.1) 0%, rgba(0,245,224,0.08) 100%);
  border-color: rgba(0,102,255,0.25);
}
.pricing-card--gigi:hover { box-shadow: 0 0 80px rgba(0,102,255,0.15); }

.pricing-top-badge {
  position: absolute; top: 24px; right: 24px;
  padding: 5px 14px;
  border-radius: var(--radius-pill);
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
}
.badge-hot { background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio)); color: var(--bg-void); }
.badge-ai  { background: linear-gradient(135deg, var(--blue-electric), var(--cyan-mid));  color: white; }

.pricing-plan-icon { font-size: 2.2rem; margin-bottom: 16px; }
.pricing-plan-name { font-family: 'Clash Display', sans-serif; font-size: 1.5rem; font-weight: 700; margin-bottom: 10px; }
.pricing-plan-desc { font-size: 0.85rem; color: var(--text-secondary); line-height: 1.65; margin-bottom: 28px; }

.pricing-price-row { margin-bottom: 8px; }
.pricing-price {
  font-family: 'Clash Display', sans-serif;
  font-size: 3.2rem; font-weight: 700; line-height: 1;
}
.pricing-price-period { font-size: 0.82rem; color: var(--text-muted); margin-bottom: 28px; }

.pricing-divider { height: 1px; background: var(--glass-border); margin-bottom: 24px; }

.pricing-features { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px; }
.pricing-feature {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 0.87rem; line-height: 1.5;
}
.pricing-feature::before {
  content: '\2713';
  display: flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; flex-shrink: 0;
  border-radius: 50%;
  font-size: 0.7rem; font-weight: 700;
  background: rgba(0,245,224,0.1);
  color: var(--cyan-electric);
  margin-top: 1px;
}
.pricing-feature--no { color: var(--text-muted); }
.pricing-feature--no::before { content: '\2715'; background: rgba(255,80,80,0.1); color: #ff6060; }

.pricing-cta { display: block; width: 100%; text-align: center; }

/* Pricing decoration */
.pricing-card__shine {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.04) 0%, transparent 50%);
  pointer-events: none;
}

/* ═══════════════════════════════════════════════════════
   PROCESS / HOW IT WORKS
═══════════════════════════════════════════════════════ */
.process-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  position: relative; margin-top: 60px;
}
.process-grid::before {
  content: '';
  position: absolute; top: 36px; left: calc(12.5% + 20px); right: calc(12.5% + 20px);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--glass-border-hi), transparent);
}
.process-step { text-align: center; }
.process-step__num {
  width: 72px; height: 72px; margin: 0 auto 20px;
  border-radius: 50%;
  border: 1px solid var(--glass-border-hi);
  background: var(--glass-bg);
  backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Clash Display', sans-serif;
  font-size: 1.6rem; font-weight: 700;
  position: relative; z-index: 1;
  transition: all var(--dur-mid) var(--ease-spring);
}
.process-step:hover .process-step__num { background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio)); color: var(--bg-void); border-color: transparent; transform: scale(1.1); }
.process-step__title { font-family: 'Clash Display', sans-serif; font-size: 1.05rem; font-weight: 600; margin-bottom: 10px; }
.process-step__desc { font-size: 0.83rem; color: var(--text-secondary); line-height: 1.65; }

/* ═══════════════════════════════════════════════════════
   TESTIMONIALS
═══════════════════════════════════════════════════════ */
.testimonials-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  margin-top: 60px;
}
.testi-card {
  padding: 32px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(16px);
  transition: all var(--dur-mid) var(--ease-spring);
  cursor: none;
}
.testi-card:hover { transform: translateY(-6px); border-color: var(--glass-border-hi); }
.testi-stars { color: #ffc000; font-size: 0.9rem; letter-spacing: 2px; margin-bottom: 16px; }
.testi-text { font-size: 0.9rem; color: var(--text-secondary); line-height: 1.75; font-style: italic; margin-bottom: 24px; }
.testi-author { display: flex; align-items: center; gap: 12px; }
.testi-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  background: linear-gradient(135deg, var(--forest-teal), var(--cyan-mid));
  display: flex; align-items: center; justify-content: center;
  font-family: 'Clash Display', sans-serif;
  font-size: 1rem; font-weight: 700; color: white;
}
.testi-name { font-weight: 600; font-size: 0.9rem; }
.testi-role { font-size: 0.75rem; color: var(--text-muted); margin-top: 2px; }

/* ═══════════════════════════════════════════════════════
   CTA / CONTACT
═══════════════════════════════════════════════════════ */
.cta-section {
  text-align: center;
  position: relative; overflow: hidden;
}
.cta-section::before {
  content: '';
  position: absolute; width: 800px; height: 800px;
  background: radial-gradient(ellipse, rgba(0,107,112,0.2) 0%, transparent 70%);
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  pointer-events: none;
}
.cta-box {
  padding: 80px clamp(30px, 8vw, 100px);
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(10,38,64,0.9), rgba(7,30,46,0.85));
  border: 1px solid var(--glass-border-hi);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow-deep), var(--shadow-glow);
  position: relative; overflow: hidden;
}
.cta-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.cta-box::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(0,245,224,0.04) 0%, rgba(0,102,255,0.04) 100%);
}

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.footer {
  border-top: 1px solid var(--glass-border);
  padding: 60px 0 30px;
  position: relative; z-index: 2;
}
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 50px;
  margin-bottom: 50px;
}
.footer-brand__desc { font-size: 0.87rem; color: var(--text-secondary); line-height: 1.7; margin: 16px 0 24px; max-width: 280px; }
.footer-socials { display: flex; gap: 10px; }
.footer-social {
  width: 38px; height: 38px; border-radius: var(--radius-sm);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 0.95rem;
  transition: all var(--dur-fast);
  cursor: none;
}
.footer-social:hover { border-color: var(--glass-border-hi); background: rgba(0,245,224,0.06); transform: translateY(-2px); }
.footer-col-title { font-family: 'Clash Display', sans-serif; font-size: 0.88rem; font-weight: 600; color: var(--cyan-electric); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 18px; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer-links a { font-size: 0.87rem; color: var(--text-secondary); transition: color var(--dur-fast); }
.footer-links a:hover { color: var(--cyan-electric); }
.footer-link-btn {
  background: none;
  border: none;
  font-size: 0.78rem;
  color: var(--text-muted);
  cursor: none;
  transition: color var(--dur-fast);
  font-family: inherit;
}
.footer-link-btn:hover { color: var(--cyan-electric); }
.footer-bottom { border-top: 1px solid var(--glass-border); padding-top: 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; }
.footer-copy { font-size: 0.8rem; color: var(--text-muted); }

/* ═══════════════════════════════════════════════════════
   FLOATING CHAT BUTTON & POPUP
═══════════════════════════════════════════════════════ */
.chat-trigger {
  position: fixed; bottom: 28px; right: 28px;
  z-index: 900;
  width: 62px; height: 62px; border-radius: 50%;
  border: none;
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  box-shadow: 0 8px 32px rgba(0,245,224,0.5);
  cursor: none;
  transition: all var(--dur-mid) var(--ease-spring);
  animation: chatFloat 4s ease-in-out infinite;
}
@keyframes chatFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
.chat-trigger:hover { transform: scale(1.12) !important; box-shadow: 0 12px 50px rgba(0,245,224,0.7); }
.chat-trigger__ping {
  position: absolute; top: 4px; right: 4px;
  width: 14px; height: 14px;
  border: 2px solid var(--bg-void);
  background: var(--green-bio);
  border-radius: 50%;
  animation: pingPulse 2s infinite;
}
@keyframes pingPulse { 0%{box-shadow:0 0 0 0 rgba(0,255,157,0.6)} 70%{box-shadow:0 0 0 8px transparent} 100%{box-shadow:0 0 0 0 transparent} }

.chat-tooltip {
  position: absolute; right: 74px; bottom: 50%; transform: translateY(50%);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: 8px 14px;
  font-size: 0.78rem; white-space: nowrap;
  backdrop-filter: blur(12px);
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--dur-fast);
  font-weight: 500;
}
.chat-trigger:hover .chat-tooltip { opacity: 1; }

.chat-popup {
  position: fixed; bottom: 106px; right: 28px;
  z-index: 901;
  width: 360px;
  border-radius: var(--radius-xl);
  background: linear-gradient(145deg, rgba(10,38,64,0.98), rgba(7,30,46,0.95));
  border: 1px solid var(--glass-border);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow-deep), var(--shadow-glow);
  transform: scale(0.9) translateY(20px);
  opacity: 0; pointer-events: none;
  transition: all 0.35s var(--ease-spring);
  transform-origin: bottom right;
  overflow: hidden;
}
.chat-popup.open { transform: scale(1) translateY(0); opacity: 1; pointer-events: all; }

.cp-header {
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--glass-border);
  display: flex; align-items: center; gap: 12px;
  background: rgba(10,38,64,0.6);
}
.cp-avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio)); display:flex;align-items:center;justify-content:center; font-size: 1.2rem; flex-shrink:0; box-shadow: 0 0 15px rgba(0,245,224,0.4); }
.cp-name { font-family: 'Clash Display', sans-serif; font-weight: 600; font-size: 0.95rem; }
.cp-status { font-size: 0.7rem; color: var(--green-bio); display:flex;align-items:center;gap:5px;margin-top:2px; }
.cp-close { margin-left: auto; background: none; border: none; color: var(--text-muted); font-size: 1.1rem; cursor: none; transition: color var(--dur-fast); padding: 4px; }
.cp-close:hover { color: var(--text-primary); }

.cp-body { padding: 18px; max-height: 260px; overflow-y: auto; display:flex;flex-direction:column;gap:14px; }
.cp-body::-webkit-scrollbar { width: 3px; }
.cp-body::-webkit-scrollbar-thumb { background: var(--forest-teal); border-radius: 3px; }

.cp-msg { display:flex;gap:8px;align-items:flex-end; }
.cp-msg.right { flex-direction:row-reverse; }
.cp-msg__av { width:24px;height:24px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.65rem;font-weight:700; }
.cp-msg__av--g { background:linear-gradient(135deg,var(--cyan-electric),var(--green-bio));color:var(--bg-void); }
.cp-msg__av--u { background:linear-gradient(135deg,var(--blue-vivid),var(--cyan-mid));color:white; }
.cp-msg__bubble {
  max-width: 230px; padding: 10px 14px;
  font-size: 0.82rem; line-height: 1.55;
  border-radius: 16px 16px 16px 4px;
  border: 1px solid var(--glass-border);
}
.cp-msg.right .cp-msg__bubble { border-radius: 16px 16px 4px 16px; background: linear-gradient(135deg, rgba(0,102,255,0.25), rgba(0,245,224,0.12)); }
.cp-msg__bubble--g { background: rgba(0,245,224,0.08); }
.cp-msg__media {
  max-width: 230px;
  background: rgba(0,245,224,0.06);
  border: 1px solid rgba(0,245,224,0.18);
  border-radius: 14px;
  overflow: hidden;
}
.cp-msg__media picture,
.cp-msg__media img { display: block; width: 100%; }
.cp-msg__media img { height: 110px; object-fit: cover; background: rgba(255,255,255,0.06); }
.cp-msg__media-cap {
  padding: 8px 10px;
  font-size: 0.74rem;
  line-height: 1.45;
  color: var(--text-secondary);
}
.cp-msg__media-cap strong { color: var(--text-primary); font-weight: 600; }

.cp-footer { padding: 14px 16px; border-top: 1px solid var(--glass-border); }
.cp-input-row { display:flex;gap:8px;align-items:center; }
.cp-input {
  flex:1; background: rgba(255,255,255,0.05);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-pill);
  padding: 9px 16px; color: var(--text-primary);
  font-size: 0.82rem; outline:none;
  transition: border-color var(--dur-fast);
  font-family: inherit;
}
.cp-input:focus { border-color: var(--glass-border-hi); }
.cp-input::placeholder { color: var(--text-muted); }
.cp-send { width:36px;height:36px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--cyan-electric),var(--green-bio));color:var(--bg-void);font-size:0.85rem;display:flex;align-items:center;justify-content:center;cursor:none;transition:all var(--dur-fast);flex-shrink:0; }
.cp-send:hover { transform:scale(1.1);box-shadow:0 0 15px rgba(0,245,224,0.5); }
.cp-mic { width:36px;height:36px;border-radius:50%;border:1px solid var(--glass-border);background:rgba(0,245,224,0.08);color:var(--cyan-electric);font-size:0.95rem;display:flex;align-items:center;justify-content:center;cursor:none;transition:all var(--dur-fast);flex-shrink:0; }
.cp-mic:hover { border-color:var(--glass-border-hi);background:rgba(0,245,224,0.15); }

/* ═══════════════════════════════════════════════════════
   PRIVACY / DATA POLICY SECTION
═══════════════════════════════════════════════════════ */
.privacy-section {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg,
    transparent 0%,
    rgba(0,102,255,0.04) 30%,
    rgba(0,107,112,0.06) 60%,
    transparent 100%
  );
  border-top: 1px solid var(--glass-border);
  border-bottom: 1px solid var(--glass-border);
}
.privacy-section::before {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 700px 400px at 10% 50%, rgba(0,102,255,0.07) 0%, transparent 70%),
    radial-gradient(ellipse 600px 350px at 90% 50%, rgba(0,245,224,0.06) 0%, transparent 70%);
  pointer-events:none;
}

/* Hero banner inside privacy section */
.priv-hero {
  display: flex; align-items: center; gap: 28px;
  padding: 36px 44px;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, rgba(0,102,255,0.12) 0%, rgba(0,245,224,0.08) 100%);
  border: 1px solid rgba(0,102,255,0.25);
  margin-bottom: 60px;
  backdrop-filter: blur(16px);
  position: relative; overflow: hidden;
}
.priv-hero::after {
  content:'';
  position: absolute; top: -50%; right: -80px;
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(0,102,255,0.15) 0%, transparent 70%);
  border-radius: 50%; filter: blur(30px); pointer-events:none;
}
.priv-hero__shield {
  width: 80px; height: 80px; flex-shrink: 0;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(0,102,255,0.25), rgba(0,245,224,0.15));
  border: 1.5px solid rgba(0,102,255,0.4);
  display: flex; align-items: center; justify-content: center;
  font-size: 2.2rem;
  box-shadow: 0 0 30px rgba(0,102,255,0.3);
  animation: shieldPulse 3s ease-in-out infinite;
}
@keyframes shieldPulse {
  0%,100%{box-shadow:0 0 30px rgba(0,102,255,0.3)}
  50%{box-shadow:0 0 55px rgba(0,102,255,0.55), 0 0 80px rgba(0,245,224,0.15)}
}
.priv-hero__text h3 {
  font-family:'Clash Display',sans-serif;
  font-size:clamp(1.3rem,2.5vw,1.8rem); font-weight:700; margin-bottom:8px;
}
.priv-hero__text p { font-size:0.9rem; color:var(--text-secondary); line-height:1.7; max-width:680px; }
.priv-hero__badges {
  margin-left: auto; flex-shrink: 0;
  display: flex; flex-direction: column; gap: 10px; align-items: flex-end;
}
@media(max-width:900px){
  .priv-hero { flex-direction:column; align-items:flex-start; }
  .priv-hero__badges { margin-left:0; align-items:flex-start; flex-direction:row; flex-wrap:wrap; }
}

/* Compliance badge */
.compliance-badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 16px;
  border-radius: var(--radius-pill);
  font-size: 0.75rem; font-weight: 700; letter-spacing: 0.06em;
  white-space: nowrap;
}
.compliance-badge--meta {
  background: linear-gradient(135deg, rgba(24,119,242,0.2), rgba(0,102,255,0.15));
  border: 1px solid rgba(24,119,242,0.4);
  color: #60a5fa;
}
.compliance-badge--gdpr {
  background: linear-gradient(135deg, rgba(0,245,224,0.1), rgba(0,255,157,0.08));
  border: 1px solid rgba(0,245,224,0.25);
  color: var(--cyan-electric);
}
.compliance-badge--iso {
  background: linear-gradient(135deg, rgba(255,170,0,0.1), rgba(255,200,50,0.06));
  border: 1px solid rgba(255,170,0,0.3);
  color: var(--amber-accent);
}

/* Privacy principle cards grid */
.priv-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 20px;
  margin-bottom: 50px;
}
@media(max-width:900px){ .priv-grid { grid-template-columns: repeat(2,1fr); } }
@media(max-width:500px){ .priv-grid { grid-template-columns: 1fr; } }

.priv-card {
  padding: 28px 24px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(14px);
  text-align: center;
  transition: all var(--dur-mid) var(--ease-spring);
  cursor: none; position: relative; overflow: hidden;
}
.priv-card::before {
  content:'';
  position:absolute; inset:0;
  background: radial-gradient(circle at 50% 0%, var(--priv-accent,rgba(0,245,224,0.08)) 0%, transparent 60%);
  opacity:0; transition:opacity var(--dur-mid);
}
.priv-card:hover { transform: translateY(-7px); border-color:var(--glass-border-hi); }
.priv-card:hover::before { opacity:1; }
.priv-card__icon {
  width: 56px; height: 56px; margin: 0 auto 18px;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
  border: 1px solid rgba(0,245,224,0.18);
  background: linear-gradient(135deg, rgba(0,245,224,0.1), rgba(0,255,157,0.06));
}
.priv-card h4 {
  font-family:'Clash Display',sans-serif;
  font-size:1rem; font-weight:600; margin-bottom:10px;
}
.priv-card p { font-size:0.8rem; color:var(--text-secondary); line-height:1.65; }

/* User rights section */
.rights-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 16px;
  margin-bottom: 44px;
}
@media(max-width:600px){ .rights-grid { grid-template-columns:1fr; } }

.right-item {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 18px 20px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  backdrop-filter: blur(10px);
  transition: border-color var(--dur-fast), transform var(--dur-fast);
  cursor: none;
}
.right-item:hover { border-color: var(--glass-border-hi); transform: translateX(5px); }
.right-item__num {
  width: 34px; height: 34px; flex-shrink:0;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan-electric), var(--green-bio));
  color: var(--bg-void);
  display:flex;align-items:center;justify-content:center;
  font-family:'Clash Display',sans-serif; font-size:0.82rem; font-weight:700;
}
.right-item h5 {
  font-family:'Clash Display',sans-serif;
  font-size:0.9rem; font-weight:600; margin-bottom:5px;
}
.right-item p { font-size:0.78rem; color:var(--text-secondary); line-height:1.6; }

/* Meta API compliance panel */
.meta-panel {
  padding: 40px;
  background: linear-gradient(135deg, rgba(24,119,242,0.1) 0%, rgba(0,102,255,0.08) 100%);
  border: 1px solid rgba(24,119,242,0.3);
  border-radius: var(--radius-xl);
  backdrop-filter: blur(16px);
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
  margin-bottom: 44px;
}
@media(max-width:768px){ .meta-panel { grid-template-columns:1fr; } }

.meta-panel__logo {
  display: flex; align-items: center; gap: 14px; margin-bottom: 20px;
}
.meta-logo-icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: linear-gradient(135deg, #1877f2, #0a5ab8);
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem; font-weight:700; color:white;
  font-family:'Clash Display',sans-serif;
  box-shadow: 0 0 20px rgba(24,119,242,0.4);
}
.meta-panel__title {
  font-family:'Clash Display',sans-serif;
  font-size:1.2rem; font-weight:700; margin-bottom:4px;
}
.meta-panel__sub { font-size:0.78rem; color:var(--text-muted); }
.meta-reqs { list-style:none; display:flex; flex-direction:column; gap:12px; }
.meta-req {
  display:flex; gap:10px; align-items:flex-start;
  font-size:0.83rem; line-height:1.6;
}
.meta-req::before {
  content:'\2713'; flex-shrink:0; margin-top:1px;
  width:18px;height:18px; border-radius:50%;
  background:rgba(24,119,242,0.15); color:#60a5fa;
  display:flex;align-items:center;justify-content:center;
  font-size:0.65rem; font-weight:700;
}
.meta-req span { color: var(--text-secondary); }
.meta-req strong { color: var(--text-primary); }

/* Retention table */
.retention-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.84rem;
}
.retention-table thead tr {
  background: rgba(0,245,224,0.06);
}
.retention-table th {
  padding: 12px 16px; text-align:left;
  font-family:'Clash Display',sans-serif;
  font-size:0.78rem; font-weight:600; letter-spacing:0.06em; text-transform:uppercase;
  color: var(--cyan-electric);
  border-bottom: 1px solid var(--glass-border);
}
.retention-table td {
  padding: 14px 16px;
  border-bottom: 1px solid var(--glass-border);
  color: var(--text-secondary);
  vertical-align: top;
}
.retention-table tr:last-child td { border-bottom: none; }
.retention-table tr:hover td { background: rgba(0,245,224,0.03); }
.ret-type { color: var(--text-primary); font-weight: 500; }
.ret-badge {
  display:inline-block; padding:3px 10px;
  border-radius:var(--radius-pill);
  font-size:0.7rem; font-weight:600;
}
.ret-badge--session { background:rgba(0,245,224,0.1); color:var(--cyan-electric); border:1px solid rgba(0,245,224,0.2); }
.ret-badge--short   { background:rgba(0,255,157,0.1); color:var(--green-bio); border:1px solid rgba(0,255,157,0.2); }
.ret-badge--medium  { background:rgba(255,170,0,0.1); color:var(--amber-accent); border:1px solid rgba(255,170,0,0.2); }
.ret-badge--long    { background:rgba(0,102,255,0.1); color:#60a5fa; border:1px solid rgba(0,102,255,0.25); }
.ret-badge--never   { background:rgba(255,80,80,0.08); color:#f87171; border:1px solid rgba(255,80,80,0.2); }

/* Action buttons area */
.priv-actions {
  display: flex; gap: 16px; flex-wrap: wrap; align-items: center;
  padding: 28px 32px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  backdrop-filter: blur(12px);
}
.priv-actions__text h4 { font-family:'Clash Display',sans-serif; font-size:1.05rem; font-weight:600; margin-bottom:6px; }
.priv-actions__text p  { font-size:0.82rem; color:var(--text-secondary); }
.priv-actions .btns { margin-left:auto; display:flex; gap:12px; flex-wrap:wrap; }
@media(max-width:600px){ .priv-actions { flex-direction:column; } .priv-actions .btns{margin-left:0;} }

/* Consent notice in chat footer */
.cp-consent {
  padding: 10px 16px 0;
  font-size: 0.7rem; color: var(--text-muted);
  line-height: 1.5; text-align: center;
  border-top: 1px solid var(--glass-border);
}
.cp-consent a { color: var(--cyan-electric); text-decoration: underline; cursor: none; }

/* ═══════════════════════════════════════════════════════
   PRIVACY POLICY FULL-PAGE MODAL
═══════════════════════════════════════════════════════ */
.policy-modal {
  position: fixed; inset: 0; z-index: 3000;
  background: rgba(2,12,16,0.92);
  backdrop-filter: blur(16px);
  display: flex; align-items: flex-start; justify-content: center;
  padding: 30px 20px;
  overflow-y: auto;
  opacity:0; pointer-events:none;
  transition: opacity var(--dur-mid);
}
.policy-modal.open { opacity:1; pointer-events:all; }

.policy-box {
  width: 100%; max-width: 860px;
  background: linear-gradient(160deg, rgba(10,38,64,0.99) 0%, rgba(4,20,32,0.99) 100%);
  border: 1px solid var(--glass-border-hi);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 40px 120px rgba(0,0,0,0.7);
  transform: translateY(20px);
  transition: transform var(--dur-mid) var(--ease-spring);
}
.policy-modal.open .policy-box { transform: translateY(0); }

.policy-header {
  display:flex; align-items:center; gap:16px;
  padding: 28px 36px 24px;
  border-bottom: 1px solid var(--glass-border);
  background: rgba(10,38,64,0.7);
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(20px);
}
.policy-header__icon {
  width: 46px; height: 46px; border-radius: 12px; flex-shrink:0;
  background: linear-gradient(135deg, rgba(0,102,255,0.3), rgba(0,245,224,0.2));
  border: 1px solid rgba(0,102,255,0.4);
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;
}
.policy-header h2 { font-family:'Clash Display',sans-serif; font-size:1.35rem; font-weight:700; }
.policy-header p { font-size:0.78rem; color:var(--text-muted); margin-top:3px; }
.policy-close {
  margin-left:auto; background:none; border:none;
  color:var(--text-muted); font-size:1.3rem; cursor:none;
  padding:8px; border-radius:8px; transition:all var(--dur-fast);
}
.policy-close:hover { color:var(--text-primary); background:rgba(255,255,255,0.06); }

/* Tabs */
.policy-tabs {
  display:flex; gap:0;
  padding: 0 36px;
  border-bottom: 1px solid var(--glass-border);
  overflow-x: auto;
  background: rgba(7,30,46,0.5);
}
.policy-tabs::-webkit-scrollbar { height:3px; }
.policy-tabs::-webkit-scrollbar-thumb { background:var(--forest-teal); border-radius:3px; }

.policy-tab {
  padding: 14px 20px;
  background: none; border: none;
  font-size: 0.82rem; font-weight: 500;
  color: var(--text-muted);
  white-space: nowrap; cursor:none;
  border-bottom: 2px solid transparent;
  transition: all var(--dur-fast);
  font-family: inherit;
}
.policy-tab:hover { color: var(--text-secondary); }
.policy-tab.active { color: var(--cyan-electric); border-bottom-color: var(--cyan-electric); }

/* Tab panels */
.policy-body { padding: 36px; }
.policy-panel { display:none; }
.policy-panel.active { display:block; }

.policy-panel h3 {
  font-family:'Clash Display',sans-serif;
  font-size:1.15rem; font-weight:700;
  color: var(--text-primary);
  margin: 28px 0 12px; padding-bottom: 8px;
  border-bottom: 1px solid var(--glass-border);
}
.policy-panel h3:first-child { margin-top:0; }
.policy-panel p { font-size:0.86rem; color:var(--text-secondary); line-height:1.8; margin-bottom:14px; }
.policy-panel ul { list-style:none; display:flex; flex-direction:column; gap:8px; margin-bottom:14px; }
.policy-panel ul li {
  display:flex; gap:10px; align-items:flex-start;
  font-size:0.84rem; color:var(--text-secondary); line-height:1.6;
}
.policy-panel ul li::before {
  content:'\203A'; color:var(--cyan-electric);
  font-weight:700; font-size:1rem; flex-shrink:0; margin-top:1px;
}
.policy-panel strong { color:var(--text-primary); font-weight:600; }
.policy-panel .highlight-box {
  padding:18px 22px;
  background: rgba(0,245,224,0.06);
  border: 1px solid rgba(0,245,224,0.15);
  border-radius: var(--radius-md);
  margin: 16px 0;
  font-size: 0.84rem; color:var(--text-secondary); line-height:1.75;
}
.policy-panel .warn-box {
  padding:18px 22px;
  background: rgba(255,170,0,0.06);
  border: 1px solid rgba(255,170,0,0.2);
  border-radius: var(--radius-md);
  margin: 16px 0;
  font-size: 0.84rem; color:var(--text-secondary); line-height:1.75;
}
.policy-panel .meta-box {
  padding:18px 22px;
  background: rgba(24,119,242,0.07);
  border: 1px solid rgba(24,119,242,0.2);
  border-radius: var(--radius-md);
  margin: 16px 0;
  font-size: 0.84rem; color:var(--text-secondary); line-height:1.75;
}

/* Deletion request form inside policy modal */
.deletion-form {
  padding: 24px;
  background: rgba(255,80,80,0.05);
  border: 1px solid rgba(255,80,80,0.2);
  border-radius: var(--radius-lg);
  margin-top: 20px;
}
.deletion-form h4 { font-family:'Clash Display',sans-serif; font-size:1rem; font-weight:600; margin-bottom:12px; color:#f87171; }
.del-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:var(--radius-pill);
  background:rgba(255,80,80,0.12); border:1px solid rgba(255,80,80,0.35);
  color:#f87171; font-size:0.85rem; font-weight:600;
  cursor:none; transition:all var(--dur-fast);
  font-family:inherit; margin-top:12px;
}
.del-btn:hover { background:rgba(255,80,80,0.2); border-color:rgba(255,80,80,0.55); }

.policy-footer-bar {
  padding: 20px 36px;
  border-top: 1px solid var(--glass-border);
  background: rgba(10,38,64,0.5);
  display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.policy-footer-bar p { font-size:0.75rem; color:var(--text-muted); }

/* Contact modal */
.modal-overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(2,12,16,0.85);
  backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity var(--dur-mid);
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal-box {
  width: 100%; max-width: 480px;
  background: linear-gradient(145deg, rgba(10,38,64,0.98), rgba(7,30,46,0.95));
  border: 1px solid var(--glass-border-hi);
  border-radius: var(--radius-xl);
  padding: 44px;
  box-shadow: var(--shadow-deep);
  transform: scale(0.95) translateY(20px);
  transition: all var(--dur-mid) var(--ease-spring);
}
.modal-overlay.open .modal-box { transform: scale(1) translateY(0); }
.modal-close { float: right; background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:none;transition:color var(--dur-fast); }
.modal-close:hover { color: var(--text-primary); }
.form-group { margin-bottom: 16px; }
.form-label { display:block;font-size:0.82rem;font-weight:500;color:var(--text-secondary);margin-bottom:6px; }
.form-input {
  width:100%; padding: 12px 16px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  color: var(--text-primary); font-size: 0.88rem;
  outline: none; transition: border-color var(--dur-fast);
  font-family: inherit;
}
.form-input:focus { border-color: var(--glass-border-hi); background: rgba(0,245,224,0.04); }
.form-input::placeholder { color: var(--text-muted); }
textarea.form-input { resize: vertical; min-height: 90px; }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .hero__grid { grid-template-columns: 1fr; }
  .hero__visual {
    display: block;
    margin-top: 28px;
  }
  .hero-phone {
    width: min(340px, 92vw);
  }
  .gigi-layout { grid-template-columns: 1fr; }
  .gigi-product-grid { grid-template-columns: 1fr; }
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .pricing-grid { grid-template-columns: 1fr; max-width: 420px; margin-left: auto; margin-right: auto; }
  .testimonials-grid { grid-template-columns: 1fr; }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid::before { display: none; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .products-grid { grid-template-columns: 1fr; }
  .logistics-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  html { font-size: 15px; }
  .container { padding: 0 16px; }
  .section-pad { padding: 64px 0; }
  .navbar { padding: 0 12px; }
  .navbar__inner { height: 64px; }
  .nav-logo { font-size: 1.35rem; gap: 8px; }
  .nav-logo__mark { width: 30px; height: 30px; border-radius: 8px; }
  .mobile-nav {
    padding: 88px 20px calc(28px + env(safe-area-inset-bottom));
    justify-content: flex-start;
    align-items: flex-start;
    gap: 1rem;
    overflow-y: auto;
  }
  .mobile-nav a { font-size: clamp(1.35rem, 7vw, 1.9rem); }
  .mobile-nav .btn { width: 100%; justify-content: center; }
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .services-grid { grid-template-columns: 1fr; }
  .pricing-grid { max-width: 100%; }
  .process-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding-top: 74px; }
  .hero__title { line-height: 0.98; }
  .hero__subtitle { font-size: 0.98rem; line-height: 1.7; }
  .hero__actions { gap: 10px; }
  .hero__actions .btn { flex: 1 1 100%; }
  .hero__proof {
    margin-top: 36px;
    padding-top: 24px;
    gap: 18px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .hero__stat-num { font-size: 1.7rem; }
  .hero-phone { width: min(340px, 100%); }
  .phone-messages { padding: 14px 12px; gap: 10px; }
  .pmsg__bubble, .gcw-msg__text, .cp-msg__bubble { max-width: 100%; }
  .chat-trigger {
    width: 56px;
    height: 56px;
    right: 16px;
    bottom: calc(16px + env(safe-area-inset-bottom));
  }
  .chat-popup {
    left: 12px;
    right: 12px;
    width: auto;
    bottom: calc(84px + env(safe-area-inset-bottom));
    max-height: calc(100vh - 110px - env(safe-area-inset-bottom));
  }
  .cp-body { max-height: min(44vh, 320px); }
  .cp-footer { padding-bottom: calc(14px + env(safe-area-inset-bottom)); }
  .gcw-body { padding: 16px; }
  .gcw-footer { padding: 12px 14px; gap: 8px; }
  .gcw-input { padding: 10px 14px; }
  .modal-box { padding: 30px 24px; margin: 20px; max-height: calc(100vh - 32px); overflow: auto; }
  .benefits-row { flex-direction: column; align-items: stretch; }
  .nav-actions .btn.btn-secondary { display: none; }
  .cta-actions { flex-direction: column; }
  .cta-actions .btn { width: 100%; justify-content: center; }
  .hero-phone__screen {
    height: 500px;
    min-height: 500px;
  }
  .blob { display: none; }
  .page-load-burst { animation-duration: 1.4s; opacity: 0.7; }
}
@media (max-width: 420px) {
  .container { padding: 0 12px; }
  .display-xl { font-size: clamp(2.25rem, 12vw, 2.7rem); }
  .display-lg { font-size: clamp(1.6rem, 8vw, 2rem); }
  .btn, .btn-lg { padding: 12px 20px; font-size: 0.9rem; }
  .hero-phone__screen { height: 430px; min-height: 430px; }
  .gigi-chat-window { height: 500px; max-height: min(72vh, 520px); }
  .chat-trigger { width: 52px; height: 52px; right: 12px; }
}
@media (max-height: 740px) and (max-width: 900px) {
  .hero-phone__screen { height: 400px; min-height: 400px; }
  .chat-popup { max-height: 78vh; }
}

/* Accessibility and mobile ergonomics */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
@media (hover: none), (pointer: coarse) {
  body, button,
  .service-card, .pricing-card, .testi-card, .gigi-feat, .product-item, .logistics-card,
  .chat-trigger, .cp-close, .cp-send, .cp-mic, .gcw-mic, .gcw-send, .footer-link-btn {
    cursor: auto !important;
  }
  .c-cursor {
    display: none !important;
  }
}
