/* ===========================================================================
   ToniTipp – Style (dunkler Sportwetten-Look, eigenes Branding)
   =========================================================================== */
:root{
  --bg:#0d1117; --surface:#161b22; --surface2:#1c232d; --line:#232b36;
  --red:#e4112d; --red-deep:#b50d22; --green:#1fd17a; --blue:#3aa0ff; --amber:#ffb020;
  --text:#f2f4f7; --muted:#8a93a3; --muted2:#5f6877;
  --radius:14px; --shadow:0 8px 26px rgba(0,0,0,.45);
  --tap:#1f2733;
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--text);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased; overscroll-behavior-y:none;
}
.boot{display:grid;place-items:center;height:100vh;color:var(--muted);font-weight:600}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
.tnum{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

/* ---- App-Grundgerüst ---------------------------------------------------- */
.app{min-height:100vh;display:flex;flex-direction:column;max-width:560px;margin:0 auto;position:relative}
.scroll{flex:1;overflow-y:auto;padding:14px 14px 96px;-webkit-overflow-scrolling:touch}

/* ---- Top-Bar ------------------------------------------------------------ */
.topbar{
  position:sticky;top:0;z-index:20;
  padding:calc(var(--safe-top) + 12px) 14px 12px;
  background:linear-gradient(180deg,#11161d 0%, #0d1117 100%);
  border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:12px;
}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.logo{
  width:38px;height:38px;border-radius:10px;background:#0d1117;position:relative;flex:none;
  display:grid;place-items:center;font-weight:900;letter-spacing:-1px;font-size:16px;
  box-shadow:inset 0 0 0 1px #2a323d; overflow:hidden;
}
.logo::after{content:"";position:absolute;left:0;right:0;bottom:0;height:42%;
  background:var(--red);clip-path:polygon(0 100%,100% 100%,100% 28%)}
.logo span{position:relative;z-index:1}
.brand h1{font-size:18px;margin:0;font-weight:800;letter-spacing:-.3px;line-height:1}
.brand p{margin:2px 0 0;font-size:11px;color:var(--muted);font-weight:600;
  text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.spacer{flex:1}
.me-chip{display:flex;align-items:center;gap:8px;background:var(--surface2);
  padding:6px 10px 6px 6px;border-radius:999px;border:1px solid var(--line)}
.me-chip .av{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:15px;background:#0d1117}
.me-chip b{font-size:13px;font-weight:700}
.me-chip .out{font-size:11px;color:var(--muted);font-weight:700;padding-left:2px}

/* ---- Segment-Filter (Spieltage / Gruppen) ------------------------------- */
.segwrap{display:flex;gap:8px;overflow-x:auto;padding:12px 14px 4px;scrollbar-width:none}
.segwrap::-webkit-scrollbar{display:none}
.seg{flex:none;padding:8px 14px;border-radius:999px;background:var(--surface);border:1px solid var(--line);
  font-weight:700;font-size:13px;color:var(--muted);white-space:nowrap;transition:.15s}
.seg.active{background:var(--text);color:#0d1117;border-color:var(--text)}

/* ---- Match-Karte -------------------------------------------------------- */
.match{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  margin-bottom:12px;overflow:hidden;position:relative;
}
.match::before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--line)}
.match.open::before{background:var(--red)}
.match.done::before{background:var(--green)}
.match .head{display:flex;align-items:center;gap:8px;padding:9px 14px;border-bottom:1px solid var(--line);
  font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.match .head .grp{background:var(--surface2);padding:2px 8px;border-radius:6px;color:var(--text)}
.match .head .ko{margin-left:auto;font-weight:600;text-transform:none;letter-spacing:0}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--red);animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

.teams{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px;padding:14px}
.team{display:flex;align-items:center;gap:8px;min-width:0}
.team.away{justify-content:flex-end}
.team .fl{font-size:22px;line-height:1;flex:none}
.team .nm{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.vs{font-weight:800;color:var(--muted2);font-size:12px}

/* Ergebnis-Anzeige (gespielt) */
.scorebox{display:flex;align-items:center;justify-content:center;gap:8px;min-width:78px}
.scorebox .sc{font-size:24px;font-weight:900;letter-spacing:-1px}
.scorebox .dash{color:var(--muted2);font-weight:800}

/* ---- Tipp-Stepper (Signature) ------------------------------------------ */
.tipper{display:flex;align-items:center;justify-content:center;gap:14px;padding:4px 14px 16px}
.stepper{display:flex;align-items:center;gap:8px}
.stepper button{
  width:34px;height:34px;border-radius:9px;background:var(--surface2);border:1px solid var(--line);
  font-size:20px;font-weight:800;color:var(--text);display:grid;place-items:center;line-height:0;
  transition:transform .06s, background .15s;
}
.stepper button:active{transform:scale(.9);background:var(--tap)}
.stepper .val{
  width:44px;height:46px;border-radius:10px;background:#0d1117;border:1px solid var(--line);
  display:grid;place-items:center;font-size:26px;font-weight:900;letter-spacing:-1px;
}
.tipsep{font-weight:900;color:var(--muted2);font-size:22px}

.match .actions{display:flex;gap:10px;padding:0 14px 14px}
.btn{
  flex:1;height:44px;border-radius:11px;font-weight:800;font-size:15px;
  display:grid;place-items:center;transition:.12s;letter-spacing:.2px;
}
.btn.primary{background:var(--red);color:#fff;box-shadow:0 6px 16px rgba(228,17,45,.32)}
.btn.primary:active{transform:translateY(1px);box-shadow:0 3px 10px rgba(228,17,45,.3)}
.btn.ghost{background:var(--surface2);border:1px solid var(--line);color:var(--text)}
.btn.saved{background:rgba(31,209,122,.14);color:var(--green);border:1px solid rgba(31,209,122,.35);box-shadow:none}
.btn:disabled{opacity:.5}

/* Punkte-Chip & Tipps der anderen */
.result-row{padding:0 14px 14px;display:flex;flex-direction:column;gap:8px}
.pts-chip{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;
  padding:5px 11px;border-radius:999px;font-weight:800;font-size:13px}
.pts-4{background:rgba(31,209,122,.16);color:var(--green)}
.pts-3{background:rgba(58,160,255,.16);color:var(--blue)}
.pts-2{background:rgba(255,176,32,.16);color:var(--amber)}
.pts-0{background:rgba(138,147,163,.14);color:var(--muted)}
.others{display:flex;flex-direction:column;gap:6px;border-top:1px dashed var(--line);padding-top:10px}
.orow{display:flex;align-items:center;gap:8px;font-size:13px}
.orow .av{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:13px;background:#0d1117}
.orow .nm{font-weight:700;flex:1;color:var(--muted)}
.orow .ot{font-weight:800;font-variant-numeric:tabular-nums}
.orow .op{font-weight:800;font-size:12px;color:var(--muted2)}

.locked-tag{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}

/* ---- Tabelle ------------------------------------------------------------ */
.standings{display:flex;flex-direction:column;gap:10px}
.srow{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:14px;position:relative;overflow:hidden}
.srow .rank{width:30px;font-size:20px;font-weight:900;color:var(--muted2);text-align:center}
.srow.r1 .rank{color:#ffd45e}
.srow.r1{border-color:rgba(255,212,94,.4)}
.srow .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-size:22px;background:#0d1117;flex:none}
.srow .who{flex:1;min-width:0}
.srow .who b{font-size:16px;font-weight:800;display:block}
.srow .who small{color:var(--muted);font-size:12px;font-weight:600}
.srow .pts{text-align:right}
.srow .pts .n{font-size:26px;font-weight:900;letter-spacing:-1px;line-height:1}
.srow .pts .l{font-size:10px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.6px}

.statgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:14px 0 6px}
.stat{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px;text-align:center}
.stat .n{font-size:20px;font-weight:900}
.stat .l{font-size:10px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-top:2px}

/* ---- Section-Titel ------------------------------------------------------ */
.eyebrow{font-size:11px;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:1px;margin:18px 2px 10px}
.eyebrow:first-child{margin-top:4px}

/* ---- Admin -------------------------------------------------------------- */
.syncpanel{background:linear-gradient(135deg,#1a2230,#141a22);border:1px solid var(--line);
  border-radius:var(--radius);padding:14px;margin-bottom:12px;position:relative;overflow:hidden}
.syncpanel::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;
  background:radial-gradient(circle,rgba(228,17,45,.18),transparent 70%)}
.syncpanel-top{display:flex;align-items:center;gap:12px;justify-content:space-between;position:relative;z-index:1}
.sp-title{font-weight:800;font-size:15px}
.sp-sub{font-size:12px;color:var(--muted);font-weight:600;margin-top:3px}
.auto-badge{background:rgba(58,160,255,.16);color:var(--blue);font-weight:800;font-size:9px;
  letter-spacing:.5px;padding:2px 6px;border-radius:5px}
.admin-hint{background:rgba(228,17,45,.08);border:1px solid rgba(228,17,45,.25);color:#ffb3bd;
  padding:10px 12px;border-radius:12px;font-size:13px;font-weight:600;margin-bottom:12px}
.match .admin-res{display:flex;gap:10px;align-items:center;padding:0 14px 14px}
.match .admin-res .stepper .val{background:#0d1117}

/* ---- Bottom-Nav --------------------------------------------------------- */
.tabbar{
  position:fixed;left:0;right:0;bottom:0;z-index:30;
  max-width:560px;margin:0 auto;
  background:rgba(15,19,26,.92);backdrop-filter:saturate(140%) blur(12px);
  border-top:1px solid var(--line);
  display:flex;padding:6px 8px calc(6px + var(--safe-bot));
}
.tabbar button{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;
  color:var(--muted);font-size:11px;font-weight:700;position:relative;transition:color .15s}
.tabbar button .ic{font-size:20px;line-height:1}
.tabbar button.active{color:var(--text)}
.tabbar button.active .ic{transform:translateY(-1px)}
.tabbar button.active::before{content:"";position:absolute;top:0;width:26px;height:3px;border-radius:3px;background:var(--red)}

/* ---- Login -------------------------------------------------------------- */
.login{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:24px 22px calc(40px + var(--safe-bot));max-width:560px;margin:0 auto}
.login .llogo{width:64px;height:64px;border-radius:18px;background:#0d1117;position:relative;overflow:hidden;
  display:grid;place-items:center;font-weight:900;font-size:28px;letter-spacing:-2px;box-shadow:inset 0 0 0 1px #2a323d;margin-bottom:18px}
.login .llogo::after{content:"";position:absolute;left:0;right:0;bottom:0;height:42%;background:var(--red);clip-path:polygon(0 100%,100% 100%,100% 28%)}
.login .llogo span{position:relative;z-index:1}
.login h2{font-size:26px;margin:0 0 4px;font-weight:900;letter-spacing:-.5px}
.login .sub{color:var(--muted);font-weight:600;margin:0 0 26px}
.userpick{display:flex;flex-direction:column;gap:10px;margin-bottom:8px}
.ubtn{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line);
  border-radius:14px;padding:14px 16px;transition:.15s;text-align:left}
.ubtn:active{background:var(--surface2)}
.ubtn.sel{border-color:var(--red);background:rgba(228,17,45,.06)}
.ubtn .av{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:24px;background:#0d1117;flex:none}
.ubtn .nm{font-weight:800;font-size:17px;flex:1}
.ubtn .chk{color:var(--red);font-weight:900;font-size:20px;opacity:0;transition:.15s}
.ubtn.sel .chk{opacity:1}

.pinpad{margin-top:18px}
.pindots{display:flex;gap:12px;justify-content:center;margin-bottom:18px;height:16px}
.pindot{width:14px;height:14px;border-radius:50%;background:var(--surface2);border:1px solid var(--line);transition:.12s}
.pindot.on{background:var(--red);border-color:var(--red)}
.keys{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.key{height:56px;border-radius:14px;background:var(--surface);border:1px solid var(--line);
  font-size:24px;font-weight:800;display:grid;place-items:center;transition:transform .06s,background .12s}
.key:active{transform:scale(.95);background:var(--surface2)}
.key.fn{font-size:15px;font-weight:700;color:var(--muted)}
.login .err{color:#ff6b7a;font-weight:700;text-align:center;min-height:20px;margin-top:14px}
.login .nopin{margin-top:18px}

/* ---- Toast & Diverses --------------------------------------------------- */
.toast{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(86px + var(--safe-bot));
  background:#fff;color:#0d1117;font-weight:800;font-size:14px;padding:11px 18px;border-radius:999px;
  box-shadow:var(--shadow);z-index:50;opacity:0;transition:.2s;pointer-events:none;max-width:90%}
.toast.show{opacity:1;transform:translateX(-50%) translateY(-4px)}
.toast.ok{background:var(--green);color:#06281a}
.toast.bad{background:var(--red);color:#fff}
.empty{text-align:center;color:var(--muted);padding:60px 20px;font-weight:600}
.empty .big{font-size:38px;margin-bottom:10px}

@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
