:root {
  --navy: #0b1320;
  --night: #020814;
  --panel: #101b2c;
  --panel-2: #132235;
  --line: rgba(255, 255, 255, .14);
  --white: #ffffff;
  --muted: #aab6c7;
  --lime: #a6e400;
  --ink: #07111f;
  --soft: #f1f3f5;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Poppins, Inter, "Segoe UI", Arial, sans-serif;
  background:
    radial-gradient(circle at 8% 18%, rgba(166, 228, 0, .065), transparent 22rem),
    radial-gradient(circle at 88% 36%, rgba(53, 145, 255, .08), transparent 30rem),
    var(--night);
  color: var(--white);
  line-height: 1.55;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
:where(a, button, input, select, textarea):focus-visible {
  outline: 3px solid var(--lime);
  outline-offset: 3px;
}
p, h1, h2, h3 { margin-top: 0; }
dl, dt, dd { margin: 0; }
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
}
.wrap { width: min(1120px, calc(100% - 36px)); margin: 0 auto; }

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(2, 8, 20, .92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}

.nav {
  min-height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 950;
  white-space: nowrap;
}

.brand img {
  width: 50px;
  height: 50px;
  object-fit: cover;
  border-radius: 8px;
}

.brand span, .lime, h1 span, h2 span { color: var(--lime); }

.nav-links {
  display: flex;
  align-items: center;
  gap: 18px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 850;
}

.nav-links a:hover { color: var(--white); }

.button, .ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 12px 16px;
  border-radius: 8px;
  font-weight: 950;
}

.button {
  position: relative;
  overflow: hidden;
  background: var(--lime);
  color: var(--ink);
  box-shadow: 0 12px 30px rgba(166, 228, 0, .14);
  transition: transform .22s ease, box-shadow .22s ease;
}

.button::after {
  content: "";
  position: absolute;
  width: 70px;
  height: 140%;
  left: -96px;
  top: -20%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .46), transparent);
  transform: skewX(-18deg);
  animation: button-shine 4.8s ease-in-out infinite;
}

.button:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 38px rgba(166, 228, 0, .22);
}
.button:active, .ghost:active { transform: translateY(1px); }
.ghost { border: 1px solid rgba(255,255,255,.22); color: var(--white); background: rgba(255,255,255,.06); }
.ghost:hover { border-color: rgba(166,228,0,.55); color: var(--lime); }

.hero {
  position: relative;
  overflow: hidden;
  padding: 86px 0 64px;
  background:
    linear-gradient(90deg, rgba(2,8,20,.98), rgba(2,8,20,.78) 52%, rgba(2,8,20,.64)),
    url("/assets/logos/p2l-logo-stacked-full.png") center right 6% / min(500px, 48vw) auto no-repeat,
    radial-gradient(circle at 50% 10%, #102746, var(--night) 64%);
}

.hero::after, .grid-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}

.hero-motion-layer {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.ambient-orb {
  position: absolute;
  border: 1px solid rgba(166, 228, 0, .16);
  border-radius: 50%;
  box-shadow: inset 0 0 80px rgba(53, 145, 255, .06), 0 0 70px rgba(166, 228, 0, .04);
}

.ambient-orb-one {
  width: 320px;
  height: 320px;
  right: 13%;
  top: 7%;
  animation: orbit-drift 16s linear infinite;
}

.ambient-orb-two {
  width: 180px;
  height: 180px;
  right: 32%;
  bottom: -70px;
  border-color: rgba(84, 167, 255, .15);
  animation: orbit-drift-reverse 12s linear infinite;
}

.ambient-beam {
  position: absolute;
  width: 44vw;
  height: 1px;
  right: -7%;
  top: 43%;
  background: linear-gradient(90deg, transparent, rgba(166, 228, 0, .3), transparent);
  transform: rotate(-13deg);
  animation: beam-glide 7s ease-in-out infinite;
}

.hero-content { position: relative; z-index: 1; max-width: 730px; }
.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--lime);
  font-size: 13px;
  font-weight: 950;
  text-transform: uppercase;
}
.eyebrow::before { content: ""; width: 40px; height: 3px; background: var(--lime); }

h1 {
  font-size: clamp(42px, 7vw, 82px);
  line-height: .98;
  margin: 22px 0 20px;
  max-width: 780px;
  letter-spacing: 0;
}

h2 {
  font-size: clamp(30px, 4.8vw, 54px);
  line-height: 1.03;
  margin-bottom: 12px;
  letter-spacing: 0;
}

.lead {
  color: #d7e3f5;
  font-size: clamp(18px, 2vw, 22px);
  max-width: 700px;
}

.actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.section { padding: 70px 0; position: relative; }
.section.alt { background: #07111f; }
.section-head { max-width: 760px; margin-bottom: 28px; }
.section-head p { color: var(--muted); font-size: 18px; }

.grid-2, .grid-3, .grid-4 { display: grid; gap: 18px; }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.card {
  position: relative;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: linear-gradient(145deg, rgba(17, 34, 57, .86), rgba(5, 15, 29, .86));
  padding: 24px;
  box-shadow: 0 20px 55px rgba(0, 0, 0, .16), inset 0 1px rgba(255, 255, 255, .035);
  transition: translate .24s ease, border-color .24s ease, box-shadow .24s ease;
}

.card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(120deg, transparent 20%, rgba(255, 255, 255, .045), transparent 64%);
  opacity: 0;
  pointer-events: none;
  transform: translateX(-28%);
  transition: opacity .24s ease, transform .45s ease;
}

.card.highlight {
  border-color: rgba(166,228,0,.62);
  background: linear-gradient(145deg, rgba(31, 63, 56, .86), rgba(9, 25, 36, .92));
}

.card:hover {
  translate: 0 -6px;
  border-color: rgba(166, 228, 0, .48);
  box-shadow: 0 28px 68px rgba(0, 0, 0, .24), 0 0 45px rgba(166, 228, 0, .045);
}

.card:hover::after { opacity: 1; transform: translateX(12%); }

.card h3 { font-size: 22px; line-height: 1.2; margin-bottom: 10px; }
.card h2 { font-size: clamp(22px, 2.8vw, 30px); line-height: 1.12; }
.card p, .card li { color: var(--muted); }
.card ul { margin: 14px 0 0; padding-left: 20px; }
.card li + li { margin-top: 8px; }

.flow-card { margin-top: 18px; }
.flow-card > p { max-width: 680px; }

.flow-list {
  display: grid;
  gap: 14px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
  counter-reset: flow;
}

.flow-list li {
  counter-increment: flow;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}

.flow-list li + li { margin-top: 0; }

.flow-list li::before {
  content: counter(flow);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--lime);
  color: var(--ink);
  font-weight: 950;
  line-height: 1;
}

