:root{
  --bg:#000;
  --text:#ffffff;
  --muted:#d9dfe6;
  --card:rgba(255,255,255,.05);
  --card-soft:rgba(255,255,255,.035);
  --border:rgba(255,255,255,.14);
  --accent:#d63031;
  --accent-hover:#ff7675;
  --radius:16px;
  --shadow:0 0 30px rgba(214,48,49,.28);
}

*,*::before,*::after{box-sizing:border-box}

html,body{
  background:var(--bg);
  color:var(--text);
  min-height:100%;
  overflow-x:hidden;
  font:16px/1.6 'Segoe UI', system-ui, -apple-system, Roboto, Ubuntu, Cantarell, 'Helvetica Neue', Arial, sans-serif;
}

img,video{max-width:100%;height:auto;display:block}

.container{max-width:1100px;margin:0 auto;padding:0 16px}

.navbar{background-color:rgba(0,0,0,.9) !important;backdrop-filter:blur(10px)}
.navbar .nav-link,.navbar-brand{color:var(--text) !important}
.navbar .nav-link:hover{color:var(--accent-hover) !important}

.text-gradient{
  background:linear-gradient(90deg,var(--accent),var(--accent-hover));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

.card{
  background:var(--card);
  border:1px solid var(--accent);
  border-radius:1rem;
  box-shadow:var(--shadow);
  padding:16px;
  margin-bottom:16px;
  overflow:hidden;
}

.card-header{background:none;border-bottom:1px solid var(--border)}

.lead{font-size:1.05rem;line-height:1.8;color:var(--muted)}

.btn,.btn-custom,.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 20px;border:none;border-radius:12px;
  background:var(--accent);color:#fff;font-weight:600;cursor:pointer;text-decoration:none;
  transition:transform .12s ease,filter .2s ease,box-shadow .2s ease;
}
.btn:hover,.btn-custom:hover{background:var(--accent-hover);color:#fff;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-ghost,.btn-outline-secondary,.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text)}
.btn-ghost:hover,.btn-outline-secondary:hover{border-color:var(--accent);color:#fff;box-shadow:0 0 0 .2rem rgba(214,48,49,.25)}

.teaser-section{border-left:4px solid var(--accent);padding-left:12px;margin:18px 0}
.badge-coming-soon{background:var(--card-soft);border:1px solid var(--border);color:var(--text);border-radius:999px;padding:6px 10px}

.ribbon-banner{
  position:fixed;top:18px;left:18px;background:linear-gradient(180deg,#aa1f21,#6b0f11);
  color:#fff;padding:8px 14px;border-radius:8px;box-shadow:var(--shadow);z-index:9999;letter-spacing:1px;
}
.ribbon-banner:hover{background:#ff7675}

.fade-in{animation:fadeIn 1.2s ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Guestbook form fixes */
.form-gb{max-width:780px;margin:0 auto}
.f{display:block;width:100%;min-width:0;margin-bottom:12px}
.f>span{display:block;margin-bottom:6px;color:var(--muted);font-size:.95rem}
.input,
input[type="text"],input[type="email"],input[type="search"],textarea,select{
  display:block;width:100%;max-width:100%;min-width:0;
  padding:10px 12px;border-radius:12px;border:1px solid var(--border);
  background:#0c0c0c;color:var(--text);outline:none;
  transition:border .18s ease, box-shadow .18s ease, background .18s ease;
}
textarea{resize:vertical;min-height:120px}
.input:focus,input[type="text"]:focus,textarea:focus,select:focus{
  border-color:var(--accent);box-shadow:0 0 0 .2rem rgba(214,48,49,.25);background:#0f0f0f
}
.grid2{display:grid;grid-template-columns:1fr;gap:12px}
.grid2>*{min-width:0}
@media(min-width:640px){.grid2{grid-template-columns:1fr 1fr}}

.quiz .q-text{font-size:1.05rem;margin-bottom:10px}
.choices{display:grid;grid-template-columns:1fr;gap:10px}
@media(min-width:560px){.choices{grid-template-columns:1fr 1fr}}
.choice{
  display:grid;grid-template-columns:18px 1fr;align-items:center;gap:10px;
  padding:10px 12px;border:1px solid var(--border);border-radius:12px;background:#0c0c0c;
  cursor:pointer;transition:border .18s ease, background .18s ease;min-width:0;overflow-wrap:anywhere;
}
.choice:hover{border-color:var(--accent);background:#121212}
.choice input[type="radio"]{accent-color:var(--accent);width:18px;height:18px}
.choice span{display:block;line-height:1.4}

.entry .meta{color:var(--muted);margin-bottom:6px}
.entry .content{white-space:pre-wrap}
.entry .social a{display:inline-block;margin-right:10px;color:var(--accent);text-decoration:none}
.entry .social a:hover{text-decoration:underline}

.site-footer{text-align:center;margin:28px 0 10px}
.site-footer a{color:var(--muted);text-decoration:none}
.site-footer a:hover{color:#fff}

body{padding-top:72px}
@media(max-width:768px){body{padding-top:64px}}

/* High-contrast paragraphs */
p, .card p, .lead { color: var(--text) !important; opacity: .98; }

.container h1, .container h2, .container h3 { margin-top: 0.2rem; }

/* Hover fades */ 
.navbar .nav-link{transition: color .2s ease, opacity .2s ease}
.navbar .nav-link:hover{opacity:.9}
.card{transition: transform .15s ease, box-shadow .25s ease, border-color .25s ease}
.card:hover{transform: translateY(-2px); box-shadow: 0 12px 40px rgba(214,48,49,.25); border-color: var(--accent-hover)}

/* About sections as cards */
.intro, .highlight, .dank, .nachwort { 
  background: var(--card); border:1px solid var(--accent); border-radius: 1rem;
  padding: 16px; margin: 16px 0; box-shadow: var(--shadow);
}
#impressum { 
  background: var(--card); border:1px solid var(--accent); border-radius: 1rem;
  padding: 16px; margin: 24px auto; box-shadow: var(--shadow); max-width: 1000px;
}
#impressum .section-title{ margin-top: 1rem; }


/* === Bright text overrides for readability === */
.f > span,
.quiz .q-text,
.choice,
.choice span,
label,
.question .q-text {
  color: #ffffff !important;
}

.btn-ghost { color: #ffffff !important; border-color: var(--border); }

/* === Dark dropdown styling for navbar === */
.navbar .dropdown-menu{
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  min-width: 240px;
  padding: 8px;
}
.navbar .dropdown-item{
  color: var(--text);
  border-radius: 8px;
}
.navbar .dropdown-item:hover{
  background: #11162a;
  color: #fff;
}
.navbar .dropdown-header{
  color: var(--muted);
  font-size: .82rem;
  padding-top: 6px;
  padding-bottom: 6px;
}
.navbar .dropdown-divider{
  border-top-color: var(--border);
}

