/* ═══════════════════════════════════════════
   MB SPRITZGUSSTECHNIK — GLOBAL STYLES
   Version 2.0
═══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=Barlow:ital,wght@0,300;0,400;0,500;0,600;1,300&display=swap');

:root {
  --mg:        #E6007E;
  --mg-dark:   #b8005f;
  --mg-light:  #ff1a8c;
  --mg-pale:   rgba(230,0,126,0.07);
  --black:     #111;
  --dark:      #1c1c1c;
  --mid:       #555;
  --muted:     #888;
  --border:    #e4e4e4;
  --light:     #f7f7f7;
  --white:     #fff;
  --radius:    3px;
  --nav-h:     68px;
  --max:       1200px;
  --t:         0.22s ease;
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth }
body { font-family:'Barlow',sans-serif; color:var(--black); background:var(--white); overflow-x:hidden }
img  { max-width:100%; display:block }
a    { text-decoration:none; color:inherit }
ul   { list-style:none }
button { cursor:pointer; border:none; background:none; font-family:inherit }

/* ── LANGUAGE ── */
.en { display:none }
body.lang-en .de { display:none }
body.lang-en .en { display:block }
body.lang-en span.en { display:inline }
body.lang-en span.de { display:none }
body.lang-en li.en   { display:list-item }
body.lang-en li.de   { display:none }

/* ── UTILS ── */
.container { max-width:var(--max); margin:0 auto; padding:0 48px }
.section-tag { font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--mg); display:flex; align-items:center; gap:10px; margin-bottom:12px }
.section-tag::before { content:''; width:24px; height:2px; background:var(--mg); flex-shrink:0 }
.section-dark .section-tag { color:#ff6ec7 }
.section-dark .section-tag::before { background:#ff6ec7 }
h2.title { font-family:'Barlow Condensed',sans-serif; font-size:clamp(28px,4vw,50px); font-weight:800; text-transform:uppercase; line-height:1; letter-spacing:.02em; margin-bottom:48px }
h2.title em { font-style:normal; color:var(--mg) }
.section-dark h2.title { color:var(--white) }
section { padding:96px 0 }
.section-dark { background:var(--black) }
.section-light { background:var(--light) }

/* ── BUTTONS ── */
.btn { display:inline-flex; align-items:center; gap:8px; padding:13px 28px; font-size:13px; font-weight:600; letter-spacing:.07em; text-transform:uppercase; border-radius:var(--radius); transition:all var(--t) }
.btn-primary    { background:var(--mg); color:var(--white) }
.btn-primary:hover { background:var(--mg-light); transform:translateY(-1px) }
.btn-outline-light { border:1.5px solid rgba(255,255,255,.28); color:var(--white) }
.btn-outline-light:hover { border-color:var(--mg); background:rgba(230,0,126,.12) }
.btn-outline-dark { border:1.5px solid var(--border); color:var(--black) }
.btn-outline-dark:hover { border-color:var(--mg); color:var(--mg) }

/* ── TOPBAR ── */
.topbar { background:var(--black); padding:7px 0 }
.topbar .container { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:8px }
.topbar-left { display:flex; gap:20px; align-items:center }
.topbar-left a { color:rgba(255,255,255,.45); font-size:12px; transition:color var(--t) }
.topbar-left a:hover { color:var(--white) }
.topbar-left .sep { color:rgba(255,255,255,.15); font-size:10px }
.topbar-right { display:flex; align-items:center; gap:6px }
.lang-btn { font-size:12px; font-weight:600; letter-spacing:.1em; padding:3px 10px; border-radius:2px; color:rgba(255,255,255,.4); transition:all var(--t) }
.lang-btn.active { background:var(--mg); color:var(--white) }
.lang-btn:hover:not(.active) { color:var(--white) }

/* ── NAV ── */
nav { background:var(--white); height:var(--nav-h); position:sticky; top:0; z-index:200; border-bottom:1px solid var(--border); box-shadow:0 2px 16px rgba(0,0,0,.06) }
.nav-inner { height:100%; display:flex; align-items:center; justify-content:space-between; gap:24px }
.logo { display:flex; align-items:center; gap:0; flex-shrink:0 }
.logo img { height:38px; width:auto; display:block }
.nav-links { display:flex; align-items:center; gap:2px }
.nav-item { position:relative }
.nav-link { display:flex; align-items:center; gap:4px; padding:8px 13px; font-size:13.5px; font-weight:500; color:var(--mid); border-radius:var(--radius); transition:all var(--t); white-space:nowrap }
.nav-link:hover, .nav-link.active { color:var(--black); background:var(--mg-pale) }
.nav-link.nav-cta { background:var(--mg)!important; color:var(--white)!important; font-weight:600!important; margin-left:4px }
.nav-link.nav-cta:hover { background:var(--mg-dark)!important }
.nav-chevron { width:11px; height:11px; transition:transform var(--t); opacity:.5 }
.nav-item.open .nav-chevron { transform:rotate(180deg) }

/* Dropdown */
.dropdown { position:absolute; top:calc(100% + 4px); left:0; background:var(--white); border:1px solid var(--border); border-radius:6px; min-width:210px; box-shadow:0 8px 28px rgba(0,0,0,.1); opacity:0; pointer-events:none; transform:translateY(-6px); transition:opacity .18s ease,transform .18s ease; z-index:300 }
.nav-item.open .dropdown { opacity:1; pointer-events:all; transform:translateY(0) }
/* No CSS hover — JS-controlled only */
.dropdown a { display:flex; align-items:center; gap:10px; padding:10px 16px; font-size:13px; color:var(--mid); transition:all var(--t); border-radius:4px; margin:3px }
.dropdown a:hover, .dropdown a.active { background:var(--mg-pale); color:var(--mg) }
.dropdown-icon { font-size:15px; width:22px; text-align:center; flex-shrink:0 }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; padding:8px; cursor:pointer }
.hamburger span { display:block; width:22px; height:2px; background:var(--black); border-radius:2px; transition:all var(--t) }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg) }
.hamburger.open span:nth-child(2) { opacity:0 }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg) }

