:root{
  --bg0:#070A12;
  --bg1:#0B1022;

  --text:#EAF0FF;
  --muted: rgba(234,240,255,.72);

  --a:#2F7BFF;
  --b:#27E0C3;
  --c:#A855F7;
  --shadow: 0 22px 60px rgba(0,0,0,.45);
}

*{ box-sizing:border-box; }
html, body{ height:100%; background: var(--bg0); }
body{
  margin:0;
  color: var(--text);
  font-family: "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  overflow-x:hidden;
}
a{ color: inherit; text-decoration:none; }
.container{ width:min(1100px, calc(100% - 32px)); margin:0 auto; }
.page{ padding-top: 86px; }
.muted{ color: var(--muted); }

/* ---------- Background FX ---------- */
.bgFx{
  position: fixed; inset: 0; z-index: -2; pointer-events:none;
  background:
    radial-gradient(1200px 700px at 18% 15%, rgba(47,123,255,.20), transparent 60%),
    radial-gradient(900px 600px at 86% 22%, rgba(39,224,195,.18), transparent 55%),
    radial-gradient(900px 700px at 60% 92%, rgba(168,85,247,.14), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
}
.bgParticles{ position:absolute; inset:0; opacity:.65; filter: drop-shadow(0 0 18px rgba(47,123,255,.20)); }
.bgGlow{
  position:absolute; inset:-30%;
  background:
    radial-gradient(circle at 25% 20%, rgba(47,123,255,.24), transparent 45%),
    radial-gradient(circle at 70% 30%, rgba(39,224,195,.22), transparent 40%),
    radial-gradient(circle at 55% 80%, rgba(168,85,247,.20), transparent 45%);
  filter: blur(18px);
  animation: glowMove 12s ease-in-out infinite alternate;
  opacity:.9;
}
@keyframes glowMove{
  from{ transform: translate3d(-1.5%, -1%, 0) scale(1); }
  to{ transform: translate3d(1.5%, 1.2%, 0) scale(1.03); }
}
.bgGrid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: radial-gradient(closest-side at 50% 40%, rgba(0,0,0,.85), transparent 78%);
  opacity:.35;
  transform: perspective(900px) rotateX(55deg) translateY(180px);
  transform-origin: top;
  animation: gridFloat 8s ease-in-out infinite alternate;
}
@keyframes gridFloat{
  from{ transform: perspective(900px) rotateX(55deg) translateY(190px); }
  to{ transform: perspective(900px) rotateX(55deg) translateY(165px); }
}
.bgNoise{
  position:absolute; inset:0; opacity: .07;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='260' height='260'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='260' height='260' filter='url(%23n)' opacity='.65'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}

/* ---------- Nav ---------- */
.navWrap{
  position: fixed; inset: 0 0 auto 0; z-index: 50;
  background: rgba(10,14,28,.55);
  border-bottom: 1px solid rgba(255,255,255,.10);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  transform: translateZ(0);
}
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .navWrap { background: rgba(10,14,28,.92); }
}
.nav{
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding: 14px 16px;
  width: min(1100px, calc(100% - 32px));
  margin: 0 auto;
}
.brand{ display:flex; gap:12px; align-items:center; }
.brand strong{ font-family: "Space Grotesk", "Inter", system-ui; letter-spacing: -0.02em; }
.brand small{ display:block; color: rgba(234,240,255,.72); font-size: 12px; margin-top:2px; }
.logoMark{
  width: 40px; height: 40px; position:relative; display:grid; place-items:center;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(47,123,255,.18), rgba(39,224,195,.16));
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: 0 12px 40px rgba(47,123,255,.18);
  overflow:hidden;
}
.logoPulse{
  position:absolute; inset:-60%;
  background: conic-gradient(from 180deg, rgba(47,123,255,.0), rgba(47,123,255,.55), rgba(39,224,195,.50), rgba(168,85,247,.48), rgba(47,123,255,.0));
  animation: spinSlow 5.5s linear infinite;
  opacity:.85;
}
@keyframes spinSlow{ to{ transform: rotate(360deg); } }
.logoLetter{ position:relative; font-weight: 900; font-family: "Space Grotesk", "Inter", system-ui; }

