/* ============================================================
   MK Mahr Konzept
   styles.css – vollständig responsive (alle Geräte + Landscape)
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-soft:#f7f8fa;
  --panel:#ffffffcc;
  --text:#111111;
  --muted:#6e6e73;
  --soft:#8f8f95;
  --line:#e8e8ed;
  --accent:#00AEEF;
  --accent-soft:rgba(0,174,239,.16);
  --shadow:0 20px 60px rgba(17,17,17,.08);
  --shadow-strong:0 32px 90px rgba(17,17,17,.12);
  --max:1180px;
  --radius:28px;
  --ease:cubic-bezier(.22,1,.36,1);
  --nav-h:82px;
}

/* ── Reset ──────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:linear-gradient(180deg,#ffffff 0%,#f8f9fb 52%,#ffffff 100%);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button,input,textarea{font:inherit}

/* ── Accessibility ──────────────────────────────────────── */
.skip-link{position:absolute;left:16px;top:-48px;z-index:1001;padding:12px 16px;border-radius:999px;background:#111111;color:#ffffff;transition:top .2s ease}
.skip-link:focus{top:16px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:2px solid rgba(0,174,239,.45);outline-offset:2px}

/* ── Progress bar ───────────────────────────────────────── */
.progress{position:fixed;top:0;left:0;height:3px;width:var(--scroll,0%);background:linear-gradient(90deg,var(--accent),#7ddcff);z-index:999;box-shadow:0 0 24px rgba(0,174,239,.35)}

/* ── Background decoration ──────────────────────────────── */
.bg-orb,.bg-orb::after{position:fixed;border-radius:50%;pointer-events:none;filter:blur(50px);z-index:-2}
.bg-orb.one{width:520px;height:520px;top:-120px;right:-120px;background:radial-gradient(circle, rgba(0,174,239,.18), transparent 68%);animation:floatA 16s var(--ease) infinite alternate}
.bg-orb.two{width:420px;height:420px;left:-120px;bottom:-120px;background:radial-gradient(circle, rgba(113,113,122,.10), transparent 68%);animation:floatB 18s var(--ease) infinite alternate}
.bg-grid{position:fixed;inset:0;z-index:-3;pointer-events:none;opacity:.35;background-image:linear-gradient(rgba(17,17,17,.03) 1px, transparent 1px),linear-gradient(90deg, rgba(17,17,17,.03) 1px, transparent 1px);background-size:48px 48px;mask-image:linear-gradient(180deg, rgba(0,0,0,.8), transparent 75%)}

/* ── Layout ─────────────────────────────────────────────── */
.wrapper{max-width:var(--max);margin:auto;padding:0 24px}
.site-shell{position:relative}

/* ── Header & Navigation ────────────────────────────────── */
header{position:sticky;top:0;z-index:100;backdrop-filter:saturate(160%) blur(18px);-webkit-backdrop-filter:saturate(160%) blur(18px);background:rgba(255,255,255,.76);border-bottom:1px solid rgba(17,17,17,.05)}
.header-inner{display:flex;justify-content:space-between;align-items:center;height:var(--nav-h)}
.logo{height:100px;filter:drop-shadow(0 4px 14px rgba(0,0,0,.06));transform:translateZ(0)}

/* Desktop nav */
nav{display:flex;align-items:center;gap:8px}
nav a{font-size:14px;color:var(--muted);padding:12px 16px;border-radius:999px;transition:transform .3s var(--ease),color .3s var(--ease),background-color .3s var(--ease),box-shadow .3s var(--ease)}
nav a:hover{color:#000;background:#fff;box-shadow:var(--shadow);transform:translateY(-1px)}

/* Hamburger – hidden on desktop */
.nav-toggle{display:none;width:44px;height:44px;border:1px solid rgba(17,17,17,.08);border-radius:999px;background:#fff;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;box-shadow:var(--shadow)}
.nav-toggle span{display:block;width:18px;height:2px;border-radius:2px;background:var(--text);transition:transform .3s var(--ease),opacity .3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Hero ───────────────────────────────────────────────── */
.hero{
  position:relative;
  /* svh = small viewport height – korrekt auf Mobile/Landscape */
  min-height:100svh;
  min-height:100vh; /* Fallback */
  display:grid;
  align-items:center;
  padding:0px 0 140px;
}
.hero-inner{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);gap:36px;align-items:center}
.hero-copy{max-width:760px;overflow:visible}

.eyebrow{display:inline-flex;align-items:center;gap:10px;min-height:42px;padding:0 16px;border-radius:999px;background:rgba(255,255,255,.82);border:1px solid rgba(17,17,17,.06);box-shadow:var(--shadow);color:var(--muted);font-size:14px;transform:translateY(18px);opacity:0;animation:riseIn .95s .15s var(--ease) forwards}
.eyebrow-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 8px rgba(0,174,239,.10),0 0 18px rgba(0,174,239,.28);animation:pulse 2.8s ease infinite}

.status-dot{width:10px;height:10px;border-radius:50%;background:#1db954;position:relative;flex:0 0 auto}
.status-dot::after{content:"";position:absolute;inset:0;border-radius:50%;background:#1db954;opacity:.42;animation:statusPulse 2s ease-out infinite}
.status-note{display:inline-flex;align-items:center;gap:10px;margin-top:18px;padding:10px 18px;border-radius:999px;background:rgba(248,249,251,.9);border:1px solid rgba(17,17,17,.06);box-shadow:var(--shadow);font-size:14px;color:var(--muted)}

.hero h1{margin-top:22px;font-size:clamp(40px,7vw,110px);letter-spacing:-.055em;line-height:.96;font-weight:650;max-width:12ch;overflow:visible;transform:translateY(24px);opacity:0;animation:riseIn 1.05s .28s var(--ease) forwards}
.hero .accent-line{display:block;}
.hero p{margin-top:28px;max-width:660px;font-size:clamp(17px,2vw,25px);color:var(--muted);letter-spacing:-.02em;transform:translateY(24px);opacity:0;animation:riseIn 1.05s .42s var(--ease) forwards}

.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px;transform:translateY(20px);opacity:0;animation:riseIn 1s .58s var(--ease) forwards}

/* ── CTA Buttons ────────────────────────────────────────── */
.cta,.cta-secondary,button{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;min-height:56px;padding:0 28px;border-radius:999px;transition:transform .35s var(--ease), box-shadow .35s var(--ease), background-color .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease)}
.cta{background:linear-gradient(180deg,#1bc2ff,#00AEEF);color:#fff;box-shadow:0 16px 42px rgba(0,174,239,.28)}
.cta::before,.cta-secondary::before,button::before{content:"";position:absolute;inset:-40% auto -40% -120%;width:70%;transform:skewX(-20deg);background:linear-gradient(90deg, transparent, rgba(255,255,255,.55), transparent);transition:transform .8s var(--ease)}
.cta:hover,button:hover{transform:translateY(-3px) scale(1.01);box-shadow:0 22px 56px rgba(0,174,239,.34)}
.cta:hover::before,.cta-secondary:hover::before,button:hover::before{transform:translateX(320%) skewX(-20deg)}
.cta-secondary{background:#fff;border:1px solid rgba(17,17,17,.08);color:var(--text);box-shadow:var(--shadow)}
.cta-secondary:hover{transform:translateY(-3px);box-shadow:var(--shadow-strong)}

/* ── Hero Visual ────────────────────────────────────────── */
.hero-visual{position:relative;min-height:560px;perspective:1400px;opacity:0;transform:translateY(30px);animation:riseIn .9s 0s var(--ease) forwards}
.visual-panel{position:absolute;inset:0;border-radius:36px;background:linear-gradient(180deg, rgba(255,255,255,.88), rgba(248,249,251,.82));border:1px solid rgba(17,17,17,.06);box-shadow:var(--shadow-strong);overflow:hidden;transform:rotateY(-10deg) rotateX(6deg) translateZ(0);transition:transform .7s var(--ease), box-shadow .7s var(--ease)}
.hero-visual:hover .visual-panel{transform:rotateY(-6deg) rotateX(3deg) translateY(-8px)}
.visual-panel::before{content:"";position:absolute;inset:0;background:radial-gradient(560px 260px at 70% 20%, rgba(0,174,239,.18), transparent 62%),linear-gradient(180deg, rgba(255,255,255,.55), transparent 30%)}
.visual-top{position:absolute;top:0;left:0;right:0;height:76px;display:flex;align-items:center;justify-content:space-between;padding:0 28px;border-bottom:1px solid rgba(17,17,17,.06);color:var(--soft);font-size:13px;letter-spacing:.12em;text-transform:uppercase}
.visual-center{position:absolute;inset:76px 0 0 0;padding:34px}

.floating-card{position:absolute;border-radius:28px;background:rgba(255,255,255,.82);border:1px solid rgba(17,17,17,.06);box-shadow:var(--shadow);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.floating-card.a{top:34px;left:36px;width:58%;padding:24px;animation:floatCard 7s 0s var(--ease) infinite alternate}
.floating-card.b{right:32px;top:132px;width:34%;padding:22px;animation:floatCard 8s 0s var(--ease) infinite alternate}
.floating-card.c{left:74px;bottom:34px;width:48%;padding:22px;animation:floatCard 9s 0s var(--ease) infinite alternate}

.card-label{font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--soft)}
.card-title{margin-top:14px;font-size:32px;line-height:1.02;letter-spacing:-.05em;font-weight:620}
.card-copy{margin-top:12px;color:var(--muted);font-size:15px;line-height:1.72}
.card-line{height:9px;border-radius:999px;background:linear-gradient(90deg, rgba(17,17,17,.08), rgba(0,174,239,.18));margin-top:14px}
.card-line.small{width:56%}
.card-line.medium{width:74%}
.card-line.full{width:100%}

.orbit{position:absolute;border-radius:50%;border:1px solid rgba(0,174,239,.16);inset:auto}
.orbit.one{width:340px;height:340px;right:-80px;bottom:-90px;animation:spin 26s linear infinite}
.orbit.two{width:210px;height:210px;left:-60px;top:110px;animation:spin 18s linear infinite reverse}

/* ── Sections ───────────────────────────────────────────── */
.section{padding:140px 0;border-top:1px solid var(--line)}
.section-head{max-width:760px;margin-bottom:54px}
.kicker{font-size:13px;text-transform:uppercase;letter-spacing:.18em;color:var(--soft)}
.section h2{margin-top:18px;font-size:clamp(34px,5vw,76px);letter-spacing:-.05em;line-height:.96;font-weight:650}
.section-copy{margin-top:22px;max-width:720px;color:var(--muted);font-size:clamp(17px,2vw,21px);letter-spacing:-.02em}

.services{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:54px}
.service{position:relative;padding:30px;border-radius:var(--radius);background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(248,249,251,.86));border:1px solid rgba(17,17,17,.06);box-shadow:var(--shadow);transition:transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);transform-style:preserve-3d}
.service:hover{transform:translateY(-10px) rotateX(4deg);box-shadow:var(--shadow-strong);border-color:rgba(0,174,239,.18)}
.service-index{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--soft)}
.service h3{margin-top:16px;font-size:28px;letter-spacing:-.04em;line-height:1.04;color:#000}
.service p{margin-top:14px;font-size:17px;color:var(--muted)}
.service::after{content:"";position:absolute;inset:auto 20px 18px 20px;height:1px;background:linear-gradient(90deg, rgba(17,19,24,.08), rgba(0,174,239,.25), transparent)}

/* ── Contact ────────────────────────────────────────────── */
.contact{display:grid;grid-template-columns:1fr 1.08fr;gap:24px;margin-top:54px}
.contact-card,.form-card{position:relative;padding:32px;border-radius:32px;background:linear-gradient(180deg, rgba(255,255,255,.84), rgba(248,249,251,.88));border:1px solid rgba(17,19,24,.06);box-shadow:var(--shadow)}
.contact-list{display:grid;gap:14px}
.contact-item{padding:18px 20px;border-radius:22px;background:#fff;border:1px solid rgba(17,19,24,.06);transition:transform .35s var(--ease), box-shadow .35s var(--ease)}
.contact-item:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.contact-label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.16em;color:var(--soft)}
.contact-value{display:block;margin-top:8px;font-size:18px;color:var(--text);letter-spacing:-.02em;word-break:break-word}
.contact-value a{color:var(--accent);transition:opacity .2s ease}
.contact-value a:hover{opacity:.75}
.legal{margin-top:28px;padding-top:24px;border-top:1px solid var(--line);font-size:15px;color:var(--muted)}

/* ── Form ───────────────────────────────────────────────── */
.field-row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
label{display:block;margin-bottom:6px;font-size:14px;color:var(--muted)}
.field,textarea{width:100%;padding:16px 18px;margin-bottom:14px;border-radius:18px;background:#fff;border:1px solid #e4e4e7;color:#000;font-size:15px;transition:border-color .3s var(--ease), box-shadow .3s var(--ease), transform .3s var(--ease)}
.field:focus,textarea:focus{outline:none;border-color:rgba(0,174,239,.36);box-shadow:0 0 0 4px rgba(0,174,239,.10);transform:translateY(-1px)}
textarea{min-height:170px;resize:vertical}
.form-note{margin:4px 0 18px;color:var(--muted);font-size:15px}
button{border:none;background:linear-gradient(180deg,#1bc2ff,#00AEEF);color:#fff;box-shadow:0 16px 42px rgba(0,174,239,.28);cursor:pointer}

/* ── Footer ─────────────────────────────────────────────── */
footer{padding:52px 0 74px;border-top:1px solid var(--line);color:var(--muted);font-size:14px}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a{transition:color .25s ease}
.footer-links a:hover{color:#000}

/* ── Reveal animations ──────────────────────────────────── */
.reveal{opacity:0;transform:translateY(36px) scale(.985);transition:opacity .95s var(--ease), transform .95s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0) scale(1)}
.delay-1{transition-delay:.08s}
.delay-2{transition-delay:.16s}
.delay-3{transition-delay:.24s}

/* ── Modal ──────────────────────────────────────────────── */
.modal-backdrop{position:fixed;inset:0;background:rgba(17,19,24,.32);backdrop-filter:blur(10px) saturate(140%);-webkit-backdrop-filter:blur(10px) saturate(140%);opacity:0;visibility:hidden;transition:opacity .28s var(--ease), visibility .28s var(--ease);z-index:220}
.modal-backdrop.is-open{opacity:1;visibility:visible}
.modal{
  position:fixed;
  left:50%;
  top:50%;
  width:min(760px, calc(100% - 24px));
  max-height:min(82vh, 900px);
  /* Landscape: mehr Höhe nutzen */
  max-height:min(82dvh, 900px);
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  transform:translate(-50%, calc(-50% + 16px)) scale(.985);
  opacity:0;
  visibility:hidden;
  border-radius:32px;
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(248,249,251,.98));
  border:1px solid rgba(17,19,24,.08);
  box-shadow:0 36px 120px rgba(17,19,24,.18);
  z-index:230;
  transition:transform .32s var(--ease), opacity .32s var(--ease), visibility .32s var(--ease)
}
.modal.is-open{opacity:1;visibility:visible;transform:translate(-50%, -50%) scale(1)}
.modal-header{position:sticky;top:0;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 24px;background:rgba(255,255,255,.82);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border-bottom:1px solid rgba(17,19,24,.06)}
.modal-title-wrap{display:grid;gap:6px}
.modal-kicker{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--soft)}
.modal-title{font-size:34px;line-height:1;letter-spacing:-.04em;font-weight:650}
.modal-close{width:44px;height:44px;border-radius:999px;border:1px solid rgba(17,19,24,.08);background:#fff;color:var(--text);box-shadow:var(--shadow);cursor:pointer}
.modal-close:hover,.modal-close:focus-visible{transform:translateY(-1px)}
.modal-body{padding:24px}
.modal-stack{display:grid;gap:14px}
.modal-panel{padding:18px 20px;border-radius:22px;background:#fff;border:1px solid rgba(17,19,24,.06)}
.modal-panel h3{margin:0 0 8px 0;font-size:18px;line-height:1.2;letter-spacing:-.02em}
.modal-panel p,.modal-panel ul{margin:0;color:var(--muted);font-size:15px;line-height:1.75}
.modal-panel ul{padding-left:18px}
body.modal-open{overflow:hidden;touch-action:none}

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

   Strategie (mobile-first ergänzend):
   – 1200px  Large Desktop
   – 1020px  Tablet Landscape / kleines Desktop
   –  860px  Tablet Portrait
   –  680px  Großes Phone / kleines Tablet
   –  480px  Standard Phone Portrait
   –  360px  Kleine Phones (Galaxy S-Klasse)

   Orientation:
   – landscape + max-height:500px  Phone Landscape
   ============================================================ */

/* ── 1200px: Large Desktop ──────────────────────────────── */
@media(min-width:1200px){
  .hero{padding:0px 0 140px}
  .hero h1{font-size:clamp(80px,8vw,110px)}
}

/* ── 1020px: Tablet Landscape / kleines Desktop ─────────── */
@media(max-width:1020px){
  .hero-inner,.contact{grid-template-columns:1fr}
  .hero-visual{min-height:440px}
  /* Visual Panel flach stellen – kein 3D auf einspaltig */
  .visual-panel{transform:none}
  .hero-visual:hover .visual-panel{transform:translateY(-6px)}
}

/* ── 860px: Tablet Portrait (iPad) ─────────────────────── */
@media(max-width:860px){
  :root{--nav-h:72px}
  .services{grid-template-columns:repeat(2,1fr)}
  .hero{padding:0px 0 96px}
  .section{padding:96px 0}
  .floating-card.a{width:68%;top:28px;left:28px}
  .floating-card.b{width:40%;top:140px;right:24px}
  .floating-card.c{width:56%;bottom:28px;left:40px}
  .card-title{font-size:26px}
  /* Kontaktformular: Name+Email nebeneinander bleibt nur wenn Platz da */
  .contact{grid-template-columns:1fr}
  .field-row{grid-template-columns:repeat(2,1fr)}
}

/* ── 680px: Großes Phone / kleines Tablet ───────────────── */
@media(max-width:680px){
  .wrapper{padding:0 18px}
  .nav-toggle{display:inline-flex}
  /* Mobile nav drawer */
  nav{
    display:none;
    position:fixed;
    inset:var(--nav-h) 0 auto 0;
    flex-direction:column;
    align-items:stretch;
    gap:6px;
    padding:16px 18px 24px;
    background:rgba(255,255,255,.96);
    backdrop-filter:blur(20px) saturate(160%);
    -webkit-backdrop-filter:blur(20px) saturate(160%);
    border-bottom:1px solid rgba(17,17,17,.06);
    box-shadow:0 24px 60px rgba(17,17,17,.10);
    z-index:99;
  }
  nav.is-open{display:flex}
  nav a{
    padding:14px 18px;
    border-radius:16px;
    font-size:16px;
    color:var(--text);
  }
  nav a:hover{background:rgba(0,174,239,.06);color:var(--accent);box-shadow:none;transform:none}
  .services{grid-template-columns:1fr}
  .hero-visual{min-height:360px}
  .hero-actions{flex-direction:column;align-items:stretch}
  .cta,.cta-secondary,button{width:100%}
  .contact-card,.form-card,.service{padding:24px}
  .field-row{grid-template-columns:1fr}
  .modal-title{font-size:28px}
  .modal-header{padding:16px 18px}
  .modal-body{padding:16px}
}

/* ── 480px: Standard Phone Portrait ────────────────────── */
@media(max-width:480px){
  .hero{padding:0px 0 72px;min-height:auto}
  .hero h1{font-size:clamp(36px,11vw,52px)}
  .hero p{font-size:16px;margin-top:18px}
  .hero-actions{margin-top:24px}
  .hero-visual{min-height:300px}
  /* Karten vereinfachen: nur Karte A sichtbar, B+C verstecken */
  .floating-card.b,.floating-card.c{display:none}
  .floating-card.a{
    position:relative;top:auto;left:auto;right:auto;bottom:auto;
    width:100%;
    margin:20px 0 0 0;
    animation:none;
  }
  .visual-center{padding:16px}
  .orbit{display:none}
  .section{padding:72px 0}
  .section h2{font-size:clamp(30px,8vw,44px)}
  .section-copy{font-size:16px}
  .service h3{font-size:22px}
  .contact-card,.form-card{padding:20px;border-radius:24px}
  .contact-value{font-size:16px}
  footer{padding:36px 0 52px}
  .modal{border-radius:20px;width:calc(100% - 16px)}
}

/* ── 360px: Kleine Phones ───────────────────────────────── */
@media(max-width:360px){
  .hero h1{font-size:32px}
  .hero p{font-size:15px}
  .eyebrow{font-size:12px;padding:0 12px}
  .kicker{font-size:11px}
  .section h2{font-size:28px}
  .service{padding:20px}
  .service h3{font-size:20px}
  .cta,.cta-secondary,button{min-height:50px;font-size:14px}
}

/* ── Phone Landscape (Höhe ≤ 500px) ────────────────────── */
@media(orientation:landscape) and (max-height:500px){
  :root{--nav-h:56px}
  .hero{
    min-height:auto;
    padding:24px 0 48px;
    align-items:start;
    padding-top:calc(var(--nav-h) + 24px);
  }
  .hero-inner{
    grid-template-columns:1fr 1fr;
    gap:24px;
    align-items:start;
  }
  .hero h1{
    font-size:clamp(28px,6vh,44px);
    margin-top:12px;
  }
  .hero p{
    font-size:14px;
    margin-top:12px;
  }
  .hero-actions{
    margin-top:16px;
    gap:10px;
  }
  .cta,.cta-secondary,button{min-height:44px;padding:0 20px;font-size:14px}
  .hero-visual{min-height:220px}
  .floating-card.b,.floating-card.c{display:none}
  .floating-card.a{
    top:16px;left:16px;width:80%;
    padding:14px;
  }
  .card-title{font-size:18px}
  .orbit{display:none}
  .eyebrow{font-size:12px;padding:0 12px;min-height:34px}
  .section{padding:56px 0}
  .services{grid-template-columns:repeat(3,1fr)}
  .contact{grid-template-columns:1fr 1fr}
  .field-row{grid-template-columns:repeat(2,1fr)}
  /* Modal: im Landscape mehr Breite, weniger Höhe */
  .modal{
    width:min(90vw, 760px);
    max-height:90dvh;
    max-height:90vh;
    top:50%;
  }
  .modal-title{font-size:22px}
  .modal-header{padding:12px 16px}
  .modal-body{padding:12px 16px}
  .modal-panel{padding:12px 16px}
}

/* ── Tablet Landscape ───────────────────────────────────── */
@media(orientation:landscape) and (min-height:501px) and (max-width:1020px){
  .hero-inner{grid-template-columns:1fr 1fr;align-items:center}
  .hero-visual{min-height:400px}
  .services{grid-template-columns:repeat(3,1fr)}
  .contact{grid-template-columns:1fr 1fr}
}

/* ── prefers-reduced-motion ─────────────────────────────── */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ── Keyframes ──────────────────────────────────────────── */
@keyframes riseIn{to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}
@keyframes shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
@keyframes floatA{from{transform:translate3d(0,0,0)}to{transform:translate3d(-30px,28px,0)}}
@keyframes floatB{from{transform:translate3d(0,0,0)}to{transform:translate3d(24px,-34px,0)}}
@keyframes floatCard{
  from{transform:translateY(0px)}
  to{transform:translateY(-16px)}
}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
@keyframes statusPulse{0%{transform:scale(1);box-shadow:0 0 0 0 rgba(29,185,84,.36)}70%{transform:scale(1.08);box-shadow:0 0 0 12px rgba(29,185,84,0)}100%{transform:scale(1);box-shadow:0 0 0 0 rgba(29,185,84,0)}}

/* ============================================================
   OPTIMIERUNGEN v3 – sauber, keine zirkulären Variablen
   ============================================================ */

/* Scrollspy aktive Nav */
#nav-menu a.is-active {
  color: #000;
  background: #fff;
  box-shadow: 0 20px 60px rgba(17,17,17,.08);
}

/* Select-Feld konsistent mit .field */
select.field {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236e6e73' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 18px center;
  padding-right: 44px;
  cursor: pointer;
}

/* Service Marker – ersetzt Nummern */
.service-marker {
  display: inline-block;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(135deg, #00AEEF, #7ddcff);
  padding: 4px 12px;
  border-radius: 999px;
  margin-bottom: 18px;
  box-shadow: 0 4px 14px rgba(0,174,239,.22);
}

/* Vertrauen-Checkmarks */
#vertrauen .service-marker {
  background: linear-gradient(135deg, #00AEEF, #7ddcff);
}

/* FAQ 6 Cards: 3+3 Grid */
#faq .services {
  grid-template-columns: repeat(3, 1fr);
}
@media(max-width: 860px) {
  #faq .services { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width: 680px) {
  #faq .services { grid-template-columns: 1fr; }
}

/* ============================================================
   RESPONSIVE FIXES – alle gefundenen Probleme
   ============================================================ */

/* Fix 1: Logo-Höhe auf Mobile – Header ist 72px, Logo darf nicht rausragen */
@media(max-width:680px){
  .logo{ height:52px }
}
@media(max-width:360px){
  .logo{ height:44px }
}

/* Fix 2: Safe-Area-Insets für iPhone Notch / Dynamic Island */
header {
  padding-left: env(safe-area-inset-left, 0px);
  padding-right: env(safe-area-inset-right, 0px);
}
.wrapper {
  padding-left: max(24px, env(safe-area-inset-left, 0px));
  padding-right: max(24px, env(safe-area-inset-right, 0px));
}
@media(max-width:680px){
  .wrapper {
    padding-left: max(18px, env(safe-area-inset-left, 0px));
    padding-right: max(18px, env(safe-area-inset-right, 0px));
  }
}
/* Footer Safe Area */
footer {
  padding-bottom: max(74px, calc(52px + env(safe-area-inset-bottom, 0px)));
}

/* Fix 3: service-marker in Phone Landscape verkleinern */
@media(orientation:landscape) and (max-height:500px){
  .service-marker {
    font-size: 10px;
    padding: 3px 9px;
    margin-bottom: 10px;
  }
  .service h3 { margin-top: 8px; }
}

/* Fix 4: hero-visual min-height in Landscape etwas mehr Luft */
@media(orientation:landscape) and (max-height:500px){
  .hero-visual{ min-height: 260px }
  .floating-card.a{ padding: 12px }
  .card-title{ font-size: 16px }
}

/* Fix 5: kicker bei 360px nicht unter 12px */
@media(max-width:360px){
  .kicker{ font-size: 12px }
}

/* Fix 6: contact-card + form-card auf 680px sicher 1-spaltig */
@media(max-width:680px){
  .contact{ grid-template-columns: 1fr !important }
}

/* Fix 7: Unsere hinzugefügten CTA-Divs zwischen Sections */
@media(max-width:680px){
  .section > .wrapper > div[style*="text-align:center"],
  .section > .wrapper > div[style*="text-align: center"] {
    margin-top: 2rem;
  }
}

/* ============================================================
   FEATURES 1–8 — Design & Interaktion 2026
   ============================================================ */

/* ── 1. SCROLL-TRIGGERED REVEALS — gestaffelt ─────────────── */
.reveal { transition-delay: 0ms }
.reveal.delay-1 { transition-delay: 80ms }
.reveal.delay-2 { transition-delay: 160ms }
.reveal.delay-3 { transition-delay: 240ms }
/* Sanftere, längere Reveal-Kurve */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1);
}
.reveal.visible {
  opacity: 1;
  transform: none;
}
/* Service cards gestaffelt innerhalb Grid */
.services .service:nth-child(1) { transition-delay: 0ms }
.services .service:nth-child(2) { transition-delay: 90ms }
.services .service:nth-child(3) { transition-delay: 180ms }
.services .service:nth-child(4) { transition-delay: 60ms }
.services .service:nth-child(5) { transition-delay: 150ms }
.services .service:nth-child(6) { transition-delay: 240ms }

/* ── 2. KINETIC TYPOGRAPHY ─────────────────────────────────── */

/* ── 3. CUSTOM CURSOR ──────────────────────────────────────── */
@media (hover: hover) and (pointer: fine) {
  html, body { cursor: none }
  a, button, [role="button"], .magnetic, .service, .faq-question,
  select, input, textarea, label { cursor: none }
}
#mk-cursor {
  position: fixed;
  top: -100px; left: -100px;
  width: 10px; height: 10px;
  background: var(--accent);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: transform .08s linear, width .25s var(--ease), height .25s var(--ease), background .25s var(--ease), opacity .3s;
  will-change: transform;
  opacity: 0;
  display: none;
}
#mk-cursor-ring {
  position: fixed;
  top: -100px; left: -100px;
  width: 36px; height: 36px;
  border: 1.5px solid rgba(0,174,239,.35);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  transition: transform .18s cubic-bezier(.22,1,.36,1), width .3s var(--ease), height .3s var(--ease), border-color .25s, opacity .3s;
  will-change: transform;
  opacity: 0;
  display: none;
}
/* Hover-State */
#mk-cursor.hover  { width: 6px; height: 6px; background: var(--accent) }
#mk-cursor-ring.hover { width: 52px; height: 52px; border-color: rgba(0,174,239,.55) }
/* Click-State */
#mk-cursor.click  { width: 14px; height: 14px }
#mk-cursor-ring.click { width: 28px; height: 28px }
/* Text-Hover: dünner Ring, keine Dot */
#mk-cursor.text   { width: 3px; height: 22px; border-radius: 2px; background: var(--accent) }
/* Hidden on touch */
@media (hover: none) {
  #mk-cursor, #mk-cursor-ring { display: none }
}

/* ── 4. GLASSMORPHISM — Hero-Cards verfeinert ──────────────── */
.floating-card {
  background: rgba(255,255,255,.78) !important;
  backdrop-filter: blur(20px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(20px) saturate(1.4) !important;
  border: 1px solid rgba(255,255,255,.65) !important;
  box-shadow: 0 8px 32px rgba(17,17,17,.08), inset 0 1px 0 rgba(255,255,255,.9) !important;
}
/* Visual panel: leichter Glas-Hintergrund */
.visual-panel {
  background: rgba(248,249,251,.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.6);
  transform: rotateY(-10deg) rotateX(6deg) translateZ(0);
}
/* Service-Cards: subtiler Glas-Hover */
.service {
  transition: background .3s var(--ease), border-color .3s var(--ease),
              transform .35s var(--ease), box-shadow .35s var(--ease);
}
.service:hover {
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(17,17,17,.09);
}

/* ── 5. SECTION-DOT-NAVIGATION ────────────────────────────── */
#section-nav {
  position: fixed;
  right: 22px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 80;
  opacity: 0;
  transition: opacity .4s var(--ease);
}
#section-nav.visible { opacity: 1 }
#section-nav .snav-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: rgba(17,17,17,.18);
  border: none;
  padding: 0;
  cursor: none;
  transition: background .3s var(--ease), transform .3s var(--ease);
  position: relative;
}
#section-nav .snav-dot::after {
  content: attr(data-label);
  position: absolute;
  right: 18px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 11px;
  letter-spacing: .08em;
  white-space: nowrap;
  color: var(--muted);
  opacity: 0;
  transition: opacity .2s var(--ease);
  pointer-events: none;
  font-family: var(--sans, sans-serif);
}
#section-nav .snav-dot:hover::after,
#section-nav .snav-dot.active::after { opacity: 1 }
#section-nav .snav-dot.active {
  background: var(--accent);
  transform: scale(1.4);
}
#section-nav .snav-dot:hover { background: rgba(0,174,239,.5) }
@media(max-width:860px) { #section-nav { display: none } }

/* ── 6. BENTO GRID — Leistungen ───────────────────────────── */
.services.bento {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 16px;
}
.services.bento .service:nth-child(1) {
  grid-row: span 2;
  background: linear-gradient(160deg, rgba(0,174,239,.06) 0%, rgba(255,255,255,0) 60%);
  border-color: rgba(0,174,239,.14);
}
.services.bento .service:nth-child(1) .service-marker {
  margin-bottom: 24px;
}
@media(max-width:860px) {
  .services.bento { grid-template-columns: repeat(2,1fr) }
  .services.bento .service:nth-child(1) { grid-row: span 1 }
}
@media(max-width:680px) {
  .services.bento { grid-template-columns: 1fr }
}

/* ══════════════════════════════════════════════════════════
   DARK MODE — erstklassig
   Kontrast-System (WCAG AA):
   Primary Text  #edeef1 → 14.8:1 auf #13151a
   Secondary     #a8adb8 →  8.4:1 auf #13151a
   Tertiary      #636878 →  4.6:1 auf #13151a
   Accent Blue   #00AEEF →  7.0:1 auf #13151a
   ══════════════════════════════════════════════════════════ */

/* ── Basis-Variablen ──────────────────────────────────────── */
body.dark-mode {
  --bg:          #13151a;
  --bg-soft:     #1d2028;
  --text:        #edeef1;
  --muted:       #a8adb8;
  --soft:        #636878;
  --line:        rgba(255,255,255,.07);
  --shadow:      0 20px 60px rgba(0,0,0,.5);
  --shadow-strong: 0 32px 90px rgba(0,0,0,.65);
  color-scheme:  dark;
  background:    #13151a;
  color:         #edeef1;
}

/* ── Header: hell bleiben — Logo bleibt sichtbar ─────────── */
body.dark-mode header {
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(20px) saturate(1.8);
  -webkit-backdrop-filter: blur(20px) saturate(1.8);
  border-bottom: 1px solid rgba(17,17,17,.08);
}
body.dark-mode .logo { filter: none }
body.dark-mode .nav-toggle span { background: #111 }
body.dark-mode nav a { color: rgba(17,17,17,.55); background: transparent }
body.dark-mode nav a:hover { color: #111; background: rgba(17,17,17,.06) }
body.dark-mode nav a.is-active { color: #111; background: rgba(17,17,17,.07) }
body.dark-mode #dark-toggle { border-color: rgba(17,17,17,.15); color: rgba(17,17,17,.5) }
body.dark-mode #dark-toggle:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,174,239,.06) }

/* ── Hintergrund & Grid ───────────────────────────────────── */
body.dark-mode .bg-grid { opacity: .4 }
body.dark-mode .bg-orb  { opacity: .18 }

/* ── Typografie ───────────────────────────────────────────── */
body.dark-mode h1,
body.dark-mode h2,
body.dark-mode h3       { color: #edeef1 }
body.dark-mode p        { color: #a8adb8 }
body.dark-mode .kicker  { color: #8a8f9e }
body.dark-mode .section-copy { color: #a8adb8 }
body.dark-mode .hero-copy > p { color: #a8adb8 }

/* accent-line (Kunden bringen.) bleibt blau — kein Override */

/* ── Hero ─────────────────────────────────────────────────── */
body.dark-mode .eyebrow {
  background: rgba(255,255,255,.06);
  border-color: rgba(0,174,239,.22);
  color: #a8adb8;
}
body.dark-mode .eyebrow-dot { background: var(--accent) }
body.dark-mode .status-note {
  background: rgba(255,255,255,.05);
  border-color: rgba(29,185,84,.22);
  color: #a8adb8;
}
body.dark-mode .cta-secondary {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.18);
  color: #edeef1;
}
body.dark-mode .cta-secondary:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.28);
}

/* ── Visual Panel & Floating Cards ───────────────────────── */
body.dark-mode .visual-panel {
  background: rgba(20,22,28,.9);
  border-color: rgba(255,255,255,.08);
}
body.dark-mode .visual-top { color: #edeef1 }
body.dark-mode .floating-card {
  background: rgba(25,27,34,.92) !important;
  border-color: rgba(255,255,255,.09) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.07) !important;
}
body.dark-mode .card-label { color: #8a8f9e }
body.dark-mode .card-title { color: #edeef1 }
body.dark-mode .card-copy  { color: #a8adb8 }
body.dark-mode .card-line  { background: linear-gradient(90deg, rgba(0,174,239,.35), transparent) }
body.dark-mode .orbit      { border-color: rgba(0,174,239,.1) }

/* ── Section / Services ───────────────────────────────────── */
body.dark-mode .section { border-top-color: rgba(255,255,255,.06) }
body.dark-mode .service {
  background: #1d2028;
  border-color: rgba(255,255,255,.07);
}
body.dark-mode .service:hover {
  background: #252933;
  border-color: rgba(0,174,239,.2);
  box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
body.dark-mode .service h3     { color: #edeef1 }
body.dark-mode .service p      { color: #a8adb8 }
body.dark-mode .service-index  { color: #8a8f9e }
body.dark-mode .service::after { background: linear-gradient(90deg, rgba(255,255,255,.04), rgba(0,174,239,.15), transparent) }

/* ── Service Marker Pills ─────────────────────────────────── */
/* Marker bleibt gleich (blauer Gradient) — kein Override nötig */

/* ── Bento Grid erster Card ───────────────────────────────── */
body.dark-mode .services.bento .service:nth-child(1) {
  background: linear-gradient(160deg, rgba(0,174,239,.08), #1d2028 60%);
  border-color: rgba(0,174,239,.18);
}

/* ── Kontakt ──────────────────────────────────────────────── */
body.dark-mode .contact-card,
body.dark-mode .form-card {
  background: linear-gradient(180deg, #1d2028, #1a1e26);
  border-color: rgba(255,255,255,.07);
  box-shadow: 0 20px 60px rgba(0,0,0,.4);
}
body.dark-mode .contact-item {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.06);
}
body.dark-mode .contact-item:hover {
  background: rgba(0,174,239,.07);
  border-color: rgba(0,174,239,.18);
}
body.dark-mode .contact-label { color: #8a8f9e }
body.dark-mode .contact-value { color: #edeef1 }
body.dark-mode .contact-value a { color: #edeef1 }
body.dark-mode .contact-value a:hover { color: var(--accent) }
body.dark-mode .legal {
  color: #8a8f9e;
  border-top-color: rgba(255,255,255,.06);
}

/* ── Formular ─────────────────────────────────────────────── */
body.dark-mode label { color: #a8adb8 }
body.dark-mode .field {
  background: #0f1115;
  border-color: rgba(255,255,255,.1);
  color: #edeef1;
  box-shadow: inset 0 2px 4px rgba(0,0,0,.2);
}
body.dark-mode .field::placeholder { color: #5a6070 }
body.dark-mode .field:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,174,239,.15), inset 0 2px 4px rgba(0,0,0,.2);
  background: #111419;
}
body.dark-mode select.field option { background: #1d2028; color: #edeef1 }
body.dark-mode .form-note { color: #8a8f9e }

/* ── Modals ───────────────────────────────────────────────── */
body.dark-mode .modal-backdrop { background: rgba(0,0,0,.75) }
body.dark-mode .modal {
  background: #1d2028;
  border-color: rgba(255,255,255,.09);
  box-shadow: 0 36px 120px rgba(0,0,0,.6);
}
body.dark-mode .modal-header {
  background: rgba(25,27,34,.95);
  border-bottom-color: rgba(255,255,255,.07);
  backdrop-filter: blur(12px);
}
body.dark-mode .modal-kicker { color: #8a8f9e }
body.dark-mode .modal-title  { color: #edeef1 }
body.dark-mode .modal-close  {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.1);
  color: #a8adb8;
}
body.dark-mode .modal-close:hover { color: #edeef1; background: rgba(255,255,255,.1) }
body.dark-mode .modal-panel {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.06);
}
body.dark-mode .modal-panel h3 { color: #edeef1 }
body.dark-mode .modal-panel p  { color: #a8adb8 }
body.dark-mode .modal-panel a  { color: var(--accent) }

/* ── Footer ───────────────────────────────────────────────── */
body.dark-mode footer {
  background: #0f1115;
  border-top-color: rgba(255,255,255,.06);
  color: #8a8f9e;
}
body.dark-mode .footer-links a { color: #8a8f9e }
body.dark-mode .footer-links a:hover { color: #c8ccd6 }

/* ── Section Dot Nav ──────────────────────────────────────── */
body.dark-mode .snav-dot { background: rgba(255,255,255,.2) }
body.dark-mode .snav-dot.active { background: var(--accent) }
body.dark-mode .snav-dot::after { color: #a8adb8 }

/* ── Cursor ───────────────────────────────────────────────── */
body.dark-mode #mk-cursor-ring { border-color: rgba(0,174,239,.45) }

/* ── Smooth Transitions ───────────────────────────────────── */
body, header, .service, .contact-card, .form-card,
.field, .floating-card, .visual-panel, footer,
nav a, .modal, .modal-panel, .contact-item, h1, h2, h3, p {
  transition:
    background-color .35s cubic-bezier(.22,1,.36,1),
    color .35s cubic-bezier(.22,1,.36,1),
    border-color .35s cubic-bezier(.22,1,.36,1),
    box-shadow .35s cubic-bezier(.22,1,.36,1);
}

/* ── DARK MODE TOGGLE — Header Slider ────────────────────── */

}

/* ── 8. MICRO-INTERAKTIONEN ────────────────────────────────── */
/* Ripple auf CTA */
.cta, button[type="submit"] { overflow: hidden; position: relative }
.ripple {
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,.3);
  transform: scale(0);
  animation: rippleAnim .55s linear;
  pointer-events: none;
}
@keyframes rippleAnim {
  to { transform: scale(4); opacity: 0 }
}
/* Scale auf Hover für CTA */
.cta:hover { transform: translateY(-2px) scale(1.02) }
.cta:active { transform: scale(.97) }
/* Nav-Links: underline wächst von links */
#nav-menu a {
  position: relative;
}
#nav-menu a::after {
  content: '';
  position: absolute;
  bottom: -2px; left: 50%;
  width: 0; height: 2px;
  background: var(--accent);
  border-radius: 1px;
  transition: width .3s var(--ease), left .3s var(--ease);
}
#nav-menu a:hover::after,
#nav-menu a.is-active::after { width: 100%; left: 0 }
/* Card-Marker: sanfte Scale-Animation */
.service-marker {
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
.service:hover .service-marker {
  transform: scale(1.05);
  box-shadow: 0 6px 18px rgba(0,174,239,.3);
}
/* Kontakt-Items: Hover-Highlight */
.contact-item {
  transition: background .25s var(--ease), border-color .25s var(--ease);
}
.contact-item:hover { background: rgba(0,174,239,.04); border-color: rgba(0,174,239,.15) }
/* Form-Fields: Focus-Glow */
.field:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,174,239,.12);
}
/* Submit Button: Puls-Animation wenn idle */
@keyframes btnPulse {
  0%,100% { box-shadow: 0 16px 42px rgba(0,174,239,.28) }
  50%      { box-shadow: 0 16px 52px rgba(0,174,239,.45) }
}
button[type="submit"]:not(:disabled) {
  animation: btnPulse 3s ease-in-out infinite;
}
button[type="submit"]:disabled { animation: none }

/* ── prefers-reduced-motion: alle neuen Animationen deaktivieren */
@media (prefers-reduced-motion: reduce) {
  #mk-cursor, #mk-cursor-ring { display: none !important }
  .ripple { animation: none }
  button[type="submit"] { animation: none }
  .service:hover { transform: none }
  .cta:hover { transform: none }
}

/* ══════════════════════════════════════════════════════════
   DARK MODE — erstklassig
   Kontrast-System (WCAG AA):
   Primary Text  #edeef1 → 14.8:1 auf #13151a
   Secondary     #a8adb8 →  8.4:1 auf #13151a
   Tertiary      #636878 →  4.6:1 auf #13151a
   Accent Blue   #00AEEF →  7.0:1 auf #13151a
   ══════════════════════════════════════════════════════════ */

/* ── Basis-Variablen ──────────────────────────────────────── */
body.dark-mode {
  --bg:          #13151a;
  --bg-soft:     #1d2028;
  --text:        #edeef1;
  --muted:       #a8adb8;
  --soft:        #636878;
  --line:        rgba(255,255,255,.07);
  --shadow:      0 20px 60px rgba(0,0,0,.5);
  --shadow-strong: 0 32px 90px rgba(0,0,0,.65);
  color-scheme:  dark;
  background:    #13151a;
  color:         #edeef1;
}

/* ── Header: hell bleiben — Logo bleibt sichtbar ─────────── */
body.dark-mode header {
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(20px) saturate(1.8);
  -webkit-backdrop-filter: blur(20px) saturate(1.8);
  border-bottom: 1px solid rgba(17,17,17,.08);
}
body.dark-mode .logo { filter: none }
body.dark-mode .nav-toggle span { background: #111 }
body.dark-mode nav a { color: rgba(17,17,17,.55); background: transparent }
body.dark-mode nav a:hover { color: #111; background: rgba(17,17,17,.06) }
body.dark-mode nav a.is-active { color: #111; background: rgba(17,17,17,.07) }
body.dark-mode #dark-toggle { border-color: rgba(17,17,17,.15); color: rgba(17,17,17,.5) }
body.dark-mode #dark-toggle:hover { border-color: var(--accent); color: var(--accent); background: rgba(0,174,239,.06) }

/* ── Hintergrund & Grid ───────────────────────────────────── */
body.dark-mode .bg-grid { opacity: .4 }
body.dark-mode .bg-orb  { opacity: .18 }

/* ── Typografie ───────────────────────────────────────────── */
body.dark-mode h1,
body.dark-mode h2,
body.dark-mode h3       { color: #edeef1 }
body.dark-mode p        { color: #a8adb8 }
body.dark-mode .kicker  { color: #8a8f9e }
body.dark-mode .section-copy { color: #a8adb8 }
body.dark-mode .hero-copy > p { color: #a8adb8 }

/* accent-line (Kunden bringen.) bleibt blau — kein Override */

/* ── Hero ─────────────────────────────────────────────────── */
body.dark-mode .eyebrow {
  background: rgba(255,255,255,.06);
  border-color: rgba(0,174,239,.22);
  color: #a8adb8;
}
body.dark-mode .eyebrow-dot { background: var(--accent) }
body.dark-mode .status-note {
  background: rgba(255,255,255,.05);
  border-color: rgba(29,185,84,.22);
  color: #a8adb8;
}
body.dark-mode .cta-secondary {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.18);
  color: #edeef1;
}
body.dark-mode .cta-secondary:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.28);
}

/* ── Visual Panel & Floating Cards ───────────────────────── */
body.dark-mode .visual-panel {
  background: rgba(20,22,28,.9);
  border-color: rgba(255,255,255,.08);
}
body.dark-mode .visual-top { color: #edeef1 }
body.dark-mode .floating-card {
  background: rgba(25,27,34,.92) !important;
  border-color: rgba(255,255,255,.09) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.07) !important;
}
body.dark-mode .card-label { color: #8a8f9e }
body.dark-mode .card-title { color: #edeef1 }
body.dark-mode .card-copy  { color: #a8adb8 }
body.dark-mode .card-line  { background: linear-gradient(90deg, rgba(0,174,239,.35), transparent) }
body.dark-mode .orbit      { border-color: rgba(0,174,239,.1) }

/* ── Section / Services ───────────────────────────────────── */
body.dark-mode .section { border-top-color: rgba(255,255,255,.06) }
body.dark-mode .service {
  background: #1d2028;
  border-color: rgba(255,255,255,.07);
}
body.dark-mode .service:hover {
  background: #252933;
  border-color: rgba(0,174,239,.2);
  box-shadow: 0 16px 48px rgba(0,0,0,.4);
}
body.dark-mode .service h3     { color: #edeef1 }
body.dark-mode .service p      { color: #a8adb8 }
body.dark-mode .service-index  { color: #8a8f9e }
body.dark-mode .service::after { background: linear-gradient(90deg, rgba(255,255,255,.04), rgba(0,174,239,.15), transparent) }

/* ── Service Marker Pills ─────────────────────────────────── */
/* Marker bleibt gleich (blauer Gradient) — kein Override nötig */

/* ── Bento Grid erster Card ───────────────────────────────── */
body.dark-mode .services.bento .service:nth-child(1) {
  background: linear-gradient(160deg, rgba(0,174,239,.08), #1d2028 60%);
  border-color: rgba(0,174,239,.18);
}

/* ── Kontakt ──────────────────────────────────────────────── */
body.dark-mode .contact-card,
body.dark-mode .form-card {
  background: linear-gradient(180deg, #1d2028, #1a1e26);
  border-color: rgba(255,255,255,.07);
  box-shadow: 0 20px 60px rgba(0,0,0,.4);
}
body.dark-mode .contact-item {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.06);
}
body.dark-mode .contact-item:hover {
  background: rgba(0,174,239,.07);
  border-color: rgba(0,174,239,.18);
}
body.dark-mode .contact-label { color: #8a8f9e }
body.dark-mode .contact-value { color: #edeef1 }
body.dark-mode .contact-value a { color: #edeef1 }
body.dark-mode .contact-value a:hover { color: var(--accent) }
body.dark-mode .legal {
  color: #8a8f9e;
  border-top-color: rgba(255,255,255,.06);
}

/* ── Formular ─────────────────────────────────────────────── */
body.dark-mode label { color: #a8adb8 }
body.dark-mode .field {
  background: #0f1115;
  border-color: rgba(255,255,255,.1);
  color: #edeef1;
  box-shadow: inset 0 2px 4px rgba(0,0,0,.2);
}
body.dark-mode .field::placeholder { color: #5a6070 }
body.dark-mode .field:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,174,239,.15), inset 0 2px 4px rgba(0,0,0,.2);
  background: #111419;
}
body.dark-mode select.field option { background: #1d2028; color: #edeef1 }
body.dark-mode .form-note { color: #8a8f9e }

/* ── Modals ───────────────────────────────────────────────── */
body.dark-mode .modal-backdrop { background: rgba(0,0,0,.75) }
body.dark-mode .modal {
  background: #1d2028;
  border-color: rgba(255,255,255,.09);
  box-shadow: 0 36px 120px rgba(0,0,0,.6);
}
body.dark-mode .modal-header {
  background: rgba(25,27,34,.95);
  border-bottom-color: rgba(255,255,255,.07);
  backdrop-filter: blur(12px);
}
body.dark-mode .modal-kicker { color: #8a8f9e }
body.dark-mode .modal-title  { color: #edeef1 }
body.dark-mode .modal-close  {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.1);
  color: #a8adb8;
}
body.dark-mode .modal-close:hover { color: #edeef1; background: rgba(255,255,255,.1) }
body.dark-mode .modal-panel {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.06);
}
body.dark-mode .modal-panel h3 { color: #edeef1 }
body.dark-mode .modal-panel p  { color: #a8adb8 }
body.dark-mode .modal-panel a  { color: var(--accent) }

/* ── Footer ───────────────────────────────────────────────── */
body.dark-mode footer {
  background: #0f1115;
  border-top-color: rgba(255,255,255,.06);
  color: #8a8f9e;
}
body.dark-mode .footer-links a { color: #8a8f9e }
body.dark-mode .footer-links a:hover { color: #c8ccd6 }

/* ── Section Dot Nav ──────────────────────────────────────── */
body.dark-mode .snav-dot { background: rgba(255,255,255,.2) }
body.dark-mode .snav-dot.active { background: var(--accent) }
body.dark-mode .snav-dot::after { color: #a8adb8 }

/* ── Cursor ───────────────────────────────────────────────── */
body.dark-mode #mk-cursor-ring { border-color: rgba(0,174,239,.45) }

/* ── Smooth Transitions ───────────────────────────────────── */
body, header, .service, .contact-card, .form-card,
.field, .floating-card, .visual-panel, footer,
nav a, .modal, .modal-panel, .contact-item, h1, h2, h3, p {
  transition:
    background-color .35s cubic-bezier(.22,1,.36,1),
    color .35s cubic-bezier(.22,1,.36,1),
    border-color .35s cubic-bezier(.22,1,.36,1),
    box-shadow .35s cubic-bezier(.22,1,.36,1);
}

/* ── DARK MODE TOGGLE — sauberes Icon-Button Design ─────── */
#dark-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: 1.5px solid rgba(17,17,17,.12);
  border-radius: 999px;
  width: 36px;
  height: 36px;
  margin-left: 12px;
  cursor: none;
  flex-shrink: 0;
  position: relative;
  overflow: hidden;
  transition: border-color .3s var(--ease), background .3s var(--ease), box-shadow .3s;
  color: rgba(17,17,17,.55);
}
#dark-toggle:hover {
  border-color: var(--accent);
  background: rgba(0,174,239,.06);
  box-shadow: 0 0 0 3px rgba(0,174,239,.1);
  color: var(--accent);
}
/* Sun icon (shown in dark mode) */
#dark-toggle .icon-sun,
#dark-toggle .icon-moon {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .3s var(--ease), transform .3s var(--ease);
}
#dark-toggle .icon-sun  { opacity: 0; transform: rotate(45deg) scale(.7) }
#dark-toggle .icon-moon { opacity: 1; transform: rotate(0deg) scale(1) }

body.dark-mode #dark-toggle {
  border-color: rgba(17,17,17,.15);
  background: rgba(17,17,17,.04);
  color: rgba(17,17,17,.6);
}
body.dark-mode #dark-toggle .icon-sun  { opacity: 1; transform: rotate(0deg) scale(1) }
body.dark-mode #dark-toggle .icon-moon { opacity: 0; transform: rotate(-45deg) scale(.7) }
body.dark-mode #dark-toggle:hover {
  border-color: var(--accent);
  color: var(--accent);
}
@media(max-width:860px) { #dark-toggle { margin-left: 8px } }
@media(max-width:680px) { #dark-toggle { width:32px; height:32px; margin-left:6px } }

/* ============================================================
   FEATURES — Rotating Text, Parallax, Grain, Card Magnetic,
               Marquee, Preloader
   ============================================================ */

/* ── 7. PRELOADER ─────────────────────────────────────────── */
#preloader {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .5s cubic-bezier(.22,1,.36,1), visibility .5s;
}
#preloader.done {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.preloader-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.preloader-logo {
  height: 56px;
  width: auto;
  opacity: 0;
  transform: translateY(10px);
  animation: preloaderLogoIn .55s .1s cubic-bezier(.22,1,.36,1) forwards;
}
@keyframes preloaderLogoIn {
  to { opacity: 1; transform: none }
}
.preloader-bar {
  width: 120px;
  height: 2px;
  background: rgba(17,17,17,.08);
  border-radius: 1px;
  overflow: hidden;
}
.preloader-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #00AEEF, #7ddcff);
  border-radius: 1px;
  animation: preloaderFill .9s .2s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes preloaderFill {
  to { width: 100% }
}
/* Dark Mode Preloader */
body.dark-mode #preloader { background: #13151a }
body.dark-mode .preloader-bar { background: rgba(255,255,255,.08) }

/* ── 1. ROTATING TEXT ─────────────────────────────────────── */
.rotating-text {
  display: block;
  position: relative;
  min-height: 1.2em;
  overflow: visible;
}
.rotating-word {
  display: block;
  position: absolute;
  top: 0; left: 0;
  white-space: normal;
  overflow: visible;
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .55s cubic-bezier(.22,1,.36,1),
              transform .55s cubic-bezier(.22,1,.36,1);
  color: var(--accent);
}
.rotating-word.active {
  opacity: 1;
  transform: none;
  position: relative;
  white-space: normal;
  overflow: visible;
}
.rotating-word.exit {
  opacity: 0;
  transform: translateY(-14px);
  position: absolute;
}
@media (prefers-reduced-motion: reduce) {
  .rotating-word { transition: none; animation: none }
}

/* ── 2. PARALLAX HERO VISUAL ──────────────────────────────── */
.hero-visual {
  transform-style: preserve-3d;
  will-change: transform;
}
/* Parallax handled by JS — no CSS needed beyond transform-style */

/* ── 3. GRAIN / NOISE TEXTURE ─────────────────────────────── */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9990;
  pointer-events: none;
  opacity: .028;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 200px 200px;
}
body.dark-mode::after { opacity: .045 }

/* ── 4. MAGNETIC SERVICE CARDS ────────────────────────────── */
.service {
  transform-origin: center center;
  /* transform handled by JS */
}

/* ── 6. MARQUEE STRIP ─────────────────────────────────────── */
.marquee-strip {
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  padding: 11px 0;
  background: var(--bg-soft);
  user-select: none;
}
body.dark-mode .marquee-strip {
  background: rgba(19,21,26,.92);
  border-color: rgba(255,255,255,.06);
}
.marquee-track {
  display: flex;
  width: max-content;
  animation: marqueeScroll 30s linear infinite;
  -moz-animation: marqueeScroll 30s linear infinite;
}
.marquee-strip:hover .marquee-track { animation-play-state: paused }
.marquee-inner {
  display: flex;
  align-items: center;
  padding-right: 0;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--soft);
  white-space: nowrap;
  font-weight: 400;
}
body.dark-mode .marquee-inner { color: #636878 }
@keyframes marqueeScroll {
  from { transform: translateX(0) }
  to   { transform: translateX(-50%) }
}
@media (prefers-reduced-motion: reduce) {
  .marquee-track { animation: none }
}

/* ============================================================
   WEBSITE-CHECK WIDGET
   ============================================================ */

.check-widget {
  max-width: 860px;
  margin: 56px auto 0;
  background: linear-gradient(180deg, rgba(255,255,255,.9), rgba(248,249,251,.95));
  border: 1px solid rgba(17,17,17,.06);
  border-radius: 36px;
  box-shadow: var(--shadow-strong);
  padding: 48px 52px;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Progress Bar */
.check-progress {
  height: 3px;
  background: var(--line);
  border-radius: 999px;
  margin-bottom: 44px;
  overflow: hidden;
}
.check-progress-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #00AEEF, #7ddcff);
  border-radius: 999px;
  transition: width .6s cubic-bezier(.22,1,.36,1);
}

/* Steps */
.check-step {
  display: none;
  animation: fadeIn .4s cubic-bezier(.22,1,.36,1);
}
.check-step.active { display: block }

.check-step-num {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 14px;
}
.check-question {
  font-size: clamp(18px, 2.5vw, 24px);
  font-weight: 650;
  letter-spacing: -.03em;
  line-height: 1.25;
  margin-bottom: 28px;
  color: var(--text);
}

/* Options Grid */
.check-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.check-option {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0;
  padding: 20px 24px;
  border-radius: 20px;
  background: #fff;
  border: 1.5px solid rgba(17,17,17,.08);
  cursor: none;
  text-align: left;
  transition: border-color .2s var(--ease), background .2s var(--ease),
              transform .25s var(--ease), box-shadow .25s var(--ease);
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.45;
}
.check-option::before {
  content: '';
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid rgba(17,17,17,.15);
  transition: all .2s var(--ease);
  flex-shrink: 0;
}
.check-option-text {
  padding-left: 28px;
}
.check-option:hover {
  border-color: var(--accent);
  background: rgba(0,174,239,.03);
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0,174,239,.1);
}
.check-option:hover::before {
  border-color: var(--accent);
  background: rgba(0,174,239,.1);
}
.check-option.selected {
  border-color: var(--accent);
  background: rgba(0,174,239,.05);
  box-shadow: 0 0 0 3px rgba(0,174,239,.12);
  transform: translateY(-1px);
}
.check-option.selected::before {
  border-color: var(--accent);
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,174,239,.2);
}
.check-option.selected::after {
  content: '';
  position: absolute;
  left: 24px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
  z-index: 1;
}

/* Result */
.check-result {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 40px;
  align-items: start;
  animation: fadeIn .6s cubic-bezier(.22,1,.36,1);
}
.check-result[hidden] { display: none }

.check-score-wrap {
  position: relative;
  width: 160px;
  height: 160px;
  flex-shrink: 0;
}
.check-score-ring {
  width: 160px;
  height: 160px;
  transform: rotate(-90deg);
}
.check-score-bg {
  fill: none;
  stroke: var(--line);
  stroke-width: 9;
}
.check-score-arc {
  fill: none;
  stroke-width: 9;
  stroke-linecap: round;
  stroke-dasharray: 376;
  stroke-dashoffset: 376;
  transition: stroke-dashoffset 1.4s cubic-bezier(.22,1,.36,1);
}
.check-score-inner {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}
.check-score-num {
  font-size: 44px;
  font-weight: 750;
  letter-spacing: -.05em;
  color: var(--text);
  line-height: 1;
}
.check-score-label {
  font-size: 12px;
  color: var(--muted);
  font-weight: 400;
  letter-spacing: .05em;
}

.check-result-content { min-width: 0 }
.check-result-grade {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 14px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.check-result-grade::before {
  content: '';
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
}
.grade-critical { background: rgba(239,68,68,.08);  color: #ef4444; border: 1px solid rgba(239,68,68,.15) }
.grade-weak     { background: rgba(245,158,11,.08); color: #d97706; border: 1px solid rgba(245,158,11,.15) }
.grade-ok       { background: rgba(0,174,239,.08);  color: #0095cc; border: 1px solid rgba(0,174,239,.15) }
.grade-good     { background: rgba(34,197,94,.08);  color: #16a34a; border: 1px solid rgba(34,197,94,.15) }

.check-result-title {
  font-size: clamp(18px, 2vw, 23px);
  font-weight: 650;
  letter-spacing: -.03em;
  line-height: 1.25;
  margin-bottom: 10px;
  color: var(--text);
}
.check-result-text {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.75;
  margin-bottom: 20px;
}
.check-result-items {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: 28px;
  padding: 16px 20px;
  background: rgba(17,17,17,.02);
  border-radius: 16px;
  border: 1px solid var(--line);
}
.check-result-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 13px;
  color: var(--soft);
  line-height: 1.5;
}
.check-result-item::before {
  content: '→';
  color: var(--accent);
  flex-shrink: 0;
  font-weight: 700;
  margin-top: 1px;
}
.check-result-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
}

/* Dark Mode */
body.dark-mode .check-widget {
  background: linear-gradient(180deg, #1d2028, #1a1e26);
  border-color: rgba(255,255,255,.07);
}
body.dark-mode .check-option {
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
  color: #edeef1;
}
body.dark-mode .check-option::before {
  border-color: rgba(255,255,255,.2);
}
body.dark-mode .check-option:hover {
  background: rgba(0,174,239,.07);
  border-color: var(--accent);
}
body.dark-mode .check-option.selected {
  background: rgba(0,174,239,.1);
  border-color: var(--accent);
}
body.dark-mode .check-score-num  { color: #edeef1 }
body.dark-mode .check-result-title { color: #edeef1 }
body.dark-mode .check-result-items {
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.06);
}

/* Responsive */
@media(max-width:860px) {
  .check-widget { padding: 36px 32px }
}
@media(max-width:680px) {
  .check-widget { padding: 28px 20px; border-radius: 24px }
  .check-options { grid-template-columns: 1fr }
  .check-result { grid-template-columns: 1fr; justify-items: center; text-align: center }
  .check-result-item { justify-content: flex-start; text-align: left }
  .check-result-actions { justify-content: center }
}
