/* ============================================================
   dela-byte.com — Design System 1b "Tiefe"
   Self-hosted fonts: Space Grotesk (display) + Inter (body)
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face {
  font-family: 'Space Grotesk';
  src: url('/fonts/SpaceGrotesk-Variable.woff2') format('woff2-variations');
  font-weight: 300 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('/fonts/Inter-Variable.woff2') format('woff2-variations');
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}

/* ---------- Design tokens ---------- */
:root {
  --navy:   #0E2A47;
  --navy-d: #0a2138;
  --navy-dd:#081a2e;
  --blue:   #2F7DC4;
  --teal:   #22C3BC;
  --coral:  #E1565F;
  --coral-d:#d2454e;
  --gold:   #F1C50E;
  --ink:    #11161D;
  --slate:  #5B6573;
  --light:  #f6f9fc;
  --white:  #ffffff;
  --border: rgba(14,42,71,.1);
  --border-w:rgba(255,255,255,.12);

  --r-sm: 9px;
  --r-md: 14px;
  --r-lg: 18px;
  --r-xl: 22px;

  --shadow-md: 0 20px 44px -22px rgba(14,42,71,.5);
  --shadow-dark: 0 22px 44px -20px rgba(0,0,0,.7);

  --container: 1200px;
  --px: clamp(20px, 4vw, 48px);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:#fff;
  -webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
button,input,textarea,select{font:inherit}
h1,h2,h3,h4,h5,h6{margin:0}
p{margin:0}
ul,ol{list-style:none;padding:0;margin:0}
figure{margin:0}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ---------- Utilities ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--px)}
.text-teal{color:var(--teal)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font:600 15px 'Inter';border-radius:var(--r-sm);
  text-decoration:none;border:none;cursor:pointer;transition:background .18s,transform .14s;
  white-space:nowrap}
