:root{
  --maxw: 1180px;
  --contentw: 1240px;
  --pad: clamp(18px, 2.2vw, 28px);
  --header-h: 72px;
  --radius: 24px;
  --radius-sm: 18px;
  --border-strong: 2px solid #23486b;
  --border-soft: 1px solid rgba(35,72,107,.16);
  --shadow: 0 16px 42px rgba(24, 43, 66, .10);
  --shadow-soft: 0 10px 30px rgba(24, 43, 66, .08);
  --text: #17304b;
  --muted: #4e6175;
  --navy: #23486b;
  --navy-2: #436a8d;
  --blue-light: #dceaf6;
  --blue-fog: #eff5f9;
  --rose: #ebcfc5;
  --rose-soft: #f5e6e1;
  --green-soft: #dfeee7;
  --white: #fff;
  --font-body: 'Quicksand', system-ui, -apple-system, sans-serif;
  --font-heading: 'Libre Caslon Display', serif;
  --font-script: 'Reenie Beanie', cursive;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--text);
  background:linear-gradient(180deg, #fbfdff 0%, #f6f9fc 100%);
  line-height:1.65;
}
a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:none; }
img,video{ max-width:100%; display:block; }

h1,h2,h3,h4{
  margin:0;
  font-family:var(--font-heading);
  color:var(--navy);
  text-wrap:balance;
}
h1{ font-size:clamp(2.4rem, 5vw, 4.4rem); line-height:1.02; }
h2{ font-size:clamp(2rem, 3.8vw, 3.2rem); line-height:1.08; }
h3{ font-size:clamp(1.35rem, 2.4vw, 1.9rem); line-height:1.18; }
p{ margin:0; }

.body-copy p,
.split-text p,
.hero-copy p,
.contact-text,
.stat-support,
.card-copy,
.acc-body,
.form-note,
.kontakt-note,
.t-card p,
.price-card li,
.feature-table p,
.included-intro,
.detail-copy{
  text-align:justify;
  hyphens:auto;
}

.script-line{
  font-family:var(--font-script);
  color:var(--navy);
  font-size:clamp(2rem, 4vw, 3.2rem);
  line-height:1;
  font-weight:400;
}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  backdrop-filter:blur(14px);
  background:rgba(235,207,197,.92);
  border-bottom:1px solid rgba(35,72,107,.12);
}
.header-inner{
  max-width:var(--contentw);
  margin:0 auto;
  min-height:var(--header-h);
  padding:0 var(--pad);
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:16px;
  align-items:center;
}
.header-nav{ display:flex; align-items:center; gap:14px; }
.nav-toggle{
  display:none;
  width:44px; height:44px;
  border-radius:14px;
  border:var(--border-strong);
  background:transparent;
  color:var(--navy);
  font-size:1.3rem;
  cursor:pointer;
}
.nav-links{ list-style:none; display:flex; gap:6px; padding:0; margin:0; }
.nav-link{
  display:inline-flex;
  align-items:center;
  min-height:44px;
  padding:8px 14px;
  border-radius:999px;
  color:var(--navy);
  font-weight:700;
  transition:background .18s ease, color .18s ease, box-shadow .18s ease;
}
.nav-link:hover,
.nav-link:focus-visible,
.header-brand:hover,
.icon-btn:hover{ background:rgba(255,255,255,.45); }
.nav-link.is-active{
  background:rgba(255,255,255,.62);
  box-shadow:inset 0 0 0 1px rgba(35,72,107,.12);
}
.header-brand{
  justify-self:center;
  padding:10px 16px;
  border-radius:999px;
  color:var(--navy);
  font-family:var(--font-heading);
  font-size:1.35rem;
}
.header-icons{ justify-self:end; display:flex; gap:10px; }
.icon-btn{
  width:42px; height:42px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:14px; border:var(--border-soft); color:var(--navy);
}
.icon-btn svg{ width:20px; height:20px; fill:currentColor; }

