:root{
  --tcg-cell:40px;
  --tcg-cols:9;
  --tcg-rows:13;
  --tcg-home:#1a6bff;
  --tcg-away:#e63946;
}

#scr-tcg-setup,
#scr-tcg-match{
  background:var(--bg-base);
}

#scr-tcg-setup .tabs{
  position:absolute;top:var(--sat,env(safe-area-inset-top,0px));left:0;right:0;z-index:30;
  background:color-mix(in srgb,var(--bg-surface) 88%,transparent);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
}

.tcg-top-back{
  position:absolute;top:calc(var(--sat,env(safe-area-inset-top,0px)) + 48px);left:12px;z-index:45;
}

#menu-pop-tcg-setup{
  position:absolute;
  top:calc(var(--sat,env(safe-area-inset-top,0px)) + 50px);
  right:12px;
  z-index:60;
  background:var(--bg-elevated);
  border:1px solid var(--border-bright);
  border-radius:10px;
  padding:4px;
  min-width:160px;
  box-shadow:0 6px 24px rgba(0,0,0,.5);
}

.tcg-summary-card{
  width:100%;
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--bg-surface);
  padding:14px 16px;
  color:var(--text-secondary);
  line-height:1.55;
  font-size:12px;
}

.tcg-summary-card strong,
.tcg-summary-card b{
  color:var(--text-primary);
}

.tcg-setup-body{
  padding-top:calc(var(--sat,env(safe-area-inset-top,0px)) + 42px);
}

.tcg-setup-stage{
  padding:18px 12px 12px;
}

.tcg-board{
  border:10px solid #2563eb;
  border-radius:20px;
  padding:12px;
  overflow:hidden;
  background-color:#275a2c;
  background-image:repeating-linear-gradient(0deg,#275a2c 0,#275a2c var(--tcg-cell),#2a6330 var(--tcg-cell),#2a6330 calc(var(--tcg-cell) * 2));
  box-shadow:0 0 0 3px rgba(37,99,235,.3),0 8px 40px rgba(0,0,0,.7);
}

.tcg-board--match{
  border-color:#1d4ed8;
}

.tcg-pitch{
  position:relative;
  display:grid;
  grid-template-columns:repeat(var(--tcg-cols),var(--tcg-cell));
  grid-template-rows:repeat(var(--tcg-rows),var(--tcg-cell));
  width:calc(var(--tcg-cols) * var(--tcg-cell));
  height:calc(var(--tcg-rows) * var(--tcg-cell));
}

.tcg-cell{
  width:var(--tcg-cell);
  height:var(--tcg-cell);
  position:relative;
  transition:background-color .15s, box-shadow .15s;
}

.tcg-cell.play{
  background:transparent;
}

.tcg-cell.oob{
  background:rgba(0,0,0,.18);
}

.tcg-cell.goal{
  background:rgba(255,255,255,.08);
}

.tcg-cell.is-valid{
  background:rgba(96,165,250,.32);
  box-shadow:inset 0 0 0 1px rgba(96,165,250,.8), inset 0 0 8px rgba(96,165,250,.25);
  cursor:pointer;
}

.tcg-cell.is-target{
  background:rgba(251,191,36,.28);
  box-shadow:inset 0 0 0 1px rgba(251,191,36,.8), inset 0 0 8px rgba(251,191,36,.25);
  cursor:pointer;
}

.tcg-cell.is-danger{
  background:rgba(248,113,113,.24);
  box-shadow:inset 0 0 0 1px rgba(248,113,113,.85), inset 0 0 8px rgba(248,113,113,.3);
}

.tcg-cell.is-selected{
  box-shadow:inset 0 0 0 2px var(--accent), inset 0 0 12px rgba(232,228,223,.18);
}

.tcg-pitch svg{
  position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;
}

.tcg-piece{
  position:absolute;
  z-index:3;
  width:calc(var(--tcg-cell) * .95);
  min-height:calc(var(--tcg-cell) * 1.18);
  transform:translate(-50%,-50%);
  border-radius:10px;
  border:1px solid rgba(255,255,255,.16);
  background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.01)),var(--bg-elevated);
  box-shadow:0 6px 20px rgba(0,0,0,.32);
  padding:4px 5px;
  display:flex;flex-direction:column;justify-content:space-between;
  gap:2px;
  cursor:pointer;
}

.tcg-piece--home{border-color:rgba(59,130,246,.45)}
.tcg-piece--away{border-color:rgba(239,68,68,.5)}
.tcg-piece.is-selected{outline:1px solid var(--accent);box-shadow:0 0 0 2px rgba(232,228,223,.2),0 8px 24px rgba(0,0,0,.42)}
.tcg-piece.has-ball::after{
  content:"⚽";
  position:absolute;
  top:-9px;right:-7px;
  width:18px;height:18px;
  display:flex;align-items:center;justify-content:center;
  font-size:12px;
  border-radius:999px;
  background:var(--bg-base);
  box-shadow:0 4px 10px rgba(0,0,0,.35);
}

