:root {
  --lp-navy: #071120;
  --lp-navy-soft: #0d1b31;
  --lp-ink: #0f172a;
  --lp-copy: #334155;
  --lp-blue: #2563eb;
  --lp-cyan: #38bdf8;
  --lp-cream: #f8fafc;
  --lp-border-dark: rgba(255, 255, 255, 0.12);
  --lp-border-light: rgba(15, 23, 42, 0.10);
  --lp-shadow-lg: 0 32px 80px rgba(2, 6, 23, 0.28);
  --lp-shadow-md: 0 20px 48px rgba(15, 23, 42, 0.12);
}

body.lp-page {
  background:
    radial-gradient(circle at top left, rgba(37, 99, 235, 0.12), transparent 30%),
    linear-gradient(180deg, #08111f 0%, #071120 100%);
}

html.light body {
  color: var(--lp-ink);
}

html.light .dark\:text-white {
  color: var(--lp-ink) !important;
}

html.light .dark\:text-slate-300,
html.light .dark\:text-slate-400,
html.light .dark\:text-slate-500 {
  color: var(--lp-copy) !important;
}

html.light .dark\:bg-slate-800,
html.light .dark\:bg-slate-800\/40,
html.light .dark\:bg-slate-900\/40,
html.light .dark\:bg-slate-900\/50,
html.light .dark\:bg-\[\#101922\],
html.light .dark\:bg-\[\#1a2632\],
html.light .dark\:bg-background-dark {
  background: #ffffff !important;
}

html.light .dark\:border-slate-700,
html.light .dark\:border-slate-800,
html.light .dark\:border-slate-600 {
  border-color: rgba(148, 163, 184, 0.25) !important;
}

html.light .bg-white .dark\:text-white,
html.light .bg-slate-50 .dark\:text-white,
html.light .lp-light-card .dark\:text-white,
html.light .lp-form-shell .dark\:text-white,
html.light .lp-contact-card .dark\:text-white,
html.light .lp-service-card .dark\:text-white {
  color: var(--lp-ink) !important;
}

html.light .bg-white .dark\:text-slate-300,
html.light .bg-white .dark\:text-slate-400,
html.light .bg-slate-50 .dark\:text-slate-300,
html.light .bg-slate-50 .dark\:text-slate-400,
html.light .lp-light-card .dark\:text-slate-300,
html.light .lp-light-card .dark\:text-slate-400,
html.light .lp-form-shell .dark\:text-slate-300,
html.light .lp-form-shell .dark\:text-slate-400,
html.light .lp-contact-card .dark\:text-slate-300,
html.light .lp-contact-card .dark\:text-slate-400,
html.light .lp-service-card .dark\:text-slate-300,
html.light .lp-service-card .dark\:text-slate-400 {
  color: var(--lp-copy) !important;
}

html.light .lp-light-card,
html.light .lp-form-shell,
html.light .lp-contact-card,
html.light .lp-service-card {
  color: var(--lp-ink);
}

html.light input,
html.light textarea,
html.light select {
  color: var(--lp-ink);
  background-color: #f8fafc;
}

html.light input::placeholder,
html.light textarea::placeholder {
  color: #64748b;
}

.lp-page .lp-hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}

.lp-page .lp-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(7, 17, 32, 0.93) 0%, rgba(7, 17, 32, 0.80) 45%, rgba(13, 27, 49, 0.86) 100%),
    radial-gradient(circle at top left, rgba(56, 189, 248, 0.16), transparent 28%),
    radial-gradient(circle at bottom right, rgba(37, 99, 235, 0.18), transparent 32%);
  z-index: -2;
}

.lp-page .lp-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(148, 163, 184, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(148, 163, 184, 0.08) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.65), transparent 85%);
  z-index: -1;
}

.lp-page .lp-hero h1 {
  text-wrap: balance;
  text-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
}

.lp-page .lp-hero p,
.lp-page .lp-dark-copy {
  color: rgba(226, 232, 240, 0.92);
}

.lp-page .lp-glass,
.lp-page .lp-dark-card {
  border: 1px solid var(--lp-border-dark);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.10), rgba(255, 255, 255, 0.05));
  box-shadow: var(--lp-shadow-lg);
  backdrop-filter: blur(18px);
}

.lp-page .lp-dark-card strong,
.lp-page .lp-dark-card h2,
.lp-page .lp-dark-card h3 {
  color: #fff;
}

.lp-page .lp-signal-strip {
  margin-top: 2rem;
  display: grid;
  gap: 0.9rem;
}

