:root {
--bg: #0a0a0a;
--card: #121212;
--muted: #9aa0a6;
--text: #e9eaee;
--accent: #e63946;
--border: #262626;
--ring: rgba(230,57,70,.35);
}

{ box-sizing: border-box }
html, body { height: 100% }
body {
margin: 0;
font-family: Outfit, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
background: radial-gradient(1200px 600px at 70% -10%, rgba(230,57,70,.08), transparent), var(--bg);
color: var(--text);
line-height: 1.6;
}

/* Container helpers */
.container { max-width: 1100px; margin: 0 auto; padding: 0 20px }
.section { padding: 34px 0 }
.grid { display: grid; gap: 24px }
.cols-3 { grid-template-columns: repeat(3, 1fr) }
.cols-2 { grid-template-columns: repeat(2, 1fr) }
@media (max-width: 980px){ .cols-3, .cols-2 { grid-template-columns: 1fr } }

/* Navbar */
.nav {
position: sticky;
top: 0;
z-index: 40;
backdrop-filter: saturate(140%) blur(8px);
background: rgba(10,10,10,.6);
border-bottom: 1px solid var(--border);
}
.nav .inner {
display: flex;
align-items: center;
justify-content: space-between;
gap: 16px;
max-width: 1100px;
margin: 0 auto;
padding: 14px 20px;
}
.brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--text); font-weight: 700; letter-spacing: .4px }
.brand img { height: 30px; width: auto }
.nav a.link { color: var(--muted); text-decoration: none; padding: 8px 10px; border-radius: 10px }
.nav a.link:hover { color: var(--text); background: #161616 }

/* Hero */
.kicker { display: inline-block; font-size: .85rem; color: var(--muted); border: 1px solid var(--border); padding: 6px 10px; border-radius: 999px }
.h1 { margin: 14px 0 6px; font-size: 2.2rem; line-height: 1.2; letter-spacing: .3px }
.sub { color: var(--muted); max-width: 70ch; margin: 0 }

/* Cards */
.card {
background: linear-gradient(180deg, rgba(255,255,255,.02), transparent 60%), var(--card);
border: 1px solid var(--border);
border-radius: 18px;
box-shadow: 0 0 0 1px rgba(255,255,255,.01), 0 30px 80px rgba(0,0,0,.35);
}
.card .inner { padding: 22px }
.card h2 { margin: 0 0 10px; font-size: 1.2rem; color: var(--accent); letter-spacing: .2px }
.muted { color: var(--muted) }

/* Details accordion */
details { border-top: 1px solid var(--border) }
details:first-of-type { border-top: 0 }
summary { cursor: pointer; list-style: none; display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 10px; padding: 18px 0; font-weight: 600 }
summary::-webkit-details-marker { display: none }
.caret { transition: transform .2s ease; width: 18px; height: 18px; border: 1px solid var(--border); border-radius: 6px; display: grid; place-items: center; background: #161616 }
details[open] .caret { transform: rotate(90deg) }
.content { padding: 0 0 18px; color: var(--text) }
.content p, .content ul, .content ol { margin: 0 0 12px }
ul, ol { padding-left: 18px }

/* Table */
.table { width: 100%; border-collapse: collapse; overflow: hidden; border-radius: 12px; border: 1px solid var(--border) }
.table th, .table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--border) }
.table th { color: var(--muted); font-weight: 600; font-size: .95rem }
.table tr:hover td { background: #141414 }

/* Chips */
.stack { display: grid; gap: 14px; padding: 12px 0 }
.chip { display: flex; align-items: center; gap: 10px; padding: 12px 14px; border: 1px solid var(--border); border-radius: 14px; background: #111; color: var(--text) }
.chip small { color: var(--muted) }

/* Buttons */
.actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px }
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 12px 16px; border-radius: 12px; text-decoration: none; font-weight: 600; border: 1px solid var(--border); background: #121212; color: var(--text) }
.btn.primary { background: var(--accent); border-color: transparent; color: #fff; box-shadow: 0 0 0 6px var(--ring) }
.btn:hover { filter: brightness(1.08) }

/* Footer */
.footer { border-top: 1px solid var(--border); color: var(--muted); padding: 28px 20px 50px; text-align: center }

/* Utility spacing */
.mt-0 { margin-top: 0 }
.mt-10 { margin-top: 10px }
.mt-20 { margin-top: 20px }
.mt-30 { margin-top: 30px }
.mb-0 { margin-bottom: 0 }
.mb-10 { margin-bottom: 10px }
.mb-20 { margin-bottom: 20px }
.mb-30 { margin-bottom: 30px }

/* Card hover for fleet items */
.card.hover { transition: transform .2s ease, box-shadow .2s ease }
.card.hover:hover { transform: translateY(-2px) }

/* Simple responsive image */
.img { width: 100%; height: auto; display: block; border-radius: 14px }

/* Badges */
.badge { display: inline-block; padding: 6px 10px; border-radius: 999px; border: 1px solid var(--border); color: var(--muted); font-size: .85rem }

/* Page wrappers */
.hero-wrap { max-width: 1100px; margin: 24px auto 0; padding: 34px 20px 10px }
.main-wrap { max-width: 1100px; margin: 10px auto 80px; padding: 0 20px }

/* Impressum layout helpers */
.impressum-wrap { max-width: 1100px; margin: 10px auto 80px; padding: 0 20px; display: grid; grid-template-columns: 1.2fr .8fr; gap: 24px }
@media (max-width: 980px){ .impressum-wrap { grid-template-columns: 1fr } }
.kv { display: grid; grid-template-columns: 180px 1fr; gap: 8px 14px }
@media (max-width: 560px){ .kv { grid-template-columns: 1fr } }