.tcg-piece__name{
  font-size:8px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--text-primary);line-height:1.1;
}

.tcg-piece__meta{
  display:flex;align-items:center;justify-content:space-between;gap:4px;
  font-size:8px;font-weight:700;color:var(--text-secondary);
}

.tcg-piece__badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:16px;
  padding:0 5px;
  border-radius:999px;
  font-size:8px;font-weight:800;
  background:rgba(255,255,255,.08);
}

.tcg-piece__stats{
  display:flex;gap:3px;flex-wrap:wrap;
}

.tcg-piece__stat{
  font-size:7px;font-weight:700;color:var(--text-faint);
}

.tcg-playbook-panel{
  width:min(1140px,100%);
  margin:0 auto;
  display:grid;
  grid-template-columns:minmax(260px,300px) minmax(0,1fr);
  gap:16px;
}

.tcg-playbook-summary,
.tcg-library-shell{
  border:1px solid var(--border);
  border-radius:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--bg-surface);
  box-shadow:0 18px 40px rgba(0,0,0,.22);
}

.tcg-playbook-summary{
  padding:16px;
  display:flex;flex-direction:column;gap:14px;
}

.tcg-playbook-summary__top{
  display:flex;flex-direction:column;gap:12px;
}

.tcg-playbook-counts{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
}

.tcg-count-pill{
  border:1px solid var(--border);
  border-radius:12px;
  background:var(--bg-card);
  padding:10px 12px;
}

.tcg-count-pill__label{
  display:block;
  font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);
  margin-bottom:4px;
}

.tcg-count-pill__value{
  font-size:18px;font-weight:800;color:var(--text-primary);
}

.tcg-playbook-actions{
  display:flex;gap:8px;flex-wrap:wrap;
}

.tcg-deck-list{
  display:flex;flex-direction:column;gap:8px;
  max-height:360px;overflow:auto;
}

.tcg-deck-row{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  background:var(--bg-card);
}

.tcg-deck-row__meta{
  display:flex;flex-direction:column;gap:3px;min-width:0;
}

.tcg-deck-row__name{
  color:var(--text-primary);
  font-size:12px;font-weight:700;
}

.tcg-deck-row__type{
  color:var(--text-muted);
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
}

.tcg-deck-row__count{
  color:var(--accent);
  font-size:11px;font-weight:800;
}

.tcg-library-shell{
  overflow:hidden;
}

.tcg-library-filters{
  border-bottom:1px solid var(--border);
}

.tcg-library-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:12px;
  padding:14px;
  max-height:min(70vh,560px);
  overflow:auto;
}

.tcg-library-card{
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--bg-card);
  padding:14px;
  display:flex;flex-direction:column;gap:10px;
}

.tcg-library-card__head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:10px;
}

.tcg-library-card__name{
  color:var(--text-primary);
  font-size:14px;font-weight:700;
  line-height:1.2;
}

.tcg-library-card__type{
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  color:var(--text-muted);
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
}

.tcg-library-card__text{
  color:var(--text-secondary);
  font-size:12px;line-height:1.5;
}

.tcg-library-card__controls{
  display:flex;align-items:center;gap:8px;margin-top:auto;
}

.tcg-stepper{
  display:inline-flex;align-items:center;gap:6px;
}

.tcg-stepper button{
  width:28px;height:28px;
  border-radius:999px;
  border:1px solid var(--ghost-button-border);
  background:var(--ghost-button-bg);
  color:var(--ghost-button-text);
  font-size:16px;line-height:1;
}

.tcg-stepper button:hover{
  color:var(--text-primary);
  border-color:var(--border-bright);
  background:var(--ghost-button-hover);
}

.tcg-stepper__value{
  min-width:18px;text-align:center;
  color:var(--text-primary);font-weight:800;font-size:13px;
}

.tcg-select{
  width:100%;
  padding:11px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--bg-card);
  color:var(--text-primary);
  font-family:var(--ff);
  font-size:13px;
}

.tcg-section-eyebrow{
  display:block;margin-bottom:7px;
  font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--text-muted);
}

.tcg-setup-bar,
.tcg-match-bar{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}

.tcg-roster-strip,
.tcg-hand-strip{
  display:flex;gap:8px;overflow:auto;
  scrollbar-width:none;
}

.tcg-roster-strip::-webkit-scrollbar,
.tcg-hand-strip::-webkit-scrollbar{display:none}