.navLinks{ display:flex; gap:16px; align-items:center; }
.navLinks a{
  padding:10px 10px; border-radius: 12px;
  color: rgba(234,240,255,.82);
  font-weight: 700; font-size: 14px;
  transition: background .2s ease, transform .2s ease;
}
.navLinks a:hover{ background: rgba(255,255,255,.08); transform: translateY(-1px); }
.navCtas{ display:flex; gap:10px; align-items:center; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  height: 42px; padding: 0 16px; border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.06));
  color: var(--text);
  font-weight: 800; font-size: 14px;
  box-shadow: 0 16px 46px rgba(0,0,0,.22);
  transition: transform .18s ease, filter .18s ease, box-shadow .18s ease;
}
.btn:hover{ filter: brightness(1.06); transform: translateY(-1px); }
.btn:active{ transform: translateY(0px) scale(.99); }
.btn.ghost{ background: rgba(255,255,255,.06); color: rgba(234,240,255,.92); }
.btn.ghost:hover{ background: rgba(255,255,255,.10); }

.scrollBar{
  height: 3px; width: 0%;
  background: linear-gradient(90deg, rgba(47,123,255,.95), rgba(39,224,195,.90), rgba(168,85,247,.90));
  box-shadow: 0 0 24px rgba(47,123,255,.25);
}

/* ---------- Hero ---------- */
.hero{ padding: 44px 0 18px; }
.heroGrid{
  width: min(1100px, calc(100% - 32px));
  margin: 0 auto;
  display:grid;
  grid-template-columns: 1.18fr .82fr;
  gap: 18px;
}
.pill{
  display:inline-flex; align-items:center; gap:10px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(234,240,255,.86);
  font-weight: 800; font-size: 13px;
}
.pillDot{
  width: 9px; height: 9px; border-radius:999px;
  background: rgba(39,224,195,.95);
  box-shadow: 0 0 18px rgba(39,224,195,.60);
  animation: pulseDot 1.8s ease-in-out infinite;
}
@keyframes pulseDot{ 0%,100%{ transform: scale(1); opacity:.9; } 50%{ transform: scale(1.35); opacity:1; } }
h1{
  margin: 14px 0 10px;
  font-size: clamp(30px, 4.2vw, 46px);
  letter-spacing: -0.03em;
  line-height: 1.05;
  font-family: "Space Grotesk", "Inter", system-ui;
}
.gradText{
  background: linear-gradient(90deg, rgba(47,123,255,1), rgba(39,224,195,1), rgba(168,85,247,1));
  -webkit-background-clip: text;
  background-clip:text;
  color: transparent;
}
.lead{ margin:0; color: rgba(234,240,255,.78); font-size: 16px; line-height: 1.6; }
.heroActions{ display:flex; gap:10px; margin-top: 18px; flex-wrap: wrap; }

.heroPanel{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  padding: 16px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.heroPanelInner h2{ margin: 0 0 10px; font-size: 18px; font-family: "Space Grotesk", "Inter"; letter-spacing:-.01em; }
.checkList{ margin:0; padding-left: 18px; color: rgba(234,240,255,.78); }
.checkList li{ margin: 8px 0; }
.heroNote{
  margin-top: 14px;
  padding: 12px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(47,123,255,.16), rgba(255,255,255,.05));
  border: 1px solid rgba(47,123,255,.22);
}
.trustRow{ display:flex; gap:10px; margin-top: 16px; flex-wrap: wrap; }
.trustCard{
  display:flex; gap:10px; align-items:center;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 16px 48px rgba(0,0,0,.24);
}
.trustCard small{ display:block; color: rgba(234,240,255,.68); font-size: 12px; }
.trustIcon{
  width: 34px; height: 34px; border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  font-weight: 900; font-size: 12px;
}

