/* Werkstatt-CMS – Frontend
   Industrieller Look: Stahl-Charcoal + Signal-Orange. Keine externen Schriften (DSGVO). */
:root{
  --ink:#15171c; --steel:#1e2229; --steel-2:#262b33;
  --line:#343a44; --paper:#f5f4f1; --muted:#8b929e;
  --accent:#ff6a13; --accent-2:#ffb347; --ok:#2faa5a; --err:#e0413c;
  --sans:"Segoe UI",system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  --display:"Arial Black","Segoe UI",system-ui,sans-serif;
  --radius:4px; --shadow:0 10px 30px rgba(0,0,0,.18);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:78px}
body{font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.6}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
.container{max-width:1140px;margin:0 auto;padding:0 22px}
.narrow{max-width:760px}.center{text-align:center}

/* Header */
.site-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:24px;
  padding:14px 22px;background:rgba(21,23,28,.96);backdrop-filter:blur(6px);border-bottom:2px solid var(--accent)}
.brand{display:flex;align-items:center;gap:12px;color:#fff;font-family:var(--display);
  font-weight:900;letter-spacing:.5px;text-transform:uppercase;font-size:1.05rem}
.brand img{height:38px;width:auto}
.main-nav{display:flex;gap:22px;margin-left:auto}
.main-nav a{color:#cfd3da;font-weight:600;font-size:.92rem;text-transform:uppercase;letter-spacing:.4px}
.main-nav a:hover{color:#fff}
.nav-cta{color:var(--accent)!important}
.header-phone{color:#fff;font-weight:700;white-space:nowrap}
@media(max-width:820px){.main-nav,.header-phone{display:none}}

/* Hero */
.hero{position:relative;color:#fff;background:
  linear-gradient(135deg,rgba(21,23,28,.94),rgba(30,34,41,.86)),
  repeating-linear-gradient(45deg,#1a1d23 0 22px,#1e2229 22px 44px);
  padding:120px 22px 110px;overflow:hidden}
.hero::after{content:"";position:absolute;right:-80px;bottom:-80px;width:340px;height:340px;
  background:var(--accent);transform:rotate(45deg);opacity:.12}
.hero-inner{max-width:760px;position:relative;z-index:1}
.eyebrow{color:var(--accent-2);text-transform:uppercase;letter-spacing:3px;font-weight:700;font-size:.85rem;margin-bottom:14px}
.hero h1{font-family:var(--display);font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.05;
  text-transform:uppercase;letter-spacing:.5px;margin-bottom:18px}
.lead{font-size:1.15rem;color:#d6dae1;max-width:620px;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-block;padding:13px 26px;font-weight:700;text-transform:uppercase;
  letter-spacing:.6px;font-size:.9rem;border-radius:var(--radius);cursor:pointer;border:2px solid transparent;transition:.15s}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:#e85d09;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;border-color:#4a525e}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-2)}

/* Sections */
.section{padding:74px 0}
.section-alt{background:#ecebe7}
.section-dark{background:var(--steel);color:#e7eaee}
.section-dark a{color:var(--accent-2)}
.section-title{font-family:var(--display);text-transform:uppercase;letter-spacing:1px;
  font-size:clamp(1.6rem,3.5vw,2.3rem);margin-bottom:30px;position:relative;display:inline-block}
.section-title::after{content:"";display:block;width:60px;height:4px;background:var(--accent);margin-top:10px}
.prose{font-size:1.05rem;max-width:620px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:36px}}

/* Cards / Leistungen */
.grid{display:grid;gap:18px}
.cards{grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}
.card{background:#fff;border:1px solid #e2e0da;border-radius:var(--radius);padding:26px 22px;
  border-top:4px solid var(--accent);transition:.15s}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.card-icon{font-size:2rem;margin-bottom:10px}
.card h3{font-size:1.15rem;margin-bottom:8px}
.card p{color:#555;font-size:.95rem}

/* Team */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:18px;margin-top:14px}
.team-member{text-align:center}
.team-member img,.avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;margin:0 auto 8px;border:3px solid var(--accent)}
.avatar{display:flex;align-items:center;justify-content:center;background:var(--steel);color:#fff;font-size:2rem;font-weight:800}
.team-member strong{display:block}.team-member span{color:var(--muted);font-size:.85rem}
.team-member small{color:#999;font-size:.78rem}

/* Brands */
.brands{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:22px}
.brand-chip{background:#fff;border:1px solid #d8d6cf;padding:10px 20px;border-radius:40px;font-weight:700;letter-spacing:.5px}

/* Galerie */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.gallery-grid figure{position:relative;overflow:hidden;border-radius:var(--radius)}
.gallery-grid img{height:200px;width:100%;object-fit:cover;transition:.3s}
.gallery-grid figure:hover img{transform:scale(1.06)}
.gallery-grid figcaption{position:absolute;left:0;right:0;bottom:0;background:linear-gradient(transparent,rgba(0,0,0,.7));
  color:#fff;padding:14px 12px 8px;font-size:.85rem}

/* FAQ */
.faq-item{border:1px solid #ddd;border-radius:var(--radius);margin-bottom:10px;background:#fff}
.faq-item summary{cursor:pointer;padding:16px 18px;font-weight:700;list-style:none}
.faq-item summary::after{content:"+";float:right;color:var(--accent);font-weight:900}
.faq-item[open] summary::after{content:"–"}
.faq-item p{padding:0 18px 16px;color:#555}

/* Kontakt */
.contact-list{list-style:none;display:grid;gap:16px}
.contact-list li strong{color:var(--accent-2);text-transform:uppercase;font-size:.8rem;letter-spacing:1px}
.oh{display:inline-block;margin-right:14px;font-size:.9rem}.oh b{color:var(--accent-2);margin-right:4px}
.oh.vac{display:block;color:var(--accent-2);margin-top:6px}
.map-consent{margin-top:22px;padding:20px;border:1px dashed #4a525e;border-radius:var(--radius);text-align:center}
.map-consent iframe{width:100%;height:280px;border:0;border-radius:var(--radius)}
.contact-form{display:grid;gap:12px}
.contact-form label{display:flex;flex-direction:column;font-size:.85rem;font-weight:600;gap:4px}
.contact-form input,.contact-form textarea{padding:11px 12px;border:1px solid #4a525e;border-radius:var(--radius);
  background:#1b1f26;color:#fff;font:inherit}
.contact-form input:focus,.contact-form textarea:focus{outline:2px solid var(--accent)}
.check{flex-direction:row!important;align-items:center;gap:8px!important;font-weight:400!important}
.hp{position:absolute;left:-9999px}
.alert{padding:12px 14px;border-radius:var(--radius);margin-bottom:12px}
.alert.ok{background:rgba(47,170,90,.18);color:#7ee0a3}
.alert.err{background:rgba(224,65,60,.18);color:#ffb0ad}

/* Footer */
.site-footer{background:var(--ink);color:#aeb4bf;padding:42px 0 18px}
.footer-inner{display:flex;flex-wrap:wrap;gap:24px;justify-content:space-between;align-items:center}
.footer-nav,.social{display:flex;gap:18px;flex-wrap:wrap}
.footer-nav a,.social a{color:#aeb4bf}.footer-nav a:hover,.social a:hover{color:var(--accent-2)}
.copy{text-align:center;color:#666;font-size:.8rem;margin-top:24px;border-top:1px solid #2a2e36;padding-top:16px}
.copy a{color:#666}

/* Legal pages */
.legal h3{margin:22px 0 8px}.legal p{margin-bottom:12px;color:#444}

/* WhatsApp */
.wa-button{position:fixed;right:22px;bottom:22px;width:58px;height:58px;border-radius:50%;
  background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(0,0,0,.3);z-index:60;transition:.15s}
.wa-button:hover{transform:scale(1.08)}

/* Cookie banner */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:80;background:var(--ink);color:#dfe3ea;
  padding:18px 22px;display:flex;flex-wrap:wrap;gap:16px;align-items:center;justify-content:space-between;
  border-top:3px solid var(--accent);box-shadow:0 -8px 24px rgba(0,0,0,.25)}
.cookie-banner p{font-size:.9rem;max-width:680px}
.cookie-banner a{color:var(--accent-2)}
.cookie-actions{display:flex;gap:10px}
.cookie-banner .btn{padding:10px 18px}