.flow-list strong { display: block; color: var(--white); margin-bottom: 3px; }
.flow-list span { color: var(--muted); }

.prep-card {
  margin-top: 18px;
  background: rgba(166,228,0,.075);
  border-color: rgba(166,228,0,.34);
}

.prep-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.prep-list li {
  min-height: 62px;
  display: flex;
  align-items: center;
  border: 1px solid rgba(166,228,0,.28);
  border-radius: 8px;
  padding: 12px;
  color: #e7f2ff;
  background: rgba(2,8,20,.28);
  font-weight: 850;
}

.pill-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.pill {
  border: 1px solid rgba(166,228,0,.28);
  border-radius: 999px;
  padding: 6px 10px;
  color: #d9e7bc;
  background: rgba(166,228,0,.07);
  font-size: 12px;
  font-weight: 850;
}

.pill-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

/* Premium secondary-page patterns */
.section-kicker {
  margin: 0 0 10px;
  color: var(--lime);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .15em;
  text-transform: uppercase;
}

.hero-stack {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, .88fr);
  gap: 40px;
  align-items: center;
}

.hero-dashboard {
  --dashboard-rotate-x: 3deg;
  --dashboard-rotate-y: -7deg;
  position: relative;
  min-height: 410px;
  border: 1px solid rgba(166, 228, 0, .24);
  border-radius: 24px;
  padding: 22px;
  background:
    linear-gradient(145deg, rgba(20, 48, 82, .78), rgba(5, 15, 31, .96)),
    rgba(2, 8, 20, .8);
  box-shadow: 0 34px 85px rgba(0, 0, 0, .32), inset 0 1px rgba(255, 255, 255, .1);
  transform: perspective(900px) rotateY(var(--dashboard-rotate-y)) rotateX(var(--dashboard-rotate-x));
  overflow: hidden;
  animation: dashboard-drift 7.2s ease-in-out infinite;
}

.hero-dashboard::before,
.hero-dashboard::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.hero-dashboard::before {
  width: 290px;
  height: 290px;
  right: -80px;
  top: -55px;
  border: 1px solid rgba(166, 228, 0, .3);
  box-shadow: 0 0 75px rgba(166, 228, 0, .11), inset 0 0 65px rgba(53, 145, 255, .1);
}

.hero-dashboard::after {
  width: 190px;
  height: 190px;
  left: -60px;
  bottom: -75px;
  border: 1px solid rgba(53, 145, 255, .28);
}

.dashboard-top,
.dashboard-stat-grid,
.signal-row,
.step-grid,
.service-link-grid {
  display: grid;
  gap: 12px;
}

.dashboard-top {
  position: relative;
  z-index: 1;
  grid-template-columns: 1fr auto;
  align-items: center;
  border-bottom: 1px solid var(--line);
  padding-bottom: 16px;
}

.dashboard-top strong,
.dashboard-stat dd,
.signal-chip dd {
  color: var(--white);
  font-weight: 950;
}

.dashboard-live {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--lime);
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .14em;
  text-transform: uppercase;
}

.dashboard-live::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 0 rgba(166, 228, 0, .35);
  animation: live-pulse 2s ease-out infinite;
}

.dashboard-stat-grid {
  position: relative;
  z-index: 1;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 28px;
}

.dashboard-stat,
.signal-chip {
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 12px;
  padding: 14px;
  background: rgba(2, 8, 20, .52);
  transition: translate .24s ease, border-color .24s ease, background .24s ease;
}

.dashboard-stat:hover,
.signal-chip:hover {
  border-color: rgba(166, 228, 0, .42);
  background: rgba(8, 27, 43, .82);
  translate: 0 -5px;
}

.dashboard-stat dt,
.signal-chip dt {
  display: block;
  color: var(--muted);
  font-size: 12px;
}

.dashboard-stat dd {
  display: block;
  margin-top: 7px;
  color: var(--lime);
  font-size: 27px;
  line-height: 1;
}

.dashboard-bars {
  position: relative;
  z-index: 1;
  display: flex;
  height: 96px;
  gap: 9px;
  align-items: end;
  margin-top: 24px;
}

.dashboard-bars span {
  flex: 1;
  min-height: 22px;
  border-radius: 7px 7px 2px 2px;
  background: linear-gradient(180deg, var(--lime), rgba(83, 153, 61, .32));
  box-shadow: 0 0 22px rgba(166, 228, 0, .16);
  transform-origin: bottom;
  animation: bar-breathe 3.6s ease-in-out infinite;
}

.dashboard-bars span:nth-child(2) { animation-delay: -.45s; }
.dashboard-bars span:nth-child(3) { animation-delay: -.9s; }
.dashboard-bars span:nth-child(4) { animation-delay: -1.35s; }
.dashboard-bars span:nth-child(5) { animation-delay: -1.8s; }
.dashboard-bars span:nth-child(6) { animation-delay: -2.25s; }

.signal-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 18px;
}

.signal-chip dd { display: block; margin-top: 5px; color: var(--lime); }

.step-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.step-card {
  min-height: 190px;
}

.step-number {
  display: inline-grid;
  width: 36px;
  height: 36px;
  margin-bottom: 16px;
  border-radius: 50%;
  background: var(--lime);
  color: var(--ink);
  font-weight: 950;
  place-items: center;
}

.service-link-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.service-link {
  display: block;
  min-height: 170px;
}

.service-link span {
  display: inline-block;
  margin-top: 16px;
  color: var(--lime);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.offer-band {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(166, 228, 0, .36);
  border-radius: 18px;
  padding: 28px;
  background:
    radial-gradient(circle at 90% 10%, rgba(166, 228, 0, .19), transparent 17rem),
    linear-gradient(135deg, rgba(22, 53, 67, .94), rgba(5, 16, 31, .96));
  box-shadow: 0 28px 75px rgba(0, 0, 0, .24);
}

.offer-band::after {
  content: "";
  position: absolute;
  width: 190px;
  height: 160%;
  right: -230px;
  top: -25%;
  background: linear-gradient(90deg, transparent, rgba(166, 228, 0, .08), transparent);
  transform: skewX(-18deg);
  animation: offer-glow 7s ease-in-out infinite;
  pointer-events: none;
}

.offer-band-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(240px, .6fr);
  gap: 28px;
  align-items: center;
}

.offer-price {
  margin: 8px 0 4px;
  color: var(--lime);
  font-size: clamp(42px, 7vw, 78px);
  font-weight: 950;
  letter-spacing: -.045em;
  line-height: 1;
}

