:root {
  --bg:#0e1117;
  --surface:#161b24;
  --surface2:#1e2430;
  --surface3:#252d3b;
  --border:#2c3445;
  --text:#eef3fb;
  --text2:#cbd3df;
  --text3:#94a0b3;
  --blue:#5aabff;
  --blue-soft:#12253b;
  --blue-mid:#2d547b;
  --blue-text:#b8dcff;
  --red:#ff7070;
  --red-soft:#2a1417;
  --red-mid:#653033;
  --red-text:#ffc1c1;
  --green:#5edba0;
  --green-soft:#10291f;
  --danger:#ff7070;
  --radius:8px;
  --topbar-height:40px;
  --safe-top:env(safe-area-inset-top, 0px);
  --app-topbar-height:calc(var(--topbar-height) + var(--safe-top));
  --footer-height:24px;
}

* {
  box-sizing:border-box;
  margin:0;
  padding:0;
  -webkit-tap-highlight-color:transparent;
  -webkit-touch-callout:none;
  touch-action:manipulation;
}
html, body { height:100%; touch-action:pan-x pan-y; }
body {
  min-height:100dvh;
  overflow:hidden;
  background:var(--bg);
  color:var(--text2);
  font-family:-apple-system,BlinkMacSystemFont,"Helvetica Neue","Hiragino Sans","Hiragino Kaku Gothic ProN","Meiryo",Arial,sans-serif;
  font-size:14px;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
button, input { font:inherit; }
button {
  color:inherit;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
input {
  -webkit-user-select:text;
  user-select:text;
  -webkit-touch-callout:default;
}
img {
  -webkit-user-drag:none;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
}

.tablet-topbar {
  position:relative;
  z-index:80;
  height:var(--app-topbar-height);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:calc(4px + var(--safe-top)) 12px 4px;
  background:var(--surface);
  border-bottom:1px solid var(--border);
  box-shadow:0 8px 24px rgba(0,0,0,.22);
  isolation:isolate;
}
.tablet-topbar::before {
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:var(--safe-top);
  background:linear-gradient(180deg,#0f1520,#161b24);
  border-bottom:1px solid rgba(255,255,255,.06);
  pointer-events:none;
  z-index:-1;
}
.topbar-left,.topbar-actions { display:flex; align-items:center; gap:8px; min-width:0; }
.topbar-left { flex:0 0 245px; }
.topbar-actions { flex:0 0 auto; }
.topbar-center {
  position:absolute;
  left:50%;
  top:calc(var(--safe-top) + 5px);
  z-index:85;
  width:auto;
  max-width:min(360px,34vw);
  transform:translateX(-50%);
  text-align:center;
  font-weight:800;
  color:var(--text);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.mode-trigger {
  height:30px;
  border:1px solid transparent;
  border-radius:7px;
  background:transparent;
  cursor:pointer;
  padding:0 12px;
}
.mode-trigger:hover,.mode-trigger.active {
  background:rgba(255,255,255,.06);
  border-color:var(--border);
}
.mode-trigger::after {
  content:'';
  display:inline-block;
  width:0;
  height:0;
  border-left:4px solid transparent;
  border-right:4px solid transparent;
  border-top:5px solid currentColor;
  margin-left:6px;
  vertical-align:middle;
  opacity:.6;
  transition:transform .18s;
}
.mode-trigger.active::after {
  transform:rotate(180deg);
}
.mode-menu {
  display:none;
  position:absolute;
  top:calc(var(--app-topbar-height) - 4px);
  left:50%;
  transform:translateX(-50%);
  z-index:90;
  min-width:200px;
  padding:7px;
  background:#f2f6fb;
  border:1px solid #9fb2c9;
  border-radius:var(--radius);
  box-shadow:0 18px 46px rgba(0,0,0,.55);
}
.mode-menu.show { display:block; }
.mode-menu button {
  width:100%;
  min-height:36px;
  border:0;
  border-radius:7px;
  background:transparent;
  color:#152033;
  text-align:left;
  padding:0 12px;
  font-size:13px;
  font-weight:900;
  cursor:pointer;
}
.mode-menu button:hover,.mode-menu button.active {
  background:#173452;
  color:#ffffff;
}
.mode-menu button:disabled {
  opacity:.42;
  cursor:not-allowed;
}
.mode-action-group {
  display:none;
  align-items:center;
  gap:6px;
}
.mode-action-group.show { display:flex; }
.mode-nav-btn {
  min-width:54px;
  border-color:#57718e;
  background:#26364a;
  color:#f2f7ff;
  font-weight:900;
}
.mode-nav-btn.primary {
  border-color:rgba(94,219,160,.72);
  background:#1a4634;
  color:#d8ffec;
}
.mode-nav-btn:disabled {
  opacity:.38;
  cursor:not-allowed;
}
.brand-block { min-width:0; }
.brand-title { font-weight:900; color:var(--text); letter-spacing:.04em; line-height:1.1; }
.brand-mode { margin-top:2px; font-size:10px; color:var(--text3); letter-spacing:.08em; text-transform:uppercase; }
.icon-menu-btn {
  width:32px;
  height:32px;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface2);
  cursor:pointer;
}
.icon-menu-btn span { width:17px; height:2px; border-radius:2px; background:var(--text2); }
.topbar-menu {
  display:none;
  position:absolute;
  top:calc(var(--app-topbar-height) - 6px);
  left:12px;
  z-index:90;
  background:var(--surface2);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  overflow:hidden;
  min-width:180px;
}
.topbar-menu.show { display:block; }
.topbar-menu button {
  display:block;
  width:100%;
  padding:11px 16px;
  border:0;
  background:transparent;
  color:var(--text2);
  font:inherit;
  font-size:13px;
  font-weight:700;
  text-align:left;
  white-space:nowrap;
  cursor:pointer;
}
.topbar-menu button:hover { background:rgba(255,255,255,.06); color:var(--text); }
.btn {
  min-height:34px;
  padding:0 12px;
  border:1px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
  color:var(--text2);
  cursor:pointer;
  font-weight:700;
}
.btn.small { min-height:32px; padding:0 10px; font-size:12px; }
.btn:hover,.btn:focus-visible { border-color:#566177; color:var(--text); outline:none; }
.btn.active { border-color:var(--green); background:var(--green-soft); color:#aef0ce; }
.btn.danger { border-color:var(--red-mid); background:var(--red-soft); color:var(--red-text); }
.btn.danger-ghost { border-color:var(--red-mid); background:transparent; color:var(--red-text); }
.btn.full { width:100%; margin-top:12px; }

.tablet-shell {
  height:calc(100dvh - var(--app-topbar-height) - var(--footer-height));
  display:grid;
  grid-template-columns:minmax(222px,.88fr) minmax(516px,1.42fr) minmax(222px,.88fr);
  gap:10px;
  padding:10px;
  min-width:900px;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
.tablet-footer {
  height:var(--footer-height);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:0 10px;
  border-top:1px solid #1e2430;
  background:#0b0e14;
  color:#4a5468;
  font-size:8px;
  line-height:1;
  white-space:nowrap;
  overflow:hidden;
}
.tablet-footer span {
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  flex:1;
}
.tablet-footer button {
  flex:0 0 auto;
  border:0;
  background:transparent;
  color:#5a7a9a;
  text-decoration:underline;
  font-size:9px;
  cursor:pointer;
}
.team-pool-panel {
  min-height:0;
  display:flex;
  flex-direction:column;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
}
.blue-panel { background:linear-gradient(180deg,rgba(90,171,255,.08),rgba(18,37,59,.92)); border-color:var(--blue-mid); }
.red-panel { background:linear-gradient(180deg,rgba(255,112,112,.08),rgba(42,20,23,.92)); border-color:var(--red-mid); }
.team-title-row {
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:6px;
  padding:4px 8px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.team-title-input {
  min-width:0;
  flex:1;
  height:16px;
  border:0;
  background:transparent;
  color:var(--text3);
  font-size:10px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  outline:none;
  cursor:default;
}
.blue-panel .team-title-input { color:rgba(184,220,255,.6); }
.red-panel .team-title-input { color:rgba(255,193,193,.6); }
.btn.team-save-btn { min-height:18px; padding:0 6px; font-size:10px; background:rgba(255,255,255,.04); }
.pool-list {
  flex:1;
  min-height:0;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  overscroll-behavior:contain;
  padding:8px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.pool-list::-webkit-scrollbar,.champ-grid::-webkit-scrollbar,.saved-list::-webkit-scrollbar { width:6px; }
.pool-list::-webkit-scrollbar-thumb,.champ-grid::-webkit-scrollbar-thumb,.saved-list::-webkit-scrollbar-thumb { background:#465268; border-radius:999px; }
.pool-row {
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius);
  background:rgba(10,13,19,.34);
  padding:8px;
}
.pool-row.editing { outline:2px solid var(--green); outline-offset:2px; }
.pool-row-head { display:flex; align-items:center; gap:4px; margin-bottom:4px; }
.pool-name-input {
  flex:1;
  min-width:0;
  height:14px;
  border:0;
  background:transparent;
  color:var(--text3);
  font-size:10px;
  font-weight:600;
  letter-spacing:.04em;
  outline:none;
  cursor:default;
}
.btn.pool-player-save {
  height:18px;
  min-height:18px;
  padding:0 5px;
  border-radius:4px;
  font-size:10px;
}
.pool-zone-scroll {
  min-height:60px;
  border:1px dashed rgba(255,255,255,.16);
  border-radius:7px;
  background:rgba(0,0,0,.18);
}
.pool-zone-scroll.drag-over { border-style:solid; border-color:var(--green); background:rgba(94,219,160,.12); }
.pool-zone {
  display:flex;
  flex-wrap:wrap;
  align-content:flex-start;
  gap:5px;
  padding:5px;
  min-height:60px;
}
.pool-empty {
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text3);
  font-size:12px;
}

.pool-protect-section {
  flex:0 0 auto;
  padding:8px;
  border-top:1px solid var(--border);
}
.pool-protect-section .protect-card {
  min-height:0;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:8px;
}
.draft-center {
  min-height:0;
  position:relative;
  display:flex;
  flex-direction:column;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  overflow:hidden;
}
.draft-board {
  flex:0 0 auto;
  display:flex;
  flex-direction:column;
  padding:10px 8px;
  gap:10px;
}
.draft-save-name {
  display:block;
  font-size:11px;
  text-align:center;
  color:var(--text3);
  letter-spacing:0;
}
#draftWarning {
  display:block;
  font-size:11px;
  text-align:center;
  color:var(--red-text);
  letter-spacing:0;
}
.ban-phase {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
}
.ban-section {
  display:flex;
  flex-direction:column;
}
.phase-label {
  color:var(--text3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-align:center;
}
.ban-row {
  min-width:0;
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:4px;
}
.pick-phase {
  flex:0 0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:6px;
}
.pick-stack {
  display:grid;
  grid-template-rows:repeat(5,58px);
  gap:3px;
}
.draft-slot,.protect-slot {
  position:relative;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1.5px dashed var(--border);
  background:var(--surface2);
  color:var(--text3);
  transition:border-color .12s,background .12s,transform .12s;
  touch-action:none;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
.draft-slot.drag-over,.protect-slot.drag-over { border-style:solid; border-color:var(--green); background:var(--green-soft); }
.draft-slot.filled,.protect-slot.filled { border-style:solid; cursor:grab; }
.protect-slot.used img { opacity:.34; filter:grayscale(.7); }
.draft-slot.pressing,.protect-slot.pressing,.pool-row.pressing { outline:2px solid var(--green); outline-offset:2px; }
.champ-chip.pressing { outline:2px solid var(--green); outline-offset:2px; }
.ban-slot {
  aspect-ratio:1;
  border-radius:7px;
}
.blue-slot { border-color:var(--blue-mid); background:rgba(90,171,255,.08); }
.red-slot { border-color:var(--red-mid); background:rgba(255,112,112,.08); }
.pick-slot {
  border-radius:7px;
  justify-content:flex-start;
  padding:3px 6px;
  gap:6px;
}
.slot-img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.pick-slot .slot-img {
  width:44px;
  height:44px;
  flex:0 0 44px;
  border-radius:6px;
}
.ban-slot .slot-img {
  width:100%;
  height:100%;
}
.slot-text {
  min-width:0;
  overflow:hidden;
  pointer-events:none;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
.slot-label,
.slot-text::before {
  content:attr(data-slot-label);
  display:block;
  font-size:11px;
  font-weight:900;
  color:var(--text3);
}
.slot-name,
.slot-text[data-slot-name]::after {
  content:attr(data-slot-name);
  display:block;
  margin-top:2px;
  max-width:100%;
  color:var(--text);
  font-size:15px;
  font-weight:800;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.slot-placeholder {
  pointer-events:none;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
.slot-placeholder::before { content:attr(data-empty-label); }
.protect-placeholder { font-size:7px; font-weight:900; letter-spacing:.04em; color:var(--text3); line-height:1; }
.ban-placeholder {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:1px;
}
.ban-ph-top {
  display:block;
  font-size:9px;
  font-weight:900;
  color:var(--text3);
  letter-spacing:.06em;
}
.ban-ph-num {
  display:block;
  font-size:13px;
  font-weight:900;
  color:var(--text3);
  line-height:1;
}
.ban-filled::before,.ban-filled::after {
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  z-index:3;
  border-radius:999px;
  transform:translate(-50%,-50%) rotate(50deg);
  pointer-events:none;
}
.ban-filled::before { width:78%; height:4px; background:rgba(35,39,48,.62); }
.ban-filled::after { width:76%; height:2px; background:rgba(245,245,255,.95); }
.delete-mode .draft-slot.filled::after,
.delete-mode .protect-slot.filled::after {
  content:"×";
  position:absolute;
  right:4px;
  top:4px;
  z-index:4;
  width:22px;
  height:22px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,112,112,.92);
  color:#fff;
  font-size:16px;
  font-weight:900;
}

.protect-card {
  min-height:100px;
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:8px;
}
.blue-protect { background:rgba(90,171,255,.06); border-color:var(--blue-mid); }
.red-protect { background:rgba(255,112,112,.06); border-color:var(--red-mid); }
.protect-slots {
  display:flex;
  gap:5px;
  width:min(calc((48px * 3.5) + (5px * 3)), calc(100% - 56px));
  max-width:min(calc((48px * 3.5) + (5px * 3)), calc(100% - 56px));
  overflow-x:auto;
  overflow-y:hidden;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  touch-action:pan-x;
  padding-bottom:2px;
}
.protect-slots::-webkit-scrollbar { display:none; }
.protect-strip {
  display:flex;
  align-items:flex-start;
  gap:8px;
  width:100%;
  min-width:0;
}
.protect-empty {
  width:100%;
  min-height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text3);
  font-size:12px;
}
.protect-slot {
  width:48px;
  height:48px;
  flex:0 0 48px;
  aspect-ratio:1;
  border-radius:7px;
}
.protect-slots .protect-slot { touch-action:pan-x; }
.protect-slot img { width:100%; height:100%; object-fit:cover; display:block; }
.fearless-panel-btn {
  width:48px;
  height:48px;
  margin-left:auto;
  flex:0 0 48px;
  border:1.5px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
  color:var(--text2);
  font-size:10px;
  font-weight:900;
  line-height:1.05;
  text-align:center;
  cursor:pointer;
}
.fearless-panel-btn:hover { border-color:var(--green); color:var(--text); }

.champ-chip {
  position:relative;
  width:50px;
  height:50px;
  flex:0 0 50px;
  border-radius:7px;
  background:var(--surface3);
  cursor:grab;
  touch-action:none;
}
.champ-chip img { width:100%; height:100%; object-fit:cover; display:block; pointer-events:none; border-radius:7px; }
.champ-chip.used img { opacity:.34; filter:grayscale(.7); }
.champ-chip.fearless img { opacity:.34; filter:grayscale(.7); }
.champ-chip.fearless::after {
  content:"FL";
  position:absolute;
  right:2px;
  bottom:2px;
  font-size:9px;
  font-weight:900;
  color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.6);
  padding:0 2px;
  border-radius:2px;
  pointer-events:none;
  line-height:13px;
  z-index:3;
}
.champ-chip-delete {
  display:none;
  position:absolute;
  right:1px;
  top:1px;
  z-index:2;
  width:18px;
  height:18px;
  border:0;
  border-radius:999px;
  background:rgba(255,112,112,.94);
  color:#fff;
  font-size:14px;
  line-height:18px;
  font-weight:900;
}
.champ-chip.ctx-selected .champ-chip-delete { display:block; }
.slot-delete-btn {
  display:block;
  position:absolute;
  right:0;
  top:0;
  z-index:4;
  width:20px;
  height:20px;
  border:0;
  border-radius:999px;
  background:rgba(255,112,112,.94);
  color:#fff;
  font-size:14px;
  line-height:20px;
  font-weight:900;
  cursor:pointer;
  padding:0;
  text-align:center;
}

.grid-panel {
  flex:1;
  display:flex;
  flex-direction:column;
  border-top:1px solid var(--border);
  background:var(--surface2);
  padding:8px 10px 8px;
  overflow:hidden;
}
.grid-panel.drag-over { box-shadow:inset 0 0 0 2px var(--green); }
.grid-controls {
  flex:0 0 auto;
  display:grid;
  grid-template-columns:auto minmax(100px,1fr);
  gap:8px;
  padding:4px 0 12px;
}
.champ-search {
  height:28px;
  min-width:0;
  border:1px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
  color:var(--text);
  padding:0 10px;
  outline:none;
}
.champ-search:focus { border-color:#596780; }
.role-tabs {
  display:flex;
  align-items:center;
  gap:4px;
}
.role-tabs button {
  height:28px;
  min-width:44px;
  padding:0 8px;
  border:1px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
  color:var(--text3);
  font-size:11px;
  font-weight:900;
}
.role-tabs button.active { border-color:var(--green); background:var(--green-soft); color:#bdf3d8; }
.champ-grid {
  flex:1;
  min-height:0;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  touch-action:pan-y;
  display:grid;
  grid-template-columns:repeat(auto-fill,52px);
  gap:8px;
  justify-content:start;
  align-content:start;
  padding:3px;
  padding-right:5px;
}
.grid-champ {
  width:50px;
  height:50px;
  border-radius:6px;
  color:var(--text2);
  cursor:pointer;
  touch-action:none;
  aspect-ratio:1;
  position:relative;
  user-select:none;
  -webkit-user-select:none;
}
.grid-champ.used { opacity:.34; filter:grayscale(.7); }
.grid-champ.fearless { opacity:.34; filter:grayscale(.7); }
.grid-champ.fearless::after {
  content:"FL";
  position:absolute;
  right:2px;
  bottom:2px;
  font-size:9px;
  font-weight:900;
  color:rgba(255,255,255,.85);
  background:rgba(0,0,0,.6);
  padding:0 2px;
  border-radius:2px;
  pointer-events:none;
  line-height:13px;
  z-index:2;
}
.grid-champ.selected { outline:2px solid var(--green); outline-offset:1px; position:relative; z-index:1; }
.ctx-selected { outline:2px solid var(--green) !important; outline-offset:2px; position:relative; z-index:1; }
.protect-slot.ctx-selected { outline-offset:-2px; }
.grid-champ img {
  width:100%;
  aspect-ratio:1;
  display:block;
  object-fit:cover;
  background:var(--surface2);
  border-radius:6px;
}
.grid-champ span { display:none; }

.modal-overlay,.confirm-overlay {
  display:none;
  position:fixed;
  inset:0;
  z-index:100;
  align-items:center;
  justify-content:center;
  background:rgba(4,6,10,.72);
  padding:18px;
}
.modal-overlay.show,.confirm-overlay.show { display:flex; }
.modal {
  width:min(860px,calc(100vw - 36px));
  max-height:min(720px,calc(100dvh - 36px));
  display:flex;
  flex-direction:column;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  box-shadow:0 18px 60px rgba(0,0,0,.55);
}
.save-modal { height:min(720px,calc(100dvh - 36px)); }
.team-save-modal,.player-modal { width:min(420px,calc(100vw - 36px)); }
.settings-modal,.fearless-modal,.file-import-modal { width:min(560px,calc(100vw - 36px)); }
.legal-modal { width:min(680px,calc(100vw - 36px)); }
.modal-title {
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-bottom:1px solid var(--border);
  color:var(--text);
  font-size:16px;
  font-weight:900;
}
.modal-close {
  width:34px;
  height:34px;
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--surface2);
  color:var(--text2);
  font-size:18px;
}
.save-pane {
  flex:1;
  min-height:0;
  overflow:auto;
  padding:12px 16px 16px;
}
#draftSavePane {
  overflow:hidden;
  display:flex;
  flex-direction:column;
  padding:14px 16px 0;
}
.save-section-label {
  font-size:11px;
  font-weight:900;
  color:var(--text3);
  letter-spacing:.06em;
  text-transform:uppercase;
  margin-bottom:7px;
}
.modal-section {
  font-size:12px;
  font-weight:800;
  color:var(--text3);
  letter-spacing:.06em;
  text-transform:uppercase;
  margin:12px 0 6px;
}
.draft-current-section { flex:0 0 auto; margin-bottom:14px; }
.draft-current-section .current-save-card { margin-bottom:0; }
.current-save-card.empty {
  justify-content:center;
  text-align:center;
  border-style:dashed;
  background:rgba(255,255,255,.02);
  color:var(--text3);
  font-size:12px;
}
.draft-new-section { flex:0 0 auto; margin-bottom:14px; }
.draft-new-section .save-row { margin-bottom:0; }
.draft-save-columns {
  flex:1;
  min-height:0;
  display:grid;
  grid-template-columns:220px 1fr;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
}
.draft-folder-col {
  display:flex;
  flex-direction:column;
  min-height:0;
  border-right:1px solid var(--border);
  background:rgba(0,0,0,.1);
}
.draft-saves-col {
  display:flex;
  flex-direction:column;
  min-height:0;
  padding:10px;
}
.draft-saves-col .saved-list { flex:1; min-height:0; max-height:none; overflow-y:auto; padding-right:2px; }
.draft-col-label {
  flex:0 0 auto;
  padding:8px 12px;
  font-size:11px;
  font-weight:900;
  color:var(--text3);
  letter-spacing:.06em;
  text-transform:uppercase;
  border-bottom:1px solid var(--border);
}
.draft-folder-list {
  flex:1;
  min-height:0;
  overflow-y:auto;
  padding:4px 0;
}
.draft-folder-item {
  position:relative;
  display:flex;
  align-items:center;
  gap:7px;
  padding:0 10px;
  height:34px;
  width:100%;
  border:0;
  border-radius:0;
  background:transparent;
  color:var(--text2);
  cursor:pointer;
  font:inherit;
  font-size:13px;
  text-align:left;
  overflow:hidden;
}
.draft-folder-item:hover { background:rgba(255,255,255,.04); }
.draft-folder-item.active {
  background:linear-gradient(90deg,rgba(248,249,251,.1),rgba(248,249,251,.04));
  color:var(--text);
  font-weight:800;
}
.draft-folder-item.active::before {
  content:'';
  position:absolute;
  left:0;
  top:7px;
  bottom:7px;
  width:3px;
  border-radius:999px;
  background:var(--text);
}
.draft-folder-icon {
  width:13px;
  height:16px;
  flex:0 0 13px;
  position:relative;
  border:1.5px solid rgba(148,160,179,.55);
  border-radius:2px 4px 2px 2px;
}
.draft-folder-icon::before {
  content:'';
  position:absolute;
  top:-1.5px;
  right:-1.5px;
  width:5px;
  height:5px;
  border-left:1.5px solid rgba(148,160,179,.55);
  border-bottom:1.5px solid rgba(148,160,179,.55);
  border-radius:0 0 0 2px;
  background:var(--surface);
}
.draft-folder-item.active .draft-folder-icon,
.draft-folder-item.active .draft-folder-icon::before { border-color:rgba(238,243,251,.4); }
.draft-folder-name { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.draft-folder-count {
  flex:0 0 auto;
  min-width:20px;
  height:18px;
  padding:0 6px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:999px;
  background:rgba(255,255,255,.05);
  color:var(--text3);
  font-size:11px;
  font-weight:800;
  display:flex;
  align-items:center;
  justify-content:center;
}
.draft-folder-edit {
  flex:0 0 18px;
  width:18px;
  height:18px;
  display:none;
  align-items:center;
  justify-content:center;
  border-radius:4px;
  font-size:12px;
  font-weight:900;
  cursor:pointer;
  color:var(--text3);
}
.draft-folder-item:hover .draft-folder-edit { display:flex; }
.draft-folder-item.drag-over {
  border:1px solid var(--green);
  background:rgba(94,219,160,.08);
  color:var(--text2);
}
.draft-folder-new-item {
  display:flex;
  align-items:center;
  gap:7px;
  padding:4px 10px;
}
.draft-folder-new-input {
  flex:1;
  min-width:0;
  height:28px;
  border:1px solid var(--border);
  border-radius:6px;
  background:var(--surface);
  color:var(--text);
  padding:0 8px;
  font:inherit;
  font-size:13px;
  outline:none;
}
.draft-folder-new-input:focus { border-color:#596780; }
.draft-folder-add-btn,
.draft-folder-delete-btn {
  flex:0 0 auto;
  width:100%;
  padding:7px 10px 7px 12px;
  border:0;
  border-top:1px solid var(--border);
  background:transparent;
  font:inherit;
  font-size:12px;
  text-align:left;
  cursor:pointer;
}
.draft-folder-add-btn { color:var(--text3); }
.draft-folder-add-btn:hover { color:var(--text2); background:rgba(255,255,255,.03); }
.draft-folder-delete-btn { color:var(--red-text); }
.draft-folder-delete-btn:hover:not(:disabled) { background:rgba(255,112,112,.06); }
.draft-folder-delete-btn:disabled { color:var(--text3); cursor:default; font-size:10px; }
#draftSavedList .saved-item[draggable=true] { cursor:grab; }
#draftSavedList .saved-item[draggable=true]:active { cursor:grabbing; }
.hidden { display:none !important; }
.current-save-card {
  min-height:54px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
  padding:10px;
  border:1px solid var(--border);
  border-radius:7px;
  background:rgba(255,255,255,.03);
}
.save-row {
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:8px;
  margin-bottom:10px;
}
.save-input {
  width:100%;
  height:36px;
  border:1px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
  color:var(--text);
  padding:0 10px;
  outline:none;
}
.save-input:focus { border-color:#596780; }
.saved-list {
  max-height:360px;
  overflow:auto;
  display:flex;
  flex-direction:column;
  gap:7px;
  padding-right:2px;
}
.saved-item {
  display:flex;
  align-items:center;
  gap:8px;
  min-height:58px;
  padding:9px;
  border:1px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
}
.saved-info { flex:1; min-width:0; }
.saved-name,
.saved-item-name {
  color:var(--text);
  font-weight:900;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.saved-meta,
.saved-item-date { margin-top:3px; color:var(--text3); font-size:11px; }
.saved-actions { display:flex; gap:6px; flex:0 0 auto; }
.rename-input { height:32px; }
.empty-msg {
  font-size:13px;
  color:var(--text3);
  text-align:center;
  padding:16px 0;
}
.modal-footer-actions {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid var(--border);
}
.modal-footer-actions.single { grid-template-columns:1fr; }
.simple-save-pane {
  padding:0 20px 16px;
  overflow:auto;
}
.simple-form-block { margin-bottom:2px; }
.simple-list-block { margin-bottom:8px; }
.simple-save-pane .save-row {
  grid-template-columns:minmax(0,1fr) 58px;
  align-items:center;
  margin-bottom:0;
}
.file-import-pane {
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:16px 20px;
}
.file-import-pick-btn {
  width:100%;
  height:40px;
}
.file-import-date {
  min-height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
  color:var(--text2);
  font-size:13px;
  font-weight:800;
  text-align:center;
}
.file-import-date.empty {
  color:var(--text3);
  font-weight:700;
}
.player-modal-form {
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:10px;
}
.player-modal-row {
  display:grid;
  grid-template-columns:56px minmax(0,1fr) 64px;
  align-items:center;
  gap:8px;
}
.player-modal-inline-label {
  color:var(--text3);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  white-space:nowrap;
}
.player-modal-input { height:34px; }
.player-modal-action {
  height:34px;
  padding:0 12px;
  display:flex;
  align-items:center;
  justify-content:center;
}
.simple-saved-list {
  max-height:350px;
  padding-right:4px;
}
.simple-save-pane .saved-item {
  min-height:0;
  padding:8px 10px;
}
.simple-save-pane .modal-footer-actions {
  margin-top:14px;
}
.settings-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  column-gap:48px;
  row-gap:12px;
  padding:20px 28px 28px;
  border-bottom:1px solid var(--border);
}
.settings-field {
  display:grid;
  grid-template-columns:minmax(0,1fr) 68px;
  align-items:start;
  gap:18px;
}
.settings-field-text {
  display:flex;
  flex-direction:column;
  gap:5px;
  min-width:0;
}
.settings-label {
  color:var(--text);
  font-size:13px;
  font-weight:800;
  line-height:1.25;
}
.settings-note {
  color:#7fb2e6;
  font-size:11px;
  line-height:1.35;
  font-weight:500;
}
.settings-number {
  width:100%;
  height:38px;
  border:1px solid var(--border);
  border-radius:7px;
  background:var(--surface2);
  color:var(--text);
  padding:0 10px;
  text-align:center;
  font-weight:700;
}
.settings-number:disabled { opacity:.35; cursor:not-allowed; pointer-events:none; border-style:dashed; }
select.settings-number {
  -webkit-appearance:none;
  appearance:none;
  cursor:pointer;
  text-align:left;
  padding:0 22px 0 10px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%2394a0b3' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 7px center;
}
.settings-toggle-row {
  grid-column:1;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:start;
  gap:14px;
  cursor:pointer;
  user-select:none;
}
.settings-toggle-row input {
  display:none;
}
.settings-toggle-track {
  width:34px;
  height:18px;
  margin-top:1px;
  border-radius:999px;
  background:#3a4455;
  position:relative;
  transition:background .18s;
  flex-shrink:0;
}
.settings-toggle-track::after {
  content:'';
  position:absolute;
  top:3px;
  left:3px;
  width:12px;
  height:12px;
  border-radius:50%;
  background:#f8f9fb;
  box-shadow:0 1px 4px rgba(0,0,0,.45);
  transition:left .18s;
}
.settings-toggle-row input:checked ~ .settings-toggle-track {
  background:#aabccc;
}
.settings-toggle-row input:checked ~ .settings-toggle-track::after {
  left:19px;
}
.settings-modal .btn.full { width:calc(100% - 32px); margin:0 16px 16px; }
.fearless-modal-body {
  padding:16px;
  max-height:min(62dvh,520px);
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}
.fearless-section+.fearless-section { margin-top:18px; }
.fearless-section-title {
  margin-bottom:8px;
  color:var(--text3);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
}
.fearless-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(48px,1fr));
  gap:8px;
}
.fearless-grid .protect-slot {
  justify-self:center;
}
.fearless-empty {
  min-height:44px;
  display:flex;
  align-items:center;
  color:var(--text3);
  font-size:12px;
}
.legal-body {
  overflow:auto;
  -webkit-overflow-scrolling:touch;
  padding:16px;
  color:var(--text2);
  font-size:13px;
  line-height:1.8;
}
.legal-body h3 {
  margin:15px 0 6px;
  color:var(--text);
  font-size:14px;
}
.legal-body p { margin:0 0 8px; }
.legal-body ul { margin:8px 0 8px 18px; }
.legal-body a { color:#6f9fc8; }

.confirm-box {
  width:min(420px,calc(100vw - 36px));
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  padding:18px;
  box-shadow:0 18px 60px rgba(0,0,0,.55);
}
.confirm-message { color:var(--text); line-height:1.7; font-weight:800; }
.confirm-actions { display:flex; justify-content:flex-end; gap:8px; margin-top:16px; }
.toast {
  position:fixed;
  left:50%;
  bottom:20px;
  z-index:200;
  transform:translateX(-50%);
  max-width:calc(100vw - 40px);
  padding:9px 14px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(30,36,48,.96);
  color:var(--text);
  font-weight:800;
  opacity:0;
  pointer-events:none;
  transition:opacity .18s, transform .18s;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(-4px); }
.drag-ghost {
  position:fixed;
  z-index:300;
  width:54px;
  height:54px;
  border:2px solid rgba(255,255,255,.82);
  border-radius:10px;
  overflow:hidden;
  pointer-events:none;
  box-shadow:0 14px 30px rgba(0,0,0,.5);
  transform:translate(-50%,-50%);
}
.drag-ghost img { width:100%; height:100%; object-fit:cover; display:block; }
body.dragging { cursor:grabbing; touch-action:none; }

@media (max-width:980px) {
  .tablet-shell { grid-template-columns:220px minmax(480px,1fr) 220px; gap:8px; padding:8px; }
  .brand-mode { display:none; }
  .pick-stack { grid-template-rows:repeat(5,minmax(36px,1fr)); }
  .pick-slot .slot-img { width:40px; height:40px; flex-basis:40px; }
  .slot-name,
  .slot-text[data-slot-name]::after { font-size:12px; }
  .grid-panel { flex-basis:220px; }
}
