/* ========================================================
   Leitstand – Shared Design System
   Referenz: leitstand-frontend (Open Sans, Blue accent, Clean Gray/White)
   ======================================================== */

@import url('https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&family=DM+Mono:wght@400;500&display=swap');

:root {
  --blue:           hsl(221, 83%, 53%);
  --blue-hover:     hsl(221, 83%, 45%);
  --blue-active:    hsl(221, 83%, 38%);
  --blue-light:     hsl(221, 83%, 96%);
  --blue-muted:     hsl(221, 50%, 93%);
  --bg:             hsl(0, 0%, 100%);
  --surface:        hsl(0, 0%, 98%);
  --surface-2:      hsl(0, 0%, 96%);
  --surface-offset: hsl(0, 0%, 94%);
  --border:         hsl(0, 0%, 91%);
  --border-card:    hsl(0, 0%, 94%);
  --text:           hsl(0, 0%, 9%);
  --text-muted:     hsl(0, 0%, 38%);
  --text-faint:     hsl(0, 0%, 58%);
  --text-inverse:   hsl(0, 0%, 98%);
  --radius-sm:  3px; --radius-md: 6px; --radius-lg: 9px; --radius-xl: 14px;
  --shadow-card: 0 1px 3px hsl(0 0% 0% / .05), 0 1px 2px hsl(0 0% 0% / .03);
  --shadow-md:   0 4px 16px hsl(0 0% 0% / .07);
  --space-1: .25rem; --space-2: .5rem; --space-3: .75rem; --space-4: 1rem;
  --space-5: 1.25rem; --space-6: 1.5rem; --space-8: 2rem; --space-10: 2.5rem;
  --space-12: 3rem; --space-16: 4rem; --space-20: 5rem; --space-24: 6rem;
  --text-xs:   clamp(.75rem, .7rem + .25vw, .875rem);
  --text-sm:   clamp(.875rem, .82rem + .25vw, 1rem);
  --text-base: clamp(1rem, .95rem + .25vw, 1.125rem);
  --text-lg:   clamp(1.125rem, 1rem + .65vw, 1.5rem);
  --text-xl:   clamp(1.5rem, 1.1rem + 1.3vw, 2.25rem);
  --text-2xl:  clamp(2rem, 1.1rem + 2.8vw, 3.25rem);
  --font-body: "Open Sans", sans-serif;
  --font-mono: "DM Mono", "Courier New", monospace;
  --transition: 160ms cubic-bezier(.16, 1, .3, 1);
  --content-default: 960px;
  --content-wide: 1160px;
  --content-narrow: 640px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: none; text-size-adjust: none; -webkit-font-smoothing: antialiased; scroll-behavior: smooth; scroll-padding-top: 5rem; }
body { font-family: var(--font-body); font-size: var(--text-base); color: var(--text); background: var(--bg); line-height: 1.65; min-height: 100dvh; }
img, picture, svg { display: block; max-width: 100%; }
h1,h2,h3,h4,h5,h6 { text-wrap: balance; line-height: 1.2; }
p, li { text-wrap: pretty; max-width: 72ch; }
button { cursor: pointer; background: none; border: none; font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
table { border-collapse: collapse; width: 100%; }
input, textarea, select { font: inherit; color: inherit; }
:focus-visible { outline: 2px solid var(--blue); outline-offset: 3px; border-radius: var(--radius-sm); }

/* NAV */
.site-nav { position: sticky; top: 0; z-index: 100; background: hsl(0 0% 100% / .94); backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); border-bottom: 1px solid var(--border); }
.nav-inner { max-width: var(--content-wide); margin-inline: auto; padding-inline: var(--space-6); height: 3.5rem; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); }
.nav-logo { display: flex; align-items: center; gap: var(--space-2); font-weight: 700; font-size: var(--text-base); color: var(--text); letter-spacing: -.01em; }
.nav-links { display: flex; align-items: center; gap: var(--space-1); }
.nav-link { font-size: var(--text-sm); color: var(--text-muted); padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); transition: color var(--transition), background var(--transition); }
.nav-link:hover { color: var(--text); background: var(--surface-2); }
.nav-link.active { color: var(--text); font-weight: 500; }
.btn-nav { font-size: var(--text-sm); font-weight: 600; color: var(--text-inverse); background: var(--blue); padding: .5rem var(--space-4); border-radius: var(--radius-md); transition: background var(--transition); white-space: nowrap; display: inline-flex; align-items: center; gap: var(--space-2); }
.btn-nav:hover { background: var(--blue-hover); }
.nav-mobile-toggle { display: none; align-items: center; justify-content: center; padding: var(--space-2); border-radius: var(--radius-md); color: var(--text-muted); transition: background var(--transition); }
.nav-mobile-toggle:hover { background: var(--surface-2); }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); font-weight: 600; padding: .625rem var(--space-5); border-radius: var(--radius-md); transition: background var(--transition), color var(--transition), border-color var(--transition); cursor: pointer; border: 1px solid transparent; text-decoration: none; line-height: 1.4; }
.btn-primary { background: var(--blue); color: var(--text-inverse); border-color: var(--blue); }
.btn-primary:hover { background: var(--blue-hover); border-color: var(--blue-hover); }
.btn-ghost { background: transparent; color: var(--text-muted); border-color: var(--border); }
.btn-ghost:hover { background: var(--surface-2); color: var(--text); border-color: var(--surface-offset); }
.btn-lg { font-size: var(--text-base); padding: .75rem var(--space-6); }
.btn-sm { font-size: var(--text-xs); padding: var(--space-2) var(--space-3); font-weight: 500; }

