/* ==============================
   DESIGN TOKENS
============================== */
:root{
  --color-primary:#0B1F3B;
  --color-secondary:#1E3A8A;
  --color-accent:#C6A95E;
  --color-light:#F5F7FA;
  --color-dark:#1A1A1A;
  --color-muted:#6B7280;

  --max-width:1120px;
  --radius:12px;
  --transition:0.22s ease;
  --shadow-soft:0 10px 30px rgba(0,0,0,0.12);
}

/* ==============================
   BASE
============================== */
*,
*::before,
*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;
  background:var(--color-light);
  color:var(--color-dark);
  line-height:1.6;
  text-rendering:optimizeLegibility;
}

img{ max-width:100%; height:auto; display:block; }
a{ color:inherit; }

:focus-visible{
  outline:3px solid rgba(198,169,94,0.65);
  outline-offset:3px;
}

.container{
  width:min(var(--max-width),100%);
  margin:0 auto;
  padding:0 1.25rem;
}

section{ padding:5rem 0; }

.skip-link{
  position:absolute;
  left:12px;
  top:12px;
  padding:0.7rem 0.9rem;
  background:#fff;
  border:1px solid rgba(11,31,59,0.15);
  border-radius:10px;
  box-shadow:var(--shadow-soft);
  transform:translateY(-200%);
  transition:transform var(--transition);
  z-index:9999;
}
.skip-link:focus{ transform:translateY(0); }

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}

/* ==============================
   TOP BAR
============================== */
.top_small{
  background:#07162b;
  color:var(--color-light);
  text-align:right;
  font-size:0.8rem;
  padding:1rem;
}
.top_small span{ margin:0 .3rem; }

.call-icon,
.email-icon,
.address-icon{
  position:relative;
  top:.5rem;
}

/* ==============================
   HEADER / NAV
============================== */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(245,247,250,0.85);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(11,31,59,0.10);

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:0.85rem 1rem;
}

#logo{
  width:56px;
  height:56px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  border-radius:12px;
  border:1px solid rgba(11,31,59,0.12);
}

.burger{
  width:44px;
  height:44px;
  border:0;
  background:transparent;
  cursor:pointer;
  display:inline-flex;
  flex-direction:column;
  justify-content:center;
  gap:6px;
}
.burger__bar{
  height:3px;
  width:28px;
  background:var(--color-primary);
  border-radius:2px;
}

.nav{
  position:absolute;
  top:100%;
  left:0;
  width:100%;
  max-height:0;
  overflow:hidden;
  transition:max-height var(--transition);
}
.nav.is-open{ max-height:80vh; }

.nav__list{
  margin:0.6rem 1rem 1rem;
  padding:0.5rem 0;
  list-style:none;
  display:flex;
  flex-direction:column;
  background:#fff;
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  border:1px solid rgba(11,31,59,0.10);
}

.nav__item{ position:relative; }

.nav__link{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0.95rem 1rem;
  text-decoration:none;
  color:var(--color-dark);
  font-weight:650;
  background:transparent;
  border:0;
  cursor:pointer;
  border-radius:10px;
}
.nav__link:hover,
.nav__link:focus-visible{ background:rgba(198,169,94,0.12); }

.dropdown__toggle{ gap:0.75rem; }

.dropdown__icon{
  display:inline-block;
  transition:transform var(--transition);
  opacity:0.85;
}
.dropdown.is-open .dropdown__icon{ transform:rotate(180deg); }

.dropdown__menu{
  list-style:none;
  margin:0;
  padding:0;
  max-height:0;
  overflow:hidden;
  transition:max-height var(--transition);
  background:rgba(11,31,59,0.04);
  border-left:3px solid rgba(198,169,94,0.55);
}
.dropdown.is-open .dropdown__menu{ max-height:520px; }

.dropdown__link{
  display:block;
  padding:0.8rem 1.5rem;
  text-decoration:none;
  color:var(--color-dark);
  font-weight:560;
}
.dropdown__link:hover,
.dropdown__link:focus-visible{
  background:rgba(198,169,94,0.12);
  outline:none;
}

