/* ── SGZ Shared Styles ──────────────────────────────────────────────── */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:      #1e3a5f;
  --navy-dark: #122438;
  --navy-mid:  #2d5a87;
  --fg:        #0f172a;
  --muted:     #4a5e72;
  --border:    #dde5ee;
  --bg-grey:   #e4eaf2;
  --bg:        #ffffff;
}
html,body{
  background:var(--bg);color:var(--fg);
  font:16px/1.65 'Inter',system-ui,sans-serif;font-weight:200;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
.container{width:min(1060px,92%);margin:0 auto}

/* ── Logo (Header) ── */
.sgz-logo{display:inline-flex;align-items:center;text-decoration:none;flex-shrink:0}
.sgz-logo-img{height:40px;width:auto;display:block}

/* ── Staging Banner ── */
#staging-banner{
  display:none;
  position:fixed;top:0;left:0;right:0;z-index:200;
  background:#f59e0b;color:#000;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:11px;
  letter-spacing:.12em;text-align:center;padding:5px 0;
  text-transform:uppercase;
}
#staging-banner.visible{display:block}
body.staging-active{padding-top:calc(73px + 27px)}
#staging-overlay{
  display:none;position:fixed;inset:0;z-index:999;
  background:var(--navy);align-items:center;justify-content:center;
}
#staging-overlay.visible{display:flex}
.staging-login-box{
  background:#fff;border-radius:1rem;padding:2.5rem 2.8rem;
  width:min(380px,90vw);text-align:center;
}
.staging-login-box h2{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:1.1rem;color:var(--navy);margin-bottom:.4rem;
}
.staging-login-box p{
  font-size:.85rem;color:var(--muted);font-weight:200;margin-bottom:1.4rem;
}
.staging-login-box input{
  width:100%;padding:.75rem 1rem;border:1.5px solid var(--border);
  border-radius:.45rem;font-size:.95rem;margin-bottom:.9rem;outline:none;
  font-family:'Inter',sans-serif;
}
.staging-login-box input:focus{border-color:var(--navy)}
.staging-login-box button{
  width:100%;padding:.8rem;border-radius:.45rem;
  background:var(--navy);color:#fff;border:none;cursor:pointer;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.9rem;
}
.staging-login-box .staging-error{
  color:#dc2626;font-size:.82rem;margin-top:.5rem;display:none;
}

