 
/* ---------- HERO ---------- */
.contact-hero{
  position:relative;
  background:#061122;
  color:#fff;
  padding:120px 0 100px;
  overflow:hidden;
  isolation:isolate;
}
.contact-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 85% 20%, rgba(239,73,51,.35), transparent 55%),
    radial-gradient(circle at 15% 95%, rgba(239,73,51,.18), transparent 50%),
    linear-gradient(120deg, #061122 0%, #0c1c36 60%, #061122 100%);
  z-index:-1;
}
.contact-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:48px 48px;
  -webkit-mask-image:radial-gradient(circle at 50% 60%, #000 0%, transparent 70%);
          mask-image:radial-gradient(circle at 50% 60%, #000 0%, transparent 70%);
  z-index:-1;
}
.contact-hero__inner{
  position:relative;
  display:flex;
  flex-direction:column-reverse;
  align-items:flex-start;
  gap:1.6rem;
  max-width:920px;
}
.contact-hero h1{
  font-family:var(--font-display);
  font-size:clamp(3rem, 8vw, 6rem);
  font-weight:900;
  margin:0;
  letter-spacing:-.025em;
  line-height:.95;
  color:#fff;
}
.contact-hero h1::after{
  content:"";
  display:block;
  width:110px;
  height:5px;
  background:var(--primary);
  margin-top:1.4rem;
  border-radius:4px;
}
.contact-breadcrumb{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  list-style:none;
  margin:0;
  padding:.55rem 1.1rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  -webkit-backdrop-filter:blur(8px);
          backdrop-filter:blur(8px);
  border-radius:999px;
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
}
.contact-breadcrumb li{ display:inline-flex; align-items:center; gap:.6rem; }
.contact-breadcrumb li + li::before{
  content:"";
  width:5px; height:5px;
  border-radius:50%;
  background:var(--primary);
}
.contact-breadcrumb a{ color:rgba(255,255,255,.78); text-decoration:none; }
.contact-breadcrumb a:hover{ color:#fff; }
.contact-breadcrumb .current{ color:var(--primary); }

.contact-hero__lead{
  margin:0;
  max-width:620px;
  font-size:1.05rem;
  line-height:1.6;
  color:rgba(255,255,255,.78);
}

.contact-hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
}
.contact-cta-btn{
  display:inline-flex;
  align-items:center;
  gap:.9rem;
  padding:.95rem 1.4rem;
  border-radius:14px;
  text-decoration:none;
  font-family:var(--font-display);
  transition:all .3s ease;
  border:1px solid transparent;
}
.contact-cta-btn i{
  font-size:1.4rem;
  width:42px; height:42px;
  display:inline-flex; align-items:center; justify-content:center;
  border-radius:10px;
  background:rgba(255,255,255,.12);
  flex-shrink:0;
}
.contact-cta-btn span{ display:flex; flex-direction:column; line-height:1.15; }
.contact-cta-btn small{ font-size:.7rem; text-transform:uppercase; letter-spacing:.14em; opacity:.75; }
.contact-cta-btn strong{ font-size:1.1rem; font-weight:800; }
.contact-cta-btn.primary{ background:var(--primary); color:#fff; box-shadow:0 16px 30px -16px rgba(239,73,51,.7); }
.contact-cta-btn.primary:hover{ background:var(--primary-hover); transform:translateY(-2px); }
.contact-cta-btn.ghost{ color:#fff; border-color:rgba(255,255,255,.25); background:rgba(255,255,255,.05); }
.contact-cta-btn.ghost:hover{ background:rgba(255,255,255,.12); transform:translateY(-2px); }

/* ---------- QUICK CONTACT TILES ---------- */
.contact-tiles{
  padding:60px 0 20px;
  margin-top:-60px;
  position:relative;
  z-index:5;
}
.contact-tiles__grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:18px;
}
.contact-tile{
  display:block;
  padding:1.6rem 1.4rem;
  background:#fff;
  border-radius:16px;
  text-decoration:none;
  color:var(--c-text);
  border:1px solid rgba(6,17,34,.06);
  box-shadow:0 24px 50px -30px rgba(6,17,34,.18);
  transition:all .35s ease;
  position:relative;
  overflow:hidden;
}
.contact-tile::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:4px;
  background:var(--primary);
  transform:scaleY(0);
  transform-origin:bottom;
  transition:transform .35s ease;
}
.contact-tile:hover{ transform:translateY(-6px); border-color:rgba(239,73,51,.2); box-shadow:0 30px 60px -28px rgba(6,17,34,.28); }
.contact-tile:hover::before{ transform:scaleY(1); transform-origin:top; }

.contact-tile__icon{
  width:48px; height:48px;
  border-radius:12px;
  background:linear-gradient(135deg, rgba(239,73,51,.12), rgba(239,73,51,.04));
  color:var(--primary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:1.3rem;
  margin-bottom:1rem;
}
.contact-tile__icon.wa{ background:linear-gradient(135deg, #25D366, #128C7E); color:#fff; }
.contact-tile h3{
  margin:0 0 .35rem;
  font-size:1.05rem;
  font-weight:800;
  letter-spacing:-.01em;
  color:var(--c-text);
}
.contact-tile p{
  margin:0 0 .4rem;
  font-weight:600;
  color:var(--c-text);
  font-size:.95rem;
}
.contact-tile small{
  font-size:.78rem;
  color:var(--c-text-soft);
}

/* ---------- AREA / EINSATZGEBIET ---------- */
.contact-area{ padding:80px 0 60px; }
.contact-area__head{ max-width:680px; margin:0 0 3rem; }
.contact-area__head .eyebrow-red{
  display:inline-block;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:.7rem;
}
.contact-area__head h2{
  font-family:var(--font-display);
  font-size:clamp(1.9rem, 3.5vw, 2.7rem);
  font-weight:800;
  letter-spacing:-.02em;
  margin:0 0 .8rem;
  color:var(--c-text);
}
.contact-area__head p{ color:var(--c-text-soft); font-size:1.02rem; line-height:1.65; margin:0; }

.contact-area__grid{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:32px;
  align-items:start;
}
.contact-area__map{
  position:relative;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 30px 60px -30px rgba(6,17,34,.3);
  border:1px solid rgba(6,17,34,.08);
}
.contact-area__map::before{
  content:"";
  position:absolute;
  top:18px; right:18px;
  background:#fff;
  color:var(--primary);
  padding:.45rem .8rem;
  border-radius:999px;
  font-size:.72rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  z-index:2;
  box-shadow:0 6px 14px rgba(6,17,34,.12);
}
.contact-area__map::before{ content:"50 km Radius"; }
.contact-area__map img{ width:100%; height:100%; object-fit:cover; display:block; min-height:380px; }

.contact-area__cards{ display:flex; flex-direction:column; gap:18px; }
.contact-area-card{
  position:relative;
  background:#fff;
  border:1px solid rgba(6,17,34,.08);
  border-radius:18px;
  padding:1.8rem 1.7rem 1.6rem;
  box-shadow:0 14px 30px -22px rgba(6,17,34,.22);
}
.contact-area-card.alt{ background:linear-gradient(140deg, #061122 0%, #0c1c36 100%); color:#fff; border-color:transparent; }
.contact-area-card.alt h3{ color:#fff; }
.contact-area-card.alt p{ color:rgba(255,255,255,.78); }
.contact-area-card.alt small{ color:rgba(255,255,255,.55); }
.contact-area-card.alt strong{ color:var(--primary); }

.contact-area-card__num{
  position:absolute;
  top:-14px; left:24px;
  background:var(--primary);
  color:#fff;
  font-family:var(--font-display);
  font-weight:800;
  font-size:.82rem;
  letter-spacing:.06em;
  padding:.3rem .7rem;
  border-radius:8px;
}
.contact-area-card h3{
  font-family:var(--font-display);
  font-size:1.25rem;
  font-weight:800;
  margin:0 0 .8rem;
  color:var(--c-text);
}
.contact-area-card__sub{
  display:block;
  font-size:.85rem;
  color:var(--c-text-soft);
  margin-bottom:1rem;
}
.contact-area-card__cities{
  list-style:none;
  margin:0 0 1rem;
  padding:0;
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:.4rem .8rem;
}
.contact-area-card__cities li{
  position:relative;
  padding-left:1rem;
  font-size:.9rem;
  color:var(--c-text);
}
.contact-area-card__cities li::before{
  content:"";
  position:absolute;
  left:0; top:.55em;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--primary);
}
.contact-area-card p{
  font-size:.92rem;
  line-height:1.6;
  color:var(--c-text-soft);
  margin:0 0 .8rem;
}
.contact-area-card small{ font-size:.78rem; color:var(--c-text-soft); }

/* ---------- CONTACT DETAILS ---------- */
.contact-details{ padding:80px 0; background:var(--c-light, #f6f7f8); }
.contact-details__grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:48px;
  align-items:center;
}
.contact-details__text .eyebrow-red{
  display:inline-block;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:.8rem;
}
.contact-details__text h2{
  font-family:var(--font-display);
  font-size:clamp(1.8rem, 3vw, 2.5rem);
  font-weight:800;
  letter-spacing:-.02em;
  line-height:1.15;
  color:var(--c-text);
  margin:0 0 1rem;
}
.contact-details__intro{
  color:var(--c-text-soft);
  font-size:1rem;
  line-height:1.65;
  margin:0 0 1.8rem;
}

.contact-details__list{
  list-style:none;
  margin:0 0 1.8rem;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:.9rem;
}
.contact-details__list li{
  display:flex;
  align-items:center;
  gap:1rem;
  padding:1rem 1.2rem;
  background:#fff;
  border-radius:14px;
  border:1px solid rgba(6,17,34,.06);
  box-shadow:0 8px 20px -16px rgba(6,17,34,.18);
  transition:all .25s ease;
}
.contact-details__list li:hover{
  transform:translateX(4px);
  border-color:rgba(239,73,51,.25);
  box-shadow:0 14px 26px -18px rgba(6,17,34,.25);
}
.contact-details__ico{
  width:44px; height:44px;
  flex-shrink:0;
  border-radius:12px;
  background:rgba(239,73,51,.12);
  color:var(--primary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:1.1rem;
}
.contact-details__ico.wa{ background:#25D366; color:#fff; }
.contact-details__list small{
  display:block;
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--c-text-soft);
  margin-bottom:.15rem;
}
.contact-details__list a{
  color:var(--c-text);
  font-weight:700;
  font-size:1rem;
  text-decoration:none;
}
.contact-details__list a:hover{ color:var(--primary); }

.contact-details__note{
  display:flex;
  align-items:flex-start;
  gap:.6rem;
  background:rgba(239,73,51,.08);
  border-left:3px solid var(--primary);
  padding:.9rem 1.1rem;
  border-radius:0 12px 12px 0;
  font-size:.88rem;
  color:var(--c-text);
  margin:0;
}
.contact-details__note i{ color:var(--primary); margin-top:.15rem; }

.contact-details__media{
  position:relative;
  isolation:isolate;
}
.contact-details__frame{
  position:absolute;
  top:24px; left:24px;
  right:-24px; bottom:-24px;
  border:3px solid var(--primary);
  border-radius:20px;
  z-index:-1;
}
.contact-details__media img{
  width:100%;
  height:100%;
  max-height:520px;
  object-fit:cover;
  border-radius:20px;
  box-shadow:0 30px 60px -30px rgba(6,17,34,.35);
  display:block;
}

/* ---------- WHY ---------- */
.contact-why{ padding:90px 0; }
.contact-why__head{ text-align:center; max-width:700px; margin:0 auto 3rem; }
.contact-why__head .eyebrow-red{
  display:inline-block;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:.7rem;
}
.contact-why__head h2{
  font-family:var(--font-display);
  font-size:clamp(1.9rem, 3.5vw, 2.7rem);
  font-weight:800;
  letter-spacing:-.02em;
  margin:0 0 .8rem;
  color:var(--c-text);
}
.contact-why__head p{ color:var(--c-text-soft); font-size:1.02rem; line-height:1.65; margin:0; }

.contact-why__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:22px;
}
.contact-why-card{
  position:relative;
  padding:2rem 1.6rem 1.7rem;
  background:#fff;
  border:1px solid rgba(6,17,34,.06);
  border-radius:18px;
  transition:all .35s ease;
  box-shadow:0 14px 30px -24px rgba(6,17,34,.18);
  overflow:hidden;
}
.contact-why-card::after{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:3px;
  background:linear-gradient(90deg, var(--primary), transparent);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s ease;
}
.contact-why-card:hover{ transform:translateY(-6px); border-color:rgba(239,73,51,.25); box-shadow:0 26px 48px -28px rgba(6,17,34,.3); }
.contact-why-card:hover::after{ transform:scaleX(1); }

.contact-why-card__icon{
  width:54px; height:54px;
  border-radius:14px;
  background:linear-gradient(135deg, rgba(239,73,51,.18), rgba(239,73,51,.04));
  color:var(--primary);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:1.5rem;
  margin-bottom:1.2rem;
}
.contact-why-card h3{
  font-family:var(--font-display);
  font-size:1.15rem;
  font-weight:800;
  margin:0 0 .6rem;
  color:var(--c-text);
  letter-spacing:-.01em;
}
.contact-why-card p{
  font-size:.93rem;
  line-height:1.6;
  color:var(--c-text-soft);
  margin:0;
}

/* ---------- PRICING ---------- */
.contact-pricing{ padding:90px 0; background:var(--c-light, #f6f7f8); }
.contact-pricing__head{ max-width:680px; margin:0 0 3rem; }
.contact-pricing__head .eyebrow-red{
  display:inline-block;
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:.7rem;
}
.contact-pricing__head h2{
  font-family:var(--font-display);
  font-size:clamp(1.9rem, 3.5vw, 2.7rem);
  font-weight:800;
  letter-spacing:-.02em;
  margin:0 0 .8rem;
  color:var(--c-text);
}
.contact-pricing__head p{ color:var(--c-text-soft); font-size:1.02rem; margin:0; }

.contact-pricing__list{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.contact-pricing-row{
  display:grid;
  grid-template-columns:auto 1fr auto auto;
  align-items:center;
  gap:1.5rem;
  padding:1.4rem 1.7rem;
  background:#fff;
  border-radius:16px;
  border:1px solid rgba(6,17,34,.06);
  transition:all .3s ease;
  position:relative;
  overflow:hidden;
}
.contact-pricing-row::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width:4px;
  background:var(--primary);
  transform:scaleY(.3);
  transition:transform .35s ease;
}
.contact-pricing-row:hover{
  transform:translateX(6px);
  border-color:rgba(239,73,51,.22);
  box-shadow:0 18px 36px -22px rgba(6,17,34,.22);
}
.contact-pricing-row:hover::before{ transform:scaleY(1); }

.contact-pricing-row__num{
  font-family:var(--font-display);
  font-size:1.6rem;
  font-weight:800;
  color:var(--primary);
  letter-spacing:-.02em;
  min-width:42px;
}
.contact-pricing-row h3{
  margin:0;
  font-family:var(--font-display);
  font-size:1.1rem;
  font-weight:700;
  color:var(--c-text);
  letter-spacing:-.01em;
}
.contact-pricing-row__sub{
  font-size:.88rem;
  color:var(--c-text-soft);
  white-space:nowrap;
}
.contact-pricing-row__price{
  font-family:var(--font-display);
  font-size:1.25rem;
  font-weight:800;
  color:var(--c-text);
  letter-spacing:-.01em;
  background:rgba(239,73,51,.1);
  color:var(--primary);
  padding:.5rem 1rem;
  border-radius:10px;
  white-space:nowrap;
}

.contact-pricing__note{
  margin-top:2rem;
  background:#fff;
  border:1px dashed rgba(6,17,34,.18);
  border-radius:16px;
  padding:1.6rem 1.8rem;
}
.contact-pricing__note h4{
  margin:0 0 .9rem;
  font-family:var(--font-display);
  font-weight:800;
  font-size:1.05rem;
  color:var(--c-text);
  display:flex;
  align-items:center;
  gap:.5rem;
}
.contact-pricing__note h4 i{ color:var(--primary); }
.contact-pricing__note ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
.contact-pricing__note li{
  position:relative;
  padding-left:1.1rem;
  font-size:.9rem;
  line-height:1.55;
  color:var(--c-text-soft);
}
.contact-pricing__note li::before{
  content:"";
  position:absolute;
  left:0; top:.55em;
  width:6px; height:6px;
  border-radius:50%;
  background:var(--primary);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 992px){
  .contact-tiles__grid{ grid-template-columns:repeat(2, 1fr); }
  .contact-area__grid{ grid-template-columns:1fr; }
  .contact-details__grid{ grid-template-columns:1fr; gap:32px; }
  .contact-details__media{ order:-1; }
  .contact-why__grid{ grid-template-columns:repeat(2, 1fr); }
}

@media (max-width: 640px){
  .contact-hero{ padding:90px 0 80px; }
  .contact-hero h1{ font-size:clamp(2.4rem, 12vw, 3.2rem); }
  .contact-tiles{ margin-top:-40px; }
  .contact-tiles__grid{ grid-template-columns:1fr; }
  .contact-area-card__cities{ grid-template-columns:1fr; }
  .contact-why__grid{ grid-template-columns:1fr; }
  .contact-pricing-row{
    grid-template-columns:auto 1fr;
    grid-template-areas:
      "num title"
      "num sub"
      "price price";
    gap:.4rem 1rem;
  }
  .contact-pricing-row__num{ grid-area:num; }
  .contact-pricing-row h3{ grid-area:title; }
  .contact-pricing-row__sub{ grid-area:sub; white-space:normal; }
  .contact-pricing-row__price{ grid-area:price; justify-self:start; margin-top:.5rem; }
  .contact-cta-btn{ flex:1; }
}

/* ============================================================
   CONTACT SECTION (map + form)
   Shared section markup `.home-contact` is reused on:
   /, /uebersicht/, /about/, /contact/
   All four pages link this stylesheet so these rules apply
   regardless of where the contact form is embedded.
   ============================================================ */
.home-contact{
  background:var(--c-bg-alt);
  padding:0;
}
.home-contact__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:560px;
}
.home-contact__map{
  min-height:400px;
  position:relative;
}
.home-contact__map iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.home-contact__form-side{
  padding:4rem 4rem 4rem 3rem;
  background:var(--c-bg-alt);
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.home-contact__form-side .eyebrow-red{
  display:inline-block;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.85rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:.55rem;
}
.home-contact__form-side h3{
  font-family:var(--font-display);
  font-size:clamp(1.4rem, 2.4vw, 1.85rem);
  font-weight:800;
  margin:0 0 1rem;
  color:var(--c-text);
}
.home-contact__form-side > p{
  font-size:.95rem;
  color:var(--c-text-soft);
  line-height:1.6;
  margin:0 0 1.8rem;
}

/* ---------- The actual contact form ---------- */
.contact-form{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:.9rem;
}
.contact-form .full{ grid-column:1/-1; }
.contact-form input,
.contact-form select,
.contact-form textarea{
  width:100%;
  background:#fff;
  border:1px solid #e4e6e9;
  border-radius:8px;
  padding:.95rem 1rem;
  font-size:.95rem;
  font-family:inherit;
  color:var(--c-text);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.contact-form textarea{
  min-height:110px;
  resize:vertical;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(239,73,51,.15);
}
.contact-form .privacy{
  display:flex;
  gap:.7rem;
  align-items:flex-start;
  font-size:.83rem;
  color:var(--c-text-soft);
  line-height:1.45;
  padding:.5rem 0;
}
.contact-form .privacy input{
  width:auto;
  margin-top:.25rem;
  accent-color:var(--primary);
}
.contact-form .privacy a{ color:var(--primary); text-decoration:underline; }
.contact-form button{
  background:var(--primary);
  color:#fff;
  border:0;
  font-family:var(--font-display);
  font-weight:700;
  font-size:.95rem;
  padding:1rem 2rem;
  border-radius:50px;
  cursor:pointer;
  justify-self:start;
  box-shadow:0 10px 22px rgba(239,73,51,.3);
  transition:background .2s ease, transform .2s ease;
}
.contact-form button:hover{ background:var(--primary-hover); transform:translateY(-2px); }

.home-contact__email{
  margin-top:1.4rem;
  font-size:.88rem;
  color:var(--c-text-soft);
}
.home-contact__email a{ color:var(--primary); text-decoration:none; font-weight:600; }

@media (max-width:980px){
  .home-contact__grid{ grid-template-columns:1fr; }
  .home-contact__form-side{ padding:3rem 1.2rem; }
}
@media (max-width:520px){
  .contact-form{ grid-template-columns:1fr; }
}