/* Mobile nav */
.mobile-nav { display:none; position:fixed; inset:0; top:calc(var(--nav-h) + 1px); background:var(--white); z-index:190; overflow-y:auto; padding:16px; flex-direction:column; gap:2px; box-shadow:0 8px 32px rgba(0,0,0,.1) }
.mobile-nav.open { display:flex }
.mobile-nav a { padding:13px 16px; font-size:15px; font-weight:500; color:var(--black); border-radius:var(--radius); transition:all var(--t) }
.mobile-nav a:hover { color:var(--mg); background:var(--mg-pale) }
.mobile-nav .mobile-sub { padding-left:32px; font-size:14px; color:var(--mid) }
.mobile-nav .mobile-sep { height:1px; background:var(--border); margin:8px 0 }

/* ── BREADCRUMB ── */
.breadcrumb { background:var(--light); border-bottom:1px solid var(--border); padding:10px 0 }
.breadcrumb .container { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--muted) }
.breadcrumb a { color:var(--muted); transition:color var(--t) }
.breadcrumb a:hover { color:var(--mg) }
.breadcrumb .sep { color:var(--border) }
.breadcrumb .current { color:var(--black); font-weight:500 }

/* ── PAGE HERO ── */
.page-hero { background:var(--black); padding:72px 0; position:relative; overflow:hidden }
.page-hero::after { content:''; position:absolute; right:0; top:0; bottom:0; width:35%; background:linear-gradient(135deg,var(--mg),#8B004C); clip-path:polygon(20% 0,100% 0,100% 100%,0% 100%); opacity:.8 }
.page-hero .container { position:relative; z-index:1 }
.page-hero-label { font-size:11px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--mg); display:flex; align-items:center; gap:10px; margin-bottom:14px }
.page-hero-label::before { content:''; width:24px; height:2px; background:var(--mg) }
.page-hero h1 { font-family:'Barlow Condensed',sans-serif; font-size:clamp(40px,5vw,68px); font-weight:900; text-transform:uppercase; line-height:.95; color:var(--white); letter-spacing:.01em; margin-bottom:18px }
.page-hero h1 em { font-style:normal; color:var(--mg) }
.page-hero p { font-size:17px; font-weight:300; line-height:1.7; color:rgba(255,255,255,.68); max-width:560px }

/* ── RIBBON ── */
.ribbon { background:var(--mg); padding:16px 0 }
.ribbon .container { display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap }
.ribbon-text { font-size:14.5px; font-weight:500; color:var(--white); line-height:1.5; max-width:700px }
.ribbon-link { font-size:12px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--white); white-space:nowrap; border-bottom:1px solid rgba(255,255,255,.4); padding-bottom:2px }
.ribbon-link:hover { border-color:white }