.has-dropdown{ position:relative; }
.has-dropdown::after{
  content:'';
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:12px;
}
.dropdown-toggle::after{
  content:'▾';
  font-size:.8em;
  margin-left:8px;
  transform:translateY(-1px);
}
.dropdown{
  list-style:none;
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  min-width:220px;
  padding:8px;
  margin:0;
  border-radius:20px;
  background:rgba(255,255,255,.98);
  border:var(--border-soft);
  box-shadow:var(--shadow-soft);
  display:block;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform:translateY(6px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
}
.dropdown li{ margin:0; }
.dropdown a{
  display:block;
  padding:12px 14px;
  border-radius:14px;
  color:var(--navy);
  font-weight:700;
}
.dropdown a:hover,
.dropdown a:focus-visible{ background:var(--blue-fog); }
.has-dropdown:hover .dropdown,
.has-dropdown:focus-within .dropdown,
.has-dropdown.is-open .dropdown{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform:translateY(0);
}

.page-content{
  min-height:calc(100vh - var(--header-h) - 90px);
}
.section{
  padding:clamp(52px, 8vw, 96px) var(--pad);
}
.section.section-tight{ padding-top:34px; padding-bottom:34px; }
.section-inner{
  max-width:var(--contentw);
  margin:0 auto;
}
.section-band,
.surface,
.split-panel,
.form-card,
.info-card,
.quote-card,
.price-card,
.feature-card,
.stat-tile,
.hero-card,
.media-frame,
.acc-item,
.simple-icon-card{
  background:rgba(255,255,255,.84);
  border:var(--border-soft);
  box-shadow:var(--shadow-soft);
  border-radius:var(--radius);
}

.section-title,
.section-kicker,
.section-intro{
  text-align:center;
}
.section-kicker{
  margin-bottom:14px;
  color:var(--navy-2);
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.9rem;
}
.section-title{ margin-bottom:14px; }
.section-intro{
  max-width:760px;
  margin:0 auto;
  color:var(--muted);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:50px;
  padding:12px 22px;
  border-radius:999px;
  border:2px solid var(--navy);
  background:transparent;
  color:var(--navy);
  font-family:var(--font-script);
  font-size:clamp(1.8rem, 3vw, 2.2rem);
  line-height:1;
  font-weight:400;
  letter-spacing:.01em;
  text-align:center;
  transition:transform .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.btn:hover{ transform:translateY(-1px); background:rgba(35,72,107,.06); }
.btn:focus-visible{ outline:3px solid rgba(67,106,141,.25); outline-offset:2px; }
.btn--rose{ border-color:#c48795; color:#b26377; }
.btn--rose:hover{ background:rgba(196,135,149,.10); }
.btn--light{ border-color:#7295b7; color:#436a8d; }
.btn-row,
.center-cta{ display:flex; justify-content:center; flex-wrap:wrap; gap:12px; }

.hero-main{
  padding-top:clamp(26px, 4vw, 38px);
  min-height:calc(100vh - var(--header-h));
  height:calc(100vh - var(--header-h));
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-shell{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:24px;
  align-items:center;
}
.hero-media{ grid-column:1 / span 2; }
.hero-copy{
  grid-column:3;
  display:grid;
  gap:18px;
}
.hero-image-card{
  border-radius:32px;
  overflow:hidden;
  border:1px solid rgba(35,72,107,.12);
  background:linear-gradient(180deg, #eef4f9 0%, #ffffff 100%);
  padding:12px;
  box-shadow:var(--shadow);
}
.hero-image-card img,
.hero-image-card video,
.media-frame img,
.media-frame video{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:22px;
}
.hero-copy .eyebrow{
  color:var(--navy-2);
  font-size:.95rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.hero-copy h1{
  color:#111;
  display:inline-block;
  padding:10px 18px 14px;
  background:rgba(255,255,255,.72);
  border-radius:26px;
  box-shadow:0 8px 18px rgba(24,43,66,.08);
}
.hero-copy p{
  color:var(--muted);
  background:rgba(255,255,255,.72);
  padding:16px 18px;
  border-radius:22px;
}
.hero-feature-row{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:14px;
}
.hero-feature{
  padding:18px;
  border-top:2px solid rgba(35,72,107,.28);
  border-bottom:2px solid rgba(35,72,107,.18);
  background:rgba(255,255,255,.46);
  text-align:center;
}
.hero-feature strong{ display:block; color:var(--navy); font-size:1rem; }
.hero-feature span{ color:var(--muted); font-size:.96rem; }

.split-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:28px;
  align-items:stretch;
}
.split-grid.reverse .split-media{ order:2; }
.split-grid.reverse .split-text{ order:1; }
.split-panel{
  padding:clamp(24px, 3vw, 34px);
  display:grid;
  gap:18px;
  height:100%;
}
.split-text .btn{ justify-self:center; }
.split-text .lead{ color:var(--navy); font-weight:800; }
.media-frame{ padding:12px; overflow:hidden; }
.media-frame.is-tall{ min-height:540px; }
.media-frame.is-medium{ min-height:420px; }
.media-frame video{ aspect-ratio:16 / 10; }

.stats-section{
  background:linear-gradient(180deg, rgba(35,72,107,.98) 0%, rgba(41,79,115,.96) 100%);
  color:#fff;
}
.stats-section .section-title,
.stats-section .section-intro,
.stats-section .section-kicker{ color:#fff; }
.stats-grid{
  margin-top:32px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
}
.stat-tile{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.15);
  box-shadow:none;
  padding:24px;
  display:grid;
  gap:10px;
  text-align:center;
}
.stat-number{ font-size:clamp(2rem, 4vw, 3.2rem); font-weight:800; color:#fff; }
.stat-label{ font-size:1.12rem; font-weight:700; color:#fff; }
.stat-support{ color:rgba(255,255,255,.84); }

.story-hero{
  background:linear-gradient(180deg, rgba(220,234,246,.62), rgba(255,255,255,0));
}
.story-card{
  padding:clamp(24px, 3vw, 36px);
  background:rgba(255,255,255,.74);
  border-radius:30px;
  border:var(--border-soft);
  box-shadow:var(--shadow);
}
.story-card .btn{ margin-top:8px; }

.icon-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
  margin-top:28px;
}
.simple-icon-card{
  padding:24px;
  display:grid;
  gap:14px;
  text-align:left;
  border:1px solid rgba(35,72,107,.14);
}
.simple-icon-card:nth-child(1){ background:rgba(220,234,246,.92); }
.simple-icon-card:nth-child(2){ background:rgba(245,230,225,.92); }
.simple-icon-card:nth-child(3){ background:rgba(223,238,231,.92); }
.simple-icon-card:nth-child(4){ background:rgba(239,245,249,.95); }
.simple-icon-card:nth-child(5){ background:rgba(245,230,225,.68); }
.simple-icon-card:nth-child(6){ background:rgba(220,234,246,.72); }
.icon-badge{
  width:56px; height:56px;
  display:grid; place-items:center;
  border-radius:18px;
  border:2px solid var(--navy);
  color:var(--navy);
  font-weight:800;
  font-size:1.25rem;
}
.icon-title{ font-weight:800; color:var(--navy); font-size:1.15rem; }
.card-copy{ color:var(--muted); }

.approach-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:start;
}
.approach-stack{
  display:grid;
  gap:16px;
}
.approach-layer{
  position:relative;
  padding:18px 20px 18px 74px;
  border-radius:22px;
  background:rgba(255,255,255,.86);
  border:var(--border-soft);
  box-shadow:var(--shadow-soft);
}
.approach-layer:nth-child(1){ margin-inline:0 0; }
.approach-layer:nth-child(2){ margin-inline:18px; }
.approach-layer:nth-child(3){ margin-inline:34px; }
.approach-layer:nth-child(4){ margin-inline:52px; }
.approach-layer:nth-child(5){ margin-inline:70px; }
.approach-layer:nth-child(6){ margin-inline:88px; background:rgba(223,238,231,.95); }
.layer-number{
  position:absolute;
  left:18px; top:18px;
  width:38px; height:38px;
  display:grid; place-items:center;
  border-radius:14px;
  background:var(--navy);
  color:#fff;
  font-weight:800;
}
.layer-title{ display:block; margin-bottom:4px; font-weight:800; color:var(--navy); }
.layer-copy{ color:var(--muted); }
.detail-card{ padding:28px; }
.detail-card ul{ margin:0; padding-left:20px; color:var(--muted); }
.detail-card li{ margin:10px 0; }

.accordion{ display:grid; gap:14px; margin-top:28px; }
.acc-item{ overflow:hidden; }
.acc-summary{
  list-style:none;
  cursor:pointer;
  padding:18px 22px;
  display:grid;
  grid-template-columns:120px 1fr;
  gap:14px;
  align-items:center;
}
.acc-item > summary::-webkit-details-marker{ display:none; }
.acc-step{
  font-weight:800;
  color:var(--navy);
  border:2px solid rgba(35,72,107,.2);
  border-radius:999px;
  padding:8px 12px;
  text-align:center;
}
.acc-title{ font-weight:800; color:var(--navy); }
.acc-body{ padding:0 22px 22px 28px; color:var(--muted); }
.acc-body li{ margin:8px 0; }
.acc-body ol{ margin-top:8px; padding-left:22px; }

.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:18px;
  margin-top:28px;
}
.price-card{
  padding:28px 22px;
  display:grid;
  gap:14px;
  text-align:center;
  background:rgba(255,255,255,.88);
}
.price-card.featured{ background:rgba(220,234,246,.82); }
.price-card h3{ min-height:70px; }
.price-card ul{ margin:0; padding-left:18px; color:var(--muted); text-align:left; }
.price-card li{ margin:8px 0; }
.price-value{ color:var(--navy); font-size:2rem; font-weight:800; }
.price-note{ color:var(--muted); font-size:.92rem; }
.included-intro{ max-width:760px; margin:0 auto 18px; color:var(--muted); text-align:center; }
.feature-table{
  max-width:860px;
  margin:28px auto 0;
  display:grid;
  gap:0;
  border-top:2px solid rgba(35,72,107,.28);
  border-bottom:2px solid rgba(35,72,107,.18);
}
.feature-row{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:18px;
  padding:16px 8px;
  border-bottom:1px solid rgba(35,72,107,.14);
}
.feature-row:last-child{ border-bottom:none; }
.feature-row strong{ color:var(--navy); }
.feature-row p{ color:var(--muted); }

.testimonials-wrap{ position:relative; margin-top:28px; }
.testimonials-rail{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:minmax(280px, 1fr);
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scrollbar-width:none;
  padding-bottom:8px;
}
.testimonials-rail::-webkit-scrollbar{ display:none; }
.t-card{
  scroll-snap-align:start;
  padding:24px;
  min-height:260px;
  display:grid;
  gap:16px;
  align-content:start;
}
.t-card p{ color:var(--muted); }
.t-meta{ color:var(--navy); font-weight:800; }
.t-arrow{
  position:absolute;
  top:50%; transform:translateY(-50%);
  width:44px; height:44px;
  border-radius:50%;
  border:2px solid var(--navy);
  background:rgba(255,255,255,.92);
  color:var(--navy);
  font-size:1.4rem;
  cursor:pointer;
  display:none;
}
.t-arrow.left{ left:-8px; }
.t-arrow.right{ right:-8px; }

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  align-items:start;
}
.info-card,
.form-card{ padding:clamp(24px, 3vw, 34px); }
.info-card{ display:grid; gap:18px; }
.contact-actions{ display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }
.kontakt-note{ color:var(--muted); }
.copy-buttons{ display:grid; gap:10px; }
.copy-hint{ min-height:24px; color:var(--navy); font-weight:700; }
.contact-form{ display:grid; gap:16px; }
.form-grid{ display:grid; gap:14px; }
.field{ display:grid; gap:8px; }
.field span{ font-weight:800; color:var(--navy); }
.field input,
.field textarea{
  width:100%;
  padding:13px 14px;
  border-radius:18px;
  border:1px solid rgba(35,72,107,.18);
  font:inherit;
  color:var(--text);
  background:#fff;
}
.field input:focus,
.field textarea:focus{
  outline:none;
  border-color:rgba(35,72,107,.5);
  box-shadow:0 0 0 4px rgba(67,106,141,.12);
}
.checkbox-row{
  display:grid;
  grid-template-columns:18px 1fr;
  gap:10px;
  align-items:start;
  color:var(--muted);
}
.checkbox-row a{ color:var(--navy); font-weight:800; }
.form-status{
  min-height:28px;
  padding:0 2px;
  font-weight:800;
  color:var(--navy);
}
.form-status.error{ color:#9b2743; }
.calendar-box{
  padding:28px;
  display:grid;
  gap:14px;
  text-align:center;
  background:rgba(220,234,246,.55);
}

.footer-cta-band{
  background:linear-gradient(180deg, rgba(245,230,225,.82), rgba(255,255,255,0));
}
.site-footer{
  border-top:1px solid rgba(35,72,107,.12);
  background:var(--rose);
}
.footer-inner{
  max-width:var(--contentw);
  margin:0 auto;
  padding:22px var(--pad);
  display:flex;
  justify-content:space-between;
  gap:14px;
  color:var(--navy);
  flex-wrap:wrap;
}
.footer-right{ display:flex; gap:16px; flex-wrap:wrap; }
.footer-right a{ font-weight:700; }

#loginOverlay{
  position:fixed;
  inset:0;
  background:rgba(235,207,197,.96);
  z-index:120;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
}
.login-box{
  width:min(380px, 100%);
  background:#fff;
  border-radius:28px;
  padding:32px 26px;
  box-shadow:var(--shadow);
  display:grid;
  gap:16px;
  text-align:center;
}
.login-box input{
  width:100%; padding:13px 14px;
  border-radius:16px; border:1px solid rgba(35,72,107,.2);
  font:inherit;
}
.login-error{ min-height:20px; color:#9b2743; font-weight:800; }

.utility-center{ text-align:center; }
.mt-8{ margin-top:8px; }
.mt-16{ margin-top:16px; }
.mt-24{ margin-top:24px; }
.mt-32{ margin-top:32px; }

@media (max-width: 1100px){
  .hero-shell{ grid-template-columns:1fr 1fr; }
  .hero-media{ grid-column:1; }
  .hero-copy{ grid-column:2; }
  .hero-feature-row{ grid-template-columns:1fr; }
  .approach-grid{ grid-template-columns:1fr; }
  .pricing-grid,
  .icon-grid,
  .contact-grid,
  .stats-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}

@media (max-width: 900px){
  .header-inner{ grid-template-columns:auto 1fr auto; }
  .nav-toggle{ display:inline-flex; align-items:center; justify-content:center; }
  .nav-links{
    position:absolute;
    top:var(--header-h);
    left:0; right:0;
    padding:10px var(--pad) 18px;
    background:rgba(255,255,255,.98);
    border-bottom:1px solid rgba(35,72,107,.12);
    display:none;
    flex-direction:column;
  }
  .nav-links.open{ display:flex; }
  .has-dropdown::after{ display:none; }
  .dropdown{
    position:static;
    min-width:0;
    box-shadow:none;
    margin-top:6px;
    background:var(--blue-fog);
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:none;
    display:none;
  }
  .has-dropdown.is-open .dropdown{ display:block; }
  .header-brand{ font-size:1.05rem; justify-self:start; }
  .header-icons{ gap:6px; }
  .hero-main{ min-height:auto; }
  .hero-shell,
  .split-grid,
  .contact-grid,
  .approach-grid{ grid-template-columns:1fr; }
  .hero-media,
  .hero-copy{ grid-column:auto; }
  .feature-row{ grid-template-columns:1fr; gap:8px; }
  .acc-summary{ grid-template-columns:1fr; }
}

@media (max-width: 640px){
  .section{ padding:44px var(--pad); }
  .stats-grid,
  .icon-grid,
  .pricing-grid{ grid-template-columns:1fr; }
  .hero-copy h1{ padding:10px 14px 12px; }
  .media-frame.is-tall,
  .media-frame.is-medium{ min-height:auto; }
  .hero-image-card{ padding:8px; }
  .hero-feature{ text-align:left; }
  .t-card{ min-height:220px; }
  .footer-inner{ flex-direction:column; }
  .t-arrow{ display:none !important; }
}

@media (min-width: 901px){
  .t-arrow{ display:inline-flex; align-items:center; justify-content:center; }
}


body.nav-open{ overflow:hidden; }


/* Hilfsangebot page refinements */
.focus-grid-two-by-two{
  max-width: 920px;
  margin-inline: auto;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.accordion-centered{
  max-width: 980px;
  margin-inline: auto;
}

.accordion-centered .acc-summary{
  grid-template-columns: 120px 1fr;
  align-items: center;
}

.accordion-centered .acc-step{
  justify-self: start;
}

.accordion-centered .acc-title{
  text-align: center;
  justify-self: center;
  width: 100%;
  max-width: 640px;
}

.accordion-centered .acc-body{
  padding: 0 22px 22px 148px;
}

.accordion-centered .acc-body ul{
  max-width: 640px;
  margin: 0 auto;
  padding-left: 1.25rem;
}

@media (max-width: 900px){
  .accordion-centered .acc-summary{
    grid-template-columns: 1fr;
  }

  .accordion-centered .acc-step,
  .accordion-centered .acc-title{
    justify-self: stretch;
    text-align: left;
    max-width: none;
  }

  .accordion-centered .acc-body{
    padding: 0 22px 22px 28px;
  }

  .accordion-centered .acc-body ul{
    max-width: none;
    margin: 0;
  }
}

@media (max-width: 640px){
  .focus-grid-two-by-two{
    grid-template-columns: 1fr;
  }
}


.hero-features-section{
  padding-top:40px;
  padding-bottom:60px;
}

.hero-features-section .hero-feature-row{
  max-width:900px;
  margin:0 auto;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
}

.hero-features-section .hero-feature{
  padding:26px 20px;
  text-align:center;
  border-top:2px solid rgba(35,72,107,.3);
  border-bottom:2px solid rgba(35,72,107,.2);
  background:rgba(255,255,255,.6);
}

.hero-features-section .hero-feature strong{
  font-size:1.2rem;
}

.hero-features-section .hero-feature span{
  font-size:1.05rem;
}

/* Responsive refinements: mobile + desktop consistency */
.hero-main,
.section{
  scroll-margin-top: calc(var(--header-h) + 12px);
}

@media (max-width: 900px){
  .hero-main{
    min-height: auto;
    height: auto;
    overflow: visible;
    padding-top: 18px;
    padding-bottom: 10px;
  }

  .hero-shell{
    grid-template-columns: 1fr;
    gap: 18px;
    align-items: start;
  }

  body[data-page="home"] .hero-copy{
    order: 1;
  }

  body[data-page="home"] .hero-media{
    order: 2;
  }

  .hero-copy{
    gap: 14px;
  }

  .hero-copy h1,
  .hero-copy p{
    width: 100%;
  }

  .hero-image-card{
    border-radius: 24px;
  }

  .hero-image-card img{
    max-height: 52vh;
    object-position: center top;
  }

  .split-grid{
    gap: 20px;
  }

  .split-grid.reverse .split-media,
  .split-grid.reverse .split-text{
    order: initial;
  }

  .split-panel,
  .story-card,
  .info-card,
  .form-card,
  .detail-card,
  .price-card,
  .stat-tile,
  .simple-icon-card,
  .acc-item{
    border-radius: 22px;
  }

  .media-frame{
    padding: 8px;
  }

  .media-frame img,
  .media-frame video{
    border-radius: 18px;
  }

  .media-frame.is-medium{
    min-height: auto;
  }

  .media-frame video{
    aspect-ratio: 16 / 9;
  }

  .hero-features-section{
    padding-top: 20px;
    padding-bottom: 34px;
  }

  .hero-features-section .hero-feature-row{
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .hero-features-section .hero-feature{
    padding: 18px 16px;
  }

  .hero-feature{
    text-align: center;
  }

  .stats-grid,
  .icon-grid,
  .pricing-grid{
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .feature-table{
    margin-top: 20px;
  }

  .feature-row{
    padding: 14px 4px;
  }

  .approach-stack{
    gap: 12px;
  }

  .approach-layer{
    margin-inline: 0 !important;
    padding: 16px 16px 16px 64px;
  }

  .layer-number{
    left: 14px;
    top: 14px;
  }

  .contact-grid{
    grid-template-columns: 1fr;
  }

  .contact-grid .form-card{
    order: 1;
  }

  .contact-grid .info-card{
    order: 2;
  }

  .contact-actions{
    flex-direction: column;
    align-items: stretch;
  }

  .contact-actions .btn,
  .copy-buttons .btn,
  .center-cta .btn,
  .btn-row .btn{
    width: 100%;
    max-width: 420px;
  }

  .copy-buttons{
    justify-items: center;
  }

  .calendar-box{
    padding: 22px 18px;
  }

  .accordion-centered .acc-title{
    text-align: left;
  }

  .accordion-centered .acc-body{
    padding: 0 18px 18px 22px;
  }

  .accordion-centered .acc-body ul{
    padding-left: 1.1rem;
  }

  .testimonials-wrap{
    padding-inline: 0;
  }

  .t-arrow{
    display: none !important;
  }
}

@media (max-width: 640px){
  .header-inner{
    gap: 10px;
  }

  .header-brand{
    max-width: 170px;
    line-height: 1.1;
  }

  .header-icons{
    gap: 4px;
  }

  .icon-btn{
    width: 38px;
    height: 38px;
    border-radius: 12px;
  }

  .section{
    padding: 36px var(--pad);
  }

  h1{
    font-size: clamp(2rem, 10vw, 2.8rem);
  }

  h2{
    font-size: clamp(1.7rem, 7vw, 2.3rem);
  }

  .btn{
    min-height: 48px;
    padding: 10px 18px;
    font-size: clamp(1.55rem, 8vw, 2rem);
  }

  .hero-copy .eyebrow,
  .section-kicker{
    font-size: .82rem;
  }

  body[data-page="home"] .hero-image-card img{
    max-height: 38vh;
  }

  .story-card,
  .split-panel,
  .info-card,
  .form-card{
    padding: 20px 16px;
  }

  .stats-section{
    padding-top: 38px;
    padding-bottom: 38px;
  }

  .price-card h3{
    min-height: 0;
  }

  .pricing-cta-top{
    margin-bottom: 18px;
  }

  .contact-form .form-grid{
    gap: 12px;
  }

  .field input,
  .field textarea{
    padding: 12px 13px;
  }

  .footer-right{
    gap: 12px;
  }
}

@media (min-width: 901px){
  .hero-features-section .hero-feature-row{
    align-items: stretch;
  }

  .pricing-cta-top{
    margin-bottom: 24px;
  }
}