/* ---------- Sections ---------- */
.section{ padding: 56px 0; }
.section.alt{
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.sectionHead h2{
  margin:0;
  font-size: 28px;
  letter-spacing: -0.02em;
  font-family: "Space Grotesk", "Inter";
}
.sectionHead p{ margin: 8px 0 0; color: rgba(234,240,255,.72); }

.cards{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 18px; }
.card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  padding: 16px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.card h3{ margin:0 0 8px; font-size: 18px; font-family: "Space Grotesk","Inter"; }
.card p{ margin:0 0 10px; color: rgba(234,240,255,.72); }
.miniList{ margin:0; padding-left: 18px; color: rgba(234,240,255,.75); }
.miniList li{ margin: 6px 0; }

/* ---------- Pricing ---------- */
.pricingGrid{ display:grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 18px; }
.priceCard{
  position:relative;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  padding: 16px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.priceCard.featured{
  border-color: rgba(39,224,195,.28);
  background:
    radial-gradient(900px 320px at 20% 10%, rgba(39,224,195,.18), transparent 55%),
    radial-gradient(900px 320px at 90% 15%, rgba(47,123,255,.18), transparent 55%),
    rgba(255,255,255,.06);
}
.badge{
  position:absolute; top: 12px; right: 12px;
  font-size: 12px; font-weight: 900;
  padding: 6px 10px; border-radius: 999px;
  background: rgba(39,224,195,.14);
  border: 1px solid rgba(39,224,195,.24);
  color: rgba(234,240,255,.92);
}
.price{ font-size: 30px; font-weight: 950; margin: 8px 0 2px; font-family: "Space Grotesk","Inter"; }
.priceCard ul{ margin: 12px 0 0; padding-left: 18px; color: rgba(234,240,255,.76); }
.priceCard li{ margin: 6px 0; }
.priceNote{
  margin-top: 14px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(39,224,195,.10);
  border: 1px solid rgba(39,224,195,.18);
}

/* ---------- Calculator ---------- */
.calcWrap{ margin-top: 18px; }
.calcCard{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 22px;
  padding: 16px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.calcTop{ display:flex; justify-content:space-between; align-items:flex-start; gap:12px; }
.calcTitle{ margin:0; font-size: 20px; font-family: "Space Grotesk","Inter"; letter-spacing:-.01em; }
.calcPill{
  display:inline-flex; align-items:center; gap:10px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  font-weight: 900; font-size: 12px;
  white-space: nowrap;
}
.calcPillDot{
  width: 9px; height: 9px; border-radius:999px;
  background: rgba(47,123,255,.95);
  box-shadow: 0 0 18px rgba(47,123,255,.55);
}
.calcGrid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.calcControls{
  padding: 14px;
  border-radius: 18px;
  background: rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.10);
}
.calcLabel span{
  display:block;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 8px;
}
.rangeRow{ display:flex; align-items:center; gap: 12px; }
input[type="range"]{ width:100%; accent-color: rgba(39,224,195,.95); }
output{
  min-width: 56px;
  text-align:center;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  font-weight: 900;
}

/* head layout */
.calcControlHead{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
  align-items: start;
}
.timeBlock{
  padding: 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
}
.timeRow{ display:flex; align-items:center; gap: 10px; }
.rateTag{
  padding: 10px 12px;
  border-radius: 16px;
  font-weight: 950;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  white-space: nowrap;
}
.rateTag.night{
  border-color: rgba(168,85,247,.28);
  background: rgba(168,85,247,.12);
}

/* Addons list */
.addons{
  margin-top: 14px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
}
.addonsTitle{
  font-size: 12px;
  font-weight: 950;
  color: rgba(234,240,255,.86);
  margin-bottom: 10px;
  letter-spacing: .02em;
}
.addonList{ display:grid; gap: 10px; }
.addonItem{
  position: relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 12px 12px;
  border-radius: 18px;
  background:
    radial-gradient(700px 180px at 10% 10%, rgba(47,123,255,.10), transparent 55%),
    rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.12);
  cursor:pointer;
  user-select:none;
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.addonItem:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.18);
  background:
    radial-gradient(700px 180px at 10% 10%, rgba(39,224,195,.12), transparent 55%),
    rgba(255,255,255,.06);
}
.addonItem.infoOnly{ cursor: default; opacity: .92; }
.addonItem.infoOnly:hover{ transform:none; }
.addonItem input{ position:absolute; inset:0; opacity:0; pointer-events:none; }

.addonMain{ display:flex; align-items:center; gap: 10px; min-width: 0; }
.addonIcon{
  width: 36px; height: 36px;
  border-radius: 14px;
  display:grid; place-items:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 14px 40px rgba(0,0,0,.22);
  flex: 0 0 auto;
}
.addonText{ display:flex; flex-direction:column; gap:2px; min-width: 0; }
.addonText strong{ font-size: 14px; letter-spacing: -0.01em; }
.addonText small{ font-size: 12px; color: rgba(234,240,255,.68); }

.addonMeta{ display:flex; align-items:center; gap: 10px; flex: 0 0 auto; }
.addonPrice{
  font-weight: 950;
  font-size: 13px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(0,0,0,.20);
  border: 1px solid rgba(255,255,255,.10);
  white-space: nowrap;
}
.addonPrice.subtle{ font-weight: 850; opacity: .85; }

/* Switch */
.switch{
  width: 54px; height: 30px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.14);
  position: relative;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.10);
  transition: background .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.knob{
  position:absolute; top: 3px; left: 3px;
  width: 24px; height: 24px;
  border-radius: 999px;
  background: rgba(234,240,255,.92);
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
  transition: transform .18s ease;
}
.addonItem:has(input:checked) .switch{
  background: rgba(39,224,195,.18);
  border-color: rgba(39,224,195,.34);
  box-shadow: 0 0 0 4px rgba(39,224,195,.10);
}
.addonItem:has(input:checked) .knob{ transform: translateX(24px); }
.addonItem:has(input:checked) .addonPrice{
  background: rgba(39,224,195,.12);
  border-color: rgba(39,224,195,.26);
}

