/* ===================================================================
   MCB Mietcontainer Barnim – Stylesheet
   Industrielles Premium-Design · Stahl & Signalrot
   =================================================================== */

/* ---------- Reset & Tokens ---------- */
:root{
  --red:#d4151a;
  --red-bright:#ef2127;
  --red-dark:#9c0d11;
  --ink:#16171a;
  --ink-2:#1f2125;
  --ink-3:#2a2d33;
  --steel:#3b3f47;
  --steel-2:#5b616b;
  --grey:#6b7079;
  --grey-light:#9aa0aa;
  --paper:#f5f5f3;
  --paper-2:#ececea;
  --paper-3:#e2e2df;
  --white:#ffffff;
  --line:rgba(0,0,0,.09);
  --line-light:rgba(255,255,255,.10);
  --shadow-sm:0 4px 14px rgba(0,0,0,.08);
  --shadow-md:0 14px 36px rgba(0,0,0,.14);
  --shadow-lg:0 28px 60px rgba(0,0,0,.22);
  --r:3px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --max:1220px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;}
body{
  font-family:'Barlow',-apple-system,sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.65;
  overflow-x:hidden;
  width:100%;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
section{position:relative;}

h1,h2,h3,h4,h5{
  font-family:'Oswald',sans-serif;font-weight:700;
  line-height:1.06;text-transform:uppercase;letter-spacing:.4px;
}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--max);margin:0 auto;padding:0 30px;}
.section{padding:108px 0;}
.section-sm{padding:72px 0;}

.kicker{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.8rem;
  letter-spacing:3.4px;text-transform:uppercase;color:var(--red);
  display:inline-flex;align-items:center;gap:12px;
}
.kicker::before{content:"";width:38px;height:2px;background:var(--red);}
.kicker.light{color:var(--red-bright);}
.kicker.center{justify-content:center;}

.dot{color:var(--red);}