@media (min-width:900px){
  .burger{ display:none; }

  .nav{
    position:static;
    max-height:none;
    overflow:visible;
    width:auto;
  }

  .nav__list{
    margin:0;
    padding:0;
    flex-direction:row;
    align-items:center;
    background:transparent;
    border:0;
    box-shadow:none;
    gap:0.25rem;
  }

  .nav__link{
    width:auto;
    padding:0.7rem 0.9rem;
  }

  .dropdown__menu{
    position:absolute;
    top:calc(100% + 10px);
    left:0;
    min-width:260px;
    max-height:none;
    overflow:visible;
    padding:0.6rem;
    opacity:0;
    visibility:hidden;
    transform:translateY(-6px);
    transition:opacity var(--transition), transform var(--transition), visibility var(--transition);
    background:var(--color-primary);
    border:1px solid rgba(11,31,59,0.12);
    border-radius:16px;
    box-shadow:0 12px 34px rgba(0,0,0,0.16);
    border-left:none;
  }

  .dropdown__link{
    color:var(--color-light);
    padding:0.6rem 0.75rem;
    border-radius:10px;
  }

  .dropdown.is-open .dropdown__menu{
    opacity:1;
    visibility:visible;
    transform:translateY(0);
  }
}

/* ==============================
   SECTION HEADER
============================== */
.section-header{
  text-align:center;
  max-width:920px;
  margin:0 auto 2.6rem;
}
.section-header h2{
  margin:0 0 0.8rem;
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:800;
  letter-spacing:-0.4px;
  color:var(--color-primary);
}
.section-header p{
  margin:0 auto;
  max-width:820px;
  color:var(--color-muted);
  font-size:1.05rem;
}

/* ==============================
   BUTTONS
============================== */
.hero-actions{
  display:flex;
  justify-content:center;
  gap:1rem;
  flex-wrap:wrap;
  margin:0 0 1.8rem;
}

.btn{
  padding:0.95rem 1.65rem;
  border-radius:var(--radius);
  text-decoration:none;
  font-weight:720;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:44px;
  transition:transform var(--transition), background var(--transition),
    border-color var(--transition), box-shadow var(--transition), color var(--transition);
  box-shadow:0 10px 24px rgba(0,0,0,0.18);
  border:1px solid transparent;
}
.btn-primary{
  background:linear-gradient(180deg,#d3b86f 0%, var(--color-accent) 60%, #b89543 100%);
  color:#0f0f0f;
  border-color:rgba(198,169,94,0.6);
}
.btn-secondary{
  background:rgba(245,247,250,0.06);
  border-color:rgba(245,247,250,0.28);
  color:var(--color-light);
  backdrop-filter:blur(6px);
}
.btn:hover{
  transform:translateY(-1px);
  box-shadow:0 16px 30px rgba(0,0,0,0.25);
}
.btn-secondary:hover{ border-color:rgba(198,169,94,0.65); }

.btn[disabled]{
  opacity:0.75;
  cursor:not-allowed;
  transform:none !important;
  box-shadow:none !important;
}

.btn-dark{
  color:var(--color-primary);
  background:rgba(30,58,138,0.06);
  border-color:rgba(30,58,138,0.18);
}
.btn-dark:hover{
  border-color:rgba(198,169,94,0.65);
}

/* ==============================
   HERO RETAIL
============================== */
#hero-retail{
  color:var(--color-light);
  padding:5.5rem 0 3.5rem;
  background:
    radial-gradient(1000px 600px at 20% 10%, rgba(30,58,138,0.35), transparent 55%),
    radial-gradient(900px 500px at 80% 20%, rgba(198,169,94,0.18), transparent 60%),
    linear-gradient(180deg,#07162b 0%, var(--color-primary) 55%, #081936 100%);
  position:relative;
}
#hero-retail::after{
  content:"";
  position:absolute;
  bottom:0;
  left:50%;
  transform:translateX(-50%);
  width:min(980px,92%);
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(198,169,94,0.55), transparent);
}

