/* =========================================================
   Loina – Play with Fire (assets/css/main.css)
   Brand: Black (#111) + Gold (#D4AF37) + Anthrazit (#1A1A1A)
   Fonts: Playfair Display (Headings), Montserrat (Body)
   ========================================================= */

/* ---------- CSS Vars / Theme ---------- */
:root{
  --gold: #D4AF37;
  --gold-2: #f8e48d;
  --accent: #C70039;
  --black: #111111;
  --dark: #1A1A1A;
  --text: #E0E0E0;
  --text-dim: #B8B8B8;
  --shadow-gold: 0 0 25px rgba(212,175,55,.6);
  --shadow-gold-soft: 0 0 15px rgba(212,175,55,.35);
  --radius-xl: 24px;
  --radius-pill: 999px;
  --container: 1100px;
}

/* ---------- Reset (soft) ---------- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background:var(--black);
  color:var(--text);
  font-family: "Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--gold);text-decoration:none;transition:.25s ease}
a:hover{color:#fff;text-shadow:0 0 10px var(--gold)}
button{font:inherit;cursor:pointer;transition:.25s ease}
:focus-visible{outline:2px solid var(--gold); outline-offset:2px}

/* ---------- Typography ---------- */
h1,h2,h3,h4{
  font-family:"Playfair Display", Georgia, serif;
  color:var(--gold);
  line-height:1.2;
  margin:0 0 .4em;
  text-shadow:0 0 20px rgba(212,175,55,.5);
}
h1{font-size:40px;letter-spacing:.5px}
h2{font-size:32px}
h3{font-size:24px}
p{margin:0 0 1rem;color:var(--text)}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.center{text-align:center}
.stack{display:flex;flex-direction:column;gap:16px}

/* ---------- Header / Footer ---------- */
.app-header{padding:40px 0 20px;text-align:center}
.app-sub{color:var(--text-dim);font-size:16px;margin-top:-6px}
.app-footer{
  text-align:center;padding:40px 0 60px;color:var(--text-dim);font-size:14px
}
.app-footer a{color:var(--text-dim)}
.app-footer a:hover{color:var(--gold)}

/* ---------- Cards / Surfaces ---------- */
.card{
  background: linear-gradient(145deg, var(--dark), var(--black));
  border:2px solid var(--gold);
  border-radius:var(--radius-xl);
  box-shadow: var(--shadow-gold-soft);
}
.card.pad{padding:32px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;border:none;text-transform:uppercase;letter-spacing:.5px;
  border-radius:var(--radius-pill);font-weight:700
}
.btn-lg{font-size:20px;padding:18px 46px}
.btn-md{font-size:18px;padding:14px 34px}
.btn-sm{font-size:14px;padding:10px 22px}

.btn-gold{
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-2) 100%);
  color:#111; box-shadow: var(--shadow-gold), inset 0 0 10px rgba(255,255,255,.5)
}
.btn-gold:hover{box-shadow:0 0 35px rgba(212,175,55,.9), inset 0 0 20px rgba(255,255,255,.8); transform:translateY(-1px)}
.btn-outline{
  background:var(--dark); color:var(--gold); border:2px solid var(--gold);
  box-shadow:0 0 10px rgba(212,175,55,.3)
}
.btn-outline:hover{background:#222; color:#fff}

/* ---------- Badges / Pills ---------- */
.badge{
  display:inline-flex;align-items:center;gap:8px;
  background:#000; color:var(--gold);
  border:1px solid var(--gold); border-radius:999px; padding:6px 14px;
  font-size:13px; box-shadow:0 0 10px rgba(212,175,55,.25)
}

/* ---------- Hero / Intro ---------- */
.hero-sub{color:var(--text-dim);font-size:18px;max-width:700px;margin:20px auto 40px}

/* ---------- Game Room ---------- */
.scoreboard{
  display:flex;justify-content:center;gap:50px;margin:0 auto 30px;flex-wrap:wrap
}
.scoreboard .slot{display:flex;flex-direction:column;align-items:center}
.scoreboard .icon{font-size:28px;color:var(--gold);line-height:1}
.scoreboard .label{margin-top:6px;font-size:18px}

.task-box{
  max-width:700px;margin:0 auto 32px;
  font-size:22px;line-height:1.5;min-height:120px;text-align:center
}
.task-surface{
  background:linear-gradient(145deg, var(--dark), var(--black));
  border:2px solid var(--gold);border-radius:var(--radius-xl);
  padding:40px 30px; box-shadow: var(--shadow-gold-soft);
  transition:opacity .4s ease, transform .4s ease;
}
.task-surface.fade-out{opacity:0;transform:translateY(4px)}
.task-surface.fade-in{opacity:1;transform:none}

.level-display{color:var(--text-dim);font-size:16px;margin-bottom:20px}
.level-display strong{color:var(--gold)}

/* ---------- Modal (Consent Wild) ---------- */
.modal{
  position:fixed; inset:0; display:none; justify-content:center; align-items:center;
  background:rgba(0,0,0,.8); z-index:999;
}
.modal.open{display:flex}
.modal-box{
  background:#1a1a1a; border:2px solid var(--gold); border-radius:20px; padding:36px;
  max-width:520px; text-align:center; box-shadow:0 0 30px rgba(212,175,55,.3)
}
.modal-title{font-family:"Playfair Display",serif;color:var(--gold);font-size:22px;margin:0 0 10px}
.modal-text{color:var(--text-dim);font-size:16px;margin:10px 0 22px}

/* ---------- Particles Canvas ---------- */
#goldParticles{
  position:fixed; inset:0; width:100%; height:100%;
  pointer-events:none; z-index:0; opacity:.2
}

