/* ============================================================
   ASTRA · Mobile refinements (all pages)
   Shared breakpoint layer — tolerates nav variants:
     - <header class="nav">  (Hero, AGB)
     - <nav class="nav">     (Preise, Kontakt)
     - <nav class="topnav">  (Impressum, Datenschutz)
   Applies on <=720px. Desktop layout untouched.
   ============================================================ */

/* Burger button — hidden on desktop, grown on mobile */
.nav-burger{
  display:none;background:transparent;border:0;padding:8px;cursor:pointer;
  flex-direction:column;gap:4px;width:36px;height:36px;
  align-items:center;justify-content:center;
}
.nav-burger span{display:block;width:18px;height:1.5px;background:var(--ink);transition:transform .25s,opacity .2s}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(5.5px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg)}

/* Drawer */
.nav-drawer{
  display:none;position:fixed;top:58px;left:0;right:0;
  background:var(--bg);border-bottom:1px solid var(--line);
  z-index:999;padding:14px 24px 22px;
  flex-direction:column;gap:0;
  box-shadow:0 20px 40px rgba(0,0,0,.4);
}
.nav-drawer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--accent-gradient, linear-gradient(135deg,#006838 0%,#4fa82c 55%,#96cf24 100%));
}
.nav-drawer.open{display:flex}
.nav-drawer a{
  color:var(--ink);text-decoration:none;
  font-family:'Inter Tight',system-ui,sans-serif;
  font-size:15px;font-weight:500;letter-spacing:-.01em;
  padding:14px 4px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  transition:color .15s,padding-left .2s;
  position:relative;
}
.nav-drawer a::before{
  content:"";position:absolute;left:-24px;top:50%;transform:translateY(-50%);
  width:3px;height:0;background:var(--accent);transition:height .2s;
}
.nav-drawer a:hover,.nav-drawer a:active{color:var(--accent);padding-left:8px}
.nav-drawer a:hover::before{height:18px}
.nav-drawer a::after{
  content:"→";font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--ink-soft);transition:color .15s,transform .15s;
}
.nav-drawer a:hover::after{color:var(--accent);transform:translateX(2px)}
.nav-drawer a:last-of-type{border-bottom:0}
.nav-drawer .drawer-cta{
  margin-top:16px;padding:13px 18px;text-align:center;font-size:13px;
  border:1px solid transparent;border-bottom:0 !important;justify-content:center;
  letter-spacing:.01em;
}
.nav-drawer .drawer-cta::before,.nav-drawer .drawer-cta::after{display:none}
/* Contact row at bottom of drawer */
.nav-drawer .drawer-meta{
  margin-top:18px;padding-top:16px;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:8px;
}
.nav-drawer .drawer-meta span{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
}
.nav-drawer .drawer-meta a{
  padding:0;border:0;font-size:13px;color:var(--ink-dim);
}
.nav-drawer .drawer-meta a::before,.nav-drawer .drawer-meta a::after{display:none}
.nav-drawer .drawer-meta a:hover{color:var(--accent);padding-left:0}

/* ===== Lang globe (all viewports) ===== */
.lang-switch{display:none !important}
.lang-globe{
  display:inline-flex;position:relative;
  background:transparent;border:1px solid var(--line-2);
  width:36px;height:36px;border-radius:50%;
  align-items:center;justify-content:center;cursor:pointer;
  padding:0;transition:border-color .15s,background .15s;
}
.lang-globe:hover{border-color:var(--ink-soft)}
.lang-globe svg{width:18px;height:18px;color:var(--ink-dim);transition:color .15s}
.lang-globe:hover svg{color:var(--ink)}
.lang-globe .active-code{
  position:absolute;bottom:-2px;right:-2px;
  font-family:'JetBrains Mono',monospace;font-size:8px;
  background:var(--accent);color:#0c0c0d;
  padding:1px 3px;border-radius:2px;font-weight:600;letter-spacing:0;
  line-height:1;
}
.lang-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:6px;
  display:none;flex-direction:column;min-width:120px;overflow:hidden;
  box-shadow:0 10px 30px rgba(0,0,0,.5);z-index:1000;
}
.lang-dropdown.open{display:flex}
.lang-dropdown button{
  background:transparent;border:0;padding:10px 14px;
  color:var(--ink-dim);text-align:left;cursor:pointer;
  font:inherit;font-size:13px;letter-spacing:.04em;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  transition:background .15s,color .15s;
}
.lang-dropdown button:hover{background:var(--panel);color:var(--ink)}
.lang-dropdown button.active{color:var(--accent)}
.lang-dropdown button.active::after{content:"✓";color:var(--accent);font-weight:600}