.hero-retail__grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:1.6rem;
  align-items:center;
}
.hero-retail__copy{ grid-column:span 7; }

.hero-retail__media{
  grid-column:span 5;
  border-radius:calc(var(--radius) + 4px);
  overflow:hidden;
  border:1px solid rgba(245,247,250,0.18);
  box-shadow:0 18px 50px rgba(0,0,0,0.25);
  background:rgba(245,247,250,0.05);
}
.hero-retail__media img{
  width:100%;
  height:auto;
  display:block;
  aspect-ratio:800 / 520;
  object-fit:cover;
  transform:scale(1.01);
  transition:transform var(--transition);
}
.hero-retail__media:hover img{ transform:scale(1.04); }

.hero-retail__eyebrow{
  margin:0 0 0.9rem;
  color:rgba(245,247,250,0.80);
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-size:0.85rem;
}
.hero-retail__copy h1{
  margin:0 0 1rem;
  font-size:clamp(2.1rem,5vw,3.4rem);
  font-weight:800;
  letter-spacing:-0.6px;
}
.hero-retail__lead{
  margin:0 0 2rem;
  max-width:760px;
  font-size:1.1rem;
  color:rgba(245,247,250,0.86);
  line-height:1.75;
}

.hero-highlights{
  list-style:none;
  padding:0;
  margin:0;
  max-width:760px;
  display:grid;
  gap:0.6rem;
  color:rgba(245,247,250,0.86);
  font-size:0.98rem;
}
.hero-highlights li{
  background:rgba(245,247,250,0.06);
  border:1px solid rgba(245,247,250,0.12);
  border-radius:calc(var(--radius) - 2px);
  padding:0.65rem 0.9rem;
}

/* ==============================
   TRUST BAR
============================== */
.trust-bar{
  padding:1.15rem 0;
  background:rgba(255,255,255,0.92);
  border-bottom:1px solid rgba(11,31,59,0.10);
}
.trust-bar__list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:0.75rem;
}
.trust-bar__item{
  grid-column:span 3;
  display:flex;
  align-items:center;
  gap:0.75rem;
  padding:0.85rem 0.9rem;
  border-radius:14px;
  background:linear-gradient(180deg,#ffffff 0%, rgba(245,247,250,0.70) 100%);
  border:1px solid rgba(11,31,59,0.10);
  box-shadow:0 10px 22px rgba(0,0,0,0.05);
}
.trust-bar__icon{
  width:34px;
  height:34px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(30,58,138,0.08);
  border:1px solid rgba(30,58,138,0.16);
  color:var(--color-primary);
  font-weight:900;
  flex:0 0 34px;
}
.trust-bar__text{
  color:var(--color-dark);
  font-size:0.95rem;
  line-height:1.25;
}
.trust-bar__text strong{
  color:var(--color-primary);
  font-weight:800;
}

/* ==============================
   LEISTUNGSUMFANG
============================== */
#leistungen-retail{ background:#fff; }

.retail-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:1.25rem;
}
.retail-card{
  grid-column:span 6;
  background:linear-gradient(180deg,#ffffff 0%, rgba(245,247,250,0.70) 100%);
  border:1px solid rgba(11,31,59,0.10);
  border-radius:calc(var(--radius) + 2px);
  padding:1.55rem 1.45rem;
  box-shadow:0 10px 26px rgba(0,0,0,0.06);
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
  position:relative;
  overflow:hidden;
}
.retail-card::before{
  content:"";
  position:absolute;
  top:0; left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg, rgba(198,169,94,0.15), rgba(198,169,94,0.95), rgba(198,169,94,0.15));
  opacity:0.8;
}
.retail-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(0,0,0,0.12);
  border-color:rgba(198,169,94,0.45);
}
.retail-card h3{
  margin:0 0 0.55rem;
  color:var(--color-primary);
  font-size:1.15rem;
  letter-spacing:-0.2px;
}
.retail-card p{
  margin:0;
  color:var(--color-muted);
  line-height:1.75;
  font-size:0.98rem;
}

