/* =========================
   Claryon Reinigung GmbH – style.css
   Vereinheitlichte, wiederverwendbare Klassen
   ========================= */

/* ----- Design Tokens ----- */
:root{
  --bg:#ffffff;
  --card:#ffffff;
  --ink:#0f172a;
  --muted:#475569;
  --brand:#0ea5e9;
  --brand-2:#22d3ee;
  --line:#e2e8f0;
  --ring:rgba(14,165,233,.35);
}

/* Prevent unwanted horizontal scrolling */
html, body { overflow-x: hidden; }

/* Constrain wide media */
.container{overflow-x:hidden}
.container, header, main, #main { min-width: 0; }
.grid > * { min-width: 0; }
img, iframe, video{max-width:100%;height:auto;display:block}

/* ----- Base ----- */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
}
a{color:inherit;text-decoration:none}

/* ----- Container & Layout ----- */
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* Grid Utility */
.grid{display:grid;gap:1rem}
.md-2{grid-template-columns:repeat(2,1fr)}
.lg-3{grid-template-columns:repeat(3,1fr)}
.lg-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:1024px){
  .lg-3,.lg-4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .md-2,.lg-3,.lg-4{grid-template-columns:1fr}
}

/* Spacing Helpers */
.section{padding:40px 0;border-bottom:1px solid var(--line)}
.section--tight{padding:24px 0}

/* Typografie */
h1,h2,h3{font-weight:700;color:#111827;margin:0 0 .5rem}
h1{font-size:clamp(30px,5vw,44px);line-height:1.2}
h2{font-size:clamp(22px,3.5vw,30px)}
h3{font-size:1.1rem}
p{margin:.5rem 0;color:#374151}
.muted{color:var(--muted)}
.kicker{color:var(--muted);font-weight:700;letter-spacing:.2px}

/* ----- Cards / Kacheln ----- */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:14px;
  padding:16px;
  transition:transform .2s, box-shadow .2s;
}
.card:hover{transform:translateY(-3px);box-shadow:0 6px 12px rgba(0,0,0,.08)}
.tile{border:1px solid var(--line);border-radius:14px;padding:12px;background:var(--card)}

.kpi .big{font-size:1.8rem;font-weight:800;line-height:1}
.kpi .desc{color:var(--muted);margin-top:6px}

.step-num{
  width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  display:grid;place-items:center;font-weight:800;color:#002;margin-bottom:8px
}

.badge{
  display:inline-block;border:1px solid var(--line);
  border-radius:999px;padding:.25rem .75rem;font-size:.85rem;color:var(--muted);background:var(--bg)
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.75rem 1.5rem;border-radius:.75rem;font-weight:600;cursor:pointer;transition:all .2s;border:none
}
.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff}
.btn-outline{background:#fff;border:1px solid var(--line);color:var(--ink)}
.btn-outline:hover{background:#f8fafc}

form .field{display:grid;gap:.4rem}
input,textarea,select{
  width:100%;padding:12px;border-radius:10px;border:1px solid var(--line);
  background:transparent;color:var(--ink);font:inherit
}
input:focus,textarea:focus,select:focus{outline:2px solid var(--ring);border-color:transparent}

/* ----- Header / Navigation ----- */
header{
  position:sticky;top:0;z-index:10;
  background:var(--bg);border-bottom:1px solid var(--line);
  transition:box-shadow .25s,border-color .25s;
}
header.opened{box-shadow:0 6px 24px rgba(0,0,0,.08);border-bottom-color:var(--brand);}
.container.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:1.2rem}
.links{display:flex;gap:24px;align-items:center}
.links a{color:var(--muted);font-weight:600}
.links a:hover{color:var(--brand)}
.cta{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;padding:10px 16px;border-radius:10px;font-weight:700;border:0}

/* Hamburger */
.menu-toggle{position:absolute;opacity:0;pointer-events:none}
.hambtn{
  display:none;position:relative;width:42px;height:42px;
  border:1px solid var(--line);border-radius:10px;cursor:pointer;
  transition:transform .2s
}
.hambtn:hover{box-shadow:0 2px 8px rgba(0,0,0,.06)}
.hambtn:active{transform:scale(.96)}
.bar{
  position:absolute;left:10px;right:10px;height:2px;background:var(--ink);
  transition:transform .25s,opacity .2s,top .25s
}
.bar:nth-child(1){top:13px}
.bar:nth-child(2){top:21px}
.bar:nth-child(3){top:29px}

/* Burger → X */
header.opened .bar:nth-child(1){top:21px;transform:rotate(45deg)}
header.opened .bar:nth-child(2){opacity:0}
header.opened .bar:nth-child(3){top:21px;transform:rotate(-45deg)}

/* Mobile Panel */
#mobile-nav{
  display:block;
  overflow:hidden;
  max-height:0;
  opacity:0;
  transform:translateY(-6px);
  transition:max-height 280ms ease, opacity 220ms ease, transform 220ms ease;
}
#mobile-nav .mobile-inner{
  display:grid;gap:8px;padding:0 20px;
}
#mobile-nav .mobile-inner a{
  display:block;
  padding:16px 0;
  border-bottom:1px solid var(--line);
  font-weight:700;text-align:center;color:var(--ink);
  opacity:0;transform:translateY(-8px);
  transition:opacity 220ms ease, transform 220ms ease;
}
#mobile-nav .mobile-inner a:last-child{border-bottom:0}

