/* ============================================================
   Freispiele.at — shared design tokens & base styles
   Clean light theme: white surfaces, red accent, slate text.
   Sora (display) / Manrope (body) / Space Mono (codes)
   (Gold-named vars are remapped to RED so component code stays valid.)
   ============================================================ */
:root{
  --bg:#ffffff;
  --bg-2:#f5f7fa;          /* zebra / expand panels */
  --surface:#ffffff;
  --surface-2:#f6f8fb;
  --surface-3:#eef1f6;
  --line:#e6e9f0;
  --line-2:#d9dee7;
  --line-gold:rgba(225,29,42,.32);   /* red tint border */

  --text:#1c2430;          /* slate ink */
  --muted:#5a6573;
  --muted-2:#8b95a4;

  /* hero / drama surfaces — deep brand red, no cold navy */
  --band:#b3101d;
  --band-2:#8c0a15;
  --band-grad:radial-gradient(1100px 520px at 50% -20%, #e0202e 0%, #b3101d 46%, #8c0a15 100%);
  --on-band:#ffffff;
  --on-band-muted:rgba(255,255,255,.80);
  --ink-band:#241318;     /* warm near-black for slot machine etc. */

  /* accent (RED) — keeps the --gold-* names for compatibility */
  --gold:#e11d2a;
  --gold-2:#cc1623;        /* darker red for text accents on white */
  --gold-soft:rgba(225,29,42,.09);
  --gold-grad:linear-gradient(180deg,#ef2532 0%,#d4121f 100%);
  --gold-text:#ffffff;

  --green:#11935f;
  --green-soft:rgba(17,147,95,.12);
  --red:#e11d2a;
  --red-soft:rgba(225,29,42,.09);
  --purple:#6b46d6;
  --blue:#2563c9;
  --star:#f5a300;          /* rating stars stay amber */

  --radius:16px;
  --radius-sm:11px;
  --radius-lg:22px;
  --radius-pill:999px;

  --shadow-card:0 1px 2px rgba(20,30,45,.04), 0 10px 30px -16px rgba(20,30,45,.18);
  --shadow-pop:0 18px 50px -16px rgba(20,30,45,.28);
  --shadow-red:0 10px 26px -10px rgba(225,29,42,.45);

  --font-display:"Sora",system-ui,sans-serif;
  --font-body:"Manrope",system-ui,sans-serif;
  --font-mono:"Space Mono","SFMono-Regular",monospace;

  --container:1200px;
  --nav-h:74px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
[id]{scroll-margin-top:calc(var(--nav-h) + 20px)}
body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
#root{position:relative;z-index:1}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit}
::selection{background:rgba(225,29,42,.18);color:var(--text)}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.05;margin:0}
p{margin:0}

/* layout */
.container{max-width:var(--container);margin:0 auto;padding:0 28px}
.eyebrow{
  font-family:var(--font-display);
  font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--gold);display:inline-flex;align-items:center;gap:8px;
}
.muted{color:var(--muted)}
.mono{font-family:var(--font-mono)}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:15px;
  border:none;cursor:pointer;border-radius:var(--radius-pill);
  padding:13px 22px;transition:transform .12s ease, box-shadow .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space:nowrap;line-height:1;
}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold-grad);color:var(--gold-text);box-shadow:var(--shadow-red)}
.btn-gold:hover{box-shadow:0 14px 32px -8px rgba(225,29,42,.6);transform:translateY(-1px)}
.btn-ghost{background:var(--surface-2);color:var(--text);border:1px solid var(--line-2)}
.btn-ghost:hover{background:var(--surface-3);border-color:var(--line-gold)}
.btn-outline{background:transparent;color:var(--gold-2);border:1px solid var(--line-2)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-light{background:#fff;color:var(--text);border:1px solid transparent}
.btn-light:hover{transform:translateY(-1px);box-shadow:0 12px 26px -12px rgba(0,0,0,.35)}
.btn-onband{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.28)}
.btn-onband:hover{background:rgba(255,255,255,.16)}
.btn-sm{padding:9px 16px;font-size:13.5px}
.btn-lg{padding:16px 28px;font-size:16.5px}

/* badges */
.badge{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.06em;text-transform:uppercase;
  padding:5px 11px;border-radius:var(--radius-pill);border:1px solid var(--line-2);color:var(--muted);background:#fff;white-space:nowrap;
}
.badge-gold{background:var(--gold-soft);color:var(--gold-2);border-color:var(--line-gold)}
.badge-green{background:var(--green-soft);color:var(--green);border-color:rgba(17,147,95,.3)}
.badge-red{background:var(--red-soft);color:var(--gold-2);border-color:var(--line-gold)}
.badge-purple{background:rgba(107,70,214,.1);color:var(--purple);border-color:rgba(107,70,214,.28)}

/* cards */
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-card);
}
.hoverable{transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease}
.hoverable:hover{transform:translateY(-3px);box-shadow:var(--shadow-pop);border-color:var(--line-gold)}
.top-pick{position:relative;border-color:var(--line-gold)!important;box-shadow:0 0 0 1px var(--line-gold), var(--shadow-card)}
.cat-card .cat-arrow{opacity:0;transform:translateX(-4px);transition:opacity .18s ease, transform .18s ease}
.cat-card:hover .cat-arrow{opacity:1;transform:none}
.top-pick-tag{
  display:inline-flex;align-items:center;gap:6px;background:var(--gold-grad);color:#fff;
  font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.07em;text-transform:uppercase;
  padding:5px 14px;border-radius:0 0 12px 0;position:absolute;top:0;left:0;
}