.seo-box{
  max-width:920px;
  margin:2rem auto 0;
  background:#fff;
  border:1px solid rgba(11,31,59,0.10);
  border-radius:var(--radius);
  padding:1.4rem;
  box-shadow:0 10px 26px rgba(0,0,0,0.05);
}
.seo-box h3{
  margin:0 0 0.6rem;
  color:var(--color-primary);
  letter-spacing:-0.2px;
  font-size:1.15rem;
}
.seo-box p{
  margin:0;
  color:var(--color-muted);
  line-height:1.75;
  font-size:0.98rem;
}

/* ==============================
   FÜR WEN
============================== */
#fuer-wen{ background:var(--color-light); }

.target-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:1.25rem;
}
.target-card{
  grid-column:span 4;
  background:#fff;
  border:1px solid rgba(11,31,59,0.10);
  border-radius:calc(var(--radius) + 2px);
  padding:1.55rem 1.45rem;
  box-shadow:0 10px 26px rgba(0,0,0,0.06);
}
.target-card h3{
  margin:0 0 0.55rem;
  color:var(--color-primary);
  font-size:1.15rem;
}
.target-card p{
  margin:0;
  color:var(--color-muted);
  line-height:1.75;
  font-size:0.98rem;
}

/* ==============================
   PROCESS
============================== */
#ablauf{ background:#fff; }

.process-steps{
  list-style:none;
  padding:0;
  margin:0 auto;
  max-width:920px;
  display:grid;
  gap:1rem;
}
.process-steps li{
  background:#fff;
  border:1px solid rgba(11,31,59,0.10);
  border-radius:var(--radius);
  padding:1.35rem;
  box-shadow:0 8px 22px rgba(0,0,0,0.05);
  position:relative;
}
.process-steps li::before{
  content:"";
  position:absolute;
  left:0;
  top:12px;
  bottom:12px;
  width:3px;
  border-radius:999px;
  background:linear-gradient(180deg, rgba(198,169,94,0.95), rgba(198,169,94,0.15));
}
.process-steps h3{
  margin:0 0 0.45rem;
  color:var(--color-primary);
  font-size:1.05rem;
}
.process-steps p{
  margin:0;
  color:var(--color-muted);
  font-size:0.98rem;
  line-height:1.7;
}

/* ==============================
   REVIEWS
============================== */
#bewertungen{ background:#fff; }

