:root {
  --bg: #04131a;
  --surface: rgba(10, 29, 38, 0.66);
  --line: rgba(132, 222, 255, 0.16);
  --text: #ecf9fb;
  --muted: #97b3bc;
  --cyan: #4bd3ff;
  --green: #34df93;
  --shadow: 0 32px 80px rgba(0, 0, 0, 0.35);
  --radius-xl: 28px;
  --radius-md: 16px;
  --container: min(1180px, calc(100vw - 32px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(circle at top left, rgba(57, 191, 243, 0.18), transparent 28%),
    radial-gradient(circle at top right, rgba(53, 223, 147, 0.16), transparent 24%),
    linear-gradient(180deg, #031117 0%, #05151b 55%, #071219 100%);
  color: var(--text);
  font-family: "Manrope", sans-serif;
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
.page-shell { position: relative; overflow: clip; }
.container { width: var(--container); margin: 0 auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 30;
  backdrop-filter: blur(16px);
  background: rgba(3, 17, 23, 0.62);
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
.nav-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  min-height: 82px;
}
.brand { display: inline-flex; align-items: center; }
.brand-logo {
  width: auto;
  height: 46px;
  filter: drop-shadow(0 14px 30px rgba(37, 177, 255, 0.18));
}
.site-nav { display: flex; align-items: center; gap: 22px; }
.site-nav a, .footer-links a {
  color: rgba(236, 249, 251, 0.78);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: color 180ms ease;
}
.site-nav a:hover, .footer-links a:hover { color: white; }
.nav-toggle, .mobile-nav { display: none; }

.cta-button, .secondary-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 0 24px;
  border-radius: 999px;
  font-weight: 800;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background-color 180ms ease;
}
.cta-button {
  color: #04131a;
  background: linear-gradient(135deg, #72e8ff 0%, #25cbff 52%, #39df9d 100%);
  box-shadow: 0 18px 42px rgba(37, 203, 255, 0.24);
}
.cta-button:hover, .secondary-button:hover { transform: translateY(-2px); }
.cta-button--small { min-height: 46px; padding-inline: 20px; font-size: 14px; }
.secondary-button {
  color: white;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.05);
}
.secondary-button:hover {
  border-color: rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.1);
}

.hero {
  position: relative;
  z-index: 5;
  min-height: calc(100vh - 82px);
  padding: 56px 0 48px;
}
.hero-layout {
  position: relative;
  z-index: 5;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
  align-items: center;
  gap: 48px;
}
.global-ambient {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: var(--container);
  height: 100%;
  overflow: hidden;
  pointer-events: none;
  z-index: 3;
}
.hero-ambient { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.site-footer { position: relative; z-index: 5; }
.mesh, .beam, .shape, .grid-layer { position: absolute; }
.mesh {
  border-radius: 999px;
  filter: blur(100px);
  opacity: 0.72;
  mix-blend-mode: screen;
}
.mesh-a {
  inset: auto auto 10% -8%;
  width: 34rem; height: 34rem;
  background: radial-gradient(circle, rgba(69, 213, 255, 0.45), transparent 68%);
  animation: drift-a 16s ease-in-out infinite;
}
.mesh-b {
  inset: -10% -8% auto auto;
  width: 30rem; height: 30rem;
  background: radial-gradient(circle, rgba(54, 223, 147, 0.34), transparent 70%);
  animation: drift-b 18s ease-in-out infinite;
}
.mesh-c {
  inset: 28% auto auto 36%;
  width: 24rem; height: 24rem;
  background: radial-gradient(circle, rgba(255, 206, 92, 0.16), transparent 72%);
  animation: pulse-float 12s ease-in-out infinite;
}
.beam {
  width: 44rem;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(114, 232, 255, 0.88), transparent);
  opacity: 0.7;
}
.beam-a { top: 18%; left: -12%; rotate: -18deg; animation: beam-sweep 9s linear infinite; }
.beam-b { bottom: 24%; right: -18%; rotate: 20deg; animation: beam-sweep 11s linear infinite reverse; }
.shape {
  border-radius: 28px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.04));
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.18);
}
.orb { border-radius: 999px; }
/* --- Figuras distribuidas por toda la página --- */
/* Section 1: Hero */
.orb-a { top: 2%; left: 68%; width: 90px; height: 90px; animation: wander-1 22s linear infinite; }
.orb-b { top: 8%; left: 18%; width: 60px; height: 60px; animation: wander-2 19s linear infinite; }
.cube-a { top: 4%; left: 45%; width: 54px; height: 54px; animation: wander-3 24s linear infinite; }
.ring-a {
  top: 10%; left: 55%;
  width: 120px; height: 120px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid rgba(114, 232, 255, 0.22);
  box-shadow: inset 0 0 0 18px rgba(255, 255, 255, 0.03);
  animation: wander-6 28s linear infinite;
}
/* Section 2: Metrics + Cómo funciona */
.cube-b { top: 16%; left: 78%; width: 44px; height: 44px; animation: wander-4 21s linear infinite; }
.chip-a { top: 18%; left: 32%; width: 120px; height: 42px; border-radius: 999px; animation: wander-5 26s linear infinite; }
.orb-c { top: 22%; left: 22%; width: 80px; height: 80px; animation: wander-7 20s linear infinite; }
.cube-c { top: 25%; left: 72%; width: 50px; height: 50px; animation: wander-8 23s linear infinite; }
/* Section 3: Seguridad */
.ring-b {
  top: 32%; left: 38%;
  width: 100px; height: 100px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid rgba(52, 223, 147, 0.18);
  box-shadow: inset 0 0 0 16px rgba(255, 255, 255, 0.03);
  animation: wander-9 25s linear infinite;
}
.chip-b { top: 35%; left: 62%; width: 110px; height: 38px; border-radius: 999px; animation: wander-10 27s linear infinite; }
.orb-d { top: 38%; left: 15%; width: 68px; height: 68px; animation: wander-1 18s linear infinite; }
.cube-d { top: 40%; left: 82%; width: 46px; height: 46px; animation: wander-3 20s linear infinite; }
/* Section 4: Beneficios */
.orb-e { top: 46%; left: 30%; width: 72px; height: 72px; animation: wander-4 24s linear infinite; }
.cube-e { top: 50%; left: 70%; width: 48px; height: 48px; animation: wander-7 22s linear infinite; }
.chip-c { top: 54%; left: 48%; width: 100px; height: 36px; border-radius: 999px; animation: wander-2 26s linear infinite; }
/* Section 5: Pricing */
.ring-c {
  top: 60%; left: 20%;
  width: 110px; height: 110px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid rgba(114, 232, 255, 0.18);
  box-shadow: inset 0 0 0 16px rgba(255, 255, 255, 0.03);
  animation: wander-8 30s linear infinite;
}
.orb-f { top: 64%; left: 74%; width: 64px; height: 64px; animation: wander-5 21s linear infinite; }
.cube-f { top: 68%; left: 42%; width: 42px; height: 42px; animation: wander-9 23s linear infinite; }
/* Section 6: Contacto + Footer */
.orb-g { top: 74%; left: 56%; width: 76px; height: 76px; animation: wander-6 19s linear infinite; }
.chip-d { top: 78%; left: 15%; width: 116px; height: 40px; border-radius: 999px; animation: wander-10 25s linear infinite; }
.ring-d {
  top: 84%; left: 70%;
  width: 96px; height: 96px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid rgba(52, 223, 147, 0.16);
  box-shadow: inset 0 0 0 14px rgba(255, 255, 255, 0.03);
  animation: wander-3 28s linear infinite;
}
.cube-g { top: 90%; left: 42%; width: 52px; height: 52px; animation: wander-1 22s linear infinite; }
.grid-layer {
  inset: -12% -12%;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.06) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: radial-gradient(circle at center, black 38%, transparent 88%);
  opacity: 0.18;
  transform: perspective(900px) rotateX(74deg) scale(1.4);
  animation: grid-shift 18s linear infinite;
}