.offer-band p,
.offer-band li { color: #c4d1de; }

.offer-list {
  display: grid;
  gap: 8px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.offer-list li::before {
  content: "\2713";
  margin-right: 9px;
  color: var(--lime);
  font-weight: 950;
}

.maintenance-callout {
  border-color: rgba(99, 189, 255, .42);
  background:
    radial-gradient(circle at 90% 10%, rgba(69, 158, 255, .18), transparent 17rem),
    linear-gradient(135deg, rgba(17, 44, 78, .94), rgba(5, 16, 31, .96));
}

.maintenance-callout .offer-price { color: #78c7ff; }

.internal-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}

.internal-links a {
  border: 1px solid rgba(166, 228, 0, .28);
  border-radius: 999px;
  padding: 8px 11px;
  color: #d9e7bc;
  background: rgba(166, 228, 0, .07);
  font-size: 12px;
  font-weight: 850;
}

.internal-links a:hover { border-color: var(--lime); color: var(--white); }

.hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 20px;
}

.hero-badges span {
  border: 1px solid rgba(166, 228, 0, 0.28);
  border-radius: 999px;
  padding: 8px 12px;
  background: rgba(166, 228, 0, 0.08);
  color: #e8f4ff;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.25;
}

.hero-tertiary {
  margin: 12px 0 0;
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}

.hero-tertiary a {
  color: var(--lime);
  font-weight: 950;
  text-decoration: underline;
  text-underline-offset: 4px;
}

.cta-band {
  border-block: 1px solid rgba(166, 228, 0, .2);
  background:
    radial-gradient(circle at 70% 0%, rgba(166, 228, 0, .12), transparent 22rem),
    rgba(4, 14, 27, .88);
}

.faq-grid { margin-top: 18px; }

/* Animated UI scene for secondary pages */
.service-stage-hero {
  min-height: 610px;
}

.service-stage-hero .hero-content { max-width: 520px; }
.service-stage-hero h1 { max-width: 520px; font-size: clamp(42px, 5.25vw, 68px); }
.service-stage-hero .lead { max-width: 520px; }

.service-stage {
  position: absolute;
  z-index: 2;
  width: min(420px, 30vw);
  height: 390px;
  right: max(18px, calc((100vw - 1400px) / 2));
  top: 112px;
  perspective: 900px;
  pointer-events: none;
}

.service-stage-panel {
  position: absolute;
  inset: 32px 20px 28px 16px;
  overflow: hidden;
  border: 1px solid rgba(166, 228, 0, .3);
  border-radius: 22px;
  padding: 20px;
  background:
    radial-gradient(circle at 92% 6%, rgba(166, 228, 0, .14), transparent 13rem),
    linear-gradient(145deg, rgba(18, 46, 77, .94), rgba(4, 14, 29, .98));
  box-shadow: 0 36px 80px rgba(0, 0, 0, .38), inset 0 1px rgba(255, 255, 255, .1);
  transform: rotateY(-8deg) rotateX(3deg);
  animation: service-stage-float 7s ease-in-out infinite;
}

.service-stage-panel::after {
  content: "";
  position: absolute;
  width: 230px;
  height: 230px;
  right: -80px;
  bottom: -95px;
  border: 1px solid rgba(166, 228, 0, .23);
  border-radius: 50%;
  box-shadow: inset 0 0 65px rgba(53, 145, 255, .1);
}

.service-stage-top,
.service-stage-grid {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 10px;
}

.service-stage-top {
  grid-template-columns: 1fr auto;
  align-items: center;
  border-bottom: 1px solid rgba(255, 255, 255, .12);
  padding-bottom: 15px;
}

.service-stage-top span { color: var(--white); font-weight: 950; }
.service-stage-top b { color: var(--lime); font-size: 10px; letter-spacing: .16em; }

.service-stage-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 20px;
}

.service-stage-grid span {
  min-height: 74px;
  border: 1px solid rgba(255, 255, 255, .11);
  border-radius: 12px;
  padding: 12px;
  background: rgba(2, 8, 20, .52);
}

.service-stage-grid small { display: block; color: var(--muted); font-size: 10px; }
.service-stage-grid strong { display: block; margin-top: 6px; color: var(--lime); font-size: 20px; }

.service-stage-bars {
  position: relative;
  z-index: 1;
  display: flex;
  height: 62px;
  gap: 8px;
  align-items: end;
  margin-top: 19px;
}

.service-stage-bars i {
  flex: 1;
  min-height: 18px;
  border-radius: 7px 7px 2px 2px;
  background: linear-gradient(180deg, var(--lime), rgba(67, 144, 70, .32));
  box-shadow: 0 0 18px rgba(166, 228, 0, .16);
  transform-origin: bottom;
  animation: bar-breathe 3.3s ease-in-out infinite;
}

.service-stage-bars i:nth-child(2) { animation-delay: -.55s; }
.service-stage-bars i:nth-child(3) { animation-delay: -1.1s; }
.service-stage-bars i:nth-child(4) { animation-delay: -1.65s; }
.service-stage-bars i:nth-child(5) { animation-delay: -2.2s; }

.service-stage-orbit {
  position: absolute;
  width: 280px;
  height: 280px;
  right: -22px;
  top: 0;
  border: 1px solid rgba(166, 228, 0, .22);
  border-radius: 50%;
  box-shadow: inset 0 0 75px rgba(53, 145, 255, .08);
  animation: orbit-soft 13s linear infinite;
}

.service-stage-float {
  position: absolute;
  z-index: 3;
  border: 1px solid rgba(255, 255, 255, .15);
  border-radius: 12px;
  padding: 11px 13px;
  background: linear-gradient(145deg, rgba(19, 42, 69, .98), rgba(4, 14, 28, .98));
  box-shadow: 0 18px 44px rgba(0, 0, 0, .35);
  animation: card-float 5.2s ease-in-out infinite;
}

.service-stage-float small { display: block; color: var(--lime); font-size: 9px; font-weight: 950; letter-spacing: .12em; text-transform: uppercase; }
.service-stage-float strong { display: block; margin-top: 5px; color: var(--white); font-size: 13px; }
.service-stage-float-one { left: 28px; top: 6px; }
.service-stage-float-two { right: -12px; bottom: 10px; animation-delay: -2.3s; }