.reviews-summary{
  max-width:980px;
  margin:0 auto 1.6rem;
  padding:1.25rem;
  border-radius:calc(var(--radius) + 6px);
  border:1px solid rgba(11,31,59,0.10);
  background:linear-gradient(180deg,#ffffff 0%, rgba(245,247,250,0.70) 100%);
  box-shadow:0 10px 26px rgba(0,0,0,0.06);

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
}
.reviews-summary__left{
  display:flex;
  align-items:center;
  gap:0.9rem;
}
.reviews-summary__badge{
  width:42px;
  height:42px;
  border-radius:999px;
  display:grid;
  place-items:center;
  background:rgba(30,58,138,0.08);
  border:1px solid rgba(30,58,138,0.16);
  color:var(--color-primary);
  font-weight:900;
  font-size:1.1rem;
}
.reviews-summary__headline{
  margin:0;
  font-weight:850;
  color:var(--color-primary);
  letter-spacing:-0.2px;
}
.reviews-summary__sub{
  margin:0.15rem 0 0;
  color:var(--color-muted);
  font-size:0.98rem;
}
.reviews-summary__actions{
  display:flex;
  gap:0.75rem;
  flex-wrap:wrap;
}

.reviews-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:1.25rem;
  align-items:stretch;
  margin-top:1.5rem;
}
.review-card{
  grid-column:span 4;
  position:relative;
  margin:0;
  padding:1.55rem 1.45rem;
  border-radius:calc(var(--radius) + 2px);
  background:#fff;
  border:1px solid rgba(11,31,59,0.10);
  box-shadow:0 10px 28px rgba(0,0,0,0.07);
  overflow:hidden;
  transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
.review-card::before{
  content:"";
  position:absolute;
  top:0; left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg, rgba(198,169,94,0.15), rgba(198,169,94,0.95), rgba(198,169,94,0.15));
  opacity:0.85;
}
.review-card::after{
  content:"“";
  position:absolute;
  top:-6px;
  right:12px;
  font-size:4rem;
  color:rgba(198,169,94,0.22);
  font-weight:900;
  pointer-events:none;
}
.review-card:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 40px rgba(0,0,0,0.12);
  border-color:rgba(198,169,94,0.45);
}
.review-card p{
  margin:0;
  color:var(--color-dark);
  font-size:0.98rem;
  line-height:1.85;
}
.review-footer{
  margin-top:1rem;
  padding-top:0.95rem;
  border-top:1px solid rgba(11,31,59,0.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:0.75rem;
  color:var(--color-muted);
  font-size:0.92rem;
}
.review-stars{
  letter-spacing:0.08em;
  font-size:0.95rem;
  background:linear-gradient(180deg,#d8c07a 0%, var(--color-accent) 60%, #b89543 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.review-source{
  display:inline-flex;
  align-items:center;
  gap:0.45rem;
  padding:0.35rem 0.65rem;
  border-radius:999px;
  border:1px solid rgba(30,58,138,0.20);
  background:rgba(30,58,138,0.06);
  color:var(--color-secondary);
  font-weight:650;
}
.reviews-seo{
  max-width:920px;
  margin:1.5rem auto 0;
  text-align:center;
  color:var(--color-muted);
  font-size:0.98rem;
  line-height:1.75;
}

/* ==============================
   EINSATZGEBIETE + INTERNE LINKS
============================== */
#einsatzgebiete{ background:var(--color-light); }

.areas-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:1.25rem;
  align-items:stretch;
  margin-top:1.8rem;
}
.areas-card{
  grid-column:span 4;
  background:#fff;
  border:1px solid rgba(11,31,59,0.10);
  border-radius:calc(var(--radius) + 2px);
  padding:1.55rem 1.45rem;
  box-shadow:0 10px 26px rgba(0,0,0,0.06);
  position:relative;
  overflow:hidden;
}
.areas-card::before{
  content:"";
  position:absolute;
  top:0; left:0;
  width:100%;
  height:3px;
  background:linear-gradient(90deg, rgba(198,169,94,0.15), rgba(198,169,94,0.95), rgba(198,169,94,0.15));
  opacity:0.85;
}
.areas-card h3{
  margin:0 0 0.85rem;
  color:var(--color-primary);
  font-size:1.15rem;
  letter-spacing:-0.2px;
}
.areas-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:0.5rem 0.75rem;
}
.areas-list li{
  padding:0.55rem 0.65rem;
  border-radius:12px;
  background:rgba(30,58,138,0.05);
  border:1px solid rgba(30,58,138,0.12);
  color:var(--color-dark);
  font-size:0.95rem;
}
.areas-note{
  margin:1rem 0 0;
  color:var(--color-muted);
  font-size:0.95rem;
  line-height:1.7;
}