/* ── CARDS ── */
.card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; transition:all var(--t) }
.card:hover { border-color:var(--mg); box-shadow:0 6px 24px rgba(0,0,0,.08); transform:translateY(-2px) }
.card-img { width:100%; height:200px; object-fit:cover }
.card-body { padding:24px }
.card-tag { font-size:10.5px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--mg); margin-bottom:8px }
.card-title { font-family:'Barlow Condensed',sans-serif; font-size:20px; font-weight:700; text-transform:uppercase; letter-spacing:.03em; margin-bottom:10px }
.card-text { font-size:13.5px; line-height:1.65; color:var(--mid) }
.card-link { display:inline-flex; align-items:center; gap:6px; margin-top:16px; font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--mg) }
.card-link::after { content:'→' }

/* ── LEISTUNG CARDS (overview) ── */
.leistung-card { background:var(--white); padding:40px 28px 36px; position:relative; overflow:hidden; transition:transform var(--t); border:1px solid var(--border) }
.leistung-card::after { content:''; position:absolute; bottom:0; left:0; right:0; height:3px; background:var(--mg); transform:scaleX(0); transform-origin:left; transition:transform .3s }
.leistung-card:hover { transform:translateY(-3px); border-color:var(--mg) }
.leistung-card:hover::after { transform:scaleX(1) }
.leistung-n { position:absolute; top:16px; right:20px; font-family:'Barlow Condensed',sans-serif; font-size:52px; font-weight:900; color:rgba(0,0,0,.04); line-height:1 }
.leistung-icon { width:52px; height:52px; margin-bottom:18px }
.leistung-card h3 { font-family:'Barlow Condensed',sans-serif; font-size:22px; font-weight:700; text-transform:uppercase; letter-spacing:.04em; margin-bottom:12px }
.leistung-card p { font-size:13.5px; line-height:1.65; color:var(--mid) }
.leistung-card ul { margin-top:14px; display:flex; flex-direction:column; gap:5px }
.leistung-card li { font-size:13px; color:var(--mid); display:flex; align-items:flex-start; gap:8px }
.leistung-card li::before { content:'›'; color:var(--mg); font-weight:700; flex-shrink:0 }
.leistung-cta { display:inline-flex; align-items:center; gap:6px; margin-top:20px; font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--mg) }
.leistung-cta::after { content:'→'; transition:transform var(--t) }
.leistung-card:hover .leistung-cta::after { transform:translateX(3px) }

/* ── STATS BAR ── */
.stats-bar { background:var(--black); padding:48px 0 }
.stats-bar .container { display:grid; grid-template-columns:repeat(4,1fr); gap:0 }
.stat-item { padding:0 32px; border-right:1px solid rgba(255,255,255,.08); text-align:center }
.stat-item:last-child { border-right:none }
.stat-val { font-family:'Barlow Condensed',sans-serif; font-size:48px; font-weight:900; color:var(--white); line-height:1 }
.stat-val span { color:var(--mg) }
.stat-lbl { font-size:12px; color:rgba(255,255,255,.4); letter-spacing:.08em; text-transform:uppercase; margin-top:6px }

/* ── TIMELINE ── */
.timeline { position:relative; padding-top:20px }
.timeline::before { content:''; position:absolute; left:50%; top:0; bottom:0; width:2px; background:var(--border); transform:translateX(-50%) }
.tl-item { display:grid; grid-template-columns:1fr 1fr; margin-bottom:4px; position:relative }
.tl-item:nth-child(odd)  .tl-body { grid-column:1; padding-right:56px; text-align:right }
.tl-item:nth-child(odd)  .tl-space { grid-column:2 }
.tl-item:nth-child(even) .tl-space { grid-column:1 }
.tl-item:nth-child(even) .tl-body  { grid-column:2; padding-left:56px }
.tl-dot { position:absolute; left:50%; top:22px; width:14px; height:14px; background:var(--mg); border-radius:50%; transform:translateX(-50%); z-index:1; border:3px solid var(--light) }
.tl-body { padding:12px 0 28px }
.tl-year { font-family:'Barlow Condensed',sans-serif; font-size:30px; font-weight:800; color:var(--mg); line-height:1; margin-bottom:6px }
.tl-text { font-size:13.5px; line-height:1.65; color:var(--mid) }

