/* ============================================================
   UWR Videoanalyse – Stylesheet
   ============================================================ */
:root{
  --deep:#022f40; --mid:#01506a; --teal:#0b8aa6; --aqua:#28c2d6;
  --foam:#d6f3f7; --coral:#ff6b5e; --gold:#ffd166; --green:#7cf29c;
  --ink:#04222e; --panel:rgba(255,255,255,.06); --line:rgba(255,255,255,.14);
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Outfit','Segoe UI',system-ui,sans-serif;
  background:radial-gradient(120% 90% at 70% -10%,#0b8aa6 0%,#01506a 38%,#022f40 100%);
  background-attachment:fixed;color:var(--foam);min-height:100vh;
}
h1,h2,h3{font-family:'Sora','Outfit',sans-serif;letter-spacing:-.5px}
a{color:inherit;text-decoration:none}
small{opacity:.7}

/* ---------- Navigation ---------- */
.nav{background:rgba(2,18,24,.5);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.nav-inner{max-width:1180px;margin:0 auto;padding:12px 18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.brand{font-weight:800;font-size:18px}
.links{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.links a:hover{color:var(--aqua)}
.user{font-size:13px;opacity:.8}
.container{max-width:1180px;margin:0 auto;padding:22px 18px 60px}

/* ---------- Buttons ---------- */
.btn{cursor:pointer;border:none;border-radius:11px;font-weight:700;font-size:15px;padding:11px 18px;
  color:var(--ink);background:linear-gradient(135deg,var(--aqua),var(--gold));transition:.15s}
.btn:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(40,194,214,.3)}
.btn.full{width:100%;margin-top:22px}
.btn-sm{cursor:pointer;background:transparent;border:1px solid var(--line);color:var(--foam);
  padding:7px 12px;border-radius:9px;font-size:13px}
.btn-sm:hover{border-color:var(--aqua)}
.btn-sm.danger:hover{border-color:var(--coral);color:var(--coral)}
.btn-sm.on{background:var(--green);color:var(--ink);border-color:var(--green)}
.ghost{cursor:pointer;background:transparent;border:1px solid var(--line);color:var(--foam);padding:11px;border-radius:11px}
.ghost:hover{border-color:var(--aqua)}

/* ---------- Login ---------- */
.login-bg{display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{width:100%;max-width:390px;background:var(--panel);backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:22px;padding:34px 30px;box-shadow:0 30px 80px rgba(0,0,0,.45)}
.badge{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--aqua);font-weight:700}
.login-card h1{font-size:28px;margin:8px 0 4px}
.sub{opacity:.7;font-size:14px;margin-bottom:22px}
label{display:block;font-size:13px;margin:14px 0 6px;opacity:.85}
input,select{width:100%;padding:12px 13px;border-radius:11px;border:1px solid var(--line);
  background:rgba(0,0,0,.25);color:var(--foam);font-size:15px;outline:none}
input:focus,select:focus{border-color:var(--aqua);box-shadow:0 0 0 3px rgba(40,194,214,.22)}
select option{color:#000}
.err{color:var(--coral);font-size:13px;margin-top:10px}

/* ---------- Seiten ---------- */
.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.page-head h1{font-size:26px}
.flash{padding:11px 14px;border-radius:11px;margin-bottom:16px;font-size:14px}
.flash.ok{background:rgba(124,242,156,.15);border:1px solid var(--green)}
.flash.err{background:rgba(255,107,94,.15);border:1px solid var(--coral)}
.empty-box,.empty{opacity:.6;text-align:center;padding:40px 0}

/* ---------- Video-Grid ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.card-link{background:var(--panel);border:1px solid var(--line);border-radius:16px;overflow:hidden;transition:.18s;display:block}
.card-link:hover{transform:translateY(-4px);border-color:var(--aqua);box-shadow:0 16px 40px rgba(0,0,0,.4)}
.thumb{height:120px;display:flex;align-items:center;justify-content:center;font-size:44px;background:rgba(0,0,0,.25)}
.card-body{padding:14px}
.card-body h3{font-size:16px;margin-bottom:6px}
.meta{font-size:12px;opacity:.7;margin-bottom:10px}
.pill{display:inline-block;background:var(--aqua);color:var(--ink);font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px}
.pill.on{background:var(--green)} .pill.off{background:var(--coral)}

/* ---------- Formulare ---------- */
.form-box{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:20px;max-width:640px;margin-bottom:22px}
.form-box summary{cursor:pointer;margin-bottom:8px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.form-grid{grid-template-columns:1fr}}

/* ---------- Tabelle ---------- */
.tbl{width:100%;border-collapse:collapse;background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.tbl th,.tbl td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
.tbl th{background:rgba(0,0,0,.25);font-size:12px;text-transform:uppercase;letter-spacing:1px}
.tbl tr:last-child td{border-bottom:none}
.inline{display:inline}
.actions{display:flex;gap:6px;flex-wrap:wrap}
.tbl select{width:auto;padding:6px 8px}

/* ---------- Analyse ---------- */
.analyse-layout{display:grid;grid-template-columns:1fr 320px;gap:18px}
@media(max-width:880px){.analyse-layout{grid-template-columns:1fr}}
.stage{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:16px}
.videobox{position:relative;border-radius:12px;overflow:hidden;background:#000;line-height:0}
#video{width:100%;display:block}
#draw{position:absolute;inset:0;width:100%;height:100%;touch-action:none}
.toolbar{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;align-items:center}
.tool{width:42px;height:42px;border-radius:11px;border:1px solid var(--line);background:rgba(0,0,0,.2);
  color:var(--foam);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:.15s}
.tool:hover{border-color:var(--aqua)}
.tool.active{background:linear-gradient(135deg,var(--aqua),var(--teal));color:var(--ink);border-color:transparent}
.swatch{width:30px;height:30px;border-radius:8px;border:2px solid rgba(255,255,255,.4);cursor:pointer}
.swatch.active{border-color:#fff;box-shadow:0 0 0 2px var(--aqua)}
.spacer{flex:1}
.ctrls{display:flex;gap:10px;align-items:center;margin-top:12px;flex-wrap:wrap}
.time{font-variant-numeric:tabular-nums;font-size:14px;opacity:.85}
.hint-text{font-size:12px;opacity:.55;margin-top:8px}

.marker-duration-form{display:flex;align-items:center;gap:8px;margin-top:8px}
.marker-duration-form label{display:flex;align-items:center;gap:8px;margin:0;font-size:12px;opacity:.85}
.marker-duration-form input{width:70px;padding:6px 8px}

.side{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:16px}
.side h3{font-size:16px;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}
.count{background:var(--aqua);color:var(--ink);font-size:12px;font-weight:700;padding:2px 9px;border-radius:20px}
.markerlist{display:flex;flex-direction:column;gap:10px;overflow:auto;max-height:62vh}
.marker{border:1px solid var(--line);border-radius:12px;padding:11px 12px;cursor:pointer;transition:.15s;background:rgba(0,0,0,.18)}
.marker:hover{border-color:var(--aqua);transform:translateX(3px)}
.marker .mt{display:flex;justify-content:space-between;font-size:13px}
.marker .tag{font-weight:700;color:var(--aqua)}
.marker .ts{font-variant-numeric:tabular-nums;opacity:.75}
.marker .note{font-size:13px;opacity:.85;margin-top:4px}
.marker .ppl{font-size:12px;opacity:.7;margin-top:5px}
.marker .author{font-size:11px;opacity:.5;margin-top:5px}
.marker .del{font-size:12px;opacity:.55;cursor:pointer;margin-top:6px;display:inline-block}
.marker .del:hover{opacity:1;color:var(--coral)}

/* ---------- Modal ---------- */
.modal{position:fixed;inset:0;background:rgba(2,18,24,.7);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal.show{display:flex}
.situations{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.chip{padding:7px 12px;border:1px solid var(--line);border-radius:20px;font-size:13px;cursor:pointer}
.chip.active{background:var(--aqua);color:var(--ink);border-color:transparent;font-weight:700}
.row{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ---------- Footer ---------- */
.foot{text-align:center;padding:24px;font-size:13px;opacity:.5;border-top:1px solid var(--line)}

/* ---------- Taktikboard 3D ---------- */
.tactic-wrap{display:grid;grid-template-columns:1fr 300px;gap:18px}
@media(max-width:880px){.tactic-wrap{grid-template-columns:1fr}}
.tactic-stage{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:10px;position:relative}
#scene{width:100%;height:520px;border-radius:12px;overflow:hidden;cursor:grab}
#scene:active{cursor:grabbing}
.scene-hint{position:absolute;left:18px;bottom:16px;font-size:12px;opacity:.7;
  background:rgba(2,18,24,.55);padding:6px 10px;border-radius:8px;pointer-events:none}
.tactic-panel{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:16px}
.tactic-panel h3{font-size:15px;margin-bottom:10px}
.tactic-panel label{font-size:13px}
.tactic-panel input[type=range]{width:100%;accent-color:var(--aqua)}
.divider{height:1px;background:var(--line);margin:16px 0}
.sel-info{background:rgba(0,0,0,.2);border:1px solid var(--line);border-radius:10px;padding:10px;font-size:14px;margin-bottom:10px}
.btn-sm.full{width:100%;text-align:center}
.play-row{display:flex;gap:8px;align-items:center;margin-bottom:12px}
.view-row{display:flex;gap:6px;flex-wrap:wrap}

/* ---------- Taktik: Aktionsliste mit Startzeiten ---------- */
.act-empty{font-size:12px;opacity:.6;margin-top:8px}
.act-list{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.act-row{display:flex;align-items:center;gap:6px;font-size:13px;
  background:rgba(0,0,0,.2);border:1px solid var(--line);border-radius:8px;padding:6px 8px}
.act-lbl{flex:1}
.act-time{display:flex;align-items:center;gap:4px;opacity:.85}
.act-time .tinp{width:54px;padding:3px 5px;border-radius:6px;font-size:12px}
.act-del{cursor:pointer;opacity:.5;padding:0 2px}
.act-del:hover{opacity:1;color:var(--coral)}
.play-row .time{font-variant-numeric:tabular-nums;font-size:14px;opacity:.85;margin-left:auto}

/* Tempo-Auswahl in Aktionszeile */
.act-row .pinp{padding:3px 5px;border-radius:6px;font-size:12px;width:auto}

/* ---------- YouTube-Player ---------- */
#ytplayer{width:100%;aspect-ratio:16/9;display:block}
#ytplayer iframe{width:100%;height:100%}

/* ---------- Upload-Quellenwahl ---------- */
.src-toggle{display:flex;gap:18px;margin:6px 0 4px}
.src-opt{display:flex;align-items:center;gap:6px;font-size:14px;opacity:.9;cursor:pointer}
.src-opt input{width:auto}

/* ---------- Kommentare ---------- */
.comments{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px;margin-top:18px}
.comments h3{font-size:16px;margin-bottom:12px}
.comment-form{display:flex;gap:10px;align-items:flex-start;margin-bottom:16px}
.comment-form textarea{flex:1;padding:10px 12px;border-radius:11px;border:1px solid var(--line);
  background:rgba(0,0,0,.25);color:var(--foam);font:inherit;resize:vertical}
.comment-list{display:flex;flex-direction:column;gap:12px}
.comment{display:flex;gap:14px;border:1px solid var(--line);border-radius:12px;padding:12px;background:rgba(0,0,0,.18)}
.c-vote{display:flex;flex-direction:column;align-items:center;gap:2px;min-width:40px}
.vbtn{cursor:pointer;background:transparent;border:1px solid var(--line);color:var(--foam);
  border-radius:8px;width:30px;height:26px;font-size:13px;line-height:1}
.vbtn:hover{border-color:var(--aqua)}
.vbtn.up.on{background:var(--green);color:var(--ink);border-color:transparent}
.vbtn.down.on{background:var(--coral);color:var(--ink);border-color:transparent}
.score{font-weight:700;font-variant-numeric:tabular-nums;font-size:15px}
.c-main{flex:1}
.c-meta{font-size:12px;opacity:.7;margin-bottom:5px}
.c-body{font-size:14px;white-space:pre-wrap;word-break:break-word}
.c-actions{display:flex;gap:14px;align-items:center;margin-top:8px}
.c-stat{font-size:12px;opacity:.7}
.c-del{font-size:12px;opacity:.6;cursor:pointer}
.c-del:hover{opacity:1;color:var(--coral)}

/* YouTube-Thumbnail in der Übersicht */
.thumb.yt{background-size:cover;background-position:center;position:relative}
.yt-badge{position:absolute;left:8px;bottom:8px;background:rgba(255,0,0,.85);color:#fff;
  font-size:11px;font-weight:700;padding:2px 7px;border-radius:5px}

/* ---------- Abschnittstitel ---------- */
.sec-title{font-size:18px;margin:22px 0 12px}

/* ---------- Mitglieder ---------- */
.member-photo{width:60px;height:60px;border-radius:50%;object-fit:cover;flex-shrink:0;border:2px solid var(--line)}
.member-photo.ph{display:flex;align-items:center;justify-content:center;font-size:28px;background:rgba(0,0,0,.25)}
.member-edit{display:grid;grid-template-columns:1fr;gap:14px;max-width:680px;margin-top:12px}
.member-photo-row{display:flex;gap:16px;align-items:center;margin-bottom:12px}
.member-photo-lg{width:90px;height:90px;border-radius:14px;object-fit:cover;border:2px solid var(--line)}
.member-photo-lg.ph{display:flex;align-items:center;justify-content:center;font-size:40px;background:rgba(0,0,0,.25)}
.member-edit textarea{width:100%;padding:10px 12px;border-radius:11px;border:1px solid var(--line);
  background:rgba(0,0,0,.25);color:var(--foam);font:inherit;resize:vertical}
.season-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:center;margin-bottom:14px}
.season-grid label{display:flex;align-items:center;gap:8px;font-size:14px}
.season-grid input[type=checkbox]{width:auto}

/* ---------- Präsenz-Status ---------- */
.status-pick{display:flex;gap:6px;flex-wrap:wrap}
.st-opt{display:flex;align-items:center;gap:4px;font-size:12px;padding:4px 8px;border:1px solid var(--line);
  border-radius:8px;cursor:pointer}
.st-opt input{width:auto}
.st-badge{font-size:12px}
.st-anwesend{border-color:#7cf29c}
.st-entschuldigt{border-color:#ffd166}
.st-unentschuldigt{border-color:#ff6b5e}
.st-verletzt{border-color:#28c2d6}
.pill.st-anwesend{background:#7cf29c;color:#04222e}
.pill.st-entschuldigt{background:#ffd166;color:#04222e}
.pill.st-unentschuldigt{background:#ff6b5e;color:#04222e}
.pill.st-verletzt{background:#28c2d6;color:#04222e}

/* ---------- Anwesenheits-Slider (3-Wege: Abwesend/Entschuldigt/Anwesend) ---------- */
.att-slider{display:flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;
  max-width:280px;font-size:12px;font-weight:700;user-select:none;background:rgba(0,0,0,.25)}
.att-slider .att-opt{flex:1;text-align:center;padding:7px 6px;cursor:pointer;color:var(--foam);
  transition:background .15s,color .15s;white-space:nowrap}
.att-slider[data-pos="0"] .att-opt.att-no{background:var(--coral);color:#04222e}
.att-slider[data-pos="1"] .att-opt.att-exc{background:var(--gold);color:#04222e}
.att-slider[data-pos="2"] .att-opt.att-yes{background:var(--green);color:#04222e}
.att-save-indicator{display:inline-block;margin-left:8px;font-size:12px;color:var(--green);
  opacity:0;transition:opacity .3s;vertical-align:middle}
.att-save-indicator.show{opacity:1}

/* ---------- Präsenz-Schnellerfassung (mobil) ---------- */
.att-quick-trainings{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.att-quick-trainings a.active{background:var(--aqua);color:var(--ink);border-color:var(--aqua)}
.att-quick-list{display:flex;flex-direction:column;gap:8px}
.att-quick-row{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:10px 14px}
.att-quick-row .name{font-weight:600;flex:1;min-width:120px}

/* ---------- Marker-Filter & Taktik-Link ---------- */
.marker-filter{margin-bottom:10px;padding:8px 10px;font-size:13px}
.marker-tactic{display:inline-block;margin-top:6px;font-size:12px;color:var(--gold);text-decoration:underline}
.marker-tactic:hover{color:#fff}

/* ---------- Dashboard ---------- */
.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.dash-card{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:16px}
.dash-card h3{font-size:15px;margin-bottom:12px}
.dash-sub{font-size:12px;opacity:.7;margin-top:8px}
.dash-list{list-style:none;display:flex;flex-direction:column;gap:6px;font-size:14px}
.dash-quote{display:flex;align-items:center;gap:12px}
.dash-quote-num{font-size:24px;font-weight:800}
.tbl.compact td{padding:7px 10px;font-size:13px}

/* ---------- Quote-Balken ---------- */
.quote-bar{flex:1;height:10px;background:rgba(0,0,0,.3);border-radius:6px;overflow:hidden;display:inline-block;min-width:80px;vertical-align:middle}
.quote-bar.big{height:16px}
.quote-fill{height:100%;border-radius:6px}
.q-good{background:var(--green)} .q-mid{background:var(--gold)} .q-low{background:var(--coral)}
.quote-num{margin-left:8px;font-variant-numeric:tabular-nums;font-size:13px}

/* ---------- Kalender ---------- */
.event-list{display:flex;flex-direction:column;gap:10px}
.event-card{display:flex;gap:14px;align-items:center;background:var(--panel);border:1px solid var(--line);
  border-left-width:4px;border-radius:12px;padding:12px 14px}
.event-card.cat-wettkampf{border-left-color:var(--coral)}
.event-card.cat-turnier{border-left-color:var(--gold)}
.event-card.cat-event{border-left-color:var(--aqua)}
.event-card.cat-sitzung{border-left-color:var(--green)}
.event-card.cat-sonstiges{border-left-color:var(--line)}
.event-cat{font-size:11px;text-transform:uppercase;letter-spacing:1px;opacity:.7;min-width:80px}
.event-main{flex:1}
.event-title{font-weight:700}
.event-meta{font-size:13px;opacity:.8;margin-top:2px}
.event-desc{font-size:13px;opacity:.7;margin-top:4px}

/* ---------- Galerie: Upload-Dropzone ---------- */
.dropzone{border:2px dashed var(--line);border-radius:14px;padding:30px 16px;text-align:center;
  cursor:pointer;transition:.2s;margin-bottom:18px}
.dropzone:hover,.dropzone.drag{border-color:var(--aqua);background:rgba(40,194,214,.08)}
.dropzone strong{color:var(--aqua)}
.upload-status{margin-top:10px;font-size:13px;opacity:.85;min-height:18px}

/* ---------- Foto-Raster ---------- */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.photo-item{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  display:flex;flex-direction:column}
.photo-item img{width:100%;height:140px;object-fit:cover;display:block;background:#000}
.photo-item.is-approved{border-color:var(--green)}
.photo-bar{display:flex;justify-content:space-between;gap:6px;font-size:11px;opacity:.8;padding:6px 8px}
.photo-state{white-space:nowrap}
.photo-actions{display:flex;gap:6px;padding:0 8px 8px;flex-wrap:wrap}
.photo-desc{display:flex;flex-direction:column;gap:6px;padding:0 8px 8px}
.photo-desc textarea{width:100%;padding:8px 10px;border-radius:9px;border:1px solid var(--line);
  background:rgba(0,0,0,.25);color:var(--foam);font:inherit;font-size:13px;resize:vertical}

/* ---------- Öffentliche Galerie-Tabs ---------- */
.gal-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.gal-tab{padding:8px 14px;border:1px solid var(--line);border-radius:20px;font-size:14px}
.gal-tab.active{background:linear-gradient(135deg,var(--aqua),var(--teal));color:var(--ink);border-color:transparent;font-weight:700}
.gal-tab .count{opacity:.7;font-size:12px;margin-left:4px}
.photo-grid.public .photo-item img{height:170px}