@media (min-width: 640px) {
  .lp-page .lp-signal-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.lp-page .lp-signal {
  border: 1px solid var(--lp-border-dark);
  background: linear-gradient(180deg, rgba(8, 20, 38, 0.86), rgba(15, 23, 42, 0.68));
  border-radius: 1.2rem;
  padding: 1rem 1rem 1rem 1.05rem;
  box-shadow: var(--lp-shadow-md);
}

.lp-page .lp-signal-label {
  font-size: 0.68rem;
  line-height: 1rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  font-weight: 800;
  color: #bfdbfe;
}

.lp-page .lp-signal-copy {
  margin-top: 0.45rem;
  font-size: 0.92rem;
  line-height: 1.45rem;
  color: rgba(226, 232, 240, 0.9);
}

.lp-page .lp-banner,
.lp-home .lp-banner,
.lp-services .lp-banner,
.lp-contact .lp-banner,
.lp-pricing .lp-banner {
  background: linear-gradient(135deg, #0f172a 0%, #1d4ed8 120%);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.lp-page .lp-banner-inner,
.lp-home .lp-banner-inner,
.lp-services .lp-banner-inner,
.lp-contact .lp-banner-inner,
.lp-pricing .lp-banner-inner {
  max-width: 80rem;
  margin: 0 auto;
  padding: 1rem 1rem;
  display: grid;
  gap: 0.8rem;
}

@media (min-width: 768px) {
  .lp-page .lp-banner-inner,
  .lp-home .lp-banner-inner,
  .lp-services .lp-banner-inner,
  .lp-contact .lp-banner-inner,
  .lp-pricing .lp-banner-inner {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 1.05rem 1.5rem;
  }
}

.lp-page .lp-banner-chip,
.lp-home .lp-banner-chip,
.lp-services .lp-banner-chip,
.lp-contact .lp-banner-chip,
.lp-pricing .lp-banner-chip {
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  padding: 0.75rem 1rem;
  color: white;
  font-weight: 700;
  font-size: 0.9rem;
  background: rgba(255, 255, 255, 0.05);
  text-align: center;
}

.lp-page .lp-light-section {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}

.lp-page .lp-light-card {
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid var(--lp-border-light);
  box-shadow: var(--lp-shadow-md);
}

.lp-page .lp-form-shell {
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  border: 1px solid rgba(148, 163, 184, 0.22);
  box-shadow: 0 28px 72px rgba(15, 23, 42, 0.14);
}

.lp-page .lp-subtle-rule {
  position: relative;
}

.lp-page .lp-subtle-rule::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 72px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--lp-blue), var(--lp-cyan));
}

.lp-page .lp-faq details {
  box-shadow: var(--lp-shadow-md);
}

.lp-home .lp-home-hero {
  position: relative;
  overflow: hidden;
}

.lp-home .lp-home-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(6, 14, 26, 0.92) 0%, rgba(8, 20, 38, 0.78) 46%, rgba(6, 14, 26, 0.74) 100%),
    radial-gradient(circle at top left, rgba(56, 189, 248, 0.18), transparent 30%);
  z-index: 0;
}

.lp-home .lp-home-hero > * {
  position: relative;
  z-index: 1;
}

.lp-home .lp-home-hero h1 {
  text-shadow: 0 20px 48px rgba(0, 0, 0, 0.45);
}

.lp-home .lp-home-route-grid a {
  box-shadow: var(--lp-shadow-md);
}

.lp-home .lp-home-banner {
  background: linear-gradient(120deg, #1d4ed8, #0f172a);
  box-shadow: 0 18px 44px rgba(29, 78, 216, 0.18);
}

.lp-services .lp-services-hero,
.lp-contact .lp-contact-hero {
  position: relative;
  overflow: hidden;
}

.lp-services .lp-services-hero::before,
.lp-contact .lp-contact-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(6, 14, 26, 0.9), rgba(29, 78, 216, 0.72));
  z-index: 0;
}

.lp-services .lp-services-hero > *,
.lp-contact .lp-contact-hero > * {
  position: relative;
  z-index: 1;
}

.lp-pricing .hero {
  position: relative;
  overflow: hidden;
}

.lp-pricing .hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(15, 31, 64, 0.95) 0%, rgba(29, 78, 216, 0.82) 100%),
    radial-gradient(circle at top left, rgba(56, 189, 248, 0.18), transparent 30%);
}

.lp-pricing .hero .container {
  position: relative;
  z-index: 1;
}

.lp-pricing .service-links {
  row-gap: 10px;
}

.lp-contact .lp-contact-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.98));
  border: 1px solid rgba(226, 232, 240, 0.96);
  box-shadow: 0 30px 80px rgba(15, 23, 42, 0.16);
}

.lp-services .lp-service-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 250, 252, 0.98));
  border: 1px solid rgba(226, 232, 240, 0.96);
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
}

.lp-services .lp-service-card h3,
.lp-services .lp-service-card p,
.lp-services .lp-service-card li,
.lp-contact .lp-contact-card h2,
.lp-contact .lp-contact-card h3,
.lp-contact .lp-contact-card h4,
.lp-contact .lp-contact-card p,
.lp-contact .lp-contact-card label,
.lp-contact .lp-contact-card a {
  color: inherit;
}