.eyebrow, .section-kicker, .floating-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #8be5ff;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.eyebrow {
  margin-bottom: 24px;
  padding: 10px 16px;
  border-radius: 999px;
  width: fit-content;
  background: rgba(73, 185, 255, 0.08);
  border: 1px solid rgba(73, 185, 255, 0.18);
}
.eyebrow-dot {
  width: 8px; height: 8px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--cyan), var(--green));
  box-shadow: 0 0 0 6px rgba(75, 211, 255, 0.12);
}
.hero-copy h1, .section-heading h2, .cta-panel h2 {
  margin: 0;
  font-family: "Space Grotesk", sans-serif;
  letter-spacing: -0.05em;
}
.hero-copy h1 {
  max-width: 12ch;
  font-size: clamp(3.2rem, 8vw, 6.5rem);
  line-height: 0.95;
}
.hero-copy h1 span {
  display: block;
  color: transparent;
  background: linear-gradient(135deg, #72e8ff 0%, #44d9ff 35%, #3de09d 100%);
  -webkit-background-clip: text;
  background-clip: text;
}
.hero-text, .section-heading p, .feature-card p, .benefit-card p, .price-card p, .step-card p, .cta-panel p {
  color: var(--muted);
  line-height: 1.75;
}
.hero-text { max-width: 640px; margin: 28px 0 0; font-size: 1.1rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.hero-proof { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 16px; margin-top: 34px; }

.proof-pill, .metric, .step-card, .feature-card, .benefit-card, .price-card, .cta-panel__inner, .floating-card {
  position: relative;
  z-index: 5;
  border: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.03));
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  transition: transform 280ms ease, border-color 280ms ease, box-shadow 280ms ease, background 280ms ease;
}
.section-heading, .hero-copy, .hero-actions, .hero-proof {
  position: relative;
  z-index: 5;
}
.proof-pill:hover, .metric:hover, .step-card:hover, .feature-card:hover, .benefit-card:hover, .price-card:hover, .floating-card:hover {
  transform: translateY(-4px);
  border-color: rgba(114, 232, 255, 0.35);
  box-shadow: 0 32px 80px rgba(0, 0, 0, 0.35), 0 0 20px rgba(75, 211, 255, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.05));
}
.proof-pill { padding: 16px 18px; border-radius: var(--radius-md); }
.proof-pill strong { display: block; margin-bottom: 6px; font-size: 0.95rem; }
.proof-pill span { color: var(--muted); font-size: 0.92rem; line-height: 1.5; }