/* ---------- Background Glow ---------- */
.bg-glow{
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background: radial-gradient(circle at center, rgba(212,175,55,.12), rgba(0,0,0,0));
  animation: glowPulse 4s ease-in-out infinite alternate
}
@keyframes glowPulse{
  from{opacity:.3} to{opacity:.6}
}

/* ---------- Utility ---------- */
.hide {
  display: none !important;
}

/* Margin Top Utilities */
.mt-0 { margin-top: 0; }
.mt-1 { margin-top: 8px; }
.mt-2 { margin-top: 16px; }
.mt-3 { margin-top: 24px; }
.mt-4 { margin-top: 32px; }

/* Margin Bottom Utilities */
.mb-0 { margin-bottom: 0; }
.mb-1 { margin-bottom: 8px; }
.mb-2 { margin-bottom: 16px; }
.mb-3 { margin-bottom: 24px; }
.mb-4 { margin-bottom: 32px; }

/* Center Utility */
.centered {
  display: flex;
  justify-content: center;
  align-items: center;
}

/* ---- Floating Score Control Bar ---- */
#pwfScoreControls {
  position: fixed;
  left: 50%;
  bottom: 80px;                 /* angehoben, damit Footer frei bleibt */
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
  padding: 8px 10px;
  background: linear-gradient(145deg, rgba(26,26,26,.95), #111);
  border: 2px solid rgba(212,175,55,.6);
  border-radius: 999px;
  box-shadow: 0 0 20px rgba(212,175,55,.35);
  z-index: 9998;
  transition: bottom 0.3s ease;
}

/* Footer-Padding, damit nichts überlappt */
footer {
  padding-bottom: 100px;        /* Abstand für Floating-Bar */
}

/* ---- Responsive Anpassung ---- */
@media (max-height: 750px) {
  #pwfScoreControls {
    bottom: 100px;              /* bei kleineren Displays leicht höher */
  }
  footer {
    padding-bottom: 120px;
  }
}

/* ---------- Animations ---------- */
@keyframes floatSoft{
  0%{transform:translateY(0)} 50%{transform:translateY(-3px)} 100%{transform:translateY(0)}
}
.float-soft{animation:floatSoft 5s ease-in-out infinite}

/* ---------- Media Queries ---------- */
@media (max-width: 900px){
  h1{font-size:34px}
  h2{font-size:28px}
  .btn-lg{font-size:18px;padding:16px 36px}
  .task-box{font-size:20px}
}
@media (max-width: 600px){
  .scoreboard{gap:28px}
  .task-surface{padding:28px 22px}
  .btn-md{font-size:16px;padding:12px 26px}
}

/* ---------- Accessibility / Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important}
  .bg-glow{display:none}
}

/* ---------- Print (minimal) ---------- */
@media print{
  body{background:#fff;color:#000}
  a{color:#000;text-shadow:none}
  .app-header,.app-footer,#goldParticles,.bg-glow{display:none !important}
}

/* ---------- Optional: Focus rings for dark surfaces ---------- */
.focus-ring:focus-visible{
  outline:2px solid #fff; outline-offset:2px; box-shadow:0 0 0 3px rgba(212,175,55,.4)
}