.areas-cta{
  grid-column:span 4;
  background:
    radial-gradient(900px 400px at 15% 15%, rgba(30,58,138,0.30), transparent 55%),
    radial-gradient(800px 380px at 85% 20%, rgba(198,169,94,0.20), transparent 60%),
    linear-gradient(180deg,#07162b 0%, var(--color-primary) 55%, #081936 100%);
  border:1px solid rgba(245,247,250,0.12);
  color:var(--color-light);
  border-radius:calc(var(--radius) + 6px);
  padding:1.7rem 1.5rem;
  box-shadow:0 16px 44px rgba(0,0,0,0.18);
}
.areas-cta h3{
  margin:0 0 0.65rem;
  font-size:1.2rem;
  letter-spacing:-0.2px;
}
.areas-cta p{
  margin:0 0 1.1rem;
  color:rgba(245,247,250,0.86);
  line-height:1.75;
}
.areas-cta__links{
  display:grid;
  gap:0.6rem;
  margin-bottom:1.2rem;
}
.areas-link{
  display:inline-flex;
  align-items:center;
  justify-content:space-between;
  gap:0.75rem;
  padding:0.75rem 0.85rem;
  border-radius:14px;
  text-decoration:none;
  font-weight:760;
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(245,247,250,0.14);
  color:rgba(245,247,250,0.92);
  transition:transform var(--transition), border-color var(--transition), background var(--transition);
  min-height:44px;
}
.areas-link::after{
  content:"→";
  font-weight:900;
  opacity:0.9;
}
.areas-link:hover{
  transform:translateY(-1px);
  background:rgba(198,169,94,0.16);
  border-color:rgba(198,169,94,0.55);
  color:#fff;
}
.areas-cta__actions{
  display:flex;
  gap:0.75rem;
  flex-wrap:wrap;
  margin-bottom:0.9rem;
}
.areas-cta__note{
  margin:0;
  color:rgba(245,247,250,0.82);
  font-size:0.95rem;
}
.areas-cta__note a{
  color:rgba(245,247,250,0.92);
  text-decoration:underline;
  text-underline-offset:3px;
}
.areas-seo{
  max-width:920px;
  margin:1.8rem auto 0;
  text-align:center;
  color:var(--color-muted);
  font-size:0.98rem;
  line-height:1.75;
}

/* ==============================
   FAQ
============================== */
#faq{ background:#fff; }

.faq-items{
  max-width:920px;
  margin:0 auto;
  display:grid;
  gap:0.9rem;
}
.faq-item{
  border:1px solid rgba(11,31,59,0.10);
  border-radius:var(--radius);
  background:var(--color-light);
  box-shadow:0 8px 22px rgba(0,0,0,0.05);
  overflow:hidden;
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:1.1rem 1.2rem;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  color:var(--color-primary);
  font-weight:800;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary:hover,
.faq-item summary:focus-visible{
  background:rgba(198,169,94,0.10);
  outline:none;
}
.faq-q{
  font-size:1.02rem;
  letter-spacing:-0.1px;
}
.faq-icon{
  width:36px;
  height:36px;
  border-radius:999px;
  display:grid;
  place-items:center;
  border:1px solid rgba(11,31,59,0.14);
  background:rgba(255,255,255,0.65);
  font-weight:900;
  flex:0 0 auto;
  transition:transform var(--transition), background var(--transition), border-color var(--transition);
}
.faq-item[open] .faq-icon{
  transform:rotate(45deg);
  background:rgba(198,169,94,0.18);
  border-color:rgba(198,169,94,0.45);
}
.faq-a{ padding:0 1.2rem 1.2rem; }
.faq-a p{
  margin:0;
  color:var(--color-muted);
  line-height:1.75;
  font-size:0.98rem;
}

/* ==============================
   CTA
============================== */
#cta{
  background:
    radial-gradient(900px 400px at 15% 15%, rgba(30,58,138,0.30), transparent 55%),
    radial-gradient(800px 380px at 85% 20%, rgba(198,169,94,0.20), transparent 60%),
    linear-gradient(180deg,#07162b 0%, var(--color-primary) 55%, #081936 100%);
  color:var(--color-light);
}
.cta-box{
  max-width:980px;
  margin:0 auto;
  text-align:center;
  padding:2.8rem 1.25rem;
  border-radius:calc(var(--radius) + 6px);
  border:1px solid rgba(245,247,250,0.14);
  background:rgba(255,255,255,0.06);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  box-shadow:0 14px 40px rgba(0,0,0,0.22);
}
#cta h2{
  margin:0 0 0.8rem;
  font-size:clamp(1.7rem,3vw,2.4rem);
  letter-spacing:-0.4px;
}
#cta p{
  margin:0 auto 1.8rem;
  max-width:820px;
  color:rgba(245,247,250,0.86);
  font-size:1.05rem;
}

/* ==============================
   CONTACT
============================== */
#kontakt{ background:var(--color-light); }

.contact-media{
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(11,31,59,0.10);
  margin-bottom:1rem;
  background:rgba(245,247,250,0.6);
}

.contact-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:1.25rem;
  align-items:start;
}