.hero-visual {
  position: relative;
  min-height: 720px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.phone-shell {
  position: relative;
  z-index: 5;
  width: min(100%, 290px);
  margin-inline: auto;
  padding: 8px;
  border-radius: 52px;
  background: linear-gradient(170deg, #2a3439 0%, #161e22 18%, #0c1215 50%, #080d10 100%);
  box-shadow:
    0 42px 100px rgba(0, 0, 0, 0.55),
    0 8px 32px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.22),
    inset 0 -1px 0 rgba(255, 255, 255, 0.06),
    inset 1px 0 0 rgba(255, 255, 255, 0.08),
    inset -1px 0 0 rgba(255, 255, 255, 0.08);
}
.phone-shell::before {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  pointer-events: none;
}
.phone-shell::after {
  content: "";
  position: absolute;
  inset: 6px;
  border-radius: 48px;
  border: 1px solid rgba(0, 0, 0, 0.5);
  pointer-events: none;
}
.phone-shell__glow {
  position: absolute;
  inset: auto 15% -8% 15%;
  height: 120px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(75, 211, 255, 0.3), transparent 68%);
  filter: blur(32px);
  pointer-events: none;
}
.phone-btn {
  position: absolute;
  background: linear-gradient(180deg, #1e2a2f 0%, #0e1518 100%);
  border-radius: 2px;
  z-index: 3;
}
.phone-btn--vol-up {
  left: -3px;
  top: 148px;
  width: 3px;
  height: 32px;
  border-radius: 2px 0 0 2px;
  box-shadow: -1px 0 0 rgba(255, 255, 255, 0.08);
}
.phone-btn--vol-down {
  left: -3px;
  top: 192px;
  width: 3px;
  height: 32px;
  border-radius: 2px 0 0 2px;
  box-shadow: -1px 0 0 rgba(255, 255, 255, 0.08);
}
.phone-btn--power {
  right: -3px;
  top: 172px;
  width: 3px;
  height: 48px;
  border-radius: 0 2px 2px 0;
  box-shadow: 1px 0 0 rgba(255, 255, 255, 0.08);
}
.device-card {
  position: relative;
  width: 100%;
  min-height: 612px;
  border-radius: 44px;
  overflow: hidden;
  background: #000;
}
.device-screen {
  position: relative;
  height: 100%;
  min-height: 612px;
  padding: 0 12px 12px;
  border-radius: 44px;
  background:
    radial-gradient(circle at top, rgba(80, 209, 255, 0.12), transparent 36%),
    linear-gradient(180deg, #08131a 0%, #071017 100%);
  overflow: hidden;
}
.status-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 24px 0;
  height: 52px;
  position: relative;
  z-index: 3;
}
.status-bar__time {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.02em;
  min-width: 42px;
}
.dynamic-island {
  width: 120px;
  height: 34px;
  border-radius: 999px;
  background: #000;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.04);
  position: absolute;
  left: 50%;
  top: 10px;
  transform: translateX(-50%);
}
.status-bar__icons {
  display: flex;
  align-items: center;
  gap: 5px;
  min-width: 42px;
  justify-content: flex-end;
}
.status-icon {
  width: 16px;
  height: 12px;
  color: var(--text);
  opacity: 0.9;
}
.status-battery {
  width: 24px;
  height: 11px;
  border: 1.5px solid rgba(236, 249, 251, 0.6);
  border-radius: 3px;
  padding: 1.5px;
  position: relative;
}
.status-battery::after {
  content: "";
  position: absolute;
  right: -4px;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
  height: 5px;
  border-radius: 0 1px 1px 0;
  background: rgba(236, 249, 251, 0.5);
}
.status-battery__fill {
  width: 78%;
  height: 100%;
  border-radius: 1.5px;
  background: var(--green);
}
.home-indicator {
  width: 134px;
  height: 5px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.25);
  margin: 14px auto 8px;
}
.device-topbar { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; padding: 4px 2px 0; }
.device-camera {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(114, 232, 255, 0.24), rgba(61, 224, 157, 0.26));
  border: 1px solid rgba(255, 255, 255, 0.14);
  flex-shrink: 0;
}
.device-topbar h2 { margin: 0; font-size: 0.95rem; }
.device-topbar p { margin: 2px 0 0; color: var(--muted); font-size: 0.82rem; }
.chat-stack { display: grid; gap: 12px; height: 100%; }
.chat-bubble, .scan-ticket, .pin-card {
  position: relative;
  z-index: 1;
  border-radius: 20px;
  padding: 14px;
}
.chat-bubble--out {
  margin-left: auto;
  max-width: 82%;
  color: #08303d;
  background: linear-gradient(135deg, #66e2ff, #4fd6ff);
  font-size: 0.95rem;
  line-height: 1.45;
}
.chat-bubble--in { max-width: 86%; background: rgba(255, 255, 255, 0.06); }
.chat-bubble strong, .scan-ticket__meta strong, .pin-card strong { display: block; margin-bottom: 6px; }
.chat-bubble span, .scan-ticket__meta span, .pin-card span { color: var(--muted); line-height: 1.45; }
.scan-ticket { display: flex; align-items: center; gap: 14px; background: rgba(255, 255, 255, 0.06); }
.scan-ticket__qr {
  width: 78px;
  height: 78px;
  flex-shrink: 0;
  border-radius: 12px;
  object-fit: cover;
}
.scan-ticket__meta { min-width: 0; }
.pin-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: linear-gradient(135deg, rgba(52, 223, 147, 0.16), rgba(75, 211, 255, 0.1));
}
.pin-card small { color: rgba(236, 249, 251, 0.7); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.72rem; }
.pin-card strong { font-size: 2.25rem; line-height: 1; }
.floating-cards-mobile { display: contents; }
.floating-card { position: absolute; padding: 18px 20px; border-radius: 22px; }
.floating-card--left {
  left: 12px;
  top: 110px;
  width: 178px;
  animation: float-card 8s ease-in-out infinite;
}
.floating-card--right {
  right: 12px;
  left: auto;
  top: 430px;
  width: 188px;
  animation: float-card 9s ease-in-out infinite reverse;
}
.floating-card strong { display: block; margin: 10px 0 8px; font-size: 1rem; }
.floating-card p { margin: 0; color: var(--muted); line-height: 1.6; }