/* LAYOUT */
.container { max-width: var(--content-default); margin-inline: auto; padding-inline: var(--space-6); }
.container-wide { max-width: var(--content-wide); margin-inline: auto; padding-inline: var(--space-6); }
.section { padding-block: clamp(var(--space-12), 8vw, var(--space-24)); }
.section-sm { padding-block: clamp(var(--space-8), 5vw, var(--space-16)); }

/* CARDS */
.card { background: var(--surface); border: 1px solid var(--border-card); border-radius: var(--radius-lg); padding: var(--space-6); box-shadow: var(--shadow-card); }
.card-title { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-2); color: var(--text); }
.card-body { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.7; }

/* SECTION HEADERS */
.section-label { font-size: var(--text-xs); font-family: var(--font-mono); color: var(--blue); text-transform: uppercase; letter-spacing: .08em; margin-bottom: var(--space-3); }
.section-heading { font-size: var(--text-xl); font-weight: 700; color: var(--text); letter-spacing: -.02em; margin-bottom: var(--space-3); line-height: 1.15; }
.section-sub { font-size: var(--text-base); color: var(--text-muted); max-width: 58ch; line-height: 1.75; }
.section-header { margin-bottom: var(--space-10); }

/* BADGE */
.badge { display: inline-flex; align-items: center; gap: var(--space-1); font-size: var(--text-xs); font-weight: 500; padding: .2rem .6rem; border-radius: 9999px; background: var(--blue-muted); color: var(--blue-hover); border: 1px solid hsl(221 83% 53% / .18); }

/* FORM */
.form-group { margin-bottom: var(--space-5); }
.form-label { display: block; font-size: var(--text-sm); font-weight: 500; color: var(--text); margin-bottom: var(--space-2); }
.form-input, .form-select, .form-textarea { display: block; width: 100%; padding: .625rem var(--space-3); border: 1px solid var(--border); border-radius: var(--radius-md); background: var(--bg); font-size: var(--text-sm); color: var(--text); transition: border-color var(--transition), box-shadow var(--transition); }
.form-input:focus, .form-select:focus, .form-textarea:focus { outline: none; border-color: var(--blue); box-shadow: 0 0 0 3px hsl(221 83% 53% / .12); }
.form-textarea { resize: vertical; min-height: 100px; line-height: 1.6; }
.form-select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .75rem center; padding-right: 2.5rem; }

/* COMPARISON TABLE */
.comparison-table { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--border); }
.comparison-table thead { background: var(--surface-2); }
.comparison-table th { font-size: var(--text-sm); font-weight: 600; padding: var(--space-3) var(--space-4); text-align: left; color: var(--text-muted); border-bottom: 1px solid var(--border); }
.comparison-table th.col-leitstand { color: var(--blue); background: var(--blue-light); }
.comparison-table td { font-size: var(--text-sm); padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--border); color: var(--text); vertical-align: top; }
.comparison-table tr:last-child td { border-bottom: none; }
.comparison-table td.col-leitstand { background: var(--blue-light); font-weight: 500; color: var(--blue-hover); }
.comparison-table td.row-label { font-weight: 600; color: var(--text); }