/* ── Header ── */
#sgz-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(255,255,255,.97);backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
body{padding-top:73px}
#sgz-header nav{
  width:min(1060px,92%);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 0;gap:1.2rem;
}
#sgz-nav{display:flex;align-items:center;gap:2px}
.nav-link{
  padding:6px 13px;border-radius:7px;color:var(--muted);
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:13px;transition:all .15s;white-space:nowrap;
}
.nav-link:hover,.nav-link.active{background:#f0f4fa;color:var(--navy)}
.nav-cta{
  padding:7px 18px;border-radius:7px;
  background:var(--navy);color:#fff;
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:13px;margin-left:.5rem;transition:background .15s;
}
.nav-cta:hover{background:var(--navy-mid)}

/* ── Page Hero (Unterseiten) — navy oben, wie Homepage ── */
.page-hero{
  background:var(--navy);
  padding:4.5rem 0 4rem;
}
.page-hero h1{
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:clamp(2.6rem,5.5vw,3.8rem);
  line-height:1.08;color:#fff;margin-bottom:1.2rem;
}
.page-hero h1 span{display:block}
.page-hero .lead{
  color:rgba(255,255,255,.75);
  font-size:1rem;line-height:1.72;
  font-weight:200;font-family:'Inter',sans-serif;
}
.eyebrow{display:none}

/* ── Sections ── */
.section{padding:3rem 0}
/* weisser Bereich (Standard) — nichts nötig */
.section-grey{background:var(--bg-grey)}  /* hellblauer letzter Bereich */

.section-title{
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:1.5rem;color:var(--navy);
  margin:0 0 1.2rem;
}
.section-intro{
  color:var(--muted);max-width:62ch;font-size:.93rem;
  line-height:1.68;margin-bottom:2rem;font-weight:200;
}

/* Buttons */
.btn-navy{
  display:inline-block;padding:.78rem 1.9rem;border-radius:.45rem;
  background:var(--navy);color:#fff;
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:.9rem;
  letter-spacing:.01em;transition:background .15s;
}
.btn-navy:hover{background:var(--navy-mid)}
.btn-outline{
  display:inline-block;padding:.74rem 1.8rem;border-radius:.45rem;
  border:1.5px solid var(--navy);color:var(--navy);
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:.9rem;letter-spacing:.01em;transition:all .15s;
}
.btn-outline:hover{background:var(--navy);color:#fff}

/* Cards */
.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
.card{
  background:#fff;border:1px solid var(--border);
  border-radius:.75rem;padding:1.7rem 1.5rem;
  transition:box-shadow .15s;
}
.card:hover{box-shadow:0 4px 18px rgba(30,58,95,.1)}
.card h3{
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:1.05rem;color:var(--navy);margin-bottom:.5rem;
}
.card p{font-size:.88rem;color:var(--muted);line-height:1.62;font-weight:200}
.card-icon{
  width:46px;height:46px;border-radius:.55rem;background:var(--bg-grey);
  display:flex;align-items:center;justify-content:center;margin-bottom:1.1rem;
}

/* ── Footer ── */
#sgz-footer{background:var(--navy);padding:2.2rem 0}
.footer-inner{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:end;
  gap:.5rem 1rem;
}
/* Row 1: empty | copyright | empty */
.footer-wordmark{
  grid-column:2;
  font-family:'Montserrat',sans-serif;
  font-weight:600;font-size:.88rem;color:#fff;
  letter-spacing:.01em;text-decoration:none;
  text-align:center;
}
/* Row 2: empty | tagline | links */
.footer-tagline{
  grid-column:2;
  font-family:'Inter',sans-serif;
  font-weight:200;font-size:.82rem;color:rgba(255,255,255,.5);
  text-align:center;
}
.footer-links{
  grid-column:3;
  display:flex;gap:1.2rem;justify-content:flex-end;
  font-family:'Inter',sans-serif;font-weight:200;font-size:.82rem;
  align-self:end;
}
.footer-links a{color:rgba(255,255,255,.5);transition:color .15s;text-decoration:none}
.footer-links a:hover{color:#fff}

/* Responsive */
@media(max-width:860px){
  .card-grid-3{grid-template-columns:1fr}
  .card-grid-2{grid-template-columns:1fr}
  #sgz-nav .nav-link{font-size:12px;padding:5px 8px}
  /* Footer: stack to single column on narrow screens */
  .footer-inner{grid-template-columns:1fr;text-align:center;gap:.4rem}
  .footer-wordmark{grid-column:1;font-size:.8rem}
  .footer-tagline{grid-column:1}
  .footer-links{grid-column:1;justify-content:center;margin-top:.3rem}
}
/* ── Hamburger Button ── */
#nav-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  padding:6px;border-radius:6px;
  flex-direction:column;justify-content:center;gap:5px;
  flex-shrink:0;
}
#nav-toggle span{
  display:block;width:22px;height:2px;
  background:var(--navy);border-radius:2px;
  transition:all .25s ease;
}
/* Animated X when open */
#nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
#nav-toggle.open span:nth-child(2){opacity:0}
#nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:700px){
  #sgz-header nav{flex-wrap:nowrap;padding:.55rem 0;align-items:center;gap:0}
  .sgz-logo{margin-right:auto}
  .sgz-logo-img{height:32px}

  /* Show hamburger, hide inline nav */
  #nav-toggle{display:flex}
  #sgz-nav{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    background:rgba(255,255,255,.98);backdrop-filter:blur(8px);
    border-bottom:1px solid var(--border);
    flex-direction:column;gap:2px;
    padding:.6rem .8rem .8rem;
    box-shadow:0 8px 24px rgba(18,36,56,.12);
  }
  #sgz-nav.open{display:flex}
  #sgz-nav .nav-link{
    font-size:.95rem;padding:.55rem .9rem;border-radius:.45rem;
    text-align:left;width:100%;
  }
  /* Page-Hero H1: kein Overflow auf Mobile */
  .page-hero h1{font-size:clamp(1.8rem,8vw,3rem);overflow-wrap:break-word;word-break:break-word}
}

/* Accessibility */
.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}
.skip-link{position:absolute;top:-40px;left:0;background:var(--navy);color:#fff;padding:.5rem 1rem;z-index:9999;font-size:.9rem;text-decoration:none;border-radius:0 0 .4rem 0;transition:top .15s}
.skip-link:focus{top:0}