.metrics { padding: 0 0 52px; position: relative; z-index: 5; }
.metrics-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
.metric { padding: 26px 24px; border-radius: 24px; }
.metric strong {
  display: block;
  margin-bottom: 8px;
  font-size: clamp(2.3rem, 4vw, 3.5rem);
  font-family: "Space Grotesk", sans-serif;
}
.metric span { color: var(--muted); line-height: 1.6; }

.section { position: relative; padding: 110px 0; z-index: 5; }
.section--dark, .section--pricing { background: linear-gradient(180deg, rgba(7, 23, 31, 0.55), rgba(4, 15, 21, 0.65)); }
.section-heading { max-width: 760px; margin: 0 auto 42px; text-align: center; }
.section-heading--left { margin-inline: 0; text-align: left; }
.section-heading h2, .cta-panel h2 { font-size: clamp(2.3rem, 5vw, 4.4rem); line-height: 0.98; }
.section-heading p, .cta-panel p { margin: 18px 0 0; font-size: 1.02rem; }
.steps-grid { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 18px; }
.step-card { padding: 24px; border-radius: 24px; }
.step-card__index {
  display: inline-flex;
  margin-bottom: 18px;
  color: rgba(255, 255, 255, 0.22);
  font-size: 2.8rem;
  font-family: "Space Grotesk", sans-serif;
  font-weight: 700;
}
.step-card h3, .feature-card h3, .benefit-card h3, .price-card__name { margin: 0 0 10px; font-size: 1.05rem; }
.security-layout { display: grid; gap: 32px; }
.feature-grid, .benefit-grid, .pricing-grid { display: grid; gap: 18px; }
.pricing-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.feature-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.benefit-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.feature-card, .benefit-card, .price-card { padding: 24px; border-radius: 24px; }
.price-card { position: relative; display: flex; flex-direction: column; }
.price-card--featured {
  border-color: rgba(114, 232, 255, 0.4);
  background:
    radial-gradient(circle at top, rgba(114, 232, 255, 0.16), transparent 42%),
    linear-gradient(180deg, rgba(17, 52, 66, 0.92), rgba(7, 22, 29, 0.96));
  transform: translateY(-10px);
}
.price-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.price-card__header .price-card__name { margin: 0; }
.price-card__badge {
  display: inline-flex;
  align-self: flex-start;
  margin-bottom: 0;
  padding: 8px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #34df93, #2bc47e);
  color: #04131a;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.price-card__amount {
  display: block;
  margin-bottom: 8px;
  font-size: 3rem;
  font-family: "Space Grotesk", sans-serif;
}
.price-card ul {
  display: grid;
  gap: 10px;
  margin: 18px 0 24px;
  padding: 0;
  color: var(--muted);
  list-style: none;
}
.price-card li {
  position: relative;
  padding-left: 18px;
  line-height: 1.6;
}
.price-card li::before {
  content: "";
  position: absolute;
  top: 10px;
  left: 0;
  width: 7px; height: 7px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--cyan), var(--green));
}
.price-card .secondary-button, .price-card .cta-button { margin-top: auto; }
.cta-panel__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding: 36px;
  border-radius: 32px;
  background:
    radial-gradient(circle at top left, rgba(114, 232, 255, 0.12), transparent 30%),
    radial-gradient(circle at bottom right, rgba(52, 223, 147, 0.12), transparent 26%),
    linear-gradient(135deg, rgba(8, 31, 42, 0.92), rgba(6, 20, 27, 0.98));
}
.cta-panel__actions { display: flex; flex-wrap: wrap; gap: 12px; }