@media (max-width:720px){
  /* Nav container shrink (covers all variants) */
  .nav-inner{padding:12px 20px !important;gap:10px !important}
  .topnav{padding:12px 20px !important}

  /* Swap 3-pill lang switch for globe (handled globally above) */

  /* Hide "/ digital" logo tag */
  .logo-tag{display:none}

  /* Logo bigger now that space is reclaimed */
  .logo img,.logo-img,.brand img{height:40px !important}

  /* Kill status pill + desktop CTA in nav */
  .nav-cta .status,.nav-status{display:none !important}
  .nav-cta-btn{display:none}

  /* Desktop nav links hidden (most pages already do this at 960/768) */
  .nav-links{display:none !important}

  /* Compact lang-switch (redundant — hidden above, but kept for odd viewports) */

  /* Show burger */
  .nav-burger{display:flex}

  /* Hero tweaks */
  .hero{min-height:auto !important}
  .hero-inner{padding-top:12px;gap:28px !important}
  .hero-col-main{gap:20px !important}
  .hero-corner{display:none}
  .hero-ctas{flex-direction:column;align-items:stretch;gap:10px !important}
  .hero-ctas .btn{justify-content:center;padding:14px 18px;font-size:14px}
  .hero-lede{font-size:15px !important;line-height:1.5 !important}
  .hero-trust{margin-top:4px !important}
  .scroll-cue{display:none !important}
  /* KI side panel — no artificial min-height */
  .hero-side{min-height:auto !important}
  .hs-stream{min-height:auto !important}

  /* KI cards full-width */
  .ki-card.full{flex-direction:column;align-items:flex-start;padding:28px 22px;gap:16px}
  .ki-card.featured .visual{display:none}

  /* Typography */
  h1.hero-title,h1.page-title{font-size:clamp(34px, 9vw, 48px) !important;line-height:1.08}
  .sec h2,.ki-section h2,.wd-section h2{font-size:clamp(26px, 6.5vw, 34px)}

  /* Legal pages (Impressum/Datenschutz/AGB) — content column */
  .legal-body,.legal-content,.page-body,.page-content{padding:20px !important}
  .toc,.legal-toc{position:static !important;margin-bottom:28px}
}

/* === Shared spacing compression — applies to mobile AND tablet (<=900px) === */
@media (max-width:900px){
  /* Section vertical rhythm — shrink */
  .hero{padding:32px 24px 36px !important}
  .wd-section,.ki-section,.sec,.page-hero,#cta-final{padding:44px 24px !important}
  .site-footer{padding:40px 24px 24px !important;margin-top:40px !important}

  /* Legal pages (Impressum / Datenschutz / AGB) */
  main{padding:40px 24px 60px !important}
  .doc-grid{margin:0 0 32px !important;padding:0 0 24px !important}
  .doc-sub{margin:0 0 32px !important}

  /* Marquee (ticker) — less breathing room above/below */
  .marquee{margin-top:20px !important;padding:12px 0 !important}

  /* KI cards tighter padding */
  .ki-card{padding:28px 22px}
  .ki-card.featured h3{font-size:22px}
  .ki-card h3{font-size:19px}

  /* Process/Stack/About stacks */
  .proc-step{padding:28px 22px 30px}
  .stack-cat{border-right:0;padding:24px 22px}
  .about-body{padding:28px 22px}
  .about-meta{padding:28px 22px}
  .faq-q{padding:18px 20px}
  .faq-a{padding:0 20px 18px}
}
