/* =========================================================
   JGV Bell – Spielhalle (Look der Vereinsseite jgv-bell.de)
   Navy #0b1220 · Grün #004f0d · Gelb #ffe201 · Plus Jakarta Sans
   ========================================================= */
:root{
  --bg:#0b1220;
  --bg-2:#0a101c;
  --panel:#0f1a2e;
  --green:#004f0d;
  --green-bright:#0a7d1c;
  --accent:#ffe201;
  --accent-2:#ffd000;
  --accent-soft:rgba(255,226,1,.12);
  --text:#e9edf2;
  --muted:rgba(233,237,242,.66);
  --line:rgba(255,255,255,.10);
  --line-strong:rgba(255,255,255,.18);
  --max:1140px;
  --header-h:72px;
  --r:16px;
  --r-lg:22px;
  --pill:999px;
  --shadow:0 22px 50px rgba(0,0,0,.45);
  --shadow-sm:0 10px 26px rgba(0,0,0,.32);
  --font:"Plus Jakarta Sans",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.65;
  overflow-x:hidden;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}

/* ---------- Hintergrund ---------- */
.bg-mesh{
  position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(70% 55% at 50% -10%, rgba(0,79,13,.30), transparent 60%),
    radial-gradient(50% 40% at 90% 10%, rgba(255,226,1,.05), transparent 55%),
    linear-gradient(180deg,#0b1220,#080d17);
}
.bg-grain{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:radial-gradient(rgba(255,255,255,.022) 1px, transparent 1px);
  background-size:30px 30px;
  -webkit-mask-image:radial-gradient(130% 90% at 50% 0%, #000, transparent 82%);
  mask-image:radial-gradient(130% 90% at 50% 0%, #000, transparent 82%);
}
.orb{position:fixed;border-radius:50%;filter:blur(90px);z-index:-1;opacity:.18;animation:drift 22s ease-in-out infinite alternate}
.orb.o1{width:400px;height:400px;left:-130px;top:-70px;background:radial-gradient(circle,#0a7d1c,transparent 70%)}
.orb.o2{width:300px;height:300px;right:-100px;top:34%;background:radial-gradient(circle,#ffe201,transparent 70%);opacity:.08;animation-delay:-7s}
.orb.o3{width:440px;height:440px;left:34%;bottom:-190px;background:radial-gradient(circle,#004f0d,transparent 70%);opacity:.4;animation-delay:-12s}
@keyframes drift{to{transform:translateY(38px)}}

/* ---------- Layout ---------- */
.wrap{width:min(var(--max),92vw);margin-inline:auto}

/* ---------- Header (grün wie Original) ---------- */
.site-header{
  position:sticky;top:0;z-index:100;height:var(--header-h);display:flex;align-items:center;
  background:var(--green);
  box-shadow:0 2px 0 rgba(255,226,1,.5), 0 8px 24px rgba(0,0,0,.35);
}
.nav{display:flex;align-items:center;justify-content:space-between;width:min(var(--max),92vw);margin-inline:auto;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none;color:#fff}
.brand .crest{
  width:42px;height:42px;flex:0 0 auto;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(150deg,#0a9622,#024a0c);
  color:var(--accent);font-weight:800;font-size:.92rem;letter-spacing:.3px;
  border:1.5px solid rgba(255,226,1,.55);box-shadow:inset 0 1px 0 rgba(255,255,255,.25);
}
.brand .bt{font-weight:800;font-size:1.04rem;line-height:1.1;letter-spacing:.2px}
.brand .bt b{color:var(--accent)}
.brand small{display:block;font-size:.62rem;font-weight:600;color:rgba(255,255,255,.7);letter-spacing:1.5px;text-transform:uppercase;margin-top:2px}
.nav-cta{
  padding:.55rem 1.2rem;border-radius:var(--pill);font-weight:700;font-size:.88rem;text-decoration:none;
  background:var(--accent);color:#1a1400;border:1.5px solid var(--accent);transition:transform .25s,box-shadow .25s;
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(255,226,1,.35)}

/* ---------- Hero ---------- */
.hero{padding:4.5rem 0 1rem;text-align:center}
.kicker{color:var(--accent);font-weight:700;font-size:.78rem;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:.8rem;display:block}
.hero h1{font-size:clamp(2rem,5vw,3rem);font-weight:800;letter-spacing:-.5px;line-height:1.12;color:#fff;margin-bottom:1rem}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero p{color:var(--muted);font-size:1.06rem;max-width:560px;margin-inline:auto}

/* ---------- Kacheln ---------- */
.tile-section{padding:3rem 0 4.5rem}
.tile-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.tile{
  position:relative;display:flex;flex-direction:column;padding:1.8rem;border-radius:var(--r-lg);overflow:hidden;
  background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);box-shadow:var(--shadow-sm);
  text-decoration:none;color:var(--text);transition:.4s var(--ease);
}
.tile::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green-bright),var(--accent));transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease)}
.tile:not(.tile-soon):hover{transform:translateY(-8px);border-color:var(--line-strong);box-shadow:var(--shadow)}
.tile:not(.tile-soon):hover::before{transform:scaleX(1)}
.tile .tile-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.tile .cat{font-size:.7rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);padding:.28rem .7rem;border-radius:var(--pill);background:var(--accent-soft);border:1px solid rgba(255,226,1,.28)}
.tile .tnum{font-size:1.6rem;line-height:1}
.tile h3{font-size:1.3rem;font-weight:700;color:#fff;margin-bottom:.5rem}
.tile p{color:var(--muted);font-size:.96rem;flex:1}
/* Top-3-Mini-Bestenliste in der Kachel */
.top3{list-style:none;margin:1rem 0 .2rem;padding:.6rem .8rem;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid var(--line)}
.top3 li{display:flex;align-items:center;gap:.5rem;padding:.28rem 0;font-size:.86rem}
.top3 li+li{border-top:1px solid var(--line)}
.top3 .medal{flex:0 0 1.4rem;text-align:center}
.top3 .t3-name{flex:1;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.top3 .t3-pts{font-weight:800;color:var(--accent)}
.top3 .t3-empty{color:var(--muted);font-style:italic;justify-content:center;display:flex}

.tile .more{margin-top:1rem;color:var(--accent);font-weight:700;font-size:.88rem;display:inline-flex;gap:.4rem;align-items:center}
.tile .more.muted{color:var(--muted)}
.tile .arrow{transition:transform .3s}
.tile:hover .more .arrow{transform:translateX(4px)}
.tile-soon{opacity:.6;cursor:default}

/* ---------- Footer (grün wie Original) ---------- */
.site-footer{margin-top:auto;background:var(--green);color:rgba(255,255,255,.85);border-top:3px solid var(--accent);padding:1.8rem 0}
.footer-bottom{text-align:center;color:rgba(255,255,255,.75);font-size:.86rem}

/* ---------- Responsiv ---------- */
@media (max-width:860px){ .tile-row{grid-template-columns:1fr} }
@media (max-width:520px){
  .brand small{display:none}
  .nav-cta{padding:.45rem .9rem;font-size:.8rem}
}
@media (prefers-reduced-motion:reduce){ .orb{animation:none} }
