
/* ------------------------------------------------------------
   Mobile hero fixes (v31)
   - Ensure the video/image always fills the whole hero on phones
   - Reduce the black text panel so it doesn't cover the whole slide
------------------------------------------------------------- */
@media (max-width: 820px) {
  .hero-slider {
    height: 72vh !important;
    min-height: 520px;
  }
  .hero-slider .slide {
    position: absolute !important;
    inset: 0 !important;
  }
  .hero-slider .hero-media {
    position: absolute !important;
    inset: 0 !important;
  }
  .hero-slider video,
  .hero-slider img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
  }

  .hero-overlay {
    align-items: flex-end !important;
  }
  .hero-content {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 12px 14px !important;
    padding: 14px 14px 16px !important;
    border-radius: 16px !important;
    background: rgba(0,0,0,.48) !important;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
  }
  .hero h1 {
    font-size: 34px !important;
    line-height: 1.08 !important;
    margin: 10px 0 10px !important;
  }
  .hero .kicker {
    font-size: 12px !important;
    letter-spacing: .12em !important;
  }
  .hero p {
    font-size: 15px !important;
    line-height: 1.45 !important;
    margin: 0 0 14px !important;
  }
  .btn-primary {
    padding: 14px 20px !important;
    font-size: 16px !important;
  }
  .hero-nav {
    width: 44px !important;
    height: 44px !important;
  }
}
:root{
  --bg:#0b1b3a;
  --blue:#0b3d91;
  --blue2:#1f6feb;
  --text:#0f172a;
  --muted:#475569;
  --line:#e2e8f0;
  --card:#ffffff;
  --radius:18px;
  --shadow:0 14px 40px rgba(2,6,23,.10);
  --max:1140px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:#f6f8fc;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 0}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:48px;width:auto}
.nav{display:flex;gap:16px;align-items:center;font-weight:700}
.nav a{padding:10px 8px;border-bottom:2px solid transparent;color:#0f172a}
.nav a:hover{color:var(--blue2)}
.nav a[aria-current="page"]{border-bottom-color:var(--blue2);color:var(--blue2)}
.header-right{display:flex;align-items:center;gap:10px}
.social{display:flex;gap:10px;align-items:center}
.social a{width:38px;height:38px;border:1px solid var(--line);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:#fff}
.social a:hover{border-color:#cbd5e1}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:11px 16px;border-radius:999px;border:1px solid #cbd5e1;background:#fff;font-weight:800}
.btn.primary{background:var(--blue2);border-color:var(--blue2);color:#fff}
.btn:hover{filter:brightness(.98)}
.hero{background:#000;position:relative}
.hero video,.hero img{width:100%;height:min(72vh,720px);object-fit:cover}
.hero-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;background:linear-gradient(180deg, rgba(0,0,0,.25) 0%, rgba(0,0,0,.55) 60%, rgba(0,0,0,.72) 100%);pointer-events:none;}
.hero-overlay a,.hero-overlay button,.hero-overlay .btn{pointer-events:auto;}
.hero-content{padding:34px 0}
.hero h1{margin:0 0 8px 0;color:#fff;font-size:clamp(26px,3.2vw,46px);letter-spacing:-.02em}
.hero p{margin:0 0 16px 0;color:rgba(255,255,255,.92);max-width:760px;font-size:clamp(15px,1.2vw,18px)}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.badges{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}
.badge{padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.10);color:#fff;font-weight:800;font-size:13px}
.section{padding:46px 0}
.kicker{color:var(--blue2);font-weight:900;letter-spacing:.08em;text-transform:uppercase;font-size:12px}
h2{margin:6px 0 12px 0;font-size:30px;letter-spacing:-.01em}
.lead{margin:0 0 18px 0;color:var(--muted);max-width:880px}
.grid{display:grid;gap:18px}
.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card--text{padding:26px;}
.card .pad{padding:18px}
.card h3{margin:0 0 6px 0;font-size:20px}
.card p{margin:0;color:var(--muted)}
.card img.thumb{height:220px;width:100%;object-fit:cover}
.link{margin-top:12px;display:inline-flex;font-weight:900;color:var(--blue2)}
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:22px;align-items:start}
.notice{border-left:4px solid var(--blue2);background:#eef6ff;color:#0b2a6f;padding:12px 14px;border-radius:14px}
.checks{list-style:none;margin:12px 0 0 0;padding:0}
.checks li{padding-left:26px;position:relative;margin:10px 0;font-weight:650}
.checks li::before{content:"✓";position:absolute;left:0;top:0;color:var(--blue2);font-weight:900}
.ba{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ba figure{margin:0}
.ba figcaption{font-weight:900;color:#0f172a;margin:8px 0 0 0}
.ba img{border-radius:14px;border:1px solid var(--line);height:280px;object-fit:cover;width:100%}
.footer{background:#07122a;color:#e5e7eb}
.footer a{color:#e5e7eb}
.footer-top{padding:34px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.footer h4{margin:0 0 10px 0;font-size:14px;text-transform:uppercase;letter-spacing:.08em;opacity:.9}
.small{font-size:14px;opacity:.92}
.footer-bottom{padding:14px 0;display:flex;gap:12px;flex-wrap:wrap;justify-content:space-between;align-items:center}
.mobile-toggle{display:none}
@media (max-width: 980px){
  .nav{display:none;flex-direction:column;align-items:stretch;background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px;position:absolute;top:66px;left:18px;right:18px;box-shadow:var(--shadow)}
  .nav.open{display:flex}
  .mobile-toggle{display:inline-flex}
  .cols-3{grid-template-columns:1fr}
  .cols-2{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .ba{grid-template-columns:1fr}
  .hero video,.hero img{height:min(62vh,560px)}
}



/* Header / Logo */
.brand img{
  height: 52px;
  width: auto;
  display:block;
}
.header-inner{
  align-items:center;
}
.nav a{
  padding: 10px 12px;
}
.nav a.active{
  text-decoration: none;
  border-bottom: 2px solid currentColor;
}

/* Hero slider */
.hero{ position: relative; padding: 0; }
.hero-slider{
  position: relative;
  height: min(72vh, 640px);
  overflow: hidden;
  border-radius: 18px;
  background: #000;
}
.hero-slider .slide{
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 700ms ease;
}
.hero-slider .slide.is-active{ opacity: 1; }
.hero-slider video,
.hero-slider img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:flex-end;
  padding: 28px;
  pointer-events:none;
}
.hero-content{
  pointer-events:auto;
  max-width: 720px;
  color: #fff;
  background: linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.55) 32%, rgba(0,0,0,.70) 100%);
  border-radius: 16px;
  padding: 22px;
}
.hero-content .kicker{
  font-weight: 600;
  opacity: .9;
  margin-bottom: 8px;
}
.hero-cta{ display:flex; gap:12px; flex-wrap:wrap; margin-top: 14px; }

.slider-arrow{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,.22);
  color: #fff;
  font-size: 28px;
  line-height: 44px;
  cursor: pointer;
  z-index: 5;
}
.slider-arrow:hover{ background: rgba(255,255,255,.32); }
.slider-arrow.prev{ left: 14px; }
.slider-arrow.next{ right: 14px; }

.slider-dots{
  position:absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 14px;
  display:flex;
  gap: 8px;
  z-index: 6;
}
.slider-dots .dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  border: 0;
  background: rgba(255,255,255,.45);
  cursor:pointer;
}
.slider-dots .dot.is-active{ background: rgba(255,255,255,.95); }

.video-play{
  position:absolute;
  inset:auto;
  left: 18px;
  bottom: 18px;
  z-index: 6;
  border:0;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  color:#fff;
  font-size: 22px;
  cursor:pointer;
}
.video-play:hover{ background: rgba(0,0,0,.70); }

@media (max-width: 820px){
  .hero-slider{ height: 64vh; border-radius: 14px; }
  .hero-overlay{ padding: 16px; }
  .hero-content{ padding: 16px; }
  .slider-arrow{ display:none; }
}


/* --- Overrides v3 --- */
.brand{display:flex;align-items:center;gap:14px;}
.logo{height:54px;width:auto;max-width:220px;object-fit:contain;display:block;}
.nav{align-items:center;gap:18px;flex-wrap:wrap;}
.nav a{padding:10px 0;}
.header-inner{gap:22px;}
.header-right{display:flex;align-items:center;gap:14px;}
.socials{display:flex;align-items:center;gap:10px;}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;border:1px solid rgba(0,0,0,.12);}
.socials img{width:18px;height:18px;display:block;}
.socials .icon{width:18px;height:18px;fill:var(--brand);display:block;}

.wkdb-link{display:inline-block;margin-top:12px;}
.wkdb-logo{display:block;max-width:320px;width:100%;height:auto;}
/* prevent cropping of wkdb badge image */
.badges img,.wkdb-badge img{max-height:44px;width:auto;object-fit:contain;}
/* hero slideshow */
.hero-slider{position:relative;}
.hero-slide{opacity:0;pointer-events:none;transition:opacity .7s ease;}
.hero-slide.active{opacity:1;pointer-events:auto;}
.slide-caption{position:absolute;left:24px;bottom:24px;background:rgba(0,0,0,.45);color:#fff;padding:14px 16px;border-radius:14px;font-size:clamp(18px,2.2vw,34px);font-weight:700;max-width:85%;}
.hero-slide img,.hero-slide video{object-fit:cover;}

/*
  Mobile menu visibility:
  - Desktop: inline nav
  - Mobile: hidden by default; shown only when JS toggles .open/.is-open
  (Placed AFTER overrides so it can't be overridden.)
*/
@media (min-width: 981px){
  .nav{display:flex;}
}

@media (max-width: 980px){
  .nav{display:none;}
  .nav.open, .nav.is-open{display:flex;}
}



/* Social icons (inline SVG) */
.social a, .socials a, .header-social a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(16,24,40,.12);
  background:#fff;
  color:#0b5ed7;
  text-decoration:none;
}
.social a:hover, .socials a:hover, .header-social a:hover{transform:translateY(-1px);}
.icon{width:18px;height:18px;display:block;fill:currentColor;}

/* Pills on combined services page */
.pill-nav{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;}
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(16,24,40,.12);
  background:#fff;
  color:#0f172a;
  text-decoration:none;
  font-weight:600;
}
.pill:hover{transform:translateY(-1px);}

/* Wer kennt den Besten logo: never crop */
.wkdb-badge img{width:auto;max-width:240px;height:auto;object-fit:contain;}


/* --- Service cards (Startseite) --- */
.service-card{
  display:block;
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  border-radius:18px;
  overflow:hidden;
  text-decoration:none;
  color:inherit;
  box-shadow:0 12px 30px rgba(2,8,23,.06);
  transition:transform .15s ease, box-shadow .15s ease;
}
.service-card:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 40px rgba(2,8,23,.10);
}
.service-card__media{
  height:190px;
  background:#f1f5f9;
}
.service-card__media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.service-card__body{
  padding:18px 18px 20px;
}
.service-card__body h3{
  margin:0 0 8px;
  font-size:1.15rem;
}
.service-card__body p{
  margin:0 0 12px;
  color:rgba(15,23,42,.72);
  line-height:1.45;
}
.service-card__body .link{
  color:var(--primary);
  font-weight:700;
}

/* --- Grid helper: 4 Spalten --- */
.grid.cols-4{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:22px;
}
@media (max-width: 980px){
  .grid.cols-4{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .grid.cols-4{ grid-template-columns:1fr; }
}

/* --- Footer / Header Social Icons --- */
.social-icons{
  display:flex;
  gap:10px;
  align-items:center;
}
.social-icons a{
  width:36px;height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid rgba(148,163,184,.45);
  background:rgba(255,255,255,.7);
  text-decoration:none;
}
.social-icons svg{ width:18px;height:18px; fill:currentColor; color:rgba(15,23,42,.85); }

/* Wer-kennt-den-Besten Logo: nicht abschneiden */
.wkdb-badge img{
  width:100%;
  height:auto;
  object-fit:contain;
  display:block;
}

/* AGB: mehr Innenabstand */
.legal-card{
  padding:28px;
  pointer-events:none;
}
@media (max-width:560px){
  .legal-card{ padding:20px; }
}


.wkdb-img{display:block;max-width:360px;width:100%;height:auto;max-height:120px;object-fit:contain;}

.header-social a svg{width:18px;height:18px;display:block;}

.header-social a{width:42px;height:42px;border-radius:999px;display:grid;place-items:center;border:1px solid rgba(15,23,42,.12);background:#fff;}

.hero{overflow:hidden;}
.hero .slide{position:absolute;inset:0;}
.hero .slide video,.hero .slide img{width:100%;height:100%;object-fit:cover;}

.legal{padding:0 18px;}
.legal .card{padding:26px;}
.legal p, .legal li{line-height:1.65;}


/* Ensure slider arrows are always clickable */
.hero-slider .slider-arrow{pointer-events:auto; z-index:20;}

/* Wer kennt den BESTEN logo in footer */
.wkdb-logo{display:block; width:100%; max-width:280px; height:auto; margin-top:16px;}

.legal-card{background:#fff; border:1px solid rgba(15,23,42,.08); border-radius:18px; padding:28px; box-shadow:0 14px 40px rgba(2,6,23,.06);}
.legal-card h2{margin-top:22px;}
.legal-card ul{padding-left:18px; margin:10px 0 0;}
.legal-card li{margin:6px 0;}


/* ===== Leistungen (Unternehmen & Privathaushalte) ===== */
.svc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  margin-top:18px;
}
.svc-card, .svc-grid .svc-card{
  background:#fff;
  border:1px solid rgba(10, 30, 60, .08);
  border-radius:18px;
  padding:18px;
  box-shadow:0 10px 30px rgba(10, 30, 60, .06);
}
.svc-grid .svc-card h3{
  margin:0 0 8px;
  font-size:18px;
}
.svc-grid .svc-card p{
  margin:0;
  color:rgba(20,30,50,.82);
  line-height:1.5;
}
.svc-note{
  margin-top:16px;
  background:rgba(26, 108, 255, .06);
  border:1px solid rgba(26, 108, 255, .20);
  border-radius:16px;
  padding:14px 16px;
}
.ba-wrap{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:22px;
  align-items:start;
}
.ba-images{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.ba-images figure{
  margin:0;
}
.ba-images img{
  width:100%;
  height:260px;
  object-fit:cover;
  border-radius:16px;
}
.ba-images figcaption{
  margin-top:8px;
  font-weight:600;
  color:rgba(20,30,50,.85);
}

/* Hero: smoother swap video->image */
.hero-slider .slide{
  transition:opacity .6s ease;
}

/* Legal pages: always enough padding */
.legal-card{
  padding:28px !important;
}
.legal-card h2, .legal-card h3{
  margin-left:0;
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .svc-grid{ grid-template-columns:repeat(2,1fr); }
  .ba-wrap{ grid-template-columns:1fr; }
  .ba-images img{ height:220px; }
}
@media (max-width: 620px){
  .svc-grid{ grid-template-columns:1fr; }
  .hero{ min-height: 72vh; }
  .hero .hero-content{ padding: 26px 0; }
  .hero h1{ font-size: 34px; }
  .hero p{ font-size: 16px; }
  .ba-images{ grid-template-columns:1fr; }
  .ba-images img{ height:220px; }
  footer .footer-grid{ grid-template-columns:1fr; gap:18px; }
}

.ba-section{margin-top:36px}

/* Footer: WKDB Logo */
.wkdb-logo{max-width:420px;width:100%;height:auto;object-fit:contain;}

/* Leistungen: Glasreinigung Before/After größer */
.ba-images img{height:320px;}
@media (max-width:768px){.ba-images img{height:240px;}}


/* Footer: WKDB logo clean sizing (no crop) */
.wkdb-logo{
  width: 100%;
  max-width: 260px;
  height: auto;
  object-fit: contain;
  display: block;
  margin-top: 14px;
}
.footer .wkdb-logo{ max-width: 240px; }
@media (max-width: 768px){
  .footer .wkdb-logo{ max-width: 200px; }
}

.footer-top img{height:auto;}


/* Leistungen: Glasreinigung vorher/nachher bigger */
.ba-section .ba-images img{
  height: 320px;
}
@media (max-width: 900px){
  .ba-section .ba-images img{ height: 260px; }
}


/* --- OVERRIDES (v4) --- */
.footer .wkdb-logo{
  max-width: 220px !important;
  width: 100% !important;
  height: auto !important;
  max-height: none !important;
  object-fit: contain !important;
}
.footer .footer-top .wkdb-logo{ margin-top: 12px !important; }


/* Leistungen: Glasreinigung vorher/nachher even bigger */
.ba-section .ba-images img{ height: 360px !important; }
@media (max-width: 900px){ .ba-section .ba-images img{ height: 280px !important; } }

/* ===== FINAL OVERRIDES (do not remove) ===== */
.footer .wkdb-logo{
  width: 100% !important;
  max-width: 340px !important;
  height: auto !important;
  object-fit: contain !important;
  display:block !important;
}
@media (max-width: 768px){
  .footer .wkdb-logo{ max-width: 260px !important; }
}

/* Leistungen: Glasreinigung vorher/nachher extra groß */
.ba-section .ba-images img{ height: 380px !important; }
@media (max-width: 900px){
  .ba-section .ba-images img{ height: 320px !important; }
}

/* WKDB badge: exact crop, never cut off */
.footer .wkdb-logo{
  display:block !important;
  width:100% !important;
  max-width: 420px !important;
  height:auto !important;
  object-fit: contain !important;
  background: transparent !important;
}
@media (max-width:768px){
  .footer .wkdb-logo{ max-width: 320px !important; }
}

/* Hero: always show video first; hide image slide until video ended */
.hero-slider .slide[data-type="image"]{ display:none; }
.hero-slider .slide[data-type="video"]{ display:block; }

/* WKDB: no border/background */
.footer .wkdb-logo{ background: transparent !important; border: 0 !important; box-shadow:none !important; }

/* Hero: force-hide image slide until video ended (prevent flash) */
.hero-slider .slide[data-type="image"]{ display:none !important; }
.hero-slider .slide[data-type="video"]{ display:block !important; }

.footer .wkdb-logo{ background: transparent !important; border: none !important; outline:none !important; }

.build-tag{opacity:.45;font-size:12px;margin-left:8px}

.footer img.wkdb-logo{max-height:none !important}

/* v10 hero safety */
.hero-slider .slide[data-type="video"]{display:block!important}

/* WKDB v11: place badge on white pill so no dark-edge artifact on navy background */
.footer .wkdb-wrap{
  display:inline-block;
  background:#fff;
  padding:8px 10px;
  border-radius:10px;
}
.footer .wkdb-logo{ display:block; background:transparent !important; }

/* v12 hero safety */
.hero-slider .slide[data-type="video"]{display:block!important}

/* v12 WKDB: no pill/background */
.footer .wkdb-wrap, .footer .wkdb-badge, .footer .wkdb-container { background: transparent !important; padding: 0 !important; border: 0 !important; box-shadow:none !important; border-radius:0 !important; }
.footer img.wkdb-logo{background:transparent!important; display:block; max-width: 320px; height:auto;}

/* v16 fix: ensure image slides are not hidden by legacy rules */
.hero-slider .slide{display:block !important;}
.hero-slider .slide[data-type="image"]{display:block !important;}

/* v17 hero video slider */
.hero-slider[data-hero-slider]{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  background: #000;
}
.hero-slider[data-hero-slider] .slide{
  position:absolute;
  inset:0;
  opacity:0;
  transition: opacity .5s ease;
  display:block !important;
}
.hero-slider[data-hero-slider] .slide.is-active{
  opacity:1;
  z-index:1;
}
.hero-slider[data-hero-slider] .hero-media{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.hero-arrow{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  z-index:60; pointer-events:auto;
  width:44px;
  height:44px;
  border-radius:999px;
  border:0;
  background: rgba(0,0,0,.45);
  color:#fff;
  font-size:28px;
  line-height:44px;
  cursor:pointer;
  user-select:none;
  backdrop-filter: blur(6px);
}
.hero-arrow--prev{ left:14px; }
.hero-arrow--next{ right:14px; }
@media (max-width: 640px){
  .hero-arrow{ width:40px; height:40px; line-height:40px; font-size:26px; }
  .hero-arrow--prev{ left:10px; }
  .hero-arrow--next{ right:10px; }
}


/* v19: soft white veil over hero video to reduce visible compression artifacts */
.hero-slider .slide[data-type="video"]{
  position: relative;
}
.hero-slider .slide[data-type="video"]::before{
  content:"";
  position:absolute;
  inset:0;
  background: rgba(255,255,255,0.24);
  pointer-events:none;
  z-index:2;
}
/* keep text card above veil */
.hero-content{ position: relative; z-index:3; }
/* ensure video below veil */
.hero-slider .slide[data-type="video"] video{ position: relative; z-index:1; }


/* ===== HERO FIXES (v33) ===== */
.hero-media video{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  pointer-events:none !important;
}
/* Hide native controls overlays (Safari/iOS) */
.hero-media video::-webkit-media-controls,
.hero-media video::-webkit-media-controls-enclosure,
.hero-media video::-webkit-media-controls-panel{
  display:none !important;
  opacity:0 !important;
}

/* Make overlay readable but not massive on mobile */
.hero-overlay{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:28px;
  pointer-events:none;
}
.hero-content{
  background:rgba(0,0,0,.55);
  border-radius:22px;
  padding:26px 26px;
  max-width:760px;
  width:100%;
  box-shadow:0 18px 45px rgba(0,0,0,.25);
  pointer-events:auto;
}
.hero-content h1{
  font-size:48px;
  line-height:1.06;
}
.hero-content p{
  font-size:18px;
  line-height:1.45;
}

@media (max-width: 900px){
  .hero-content h1{ font-size:40px; }
}

@media (max-width: 720px){
  .hero-overlay{ align-items:flex-end; padding:14px; }
  .hero-content{
    padding:16px 16px;
    border-radius:18px;
    background:rgba(0,0,0,.45);
    max-width:100%;
  }
  .hero-content h1{ font-size:32px; }
  .hero-content p{ font-size:16px; }
  .hero-content .btn{ width:100%; }
}

@media (max-width: 420px){
  .hero-content h1{ font-size:28px; }
}


/* V39_ARROW_FIX: ensure arrows are always clickable */
.hero-arrow{ z-index: 60; pointer-events: auto; }
.hero-slider{ position: relative; }