/* FOOTER */
.site-footer { background: var(--surface); border-top: 1px solid var(--border); padding-block: var(--space-8); }
.footer-inner { max-width: var(--content-wide); margin-inline: auto; padding-inline: var(--space-6); display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: var(--space-4); }
.footer-links { display: flex; gap: var(--space-4); flex-wrap: wrap; }
.footer-link { font-size: var(--text-sm); color: var(--text-muted); transition: color var(--transition); }
.footer-link:hover { color: var(--text); }
.footer-copy { font-size: var(--text-xs); color: var(--text-faint); }

/* CTA BANNER */
.cta-banner { background: var(--blue); color: var(--text-inverse); text-align: center; padding-block: clamp(var(--space-12), 7vw, var(--space-20)); }
.cta-banner .section-heading { color: var(--text-inverse); }
.cta-banner .section-sub { color: hsl(0 0% 100% / .80); max-width: 48ch; margin-inline: auto; margin-bottom: var(--space-8); }
.cta-banner .btn-white { background: var(--bg); color: var(--blue); border-color: var(--bg); border: 1px solid var(--bg); padding: .75rem var(--space-6); border-radius: var(--radius-md); font-size: var(--text-base); font-weight: 600; display: inline-flex; align-items: center; gap: var(--space-2); transition: background var(--transition); }
.cta-banner .btn-white:hover { background: var(--surface-2); }

/* FEATURES */
.feature-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr)); gap: var(--space-4); }
.feature-card { background: var(--surface); border: 1px solid var(--border-card); border-radius: var(--radius-lg); padding: var(--space-6); }
.feature-icon { width: 34px; height: 34px; color: var(--blue); margin-bottom: var(--space-4); }
.feature-title { font-size: var(--text-base); font-weight: 600; margin-bottom: var(--space-2); color: var(--text); }
.feature-desc { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.7; }

/* FAQ */
.faq-item { border-bottom: 1px solid var(--border); padding-block: var(--space-5); }
.faq-item:last-child { border-bottom: none; }
.faq-question { font-size: var(--text-base); font-weight: 600; cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: var(--space-4); color: var(--text); background: none; border: none; width: 100%; text-align: left; }
.faq-question:hover { color: var(--blue); }
.faq-answer { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.75; margin-top: var(--space-3); display: none; }
.faq-item.open .faq-answer { display: block; }
.faq-chevron { flex-shrink: 0; transition: transform var(--transition); }
.faq-item.open .faq-chevron { transform: rotate(180deg); }

/* SUCCESS */
.success-msg { background: var(--blue-light); border: 1px solid hsl(221 83% 53% / .2); border-radius: var(--radius-lg); padding: var(--space-6); text-align: center; display: none; }
.success-msg.show { display: block; }
.success-msg h3 { font-size: var(--text-base); font-weight: 600; color: var(--blue-hover); margin-bottom: var(--space-2); }
.success-msg p { font-size: var(--text-sm); color: var(--text-muted); }

/* MONO */
.mono { font-family: var(--font-mono); font-size: var(--text-xs); }

/* MOBILE */
@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-links.open { display: flex; flex-direction: column; position: absolute; top: 3.5rem; left: 0; right: 0; background: var(--bg); border-bottom: 1px solid var(--border); padding: var(--space-3); gap: var(--space-1); z-index: 99; box-shadow: var(--shadow-md); }
  .nav-link { padding: var(--space-3); }
  .nav-mobile-toggle { display: flex; }
  .hide-mobile { display: none !important; }
}

@keyframes fadeUp { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: translateY(0); } }
.animate-in { animation: fadeUp .5s cubic-bezier(.16, 1, .3, 1) both; }
.delay-1 { animation-delay: .1s; } .delay-2 { animation-delay: .2s; } .delay-3 { animation-delay: .3s; } .delay-4 { animation-delay: .4s; }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; } }