/* =============================================================
   gameplan.css — Gameplan-Modul (Studio-Tab)
   Nutzt die Design-Tokens aus base.css (--brand, --bg-*, --text-*, …).
   Offense-Akzent = --brand (orange), Defense-Akzent = --brand-2 (blau).
   ============================================================= */

.gp-wrap { display: flex; flex-direction: column; gap: 14px; }
.gp-intro { color: var(--text-muted); font-size: 14px; line-height: 1.5; }

/* ── Kopf: Seite + Gegner + Aktion ── */
.gp-head { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.gp-side-toggle { display: inline-flex; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-full); padding: 3px; }
.gp-side-toggle button { border: none; background: none; color: var(--text-secondary); font-size: 13px; font-weight: 600; padding: 6px 16px; border-radius: var(--r-full); cursor: pointer; }
.gp-side-toggle button.on { background: var(--brand); color: #fff; }
.gp-side-toggle button.on[data-side="defense"] { background: var(--brand-2); }
.gp-head .gp-spacer { flex: 1; }

.gp-scout-chips { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 2px; }

/* ── Gameplan-Liste ── */
.gp-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.gp-card { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 14px; display: flex; flex-direction: column; gap: 8px; }
.gp-card-title { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.gp-card-meta { font-size: 12px; color: var(--text-muted); display: flex; gap: 10px; }
.gp-card-actions { display: flex; gap: 6px; margin-top: 4px; }
.gp-empty { color: var(--text-muted); font-size: 13px; padding: 18px 4px; text-align: center; }

/* ── Builder ── */
.gp-builder { display: flex; flex-direction: column; gap: 12px; }
.gp-builder-head { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.gp-builder-title { font-size: 17px; font-weight: 700; color: var(--text-primary); }
.gp-builder-tools { display: flex; gap: 6px; flex-wrap: wrap; }
.gp-builder-head .gp-spacer { flex: 1; }
/* Aktiver Panel-Schalter (Plays & Pakete / Erweitert / Konzepte) klar als „an" erkennbar */
.gp-builder-tools .btn.on { background: var(--brand-subtle); border-color: var(--brand); color: var(--brand); box-shadow: inset 0 0 0 1px var(--brand); }

/* Version-Nummer (editierbar) */
.gp-ver { display: inline-flex; align-items: center; gap: 2px; font-size: 13px; font-weight: 700; color: var(--text-secondary); background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-full); padding: 3px 4px 3px 9px; }
.gp-ver input { width: 42px; background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-full); color: var(--text-primary); font-size: 13px; font-weight: 700; padding: 3px 6px; text-align: center; }
.gp-ver input:focus { outline: none; border-color: var(--brand); }

/* Speicher-Status-Pille */
.gp-save-status { font-size: 12px; font-weight: 600; padding: 3px 9px; border-radius: var(--r-full); opacity: 0; transition: opacity .18s; white-space: nowrap; }
.gp-save-status.saving { opacity: 1; background: var(--bg-hover); color: var(--text-muted); }
.gp-save-status.saved { opacity: 1; background: rgba(74,222,128,.16); color: var(--success); }
.gp-save-status.error { opacity: 1; background: rgba(248,113,113,.16); color: var(--danger, #f87171); }
.gp-save-status.saved.fade { opacity: 0; }

/* Builder im Vollbild-Modus (Chrome ausgeblendet) */
.gp-wrap-builder { gap: 10px; }
.gp-plays-hint { font-size: 13px; color: var(--text-secondary); line-height: 1.5; margin-bottom: 10px; }

.gp-section { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.gp-section-head { display: flex; align-items: center; justify-content: space-between; padding: 10px 12px; cursor: pointer; user-select: none; }
.gp-section-head h3 { font-size: 13px; font-weight: 700; color: var(--text-primary); text-transform: uppercase; letter-spacing: .03em; margin: 0; }
.gp-section-head .gp-sec-count { color: var(--text-muted); font-size: 12px; font-weight: 600; }
.gp-section-body { padding: 0 12px 12px; display: flex; flex-direction: column; gap: 8px; }
.gp-section.collapsed .gp-section-body { display: none; }

.gp-call { display: flex; flex-direction: column; gap: 8px; background: var(--bg-elevated); border: 1px solid var(--border-muted); border-radius: var(--r-md); padding: 8px; }
.gp-call-top { display: flex; align-items: center; gap: 10px; }
.gp-call-thumb { width: 64px; height: 38px; flex: 0 0 auto; background: var(--bg-base); border-radius: var(--r-sm); overflow: hidden; }
.gp-call-thumb svg { width: 100%; height: 100%; display: block; }
.gp-call-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.gp-call-name { font-size: 13px; font-weight: 600; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gp-call-note { font-size: 12px; color: var(--text-muted); }
.gp-call-side { display: flex; align-items: center; gap: 6px; }
.gp-call-pri { width: 44px; background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 5px 4px; font-size: 13px; text-align: center; }
.gp-call-pri:focus { outline: none; border-color: var(--brand); }
.gp-call-note-inp { width: 100%; background: transparent; border: none; border-bottom: 1px solid transparent; color: var(--text-muted); font-size: 12px; padding: 2px 0; transition: border-color .12s; }
.gp-call-note-inp::placeholder { color: var(--text-muted); opacity: .6; }
.gp-call-note-inp:hover { border-bottom-color: var(--border); }
.gp-call-note-inp:focus { outline: none; border-bottom-color: var(--brand); color: var(--text-primary); }
.gp-add-call { align-self: flex-start; }

/* ── Engine-Vorschau ── */
.gp-preview, .gp-weights { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 14px; }
.gp-panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.gp-panel-head h3 { font-size: 14px; font-weight: 700; margin: 0; }
.gp-sit-form { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 8px; align-items: end; }
.gp-field { display: flex; flex-direction: column; gap: 3px; font-size: 12px; color: var(--text-secondary); }
.gp-field input, .gp-field select { background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 6px 8px; font-size: 13px; }

.gp-suggestions { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.gp-sug { display: flex; align-items: center; gap: 10px; background: var(--bg-elevated); border: 1px solid var(--border); border-left: 3px solid var(--brand); border-radius: var(--r-md); padding: 8px 10px; }
.gp-sug.rank-0 { border-left-color: var(--brand); }
.gp-sug-rank { font-family: var(--font-display); font-size: 22px; color: var(--brand); width: 26px; text-align: center; }
.gp-sug-body { flex: 1; min-width: 0; }
.gp-sug-name { font-size: 14px; font-weight: 700; color: var(--text-primary); }
.gp-sug-rationale { font-size: 13px; color: var(--text-secondary); line-height: 1.5; }
.gp-conf { font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: var(--r-full); }
.gp-conf.high { background: rgba(74,222,128,.16); color: var(--success); }
.gp-conf.med { background: rgba(251,191,36,.16); color: var(--warning); }
.gp-conf.low { background: var(--bg-hover); color: var(--text-muted); }

/* ── Gewichte ── */
.gp-panel-actions { display: flex; gap: 6px; flex-wrap: wrap; }
.gp-weights { padding: 16px; }
.gp-weight-row { display: grid; grid-template-columns: 168px 1fr 42px; align-items: center; gap: 12px; padding: 7px 0; font-size: 13.5px; color: var(--text-secondary); border-bottom: 1px solid var(--border-muted); }
.gp-weight-row:last-child { border-bottom: none; }
.gp-weight-row > span:first-child { font-weight: 600; color: var(--text-primary); }
.gp-weight-row input[type="range"] { width: 100%; accent-color: var(--brand); height: 4px; }
.gp-weight-val { text-align: right; font-variant-numeric: tabular-nums; color: var(--brand); font-weight: 700; }

/* ── Live-Modus (große Touch-Ziele, Outdoor) ── */
.gp-live { display: flex; flex-direction: column; gap: 12px; }
.gp-live-top { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.gp-live-presence { font-size: 12px; color: var(--text-muted); display: inline-flex; align-items: center; gap: 5px; }
.gp-live-presence .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--success); display: inline-block; }
.gp-banner { background: var(--brand-subtle); border: 1px solid var(--brand); color: var(--brand); border-radius: var(--r-md); padding: 10px 12px; font-size: 14px; font-weight: 600; }
.gp-banner.twomin { background: rgba(14,165,233,.12); border-color: var(--brand-2); color: var(--brand-2); }
.gp-offline { background: var(--bg-hover); color: var(--text-muted); border-radius: var(--r-md); padding: 6px 10px; font-size: 12px; }

.gp-state { display: grid; grid-template-columns: repeat(auto-fit, minmax(72px, 1fr)); gap: 8px; }
.gp-state-cell { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 8px; text-align: center; }
.gp-state-cell label { display: block; font-size: 11px; color: var(--text-muted); margin-bottom: 4px; }
.gp-state-cell .val { font-family: var(--font-display); font-size: 24px; color: var(--text-primary); line-height: 1; }
.gp-state-cell .step { display: flex; gap: 4px; justify-content: center; margin-top: 6px; }
.gp-state-cell .step button { width: 32px; height: 32px; border-radius: var(--r-sm); border: 1px solid var(--border); background: var(--bg-elevated); color: var(--text-secondary); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; transition: border-color .12s, color .12s; }
.gp-state-cell .step button:hover { border-color: var(--brand); color: var(--brand); }
.gp-state-cell .step button:active { transform: scale(.94); }

.gp-live-sugs .gp-sug { padding: 12px; }
.gp-live-sugs .gp-sug-name { font-size: 17px; }
.gp-call-btn { min-height: 44px; min-width: 88px; font-size: 15px; }

/* großflächige Tap-Buttons für Erfassung/Ergebnis */
.gp-bigrow { display: flex; gap: 10px; flex-wrap: wrap; }
.gp-big { flex: 1 1 120px; min-height: 56px; border-radius: var(--r-lg); border: 1px solid var(--border); background: var(--bg-surface); color: var(--text-primary); font-size: 16px; font-weight: 700; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; transition: border-color .12s, background .12s, transform .06s; }
.gp-big:hover { border-color: var(--brand); }
.gp-big:active { transform: scale(.98); }
.gp-big.ok { border-color: var(--success); color: var(--success); }
.gp-big.no { border-color: var(--danger); color: var(--danger); }
.gp-big.brand { border-color: var(--brand); color: var(--brand); }

.gp-log { display: flex; flex-direction: column; gap: 4px; max-height: 220px; overflow-y: auto; }
.gp-log-row { display: flex; gap: 8px; font-size: 12px; color: var(--text-secondary); padding: 5px 8px; background: var(--bg-surface); border-radius: var(--r-sm); }
.gp-log-row .ev { font-weight: 700; color: var(--text-primary); }

/* ── Play-Picker (Modal) ── */
.gp-pick-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.gp-pick-item { display: flex; flex-direction: column; gap: 6px; background: var(--bg-elevated); border: 1px solid var(--border); border-radius: var(--r-md); padding: 8px; cursor: pointer; color: var(--text-primary); font-size: 13px; text-align: center; }
.gp-pick-item:hover { border-color: var(--brand); }
.gp-pick-item .gp-call-thumb { width: 100%; height: 80px; }

/* ── Rollen-Umschalter (Live, pro Nutzer) ── */
.gp-role-toggle { display: inline-flex; gap: 2px; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-full); padding: 2px; }
.gp-role-toggle button { border: none; background: none; color: var(--text-secondary); font-size: 12px; font-weight: 600; padding: 4px 12px; border-radius: var(--r-full); cursor: pointer; min-height: 32px; }
.gp-role-toggle button.on { background: var(--brand); color: #fff; }

/* ── Clip-Sprung-Button (Vorschlag + Call-Zeile) ── */
.gp-clip-btn, .gp-call-clip { color: var(--text-muted); }
.gp-clip-btn:hover, .gp-call-clip:hover { color: var(--brand); }

/* ── Live-Einstellungen ── */
.gp-live-settings { display: flex; flex-wrap: wrap; gap: 10px; padding: 6px 2px 2px; }
.gp-live-settings label { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; color: var(--text-secondary); cursor: pointer; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-full); padding: 5px 12px 5px 10px; transition: border-color .12s, color .12s; }
.gp-live-settings label:hover { border-color: var(--brand); color: var(--text-primary); }
.gp-live-settings input[type="checkbox"] { width: 15px; height: 15px; accent-color: var(--brand); cursor: pointer; margin: 0; }

/* ── Konzepte & Pakete ── */
.gp-concepts { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 14px; margin-bottom: 12px; }
.gp-concept-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 12px; }
.gp-concept-group h4 { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--text-muted); margin: 0 0 6px; }
.gp-concept-row { display: flex; align-items: center; gap: 6px; margin-bottom: 5px; }
.gp-concept-name { flex: 1; min-width: 0; background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 5px 7px; font-size: 13px; }
.gp-concept-add { display: flex; gap: 6px; margin-top: 4px; }
.gp-concept-new { flex: 1; min-width: 0; background: var(--bg-base); border: 1px dashed var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 5px 7px; font-size: 13px; }
.gp-concept-name:focus, .gp-concept-new:focus, .gp-call-meta select:focus, .gp-yards input:focus { outline: none; border-color: var(--brand); border-style: solid; }
.gp-concept-addbtn { padding: 5px 12px; font-weight: 700; }
.gp-call-meta-toggle { color: var(--text-muted); }
.gp-call-meta-toggle:hover, .gp-call.meta-open .gp-call-meta-toggle { color: var(--brand); }

/* ── Call-Chips (Konzept/Formation/Motion/Package) ── */
.gp-call-chips { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 2px; }
.gp-chip { font-size: 10px; font-weight: 600; color: var(--text-secondary); background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-full); padding: 1px 7px; }
.gp-chip-pkg { color: var(--brand); border-color: var(--brand); }

/* ── Call-Zuweisung (ein-/ausklappbar) ── */
.gp-call-meta { display: none; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); gap: 8px; padding: 8px; border-top: 1px dashed var(--border); }
.gp-call.meta-open .gp-call-meta { display: grid; }
.gp-call-meta label { display: flex; flex-direction: column; gap: 3px; font-size: 11px; color: var(--text-muted); }
.gp-call-meta select { background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 5px 6px; font-size: 12px; }

