/* ==========================================================================
   Eisstocklegenden – Vereinsdesign SC Oberhummel (Grün & Weiß)
   Hell, modern, mobile-first
   ========================================================================== */
:root{
  --green:#4ca62e;        /* Vereinsgrün */
  --green-dark:#3a8523;
  --green-700:#2e6e1b;
  --green-soft:#eaf6e6;
  --ink:#161b14;          /* fast schwarz, Header */
  --ink-2:#23291f;
  --text:#1d2419;
  --muted:#6c7a66;
  --bg:#f4f7f2;
  --card:#ffffff;
  --line:#e1e8db;
  --gold:#e8a91e;
  --red:#d64545;
  --good:#2e9e3f;
  --bad:#d64545;
  --radius:14px;
  --shadow:0 6px 22px rgba(30,60,20,.08);
  --shadow-lg:0 14px 40px rgba(30,60,20,.14);
  --safe-bottom:env(safe-area-inset-bottom,0px);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  min-height:100dvh;
  line-height:1.55;
  padding-bottom:calc(76px + var(--safe-bottom));
  -webkit-text-size-adjust:100%;
}
a{color:var(--green-dark);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3{line-height:1.2;margin:.2em 0 .5em;color:var(--ink)}
h1{font-size:1.55rem;font-weight:800}
h2{font-size:1.2rem;font-weight:700}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---- Topbar (schwarz, wie Vereinsseite) ---- */
.topbar{
  position:sticky;top:0;z-index:50;
  background:var(--ink);
  border-bottom:3px solid var(--green);
}
.topbar-inner{
  max-width:1040px;margin:0 auto;padding:.7rem 1rem;
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.brand{display:flex;align-items:center;gap:.55rem;font-size:1.2rem;color:#fff;font-weight:800;letter-spacing:.3px}
.brand:hover{text-decoration:none}
.brand-mark{
  width:34px;height:34px;display:grid;place-items:center;
  background:var(--green);border-radius:9px;font-size:1.1rem;
}
.brand-text{color:#fff}
.brand-text strong{color:var(--green)}
.nav-desktop{display:none;align-items:center;gap:1.4rem}
.nav-desktop a{color:#dfe7da;font-weight:600;font-size:.95rem}
.nav-desktop a:hover{color:#fff;text-decoration:none}
.nav-user{color:#9fb398;font-size:.9rem}

/* ---- Container ---- */
.container{max-width:1040px;margin:0 auto;padding:1rem 1rem 2rem}

/* ---- Flash ---- */
.flash{padding:.8rem 1rem;border-radius:12px;margin:.6rem 0;border:1px solid var(--line);background:#fff;font-weight:500}
.flash-info{border-left:4px solid var(--green)}
.flash-error{border-left:4px solid var(--red);background:#fdf0f0}
.flash-success{border-left:4px solid var(--good);background:var(--green-soft)}

/* ---- Cards ---- */
.card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.1rem;
  box-shadow:var(--shadow);
  margin-bottom:1rem;
}
.card-link{display:block;color:var(--text);transition:.18s ease}
.card-link:hover{text-decoration:none;box-shadow:var(--shadow-lg);transform:translateY(-3px);border-color:var(--green)}
.grid{display:grid;gap:1rem}
@media(min-width:640px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:repeat(3,1fr)}}

/* ---- Hero (grüner Verlauf, klar) ---- */
.hero{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--green) 0%,var(--green-700) 100%);
  color:#fff;border-radius:20px;
  padding:2.4rem 1.3rem;margin:.3rem 0 1.4rem;
  text-align:center;box-shadow:var(--shadow-lg);
}
.hero::after{
  content:"🥌";position:absolute;right:-10px;bottom:-22px;font-size:7rem;opacity:.14;transform:rotate(-12deg)
}
.hero h1{color:#fff;font-size:2rem;margin:0 0 .4rem}
.hero p{color:#eaf6e6;max-width:44ch;margin:0 auto 1.3rem}
.hero .pill{display:inline-block;padding:.3rem .8rem;border-radius:999px;background:rgba(255,255,255,.18);font-size:.78rem;font-weight:600;margin-bottom:1rem}
.hero .btn-row{justify-content:center}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  padding:.72rem 1.15rem;border-radius:11px;border:1px solid transparent;
  font-weight:700;cursor:pointer;font-size:1rem;text-decoration:none;transition:.15s ease;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-sm{padding:.45rem .8rem;font-size:.85rem}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-dark)}
.btn-accent{background:var(--ink);color:#fff}
.btn-accent:hover{background:#000}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--green);color:var(--green-dark)}
.btn-white{background:#fff;color:var(--green-700)}
.btn-block{display:flex;width:100%}
.btn-row{display:flex;gap:.6rem;flex-wrap:wrap}

/* ---- Forms ---- */
label{display:block;font-size:.85rem;color:var(--muted);margin:.7rem 0 .3rem;font-weight:600}
input,select,textarea{
  width:100%;padding:.78rem .85rem;border-radius:11px;
  border:1px solid var(--line);background:#fff;color:var(--text);font-size:1rem;
}
input:focus,select:focus,textarea:focus{outline:2px solid var(--green);border-color:transparent}
.form-narrow{max-width:420px;margin:0 auto}
.inline-row{display:flex;gap:.5rem;align-items:flex-end}
.inline-row > *{flex:1}

/* ---- Tables ---- */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:.92rem}
th,td{padding:.65rem .5rem;text-align:left;border-bottom:1px solid var(--line);white-space:nowrap}
th{color:var(--muted);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.4px}
tbody tr:hover{background:var(--green-soft)}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.rank{font-weight:800;color:var(--green-dark)}
tbody tr:first-child .rank{color:var(--gold)}

/* ---- Badges ---- */
.badge{display:inline-block;padding:.18rem .6rem;border-radius:999px;font-size:.74rem;font-weight:700;border:1px solid var(--line);background:#fff}
.badge-live{background:#fdecea;border-color:var(--red);color:var(--red)}
.badge-done{background:var(--green-soft);border-color:var(--green);color:var(--green-700)}
.badge-guest{background:#fff7e6;border-color:var(--gold);color:#9a6a0a}
.win{color:var(--good);font-weight:800}
.lose{color:var(--bad);font-weight:800}

/* ---- Scoreboard ---- */
.scoreboard{display:grid;grid-template-columns:1fr auto 1fr;gap:.5rem;align-items:center;text-align:center}
.scoreboard .team{font-weight:700;color:var(--ink)}
.bigscore{font-size:2.4rem;font-weight:800;font-variant-numeric:tabular-nums;color:var(--green-dark)}
.vs{color:var(--muted);font-weight:700}
.kehre-row{display:grid;grid-template-columns:1fr 56px auto 56px 1fr;gap:.4rem;align-items:center;margin:.4rem 0}
.kehre-row input{text-align:center;padding:.55rem .3rem}
.kehre-no{text-align:center;color:var(--muted);font-size:.8rem;font-weight:600}

/* ---- Chips ---- */
.chips{display:flex;flex-wrap:wrap;gap:.4rem;margin:.4rem 0}
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.32rem .7rem;border-radius:999px;background:var(--green-soft);border:1px solid var(--line);font-size:.85rem;font-weight:600;color:var(--ink-2)}
.chip.badge-guest{background:#fff7e6}
.chip form{display:inline}
.chip button{background:none;border:none;color:var(--bad);cursor:pointer;font-size:1rem;padding:0;line-height:1}

/* ---- Section header ---- */
.section-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1.5rem 0 .7rem}
.section-head h1,.section-head h2{margin:0}
.section-head h2{position:relative;padding-left:.7rem}
.section-head h2::before{content:"";position:absolute;left:0;top:.1em;bottom:.1em;width:4px;border-radius:3px;background:var(--green)}

/* ---- Empty state ---- */
.empty{text-align:center;color:var(--muted);padding:2rem 1rem;border:2px dashed var(--line);border-radius:var(--radius);background:#fff}

/* ---- Stat tiles ---- */
.stat-tiles{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem}
@media(min-width:640px){.stat-tiles{grid-template-columns:repeat(4,1fr)}}
.tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1rem;text-align:center;box-shadow:var(--shadow)}
.tile .big{font-size:1.9rem;font-weight:800;color:var(--green-dark)}
.tile .lbl{color:var(--muted);font-size:.8rem;font-weight:600}

/* ---- Quick action tiles (Startseite) ---- */
.actions{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:1rem 0}
.action{
  display:flex;flex-direction:column;gap:.25rem;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:1.1rem;box-shadow:var(--shadow);color:var(--text);transition:.18s ease;
}
.action:hover{text-decoration:none;transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--green)}
.action .ic{font-size:1.7rem}
.action b{color:var(--ink);font-size:1.02rem}
.action span{color:var(--muted);font-size:.82rem}

/* ---- Footer ---- */
.site-footer{
  max-width:1040px;margin:1rem auto 0;padding:1.6rem 1rem;
  text-align:center;color:var(--muted);font-size:.85rem;border-top:1px solid var(--line);
}
.site-footer a{color:var(--green-dark)}

/* ---- Mobile bottom nav ---- */
.nav-mobile{
  position:fixed;bottom:0;left:0;right:0;z-index:60;
  display:flex;justify-content:space-around;
  background:#fff;border-top:1px solid var(--line);
  box-shadow:0 -4px 16px rgba(30,60,20,.08);
  padding:.4rem 0 calc(.4rem + var(--safe-bottom));
}
.nav-mobile a{
  display:flex;flex-direction:column;align-items:center;gap:.1rem;
  color:var(--muted);font-size:.7rem;font-weight:600;padding:.3rem .6rem;flex:1;text-align:center;
}
.nav-mobile a span{font-size:1.3rem}
.nav-mobile a:hover{color:var(--green-dark);text-decoration:none}

/* ---- Desktop ---- */
@media(min-width:780px){
  .nav-desktop{display:flex}
  .nav-mobile{display:none}
  body{padding-bottom:0}
  h1{font-size:1.9rem}
  .hero{padding:3rem 2rem}
  .hero h1{font-size:2.4rem}
}