/* Stagger-Animation */
#mobile-nav .mobile-inner a:nth-child(1){transition-delay:30ms}
#mobile-nav .mobile-inner a:nth-child(2){transition-delay:120ms}
#mobile-nav .mobile-inner a:nth-child(3){transition-delay:210ms}
#mobile-nav .mobile-inner a:nth-child(4){transition-delay:300ms}
#mobile-nav .mobile-inner a:nth-child(5){transition-delay:390ms}

/* Offen */
header.opened #mobile-nav{
  max-height:520px;
  opacity:1;
  transform:translateY(0);
  border-top:1px solid var(--line);
}
header.opened #mobile-nav .mobile-inner a{opacity:1;transform:translateY(0)}

#mobile-nav .cta{
  margin:10px 0;
  width:100%;
  display:block;
  border-radius:12px;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));
  color:#fff !important;
}

/* Fokus sichtbar */
a:focus-visible,
.hambtn:focus-visible{outline:3px solid var(--ring);outline-offset:2px;border-radius:10px}

/* Breakpoints */
@media (min-width:900px){
  nav.links{display:flex}
  .hambtn,#mobile-nav{display:none}
}
@media (max-width:899.98px){
  nav.links{display:none}
  .hambtn{display:block}
}

/* ----- Rest ----- */
.page-hero{padding:48px 0 24px;border-bottom:1px solid var(--line)}
.crumbs{font-size:.95rem;color:var(--muted);margin-bottom:8px}
.crumbs a{color:var(--muted)}

.cta-band{
  margin-top:8px;border:1px solid var(--line);border-radius:18px;padding:18px;
  display:flex;gap:12px;align-items:center;justify-content:space-between;
  background:linear-gradient(180deg,rgba(0,0,0,.02),transparent)
}

footer{background:var(--bg);border-top:1px solid var(--line)}
.cf-wrap{max-width:1200px;margin:0 auto;padding:28px 20px}
.cf-grid{display:grid;grid-template-columns:1.2fr .9fr .9fr;gap:22px}
.cf-title{font-weight:800;margin:0 0 8px}
.cf-sub{color:var(--muted);margin:0 0 10px}
.cf-links{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.cf-links a{color:var(--muted);font-weight:600}
.cf-links a:hover{color:var(--brand)}
.cf-chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:12px;padding:8px 10px}
.cf-cta{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;padding:10px 14px;border-radius:12px;font-weight:800}
.cf-bottom{border-top:1px solid var(--line);margin-top:18px;padding-top:12px;display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:.95rem}
@media (max-width:980px){
  .cf-grid{grid-template-columns:1fr}
  .cf-bottom{flex-direction:column;gap:10px;align-items:flex-start}
}
.hero-grid{display:grid;gap:22px;grid-template-columns:1.2fr .8fr}
@media (max-width:1024px){.hero-grid{grid-template-columns:1fr}}
#main{max-width:1200px;margin:0 auto;padding:2rem 1rem}
.faq{display:grid;gap:10px}
.faq details{border:1px solid var(--line);border-radius:12px;padding:12px;background:var(--card)}
.stars{letter-spacing:2px}

/* Hero in zwei Spalten */
.hero-grid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  align-items: start;
  gap: 20px;
}
.hero-logo { text-align: right; }
@media (max-width: 768px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-logo { text-align: center; margin-top: 20px; }
  .hero-logo img { max-width: 280px; width: 100%; height: auto; }
}

/* --- Consent + Submit Block: Text über Checkbox --- */
.form-actions{
  grid-column:1/-1;
  display:grid;
  grid-template-columns: 1fr auto; /* links Consent, rechts Button */
  align-items:flex-start;
  gap:1rem;
  margin-top:1rem;
  width:100%;
}

.form-actions .consent{
  display:flex;
  flex-direction:column; /* Text oben, Checkbox unten */
  gap:.5rem;
  min-width:0;
}

.form-actions .consent-text{
  font-size:.95rem;
  color:var(--muted);
  line-height:1.4;
}

.form-actions .consent-box{
  display:flex;
  align-items:center;
  gap:.5rem;
}

.form-actions .consent-box input{
  flex:0 0 auto;
}

.form-actions .consent-box label{
  font-size:.9rem;
}

.form-actions .submit-wrap{
  flex:0 0 auto;
}

@media (max-width:640px){
  .form-actions{
    grid-template-columns:1fr; /* alles stapelt */
  }
  .form-actions .submit-wrap button{
    width:100%;
  }
}
