/* ============================================================
   Augsburg DJs — Agentur-Komponenten
   Ergänzt die bestehenden Styles, überschreibt nichts.
   ============================================================ */

/* Hero CTA Row */
.hero__ctas{
  display:flex;flex-wrap:wrap;gap:14px;margin-top:1.4rem;
}

/* Dezente Button-Variante für dunkle Hintergründe */
.btn--outline-white{
  background:transparent;color:var(--white);
  border:1.5px solid rgba(255,255,255,.7);
}
.btn--outline-white:hover{
  background:rgba(255,255,255,.08);
  border-color:var(--white);
  transform:translateY(-2px);
}

/* Stats-Strip */
.stats-strip{padding:36px 0;border-bottom:1px solid var(--gray-mid)}
.stats-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center;
}
.stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}
.stat strong{
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:900;color:var(--gold-dark);line-height:1;
}
.stat span{
  font-size:.82rem;color:var(--gray-muted);
  letter-spacing:.02em;line-height:1.4;
}

/* Service-Karten */
.service-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:40px;
}
.service-card{
  display:block;background:var(--charcoal);
  border:1px solid var(--gray-mid);border-radius:var(--r-lg);
  overflow:hidden;transition:transform var(--t),box-shadow var(--t),border-color var(--t);
  text-decoration:none;color:inherit;
  position:relative;
}
.service-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-border);
}
.service-card__img{aspect-ratio:16/10;overflow:hidden;background:var(--gray-mid);position:relative}
.service-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.service-card:hover .service-card__img img{transform:scale(1.04)}

/* Body als Overlay UNTEN über dem Bild
   Schwarz halbtransparent, nimmt nur die Höhe des Inhalts ein */
.service-card__body{
  position:absolute !important;
  left:0; right:0; bottom:0;
  z-index:2;
  background:rgba(0,0,0,0.30);
  padding:18px 22px 20px !important;
  inset:auto 0 0 0 !important;
}
.service-card__body h3{
  color:var(--white) !important;
  margin-bottom:.45rem;
  font-size:1.35rem;
  font-weight:700;
  text-shadow:0 1px 2px rgba(0,0,0,0.4);
}
.service-card__body p{
  color:var(--white) !important;
  font-size:.92rem;line-height:1.55;
  margin-bottom:.7rem;
  font-weight:400;
  text-shadow:0 1px 2px rgba(0,0,0,0.4);
}
.service-card__more{
  font-size:.78rem;font-weight:700;
  color:var(--gold) !important;
  letter-spacing:.04em;text-transform:uppercase;
  text-shadow:0 1px 2px rgba(0,0,0,0.4);
}
/* Falls altes Overlay-Element noch im DOM ist, ausblenden */
.service-card__overlay{display:none !important}

/* Why-Grid (auf dunklem Hintergrund) */
.why-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:48px;
}
.why-card{
  padding:28px 24px;
  background:rgba(255,255,255,.035);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-lg);
  transition:background var(--t),border-color var(--t);
}
.why-card:hover{
  background:rgba(184,150,90,.06);
  border-color:rgba(184,150,90,.25);
}
.why-card__icon{
  width:42px;height:42px;display:flex;align-items:center;justify-content:center;
  color:var(--gold-light);margin-bottom:1rem;
}
.why-card__icon svg{width:100%;height:100%}
.why-card h3{color:var(--white);font-size:1.2rem;margin-bottom:.6rem;font-weight:700}
.why-card p{color:rgba(255,255,255,.88);font-size:.95rem;line-height:1.65;margin:0}