/* Rich product storytelling */
.story-hero {
  padding: 82px 0 76px;
  background:
    radial-gradient(circle at 74% 38%, rgba(31, 111, 255, .19), transparent 26rem),
    radial-gradient(circle at 12% 20%, rgba(166, 228, 0, .09), transparent 21rem),
    linear-gradient(145deg, #020814, #061326 64%, #020814);
}

.story-hero .hero-content { max-width: none; }
.story-hero h1 { max-width: 720px; margin-bottom: 22px; }
.story-hero .lead { max-width: 690px; }

.package-stage {
  position: relative;
  min-height: 550px;
  perspective: 1100px;
  isolation: isolate;
}

.stage-glow,
.stage-orbit {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}

.stage-glow {
  width: 390px;
  height: 390px;
  right: 6%;
  top: 10%;
  background: radial-gradient(circle, rgba(166, 228, 0, .13), rgba(69, 158, 255, .06) 48%, transparent 70%);
  filter: blur(2px);
}

.stage-orbit {
  width: 360px;
  height: 360px;
  right: 4%;
  top: 13%;
  border: 1px solid rgba(166, 228, 0, .2);
  box-shadow: inset 0 0 80px rgba(69, 158, 255, .07);
  animation: orbit-soft 14s linear infinite;
}

.browser-mockup {
  position: absolute;
  z-index: 2;
  width: min(610px, 94%);
  right: 1%;
  top: 74px;
  border: 1px solid rgba(255, 255, 255, .17);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(20, 44, 75, .98), rgba(4, 14, 29, .98));
  box-shadow: 0 42px 90px rgba(0, 0, 0, .42), 0 0 80px rgba(69, 158, 255, .07);
  transform: rotateY(-8deg) rotateX(4deg) rotateZ(-1deg);
  overflow: hidden;
  animation: stage-float 7s ease-in-out infinite;
}

.browser-topbar {
  display: flex;
  min-height: 44px;
  align-items: center;
  gap: 7px;
  border-bottom: 1px solid rgba(255, 255, 255, .1);
  padding: 10px 14px;
  background: rgba(2, 8, 20, .42);
}

.browser-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .25);
}

.browser-dot.lime { background: var(--lime); }