.btn--coral{background:var(--coral);color:#fff;box-shadow:0 14px 30px -12px rgba(225,86,95,.7)}
.btn--coral:hover,.btn--coral:focus-visible{background:var(--coral-d);transform:translateY(-1px)}
.btn--ghost{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.18)}
.btn--ghost:hover,.btn--ghost:focus-visible{border-color:var(--teal);color:var(--teal)}
.btn--navy{background:var(--navy);color:#fff}
.btn--navy:hover,.btn--navy:focus-visible{background:#163a5e}
.btn--sm{padding:10px 17px;font-size:14px}
.btn--md{padding:13px 20px}
.btn--lg{padding:15px 24px;font-size:16px}
.btn--full{width:100%;justify-content:center}
.btn:focus-visible{outline:2px solid var(--teal);outline-offset:3px}

/* Kickers */
.kicker{display:inline-flex;align-items:center;gap:10px;font:600 12px/1 'Space Grotesk';
  letter-spacing:.12em;text-transform:uppercase}
.kicker--blue{color:var(--blue)}
.kicker--teal{color:var(--teal)}
.kicker__line{width:26px;height:1.5px;background:currentColor;display:inline-block;flex:none}

/* Section common */
.section-intro{max-width:680px}
.section-title{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:clamp(32px,4vw,46px);
  line-height:1.04;letter-spacing:-.025em;color:var(--navy);margin:16px 0 0}
.section-sub{font:400 18px/1.6 'Inter';color:var(--slate);margin:16px 0 0}

/* Stars */
.star-icon{color:var(--gold)}

/* Check icon */
.check-icon{color:var(--teal);flex:none;margin-top:1px}

/* Prose (article content) */
.prose{font:400 16px/1.7 'Inter';color:#2b3440}
.prose h2{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.6rem;color:var(--navy);
  margin:2em 0 .6em;letter-spacing:-.01em}
.prose h3{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.2rem;color:var(--navy);
  margin:1.6em 0 .5em}
.prose p{margin:.9em 0}
.prose ul,.prose ol{margin:.9em 0;padding-left:1.4em;list-style:disc}
.prose ol{list-style:decimal}
.prose li{margin:.3em 0}
.prose a{color:var(--blue);text-decoration:underline}
.prose a:hover{color:var(--navy)}
.prose strong{font-weight:700}
.prose em{font-style:italic}
.prose code{background:var(--light);padding:2px 6px;border-radius:4px;font-size:.88em}
.prose blockquote{border-left:3px solid var(--teal);margin:1.5em 0;padding:.8em 1.2em;
  background:var(--light);border-radius:0 var(--r-sm) var(--r-sm) 0}
.prose img{border-radius:var(--r-md);margin:1.5em 0}
.prose table{width:100%;border-collapse:collapse;margin:1.5em 0;font-size:.92em}
.prose th,.prose td{border:1px solid var(--border);padding:.6em .8em;text-align:left}
.prose th{background:var(--light);font-weight:600}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{position:sticky;top:0;z-index:60;height:76px;margin-bottom:-76px;color:#e8eff7}
.site-header__bar{position:absolute;inset:0;background:var(--navy-d);
  border-bottom:1px solid rgba(34,195,188,.45);box-shadow:0 14px 34px -22px rgba(0,0,0,.8);
  opacity:1}
.site-header__inner{position:relative;height:76px;max-width:var(--container);margin:0 auto;
  padding:0 var(--px);display:flex;align-items:center;gap:30px}

.site-header__logo img{height:30px;width:auto}

.site-header__nav{display:flex;align-items:center;gap:4px;margin-left:6px}
.site-header__nav-link{font:600 14.5px 'Inter';color:inherit;text-decoration:none;
  padding:9px 12px;border-radius:8px;opacity:.88;transition:opacity .15s,background .15s}
.site-header__nav-link:hover,.site-header__nav-link:focus-visible{opacity:1;background:rgba(255,255,255,.08)}
.site-header__nav-link:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.site-header__nav-btn{display:inline-flex;align-items:center;gap:5px;background:none;border:none;
  cursor:pointer;font:600 14.5px 'Inter';color:inherit;padding:9px 12px;border-radius:8px;
  transition:background .15s}
.site-header__nav-btn:hover,.site-header__nav-btn:focus-visible{background:rgba(255,255,255,.08)}
.site-header__nav-btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.icon-chev{transition:transform .2s;opacity:.55}
.site-header__nav-btn[aria-expanded="true"] .icon-chev{transform:rotate(180deg)}

/* Dropdown */
.site-header__dropdown{position:relative}
.site-header__menu{position:absolute;top:66px;left:0;width:600px;
  background:#0c2742;border:1px solid rgba(34,195,188,.25);border-radius:16px;
  box-shadow:0 30px 60px -24px rgba(0,0,0,.8);padding:18px;
  display:grid;grid-template-columns:1fr 1fr;gap:6px;z-index:70;
  animation:fade-in .15s ease}
.site-header__menu[hidden]{display:none}
@keyframes fade-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.site-header__menu-item{display:flex;gap:12px;padding:13px;border-radius:11px;
  text-decoration:none;transition:background .15s}
.site-header__menu-item:hover,.site-header__menu-item:focus-visible{background:rgba(255,255,255,.06)}
.site-header__menu-item:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}
.site-header__menu-icon{flex:none;width:38px;height:38px;border-radius:9px;
  background:rgba(34,195,188,.16);color:var(--teal);display:grid;place-items:center}
.site-header__menu-name{display:block;font:700 14px 'Space Grotesk';color:#fff}
.site-header__menu-desc{display:block;font:400 12px/1.4 'Inter';color:#9fb3c8;margin-top:2px}

/* Actions */
.site-header__actions{margin-left:auto;display:flex;align-items:center;gap:18px}
.lang-switcher{display:flex;align-items:center;gap:1px;background:rgba(255,255,255,.1);
  padding:3px;border-radius:999px}
.lang-switcher__btn{border:none;cursor:pointer;font:600 11.5px 'Inter';padding:5px 11px;
  border-radius:999px;background:transparent;color:currentColor;transition:all .2s;text-decoration:none}
.lang-switcher__btn.is-active{background:var(--blue);color:#fff}
.lang-switcher__btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
/* Header CTA: spec uses tighter shadow + slightly larger tap target than shared .btn--sm */
.site-header__actions .btn--coral{box-shadow:0 8px 20px -8px rgba(225,86,95,.8)}
.site-header__actions .btn--sm{padding:11px 18px}

/* Burger */
.site-header__burger{display:none;background:none;border:none;cursor:pointer;
  flex-direction:column;gap:5px;padding:8px;border-radius:6px}
.site-header__burger span{display:block;width:22px;height:2px;background:#fff;
  border-radius:2px;transition:transform .2s,opacity .2s}
.site-header__burger:focus-visible{outline:2px solid var(--teal)}

/* Mobile nav */
.mobile-nav{display:none;position:fixed;inset:0;top:76px;background:var(--navy-d);z-index:50;
  overflow-y:auto;padding:24px var(--px) 40px}
.mobile-nav[hidden]{display:none}
.mobile-nav.is-open{display:block}
.mobile-nav__section{margin-bottom:24px}
.mobile-nav__label{font:700 11px 'Space Grotesk';letter-spacing:.1em;text-transform:uppercase;
  color:var(--teal);margin-bottom:8px}
.mobile-nav__link{display:block;font:500 18px 'Inter';color:#cdd8e3;text-decoration:none;
  padding:10px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.mobile-nav__link:hover{color:#fff}
.mobile-nav__cta{margin-top:32px}

@media (max-width:900px){
  .site-header__nav,.site-header__actions .btn{display:none}
  .site-header__burger{display:flex}
  .lang-switcher{margin-right:auto}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:166px 0 96px;background:var(--navy);overflow:hidden}
.hero__bg-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(122,165,206,.16) 1.3px,transparent 1.3px);
  background-size:24px 24px;opacity:.55;pointer-events:none}
.hero__glow{position:absolute;pointer-events:none;border-radius:50%}
.hero__glow--tr{top:-160px;right:-120px;width:620px;height:620px;
  background:radial-gradient(circle,rgba(34,195,188,.22),transparent 62%)}
.hero__glow--bl{bottom:-200px;left:-120px;width:560px;height:560px;
  background:radial-gradient(circle,rgba(47,125,196,.28),transparent 62%)}
.hero__inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
.hero__content{display:flex;flex-direction:column;gap:0}
.hero__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(40px,5vw,64px);line-height:1.02;letter-spacing:-.025em;color:#fff;
  margin:24px 0 0;text-wrap:balance}
.hero__sub{font:400 19px/1.6 'Inter';color:#bcccde;margin:24px 0 0;max-width:530px}
.hero__ctas{display:flex;align-items:center;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero__trust{display:flex;align-items:center;gap:24px;margin-top:36px;flex-wrap:wrap}
.hero__trust-item{display:inline-flex;align-items:center;gap:7px;font:500 13.5px 'Inter';color:#9fb3c8}

.hero__visual{position:relative}
.hero__img-frame{border:1px solid rgba(34,195,188,.4);border-radius:var(--r-xl);
  padding:10px;background:rgba(255,255,255,.03)}
.hero__img{border-radius:14px;display:block;width:100%;height:420px;object-fit:cover}

.hero__rating-badge{position:absolute;left:-24px;bottom:-20px;background:#0c2742;
  border:1px solid rgba(34,195,188,.35);border-radius:15px;box-shadow:var(--shadow-dark);
  padding:15px 18px;display:flex;align-items:center;gap:13px}
.hero__rating-value{font:700 22px 'Space Grotesk';color:#fff;margin-top:3px}
.hero__rating-divider{width:1px;height:38px;background:rgba(255,255,255,.16);flex:none}
.hero__rating-label{font:600 12.5px/1.35 'Inter';color:#9fb3c8;max-width:108px}

/* Hero eyebrow uses wider tracking than other kickers; CTAs use the prominent 11px radius */
.hero .kicker{letter-spacing:.14em}
.hero__ctas .btn{border-radius:11px}
.hero__ctas .btn--coral{box-shadow:0 16px 34px -12px rgba(225,86,95,.8)}
.hero__ctas .btn--ghost{padding:15px 22px}

@media (max-width:900px){
  .hero{padding:110px 0 60px}
  .hero__inner{grid-template-columns:1fr}
  .hero__visual{display:none}
}

/* ============================================================
   TRUST BADGES
   ============================================================ */
.trust-badges{background:var(--navy);border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);padding:15px 0}
.trust-badges__inner{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}
.trust-badge{display:inline-flex;align-items:center;gap:9px;font:600 12.5px 'Inter';
  color:#cdd8e3;padding:7px 15px;border:1px solid rgba(34,195,188,.28);
  border-radius:999px;background:rgba(34,195,188,.06)}
.trust-badge svg{color:var(--teal)}
/* Per-badge accents so the sales points read as distinct signals */
.trust-badge:nth-child(1){border-color:rgba(47,125,196,.42);background:rgba(47,125,196,.09)}
.trust-badge:nth-child(1) svg{color:#6aaede}
.trust-badge:nth-child(2){border-color:rgba(34,195,188,.4);background:rgba(34,195,188,.08)}
.trust-badge:nth-child(3){border-color:rgba(241,197,14,.5);background:rgba(241,197,14,.1);
  color:#fff;font-weight:700}
.trust-badge:nth-child(3) svg{color:var(--gold)}
.trust-badge:nth-child(4){border-color:rgba(225,86,95,.42);background:rgba(225,86,95,.08)}
.trust-badge:nth-child(4) svg{color:#ef8f95}

/* ============================================================
   STACK LOGOS (technologies we work with)
   ============================================================ */
.stack-logos{background:var(--navy-d);border-top:1px solid rgba(255,255,255,.07);padding:26px 0}
.stack-logos__inner{display:flex;align-items:center;gap:36px;flex-wrap:wrap}
.stack-logos__label{font:600 11.5px/1.4 'Space Grotesk';letter-spacing:.1em;text-transform:uppercase;
  color:#5e718a;max-width:200px;flex:none}
.stack-logos__list{display:flex;align-items:center;gap:52px;flex-wrap:wrap;flex:1;
  justify-content:space-around}
.stack-logos__img{width:80px;height:48px;object-fit:contain;opacity:.88;transition:opacity .2s}
.stack-logos__img:hover{opacity:1}

/* ============================================================
   SERVICES
   ============================================================ */
.services{padding:100px 0;background:var(--light)}
.services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
.service-card{display:flex;flex-direction:column;height:100%;text-decoration:none;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:transform .22s,box-shadow .22s,border-color .22s}
.service-card:hover,.service-card:focus-visible{transform:translateY(-5px);
  box-shadow:0 26px 50px -26px rgba(14,42,71,.5);border-color:rgba(34,195,188,.6)}
.service-card:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}
.service-card--flag .service-card__flag-bar{height:4px;background:linear-gradient(90deg,var(--teal),var(--blue))}
.service-card__body{padding:28px 26px 26px;display:flex;flex-direction:column;gap:14px;flex:1 1 auto}
.service-card__top{display:flex;align-items:center;justify-content:space-between}
.service-card__icon{width:48px;height:48px;border-radius:12px;background:rgba(34,195,188,.14);
  color:var(--navy);display:grid;place-items:center;flex:none}
.service-card__badge{display:inline-flex;align-items:center;gap:5px;font:700 11px 'Space Grotesk';
  letter-spacing:.04em;text-transform:uppercase;color:var(--navy);
  background:rgba(34,195,188,.2);padding:5px 10px;border-radius:999px}
.service-card__name{font:700 20px 'Space Grotesk';letter-spacing:-.01em;color:var(--navy);margin:0}
.service-card__desc{font:400 14.5px/1.55 'Inter';color:var(--slate);margin:0}
.service-card__more{display:inline-flex;align-items:center;gap:7px;font:600 13.5px 'Inter';
  color:var(--blue);margin-top:auto;align-self:flex-start}

/* Per-card accents: each service gets its own color; the Shopware flag card
   stays the visually strongest (gradient bar + tinted background) */
.service-card--flag{background:linear-gradient(180deg,rgba(34,195,188,.06),#fff 55%);
  border-color:rgba(34,195,188,.5)}
.services__grid li:nth-child(1) .service-card__icon{background:rgba(47,125,196,.13);color:var(--blue)}
.services__grid li:nth-child(1) .service-card:hover{border-color:rgba(47,125,196,.55)}
.services__grid li:nth-child(2) .service-card__icon{background:rgba(34,195,188,.16);color:var(--teal)}
.services__grid li:nth-child(3) .service-card__icon{background:rgba(241,197,14,.18);color:#8a7108}
.services__grid li:nth-child(3) .service-card:hover{border-color:rgba(241,197,14,.6)}
.services__grid li:nth-child(4) .service-card__icon{background:rgba(225,86,95,.12);color:var(--coral)}
.services__grid li:nth-child(4) .service-card:hover{border-color:rgba(225,86,95,.5)}
.services__grid li:nth-child(5) .service-card__icon{background:rgba(14,42,71,.1);color:var(--navy)}
.services__grid li:nth-child(5) .service-card:hover{border-color:rgba(14,42,71,.45)}
.services__grid li:nth-child(6) .service-card__icon{background:rgba(122,165,206,.18);color:#3f6a94}
.services__grid li:nth-child(6) .service-card:hover{border-color:rgba(122,165,206,.65)}

@media (max-width:900px){.services__grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.services__grid{grid-template-columns:1fr}}

/* ============================================================
   WHY SECTION — navy
   ============================================================ */
.why-section{padding:96px 0;background:var(--navy);position:relative;overflow:hidden}
.why-section__bg-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(122,165,206,.13) 1.3px,transparent 1.3px);
  background-size:24px 24px;opacity:.5;pointer-events:none}
.why-section__inner{position:relative;display:grid;grid-template-columns:.8fr 1.2fr;gap:50px;align-items:center}
.why-section__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(28px,3.5vw,42px);line-height:1.06;letter-spacing:-.025em;color:#fff;margin:16px 0 0}

.why-section__head{max-width:640px}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:30px}
.stats-grid--wide{grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
.stats-grid__item{border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:18px}
.stats-grid--wide .stats-grid__item{padding:28px 26px;background:rgba(255,255,255,.03)}
.stats-grid__value{font:700 32px 'Space Grotesk';letter-spacing:-.02em;color:var(--teal)}
.stats-grid--wide .stats-grid__value{font-size:46px}
.stats-grid__label{font:500 12.5px/1.35 'Inter';color:#9fb3c8;margin-top:5px}
.stats-grid--wide .stats-grid__label{font-size:14px;margin-top:8px}
@media (max-width:900px){.stats-grid--wide{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.stats-grid--wide{grid-template-columns:1fr}}
/* Visual hierarchy: each stat gets its own accent; the review score is featured */
.stats-grid__item:nth-child(2) .stats-grid__value{color:var(--blue)}
.stats-grid__item:nth-child(3){background:rgba(241,197,14,.09);border-color:rgba(241,197,14,.45)}
.stats-grid__item:nth-child(3) .stats-grid__value{color:var(--gold);font-size:37px}
.stats-grid--wide .stats-grid__item:nth-child(3) .stats-grid__value{font-size:50px}
.stats-grid__item:nth-child(3) .stats-grid__value::after{content:' ★';font-size:21px;vertical-align:3px}
.stats-grid__item:nth-child(3) .stats-grid__label{color:#c8d6e4}
.stats-grid__item:nth-child(4) .stats-grid__value{color:#e8eff7}

.why-cards{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.why-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);
  border-radius:16px;padding:26px}
.why-card__icon{width:44px;height:44px;border-radius:11px;background:rgba(34,195,188,.16);
  color:var(--teal);display:grid;place-items:center}
.why-card__title{font:700 18px 'Space Grotesk';color:#fff;margin:18px 0 0}
.why-card__desc{font:400 14px/1.55 'Inter';color:#a9bccf;margin:9px 0 0}

@media (max-width:900px){
  .why-section__inner{grid-template-columns:1fr}
  .why-cards{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){.why-cards{grid-template-columns:1fr}}

/* ============================================================
   SHOPWARE SECTION — white
   ============================================================ */
.shopware-section{padding:96px 0;background:#fff}
.shopware-section__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.shopware-section__img-frame{border:1px solid rgba(14,42,71,.12);border-radius:20px;overflow:hidden;
  min-height:380px;position:relative}
.shopware-section__img{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;display:block}
.shopware-section__visual{position:relative}
.shopware-section__badge{position:absolute;right:-18px;bottom:-18px;background:var(--navy);
  color:#fff;border-radius:14px;padding:14px 18px;box-shadow:0 20px 40px -18px rgba(14,42,71,.7)}
.shopware-section__badge-kicker{font:600 10.5px 'Space Grotesk';letter-spacing:.08em;
  text-transform:uppercase;color:var(--teal)}
.shopware-section__badge-line{font:700 16px 'Space Grotesk';margin-top:3px}
.shopware-section__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(26px,3.5vw,40px);line-height:1.08;letter-spacing:-.025em;
  color:var(--navy);margin:16px 0 0}
.shopware-section__body{font:400 16px/1.65 'Inter';color:var(--slate);margin:16px 0 0}
.shopware-bullets{display:grid;grid-template-columns:1fr 1fr;gap:12px 22px;margin-top:24px}
.shopware-bullets__item{display:flex;align-items:flex-start;gap:9px;font:500 14px/1.4 'Inter';
  color:#2b3440}
/* Spec CTA: 11px radius, 14px 22px padding, 30px above (shared .btn--navy/.btn--md differ) */
.shopware-section__content .btn{border-radius:11px;padding:14px 22px;margin-top:30px}
/* Flipped variant (SEO spotlight): text left, visual right */
.shopware-section--flip{background:var(--light);border-top:1px solid rgba(14,42,71,.06)}
.shopware-section--flip .shopware-section__visual{order:2}
@media (max-width:900px){.shopware-section--flip .shopware-section__visual{order:0}}

/* ============================================================
   TECH CARDS (Technologien — Alt-Content überarbeitet)
   ============================================================ */
.tech-section{padding:96px 0;background:#fff;border-top:1px solid rgba(14,42,71,.06)}
.tech-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(255px,1fr));gap:20px;
  margin-top:42px;padding:0}
.tech-card{display:flex;flex-direction:column;gap:12px;background:var(--light);
  border:1px solid var(--border);border-radius:var(--r-lg);padding:26px;
  transition:transform .2s,box-shadow .2s,border-color .2s}
.tech-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -24px rgba(14,42,71,.4);
  border-color:rgba(34,195,188,.5)}
.tech-card__logo{height:40px;display:flex;align-items:center}
.tech-card__logo img{max-height:38px;width:auto;object-fit:contain}
.tech-card__name{font:700 18px 'Space Grotesk';letter-spacing:-.01em;color:var(--navy);margin:0}
.tech-card__desc{font:400 14px/1.6 'Inter';color:var(--slate);margin:0;flex:1 1 auto}
.tech-card__link{display:inline-flex;align-items:center;gap:7px;font:600 13.5px 'Inter';
  color:var(--blue);text-decoration:none;align-self:flex-start}
.tech-card__link:hover{color:var(--navy)}

@media (max-width:900px){.shopware-section__inner{grid-template-columns:1fr}}
@media (max-width:600px){.shopware-bullets{grid-template-columns:1fr}}

/* ============================================================
   MID CTA — navy
   ============================================================ */
.mid-cta{background:var(--navy);position:relative;overflow:hidden;padding:62px 0}
.mid-cta__bg-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(122,165,206,.13) 1.3px,transparent 1.3px);
  background-size:24px 24px;opacity:.5;pointer-events:none}
.mid-cta__glow{position:absolute;top:-130px;right:-70px;width:420px;height:420px;
  background:radial-gradient(circle,rgba(34,195,188,.18),transparent 62%);pointer-events:none}
.mid-cta__inner{position:relative;max-width:1100px;display:flex;align-items:center;
  justify-content:space-between;gap:32px;flex-wrap:wrap}
.mid-cta__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(22px,3vw,32px);line-height:1.1;letter-spacing:-.02em;color:#fff;margin:0}
.mid-cta__sub{font:400 16px/1.55 'Inter';color:#bcccde;margin:12px 0 0;max-width:540px}
.mid-cta__left{flex:1;min-width:300px}
/* Spec CTA: 11px radius, 16px 26px padding, stronger shadow than shared .btn--lg/.btn--coral */
.mid-cta .btn--lg{border-radius:11px;padding:16px 26px}
.mid-cta .btn--coral{box-shadow:0 16px 34px -12px rgba(225,86,95,.8)}

/* ============================================================
   PROCESS
   ============================================================ */
.process-section{padding:94px 0;background:var(--light);border-top:1px solid rgba(14,42,71,.06)}
.process-section__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(26px,3.5vw,42px);letter-spacing:-.025em;color:var(--navy);
  margin:16px 0 38px}
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  counter-reset:step}
.process-step{background:#fff;border:1px solid rgba(14,42,71,.1);border-radius:16px;
  padding:26px 24px 24px;position:relative;transition:transform .2s,box-shadow .2s}
.process-step:hover{transform:translateY(-4px);box-shadow:0 16px 34px -20px rgba(14,42,71,.45)}
.process-step__dot{display:none}
.process-step__no{display:inline-grid;place-items:center;width:46px;height:46px;
  border-radius:50%;font:700 19px 'Space Grotesk';letter-spacing:-.02em;color:#fff}
/* Each step advances through the brand palette: teal → blue → navy → coral */
.process-step:nth-child(1) .process-step__no{background:var(--teal)}
.process-step:nth-child(2) .process-step__no{background:var(--blue)}
.process-step:nth-child(3) .process-step__no{background:var(--navy)}
.process-step:nth-child(4) .process-step__no{background:var(--coral)}
/* Connector arrows between steps (desktop only) */
.process-step:not(:last-child)::after{content:'→';position:absolute;top:36px;right:-16px;
  font:700 17px 'Space Grotesk';color:rgba(14,42,71,.35);z-index:1}
.process-step__title{font:700 19px 'Space Grotesk';color:var(--navy);margin:14px 0 0}
.process-step__desc{font:400 14px/1.55 'Inter';color:var(--slate);margin:8px 0 0}
@media (max-width:900px){.process-step::after{display:none}}

@media (max-width:900px){.process-steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.process-steps{grid-template-columns:1fr}}

/* ============================================================
   CASES (Referenzen)
   ============================================================ */
.cases-section{padding:96px 0;background:#fff}
.cases-section__head{display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;flex-wrap:wrap}
.cases-section__all-link{display:inline-flex;align-items:center;gap:8px;
  font:600 14.5px 'Inter';color:var(--blue);text-decoration:none}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}
.case-card{display:block;text-decoration:none;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);overflow:hidden;transition:transform .22s,box-shadow .22s}
.case-card:hover,.case-card:focus-visible{transform:translateY(-5px);
  box-shadow:0 26px 50px -26px rgba(14,42,71,.5)}
.case-card:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}
.case-card__img{height:188px;background:var(--light);overflow:hidden}
.case-card__body{padding:24px}
.case-card__sector{font:600 11.5px 'Space Grotesk';letter-spacing:.06em;text-transform:uppercase;
  color:var(--blue)}
.case-card__title{font:700 18px/1.25 'Space Grotesk';color:var(--navy);margin:10px 0 0}
.case-card__outcome{display:flex;align-items:center;gap:9px;margin:18px 0 0;
  font:600 13px 'Inter';color:var(--slate)}
.case-card__tags{display:flex;gap:7px;flex-wrap:wrap;margin-top:18px}
.case-card__tag{font:600 11.5px 'Inter';color:var(--slate);background:#EEF2F6;
  padding:5px 10px;border-radius:999px}

@media (max-width:900px){.cases-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.cases-grid{grid-template-columns:1fr}}

/* ============================================================
   STIMMEN (Testimonials) — navy
   ============================================================ */
.stimmen{padding:96px 0;background:var(--navy);position:relative;overflow:hidden}
.stimmen__bg-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(122,165,206,.13) 1.3px,transparent 1.3px);
  background-size:24px 24px;opacity:.5;pointer-events:none}
.stimmen__glow{position:absolute;bottom:-160px;left:-100px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(34,195,188,.16),transparent 62%);pointer-events:none}
.stimmen__inner{position:relative;display:grid;grid-template-columns:.82fr 1.18fr;
  gap:54px;align-items:center}
.stimmen__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(22px,3vw,36px);line-height:1.1;letter-spacing:-.025em;color:#fff;margin:16px 0 0}
.stimmen__rating{display:flex;align-items:center;gap:14px;margin-top:28px;
  padding:18px 20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-radius:16px}
.stimmen__rating-value{font:700 15px 'Space Grotesk';color:#fff}
.stimmen__rating-divider{width:1px;height:42px;background:rgba(255,255,255,.14);flex:none}
.stimmen__rating-label{font:500 12.5px/1.4 'Inter';color:#9fb3c8;max-width:150px}

.stimmen__carousel{position:relative}
.stimmen__quote-mark{font-family:'Space Grotesk';font-weight:700;font-size:84px;line-height:.6;
  color:rgba(34,195,188,.45);height:44px;user-select:none}
.stimmen__slide-stars{display:flex;gap:3px;color:var(--gold);margin-bottom:16px}
.stimmen__quote{margin:0;font:500 clamp(16px,2.2vw,24px)/1.42 'Space Grotesk';
  letter-spacing:-.01em;color:#fff;min-height:132px}
.stimmen__author{display:flex;align-items:center;gap:12px;margin-top:16px}
.stimmen__avatar{width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--blue));flex:none}
.stimmen__author-name{font:600 14px 'Inter';color:#fff}
.stimmen__author-tag{display:block;font-weight:400;color:#7e93a8;font-size:12.5px;margin-top:2px}
.stimmen__controls{display:flex;align-items:center;gap:14px;margin-top:26px}
.stimmen__btn{width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  background:none;color:#fff;cursor:pointer;display:grid;place-items:center;transition:border-color .15s,color .15s}
.stimmen__btn:hover,.stimmen__btn:focus-visible{border-color:var(--teal);color:var(--teal)}
.stimmen__btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.stimmen__dots{display:flex;gap:8px;margin-left:10px}
.stimmen__dot{width:9px;height:9px;border-radius:50%;border:none;cursor:pointer;padding:0;
  background:rgba(255,255,255,.25);transition:background .2s}
.stimmen__dot.is-active{background:var(--teal)}
.stimmen__dot:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

@media (max-width:900px){.stimmen__inner{grid-template-columns:1fr}}

/* ============================================================
   FULL-SERVICE ERKLÄRT (definitional + FAQ)
   ============================================================ */
.fsa-section{padding:96px 0;background:var(--light);border-top:1px solid rgba(14,42,71,.06)}
.fsa-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:48px;margin-top:42px}
.fsa-def{font:400 16px/1.75 'Inter';color:#2b3440}
.fsa-def p{margin:0 0 1em}
.fsa-def p:last-child{margin-bottom:0}
.fsa-def a{color:var(--blue);text-decoration:underline}
.fsa-def a:hover{color:var(--navy)}
.fsa-def__lead{font:600 17px/1.6 'Inter';color:var(--navy)}
.fsa-points{display:grid;grid-template-columns:1fr 1fr;gap:9px 20px;margin:4px 0 22px;padding:0}
.fsa-points__item{position:relative;padding-left:28px;font:500 15px/1.5 'Inter';color:var(--navy)}
.fsa-points__item::before{content:'✓';position:absolute;left:0;top:0;width:19px;height:19px;
  border-radius:50%;background:rgba(34,195,188,.16);color:var(--teal);
  font:700 11px/19px 'Inter';text-align:center}
.fsa-highlight{background:rgba(34,195,188,.08);border-left:3px solid var(--teal);
  border-radius:0 var(--r-sm) var(--r-sm) 0;padding:16px 20px;margin:0 0 20px;
  font:500 15.5px/1.65 'Inter';color:var(--navy)}
.fsa-def__guide a{font-weight:600;text-decoration:none}
.fsa-def__guide a:hover{text-decoration:underline}
.fsa-faq{display:flex;flex-direction:column;gap:12px}
.fsa-faq__title{font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:1.15rem;
  color:var(--navy);margin:0 0 6px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--r-md);padding:2px 20px;
  transition:border-color .2s,box-shadow .2s}
.faq-item:hover{border-color:rgba(34,195,188,.45)}
.faq-item[open]{border-color:rgba(34,195,188,.55);border-left:3px solid var(--teal);
  box-shadow:0 12px 28px -20px rgba(14,42,71,.35)}
.faq-item summary{cursor:pointer;font:600 15.5px/1.5 'Space Grotesk',sans-serif;color:var(--navy);
  padding:14px 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-item summary:hover{color:var(--teal)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:20px;color:var(--teal);flex-shrink:0;line-height:1}
.faq-item[open] summary::after{content:'\2013'}
.faq-item summary:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.faq-item p{font:400 15px/1.7 'Inter';color:#2b3440;margin:0;padding:0 0 16px}

/* ============================================================
   INSIGHTS
   ============================================================ */
.insights-section{padding:96px 0;background:#fff}
.insights-section__head{display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;flex-wrap:wrap}
.insights-section__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(26px,3.5vw,42px);letter-spacing:-.025em;color:var(--navy);margin:16px 0 0}
.insights-section__all-link{display:inline-flex;align-items:center;gap:8px;
  font:600 14.5px 'Inter';color:var(--blue);text-decoration:none;white-space:nowrap}

/* Explainer card */
.explainer-card{display:grid;grid-template-columns:1.25fr 1fr;gap:0;align-items:stretch;
  margin-top:36px;background:var(--navy);border-radius:20px;overflow:hidden;
  text-decoration:none;position:relative;transition:transform .22s,box-shadow .22s}
.explainer-card:hover,.explainer-card:focus-visible{transform:translateY(-3px);
  box-shadow:0 26px 50px -26px rgba(14,42,71,.6)}
.explainer-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.explainer-card__content{padding:40px 44px}
.explainer-card__tag{display:inline-flex;align-items:center;gap:8px;font:600 11px 'Space Grotesk';
  letter-spacing:.1em;text-transform:uppercase;color:var(--teal)}
.explainer-card__title{font:700 clamp(18px,2.5vw,27px)/1.16 'Space Grotesk';
  letter-spacing:-.02em;color:#fff;margin:14px 0 0}
.explainer-card__body{font:400 15px/1.6 'Inter';color:#bcccde;margin:13px 0 0;max-width:470px}
.explainer-card__cta{display:inline-flex;align-items:center;gap:8px;margin-top:20px;
  font:600 14px 'Inter';color:var(--teal)}
.explainer-card__visual{position:relative;min-height:210px;
  background:linear-gradient(135deg,rgba(34,195,188,.2),rgba(47,125,196,.1))}
.explainer-card__bg-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(122,165,206,.22) 1.3px,transparent 1.3px);
  background-size:20px 20px;opacity:.6}
.explainer-card__vs{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:7px;font-family:'Space Grotesk';font-weight:700;font-size:25px;
  color:#e5eef8;letter-spacing:-.01em;text-align:center;padding:0 18px}
.explainer-card__vs .text-teal{color:var(--teal);font-size:13px;letter-spacing:.18em;
  text-transform:uppercase}

/* Article list */
.article-list{margin-top:40px;border-top:1px solid rgba(14,42,71,.1)}
.article-row{display:grid;grid-template-columns:140px 1fr auto;align-items:center;gap:26px;
  padding:24px 0;border-bottom:1px solid rgba(14,42,71,.1);text-decoration:none;transition:background .15s}
.article-row:hover,.article-row:focus-visible{background:var(--light)}
.article-row:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}
.article-row__thumb{width:140px;height:88px;border-radius:11px;object-fit:cover;flex:none}
.article-row__thumb--placeholder{background:linear-gradient(135deg,var(--teal) 0%,var(--blue) 100%)}
.article-row__meta{display:flex;align-items:center;gap:10px;font:600 11.5px 'Space Grotesk';letter-spacing:.05em;text-transform:uppercase;
  color:var(--blue);margin-bottom:4px}
.article-row__readinfo{color:#9aa6b3;font-weight:500;letter-spacing:0;text-transform:none}
.article-row__title{font:700 clamp(16px,2vw,22px)/1.25 'Space Grotesk';color:var(--navy);margin:8px 0 0}
.article-row__arrow{color:var(--blue);flex:none}

@media (max-width:700px){.explainer-card{grid-template-columns:1fr}.explainer-card__visual{display:none}
  .article-row{grid-template-columns:1fr auto}.article-row__thumb{display:none}}

/* Contact left column: benefits checklist + channel cards */
.contact-benefits{margin:22px 0 26px;padding:0;display:flex;flex-direction:column;gap:11px}
.contact-benefits__item{position:relative;padding-left:30px;font:500 15px/1.55 'Inter';color:#cdd8e3}
.contact-benefits__item::before{content:'✓';position:absolute;left:0;top:1px;width:20px;height:20px;
  border-radius:50%;background:rgba(34,195,188,.18);color:var(--teal);
  font:700 11px/20px 'Inter';text-align:center}
.contact-channels{display:flex;flex-direction:column;gap:12px;margin-top:4px;max-width:420px}
.contact-channel{display:flex;align-items:center;gap:15px;text-decoration:none;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.14);border-radius:14px;
  padding:15px 18px;transition:border-color .2s,background .2s,transform .2s}
.contact-channel:hover,.contact-channel:focus-visible{border-color:rgba(34,195,188,.65);
  background:rgba(34,195,188,.07);transform:translateY(-2px)}
.contact-channel:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.contact-channel__icon{width:42px;height:42px;border-radius:11px;background:rgba(34,195,188,.16);
  color:var(--teal);display:grid;place-items:center;flex:none}
.contact-channel__text{display:flex;flex-direction:column;gap:2px}
.contact-channel__label{font:700 15px 'Space Grotesk';color:#fff}
.contact-channel__value{font:400 13px 'Inter';color:#9fb3c8}
/* Light-theme variants for the standalone /kontakt page */
.contact-benefits--light .contact-benefits__item{color:#2b3440}
.contact-channel--light{background:#fff;border-color:var(--border)}
.contact-channel--light:hover,.contact-channel--light:focus-visible{background:rgba(34,195,188,.06);
  border-color:rgba(34,195,188,.6)}
.contact-channel--light .contact-channel__label{color:var(--navy)}
.contact-channel--light .contact-channel__value{color:var(--slate)}
.contact-hours{font:400 13px 'Inter';color:#9fb3c8;margin:16px 0 0}
.contact-hours--light{color:var(--slate)}

/* ============================================================
   CONTACT SECTION — dark navy
   ============================================================ */
.contact-section{background:var(--navy-d);position:relative;overflow:hidden}
.contact-section__bg-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(122,165,206,.13) 1.3px,transparent 1.3px);
  background-size:24px 24px;opacity:.5;pointer-events:none}
.contact-section__inner{position:relative;padding-top:88px;padding-bottom:88px;display:grid;
  grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.contact-section__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(26px,3.5vw,42px);line-height:1.06;letter-spacing:-.025em;
  color:#fff;margin:16px 0 0}
.contact-section__sub{font:400 17px/1.6 'Inter';color:#bcccde;margin:16px 0 0;max-width:430px}
.contact-section__senior{display:flex;align-items:flex-start;gap:9px;font:600 14px/1.5 'Inter';
  color:#e4ecf5;margin:18px 0 0;max-width:450px}
.contact-section__person{display:flex;align-items:center;gap:15px;margin-top:28px}
.contact-section__avatar{width:62px;height:62px;border-radius:50%;
  background:linear-gradient(135deg,var(--teal),var(--blue));flex:none}
.contact-section__person-name{font:700 16px 'Space Grotesk';color:#fff}
.contact-section__person-role{font:400 13.5px 'Inter';color:#94a6bb;margin-top:2px}
.contact-section__links{display:flex;align-items:center;gap:22px;margin-top:24px;flex-wrap:wrap}
.contact-section__link{display:inline-flex;align-items:center;gap:9px;color:#e4ecf5;
  text-decoration:none;font:600 15px 'Inter';transition:color .15s}
.contact-section__link:hover,.contact-section__link:focus-visible{color:var(--teal)}
.contact-section__link svg{color:var(--teal)}

/* Contact Form */
.contact-form{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-lg);padding:30px}
.contact-form__row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-form__label{display:flex;flex-direction:column;gap:6px;font:600 12.5px 'Inter';
  color:#cdd8e3;margin-top:0}
.contact-form__row+.contact-form__label{margin-top:14px}
.contact-form__input,.contact-form__textarea{background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.16);border-radius:var(--r-sm);padding:11px 12px;
  font:400 14px 'Inter';color:#fff;transition:border-color .15s;width:100%}
.contact-form__input:focus,.contact-form__textarea:focus{border-color:var(--teal);outline:none}
.contact-form__input.is-error,.contact-form__textarea.is-error{border-color:var(--coral)}
.contact-form__textarea{resize:vertical}
.contact-form__error{font:400 11.5px 'Inter';color:#f9a8ad;margin-top:4px}
.contact-form__error--field{display:block}
.contact-form__error--global{background:rgba(225,86,95,.14);border:1px solid rgba(225,86,95,.45);
  border-radius:var(--r-sm);padding:12px 16px;font:600 13.5px 'Inter';color:#f9a8ad;
  margin-bottom:16px}
.contact-form__error--global[hidden],.contact-form__success[hidden]{display:none}
.contact-form .btn{margin-top:16px;padding:14px;font-weight:700;border-radius:11px}
.contact-form__consent{font:400 11.5px/1.45 'Inter';color:#7e93a8;margin:12px 0 0}
.contact-form__success{background:rgba(34,195,188,.15);border:1px solid rgba(34,195,188,.4);
  border-radius:var(--r-sm);padding:12px 16px;font:600 14px 'Inter';color:var(--teal);
  margin-bottom:16px}

@media (max-width:900px){.contact-section__inner{grid-template-columns:1fr}}
@media (max-width:600px){.contact-form__row{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy-dd);color:#9fb0c1;padding:64px 0 30px}
.site-footer__inner{max-width:var(--container);margin:0 auto;padding:0 var(--px)}
.site-footer__cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:38px}
.site-footer__logo{height:26px;width:auto;margin-bottom:14px}
.site-footer__blurb{font:400 14px/1.6 'Inter';color:#7e93a8;max-width:280px}
.site-footer__dach{display:flex;align-items:center;gap:8px;margin-top:18px;
  font:600 12.5px 'Inter';color:var(--teal)}
.site-footer__dot{width:8px;height:8px;border-radius:50%;background:var(--teal);flex:none}
.site-footer__socials{display:flex;gap:10px;margin-top:18px}
.site-footer__social{width:36px;height:36px;border-radius:9px;background:rgba(255,255,255,.07);
  color:#cdd8e3;display:grid;place-items:center;text-decoration:none;transition:background .15s,color .15s}
.site-footer__social:hover,.site-footer__social:focus-visible{background:var(--teal);color:#06332f}
.site-footer__social:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.site-footer__col-title{font:700 13px 'Space Grotesk';letter-spacing:.04em;text-transform:uppercase;
  color:#fff;margin-bottom:16px}
.site-footer__link{display:block;font:400 14px 'Inter';color:#92a5b8;text-decoration:none;
  padding:5px 0;transition:color .15s}
.site-footer__link:hover,.site-footer__link:focus-visible{color:#fff}
.site-footer__link:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.site-footer__bottom{display:flex;align-items:center;justify-content:space-between;gap:20px;
  flex-wrap:wrap;margin-top:46px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1)}
.site-footer__copy{font:400 13px 'Inter';color:#6b8199}
.site-footer__copy-link{color:#92a5b8;text-decoration:none}
.site-footer__copy-link:hover{color:#fff}
.site-footer__nl{display:flex;align-items:center;gap:12px}
.site-footer__nl-label{font:500 12.5px 'Inter';color:#6b8199}
.site-footer__nl-form{display:flex;background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);border-radius:var(--r-sm);overflow:hidden}
.site-footer__nl-input{background:none;border:none;padding:9px 12px;font:400 13px 'Inter';
  color:#fff;width:170px;outline:none}
.site-footer__nl-input::placeholder{color:#6b8199}
.site-footer__nl-btn{background:var(--teal);border:none;color:#06332f;font:700 13px 'Inter';
  padding:0 16px;cursor:pointer;transition:background .15s}
.site-footer__nl-btn:hover,.site-footer__nl-btn:focus-visible{background:#3ad3cc}
.site-footer__nl-btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

@media (max-width:900px){
  .site-footer__cols{grid-template-columns:1fr 1fr}
  .site-footer__brand{grid-column:1/-1}
}
@media (max-width:600px){
  .site-footer__cols{grid-template-columns:1fr}
  .site-footer__bottom{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   ARTICLE PAGE
   ============================================================ */
.article-page{}
.article-page__header{background:var(--navy);padding:80px 0 60px}
.article-page__header-inner{max-width:800px}
.article-page__meta{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}
.article-page__date{font:400 13px 'Inter';color:#9fb3c8}
.article-page__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(26px,4vw,46px);line-height:1.08;letter-spacing:-.025em;color:#fff;text-wrap:balance}
.article-page__excerpt{font:400 18px/1.55 'Inter';color:#bcccde;margin:16px 0 0;max-width:640px}
.article-page__body-wrap{display:grid;grid-template-columns:1fr 280px;gap:48px;
  padding-top:56px;padding-bottom:80px;align-items:start}
.article-body{max-width:740px}
.article-page__footer{padding-bottom:56px}
.article-page__back{font:600 14px 'Inter';color:var(--blue);text-decoration:none}
.article-page__back:hover{color:var(--navy)}

/* Sidebar */
.article-sidebar{position:sticky;top:96px}
.sidebar-cta{background:var(--navy);border-radius:var(--r-lg);padding:24px;
  display:flex;flex-direction:column;gap:14px}
.sidebar-cta__title{font:700 16px 'Space Grotesk';color:#fff;margin:0}
.sidebar-cta__sub{font:400 13.5px/1.5 'Inter';color:#9fb3c8;margin:0}
.sidebar-cta__email{font:600 13px 'Inter';color:#bcccde;text-decoration:none;
  word-break:break-all}
.sidebar-cta__email:hover{color:var(--teal)}

@media (max-width:900px){
  .article-page__body-wrap{grid-template-columns:1fr}
  .article-sidebar{display:none}
}

/* ============================================================
   LEGAL / CONTACT PAGES
   ============================================================ */
.legal-page__inner{max-width:800px;padding-top:128px;padding-bottom:80px}
.legal-page__header h1{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(26px,4vw,40px);color:var(--navy);margin-bottom:32px}
.legal-page__body{margin-top:32px}

.contact-page__inner{display:grid;grid-template-columns:1fr 1fr;gap:54px;
  align-items:center;padding-top:128px;padding-bottom:80px}
.contact-page__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(24px,3.5vw,42px);line-height:1.06;letter-spacing:-.025em;color:var(--navy);
  margin:16px 0 0}
.contact-page__sub{font:400 17px/1.6 'Inter';color:var(--slate);margin:16px 0 0}
.contact-page .contact-form{background:var(--light);border-color:rgba(14,42,71,.1)}
.contact-page .contact-form__label{color:var(--navy)}
.contact-page .contact-form__input,.contact-page .contact-form__textarea{
  background:#fff;border-color:rgba(14,42,71,.16);color:var(--ink)}
.contact-page .contact-form__input:focus,.contact-page .contact-form__textarea:focus{border-color:var(--blue)}
.contact-page .contact-form__consent{color:#9aa6b3}

@media (max-width:900px){.contact-page__inner{grid-template-columns:1fr}}

/* ============================================================
   INSIGHTS PAGE
   ============================================================ */
.insights-page{padding:128px 0 80px}
.insights-page__header{margin-bottom:48px}
.insights-page__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(26px,4vw,42px);letter-spacing:-.025em;color:var(--navy);margin:16px 0 0}
.insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.insight-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);
  border-radius:var(--r-lg);padding:28px;text-decoration:none;transition:transform .2s,box-shadow .2s;
  height:100%}
.insight-card:hover,.insight-card:focus-visible{transform:translateY(-4px);
  box-shadow:var(--shadow-md)}
.insight-card:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}
.insight-card__cat{font:600 11.5px 'Space Grotesk';letter-spacing:.06em;text-transform:uppercase;
  color:var(--blue)}
.insight-card__title{font:700 20px/1.3 'Space Grotesk';color:var(--navy);margin:12px 0 0}
.insight-card__excerpt{font:400 14px/1.55 'Inter';color:var(--slate);margin:8px 0 0;flex:1}
.insight-card__date{font:400 12px 'Inter';color:#9aa6b3;margin-top:16px}

@media (max-width:900px){.insights-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.insights-grid{grid-template-columns:1fr}}

/* ============================================================
   BREADCRUMB
   ============================================================ */
.breadcrumb{padding:16px 0;background:var(--navy-d);border-bottom:1px solid rgba(255,255,255,.06)}
.breadcrumb ol{max-width:var(--container);margin:0 auto;padding:0 var(--px);
  display:flex;align-items:center;gap:8px;font:400 13px 'Inter';color:#7e93a8}
.breadcrumb li{display:flex;align-items:center;gap:8px}
.breadcrumb li:not(:last-child)::after{content:'›';color:#5e718a}
.breadcrumb a{color:#9fb3c8;text-decoration:none}
.breadcrumb a:hover{color:#fff}
.breadcrumb [aria-current]{color:#cdd8e3}

/* ============================================================
   ERROR PAGE (404)
   ============================================================ */
.error-page{padding:150px 0 110px;background:var(--navy);position:relative;overflow:hidden;
  min-height:72vh;display:flex;align-items:center}
.error-page__bg-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(122,165,206,.14) 1.3px,transparent 1.3px);
  background-size:24px 24px;opacity:.5;pointer-events:none}
.error-page__inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.error-page__code{font:700 clamp(84px,12vw,150px)/1 'Space Grotesk';letter-spacing:-.04em;
  color:#fff;margin:0;text-shadow:0 24px 60px rgba(0,0,0,.45)}
.error-page__title{font-family:'Space Grotesk',sans-serif;font-weight:700;
  font-size:clamp(24px,3.2vw,38px);letter-spacing:-.025em;color:#fff;margin:18px 0 0}
.error-page__lead{font:400 16.5px/1.65 'Inter';color:#cdd8e3;margin:16px 0 0;max-width:520px}
.error-page__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}
.error-page__quip{font:400 13px 'Inter';color:#7e93a8;margin:26px 0 0}

/* Fake terminal (dev-agency wink) */
.terminal{background:var(--navy-dd);border:1px solid rgba(255,255,255,.14);border-radius:14px;
  overflow:hidden;box-shadow:0 34px 70px -30px rgba(0,0,0,.7)}
.terminal__bar{display:flex;align-items:center;gap:7px;padding:11px 14px;
  background:rgba(255,255,255,.05);border-bottom:1px solid rgba(255,255,255,.09)}
.terminal__dot{width:11px;height:11px;border-radius:50%}
.terminal__dot--r{background:#e1565f}
.terminal__dot--y{background:#f1c50e}
.terminal__dot--g{background:#22c38a}
.terminal__bar-title{font:500 11.5px 'Inter';color:#7e93a8;margin-left:8px}
.terminal__body{padding:20px 22px 24px;font:400 13.5px/1.9 ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  color:#cdd8e3;overflow-wrap:anywhere}
.terminal__body p{margin:0}
.terminal__prompt{color:var(--teal);font-weight:700;margin-right:6px}
.terminal__err{color:#f9a8ad}
.terminal__muted{color:#7e93a8}
.terminal__link{color:var(--teal);text-decoration:underline}
.terminal__link:hover{color:#fff}
.terminal__cursor{color:var(--teal);animation:term-blink 1.1s steps(1) infinite}
@keyframes term-blink{50%{opacity:0}}
@media (prefers-reduced-motion:reduce){.terminal__cursor{animation:none}}
@media (max-width:900px){.error-page__inner{grid-template-columns:1fr;text-align:center}
  .error-page__actions{justify-content:center}
  .error-page__lead{margin-left:auto;margin-right:auto}
  .error-page__terminal{max-width:520px;margin:0 auto;width:100%;text-align:left}}

/* ============================================================
   KEYWORD LANDING PAGE components (inside .prose article bodies)
   ============================================================ */
.prose .lp-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:1.4em 0;
  padding:0;list-style:none}
.prose .lp-grid li{background:var(--light);border:1px solid var(--border);border-radius:12px;
  padding:16px 18px;margin:0;font:400 14px/1.55 'Inter';color:var(--slate)}
.prose .lp-grid li strong{display:block;font:700 15px 'Space Grotesk';color:var(--navy);
  margin-bottom:4px}
.prose .lp-grid li a{color:var(--blue)}
.prose .lp-check{list-style:none;padding:0;margin:1.2em 0;display:flex;flex-direction:column;gap:11px}
.prose .lp-check li{position:relative;padding-left:31px;margin:0;font:400 15px/1.6 'Inter';color:#2b3440}
.prose .lp-check li::before{content:'✓';position:absolute;left:0;top:2px;width:20px;height:20px;
  border-radius:50%;background:rgba(34,195,188,.15);color:var(--teal);
  font:700 11px/20px 'Inter';text-align:center}
.prose .lp-steps{list-style:none;padding:0;margin:1.4em 0;counter-reset:lp;
  display:flex;flex-direction:column;gap:12px}
.prose .lp-steps li{counter-increment:lp;position:relative;margin:0;
  padding:16px 18px 16px 62px;background:var(--light);border:1px solid var(--border);
  border-radius:12px;font:400 14.5px/1.6 'Inter';color:var(--slate)}
.prose .lp-steps li::before{content:counter(lp,decimal-leading-zero);position:absolute;
  left:16px;top:16px;width:32px;height:32px;border-radius:50%;background:var(--teal);
  color:#fff;font:700 13px 'Space Grotesk';display:grid;place-items:center}
.prose .lp-steps li strong{color:var(--navy)}
.prose .lp-faq{display:flex;flex-direction:column;gap:12px;margin:1.2em 0}
.prose .lp-faq .faq-item p{margin:0;padding:0 0 16px}
.prose .lp-cta{background:var(--navy);border-radius:16px;padding:30px 32px;margin:2.4em 0 0;
  color:#cdd8e3;font:400 15.5px/1.65 'Inter'}
.prose .lp-cta h2{color:#fff;margin:0 0 .5em}
.prose .lp-cta p{margin:0 0 1.3em}
/* .prose a (color:var(--blue)) outranks .btn--coral (color:#fff); restore button colors inside article bodies */
.prose a.btn{text-decoration:none;color:#fff}
.prose a.btn:hover,.prose a.btn:focus-visible{color:#fff}
@media (max-width:700px){.prose .lp-grid{grid-template-columns:1fr}}

/* ============================================================
   FOCUS & SKIP LINK
   ============================================================ */
:focus-visible{outline:2px solid var(--teal);outline-offset:3px}
.skip-link{position:absolute;top:-100%;left:16px;background:var(--teal);color:#fff;
  padding:10px 18px;border-radius:0 0 var(--r-sm) var(--r-sm);font:600 14px 'Inter';
  text-decoration:none;z-index:9999;transition:top .15s}
.skip-link:focus{top:0}