.site-footer {
  padding: 24px 0 42px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.footer-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.brand--footer .brand-logo { height: 40px; }
.footer-links { display: flex; flex-wrap: wrap; gap: 18px; }
.footer-copy { margin: 0; color: rgba(151, 179, 188, 0.7); font-size: 0.92rem; }

.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 700ms ease, transform 700ms ease;
}
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@keyframes drift-a { 0%,100% { transform: translate3d(0,0,0) scale(1); } 50% { transform: translate3d(40px,-34px,0) scale(1.12); } }
@keyframes drift-b { 0%,100% { transform: translate3d(0,0,0) scale(1); } 50% { transform: translate3d(-48px,36px,0) scale(1.08); } }
@keyframes pulse-float { 0%,100% { transform: translate3d(0,0,0) scale(.96); opacity: .4; } 50% { transform: translate3d(12px,-18px,0) scale(1.1); opacity: .82; } }
@keyframes beam-sweep { 0% { transform: translateX(-12%) scaleX(.8); opacity: 0; } 15%,85% { opacity: .72; } 100% { transform: translateX(44%) scaleX(1.05); opacity: 0; } }
@keyframes orbit-left { 0%,100% { transform: translate3d(0,0,0); } 25% { transform: translate3d(-24px,20px,0); } 50% { transform: translate3d(8px,52px,0); } 75% { transform: translate3d(28px,12px,0); } }
@keyframes orbit-right { 0%,100% { transform: translate3d(0,0,0) scale(1); } 40% { transform: translate3d(22px,-20px,0) scale(1.08); } 70% { transform: translate3d(-12px,-42px,0) scale(.94); } }
@keyframes spin-drift { 0%,100% { transform: translate3d(0,0,0) rotate(18deg); } 50% { transform: translate3d(22px,-34px,0) rotate(110deg); } }
@keyframes spin-drift-rev { 0%,100% { transform: translate3d(0,0,0) rotate(-24deg); } 50% { transform: translate3d(-28px,24px,0) rotate(-130deg); } }
@keyframes chip-drift { 0%,100% { transform: translate3d(0,0,0) rotate(0); } 50% { transform: translate3d(-34px,20px,0) rotate(-12deg); } }
@keyframes ring-pulse { 0%,100% { transform: scale(.92); opacity: .42; } 50% { transform: scale(1.08); opacity: .88; } }
@keyframes grid-shift { from { transform: perspective(900px) rotateX(74deg) scale(1.4) translateY(0); } to { transform: perspective(900px) rotateX(74deg) scale(1.4) translateY(48px); } }
@keyframes float-card { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }

/* Continuous wander animations — no bounce, no reverse */
@keyframes wander-1 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 20% { transform: translate3d(18px,-22px,0) rotate(38deg); } 40% { transform: translate3d(-14px,-8px,0) rotate(95deg); } 60% { transform: translate3d(24px,16px,0) rotate(178deg); } 80% { transform: translate3d(-8px,26px,0) rotate(270deg); } 100% { transform: translate3d(0,0,0) rotate(360deg); } }
@keyframes wander-2 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 25% { transform: translate3d(-20px,14px,0) rotate(-45deg); } 50% { transform: translate3d(12px,28px,0) rotate(-120deg); } 75% { transform: translate3d(22px,-18px,0) rotate(-240deg); } 100% { transform: translate3d(0,0,0) rotate(-360deg); } }
@keyframes wander-3 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 16% { transform: translate3d(26px,10px,0) rotate(72deg); } 33% { transform: translate3d(-6px,30px,0) rotate(144deg); } 50% { transform: translate3d(-24px,6px,0) rotate(216deg); } 66% { transform: translate3d(-10px,-22px,0) rotate(288deg); } 83% { transform: translate3d(16px,-14px,0) rotate(340deg); } 100% { transform: translate3d(0,0,0) rotate(360deg); } }
@keyframes wander-4 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 20% { transform: translate3d(-16px,-24px,0) rotate(55deg); } 40% { transform: translate3d(20px,-10px,0) rotate(130deg); } 60% { transform: translate3d(8px,22px,0) rotate(210deg); } 80% { transform: translate3d(-22px,12px,0) rotate(295deg); } 100% { transform: translate3d(0,0,0) rotate(360deg); } }
@keyframes wander-5 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 25% { transform: translate3d(14px,20px,0) rotate(-60deg); } 50% { transform: translate3d(-18px,-6px,0) rotate(-150deg); } 75% { transform: translate3d(10px,-26px,0) rotate(-260deg); } 100% { transform: translate3d(0,0,0) rotate(-360deg); } }
@keyframes wander-6 { 0% { transform: translate3d(0,0,0) scale(0.94); } 20% { transform: translate3d(22px,-16px,0) scale(1.04); } 40% { transform: translate3d(-10px,24px,0) scale(0.96); } 60% { transform: translate3d(-26px,-8px,0) scale(1.06); } 80% { transform: translate3d(8px,-20px,0) scale(0.92); } 100% { transform: translate3d(0,0,0) scale(0.94); } }
@keyframes wander-7 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 14% { transform: translate3d(-12px,18px,0) rotate(50deg); } 28% { transform: translate3d(20px,24px,0) rotate(110deg); } 42% { transform: translate3d(28px,-4px,0) rotate(165deg); } 57% { transform: translate3d(6px,-26px,0) rotate(220deg); } 71% { transform: translate3d(-18px,-16px,0) rotate(280deg); } 85% { transform: translate3d(-24px,8px,0) rotate(330deg); } 100% { transform: translate3d(0,0,0) rotate(360deg); } }
@keyframes wander-8 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 33% { transform: translate3d(-20px,-18px,0) rotate(90deg); } 66% { transform: translate3d(16px,22px,0) rotate(210deg); } 100% { transform: translate3d(0,0,0) rotate(360deg); } }
@keyframes wander-9 { 0% { transform: translate3d(0,0,0) scale(0.96); } 25% { transform: translate3d(18px,14px,0) scale(1.08); } 50% { transform: translate3d(-14px,26px,0) scale(0.92); } 75% { transform: translate3d(-22px,-12px,0) scale(1.04); } 100% { transform: translate3d(0,0,0) scale(0.96); } }
@keyframes wander-10 { 0% { transform: translate3d(0,0,0) rotate(0deg); } 20% { transform: translate3d(24px,-14px,0) rotate(72deg); } 40% { transform: translate3d(-8px,-28px,0) rotate(144deg); } 60% { transform: translate3d(-26px,10px,0) rotate(216deg); } 80% { transform: translate3d(6px,24px,0) rotate(288deg); } 100% { transform: translate3d(0,0,0) rotate(360deg); } }