/* About-Grid */
.about-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:54px;align-items:center;
}
.about-grid__text h2{margin-bottom:1rem}
.about-grid__text p{color:var(--gray-muted);margin-bottom:1rem;line-height:1.75}
.about-grid__text strong{color:var(--charcoal);font-weight:700}
.about-grid__text .btn{margin-top:.6rem}
.about-grid__img{
  border-radius:var(--r-lg);overflow:hidden;
  box-shadow:var(--shadow-md);
  aspect-ratio:4/3;
}
.about-grid__img img{width:100%;height:100%;object-fit:cover}
.about-grid__img--team{aspect-ratio:auto;background:#f5f3ee;padding:18px 18px 0;display:flex;flex-direction:column;justify-content:flex-end;}
.about-grid__img--team img{width:100%;height:auto;object-fit:contain;display:block;}
.about-grid__caption{padding:18px 4px 22px;text-align:left;}
.about-grid__caption strong{display:block;color:var(--charcoal);font-size:1.35rem;font-weight:800;line-height:1.15;}
.about-grid__caption span{display:block;margin-top:.25rem;color:var(--gray-muted);font-size:.95rem;}

.about-grid--team{grid-template-columns:.58fr 1.42fr;align-items:center;}
.about-grid__profiles{display:grid;grid-template-columns:1fr;gap:18px;align-items:start;justify-self:start;max-width:290px;width:100%;}
.about-profile-card{margin:0;background:#f5f3ee;border:1px solid var(--gold-border);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);}
.about-profile-card img{display:block;width:100%;height:300px;object-fit:cover;object-position:center 16%;background:#111;padding:0;box-sizing:border-box;}
.about-profile-card:nth-child(1) img{object-position:56% 16%;}
.about-profile-card:nth-child(2) img{object-position:50% 14%;}
.about-profile-card figcaption{padding:14px 16px 16px;background:#fff;}
.about-profile-card figcaption strong{display:block;color:var(--charcoal);font-size:1.16rem;font-weight:800;line-height:1.15;}
.about-profile-card figcaption span{display:block;margin-top:.25rem;color:var(--gray-muted);font-size:.88rem;line-height:1.35;}
.about-profile-card--mobile{display:none;}
@media(max-width:991px){.about-grid--team{grid-template-columns:1fr;}.about-grid__profiles{max-width:none;grid-template-columns:repeat(2,minmax(0,1fr));}.about-profile-card img{height:280px;}.about-grid--team .about-grid__profiles{order:-1;}}
@media(max-width:575px){.about-profile-card--desktop{display:none;}.about-profile-card--mobile{display:block;}.about-grid__profiles{grid-template-columns:1fr;max-width:none;}.about-profile-card--mobile img{height:auto;max-height:220px;aspect-ratio:16/10;object-fit:cover;object-position:center center;padding:0;background:#111;box-sizing:border-box;}}

/* About-Grid Reverse */
.about-grid--reverse .about-grid__img{order:0}
.about-grid--reverse .about-grid__text{order:1}
@media(max-width:991px){
  .about-grid--reverse .about-grid__img{order:-1}
}

/* 3-Schritte */
.steps-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:44px;
}
.step{
  background:var(--white);padding:32px 28px;border-radius:var(--r-lg);
  border:1px solid var(--gold-border);position:relative;
}
.step__num{
  display:inline-block;font-size:2.2rem;font-weight:900;
  color:var(--gold);line-height:1;margin-bottom:.7rem;
  letter-spacing:-.04em;
}
.step h3{color:var(--charcoal);font-size:1.25rem;margin-bottom:.5rem;font-weight:700}
.step p{color:var(--gray-text);font-size:.95rem;line-height:1.7;margin:0}

/* Regions-Grid */
.regions-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:36px;
}
.region-tile{
  display:flex;flex-direction:column;padding:20px 22px;
  background:var(--white);border:1px solid var(--gray-mid);
  border-radius:var(--r);text-decoration:none;
  transition:border-color var(--t),background var(--t),transform var(--t);
}
.region-tile:hover{
  border-color:var(--gold);
  background:var(--gold-pale);
  transform:translateY(-2px);
}
.region-tile strong{color:var(--charcoal);font-size:1.15rem;font-weight:700;margin-bottom:.2rem}
.region-tile span{color:var(--gray-text);font-size:.88rem;font-weight:500}
.region-tile--all{background:var(--gold-pale);border-color:var(--gold-border)}
.region-tile--all strong{color:var(--gold-dark)}

/* FAQ-Liste */
.faq-list{margin-top:32px;max-width:820px}
.faq-item{
  background:var(--white);border:1px solid var(--gray-mid);
  border-radius:var(--r);margin-bottom:10px;overflow:hidden;
  transition:border-color var(--t),box-shadow var(--t);
}
.faq-item[open]{border-color:var(--gold-border);box-shadow:var(--shadow-sm)}
.faq-item summary{
  padding:18px 22px;font-weight:700;color:var(--charcoal);
  cursor:pointer;list-style:none;position:relative;padding-right:50px;
  font-size:.98rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";position:absolute;right:22px;top:50%;
  transform:translateY(-50%);font-size:1.4rem;color:var(--gold);
  font-weight:300;transition:transform var(--t);
}
.faq-item[open] summary::after{content:"−"}
.faq-item p{
  padding:0 22px 20px;color:var(--gray-muted);
  font-size:.92rem;line-height:1.7;margin:0;
}
.faq-item a{color:var(--gold-dark);text-decoration:underline}
.faq-cta{text-align:center;margin-top:32px}

/* CTA-Band */
.cta-strip{
  padding:60px 0;text-align:center;
  background:linear-gradient(135deg,var(--gold-dark) 0%,var(--gold) 55%,var(--gold-light) 100%);
  color:var(--white);
}
.cta-strip h2{color:var(--white);margin-bottom:.6rem}
.cta-strip p{color:rgba(255,255,255,.92);max-width:620px;margin:0 auto 1.4rem;font-size:1rem}
.cta-strip .btn--dark{background:var(--charcoal-2);color:var(--white);border-color:var(--charcoal-2)}
.cta-strip .btn--dark:hover{background:var(--charcoal-3);color:var(--gold-light)}

/* Wertelisten */
.value-list{list-style:none;padding:0;margin:0 0 1rem 0}
.value-list li{
  position:relative;padding-left:1.8rem;margin-bottom:.6rem;
  color:var(--gray-muted);line-height:1.65;
}
.value-list li::before{
  content:"";position:absolute;left:0;top:.55em;
  width:14px;height:14px;border-radius:50%;
  background:var(--gold-pale);
  border:1.5px solid var(--gold);
}
.value-list li::after{
  content:"";position:absolute;left:4px;top:.85em;
  width:6px;height:3px;border-left:2px solid var(--gold-dark);
  border-bottom:2px solid var(--gold-dark);
  transform:rotate(-45deg);
}

/* DJ-Team-Grid */
.dj-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:26px;
}
.dj-card{
  display:flex;flex-direction:column;background:var(--white);
  border:1px solid var(--gray-mid);border-radius:var(--r-lg);
  overflow:hidden;transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.dj-card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:var(--gold-border);
}
.dj-card__img{
  aspect-ratio:1/1;overflow:hidden;background:var(--gray-mid);
  position:relative;
}
.dj-card__img img{width:100%;height:100%;object-fit:cover;display:block}
.dj-card__img--placeholder{
  background:linear-gradient(135deg,var(--gold-dark) 0%,var(--gold) 60%,var(--gold-light) 100%);
  display:flex;align-items:center;justify-content:center;
}
.dj-card__img--placeholder::after{
  content:attr(data-initials);
  color:var(--white);
  font-size:clamp(2.2rem,5vw,3.4rem);
  font-weight:900;
  letter-spacing:-.02em;
  text-shadow:0 4px 12px rgba(46,42,36,.2);
}
.dj-card__body{padding:22px 22px 24px}
.dj-card__body h3{color:var(--charcoal);font-size:1.15rem;margin-bottom:.25rem}
.dj-card__role{
  display:block;
  font-size:.78rem;font-weight:700;
  color:var(--gold-dark);
  letter-spacing:.04em;text-transform:uppercase;
  margin-bottom:.7rem;
}
.dj-card__body p{
  color:var(--gray-muted);
  font-size:.9rem;line-height:1.65;margin:0;
}

/* Reviews-Section */
.reviews-section{padding:56px 0 48px}
.reviews-section .section-header{margin-bottom:28px}
.reviews-widget-stack{display:grid;gap:18px;max-width:1120px;margin:0 auto}
.reviews-widget{width:100%;margin:0 auto;overflow:hidden}
.reviews-widget [class*="elfsight-app-"],
.reviews-section [class*="elfsight-app-"]{min-height:0 !important;height:auto}
.reviews-widget + .reviews-widget{margin-top:4px}
@media(max-width:767px){
  .reviews-section{padding:44px 0 38px}
  .reviews-section .section-header{margin-bottom:22px}
  .reviews-widget-stack{gap:14px}
}

/* Preis-Hinweisbox */
.price-hint{
  background:var(--gold-pale);
  border:1px solid var(--gold-border);
  border-radius:var(--r-lg);
  padding:24px 28px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;
  gap:20px;margin:32px 0;
}
.price-hint__lead{flex:1;min-width:240px}
.price-hint__lead strong{
  display:block;font-size:1.6rem;font-weight:900;color:var(--gold-dark);line-height:1;
  margin-bottom:.3rem;
}
.price-hint__lead span{color:var(--gray-muted);font-size:.9rem}
.price-hint .btn{flex-shrink:0}

/* Utility */
.u-text-center{text-align:center}
.u-mt-24{margin-top:24px}
.u-mt-32{margin-top:32px}

/* Responsive */
@media(max-width:991px){
  .service-grid,.why-grid,.steps-grid{grid-template-columns:repeat(2,1fr)}
  .regions-grid{grid-template-columns:repeat(3,1fr)}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .about-grid__img{order:-1}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .dj-grid{grid-template-columns:repeat(2,1fr);gap:20px}
}

@media(max-width:640px){
  .service-grid,.why-grid,.steps-grid{grid-template-columns:1fr;gap:18px}
  .regions-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .region-tile{padding:16px 18px}
  .hero__ctas{flex-direction:column;align-items:stretch}
  .hero__ctas .btn{justify-content:center}
  .stats-strip{padding:28px 0}
  .cta-strip{padding:44px 0}
  .dj-grid{grid-template-columns:1fr;gap:16px}
  .price-hint{flex-direction:column;align-items:stretch;text-align:center}
}


/* Mobile Korrektur: seitlicher Abstand und kein horizontales Verschieben */
@media(max-width:640px){
  html,body{max-width:100%;overflow-x:hidden;}
  .page-body{overflow-x:hidden;}
  .hero{max-width:100%;overflow:hidden;}
  .hero .container,
  .hero__content{
    box-sizing:border-box;
    width:100%;
    max-width:100%;
    padding-left:22px;
    padding-right:22px;
  }
  .hero__content h1,
  .hero__content p{
    max-width:100%;
  }
}

/* Geburtstags-Anlasskarten */
.service-grid--birthday-occasions{
  grid-template-columns:repeat(3,minmax(0,1fr));
}
@media(max-width:991px){
  .service-grid--birthday-occasions{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(max-width:640px){
  .service-grid--birthday-occasions{grid-template-columns:1fr;}
}

/* Crosslinks am Seitenende */
.service-crosslinks{padding-top:70px;padding-bottom:74px;}
.service-crosslinks__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
  margin-top:30px;
}
.service-crosslinks__card{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:22px 24px;
  background:#fff;
  border:1px solid var(--gold-border);
  border-radius:var(--r-lg);
  color:inherit;
  text-decoration:none;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.service-crosslinks__card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:rgba(184,150,90,.55);
}
.service-crosslinks__card strong{font-size:1.08rem;color:var(--charcoal);}
.service-crosslinks__card span{font-size:.94rem;line-height:1.55;color:var(--gray-muted);}
@media(max-width:991px){
  .service-crosslinks__grid{grid-template-columns:1fr;}
}