/* right side */
.calcResult{
  padding: 14px;
  border-radius: 18px;
  background:
    radial-gradient(900px 280px at 30% 10%, rgba(47,123,255,.16), transparent 55%),
    rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.10);
}
.calcTotalWrap{
  padding: 10px 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
}
.calcTotalLabel{ font-size: 12px; font-weight: 900; color: rgba(234,240,255,.78); }
.calcTotal{
  font-size: 34px;
  font-weight: 950;
  letter-spacing: -0.02em;
  margin-top: 4px;
  font-family: "Space Grotesk","Inter";
}
.calcSub{ margin-top: 6px; }
.calcBreak{ margin-top: 12px; }
.calcBreakTitle{ font-weight: 950; margin-bottom: 8px; font-size: 12px; color: rgba(234,240,255,.80); }
.calcList{ list-style:none; margin:0; padding:0; display:grid; gap: 8px; }
.calcList li{
  display:flex; justify-content:space-between; gap:12px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
}
.calcCtas{ display:flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.calcFoot{ margin: 12px 0 0; font-size: 12px; }

/* ---------- Ablauf Timeline (NEU) ---------- */
.timeline{
  margin-top: 18px;
  position: relative;
  padding: 16px;
  border-radius: 22px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.tLine{
  position:absolute;
  left: 26px;
  top: 22px;
  bottom: 22px;
  width: 2px;
  background: linear-gradient(180deg, rgba(47,123,255,.0), rgba(47,123,255,.55), rgba(39,224,195,.55), rgba(168,85,247,.55), rgba(47,123,255,.0));
  opacity:.65;
  filter: drop-shadow(0 0 14px rgba(47,123,255,.16));
}
.tStep{
  display:grid;
  grid-template-columns: 48px 1fr;
  gap: 12px;
  align-items: start;
  padding: 10px 6px;
}
.tDot{
  width: 44px; height: 44px;
  border-radius: 16px;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 16px 44px rgba(0,0,0,.26);
  position: relative;
  z-index: 1;
}
.tDot span{
  font-family: "Space Grotesk","Inter";
  font-weight: 950;
}
.tCard{
  border-radius: 20px;
  padding: 14px;
  background:
    radial-gradient(900px 220px at 20% 10%, rgba(47,123,255,.12), transparent 55%),
    rgba(0,0,0,.20);
  border: 1px solid rgba(255,255,255,.10);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.tCard:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.18);
  background:
    radial-gradient(900px 220px at 20% 10%, rgba(39,224,195,.14), transparent 55%),
    rgba(0,0,0,.22);
}
.tTop{
  display:flex;
  gap: 12px;
  align-items:flex-start;
}
.tIcon{
  width: 44px; height: 44px;
  border-radius: 18px;
  display:grid; place-items:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  flex: 0 0 auto;
}
.tCard h3{
  margin: 0 0 6px;
  font-size: 18px;
  font-family: "Space Grotesk","Inter";
}
.tCard p{ margin: 0; color: rgba(234,240,255,.74); line-height: 1.6; }
.tBadges{
  margin-top: 10px;
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
}
.chip{
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  background: rgba(39,224,195,.12);
  border: 1px solid rgba(39,224,195,.20);
}
.chip.ghost{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(234,240,255,.84);
}

/* ---------- Kontakt (Fix + nicer) ---------- */
.contactGrid{
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 14px;
  margin-top: 18px;
}
.contactCard, .formCard{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 20px;
  padding: 16px;
  box-shadow: var(--shadow);
  overflow:hidden;
}
.quickActions{ display:flex; gap:10px; flex-wrap: wrap; margin-top: 10px; }

.contactMeta{ display:grid; gap: 8px; margin-top: 12px; }
.contactMeta div{
  display:flex; justify-content:space-between; gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
}
.miniHint{
  margin-top: 12px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(47,123,255,.10);
  border: 1px solid rgba(47,123,255,.18);
  color: rgba(234,240,255,.86);
}
.miniHint strong{ display:block; margin-bottom: 4px; }

.formCard h3{ margin:0 0 10px; font-family:"Space Grotesk","Inter"; }
label{ display:block; margin-top: 10px; }
label span{
  display:block;
  font-size: 13px;
  font-weight: 900;
  color: rgba(234,240,255,.84);
  margin-bottom: 6px;
}
input, select, textarea{
  width:100%;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.28);
  color: rgba(234,240,255,.92);
  outline: none;
}
input:focus, select:focus, textarea:focus{
  border-color: rgba(39,224,195,.40);
  box-shadow: 0 0 0 4px rgba(39,224,195,.14);
}
input.invalid, select.invalid, textarea.invalid{
  border-color: rgba(255,120,120,.45);
  box-shadow: 0 0 0 4px rgba(255,120,120,.12);
}
.fieldRow{ display:grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.formActions{ display:flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.formHint{ margin-top: 10px; color: rgba(234,240,255,.62); font-size: 12px; }

.formStatus{
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  color: rgba(234,240,255,.78);
  min-height: 44px;
  display:flex;
  align-items:center;
}
.formStatus.ok{
  border-color: rgba(39,224,195,.22);
  background: rgba(39,224,195,.10);
}
.formStatus.err{
  border-color: rgba(255,120,120,.20);
  background: rgba(255,120,120,.08);
}

/* ---------- Footer / Modals / Reveal / Loader ---------- */
.footer{ padding: 24px 0; border-top: 1px solid rgba(255,255,255,.10); background: rgba(0,0,0,.22); }
.footerGrid{ display:flex; align-items:center; justify-content:space-between; gap: 14px; }
.footerLinks{ display:flex; gap: 10px; }
.linkBtn{
  border: 0; background: transparent;
  color: rgba(234,240,255,.82);
  font-weight: 950;
  padding: 10px 10px;
  border-radius: 14px;
  cursor:pointer;
}
.linkBtn:hover{ background: rgba(255,255,255,.06); }

.modal{ position: fixed; inset: 0; display:none; z-index: 100; }
.modal.open{ display:block; }
.modalBackdrop{ position:absolute; inset: 0; background: rgba(0,0,0,.62); }
.modalPanel{
  position: relative;
  width: min(860px, calc(100% - 22px));
  margin: 70px auto;
  background: rgba(15,18,35,.92);
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 28px 100px rgba(0,0,0,.55);
  overflow:hidden;
}
.modalHead{ display:flex; align-items:center; justify-content:space-between; padding: 14px 16px; border-bottom: 1px solid rgba(255,255,255,.10); }
.modalHead h2{ margin:0; font-size: 18px; font-family:"Space Grotesk","Inter"; }
.iconBtn{
  width: 40px; height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  cursor:pointer;
  font-size: 20px;
  color: rgba(234,240,255,.92);
}
.modalBody{ padding: 16px; color: rgba(234,240,255,.86); }
.modalBody h3{ margin-top: 16px; }

.shineCard::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(520px 160px at var(--mx, 30%) var(--my, 10%), rgba(255,255,255,.16), transparent 60%);
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events:none;
}
.shineCard:hover::before{ opacity: 1; }

.reveal{ opacity: 1; transform: none; }
.js .reveal{
  opacity: 0.01;
  transform: translateY(10px);
  transition: opacity .55s ease, transform .55s ease;
  will-change: transform, opacity;
}
.js .reveal.in{ opacity: 1; transform: translateY(0); }

.bootOverlay{
  position: fixed; inset: 0;
  display: grid; place-items: center;
  background: radial-gradient(900px 600px at 30% 20%, rgba(47,123,255,.18), transparent 60%), var(--bg0);
  z-index: 200;
  opacity: 1; visibility: visible;
  transition: opacity .35s ease, visibility .35s ease;
}
.bootOverlay.hide{ opacity: 0; visibility: hidden; }
.bootCard{
  display:flex; gap:12px; align-items:center;
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
}
.bootCard small{ display:block; color: rgba(234,240,255,.66); margin-top: 2px; }
.bootSpinner{
  width: 26px; height: 26px;
  border-radius: 999px;
  border: 3px solid rgba(255,255,255,.16);
  border-top-color: rgba(39,224,195,.85);
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ---------- Mobile ---------- */
.navToggle{
  display:none;
  width: 44px; height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(255,255,255,.06);
}
.navToggle span{ display:block; height:2px; background: rgba(234,240,255,.90); margin: 6px 10px; border-radius:2px; }

@media (max-width: 980px){
  .heroGrid{ grid-template-columns: 1fr; }
  .cards{ grid-template-columns: 1fr; }
  .pricingGrid{ grid-template-columns: 1fr; }
  .calcGrid{ grid-template-columns: 1fr; }
  .calcControlHead{ grid-template-columns: 1fr; }
  .contactGrid{ grid-template-columns: 1fr; }
  .fieldRow{ grid-template-columns: 1fr; }
  .tLine{ left: 24px; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; scroll-behavior: auto !important; }
  .bgGrid{ display:none; }
}