/* ── CERT LOGOS ── */
.cert-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px }
.cert-card { background:var(--light); border:1px solid var(--border); border-radius:var(--radius); padding:24px 16px; display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:96px; gap:10px; transition:border-color var(--t) }
.cert-card:hover { border-color:var(--mg) }
.cert-card img { max-height:52px; object-fit:contain }
.cert-label { font-size:11.5px; font-weight:600; color:var(--mid); text-align:center; letter-spacing:.04em }

/* ── EFRE ── */
.efre-box { background:var(--light); border-left:4px solid var(--mg); padding:28px 36px; margin-top:56px; display:flex; align-items:center; gap:40px; flex-wrap:wrap; border-radius:0 var(--radius) var(--radius) 0 }
.efre-text h4 { font-family:'Barlow Condensed',sans-serif; font-size:18px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; margin-bottom:6px }
.efre-text p  { font-size:13.5px; color:var(--mid); line-height:1.55; max-width:500px }
.efre-logos   { display:flex; gap:20px; align-items:center; flex-shrink:0 }
.efre-logos img { height:48px; object-fit:contain }

/* ── IHK STRIP ── */
.ihk-strip { background:var(--mg); padding:36px 0 }
.ihk-strip .container { display:flex; align-items:center; justify-content:center; gap:40px; flex-wrap:wrap }
.ihk-logo-box { background:rgba(0,0,0,.15); border-radius:var(--radius); padding:14px 22px }
.ihk-logo-box img { height:56px; filter:brightness(10); opacity:.9 }
.ihk-text h3 { font-family:'Barlow Condensed',sans-serif; font-size:26px; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:var(--white); margin-bottom:4px }
.ihk-text p   { font-size:14px; color:rgba(255,255,255,.8); font-weight:300 }
.ihk-cta { display:inline-block; margin-top:10px; color:var(--white); font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; border-bottom:1px solid rgba(255,255,255,.4); padding-bottom:2px }
.ihk-cta:hover { border-color:white }