.browser-address {
  min-width: 0;
  flex: 1;
  margin-left: 8px;
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 999px;
  padding: 6px 10px;
  color: #8796a8;
  background: rgba(2, 8, 20, .36);
  font-size: 10px;
  font-weight: 850;
  letter-spacing: .06em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mockup-screen {
  min-height: 390px;
  padding: 28px;
  background:
    linear-gradient(115deg, rgba(4, 15, 30, .93), rgba(9, 32, 54, .7)),
    radial-gradient(circle at 86% 10%, rgba(166, 228, 0, .13), transparent 15rem);
}

.screen-label,
.float-label,
.deliverable-index,
.flow-node-index {
  color: var(--lime);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .16em;
  text-transform: uppercase;
}

.screen-title {
  max-width: 440px;
  margin: 14px 0 8px;
  color: var(--white);
  font-size: clamp(32px, 4vw, 56px);
  font-weight: 950;
  letter-spacing: -.055em;
  line-height: .98;
}

.screen-title span { color: var(--lime); }
.screen-copy { max-width: 430px; color: #9eafbf; font-size: 13px; }

.screen-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.screen-actions span {
  border: 1px solid rgba(166, 228, 0, .42);
  border-radius: 999px;
  padding: 7px 10px;
  color: #e6f7bc;
  background: rgba(166, 228, 0, .08);
  font-size: 10px;
  font-weight: 900;
}

.screen-actions span:first-child { color: var(--ink); background: var(--lime); }

.screen-ui-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 9px;
  margin-top: 23px;
}

.screen-ui-card {
  min-height: 67px;
  border: 1px solid rgba(255, 255, 255, .11);
  border-radius: 10px;
  padding: 10px;
  background: rgba(2, 8, 20, .45);
}

.screen-ui-card dt {
  display: block;
  color: #8391a2;
  font-size: 9px;
  font-weight: 850;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.screen-ui-card dd {
  display: block;
  margin-top: 6px;
  color: var(--lime);
  font-size: 17px;
}

.floating-ui-card {
  position: absolute;
  z-index: 3;
  min-width: 150px;
  border: 1px solid rgba(255, 255, 255, .15);
  border-radius: 14px;
  padding: 13px;
  background: linear-gradient(145deg, rgba(17, 39, 65, .96), rgba(4, 14, 28, .96));
  box-shadow: 0 22px 54px rgba(0, 0, 0, .34);
  animation: card-float 5.4s ease-in-out infinite;
}

.floating-ui-card .metric-value { display: block; margin-top: 6px; color: var(--white); font-size: 15px; font-weight: 950; }
.floating-ui-card .metric-note { display: block; margin-top: 4px; color: var(--muted); font-size: 10px; }
.float-one { left: 0; top: 20px; }
.float-two { right: -20px; bottom: 18px; animation-delay: -2.2s; }
.float-three { left: 4%; bottom: 25px; animation-delay: -1.1s; }

.portfolio-float {
  position: absolute;
  z-index: 1;
  width: 210px;
  right: 14%;
  bottom: -8px;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 14px;
  padding: 7px;
  background: rgba(4, 14, 28, .92);
  box-shadow: 0 24px 58px rgba(0, 0, 0, .38);
  transform: rotate(6deg);
}

.portfolio-float img {
  width: 100%;
  height: 120px;
  border-radius: 9px;
  object-fit: cover;
  object-position: top;
}

.portfolio-float span { display: block; padding: 8px 4px 4px; color: #dbe6ed; font-size: 10px; font-weight: 900; }

.story-panel {
  border-block: 1px solid rgba(255, 255, 255, .08);
  background:
    radial-gradient(circle at 13% 50%, rgba(166, 228, 0, .08), transparent 19rem),
    linear-gradient(135deg, rgba(4, 17, 31, .96), rgba(2, 8, 20, .98));
}

.story-layout {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(460px, 1.1fr);
  gap: 36px;
  align-items: center;
}

.story-flow { position: relative; display: grid; gap: 12px; }

.story-flow::before {
  content: "";
  position: absolute;
  width: 1px;
  left: 24px;
  top: 30px;
  bottom: 30px;
  background: linear-gradient(var(--lime), rgba(69, 158, 255, .42));
}

.flow-node {
  position: relative;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 14px;
  align-items: start;
  border: 1px solid rgba(255, 255, 255, .11);
  border-radius: 14px;
  padding: 15px;
  background: rgba(7, 21, 39, .88);
  box-shadow: 0 16px 35px rgba(0, 0, 0, .14);
}

.flow-node-index {
  position: relative;
  display: grid;
  width: 48px;
  height: 48px;
  border: 1px solid rgba(166, 228, 0, .34);
  border-radius: 50%;
  background: #071427;
  place-items: center;
}

.flow-node h3 { margin: 1px 0 5px; font-size: 18px; }
.flow-node p { margin: 0; color: var(--muted); font-size: 14px; }

.deliverable-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.deliverable-card {
  position: relative;
  min-height: 245px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 16px;
  padding: 20px;
  background:
    radial-gradient(circle at 88% 6%, rgba(166, 228, 0, .11), transparent 10rem),
    linear-gradient(145deg, rgba(18, 40, 66, .87), rgba(5, 15, 30, .94));
  box-shadow: 0 22px 54px rgba(0, 0, 0, .16);
  transition: translate .24s ease, border-color .24s ease;
}

.deliverable-card:hover { translate: 0 -8px; border-color: rgba(166, 228, 0, .52); }
.deliverable-index { display: block; margin-bottom: 30px; color: #82c6ff; }
.deliverable-card h3 { margin-bottom: 8px; font-size: 22px; }
.deliverable-card p { color: var(--muted); font-size: 14px; }

.deliverable-note {
  position: absolute;
  right: 15px;
  bottom: 13px;
  color: rgba(166, 228, 0, .72);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.visual-case-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.visual-case {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .14);
  border-radius: 18px;
  background: rgba(4, 14, 28, .84);
  box-shadow: 0 24px 56px rgba(0, 0, 0, .18);
}

.visual-case img {
  width: 100%;
  height: 300px;
  object-fit: cover;
  object-position: top;
  transition: transform .45s ease;
}

.visual-case:hover img { transform: scale(1.035); }
.visual-case-copy { padding: 18px; border-top: 1px solid rgba(255, 255, 255, .1); }
.visual-case-copy h3 { margin: 6px 0; }
.visual-case-copy p { margin: 0; color: var(--muted); font-size: 14px; }

.experience-strip {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 16px;
  background: rgba(255, 255, 255, .1);
}

.experience-strip div { min-height: 116px; padding: 16px; background: #071426; }
.experience-strip dt { display: block; color: var(--muted); font-size: 12px; }
.experience-strip dd { display: block; margin-top: 5px; color: var(--lime); font-size: 25px; font-weight: 950; }

.package-breakdown {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(310px, .75fr);
  gap: 22px;
  align-items: start;
}

.scope-panel {
  border: 1px solid rgba(166, 228, 0, .34);
  border-radius: 18px;
  padding: 22px;
  background: linear-gradient(145deg, rgba(25, 55, 60, .85), rgba(5, 16, 30, .95));
}

.scope-panel h3 { margin-top: 0; }
.scope-panel .offer-price { margin: 14px 0; }

.scope-list { display: grid; gap: 10px; margin: 18px 0 0; padding: 0; list-style: none; }
.scope-list li { border-top: 1px solid rgba(255, 255, 255, .1); padding-top: 10px; color: #c6d4de; font-size: 14px; }
.scope-list strong { color: var(--white); }

.mini-marquee {
  overflow: hidden;
  border-block: 1px solid rgba(166, 228, 0, .2);
  background: rgba(166, 228, 0, .055);
}

.mini-marquee-track { display: flex; width: max-content; animation: marquee-shift 25s linear infinite; }
.mini-marquee span { display: block; padding: 13px 23px; color: #d7e7af; font-size: 11px; font-weight: 950; letter-spacing: .13em; text-transform: uppercase; white-space: nowrap; }
.mini-marquee span::after { content: "\2726"; margin-left: 24px; color: var(--lime); }

.reveal-on-scroll {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .65s ease, transform .65s ease;
}

.reveal-on-scroll.is-visible { opacity: 1; transform: translateY(0); }

@keyframes stage-float {
  50% { transform: translateY(-10px) rotateY(-6deg) rotateX(3deg) rotateZ(-.5deg); }
}

@keyframes card-float {
  50% { transform: translateY(-10px); }
}

@keyframes orbit-soft {
  to { transform: rotate(360deg); }
}

@keyframes marquee-shift {
  to { transform: translateX(-50%); }
}

@keyframes button-shine {
  0%, 62% { left: -96px; }
  84%, 100% { left: calc(100% + 24px); }
}

@keyframes offer-glow {
  0%, 58% { right: -230px; }
  86%, 100% { right: calc(100% + 50px); }
}

@keyframes orbit-drift {
  50% { transform: translate3d(-18px, 12px, 0) rotate(180deg); }
  to { transform: translate3d(0, 0, 0) rotate(360deg); }
}

@keyframes orbit-drift-reverse {
  50% { transform: translate3d(16px, -14px, 0) rotate(-180deg); }
  to { transform: translate3d(0, 0, 0) rotate(-360deg); }
}

@keyframes beam-glide {
  50% { opacity: .35; transform: translate3d(-58px, 18px, 0) rotate(-13deg); }
}

@keyframes dashboard-drift {
  50% {
    transform:
      perspective(900px)
      translate3d(0, -11px, 0)
      rotateY(calc(var(--dashboard-rotate-y) + 1deg))
      rotateX(calc(var(--dashboard-rotate-x) - 1deg));
  }
}

@keyframes service-stage-float {
  50% { transform: translateY(-10px) rotateY(-6deg) rotateX(2deg); }
}

@keyframes live-pulse {
  70% { box-shadow: 0 0 0 8px rgba(166, 228, 0, 0); }
  100% { box-shadow: 0 0 0 0 rgba(166, 228, 0, 0); }
}

@keyframes bar-breathe {
  50% { transform: scaleY(.82); filter: brightness(1.18); }
}

.industry-pill {
  min-height: 58px;
  display: flex;
  align-items: center;
  border: 1px solid rgba(166,228,0,.28);
  border-radius: 8px;
  padding: 12px 14px;
  color: #e7f2ff;
  background: rgba(255,255,255,.045);
  font-weight: 900;
}

.price { display: flex; flex-direction: column; gap: 14px; }
.amount {
  margin-bottom: 5px;
  font-size: 36px;
  line-height: 1.08;
  font-weight: 950;
  letter-spacing: -.035em;
}
.tag {
  display: inline-flex;
  align-self: flex-start;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--lime);
  color: var(--ink);
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
}

.portfolio-grid { display: grid; gap: 22px; }

.case-showcase {
  padding: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
}

.case-visual {
  min-width: 0;
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(166,228,0,.08), rgba(255,255,255,.03)),
    rgba(3, 10, 19, .72);
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(300px, .75fr);
  align-items: stretch;
}

.case-shot {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  min-height: 0;
  max-height: 260px;
  border-right: 1px solid var(--line);
  background: #07111f;
  overflow: hidden;
}

.case-shot picture,
.ba-visual picture,
.founder-photo-card picture,
.desktop-mockup picture,
.phone-mockup picture {
  display: block;
  width: 100%;
  height: 100%;
}

.case-visual .case-shot {
  border-right: 1px solid var(--line);
  border-bottom: 0;
}

.case-shot img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: top center;
}

.visual-cta {
  position: absolute;
  right: 12px;
  bottom: 12px;
  z-index: 2;
  border: 1px solid rgba(166,228,0,.42);
  border-radius: 999px;
  padding: 8px 10px;
  background: rgba(2,8,20,.82);
  color: var(--lime);
  font-size: 12px;
  font-weight: 950;
  box-shadow: 0 12px 30px rgba(0,0,0,.24);
}

.case-shot:hover .visual-cta,
.ba-visual:hover .visual-cta {
  background: var(--lime);
  color: var(--ink);
}

.case-body {
  padding: 24px;
  display: grid;
  align-content: start;
  gap: 16px;
}

.case-visual-panel {
  padding: 14px;
  display: grid;
  align-content: center;
  gap: 10px;
}

.case-visual-panel div {
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  padding: 10px;
  background: rgba(2, 8, 20, .48);
}

.case-visual-panel strong {
  display: block;
  color: var(--lime);
  font-size: 11px;
  font-weight: 950;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.case-visual-panel span {
  display: block;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.case-meta { display: flex; flex-wrap: wrap; gap: 8px; }

.case-meta span {
  border: 1px solid rgba(166,228,0,.26);
  border-radius: 999px;
  padding: 6px 9px;
  color: #d9e7bc;
  background: rgba(166,228,0,.07);
  font-size: 12px;
  font-weight: 850;
}

.case-brief { display: grid; gap: 10px; }

.case-brief div {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  padding: 12px;
  background: rgba(255,255,255,.045);
}

.case-brief strong {
  display: block;
  color: var(--lime);
  font-size: 12px;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.case-brief span { color: var(--muted); font-size: 14px; }

.before-after-panel {
  display: grid;
  grid-template-columns: minmax(0, .82fr) minmax(300px, 1.1fr) minmax(0, .82fr);
  gap: 0;
  overflow: hidden;
  padding: 0;
  border-color: rgba(166,228,0,.26);
}

.ba-column { padding: 24px; display: grid; align-content: start; gap: 16px; }
.ba-column.after { background: rgba(166,228,0,.08); }

.ba-label {
  display: inline-flex;
  width: fit-content;
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 950;
  text-transform: uppercase;
  color: var(--ink);
  background: var(--lime);
}

.ba-column.before .ba-label {
  color: #dbe7ff;
  background: rgba(255,255,255,.12);
}

.ba-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
  color: var(--muted);
}

.ba-list li {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 10px;
}

.ba-list li::before {
  content: "";
  width: 8px;
  height: 8px;
  margin-top: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: .72;
}

.ba-visual {
  position: relative;
  aspect-ratio: 16 / 9;
  max-height: 320px;
  min-height: 0;
  border-inline: 1px solid var(--line);
  border-radius: 20px;
  background: #07111f;
  overflow: hidden;
}

.ba-visual img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: top center;
}

.ba-flow { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 18px; }

.ba-flow span {
  border: 1px solid rgba(166,228,0,.26);
  border-radius: 999px;
  padding: 8px 10px;
  color: #d9e7bc;
  background: rgba(166,228,0,.07);
  font-size: 12px;
  font-weight: 850;
}

.ba-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 18px; }

.case-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  width: fit-content;
  padding: 9px 12px;
  border: 1px solid rgba(166,228,0,.42);
  border-radius: 8px;
  color: var(--lime);
  font-weight: 950;
}

.case-link:hover { background: rgba(166,228,0,.1); color: var(--white); }

.package-comparison { margin-top: 18px; padding: 0; overflow: hidden; }
.comparison-copy { padding: 22px 22px 0; }
.comparison-copy p { max-width: 760px; }

.comparison-table-wrap {
  margin-top: 18px;
  overflow-x: auto;
  border-top: 1px solid var(--line);
}

.comparison-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.comparison-table th,
.comparison-table td {
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  text-align: left;
  vertical-align: top;
}

.comparison-table th {
  color: var(--white);
  background: rgba(255,255,255,.045);
  font-size: 13px;
  line-height: 1.3;
}

.comparison-table td { color: var(--muted); font-size: 14px; }

.comparison-table th:first-child,
.comparison-table td:first-child {
  color: var(--white);
  font-weight: 950;
  width: 145px;
}

.comparison-table .recommended { background: rgba(166,228,0,.08); color: #efffc2; }

.scope-grid { margin-top: 18px; }
.scope-card { background: rgba(166,228,0,.07); border-color: rgba(166,228,0,.3); }

.commercial-disclaimer {
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid rgba(166,228,0,.24);
  border-radius: 8px;
  background: rgba(166,228,0,.07);
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}

.founder-grid { align-items: center; grid-template-columns: minmax(180px, 220px) minmax(0, 1fr); }

.founder-photo-card {
  padding: 0;
  overflow: hidden;
  width: 100%;
  max-width: 220px;
  justify-self: center;
}

.founder-photo-card img {
  display: block;
  width: 100%;
  height: 260px;
  object-fit: cover;
  object-position: center top;
}

.founder-caption {
  display: grid;
  gap: 4px;
  padding: 16px 20px 18px;
  border-top: 1px solid var(--line);
  background: rgba(2,8,20,.64);
}

.founder-caption strong { color: var(--white); font-size: 18px; }
.founder-caption span { color: var(--muted); }
.founder-proof ul { margin-top: 12px; }

.faq-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; }
.faq-grid .card h3 { font-size: 20px; }

.form-shell {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
  color: var(--ink);
  padding: 24px;
}

.form-shell p { color: #4b5565; }
form { display: grid; gap: 12px; }
.form-note { color: #4b5565; font-size: 13px; margin: 0; }
.form-note a { color: #344b00; font-weight: 850; text-decoration: underline; text-underline-offset: 2px; }
.form-step-note,
.consent-note {
  padding: 10px 12px;
  border: 1px solid rgba(166,228,0,.28);
  border-radius: 8px;
  background: rgba(166,228,0,.08);
  color: #263244;
  font-size: 13px;
  font-weight: 850;
}
.consent-note { background: #f3f7ee; color: #374151; }
.microcopy { color: #d7e3f5; font-size: 14px; font-weight: 800; margin: 14px 0 0; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
label { display: grid; gap: 6px; font-size: 13px; font-weight: 850; color: #1f2937; }
.form-control { display: grid; gap: 6px; }
.form-help { color: #536174; font-size: 12px; font-weight: 700; }
input, select, textarea {
  width: 100%;
  border: 1px solid #ccd4df;
  border-radius: 8px;
  min-height: 44px;
  padding: 11px 12px;
  font: inherit;
  background: #fff;
  color: var(--ink);
}
textarea { min-height: 110px; resize: vertical; }
.checkbox-label {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
  min-height: 44px;
}
.scope-checkbox {
  padding: 12px;
  border: 1px solid rgba(166,228,0,.34);
  border-radius: 8px;
  background: rgba(166,228,0,.08);
}
input[type="checkbox"] {
  width: 20px;
  height: 20px;
  min-height: 20px;
  margin-top: 1px;
  accent-color: var(--lime);
}
.form-button { border: 0; cursor: pointer; }
.form-button:disabled { cursor: wait; opacity: .72; }
.form-status {
  margin: 0;
  border: 1px solid rgba(166,228,0,.38);
  border-radius: 8px;
  padding: 10px 12px;
  background: rgba(166,228,0,.08);
  color: #263244;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.55;
}
.form-status:focus { outline: 3px solid rgba(94,178,0,.62); outline-offset: 3px; }
.form-status-success { border-color: rgba(94,178,0,.45); background: #edf8da; color: #27420b; }
.form-status-error { border-color: rgba(190,45,45,.42); background: #fff0f0; color: #8a1e1e; }

.demo-preview {
  min-height: 360px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 8px;
  background: #0f1c2f;
  overflow: hidden;
}
.demo-bar {
  min-height: 42px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.05);
}
.demo-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--lime); opacity: .8; }
.demo-body { padding: 24px; display: grid; gap: 16px; }
.mock-line { height: 12px; border-radius: 999px; background: rgba(255,255,255,.14); }
.mock-line.lime { background: var(--lime); }
.mock-card {
  min-height: 88px;
  border: 1px solid rgba(166,228,0,.24);
  border-radius: 8px;
  background: rgba(166,228,0,.07);
  padding: 14px;
}

/* Footer */
.footer {
  padding: 34px 0;
  border-top: 1px solid var(--line);
  color: var(--muted);
  background: #020814;
}
.footer-grid { display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap; }
.footer-meta { display: grid; gap: 8px; text-align: right; }
.footer-links { display: flex; justify-content: flex-end; flex-wrap: wrap; gap: 8px 14px; font-size: 12px; }
.footer-links a { color: var(--lime); font-weight: 850; }

.footer-social {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  flex-wrap: wrap;
}

.footer-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-height: 34px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 999px;
  padding: 7px 11px;
  line-height: 1;
  transition: border-color .2s, color .2s, background .2s;
}

.footer-social a:hover {
  border-color: rgba(166,228,0,.5);
  color: var(--lime);
  background: rgba(166,228,0,.08);
}

.footer-social-icon {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.footer-social-icon-fill {
  fill: currentColor;
  stroke: none;
}

@media (max-width: 900px) {
  .hero-stack,
  .offer-band-grid {
    grid-template-columns: 1fr;
  }

  .hero-dashboard {
    --dashboard-rotate-x: 0deg;
    --dashboard-rotate-y: 0deg;
    min-height: 330px;
  }

  .signal-row,
  .step-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .package-stage { min-height: 450px; }
  .browser-mockup { top: 55px; right: 0; width: 100%; transform: none; }
  .portfolio-float { right: 2%; }
  .story-layout,
  .package-breakdown { grid-template-columns: 1fr; }
  .deliverable-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 720px) {
  .nav-links { display: none; }
  .hero { padding-top: 62px; }
  .section { padding: 56px 0; }
  .grid-2, .grid-3, .grid-4,
  .service-link-grid,
  .signal-row,
  .step-grid {
    grid-template-columns: 1fr;
  }

  .hero-dashboard { min-height: 290px; padding: 16px; }
  .dashboard-stat-grid { margin-top: 18px; }
  .dashboard-bars { height: 68px; margin-top: 17px; }
  .offer-band { padding: 21px; }
  .package-stage { min-height: 365px; margin-top: 10px; }
  .browser-mockup { top: 38px; border-radius: 13px; }
  .mockup-screen { min-height: 275px; padding: 18px; }
  .screen-title { font-size: 34px; }
  .screen-copy { font-size: 12px; }
  .screen-ui-grid { gap: 6px; margin-top: 16px; }
  .screen-ui-card { min-height: 56px; padding: 7px; }
  .screen-ui-card dd { font-size: 14px; }
  .floating-ui-card { min-width: 115px; padding: 9px; }
  .floating-ui-card .metric-value { font-size: 12px; }
  .float-one { left: -3px; top: 0; }
  .float-two { right: -3px; bottom: -3px; }
  .float-three,
  .portfolio-float { display: none; }
  .deliverable-grid,
  .visual-case-grid { grid-template-columns: 1fr; }
  .deliverable-card { min-height: 190px; }
  .deliverable-index { margin-bottom: 20px; }
  .experience-strip { grid-template-columns: 1fr; }
  .experience-strip div { min-height: auto; }
  .footer-meta { text-align: left; }
  .footer-links, .footer-social { justify-content: flex-start; }
}

/* Tracking notice */
.tracking-notice {
  border-top: 1px solid var(--line);
  background: rgba(166,228,0,.075);
  color: #dbe7ff;
}

.tracking-notice .wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 0;
}

.tracking-notice p { margin: 0; font-size: 13px; }
.tracking-notice a { color: var(--lime); font-weight: 950; white-space: nowrap; }

@media (min-width: 921px) {
  .case-showcase .device-mockups { display: none; }
  .case-showcase .case-brief { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .case-showcase .case-brief div:last-child:nth-child(odd) { grid-column: auto; }
}

@media (max-width: 920px) {
  .nav-links { display: none; }
  .hero {
    padding: 60px 0 48px;
    background:
      linear-gradient(180deg, rgba(2,8,20,.96), rgba(2,8,20,.88)),
      url("/assets/logos/p2l-logo-icon-dark.png") center 22px / min(190px, 48vw) auto no-repeat,
      radial-gradient(circle at 50% 10%, #102746, var(--night) 64%);
  }
  .hero-content { padding-top: 160px; }
  .hero-stack .hero-content { padding-top: 76px; }
  .service-stage-hero { min-height: auto; }
  .service-stage-hero .hero-content { max-width: 730px; }
  .service-stage {
    position: relative;
    width: min(520px, calc(100% - 24px));
    height: 330px;
    right: auto;
    top: auto;
    margin: 26px auto 0;
  }
  .service-stage-panel { inset: 26px 12px 18px; transform: none; }
  .service-stage-orbit { right: 4px; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .pill-grid, .faq-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .prep-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .case-showcase { grid-template-columns: 1fr; }
  .case-visual { display: block; border-right: 0; border-bottom: 0; }
  .case-visual-panel { display: none; }
  .case-shot {
    aspect-ratio: 16 / 11;
    max-height: 200px;
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
  .primary-case .case-shot { max-height: 200px; }
  .before-after-panel { grid-template-columns: 1fr; }
  .footer-meta { text-align: left; }
  .footer-links { justify-content: flex-start; }
  .footer-social { justify-content: flex-start; }
  .tracking-notice .wrap { display: grid; }
  .ba-visual {
    aspect-ratio: 4 / 3;
    max-height: 220px;
    order: -1;
    border-inline: 0;
    border-bottom: 1px solid var(--line);
  }
}

@media (max-width: 640px) {
  .wrap { width: min(100% - 24px, 1120px); }
  .brand strong { display: none; }
  .brand img { width: 46px; height: 46px; }
  .nav { min-height: 64px; }
  .actions, .form-grid { display: grid; grid-template-columns: 1fr; }
  .button, .ghost { width: 100%; }
  .pill-grid, .faq-grid { grid-template-columns: 1fr; }
  .prep-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .founder-photo-card {
    max-width: 140px;
    border-radius: 999px;
    border: 0;
    background: transparent;
  }
  .founder-photo-card img {
    width: 140px;
    height: 140px;
    margin: 0 auto;
    border-radius: 999px;
  }
  .founder-caption { display: none; }
  h1 { font-size: 43px; }
  .hero-stack .hero-content { padding-top: 54px; }
  .service-stage { height: 290px; margin-top: 18px; }
  .service-stage-panel { inset: 20px 0 12px; border-radius: 16px; padding: 15px; }
  .service-stage-grid { gap: 7px; margin-top: 15px; }
  .service-stage-grid span { min-height: 60px; padding: 9px; }
  .service-stage-grid strong { font-size: 16px; }
  .service-stage-bars { height: 46px; margin-top: 14px; }
  .service-stage-float { padding: 8px 10px; }
  .service-stage-float-one { left: -4px; top: 0; }
  .service-stage-float-two { right: -4px; bottom: 0; }
  .ambient-orb,
  .ambient-beam,
  .stage-orbit,
  .service-stage-orbit {
    display: none;
  }
}

.p2l-asset-frame {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  background:
    linear-gradient(145deg, rgba(4, 12, 26, 0.82), rgba(12, 31, 43, 0.58)),
    radial-gradient(circle at 78% 12%, rgba(166, 228, 0, 0.12), transparent 36%);
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.28), inset 0 1px rgba(255, 255, 255, 0.08);
  transform-style: preserve-3d;
  transition: transform 260ms ease, border-color 260ms ease, box-shadow 260ms ease;
}

.p2l-asset-frame::before {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.18), transparent 28%),
    radial-gradient(circle at 16% 84%, rgba(85, 167, 255, 0.12), transparent 34%);
  content: "";
  opacity: 0.62;
  pointer-events: none;
}

.p2l-asset-frame img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  object-position: center;
  filter: saturate(1.04) contrast(1.05);
  transform: scale(1.02) translateZ(12px);
  transition: transform 520ms ease, filter 520ms ease;
}

.p2l-asset-frame:hover {
  border-color: rgba(166, 228, 0, 0.36);
  box-shadow: 0 34px 82px rgba(0, 0, 0, 0.34), 0 0 48px rgba(166, 228, 0, 0.08), inset 0 1px rgba(255, 255, 255, 0.11);
  transform: perspective(1000px) rotateX(2deg) rotateY(-3deg) translateY(-4px);
}

.p2l-asset-frame:hover img {
  filter: saturate(1.14) contrast(1.08);
  transform: scale(1.07) translateZ(16px);
}

.p2l-asset-frame .asset-caption {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  max-width: calc(100% - 28px);
  border: 1px solid rgba(166, 228, 0, 0.22);
  border-radius: 999px;
  padding: 7px 11px;
  background: rgba(2, 8, 20, 0.72);
  color: var(--lime);
  font-size: 0.7rem;
  font-weight: 950;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.store-overview-asset {
  min-height: 330px;
  aspect-ratio: 16 / 11;
}

.package-asset {
  margin: 14px 0 16px;
  aspect-ratio: 16 / 10;
}

.design-card.highlight .package-asset {
  border-color: rgba(166, 228, 0, 0.44);
  box-shadow: 0 32px 78px rgba(0, 0, 0, 0.32), 0 0 52px rgba(166, 228, 0, 0.1);
}

.premium-system-section {
  background:
    linear-gradient(rgba(2, 7, 17, 0.86), rgba(2, 7, 17, 0.9)),
    url("/assets/p2l/16_shared_dark_background_generated.png") center / cover;
}

.lead-flow-cinematic .grid-2,
.audit-visual-grid,
.maintenance-visual-grid,
.bilingual-visual-grid,
.contractor-visual-grid,
.proof-showcase-grid {
  align-items: center;
}

.lead-flow-steps {
  display: grid;
  gap: 12px;
  margin-top: 24px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.lead-flow-step {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.045);
  box-shadow: inset 0 1px rgba(255, 255, 255, 0.08);
}

.lead-flow-step::after {
  position: absolute;
  right: -18px;
  bottom: -18px;
  width: 78px;
  height: 78px;
  border-radius: 50%;
  background: rgba(166, 228, 0, 0.09);
  content: "";
  filter: blur(8px);
}

.lead-flow-step span,
.audit-checklist span,
.maintenance-status span,
.bilingual-toggle span,
.contractor-chip-row span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: max-content;
  max-width: 100%;
  border: 1px solid rgba(166, 228, 0, 0.24);
  border-radius: 999px;
  padding: 7px 10px;
  background: rgba(166, 228, 0, 0.08);
  color: var(--lime);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.audit-score-card,
.maintenance-status,
.bilingual-toggle,
.contractor-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.audit-checklist {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.audit-score-card strong {
  color: var(--white);
  font-size: clamp(2.6rem, 7vw, 4.8rem);
  line-height: 1;
}

.maintenance-status {
  align-items: center;
}

.bilingual-split-panel {
  display: grid;
  overflow: hidden;
  border-radius: 18px;
  grid-template-columns: 1fr 1fr;
}

.bilingual-split-panel div {
  min-height: 150px;
  padding: 20px;
  background: rgba(255, 255, 255, 0.055);
}

.bilingual-split-panel div + div {
  border-left: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(166, 228, 0, 0.07);
}

.demo-mockup-showcase {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.demo-mockup-showcase .p2l-asset-frame {
  aspect-ratio: 16 / 12;
}

@media (max-width: 900px) {
  .lead-flow-steps,
  .demo-mockup-showcase {
    grid-template-columns: 1fr;
  }

  .store-overview-asset {
    min-height: 260px;
  }

  .p2l-asset-frame:hover {
    transform: none;
  }
}

@media (max-width: 640px) {
  .p2l-asset-frame {
    border-radius: 14px;
  }

  .p2l-asset-frame img {
    transform: none;
  }

  .lead-flow-step {
    padding: 14px;
  }

  .bilingual-split-panel {
    grid-template-columns: 1fr;
  }

  .bilingual-split-panel div + div {
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    border-left: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .p2l-asset-frame,
  .p2l-asset-frame img,
  .button::after,
  .offer-band::after,
  .ambient-orb,
  .ambient-beam,
  .hero-dashboard,
  .dashboard-live::before,
  .dashboard-bars span,
  .service-stage-panel,
  .service-stage-orbit,
  .service-stage-float,
  .service-stage-bars i,
  .browser-mockup,
  .floating-ui-card,
  .stage-orbit,
  .mini-marquee-track {
    animation: none;
    transition: none;
    transform: none;
  }

  .reveal-on-scroll {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