/* chips */
.chip{
  display:inline-flex;align-items:center;gap:7px;
  font-size:13.5px;font-weight:600;font-family:var(--font-display);
  padding:9px 15px;border-radius:var(--radius-pill);
  border:1px solid var(--line-2);background:#fff;color:var(--muted);
  cursor:pointer;transition:all .15s ease;white-space:nowrap;
}
.chip:hover{color:var(--text);border-color:var(--line-gold)}
.chip[data-active="true"]{background:var(--gold);color:#fff;border-color:transparent}

/* ============ responsive layout grids ============ */
.bonus-grid{display:grid;grid-template-columns:auto 1fr auto;gap:24px;align-items:flex-start}
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;text-align:left}
.split-2{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}
.test-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:0}
.machine-grid{display:grid;grid-template-columns:auto 1fr;gap:30px;align-items:start}
.podium-grid{display:grid;grid-template-columns:repeat(3,minmax(180px,260px));gap:18px;justify-content:center;align-items:end;max-width:860px;margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:36px}

@media (max-width:900px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .split-2{grid-template-columns:1fr;gap:28px}
  .test-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .machine-grid{grid-template-columns:1fr}
  .machine-grid > div:first-child{margin:0 auto}
}
@media (max-width:680px){
  .container{padding:0 18px}
  .section{padding:52px 0}
  .section-sm{padding:40px 0}
  .bonus-grid{grid-template-columns:1fr;gap:18px}
  .bonus-grid > div:last-child{min-width:0 !important}
  .cat-grid{grid-template-columns:1fr 1fr;gap:12px}
  .podium-grid{grid-template-columns:minmax(0,340px);justify-content:center;align-items:stretch}
  .podium-grid > *{transform:none !important}
  .pod-mobile-1{order:1}.pod-mobile-2{order:2}.pod-mobile-3{order:3}
  .footer-grid{grid-template-columns:1fr}
  .t-h3{font-size:19px}
}

/* kbd */
kbd{
  font-family:var(--font-mono);font-size:12px;
  background:var(--surface-3);border:1px solid var(--line-2);
  border-bottom-width:2px;border-radius:6px;padding:2px 7px;color:var(--text);
}

.rule{height:1px;background:var(--line);border:none;margin:0}
@keyframes fsspin{to{transform:rotate(360deg)}}

/* reveal class kept in markup for future use; content is ALWAYS visible
   (no opacity/transform gating — that breaks in offscreen iframes). */
.reveal{opacity:1;transform:none}