@media (max-width: 1120px) {
  .hero-layout, .cta-panel__inner, .footer-row { grid-template-columns: 1fr; display: grid; }
  .hero-visual { max-width: 600px; margin: 0 auto; }
  .phone-shell { margin: 0 auto; }
  .floating-card--left { left: 0; width: 160px; top: 80px; }
  .floating-card--right { right: 0; left: auto; top: 380px; width: 170px; }
  .hero-proof, .feature-grid, .benefit-grid, .steps-grid, .metrics-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
  .site-nav, .cta-button--small { display: none; }
  .nav-toggle {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
    width: 48px;
    height: 48px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    color: white;
  }
  .nav-toggle span {
    width: 20px;
    height: 2px;
    margin: 0 auto;
    background: white;
    border-radius: 999px;
    transition: transform 180ms ease, opacity 180ms ease;
  }
  .site-header.is-open .nav-toggle span:first-child { transform: translateY(4px) rotate(45deg); }
  .site-header.is-open .nav-toggle span:last-child { transform: translateY(-4px) rotate(-45deg); }
  .mobile-nav {
    display: grid;
    gap: 14px;
    max-height: 0;
    overflow: hidden;
    padding: 0 16px;
    background: rgba(3, 17, 23, 0.94);
    transition: max-height 240ms ease, padding 240ms ease, border-color 240ms ease;
  }
  .site-header.is-open .mobile-nav {
    max-height: 420px;
    padding: 0 16px 18px;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
  }
  .mobile-nav a:not(.cta-button) { color: rgba(236, 249, 251, 0.82); font-weight: 700; }
  .hero { min-height: auto; padding-top: 34px; }
  .hero-layout, .hero-proof, .metrics-grid, .steps-grid, .feature-grid, .benefit-grid, .pricing-grid, .cta-panel__inner, .footer-row {
    display: grid;
    grid-template-columns: 1fr;
  }
  .hero-visual { min-height: auto; display: flex; flex-direction: column; align-items: center; }
  .floating-cards-mobile { display: none !important; }
  .phone-shell {
    width: min(100%, 280px);
    padding: 8px;
  }
  .device-card {
    min-height: 520px;
  }
  .device-screen {
    min-height: 520px;
  }
}
@media (max-width: 560px) {
  .brand-logo { height: 38px; }
  .hero-copy h1 { font-size: 2.8rem; }
  .hero-text, .section-heading p, .cta-panel p { font-size: 0.98rem; }
  .device-topbar { align-items: flex-start; }
  .floating-card--left,
  .floating-card--right {
    max-width: none;
    width: auto;
  }
  .scan-ticket, .pin-card { flex-direction: column; align-items: flex-start; gap: 10px; }
  .metric, .step-card, .feature-card, .benefit-card, .price-card, .cta-panel__inner { padding: 20px; }
}