.tcg-roster-card,
.tcg-hand-card{
  flex:0 0 auto;
  width:132px;
  min-height:92px;
  border-radius:16px;
  border:1px solid var(--border);
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--bg-card);
  padding:12px;
  display:flex;flex-direction:column;gap:8px;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}

.tcg-roster-card.is-selected,
.tcg-hand-card.is-selected{
  border-color:var(--accent);
  box-shadow:0 0 0 2px rgba(232,228,223,.14),0 12px 28px rgba(0,0,0,.24);
}

.tcg-roster-card__top,
.tcg-hand-card__top{
  display:flex;align-items:flex-start;justify-content:space-between;gap:8px;
}

.tcg-roster-card__name,
.tcg-hand-card__name{
  color:var(--text-primary);
  font-size:12px;font-weight:700;line-height:1.2;
}

.tcg-roster-card__pos,
.tcg-hand-card__type{
  color:var(--text-muted);
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
}

.tcg-roster-card__keywords,
.tcg-hand-card__text{
  color:var(--text-secondary);
  font-size:11px;line-height:1.45;
}

.tcg-roster-card__footer{
  display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto;
}

.tcg-status-chip{
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 8px;
  border-radius:999px;
  background:rgba(255,255,255,.07);
  color:var(--text-secondary);
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;
}

.tcg-status-chip.on-field{color:#93c5fd;background:rgba(59,130,246,.12)}
.tcg-status-chip.bench{color:#fca5a5;background:rgba(239,68,68,.12)}

.tcg-roster-toggle{
  padding:6px 10px;border-radius:8px;border:1px solid var(--ghost-button-border);
  background:var(--ghost-button-bg);color:var(--ghost-button-text);
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
}

.tcg-roster-toggle:hover{
  color:var(--text-primary);border-color:var(--border-bright);background:var(--ghost-button-hover);
}

.tcg-setup-chips{
  padding:0 2px;
}

.tcg-match-body{
  overflow:hidden;
}

.tcg-stage-shell{
  width:min(980px,calc(100% - 32px));
  margin:0 auto;
  padding:84px 0 130px;
  display:grid;
  grid-template-columns:120px minmax(0,1fr) 120px;
  align-items:center;
  gap:18px;
}

.tcg-sidepile{
  display:flex;flex-direction:column;gap:10px;
}

.tcg-sidepile__card{
  border:1px solid var(--border);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.02),transparent),var(--bg-surface);
  padding:12px;
  text-align:center;
  box-shadow:0 12px 28px rgba(0,0,0,.18);
}

.tcg-sidepile__label{
  display:block;
  color:var(--text-muted);
  font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  margin-bottom:4px;
}

.tcg-sidepile__value{
  color:var(--text-primary);
  font-size:20px;font-weight:800;
}

.tcg-sidepile__coach{
  color:var(--text-secondary);
  font-size:11px;line-height:1.45;
}

.tcg-ball{
  position:absolute;
  z-index:4;
  width:16px;height:16px;
  border-radius:999px;
  background:radial-gradient(circle at 30% 30%,#fff 0 24%,#d1d5db 25% 45%,#111 46% 55%,#fff 56% 100%);
  box-shadow:0 6px 12px rgba(0,0,0,.35);
  transform:translate(-50%,-50%);
}

.tcg-action-strip{
  padding:0 2px;
}

.tcg-action-pill{
  flex:0 0 auto;
  padding:8px 12px;
  border-radius:10px;
  border:1px solid var(--ghost-button-border);
  background:var(--ghost-button-bg);
  color:var(--ghost-button-text);
  font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;
}

.tcg-action-pill:hover{
  color:var(--text-primary);
  border-color:var(--border-bright);
  background:var(--ghost-button-hover);
}

.tcg-action-pill.is-live{
  color:var(--accent);
  border-color:color-mix(in srgb,var(--accent) 32%,var(--border));
  background:color-mix(in srgb,var(--accent) 12%,var(--bg-elevated));
}

.tcg-counter-modal p{
  color:var(--text-secondary);
  font-size:13px;
  line-height:1.6;
}

@media (max-width:960px){
  .tcg-playbook-panel{
    grid-template-columns:1fr;
  }

  .tcg-setup-bar,
  .tcg-match-bar{
    grid-template-columns:1fr;
  }

  .tcg-stage-shell{
    grid-template-columns:1fr;
    gap:14px;
    padding-top:88px;
  }

  .tcg-sidepile{
    order:2;
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

@media (max-width:640px){
  :root{
    --tcg-cell:28px;
  }

  .tcg-roster-card,
  .tcg-hand-card{
    width:118px;
    min-height:86px;
    padding:10px;
  }

  .tcg-library-grid{
    grid-template-columns:1fr;
  }

  .tcg-sidepile{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