.contact-form{
  grid-column:span 7;
  background:#fff;
  border-radius:var(--radius);
  border:1px solid rgba(11,31,59,0.10);
  box-shadow:0 10px 28px rgba(0,0,0,0.06);
  padding:1.6rem 1.5rem;
}

.contact-aside{
  grid-column:span 5;
  background:#fff;
  border-radius:var(--radius);
  border:1px solid rgba(11,31,59,0.10);
  box-shadow:0 10px 28px rgba(0,0,0,0.06);
  padding:1.6rem 1.5rem;
}

.contact-line{ margin:0.55rem 0; color:var(--color-dark); }
.contact-note{ margin-top:1rem; color:var(--color-muted); line-height:1.7; }
.contact-address{ font-style:normal; color:var(--color-dark); line-height:1.7; }

.hp-field{
  position:absolute;
  left:-9999px;
  top:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
}

.form-row{ margin-bottom:1rem; }
.form-row label{
  display:block;
  font-weight:650;
  margin-bottom:0.4rem;
  color:var(--color-primary);
}

.form-row-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0.9rem;
}

input,select,textarea{
  width:100%;
  padding:0.85rem 0.9rem;
  border-radius:12px;
  border:1px solid rgba(11,31,59,0.14);
  background:rgba(245,247,250,0.65);
  color:var(--color-dark);
  font:inherit;
  transition:border-color var(--transition), box-shadow var(--transition), background var(--transition);
}
input:focus,select:focus,textarea:focus{
  outline:none;
  border-color:rgba(198,169,94,0.70);
  box-shadow:0 0 0 4px rgba(198,169,94,0.18);
  background:#fff;
}
textarea{ resize:vertical; }

.form-consent{ margin-top:0.25rem; }
.checkbox{
  display:flex;
  gap:0.6rem;
  align-items:flex-start;
  color:var(--color-muted);
}
.checkbox input{
  width:18px;
  height:18px;
  margin-top:0.2rem;
}

.btn-submit{
  width:100%;
  justify-content:center;
}

.form-status{
  margin:0.9rem 0 0;
  font-weight:650;
  color:var(--color-primary);
}
.form-status.is-error{ color:#b42318; }
.form-status.is-success{ color:#067647; }

.form-hint{
  margin:0.8rem 0 0;
  color:var(--color-muted);
  font-size:0.92rem;
}

/* ==============================
   FOOTER
============================== */
.site-footer{
  background:#0a1730;
  color:rgba(245,247,250,0.85);
  padding:2.5rem 0;
}
.footer__inner{
  display:flex;
  gap:1rem;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.site-footer a{
  color:rgba(245,247,250,0.85);
  text-decoration:none;
  padding:0.35rem 0.5rem;
  border-radius:10px;
}
.site-footer a:hover,
.site-footer a:focus-visible{
  background:rgba(198,169,94,0.14);
}
.footer__small{ margin:0.2rem 0; }
.footer__nap{ color:rgba(245,247,250,0.80); }

/* ==============================
   RESPONSIVE
============================== */
@media (max-width:980px){
  .trust-bar__item{ grid-column:span 6; }

  .hero-retail__copy{ grid-column:span 12; }
  .hero-retail__media{ grid-column:span 12; }

  .review-card{ grid-column:span 6; }

  .areas-card{ grid-column:span 12; }
  .areas-cta{ grid-column:span 12; }
}

@media (max-width:900px){
  section{ padding:3.5rem 0; }

  .retail-card{ grid-column:span 12; }
  .target-card{ grid-column:span 12; }

  .contact-form,
  .contact-aside{ grid-column:span 12; }

  .form-row-2{ grid-template-columns:1fr; }

  .hero-highlights li{ text-align:left; }
}

@media (max-width:640px){
  .trust-bar__item{ grid-column:span 12; }
  .review-card{ grid-column:span 12; }
}

@media (max-width:520px){
  .areas-list{ grid-template-columns:1fr; }
}

@media (max-width:480px){
  .cta-box{ padding:2.3rem 1.05rem; }
}

svg {
  position: relative;
  top: .3rem;
}