/* nav */
.topbar{background:var(--band-2);color:var(--on-band-muted);font-size:12.5px}
.topbar a{color:var(--on-band-muted);transition:color .15s}
.topbar a:hover{color:#fff}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:38px;gap:18px;white-space:nowrap}
.topbar .dot{width:3px;height:3px;border-radius:50%;background:currentColor;opacity:.45}
.topbar-18{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;border:1.5px solid rgba(255,255,255,.5);color:#fff;font-size:9.5px;font-weight:800;font-family:var(--font-display)}
@media (max-width:760px){.topbar{display:none}}

/* nav dropdown (Ratgeber) */
.nav-item{position:relative}
.nav-caret{transition:transform .18s ease}
.nav-item:hover .nav-caret{transform:rotate(180deg)}
.nav-pop{
  position:absolute;top:calc(100% + 6px);left:50%;transform:translateX(-50%) translateY(6px);
  min-width:300px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-pop);
  padding:8px;opacity:0;visibility:hidden;z-index:60;
  transition:opacity .16s ease .2s, transform .16s ease .2s, visibility 0s linear .36s;
}
/* invisible bridge so the pointer can cross the gap without closing the menu */
.nav-pop::before{content:"";position:absolute;left:0;right:0;top:-14px;height:14px}
.nav-item:hover .nav-pop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);transition-delay:0s}
.nav-pop-link{display:flex;gap:13px;align-items:flex-start;padding:12px 13px;border-radius:11px;transition:background .14s}
.nav-pop-link:hover{background:var(--surface-2)}
.nav-pop-ico{width:38px;height:38px;border-radius:10px;flex:none;display:flex;align-items:center;justify-content:center;background:var(--gold-grad);color:#fff;box-shadow:var(--shadow-red)}

.nav{
  position:sticky;top:0;z-index:50;height:var(--nav-h);
  display:flex;align-items:center;
  background:rgba(255,255,255,.9);backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);transition:box-shadow .2s ease;
}
.nav.scrolled{box-shadow:0 10px 30px -20px rgba(20,30,45,.55)}
.nav-inner{display:flex;align-items:center;gap:22px;width:100%}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:10px}
.nav-link{
  font-family:var(--font-display);font-weight:600;font-size:14.5px;color:var(--muted);
  padding:9px 13px;border-radius:10px;transition:all .15s ease;position:relative;white-space:nowrap;
}
.nav-link:hover{color:var(--text);background:var(--surface-2)}
.nav-link[data-active="true"]{color:var(--gold-2)}
.nav-link[data-active="true"]::after{content:"";position:absolute;left:13px;right:13px;bottom:-1px;height:2.5px;background:var(--gold);border-radius:2px}
.nav-spacer{flex:1}
.brand{display:flex;align-items:center;gap:11px}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-word{font-family:var(--font-display);font-weight:800;font-size:22px;letter-spacing:-.02em;color:var(--text)}
.brand-word .tld{color:var(--gold)}
.brand-tag{font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2);margin-top:4px}
.region{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--muted);
  border:1px solid var(--line-2);border-radius:var(--radius-pill);padding:7px 12px}
.flag-at{width:18px;height:13px;border-radius:2px;overflow:hidden;display:inline-block;box-shadow:0 0 0 1px rgba(0,0,0,.08)}

/* footer */
.footer{border-top:1px solid var(--line);background:var(--bg-2);margin-top:90px}
.footer a{color:var(--muted);font-size:14px;transition:color .15s}
.footer a:hover{color:var(--gold-2)}

/* mobile menu */
.menu-btn{display:none}
@media (max-width:1000px){
  .nav-links{display:none}
  .menu-btn{display:inline-flex}
  .region{display:none}
}
@media (max-width:560px){
  .nav-inner > .btn-gold{display:none}
  .brand-word{font-size:19px}
}

/* section spacing */
.section{padding:72px 0}
.section-sm{padding:52px 0}

/* type sizes */
.t-display{font-size:clamp(38px,6vw,66px)}
.t-h2{font-size:clamp(28px,4vw,42px)}
.t-h3{font-size:clamp(20px,2.4vw,27px)}
.lead{font-size:clamp(17px,2vw,20px);color:var(--muted);line-height:1.6}

/* age gate */
.age18{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  border:2px solid var(--red);color:var(--gold-2);font-weight:800;font-size:12px;font-family:var(--font-display);
}