/* ── Live: Packages + Yardage ── */
.gp-pkg-bar { flex-wrap: wrap; }
.gp-pkg-btn { flex: 0 1 auto; min-height: 44px; }
.gp-pkg-plays { display: flex; flex-direction: column; gap: 6px; margin-top: 8px; }
.gp-yards { display: flex; justify-content: center; padding: 2px 0; }
.gp-yards label { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; color: var(--text-secondary); }
.gp-yards input { width: 90px; background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 8px; font-size: 18px; text-align: center; }

@media (max-width: 640px) {
  .gp-list { grid-template-columns: 1fr 1fr; }
  .gp-call-thumb { width: 52px; height: 32px; }
  .gp-role-toggle button { padding: 4px 10px; }
}

/* ── Erweitert / Plays-Panel ── */
.gp-adv-panel { margin-top: 14px; border-top: 1px dashed var(--border); padding-top: 12px; }

/* ── Flow-Builder (Node-Canvas) ── */
.gp-flow-builder-root { height: 62vh; min-height: 380px; margin-top: 10px; }
.gpf-wrap { display: grid; grid-template-columns: 132px 1fr 240px; gap: 10px; height: 100%; }
.gpf-palette { display: flex; flex-direction: column; gap: 6px; }
.gpf-pal-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--text-muted); }
.gpf-pal-btn { display: flex; align-items: center; gap: 7px; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-md); color: var(--text-primary); padding: 8px 10px; font-size: 13px; font-weight: 600; cursor: pointer; transition: border-color .12s; }
.gpf-pal-btn:hover { border-color: var(--brand); }
.gpf-hint { font-size: 12.5px; color: var(--text-secondary); margin-top: 6px; line-height: 1.5; }
.gpf-canvas-wrap { position: relative; overflow: hidden; border: 1px solid var(--border); border-radius: var(--r-md); background: var(--bg-base); display: flex; flex-direction: column; }
.gpf-toolbar { display: flex; align-items: center; gap: 6px; padding: 6px 8px; border-bottom: 1px solid var(--border); background: var(--bg-surface); }
.gpf-valid { font-size: 12px; margin-left: auto; padding: 2px 8px; border-radius: var(--r-full); font-weight: 600; }
.gpf-valid.ok { color: var(--success, #3fb950); }
.gpf-valid.bad { color: var(--danger); }
.gpf-svg { width: 100%; flex: 1; min-height: 0; display: block; touch-action: none; }
.gp-flow-cue { background: rgba(217, 161, 65, .14); border-color: var(--warning, #d9a441); color: var(--text-primary); }

.gpf-edge { fill: none; stroke: var(--text-muted); stroke-width: 1.6; color: var(--text-muted); }
.gpf-edge.sel { stroke: var(--brand); color: var(--brand); stroke-width: 2.2; }
.gpf-edge.rubber { stroke: var(--brand); stroke-dasharray: 4 3; }
.gpf-edge-hit { fill: none; stroke: transparent; stroke-width: 12; cursor: pointer; }

.gpf-box { fill: var(--bg-surface); stroke: var(--border); stroke-width: 1.4; }
.gpf-node .gpf-title { fill: var(--text-primary); font-size: 12px; font-weight: 700; }
.gpf-node .gpf-summary { fill: var(--text-muted); font-size: 10px; }
.gpf-node { cursor: grab; }
.gpf-node.sel .gpf-box { stroke: var(--brand); stroke-width: 2; }
.gpf-node.bad .gpf-box { stroke: var(--danger); }
.gpf-node.is-start .gpf-box { stroke-dasharray: 3 2; }
.gpf-node.start .gpf-box { fill: var(--bg-elevated); }
.gpf-node.gate .gpf-box { stroke-left: 3px; fill: var(--bg-surface); }
.gpf-node.gate .gpf-title { fill: var(--warning, #d9a441); }
.gpf-node.suggest .gpf-title { fill: var(--brand); }
.gpf-node.capture .gpf-title { fill: var(--success, #3fb950); }
.gpf-port { fill: var(--bg-elevated); stroke: var(--text-muted); stroke-width: 1.4; cursor: crosshair; }
.gpf-port.out:hover, .gpf-port.in:hover { fill: var(--brand); stroke: var(--brand); }
.gpf-portlbl { fill: var(--text-muted); font-size: 9px; }

.gpf-inspector { overflow-y: auto; }
.gpf-insp { background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 12px; display: flex; flex-direction: column; gap: 10px; }
.gpf-insp-empty { font-size: 13px; color: var(--text-secondary); line-height: 1.5; }
.gpf-insp-head { font-size: 12px; color: var(--text-muted); font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--text-secondary); }
.gpf-insp-actions { display: flex; gap: 6px; flex-wrap: wrap; border-top: 1px dashed var(--border); padding-top: 10px; }
.gpf-srclist { display: flex; flex-wrap: wrap; gap: 5px; margin: 4px 0; }
.gpf-srcchip { font-size: 11px; background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-full); padding: 2px 4px 2px 8px; display: inline-flex; align-items: center; gap: 4px; }
.gpf-srcchip button { border: none; background: none; color: var(--text-muted); cursor: pointer; font-size: 14px; line-height: 1; }
.gpf-pickgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); gap: 6px; margin: 6px 0 14px; }
.gpf-pick { background: var(--bg-elevated); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 7px 8px; font-size: 12px; cursor: pointer; text-align: left; }
.gpf-pick:hover { border-color: var(--brand); }

/* ── Geführter Live-Modus ── */
.gp-flow-sit { margin: 6px 0 12px; }
.gp-flow-sitline { display: flex; flex-wrap: wrap; align-items: center; gap: 14px; font-size: 14px; color: var(--text-secondary); background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-md); padding: 8px 12px; }
.gp-flow-sitline b { color: var(--text-primary); font-size: 16px; }
.gp-flow-correct-btn { margin-left: auto; font-size: 12px; }
.gp-flow-main { margin: 8px 0 14px; }
.gp-flow-step-title { font-size: 16px; font-weight: 700; color: var(--text-primary); margin-bottom: 10px; }
.gp-flow-opp { margin: 6px 0; border: 1px solid var(--border); border-radius: var(--r-md); background: var(--bg-surface); }
.gp-flow-opp summary { cursor: pointer; padding: 8px 12px; font-size: 13px; color: var(--text-secondary); font-weight: 600; }
.gp-flow-opp-row { display: flex; flex-wrap: wrap; gap: 6px; padding: 0 12px 12px; }
.gp-chip-btn { min-height: 38px; padding: 6px 14px; border-radius: var(--r-full); border: 1px solid var(--border); background: var(--bg-elevated); color: var(--text-primary); font-size: 14px; cursor: pointer; }
.gp-chip-btn:hover { border-color: var(--brand); }
.gp-flow-foot { margin-top: 12px; display: flex; flex-direction: column; gap: 8px; }

@media (max-width: 820px) {
  .gpf-wrap { grid-template-columns: 1fr; }
  .gpf-palette { flex-direction: row; flex-wrap: wrap; }
  .gp-flow-builder-root { height: auto; }
  .gpf-canvas-wrap { height: 52vh; }
}

/* ── Phase 3: Plays-Karten-Grid ── */
.gp-play-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; padding-top: 8px; }
.gp-play-card { display: flex; flex-direction: column; gap: 6px; }
.gp-play-card .gp-call-thumb { width: 100%; height: 84px; }
.gp-card-foot { display: flex; align-items: center; gap: 6px; margin-top: auto; }
.gp-card-pkg { flex: 1; min-width: 0; background: var(--bg-base); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); font-size: 11px; padding: 4px 5px; }
.gp-card-actions { display: flex; gap: 2px; }
.gp-section-head .gp-add-call { margin-left: auto; }

/* ── Phase 3: Node-Highlight (Vorschau) + Multiselect + Lasso ── */
.gpf-node.multisel .gpf-box { stroke: var(--brand); stroke-width: 1.8; }
.gpf-node.onpath .gpf-box { stroke: var(--brand); }
.gpf-node.active .gpf-box { stroke: var(--success, #3fb950); stroke-width: 2.4; }
.gpf-edge.active { stroke: var(--success, #3fb950); stroke-width: 2.4; color: var(--success, #3fb950); }
.gpf-lasso { fill: rgba(80, 150, 240, .12); stroke: var(--brand); stroke-width: 1; stroke-dasharray: 4 3; }
.gpf-insp-help { font-size: 13px; color: var(--text-secondary); line-height: 1.55; background: var(--bg-base); border-radius: var(--r-sm); padding: 9px 11px; }

/* Quellen-Picker + eigene Vorlagen */
.gpf-src-hint { font-size: 13px; color: var(--text-secondary); line-height: 1.5; margin: 0 0 12px; }
.gpf-tpl-save { width: 100%; margin-bottom: 12px; }
.gpf-tpl-list { display: flex; flex-direction: column; gap: 6px; }
.gpf-tpl-row { display: flex; align-items: center; gap: 6px; }
.gpf-tpl-row .gpf-pick { flex: 1; }
.gpf-toolbar .btn.on { color: var(--brand); border-color: var(--brand); }

/* ── Phase 3: Live-Vorschau-Panel ── */
.gpf-preview { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding: 8px 10px; border-bottom: 1px solid var(--border); background: var(--bg-base); }
.gpf-pv-lbl { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em; color: var(--brand); }
.gpf-pv-f { display: inline-flex; align-items: center; gap: 4px; font-size: 11px; color: var(--text-muted); }
.gpf-pv-f input { width: 50px; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-sm); color: var(--text-primary); padding: 3px 5px; font-size: 12px; }
.gpf-pv-sigs { display: inline-flex; gap: 4px; }
.gpf-pv-sig { font-size: 11px; padding: 3px 9px; border-radius: var(--r-full); border: 1px solid var(--border); background: var(--bg-surface); color: var(--text-secondary); cursor: pointer; }
.gpf-pv-sig.on { background: var(--brand); color: #fff; border-color: var(--brand); }
.gpf-pv-out { flex-basis: 100%; display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
.gpf-pv-active { font-size: 12px; font-weight: 700; color: var(--success, #3fb950); }
.gpf-pv-sug { font-size: 12px; background: var(--bg-surface); border: 1px solid var(--border); border-radius: var(--r-sm); padding: 2px 8px; }
