:root{
  --bg:#f2f6fb; --row-even:#fff; --row-odd:#f7fafc;
  --text:#0e1b2b; --divider:#cfd7e3; --accent:#0f6fff; --radius:12px; --rowH:86px;
  --ct-sz:#0ea5e9; --ct-w:#f59e0b; --ct-z:#7c3aed; --ct-a:#ef4444;
}

html,body{height:100%}
body{
  margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);
  background:#10131a linear-gradient(180deg,#10131a,#121828 50%,#0e1424);min-height:100vh;display:flex;flex-direction:column
}
.app{flex:1 0 auto;display:grid;grid-template-columns:380px 1fr;gap:18px;padding:18px;box-sizing:border-box;align-items:start}

.panel{background:#0f1628;color:#e5ecf8;border:1px solid #1f2b46;border-radius:14px;padding:16px;position:sticky;top:18px}
.panel .row{display:flex;gap:8px;align-items:center;margin:8px 0}
.panel input[type="text"],.panel input[type="number"],.panel select{background:#0b1222;border:1px solid #223055;color:#e5ecf8;border-radius:8px;padding:8px 10px}
.btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 14px;cursor:pointer;font-weight:600}
.btn.secondary{background:#223055}
.btn:disabled{opacity:.6;cursor:not-allowed}
.sep{border:none;border-top:1px solid #253052;margin:14px 0}
.note{font-size:12px;color:#a9b6cb}
.subhead{margin-top:12px;margin-bottom:6px;font-size:12px;color:#a9b6cb;text-transform:uppercase;letter-spacing:.04em}

/* Sekcje i pomoc */
.sec,.help{margin-top:12px;background:#0b1222;border:1px solid #223055;border-radius:12px;padding:10px}
.sec summary,.help summary{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:800;color:#e5ecf8;list-style:none}
.sec summary::-webkit-details-marker,.help summary::-webkit-details-marker{display:none}
.chev{transition:transform .2s ease}
.sec[open] .chev,.help[open] .chev{transform:rotate(180deg)}
.help-grid{margin-top:10px;display:grid;gap:10px}
.help-sec{background:#0f1628;border:1px dashed #223055;border-radius:10px;padding:8px 10px;color:#d7e1f3}
.help-sec h4{margin:0 0 6px;font-size:12px;color:#a9b6cb;text-transform:uppercase;letter-spacing:.04em}
.help-sec ul{margin:0;padding-left:18px}
.help-sec li{margin:4px 0;font-size:13px;line-height:1.25}

/* STAGE */
.stage-wrap{overflow:auto;background:#0b1222;border:1px solid #1f2b46;border-radius:14px}
.stage{box-sizing:border-box;width:1920px;height:1080px;padding:24px;background:var(--bg);display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.title{font-weight:800;font-size:38px;color:#10243a}
.stage.exporting .row-actions{display:none!important}

/* BOARD */
.board{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:0 6px 24px rgba(16,24,40,.08);flex:1;display:flex;flex-direction:column;min-height:0}
.board-header{
  display:grid;grid-template-columns:110px 140px 160px 1fr 150px; /* większy odstęp flagi od nazwiska */
  align-items:center;padding:0 16px;height:76px;border-bottom:1px solid var(--divider);
  font-weight:700;font-size:20px;color:#334155;background:#f8fafc; column-gap:18px;
}
.header-right{text-align:center;display:flex;align-items:center;justify-content:center;gap:8px}
.sort-btn{background:#e2e8f0;border:1px solid #cbd5e1;color:#0b2239;padding:4px 8px;border-radius:8px;font-size:12px;cursor:pointer}

/* ROWS */
#rows{flex:1;min-height:0;display:grid;grid-auto-rows:var(--rowH)}
.row-item{
  position:relative;display:grid;grid-template-columns:110px 140px 160px 1fr 150px; /* większy odstęp flagi od nazwiska */
  align-items:center;gap:18px;padding:0 16px;border-bottom:1px solid #eef2f7
}
.row-item:nth-child(odd){background:#f7fafc}
.row-item:nth-child(even){background:#fff}
.row-item.selected{outline:3px solid rgba(15,111,255,.45);outline-offset:-3px}
.row-item.db-over{outline:3px dashed #0f6fff;outline-offset:-3px}

.pos{font-weight:800;font-size:28px;color:#243244;display:flex;gap:10px;align-items:center;justify-content:flex-start;cursor:grab;user-select:none}
.club{display:flex;align-items:center;gap:12px}
.logo{width:64px;height:64px;object-fit:contain;background:#f2f4f7;border-radius:12px;border:1px solid #e5e8ef}
.cc{display:inline-flex;align-items:center;justify-content:center;min-width:60px;height:36px;border-radius:8px;border:1px solid #d8e1ee;background:#f8fafc;font-weight:800;cursor:pointer;text-transform:uppercase}
.cc[data-cc="SZ"]{background:#e8f6ff;border-color:#bfe6ff;color:#084b6f}
.cc[data-cc="W"]{background:#fff2d9;border-color:#f5d08a;color:#5f3b00}
.cc[data-cc="Z"]{background:#efe7ff;border-color:#c7b6ff;color:#3b1e8a}
.cc[data-cc="A"]{background:#ffe7e7;border-color:#ffc0c0;color:#6b1111}

.name{font-size:24px;font-weight:700;outline:none;cursor:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.name[contenteditable][data-ph]:empty::before{content:attr(data-ph); color:#94a3b8}
.goals{font-weight:900;font-size:24px;text-align:center;color:#082038;border-left:2px solid var(--divider);padding-left:16px;cursor:text}
.gval:focus{outline:none}

/* Baza klubów */
.db-search{width:100%;background:#0b1222;border:1px solid #223055;color:#e5ecf8;border-radius:8px;padding:8px 10px}
.db-list{display:grid;gap:8px;margin:10px 0;max-height:260px;overflow:auto}
.db-item{
  display:grid;grid-template-columns:26px 1fr 60px;column-gap:10px;align-items:center;
  background:linear-gradient(180deg,#0b1222,#0e1730);border:1px solid #223055;color:#e5ecf8;border-radius:10px;
  padding:8px 10px;cursor:grab;transition:.15s border-color,.15s background;
}
.db-item:hover{border-color:#2a3c6b;background:#0f1c39}
.db-badge{width:26px;height:26px;border-radius:6px;background:var(--badge,#2b67ff);color:#cfe2ff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px}
.db-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.db-country{justify-self:end;padding:2px 8px;border-radius:999px;font-weight:800;font-size:12px;color:#fff}
.db-country[data-cc="SZ"]{background:var(--ct-sz)}
.db-country[data-cc="W"]{background:var(--ct-w)}
.db-country[data-cc="I"]{background:#64748b}

/* Error */
.db-error{background:#311b1b;color:#ffd9d9;border:1px solid #5b2b2b;border-radius:10px;padding:8px 10px;margin:8px 0;font-size:13px}

/* CC popover */
.cc-menu{position:absolute;z-index:20;background:#fff;border:1px solid #e5e8ef;border-radius:10px;box-shadow:0 12px 24px rgba(16,24,40,.18);padding:6px;display:none}
.cc-item{display:flex;align-items:center;gap:8px;width:100%;background:transparent;border:0;text-align:left;padding:8px;border-radius:8px;cursor:pointer;color:#0b2239}
.cc-item:hover{background:#f1f5f9}
.cc-badge{min-width:28px;height:28px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;font-weight:800;border:1px solid #d8e1ee}
.cc-badge[data-cc="SZ"]{background:#e8f6ff;border-color:#bfe6ff;color:#084b6f}
.cc-badge[data-cc="W"]{background:#fff2d9;border-color:#f5d08a;color:#5f3b00}
.cc-badge[data-cc="Z"]{background:#efe7ff;border-color:#c7b6ff;color:#3b1e8a}
.cc-badge[data-cc="A"]{background:#ffe7e7;border-color:#ffc0c0;color:#6b1111}

/* Footer */
.site-footer{padding:12px 18px 18px;text-align:right;font-weight:700;color:#a9b6cb}