/* ── KONTAKT INLINE ── */
.kinfo-item { display:flex; gap:14px; align-items:flex-start; margin-bottom:20px }
.kinfo-icon { width:38px; height:38px; background:rgba(230,0,126,.12); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0 }
.kinfo-label { font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:3px }
.kinfo-val    { font-size:15px; color:var(--white) }
.kinfo-val a  { color:#ff6ec7 }
.kinfo-val a:hover { text-decoration:underline }

/* ── FORM ── */
.form { display:flex; flex-direction:column; gap:14px }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px }
.fg { display:flex; flex-direction:column; gap:5px }
.fg label { font-size:10.5px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.38) }
.fg input,.fg textarea,.fg select { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius); padding:11px 14px; color:var(--white); font-family:'Barlow',sans-serif; font-size:14px; outline:none; transition:border-color var(--t) }
.fg input:focus,.fg textarea:focus,.fg select:focus { border-color:var(--mg) }
.fg textarea   { resize:vertical; min-height:100px }
.fg select option { background:var(--dark) }
.form-note { font-size:12px; color:rgba(255,255,255,.28); line-height:1.5 }
.form-note a   { color:#ff6ec7 }

/* ── FOOTER ── */
footer { background:#0a0a0a; border-top:1px solid rgba(255,255,255,.05) }
.footer-main { padding:52px 0 32px }
.footer-main .container { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px }
.footer-logo img { height:30px; margin-bottom:16px; filter:brightness(10) }
.footer-brand p  { font-size:13px; color:rgba(255,255,255,.35); line-height:1.65; margin-top:4px }
.footer-col h4   { font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.3); margin-bottom:14px }
.footer-col a    { display:block; font-size:13px; color:rgba(255,255,255,.45); margin-bottom:8px; transition:color var(--t) }
.footer-col a:hover { color:var(--mg) }
.footer-bottom { border-top:1px solid rgba(255,255,255,.05); padding:16px 0 }
.footer-bottom .container { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px }
.footer-copy  { font-size:12px; color:rgba(255,255,255,.25) }
.footer-legal { display:flex; gap:24px }
.footer-legal a { font-size:12px; color:rgba(255,255,255,.25); transition:color var(--t) }
.footer-legal a:hover { color:var(--mg) }

/* ── INPAGE EDITOR ── */
.edit-fab { position:fixed; bottom:28px; right:28px; z-index:999; width:50px; height:50px; background:var(--mg); border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(230,0,126,.4); cursor:pointer; transition:all var(--t) }
.edit-fab:hover { background:var(--mg-dark); transform:scale(1.08) }
.edit-fab svg  { width:18px; height:18px; fill:white }
.edit-toolbar  { position:fixed; bottom:88px; right:28px; z-index:999; background:var(--black); border:1px solid rgba(255,255,255,.12); border-radius:8px; padding:12px; display:none; flex-direction:column; gap:7px; box-shadow:0 8px 32px rgba(0,0,0,.4); min-width:192px }
.edit-toolbar.open { display:flex }
.edit-toolbar-title { font-size:10px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.3); padding:0 4px; margin-bottom:2px }
.edit-tb-btn { background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); color:rgba(255,255,255,.75); font-family:'Barlow',sans-serif; font-size:13px; padding:9px 14px; border-radius:4px; text-align:left; transition:all var(--t) }
.edit-tb-btn:hover  { background:rgba(230,0,126,.2); border-color:var(--mg); color:var(--white) }
.edit-tb-btn.active { background:rgba(230,0,126,.25); border-color:var(--mg); color:var(--mg) }
.editing [contenteditable]       { outline:2px dashed rgba(230,0,126,.4); outline-offset:2px; border-radius:2px; cursor:text }
.editing [contenteditable]:focus { outline:2px solid var(--mg); background:rgba(230,0,126,.05) }
.save-toast { position:fixed; bottom:28px; left:50%; transform:translateX(-50%) translateY(80px); background:var(--black); color:var(--white); padding:10px 24px; border-radius:20px; font-size:13px; border:1px solid var(--mg); opacity:0; transition:all .3s; z-index:1000; pointer-events:none }
.save-toast.show { opacity:1; transform:translateX(-50%) translateY(0) }

/* ── SCROLL ANIMATIONS ── */
.fade-up { opacity:0; transform:translateY(26px); transition:opacity .6s ease,transform .6s ease }
.fade-up.visible { opacity:1; transform:translateY(0) }
.d1 { transition-delay:.1s }
.d2 { transition-delay:.2s }
.d3 { transition-delay:.3s }

/* ── SVG ICONS ── */
.icon { width:100%; height:100%; fill:var(--mg) }

/* ── RESPONSIVE ── */
@media(max-width:1024px) {
  .container { padding:0 24px }
  .nav-links  { display:none }
  .hamburger  { display:flex }
  .stats-bar .container { grid-template-columns:repeat(2,1fr); gap:0 }
  .stat-item  { padding:24px; border-bottom:1px solid rgba(255,255,255,.08) }
  .stat-item:nth-child(2n) { border-right:none }
  .footer-main .container { grid-template-columns:1fr 1fr; gap:32px }
  .tl-item { grid-template-columns:1fr }
  .timeline::before { left:20px }
  .tl-item:nth-child(odd)  .tl-body,
  .tl-item:nth-child(even) .tl-body { grid-column:1; padding-left:52px; padding-right:0; text-align:left }
  .tl-item:nth-child(odd)  .tl-space,
  .tl-item:nth-child(even) .tl-space { display:none }
  .tl-dot { left:20px }
  .cert-grid { grid-template-columns:1fr 1fr }
}
@media(max-width:640px) {
  section { padding:64px 0 }
  .footer-main .container { grid-template-columns:1fr }
  .form-row { grid-template-columns:1fr }
  .cert-grid { grid-template-columns:1fr }
  .efre-box  { flex-direction:column }
}