.section-head{max-width:680px;margin-bottom:60px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head h2{font-size:clamp(2.1rem,4.4vw,3.3rem);margin:18px 0 16px;}
.section-head p{color:var(--grey);font-size:1.1rem;}

/* ---------- Buttons ---------- */
.btn{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.96rem;
  letter-spacing:1.7px;text-transform:uppercase;
  padding:17px 36px;border-radius:var(--r);cursor:pointer;
  border:2px solid transparent;display:inline-flex;align-items:center;gap:11px;
  transition:all .25s var(--ease);position:relative;
}
.btn svg{width:17px;height:17px;}
.btn-primary{background:var(--red);color:#fff;}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-3px);box-shadow:0 14px 30px rgba(212,21,26,.4);}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.42);}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.09);transform:translateY(-3px);}
.btn-dark{background:var(--ink);color:#fff;}
.btn-dark:hover{background:#000;transform:translateY(-3px);box-shadow:var(--shadow-md);}
.btn-outline-dark{background:transparent;color:var(--ink);border-color:var(--ink);}
.btn-outline-dark:hover{background:var(--ink);color:#fff;transform:translateY(-3px);}

/* ---------- Header ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:rgba(22,23,26,.97);
  backdrop-filter:blur(10px);
  border-bottom:3px solid var(--red);
  transition:padding .28s var(--ease);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--max);margin:0 auto;padding:12px 30px;
}
.nav-logo img{height:100px;width:auto;transition:height .28s var(--ease);}
header.shrink .nav-logo img{height:72px;}
.nav-links{display:flex;gap:6px;align-items:center;}
.nav-links > a{
  font-family:'Oswald',sans-serif;font-weight:500;font-size:.9rem;
  text-transform:uppercase;letter-spacing:1.2px;color:#e7e7e7;
  padding:9px 15px;position:relative;transition:color .2s;
}
.nav-links > a::after{
  content:"";position:absolute;bottom:2px;left:15px;right:15px;
  height:2px;background:var(--red);transform:scaleX(0);
  transform-origin:left;transition:transform .26s var(--ease);
}
.nav-links > a:hover{color:#fff;}
.nav-links > a:hover::after,.nav-links > a.active::after{transform:scaleX(1);}
.nav-links > a.active{color:#fff;}
.nav-cta{
  background:var(--red);color:#fff !important;
  padding:12px 24px !important;border-radius:var(--r);
  font-weight:600;letter-spacing:1.3px;margin-left:8px;
  transition:background .2s,transform .2s;
}
.nav-cta::after{display:none !important;}
.nav-cta:hover{background:var(--red-dark);transform:translateY(-2px);}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px;position:relative;z-index:330;}
.burger span{width:27px;height:3px;background:#fff;display:block;transition:.3s var(--ease);border-radius:2px;}
.burger.open span:nth-child(1){transform:translateY(8px) rotate(45deg);}
.burger.open span:nth-child(2){opacity:0;}
.burger.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg);}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{
  padding:170px 0 80px;color:#fff;
  background:
    linear-gradient(rgba(18,19,21,.86),rgba(18,19,21,.93)),
    repeating-linear-gradient(135deg,#1c1d20 0 40px,#171819 40px 80px);
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:"";position:absolute;top:0;right:0;width:42%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(212,21,26,.16));
  clip-path:polygon(32% 0,100% 0,100% 100%,0 100%);
}
.page-hero .container{position:relative;z-index:2;}
.page-hero h1{font-size:clamp(2.4rem,5.4vw,4rem);margin:18px 0 14px;}
.page-hero p{color:#c6c6c6;font-size:1.15rem;max-width:600px;}
.breadcrumb{
  font-family:'Oswald',sans-serif;font-size:.82rem;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--grey-light);margin-top:22px;
}
.breadcrumb a:hover{color:var(--red-bright);}
.breadcrumb span{color:var(--red-bright);}

/* ---------- Footer ---------- */
footer{background:#0e0f11;color:#9a9ca1;padding:66px 0 28px;}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:40px;margin-bottom:48px;}
.foot-brand img{height:66px;margin-bottom:20px;}
.foot-brand p{font-size:.96rem;max-width:300px;margin-bottom:18px;}
.foot-tag{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.85rem;
  letter-spacing:1.6px;text-transform:uppercase;color:var(--red-bright);
}
.foot-col h4{color:#fff;font-size:1.04rem;margin-bottom:20px;letter-spacing:1px;}
.foot-col a,.foot-col p{
  display:block;font-size:.95rem;margin-bottom:11px;transition:color .2s,padding .2s;
}
.foot-col a:hover{color:var(--red-bright);padding-left:5px;}
.foot-contact-row{display:flex;gap:10px;align-items:flex-start;margin-bottom:13px;}
.foot-contact-row svg{width:17px;height:17px;fill:var(--red);flex:none;margin-top:3px;}
.foot-bottom{
  border-top:1px solid var(--line-light);padding-top:26px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:.85rem;
}
.foot-bottom a{text-decoration:underline;}
.foot-bottom a:hover{color:var(--red-bright);}

/* ---------- Floating actions ---------- */
.float-actions{
  position:fixed;right:22px;bottom:22px;z-index:150;
  display:flex;flex-direction:column;gap:13px;
}
.float-btn{
  width:60px;height:60px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 26px rgba(0,0,0,.34);transition:transform .22s var(--ease);
}
.float-btn:hover{transform:scale(1.12);}
.float-btn svg{width:31px;height:31px;fill:#fff;}
.float-wa{background:#25d366;}
.float-call{background:var(--red);}
.float-btn .pulse{position:absolute;width:100%;height:100%;border-radius:50%;animation:pulse 2.4s infinite;}
.float-call .pulse{background:var(--red);}
@keyframes pulse{0%{transform:scale(1);opacity:.6;}70%{transform:scale(1.7);opacity:0;}100%{opacity:0;}}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal-d1{transition-delay:.08s;}
.reveal-d2{transition-delay:.16s;}
.reveal-d3{transition-delay:.24s;}

/* ---------- Cookie banner ---------- */
.cookie{
  position:fixed;left:22px;right:22px;bottom:22px;z-index:300;
  background:var(--ink);color:#e2e2e2;border:1px solid var(--ink-3);
  border-left:5px solid var(--red);
  padding:22px 26px;border-radius:var(--r);
  display:none;align-items:center;gap:24px;flex-wrap:wrap;
  box-shadow:var(--shadow-lg);max-width:760px;margin:0 auto;
}
.cookie.show{display:flex;}
.cookie p{font-size:.92rem;flex:1;min-width:240px;}
.cookie p a{color:var(--red-bright);text-decoration:underline;}
.cookie-actions{display:flex;gap:10px;}
.cookie-actions button{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.82rem;
  letter-spacing:1.2px;text-transform:uppercase;padding:11px 20px;
  border-radius:var(--r);cursor:pointer;border:2px solid transparent;transition:.2s;
}
.ck-accept{background:var(--red);color:#fff;}
.ck-accept:hover{background:var(--red-dark);}
.ck-decline{background:transparent;color:#bdbdbd;border-color:var(--steel);}
.ck-decline:hover{border-color:#fff;color:#fff;}

/* ---------- Generic prose (legal pages) ---------- */
.prose{max-width:860px;margin:0 auto;}
.prose h2{font-size:1.6rem;margin:42px 0 16px;color:var(--ink);}
.prose h3{font-size:1.18rem;margin:28px 0 10px;color:var(--ink);}
.prose p{margin-bottom:14px;color:var(--steel);}
.prose ul{margin:0 0 14px 0;}
.prose ul li{position:relative;padding-left:22px;margin-bottom:8px;color:var(--steel);}
.prose ul li::before{content:"";position:absolute;left:0;top:10px;width:8px;height:8px;background:var(--red);transform:rotate(45deg);}
.prose a{color:var(--red);text-decoration:underline;}
.prose strong{color:var(--ink);}

/* ===================================================================
   COMPONENTS
   =================================================================== */

/* ---- Home hero ---- */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:160px 0 100px;color:#fff;overflow:hidden;
  background:
    linear-gradient(rgba(16,17,19,.80),rgba(16,17,19,.90)),
    repeating-linear-gradient(135deg,#1c1d20 0 42px,#171819 42px 84px);
}
.hero::before{
  content:"";position:absolute;top:0;right:0;width:48%;height:100%;
  background:linear-gradient(115deg,transparent 0%,rgba(212,21,26,.20) 100%);
  clip-path:polygon(26% 0,100% 0,100% 100%,0 100%);
}
.hero::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(circle,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:28px 28px;
}
.hero-inner{position:relative;z-index:3;max-width:780px;}
.hero h1{font-size:clamp(2.9rem,6.6vw,5.4rem);letter-spacing:.6px;margin:24px 0 22px;}
.hero h1 .hl{color:var(--red-bright);position:relative;}
.hero p.lead{font-size:1.26rem;color:#d0d0d0;max-width:560px;margin-bottom:6px;}
.hero-badges{display:flex;flex-wrap:wrap;gap:11px;margin:28px 0 36px;}
.hero-badges span{
  font-family:'Oswald',sans-serif;font-weight:500;font-size:.82rem;
  letter-spacing:1.6px;text-transform:uppercase;color:#e7e7e7;
  border:1px solid rgba(255,255,255,.26);padding:9px 16px;
  display:flex;align-items:center;gap:9px;
}
.hero-badges span::before{content:"";width:7px;height:7px;background:var(--red);transform:rotate(45deg);}
.hero-actions{display:flex;flex-wrap:wrap;gap:16px;}
.hero-scroll{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:3;
  font-family:'Oswald',sans-serif;font-size:.74rem;letter-spacing:2px;
  text-transform:uppercase;color:var(--grey-light);
  display:flex;flex-direction:column;align-items:center;gap:9px;
}
.hero-scroll .line{width:2px;height:42px;background:linear-gradient(var(--red),transparent);animation:scrolldown 1.8s infinite;}
@keyframes scrolldown{0%{transform:scaleY(0);transform-origin:top;}50%{transform:scaleY(1);transform-origin:top;}51%{transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}

/* ---- Container Rotate Showcase ---- */
.rotate-section{
  background:
    linear-gradient(rgba(16,17,19,.95),rgba(16,17,19,.97)),
    repeating-linear-gradient(135deg,#1c1d20 0 42px,#171819 42px 84px);
  color:#fff;padding:104px 0;overflow:hidden;position:relative;
}
.rotate-section::before{
  content:"";position:absolute;top:50%;right:-12%;width:640px;height:640px;
  transform:translateY(-50%);border-radius:50%;
  background:radial-gradient(circle,rgba(212,21,26,.22),transparent 68%);
  pointer-events:none;
}
.rotate-layout{
  display:grid;grid-template-columns:1fr 1.05fr;gap:56px;align-items:center;
  position:relative;z-index:2;
}
.rotate-info h2{font-size:clamp(2rem,4vw,3.1rem);margin:18px 0 18px;}
.rotate-info > p{color:#bcbcbc;font-size:1.08rem;margin-bottom:30px;max-width:460px;}

.rotate-stats{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.10);
}
.rs-item{
  background:var(--ink);
  padding:22px 20px;
  min-width:0;
  transition:background .25s;
}
.rs-item:hover{background:var(--ink-2);}
.rs-top{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;}
.rs-num{
  font-family:'Oswald',sans-serif;font-weight:700;font-size:2.6rem;
  line-height:1;color:#fff;
}
.rs-unit{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:1.05rem;
  color:var(--red-bright);
}
.rs-lbl{
  font-family:'Oswald',sans-serif;font-size:.74rem;letter-spacing:1.4px;
  text-transform:uppercase;color:var(--grey-light);margin-top:7px;
  line-height:1.3;
}
.rotate-actions{margin-top:28px;}

/* Bühne mit rotierendem Container */
.rotate-stage{
  position:relative;height:440px;
  display:flex;align-items:center;justify-content:center;
}
.rotate-glow{
  position:absolute;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(212,21,26,.16),transparent 66%);
  pointer-events:none;
}
.rotate-wrap{
  position:relative;width:100%;max-width:480px;
}
.rotate-img{
  width:100%;height:auto;display:block;
  transform-origin:50% 60%;
  will-change:transform;
  filter:drop-shadow(0 26px 36px rgba(0,0,0,.55));
}
.rotate-shadow{
  position:absolute;left:50%;bottom:6%;
  width:62%;height:30px;transform:translateX(-50%);
  background:radial-gradient(ellipse,rgba(0,0,0,.55),transparent 72%);
  filter:blur(7px);
}


/* ---- USP grid ---- */
.usp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.usp{background:var(--white);padding:42px 34px;transition:background .25s,transform .25s;}
.usp:hover{background:var(--ink);transform:translateY(-4px);}
.usp:hover h3,.usp:hover p{color:#fff;}
.usp:hover .usp-ico{background:var(--red);border-color:var(--red);}
.usp:hover .usp-ico svg{fill:#fff;}
.usp-ico{
  width:62px;height:62px;border:2px solid var(--ink);border-radius:var(--r);
  display:flex;align-items:center;justify-content:center;margin-bottom:22px;
  transition:.25s var(--ease);
}
.usp-ico svg{width:30px;height:30px;fill:var(--ink);transition:.25s;}
.usp h3{font-size:1.32rem;margin-bottom:12px;transition:color .25s;}
.usp p{color:var(--grey);font-size:.99rem;transition:color .25s;}

/* ---- Container showcase ---- */
.showcase{background:var(--ink);color:#fff;overflow:hidden;
  background-image:
    linear-gradient(rgba(22,23,26,.96),rgba(22,23,26,.96)),
    repeating-linear-gradient(90deg,#0e0f11 0 64px,#1a1b1e 64px 128px);
}
.showcase-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.showcase-visual{
  position:relative;background:var(--ink-2);
  border:1px solid var(--ink-3);border-left:5px solid var(--red);
  padding:0;aspect-ratio:4/3;overflow:hidden;
}
.container-illus{width:100%;height:100%;display:block;}
.showcase-tag{
  position:absolute;top:22px;left:22px;background:var(--red);color:#fff;
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.78rem;
  letter-spacing:1.5px;text-transform:uppercase;padding:8px 16px;
}
.showcase-text h2{font-size:clamp(2rem,4vw,3rem);margin:18px 0 18px;}
.showcase-text > p{color:#bcbcbc;font-size:1.06rem;margin-bottom:26px;}
.spec-list{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--ink-3);border:1px solid var(--ink-3);margin-bottom:30px;}
.spec-list div{background:var(--ink);padding:18px 20px;}
.spec-list .sk{font-family:'Oswald',sans-serif;font-size:.74rem;letter-spacing:1.6px;text-transform:uppercase;color:var(--red-bright);}
.spec-list .sv{font-family:'Oswald',sans-serif;font-weight:600;font-size:1.18rem;margin-top:4px;}

/* ---- Process steps ---- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;counter-reset:s;}
.step{position:relative;background:var(--white);border:1px solid var(--line);border-top:4px solid var(--red);padding:34px 28px 30px;transition:transform .25s,box-shadow .25s;}
.step:hover{transform:translateY(-7px);box-shadow:var(--shadow-md);}
.step::before{
  counter-increment:s;content:"0" counter(s);
  font-family:'Oswald',sans-serif;font-weight:700;font-size:3.2rem;
  color:var(--paper-3);line-height:1;display:block;margin-bottom:12px;
}
.step h3{font-size:1.2rem;margin-bottom:11px;}
.step p{color:var(--grey);font-size:.97rem;}

/* ---- Testimonials ---- */
.testimonials{background:var(--paper-2);}
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.tm{background:var(--white);border:1px solid var(--line);padding:34px 30px;position:relative;}
.tm::before{
  content:"\201C";font-family:'Oswald',sans-serif;font-size:5rem;
  color:var(--paper-3);position:absolute;top:6px;right:22px;line-height:1;
}
.tm-stars{display:flex;gap:3px;margin-bottom:16px;}
.tm-stars svg{width:18px;height:18px;fill:var(--red);}
.tm p{font-size:1rem;color:var(--steel);margin-bottom:20px;font-style:italic;}
.tm-author{display:flex;align-items:center;gap:13px;}
.tm-avatar{
  width:46px;height:46px;border-radius:50%;background:var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:'Oswald',sans-serif;font-weight:700;color:#fff;font-size:1.1rem;flex:none;
}
.tm-name{font-family:'Oswald',sans-serif;font-weight:600;font-size:1rem;letter-spacing:.5px;}
.tm-role{font-size:.84rem;color:var(--grey);}

/* ---- CTA band ---- */
.cta-band{background:var(--red);color:#fff;padding:78px 0;text-align:center;overflow:hidden;position:relative;}
.cta-band::before,.cta-band::after{
  content:"";position:absolute;top:0;height:100%;width:130px;
  background:repeating-linear-gradient(45deg,rgba(0,0,0,.15) 0 15px,transparent 15px 30px);
}
.cta-band::before{left:0;}.cta-band::after{right:0;}
.cta-band .container{position:relative;z-index:2;}
.cta-band h2{font-size:clamp(2rem,4.2vw,3rem);margin-bottom:14px;}
.cta-band p{font-size:1.14rem;max-width:580px;margin:0 auto 28px;opacity:.96;}
.cta-band .hero-actions{justify-content:center;}

/* ---- Feature split (about) ---- */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;}
.split-text h2{font-size:clamp(2rem,4vw,3rem);margin:18px 0 20px;}
.split-text p{color:var(--grey);margin-bottom:16px;font-size:1.05rem;}
.check-list{margin-top:24px;}
.check-list li{display:flex;gap:14px;align-items:flex-start;margin-bottom:14px;font-weight:500;}
.check-list li::before{
  content:"";flex:none;width:24px;height:24px;margin-top:3px;background:var(--red);
  clip-path:polygon(43% 0,100% 0,57% 100%,0 100%);
}
.panel-dark{background:var(--ink);color:#fff;padding:46px 42px;border-left:6px solid var(--red);position:relative;}
.panel-dark::before{content:"";position:absolute;top:-1px;right:-1px;width:72px;height:72px;background:var(--red);clip-path:polygon(100% 0,0 0,100% 100%);}
.panel-dark h3{font-size:1.5rem;margin-bottom:22px;}
.panel-row{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid var(--line-light);font-size:.98rem;}
.panel-row:last-child{border-bottom:none;}
.panel-row span:first-child{color:#bcbcbc;}
.panel-row span:last-child{font-family:'Oswald',sans-serif;font-weight:600;letter-spacing:.4px;}

/* ---- FAQ ---- */
.faq-list{max-width:880px;margin:0 auto;}
.faq-item{background:var(--white);border:1px solid var(--line);margin-bottom:14px;transition:box-shadow .25s;}
.faq-item.open{box-shadow:var(--shadow-sm);border-color:var(--paper-3);}
.faq-q{
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:24px 26px;text-align:left;
  font-family:'Oswald',sans-serif;font-weight:600;font-size:1.1rem;
  text-transform:uppercase;letter-spacing:.5px;color:var(--ink);
}
.faq-q .ico{flex:none;width:32px;height:32px;background:var(--red);display:flex;align-items:center;justify-content:center;position:relative;transition:transform .3s var(--ease);}
.faq-q .ico::before,.faq-q .ico::after{content:"";position:absolute;background:#fff;}
.faq-q .ico::before{width:15px;height:3px;}
.faq-q .ico::after{width:3px;height:15px;transition:opacity .3s;}
.faq-item.open .faq-q .ico{transform:rotate(135deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .38s var(--ease);}
.faq-a p{padding:0 26px 24px;color:var(--grey);font-size:1rem;}

/* ---- Container detail ---- */
.detail-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:start;}
.detail-visual{position:sticky;top:110px;}
.detail-img{background:var(--ink);border:1px solid var(--ink-3);border-bottom:5px solid var(--red);aspect-ratio:4/3;overflow:hidden;position:relative;}
.detail-highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:12px;}
.dh{
  background:var(--white);border:1px solid var(--line);
  padding:18px 12px;text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:9px;
  transition:transform .22s var(--ease),border-color .22s;
}
.dh:hover{transform:translateY(-4px);border-color:var(--red);}
.dh svg{width:26px;height:26px;fill:var(--red);}
.dh span{
  font-family:'Oswald',sans-serif;font-weight:600;font-size:.82rem;
  letter-spacing:1px;text-transform:uppercase;color:var(--ink);
}
.detail-text h2{font-size:2rem;margin:14px 0 14px;}
.detail-text p{color:var(--grey);margin-bottom:16px;}
.bigspecs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);margin:24px 0;}
.bigspecs div{background:var(--white);padding:20px 22px;}
.bigspecs .bk{font-family:'Oswald',sans-serif;font-size:.74rem;letter-spacing:1.6px;text-transform:uppercase;color:var(--red);}
.bigspecs .bv{font-family:'Oswald',sans-serif;font-weight:600;font-size:1.3rem;margin-top:4px;color:var(--ink);}

/* ---- Use cases ---- */
.usecase-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.usecase{background:var(--white);border:1px solid var(--line);padding:30px 24px;text-align:center;transition:transform .25s,box-shadow .25s;}
.usecase:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);}
.usecase-ico{width:56px;height:56px;margin:0 auto 16px;background:var(--paper-2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;}
.usecase-ico svg{width:28px;height:28px;fill:var(--red);}
.usecase h3{font-size:1.06rem;margin-bottom:8px;}
.usecase p{font-size:.92rem;color:var(--grey);}

/* ---- Info cards (ablauf documents) ---- */
.docs-box{background:var(--white);border:1px solid var(--line);border-left:5px solid var(--red);padding:38px 40px;}
.docs-box h3{font-size:1.4rem;margin-bottom:18px;}
.docs-list li{display:flex;gap:13px;align-items:flex-start;margin-bottom:13px;color:var(--steel);}
.docs-list li svg{width:21px;height:21px;fill:var(--red);flex:none;margin-top:3px;}

/* ---- Contact ---- */
.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:54px;align-items:start;}
.contact-card{background:var(--ink);color:#fff;padding:40px 38px;border-top:5px solid var(--red);}
.contact-card h3{font-size:1.5rem;margin-bottom:8px;}
.contact-card > p{color:#bcbcbc;font-size:.98rem;margin-bottom:26px;}
.cc-row{display:flex;gap:15px;align-items:flex-start;padding:17px 0;border-bottom:1px solid var(--line-light);}
.cc-row:last-child{border-bottom:none;}
.cc-ico{flex:none;width:46px;height:46px;background:var(--red);display:flex;align-items:center;justify-content:center;}
.cc-ico svg{width:21px;height:21px;fill:#fff;}
.cc-label{font-family:'Oswald',sans-serif;font-weight:600;font-size:.74rem;letter-spacing:1.8px;text-transform:uppercase;color:var(--red-bright);}
.cc-val{font-size:1.04rem;font-weight:600;margin-top:2px;}
.cc-val a:hover{color:var(--red-bright);}
.cc-hours{margin-top:24px;padding-top:20px;border-top:1px solid var(--line-light);}
.cc-hours .hk{font-family:'Oswald',sans-serif;font-weight:600;font-size:.74rem;letter-spacing:1.8px;text-transform:uppercase;color:var(--red-bright);margin-bottom:10px;}
.cc-hours .hrow{display:flex;justify-content:space-between;font-size:.94rem;color:#cfcfcf;padding:4px 0;}

.form-card{background:var(--white);border:1px solid var(--line);border-top:5px solid var(--red);padding:42px 40px;}
.form-card h3{font-size:1.6rem;margin-bottom:6px;}
.form-card .fsub{color:var(--grey);font-size:.97rem;margin-bottom:26px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.field{margin-bottom:18px;}
.field label{
  display:block;font-family:'Oswald',sans-serif;font-weight:500;
  font-size:.78rem;letter-spacing:1.4px;text-transform:uppercase;
  margin-bottom:8px;color:var(--steel);
}
.field input,.field select,.field textarea{
  width:100%;padding:14px 15px;border:1px solid #d2d2ce;background:var(--paper);
  font-family:'Barlow',sans-serif;font-size:.99rem;border-radius:var(--r);
  transition:border .2s,box-shadow .2s;color:var(--ink);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--red);box-shadow:0 0 0 3px rgba(212,21,26,.13);
}
.field textarea{resize:vertical;min-height:120px;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--red);background:#fdf0f0;}
.field .err{display:none;color:var(--red);font-size:.8rem;margin-top:5px;font-weight:600;}
.field.invalid .err{display:block;}
.form-check{display:flex;gap:11px;align-items:flex-start;margin-bottom:22px;font-size:.87rem;color:var(--grey);padding:10px 12px;border:1px solid transparent;border-radius:var(--r);transition:background .2s,border-color .2s;}
.form-check.invalid{background:#fdf0f0;border-color:var(--red);color:var(--red-dark);}
.form-check input{margin-top:3px;flex:none;width:18px;height:18px;accent-color:var(--red);}
.form-check a{color:var(--red);text-decoration:underline;}
.form-note{font-size:.82rem;color:var(--grey-light);margin-top:15px;text-align:center;}
.form-msg{padding:16px 18px;border-radius:var(--r);font-size:.96rem;margin-bottom:18px;font-weight:500;display:none;}
.form-msg.ok{background:#e7f5ec;color:#1b6b34;border:1px solid #b4ddc1;}
.form-msg.show{display:block;}

/* ---- Map embed ---- */
.map-wrap{margin-top:14px;border:1px solid var(--line);border-top:4px solid var(--red);overflow:hidden;}
.map-wrap iframe{width:100%;height:340px;display:block;border:0;filter:grayscale(.3) contrast(1.05);}

/* ---- Mini CTA inline ---- */
.inline-cta{background:var(--white);border:1px solid var(--line);border-left:5px solid var(--red);padding:30px 34px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;margin-top:40px;}
.inline-cta h3{font-size:1.3rem;}
.inline-cta p{color:var(--grey);font-size:.96rem;margin-top:4px;}

/* ===================================================================
   RESPONSIVE
   =================================================================== */

/* ---- Tablet quer / kleiner Desktop ---- */
@media(max-width:1020px){
  .nav-links > a{padding:9px 11px;font-size:.85rem;}
  .nav-cta{padding:11px 18px !important;}
  .nav-logo img{height:86px;}
}

/* ---- Tablet ---- */
@media(max-width:920px){
  .container{padding:0 24px;}
  .split,.contact-grid,.showcase-grid,.detail-grid{grid-template-columns:1fr;gap:42px;}
  .usp-grid,.steps,.tm-grid{grid-template-columns:1fr 1fr;}
  .usecase-grid{grid-template-columns:1fr 1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;}
  .detail-visual{position:static;}
  .rotate-layout{grid-template-columns:1fr;gap:44px;}
  .rotate-info{order:2;}
  .rotate-stage{order:1;}
  .rotate-info > p{max-width:none;}
  .spec-list[style*="repeat(3"]{grid-template-columns:1fr 1fr !important;}
}

/* ---- Mobile (Smartphone) ---- */
@media(max-width:680px){
  /* Burger sichtbar */
  .burger{display:flex;}

  /* Header: kompakter, Logo größer & gut sichtbar */
  .nav{padding:12px 18px;}
  .nav-logo img{height:90px;}
  header.shrink .nav-logo img{height:68px;}
  .container{padding:0 18px;}

  /* Mobiles Menü-Overlay */
  .nav-links{
    position:fixed;top:0;left:0;right:0;bottom:0;
    width:100%;height:100%;min-height:100dvh;
    background:var(--ink);
    flex-direction:column;justify-content:center;gap:4px;
    transform:translateX(100%);
    visibility:hidden;
    transition:transform .38s var(--ease),visibility 0s linear .38s;
    border-left:none;z-index:320;padding:0 24px;
  }
  .nav-links.open{
    transform:translateX(0);
    visibility:visible;
    transition:transform .38s var(--ease),visibility 0s linear 0s;
  }
  .nav-links > a{font-size:1.3rem;padding:15px;color:#fff;width:100%;text-align:center;}
  .nav-links > a::after{display:none;}
  .nav-links > a.active{color:var(--red-bright);}
  .nav-cta{
    margin-left:0;margin-top:14px;width:100%;max-width:280px;
    text-align:center;font-size:1.05rem !important;padding:16px 24px !important;
  }

  /* Abschnitts-Abstände */
  .section{padding:60px 0;}
  .section-sm{padding:48px 0;}
  .section-head{margin-bottom:34px;}
  .section-head h2{font-size:2rem;}
  .section-head p{font-size:1rem;}

  /* HERO – keine 100vh mehr, flexible Höhe, kein Abschneiden */
  .hero{
    min-height:auto;
    padding:130px 0 64px;
    display:block;
  }
  .hero::before{width:100%;clip-path:none;opacity:.5;}
  .hero h1{font-size:2.45rem;margin:16px 0 16px;}
  .hero p.lead{font-size:1.05rem;}
  .hero-badges{gap:8px;margin:22px 0 26px;}
  .hero-badges span{font-size:.74rem;padding:8px 12px;}
  .hero-actions{flex-direction:column;align-items:stretch;gap:12px;}
  .hero-actions .btn{justify-content:center;width:100%;}
  .hero-scroll{display:none;}

  /* Page-Hero (Unterseiten) */
  .page-hero{padding:120px 0 50px;}
  .page-hero::before{width:100%;clip-path:none;opacity:.5;}
  .page-hero h1{font-size:2.1rem;}
  .page-hero p{font-size:1rem;}

  /* Container-Rotate-Showcase mobil */
  .rotate-section{padding:62px 0;}
  .rotate-section::before{width:360px;height:360px;}
  .rotate-info h2{font-size:1.9rem;}
  .rotate-stats{grid-template-columns:repeat(2,minmax(0,1fr));}
  .rs-item{padding:18px 14px;}
  .rs-num{font-size:2.1rem;}
  .rs-unit{font-size:.9rem;}
  .rs-lbl{letter-spacing:.8px;font-size:.7rem;}
  .rotate-stage{height:300px;}
  .rotate-glow{width:300px;height:300px;}
  .rotate-wrap{max-width:340px;}

  /* Grids einspaltig */
  .usp-grid,.steps,.tm-grid,.usecase-grid,.spec-list,.bigspecs,.foot-grid,.form-row{
    grid-template-columns:1fr !important;
  }
  .spec-list[style*="repeat(3"]{grid-template-columns:1fr !important;}

  /* USP-Kacheln kompakter */
  .usp{padding:32px 24px;}
  .usp h3{font-size:1.2rem;}

  /* Showcase */
  .showcase-text h2{font-size:1.8rem;}
  .showcase-visual{aspect-ratio:4/3;}

  /* Schritte */
  .step{padding:28px 24px 26px;}
  .step::before{font-size:2.6rem;}

  /* Testimonials */
  .tm{padding:28px 24px;}

  /* Container-Detail */
  .detail-text h2{font-size:1.7rem;}
  .detail-highlights{grid-template-columns:repeat(3,1fr);}
  .dh{padding:14px 6px;}
  .dh span{font-size:.72rem;}

  /* CTA-Band */
  .cta-band{padding:56px 0;}
  .cta-band h2{font-size:1.9rem;}
  .cta-band p{font-size:1rem;}
  .cta-band::before,.cta-band::after{width:50px;}

  /* Inline-CTA */
  .inline-cta{flex-direction:column;align-items:stretch;text-align:left;padding:26px 22px;}
  .inline-cta .btn{justify-content:center;}

  /* Formular */
  .form-card,.contact-card{padding:30px 22px;}
  .form-card h3{font-size:1.4rem;}
  .panel-dark,.docs-box{padding:30px 24px;}

  /* Footer */
  footer{padding:50px 0 24px;}
  .foot-grid{gap:32px;}
  .foot-bottom{flex-direction:column;gap:8px;text-align:center;}

  /* Cookie-Banner */
  .cookie{left:10px;right:10px;bottom:10px;padding:18px;flex-direction:column;align-items:stretch;gap:14px;}
  .cookie-actions{justify-content:stretch;}
  .cookie-actions button{flex:1;}

  /* Floating-Buttons – kleiner, damit sie weniger überdecken */
  .float-actions{right:12px;bottom:12px;gap:10px;}
  .float-btn{width:52px;height:52px;}
  .float-btn svg{width:26px;height:26px;}

  /* Prose / Rechtsseiten */
  .prose h2{font-size:1.35rem;}
  .prose h3{font-size:1.08rem;}

  /* FAQ */
  .faq-q{padding:18px 18px;font-size:.98rem;gap:14px;}
  .faq-a p{padding:0 18px 20px;font-size:.95rem;}

  /* Map */
  .map-wrap iframe,#mapHolder{height:280px !important;}

  /* Breadcrumb */
  .breadcrumb{font-size:.76rem;}

  /* Kicker etwas kleiner */
  .kicker{font-size:.72rem;letter-spacing:2.4px;}
  .kicker::before{width:26px;}
}

/* ---- Sehr kleine Geräte ---- */
@media(max-width:380px){
  .hero h1{font-size:2.1rem;}
  .page-hero h1{font-size:1.85rem;}
  .rs-num{font-size:1.8rem;}
  .rs-lbl{font-size:.62rem;letter-spacing:.4px;}
  .rs-item{padding:16px 11px;}
  .section-head h2{font-size:1.75rem;}
  .nav-logo img{height:76px;}
  .rotate-wrap{max-width:290px;}
  .rotate-stage{height:260px;}
}
