/* Hide native select + any select2 the theme spawns on it — immediately, no flash */
#odk-deck-app #odk-deck-select,
#odk-deck-app #odk-deck-select + .select2-container,
#odk-deck-app span[aria-owns="select2-odk-deck-select-results"],
#odk-deck-app .select2-container .select2-selection[aria-owns="select2-odk-deck-select-results"] { display: none !important; }

/* ── OPCG Deck Builder ─────────────────────────────────────────────────── */

#opcg-deck-app {
    --odk-bg:       #080e1a;
    --odk-surface:  #111827;
    --odk-surface2: #1e293b;
    --odk-border:   #1f2d40;
    --odk-text:     #f1f5f9;
    --odk-muted:    #64748b;
    --odk-gold:     #f59e0b;
    --odk-green:    #22c55e;
    --odk-red:      #ef4444;
    --odk-radius:   12px;
    font-family: inherit;
    color: var(--odk-text);
}
.odk-header {
    display:flex;flex-direction:column;gap:8px;
    padding:16px 0 20px;border-bottom:1px solid var(--odk-border);margin-bottom:20px;
}
.odk-header-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.odk-header-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.odk-select{background:var(--odk-surface);border:1px solid var(--odk-border);border-radius:8px;color:var(--odk-text);padding:9px 14px;font-size:13px;cursor:pointer;flex:0 0 280px;max-width:280px;appearance:auto;-webkit-appearance:auto}
.odk-select:focus{outline:none;border-color:var(--odk-gold)}
.odk-deck-name-input{background:var(--odk-surface);border:1px solid var(--odk-border);border-radius:8px;color:var(--odk-text);padding:9px 14px;font-size:14px;font-weight:600;flex:0 0 280px;max-width:280px;transition:border-color .15s}
.odk-deck-name-input:focus{outline:none;border-color:var(--odk-gold)}
.odk-deck-name-input::placeholder{color:var(--odk-muted);font-weight:400}
.odk-btn{padding:9px 18px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.odk-btn-new{background:var(--odk-surface2);color:var(--odk-text);border:1px solid var(--odk-border)}
.odk-btn-new:hover{background:#263548}
.odk-btn-save{background:var(--odk-gold);color:#000;box-shadow:0 2px 10px rgba(245,158,11,.3)}
.odk-btn-save:hover{background:#f6a821}
.odk-btn-share{background:var(--odk-surface2);color:var(--odk-text);border:1px solid var(--odk-border)}
.odk-btn-share:hover{background:#263548}
.odk-btn-delete{background:transparent;color:var(--odk-red);border:1px solid rgba(239,68,68,.4);padding:9px 13px}
.odk-btn-delete:hover{background:rgba(239,68,68,.1)}
.odk-main{display:grid;grid-template-columns:300px 1fr;gap:16px;align-items:start}
@media(max-width:900px){.odk-main{grid-template-columns:1fr}}
.odk-browser{background:var(--odk-surface);border:1px solid var(--odk-border);border-radius:var(--odk-radius);padding:14px;position:sticky;top:72px}
.odk-browser-search{margin-bottom:10px}
.odk-browser-search input{width:100%;background:#0a1120;border:1px solid var(--odk-border);border-radius:8px;color:var(--odk-text);padding:9px 12px;font-size:13px;box-sizing:border-box;transition:border-color .15s}
.odk-browser-search input:focus{outline:none;border-color:var(--odk-gold)}
.odk-series-filter{width:100%;background:#0a1120;border:1px solid var(--odk-border);border-radius:8px;color:var(--odk-text);padding:8px 12px;font-size:12px;box-sizing:border-box;margin-top:6px;cursor:pointer;transition:border-color .15s}
.odk-series-filter:focus{outline:none;border-color:var(--odk-gold)}
.odk-series-filter option{background:#0a1120;color:var(--odk-text)}

/* ── Match Record panel (deck-builder right column) ── */
.odk-match-panel{background:#0f172a;border:1px solid #1f2d40;border-radius:10px;padding:10px 12px;margin-bottom:10px}
.odk-match-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;font-weight:700;color:#f1f5f9}
.odk-match-rate{background:#1e3a5f;color:#7dd3fc;font-size:11px;padding:2px 8px;border-radius:10px}
.odk-match-stats{display:flex;gap:6px;margin-bottom:8px}
.odk-match-stat{flex:1;background:rgba(0,0,0,.25);border-radius:6px;padding:6px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2px}
.odk-match-stat b{font-size:18px;font-weight:800}
.odk-match-stat i{font-size:9px;font-style:normal;color:#94a3b8;letter-spacing:.06em}
.odk-match-w b{color:#4ade80} .odk-match-l b{color:#f87171} .odk-match-d b{color:#fbbf24}
.odk-match-actions{display:flex;gap:6px}
.odk-match-actions .odk-mini-btn{flex:1;font-size:12px;font-weight:700;padding:8px 10px;border-radius:8px;cursor:pointer;transition:filter .15s,transform .05s}
.odk-match-actions .odk-mini-btn:hover{filter:brightness(1.12)}
.odk-match-actions .odk-mini-btn:active{transform:translateY(1px)}
#odk-match-record{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;border:1px solid #15803d;box-shadow:0 2px 6px rgba(34,197,94,.35)}
#odk-match-history{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border:1px solid #1d4ed8;box-shadow:0 2px 6px rgba(59,130,246,.35)}

/* ── Match Record modal ── */
.odk-match-modal{display:none;position:fixed;inset:0;z-index:999998;background:rgba(0,0,0,.8);backdrop-filter:blur(6px);align-items:flex-start;justify-content:center;padding:40px 16px;box-sizing:border-box;overflow:auto}
.odk-match-modal.show{display:flex}
.odk-match-modal-card{background:#131a27;border:1px solid #1f2d40;border-radius:14px;width:100%;max-width:520px;padding:22px 24px;position:relative}
.odk-match-modal-close{position:absolute;top:10px;right:12px;background:transparent;border:1px solid #334155;color:#94a3b8;border-radius:6px;width:30px;height:30px;cursor:pointer;font-size:13px}
.odk-match-modal-close:hover{background:#ef4444;color:#fff;border-color:#ef4444}
.odk-match-modal-title{font-size:16px;font-weight:800;color:#f1f5f9;margin-bottom:14px;padding-right:36px}
.odk-match-modal-body{font-size:13px;color:#cbd5e1}

/* Match form */
.odk-mf-row{display:flex;gap:6px;margin-bottom:10px}
.odk-mf-row label{flex:1;font-size:11px;color:#94a3b8;display:flex;flex-direction:column;gap:4px}
.odk-mf-row input[type=text],.odk-mf-row select,.odk-mf-row textarea{background:#0a1120;border:1px solid #1f2d40;border-radius:6px;color:#e2e8f0;padding:7px 9px;font-size:12px;font-family:inherit;width:100%;box-sizing:border-box}
.odk-mf-row input:focus,.odk-mf-row select:focus,.odk-mf-row textarea:focus{outline:none;border-color:var(--odk-gold)}
.odk-mf-result{display:flex;gap:6px}
.odk-mf-result button{flex:1;padding:10px;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;border:1px solid #334155;background:transparent;color:#94a3b8;transition:all .15s}
.odk-mf-result button.active.W{background:#16a34a;color:#fff;border-color:#16a34a}
.odk-mf-result button.active.L{background:#dc2626;color:#fff;border-color:#dc2626}
.odk-mf-result button.active.D{background:#ca8a04;color:#fff;border-color:#ca8a04}
.odk-mf-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:#cbd5e1;cursor:pointer}
.odk-mf-toggle input{accent-color:var(--odk-gold)}
.odk-mf-submit{margin-top:14px;width:100%;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#0b0b0b;border:1px solid #b45309;border-radius:10px;padding:12px;font-size:14px;font-weight:900;letter-spacing:.04em;cursor:pointer;box-shadow:0 0 0 1px rgba(251,191,36,.25),0 4px 14px rgba(245,158,11,.45)}
.odk-mf-submit:hover{filter:brightness(1.12);box-shadow:0 0 0 1px rgba(251,191,36,.4),0 6px 18px rgba(245,158,11,.6)}
.odk-mf-submit:active{transform:translateY(1px)}

/* Match history list */
.odk-mh-empty{text-align:center;color:#64748b;padding:20px}
.odk-mh-row{display:flex;align-items:center;gap:8px;background:#0a1120;border:1px solid #1f2d40;border-radius:6px;padding:8px 10px;margin-bottom:6px;font-size:12px}
.odk-mh-result{font-weight:800;width:24px;text-align:center}
.odk-mh-result.W{color:#4ade80} .odk-mh-result.L{color:#f87171} .odk-mh-result.D{color:#fbbf24}
.odk-mh-info{flex:1;color:#cbd5e1;line-height:1.4}
.odk-mh-info small{color:#64748b;font-size:10px}
.odk-mh-del{background:transparent;border:none;color:#475569;cursor:pointer;font-size:14px;padding:4px 8px;border-radius:4px}
.odk-mh-del:hover{background:#1e293b;color:#f87171}

.odk-browser-filters{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.odk-pill{padding:4px 10px;border-radius:20px;border:1px solid var(--odk-border);background:transparent;color:var(--odk-muted);font-size:11px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:all .15s}
.odk-pill.active,.odk-pill:hover{background:var(--odk-surface2);color:var(--odk-text);border-color:#334155}
.odk-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.odk-card-list{max-height:500px;overflow-y:auto;display:flex;flex-direction:column;gap:3px}
.odk-card-list::-webkit-scrollbar{width:4px}
.odk-card-list::-webkit-scrollbar-thumb{background:#1f2d40;border-radius:4px}
.odk-browser-hint{text-align:center;padding:32px 16px;color:var(--odk-muted);font-size:13px}
.odk-browser-card{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:all .1s}
.odk-browser-card:hover{background:var(--odk-surface2);border-color:var(--odk-border)}
.odk-browser-card img{width:34px;height:47px;object-fit:cover;border-radius:4px;flex-shrink:0;background:#0a1120}
.odk-browser-card-info{flex:1;min-width:0}
.odk-browser-card-id{font-size:9px;color:var(--odk-muted);font-family:monospace;margin-bottom:1px}
.odk-browser-card-name{font-size:12px;color:var(--odk-text);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.odk-browser-card-meta{font-size:10px;color:var(--odk-muted);margin-top:2px;display:flex;align-items:center;gap:4px}
.odk-browser-card-add{width:26px;height:26px;border-radius:6px;border:1px solid var(--odk-border);background:var(--odk-surface2);color:var(--odk-gold);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .1s}
.odk-browser-card-add:hover{background:var(--odk-gold);color:#000;border-color:var(--odk-gold)}
.odk-browser-card-add.is-leader{color:var(--odk-green);border-color:rgba(34,197,94,.4)}
.odk-browser-card-add.is-leader:hover{background:var(--odk-green);color:#000;border-color:var(--odk-green)}
.odk-deck-panel{background:var(--odk-surface);border:1px solid var(--odk-border);border-radius:var(--odk-radius);padding:16px}
.odk-stats-bar{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;background:#0a1120;border-radius:10px;padding:14px 20px;margin-bottom:14px;align-items:center}
.odk-stat{text-align:center}
.odk-stat-num{font-size:22px;font-weight:800;color:var(--odk-text);line-height:1}
.odk-stat-lbl{font-size:10px;color:var(--odk-muted);display:block;margin-top:4px;text-transform:uppercase;letter-spacing:.05em}
.odk-stat-div{width:1px;height:36px;background:var(--odk-border)}
.odk-chart-wrap{margin-bottom:14px;background:#0a1120;border-radius:10px;padding:14px}
.odk-chart-title{font-size:10px;color:var(--odk-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.odk-chart{display:flex;align-items:flex-end;gap:5px;height:64px}
.odk-chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;height:100%;justify-content:flex-end}
.odk-chart-bar{width:100%;background:linear-gradient(180deg,#fbbf24,#f59e0b);border-radius:3px 3px 0 0;min-height:3px;transition:height .3s cubic-bezier(.34,1.4,.64,1)}
.odk-chart-label{font-size:9px;color:var(--odk-muted)}
.odk-chart-count{font-size:10px;color:var(--odk-text);font-weight:700;min-height:14px}
.odk-section-label{font-size:10px;color:var(--odk-muted);text-transform:uppercase;letter-spacing:.06em;margin:14px 0 8px;display:flex;align-items:center;gap:8px}
.odk-section-label::after{content:'';flex:1;height:1px;background:var(--odk-border)}
.odk-leader-slot{background:#0a1120;border:1px dashed var(--odk-border);border-radius:10px;padding:12px;min-height:72px;display:flex;align-items:center;transition:border-color .2s}
.odk-leader-empty{color:var(--odk-muted);font-size:12px;text-align:center;width:100%}
.odk-leader-card{display:flex;align-items:center;gap:12px;width:100%}
.odk-leader-card img{width:44px;height:61px;object-fit:cover;border-radius:5px;border:1px solid var(--odk-border)}
.odk-leader-card-info{flex:1}
.odk-leader-card-id{font-size:10px;color:var(--odk-muted);font-family:monospace}
.odk-leader-card-name{font-size:14px;font-weight:700;color:var(--odk-gold);margin-top:2px}
.odk-leader-remove{background:none;border:none;color:var(--odk-muted);font-size:16px;cursor:pointer;padding:4px;border-radius:4px;transition:color .15s}
.odk-leader-remove:hover{color:var(--odk-red)}
.odk-deck-cards{display:flex;flex-direction:column;gap:3px;max-height:420px;overflow-y:auto}
.odk-deck-cards::-webkit-scrollbar{width:4px}
.odk-deck-cards::-webkit-scrollbar-thumb{background:#1f2d40;border-radius:4px}
.odk-deck-empty{color:var(--odk-muted);font-size:12px;text-align:center;padding:28px}
.odk-deck-row{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#0a1120;border-radius:8px;border:1px solid var(--odk-border);transition:border-color .1s}
.odk-deck-row:hover{border-color:#334155}
.odk-deck-row img{width:28px;height:39px;object-fit:cover;border-radius:3px;flex-shrink:0}
.odk-deck-row-info{flex:1;min-width:0}
.odk-deck-row-id{font-size:9px;color:var(--odk-muted);font-family:monospace;display:flex;align-items:center;gap:4px}
.odk-deck-row-name{font-size:12px;color:var(--odk-text);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.odk-deck-row-controls{display:flex;align-items:center;gap:4px;flex-shrink:0}
.odk-qty-btn{width:22px;height:22px;border-radius:4px;border:1px solid var(--odk-border);background:var(--odk-surface2);color:var(--odk-text);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;line-height:1;transition:background .1s}
.odk-qty-btn:hover{background:#334155}
.odk-qty-num{min-width:26px;text-align:center;font-size:13px;font-weight:800;color:var(--odk-gold);font-family:monospace}
.odk-remove-btn{background:none;border:none;color:var(--odk-muted);font-size:13px;cursor:pointer;padding:2px 4px;border-radius:3px;transition:color .1s;flex-shrink:0}
.odk-remove-btn:hover{color:var(--odk-red)}
.odk-color-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}
.odk-share-header{padding:20px 0 16px;border-bottom:1px solid var(--odk-border);margin-bottom:20px}
.odk-share-title{font-size:26px;font-weight:800;color:var(--odk-text)}
.odk-share-meta{font-size:13px;color:var(--odk-muted);margin-top:6px}
@media(max-width:640px){
    .odk-header{flex-direction:column;align-items:stretch}
    .odk-header-left,.odk-header-right{width:100%}
    .odk-deck-name-input{width:100%}
    .odk-stats-bar{grid-template-columns:1fr 1fr;gap:10px;padding:12px}
    .odk-stat-div{display:none}
}

/* ── Public toggle ── */
.odk-btn-public { background:transparent;color:#64748b;border:1px solid #334155 }
.odk-btn-public:hover { background:#1e293b;color:#f1f5f9 }
.odk-btn-public.is-public { background:rgba(34,197,94,.15);color:#22c55e;border-color:rgba(34,197,94,.4) }
.odk-btn-export { background:transparent;color:#64748b;border:1px solid #334155 }
.odk-btn-export:hover { background:#1e293b;color:#f1f5f9 }
.odk-btn-playtest { background:transparent;color:#64748b;border:1px solid #334155 }
.odk-btn-playtest:hover { background:#1e293b;color:#f1f5f9 }

/* ── Library ── */
#opcg-deck-library-app { font-family:inherit;color:#f1f5f9 }
.odl-filters { display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px }
.odl-input { flex:1;min-width:180px;background:#111827;border:1px solid #1f2d40;border-radius:8px;color:#f1f5f9;padding:9px 14px;font-size:13px }
.odl-input:focus { outline:none;border-color:#f59e0b }
.odl-btn-search { background:#f59e0b;color:#000;border:none;border-radius:8px;padding:9px 20px;font-size:13px;font-weight:700;cursor:pointer }
.odl-grid { display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px }
.odl-loading { text-align:center;padding:40px;color:#64748b;grid-column:1/-1 }
.odl-deck-card { background:#111827;border:1px solid #1f2d40;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .15s;text-decoration:none;display:block }
.odl-deck-card:hover { border-color:#334155;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.4) }
.odl-deck-card-img { width:100%;aspect-ratio:5/7;object-fit:cover;background:#0a1120 }
.odl-deck-card-img-placeholder { width:100%;aspect-ratio:5/7;background:#0a1120;display:flex;align-items:center;justify-content:center;font-size:11px;color:#334155 }
.odl-deck-card-body { padding:12px }
.odl-deck-card-name { font-size:14px;font-weight:700;color:#f1f5f9;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis }
.odl-deck-card-meta { font-size:11px;color:#64748b }
.odl-pagination { display:flex;justify-content:center;gap:8px;margin-top:24px;flex-wrap:wrap }
.odl-page-btn { padding:6px 14px;border-radius:6px;border:1px solid #1f2d40;background:transparent;color:#94a3b8;cursor:pointer;font-size:13px }
.odl-page-btn.active { background:#f59e0b;color:#000;border-color:#f59e0b;font-weight:700 }
.odl-page-btn:hover:not(.active) { background:#1e293b }

/* ── Playtest stub block removed 2026-05-09 — full rules at line ~378 (.odk-pt-card,
   .odk-pt-card img, .odk-pt-card-label) override these in cascade anyway. */

/* ── Validation Panel ─────────────────────────────────────────────────────── */
.odk-validation-panel {
    display: flex;
    flex-direction: column;
    gap: 4px;
    background: #0a1120;
    border: 1px solid var(--odk-border);
    border-radius: 10px;
    padding: 10px 12px;
    margin-bottom: 12px;
    transition: border-color .2s;
}
.odk-validation-panel[data-state="ok"]    { border-color: rgba(34,197,94,.4); }
.odk-validation-panel[data-state="error"] { border-color: rgba(239,68,68,.4); }
.odk-validation-panel[data-state="warn"]  { border-color: rgba(245,158,11,.3); }
.odk-val-row {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: var(--odk-muted);
    line-height: 1.4;
}
.odk-val-row[data-ok="1"] .odk-val-text { color: var(--odk-text); }
.odk-val-icon { font-size: 13px; flex-shrink: 0; width: 16px; text-align: center; }

/* ── Type + Color Breakdown ──────────────────────────────────────────────── */
.odk-breakdown-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-bottom: 12px;
}
.odk-breakdown-col, .odk-color-breakdown {
    background: #0a1120;
    border: 1px solid var(--odk-border);
    border-radius: 10px;
    padding: 10px 12px;
}
.odk-bd-title {
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--odk-muted);
    margin-bottom: 8px;
}
.odk-bd-row {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 5px;
}
.odk-bd-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
}
.odk-bd-label {
    font-size: 10px;
    color: var(--odk-muted);
    width: 46px;
    flex-shrink: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.odk-bd-bar-wrap {
    flex: 1;
    height: 4px;
    background: var(--odk-border);
    border-radius: 2px;
    overflow: hidden;
}
.odk-bd-bar {
    height: 100%;
    border-radius: 2px;
    transition: width .3s cubic-bezier(.34,1.4,.64,1);
    opacity: .85;
}
.odk-bd-count {
    font-size: 10px;
    font-weight: 700;
    color: var(--odk-text);
    min-width: 20px;
    text-align: right;
    flex-shrink: 0;
}
.odk-bd-empty { font-size: 11px; color: var(--odk-muted); }
@media(max-width: 640px) {
    .odk-breakdown-wrap { grid-template-columns: 1fr; }
}


/* ── Custom Deck Dropdown ────────────────────────────────────────────────── */
.odk-dd-wrap { position: relative; flex: 0 0 280px; max-width: 280px; }
.odk-dd-trigger {
    width: 100%; display: flex; align-items: center; justify-content: space-between;
    gap: 8px; padding: 9px 14px; background: var(--odk-surface);
    border: 1px solid var(--odk-border); border-radius: 8px;
    color: var(--odk-text); font-size: 13px; cursor: pointer;
    transition: border-color .15s; text-align: left;
}
.odk-dd-trigger:hover { border-color: #334155; }
.odk-dd-trigger.open { border-color: var(--odk-gold); }
.odk-dd-label { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.odk-dd-arrow { color: var(--odk-muted); font-size: 11px; flex-shrink: 0; transition: transform .2s; }
.odk-dd-trigger.open .odk-dd-arrow { transform: rotate(180deg); }
.odk-dd-panel {
    position: absolute; top: calc(100% + 4px); left: 0;
    width: 100%; min-width: 240px;
    background: var(--odk-surface); border: 1px solid var(--odk-border);
    border-radius: 8px; box-shadow: 0 8px 24px rgba(0,0,0,.5);
    z-index: 9999; overflow: hidden;
}
.odk-dd-search-wrap { padding: 8px; border-bottom: 1px solid var(--odk-border); }
.odk-dd-search {
    width: 100%; background: var(--odk-surface2); border: 1px solid var(--odk-border);
    border-radius: 6px; color: var(--odk-text); padding: 7px 10px;
    font-size: 12px; box-sizing: border-box; outline: none;
}
.odk-dd-search:focus { border-color: var(--odk-gold); }
.odk-dd-list { max-height: 220px; overflow-y: auto; padding: 4px; }
.odk-dd-list::-webkit-scrollbar { width: 4px; }
.odk-dd-list::-webkit-scrollbar-thumb { background: var(--odk-border); border-radius: 4px; }
.odk-dd-item {
    display: flex; align-items: center; justify-content: space-between;
    padding: 8px 10px; border-radius: 6px; cursor: pointer;
    font-size: 13px; color: var(--odk-muted); transition: background .1s;
    gap: 8px;
}
.odk-dd-item:hover { background: var(--odk-surface2); color: var(--odk-text); }
.odk-dd-new-btn { color: var(--odk-gold) !important; font-weight: 600; border-bottom: 1px solid var(--odk-border); border-radius: 6px 6px 0 0; margin-bottom: 2px; }
.odk-dd-new-btn:hover { background: rgba(245,158,11,.1) !important; }
.odk-dd-item-name { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.odk-dd-item-count { font-size: 11px; color: var(--odk-muted); flex-shrink: 0; font-family: monospace; }
.odk-dd-empty { padding: 16px; text-align: center; color: var(--odk-muted); font-size: 12px; }

/* ── Playtest Modal ───────────────────────────────────────────────────────── */
.odk-pt-wrap {
    background: #111827; border: 1px solid #1f2d40; border-radius: 20px;
    width: 100%; max-width: 760px; max-height: 90vh; overflow-y: auto;
    padding: 24px; position: relative; display: flex; flex-direction: column; gap: 20px;
}
.odk-pt-header {
    display: flex; align-items: flex-start; justify-content: space-between;
}
.odk-pt-title { font-size: 18px; font-weight: 700; color: #f1f5f9; margin-bottom: 4px; }
.odk-pt-subtitle { font-size: 13px; color: #64748b; }
.odk-pt-close {
    background: none; border: none; color: #64748b; font-size: 20px;
    cursor: pointer; padding: 4px 8px; border-radius: 6px; line-height: 1;
    transition: color .15s, background .15s; flex-shrink: 0;
}
.odk-pt-close:hover { color: #f1f5f9; background: #1e293b; }
.odk-pt-hand {
    display: flex; flex-wrap: wrap; gap: 10px;
    min-height: 140px; padding: 16px;
    background: #0a1120; border: 1px solid #1f2d40; border-radius: 12px;
    align-content: flex-start;
}
.odk-pt-footer {
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 12px;
    padding-top: 16px; border-top: 1px solid #1f2d40;
}
.odk-pt-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.odk-pt-info { font-size: 13px; color: #64748b; }

/* Card in hand */
.odk-pt-card { width: 72px; border-radius: 8px; overflow: hidden; background: #0f172a; border: 1px solid #1f2d40; flex-shrink: 0; transition: transform .15s; }
.odk-pt-card:hover { transform: translateY(-4px); }
.odk-pt-card img { width: 100%; aspect-ratio: 5/7; object-fit: cover; display: block; }
.odk-pt-card-label { padding: 4px 5px; font-size: 9px; color: #94a3b8; text-align: center; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ── Playtest Buttons (standalone — no theme override) ───────────────────── */
.odk-pt-btn {
    display: inline-flex !important; align-items: center !important; gap: 6px !important;
    padding: 9px 18px !important; border-radius: 8px !important;
    font-size: 13px !important; font-weight: 600 !important;
    cursor: pointer !important; white-space: nowrap !important;
    transition: filter .15s, transform .1s !important;
    line-height: 1 !important; text-decoration: none !important;
}
.odk-pt-btn:hover { filter: brightness(1.15) !important; transform: translateY(-1px) !important; }
.odk-pt-btn:active { transform: translateY(0) !important; }
.odk-pt-btn-primary {
    background: #f59e0b !important; color: #000 !important;
    border: none !important; box-shadow: 0 2px 10px rgba(245,158,11,.35) !important;
}
.odk-pt-btn-secondary {
    background: #1e293b !important; color: #f1f5f9 !important;
    border: 1px solid #334155 !important;
}
.odk-pt-btn-ghost {
    background: transparent !important; color: #64748b !important;
    border: 1px solid #1f2d40 !important;
}
.odk-pt-btn-ghost:hover { color: #f1f5f9 !important; border-color: #334155 !important; }

/* ── Share Card Popup — removed 2026-05-09. The "Card Popup — Full Info" block
   below (~line 482) defines the same .odk-cp-* selectors with later cascade
   priority, so the rules here were dead in cascade. Verified .odk-cp-attrs/attr*
   classes are not emitted by JS or PHP either. */

/* ── Share Card Grid ─────────────────────────────────────────────────────── */
.odk-share-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
    gap: 12px;
}
.odk-share-card {
    position: relative; border-radius: 10px; overflow: hidden;
    background: #0f172a; border: 1px solid #1f2d40;
    cursor: pointer; transition: transform .2s, box-shadow .2s, border-color .2s;
}
.odk-share-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: 0 12px 32px rgba(0,0,0,.6);
    border-color: #334155;
}
.odk-share-card img { width: 100%; aspect-ratio: 5/7; object-fit: cover; display: block; }
.odk-share-card-no-img {
    width: 100%; aspect-ratio: 5/7; background: #1e293b;
    display: flex; align-items: center; justify-content: center;
    font-size: 11px; color: #475569; text-align: center; padding: 8px; box-sizing: border-box;
}
.odk-share-card-footer {
    padding: 6px 8px; background: #0a1120;
    display: flex; align-items: center; gap: 5px;
}
.odk-share-card-name {
    font-size: 10px; color: #94a3b8;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1;
}
.odk-share-card-qty {
    font-size: 10px; font-weight: 800; color: #f59e0b;
    font-family: monospace; flex-shrink: 0;
}
.odk-share-card-badge {
    position: absolute; top: 6px; right: 6px;
    background: rgba(0,0,0,.75); backdrop-filter: blur(4px);
    color: #f59e0b; font-size: 11px; font-weight: 800;
    font-family: monospace; padding: 2px 7px; border-radius: 6px;
    border: 1px solid rgba(245,158,11,.3);
}

/* ── Card Popup — Full Info ────────────────────────────────────────────── */
.odk-cp-wrap { background: #111827; border: 1px solid #1f2d40; border-radius: 16px; width: 100%; max-width: 680px; padding: 24px; position: relative; max-height: 90vh; overflow-y: auto; }
.odk-cp-close { position: absolute; top: 14px; right: 16px; background: none; border: none; color: #64748b; font-size: 18px; cursor: pointer; padding: 4px 8px; border-radius: 6px; transition: color .15s, background .15s; }
.odk-cp-close:hover { color: #f1f5f9; background: #1e293b; }
.odk-cp-inner { display: flex; gap: 20px; align-items: flex-start; }
.odk-cp-img-wrap { flex-shrink: 0; }
.odk-cp-img-wrap img { width: 210px; aspect-ratio: 5/7; object-fit: cover; border-radius: 10px; box-shadow: 0 8px 28px rgba(0,0,0,.6); display: block; }
.odk-cp-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 10px; }
.odk-cp-id { font-size: 11px; color: #f59e0b; font-family: monospace; font-weight: 700; }
.odk-cp-name { font-size: 18px; font-weight: 800; color: #f1f5f9; line-height: 1.3; }
.odk-cp-badges { display: flex; flex-wrap: wrap; gap: 6px; }
.odk-cp-badge { font-size: 11px; font-weight: 600; padding: 3px 10px; border-radius: 20px; border: 1px solid; }
.odk-cp-badge-type { background: rgba(59,130,246,.15); color: #3b82f6; border-color: rgba(59,130,246,.3); }
.odk-cp-affiliation { font-size: 12px; color: #94a3b8; background: #0a1120; border-radius: 8px; padding: 8px 10px; }
.odk-cp-ability { font-size: 12px; color: #cbd5e1; line-height: 1.6; background: rgba(245,158,11,.05); border-left: 2px solid rgba(245,158,11,.4); border-radius: 0 6px 6px 0; padding: 8px 12px; }
.odk-cp-trigger { font-size: 12px; color: #94a3b8; line-height: 1.5; }
.odk-cp-trigger-label { background: rgba(168,85,247,.2); color: #a855f7; font-size: 10px; font-weight: 700; padding: 1px 6px; border-radius: 4px; margin-right: 4px; }
.odk-cp-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.odk-cp-stat { background: #0a1120; border-radius: 8px; padding: 8px 12px; }
.odk-cp-stat-label { font-size: 10px; color: #64748b; margin-bottom: 3px; }
.odk-cp-stat-val { font-size: 16px; font-weight: 800; color: #f1f5f9; }
.odk-cp-series { font-size: 11px; color: #475569; padding-top: 6px; border-top: 1px solid #1f2d40; }
.odk-cp-series-label { color: #334155; margin-right: 6px; }
@media (max-width: 480px) { .odk-cp-inner { flex-direction: column; align-items: center; } .odk-cp-img-wrap img { width: 140px; } }

/* ── Popup additions ─────────────────────────────────────────────────────── */
.odk-cp-badge-circle { border-radius: 50% !important; width: 26px; height: 26px; display: inline-flex !important; align-items: center; justify-content: center; padding: 0 !important; font-size: 11px !important; }
.odk-cp-ability-wrap { display: flex; flex-direction: column; gap: 4px; }
.odk-cp-ability-label { font-size: 10px; color: #64748b; text-transform: uppercase; letter-spacing: .05em; }

/* ── Share Author Card ───────────────────────────────────────────────────── */
.odk-share-author {
    display: flex; align-items: center; gap: 14px;
    background: linear-gradient(135deg, #0f172a 0%, #1a2540 100%);
    border: 1px solid #1f2d40; border-radius: 14px;
    padding: 16px 20px; margin-bottom: 20px;
}
.odk-share-author-avatar {
    width: 56px; height: 56px; border-radius: 50%;
    object-fit: cover; flex-shrink: 0;
    border: 2px solid rgba(245,158,11,.4);
    box-shadow: 0 4px 16px rgba(0,0,0,.4);
}
.odk-share-author-info { display: flex; flex-direction: column; gap: 3px; }
.odk-share-author-label { font-size: 10px; color: #475569; text-transform: uppercase; letter-spacing: .06em; }
.odk-share-author-name { font-size: 16px; font-weight: 700; color: #f1f5f9; }

/* ── Login Gate ───────────────────────────────────────────────────────────── */
.odk-login-gate {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    min-height: 320px; gap: 16px; text-align: center;
    background: linear-gradient(135deg, #0a1120 0%, #111827 100%);
    border: 1px solid #1f2d40; border-radius: 20px; padding: 48px 24px;
    margin: 20px 0;
}
.odk-login-icon { font-size: 48px; line-height: 1; }
.odk-login-title { font-size: 22px; font-weight: 800; color: #f1f5f9; }
.odk-login-desc { font-size: 14px; color: #64748b; max-width: 320px; line-height: 1.6; }
.odk-login-btn {
    display: inline-flex; align-items: center; gap: 8px;
    background: #f59e0b; color: #000; font-weight: 700; font-size: 14px;
    padding: 12px 28px; border-radius: 10px; text-decoration: none;
    margin-top: 8px; transition: background .15s, transform .1s;
    box-shadow: 0 4px 16px rgba(245,158,11,.35);
}
.odk-login-btn:hover { background: #f6a821; transform: translateY(-1px); color: #000; }

/* ═══════════════════════════════════════════════════════════
   PLAYTEST — Full Playmat
   (modal rule lives further down in the Playmat section)
   ═══════════════════════════════════════════════════════════ */

/* ── Top bar ── */
#odk-pt-topbar {
    display: flex; align-items: center; justify-content: space-between;
    padding: 6px 12px; gap: 8px; flex-shrink: 0;
    background: #1a3a1a; border-bottom: 1px solid rgba(255,255,255,.1);
    transition: background .4s;
}
#odk-pt-phase-wrap {
    display: flex; align-items: center; gap: 4px; flex-wrap: wrap;
}
.odk-pt-phase-btn {
    font-size: 11px; padding: 3px 8px; border-radius: 20px; cursor: pointer;
    color: #94a3b8; border: 1px solid #334155; background: transparent;
    transition: all .2s; white-space: nowrap;
}
.odk-pt-phase-btn.active {
    background: #f59e0b; color: #000; border-color: #f59e0b; font-weight: 700;
    box-shadow: 0 0 12px rgba(245,158,11,.5);
}
.odk-pt-phase-arrow { color: #334155; font-size: 11px; }
#odk-pt-topbar-right { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }
#odk-pt-turn-badge {
    background: #1e3a5f; color: #7dd3fc; font-size: 11px; font-weight: 700;
    padding: 3px 10px; border-radius: 20px; white-space: nowrap;
}
#odk-pt-next-phase { font-size: 11px; padding: 4px 12px; }
.odk-pt-close {
    background: transparent; border: 1px solid #334155; color: #94a3b8;
    border-radius: 6px; padding: 4px 10px; cursor: pointer; font-size: 13px;
}
.odk-pt-close:hover { background: #ef4444; color: #fff; border-color: #ef4444; }

/* ── Playmat ── */
#odk-pt-mat {
    flex: 1; overflow: hidden;
    background:
        radial-gradient(ellipse at center, #1a4a1a 0%, #0f2d0f 60%, #0a1a0a 100%);
    background-image:
        radial-gradient(ellipse at center, #1a4a1a 0%, #0f2d0f 60%, #0a1a0a 100%),
        url("data:image/svg+xml,%3Csvg width='4' height='4' viewBox='0 0 4 4' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='0' y='0' width='2' height='2' fill='rgba(255,255,255,0.015)'/%3E%3C/svg%3E");
    display: flex; flex-direction: column; gap: 6px; padding: 8px;
    box-sizing: border-box;
    border: 2px solid rgba(255,255,255,.06);
    box-shadow: inset 0 0 60px rgba(0,0,0,.5);
}

/* ── Character Area Row ── */
#odk-pt-char-row {
    background: rgba(255,255,255,.04);
    border: 1px dashed rgba(255,255,255,.15);
    border-radius: 10px; padding: 6px 8px;
    display: flex; flex-direction: column; gap: 4px;
}
#odk-pt-char-row .odk-pt-zone-label {
    font-size: 10px; font-weight: 700; color: #94a3b8;
    text-align: center; text-transform: uppercase; letter-spacing: .08em;
    line-height: 1.3;
}
#odk-pt-char-slots {
    display: flex; gap: 6px; justify-content: center;
}
.odk-pt-char-slot {
    width: calc(20% - 5px); max-width: 90px;
    aspect-ratio: 5/7;
    background: rgba(255,255,255,.05);
    border: 1px dashed rgba(255,255,255,.2);
    border-radius: 6px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: all .2s; position: relative; overflow: hidden;
}
.odk-pt-char-slot:hover { background: rgba(255,255,255,.1); border-color: #f59e0b; }
.odk-pt-char-slot.has-card { border-color: transparent; }

/* ── Main Row ── */
#odk-pt-main-row {
    display: flex; gap: 6px; align-items: stretch; flex: 1;
}
.odk-pt-zone {
    background: rgba(255,255,255,.04);
    border: 1px dashed rgba(255,255,255,.15);
    border-radius: 8px; padding: 4px;
    display: flex; flex-direction: column; align-items: center; gap: 4px;
    position: relative;
}
.odk-pt-zone-label {
    font-size: 9px; font-weight: 700; color: #64748b;
    text-align: center; text-transform: uppercase; letter-spacing: .06em;
    line-height: 1.3; white-space: nowrap;
}
#odk-pt-life-zone { min-width: 60px; }
#odk-pt-leader-zone, #odk-pt-stage-zone { min-width: 72px; cursor: pointer; }
#odk-pt-deck-zone { min-width: 72px; }
#odk-pt-trash-zone { min-width: 68px; }

.odk-pt-card-slot, .odk-pt-card-back, .odk-pt-don-back {
    aspect-ratio: 5/7; width: 64px; border-radius: 6px;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; overflow: hidden; position: relative;
}
.odk-pt-card-slot {
    background: rgba(255,255,255,.05); border: 1px dashed rgba(255,255,255,.2);
}
/* Card back — navy blue like official OPCG */
.odk-pt-card-back {
    background:
        radial-gradient(circle at 50% 50%, rgba(255,255,255,.07) 0%, transparent 65%),
        linear-gradient(160deg, #0d2a6e 0%, #061540 50%, #0a1d50 100%);
    border: 2px solid #1e3a8a;
    box-shadow: 0 2px 8px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.08);
    position: relative; overflow: hidden;
}
.odk-pt-card-back::after {
    content: '';
    position: absolute; inset: 4px;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 4px;
}
.odk-pt-card-back.empty { opacity: .3; }
.odk-pt-deck-logo {
    font-size: 26px; color: rgba(255,255,255,.5);
    text-shadow: 0 0 12px rgba(100,149,237,.8);
    position: relative; z-index: 1;
}

/* Life card — full rule below at ~line 695. Dead block removed 2026-05-09. */

/* Don!! card back — teal/green like official */
.odk-pt-don-back {
    background:
        radial-gradient(circle at 50% 40%, rgba(0,200,150,.15) 0%, transparent 60%),
        linear-gradient(160deg, #064e3b 0%, #022c22 50%, #064e3b 100%);
    border: 2px solid #059669; color: #6ee7b7;
    font-weight: 900; font-size: 10px; letter-spacing: .05em;
    text-shadow: 0 0 8px rgba(110,231,183,.6);
    box-shadow: 0 2px 8px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.06);
}

#odk-pt-life-stack { display: flex; flex-direction: column; gap: 2px; align-items: center; }
.odk-pt-life-card {
    width: 40px; height: 10px; background: linear-gradient(90deg, #1a2a4a, #0f1a2f);
    border: 1px solid #1e3a5f; border-radius: 2px;
}
.odk-pt-mini-btn {
    font-size: 10px; padding: 2px 8px; border-radius: 4px;
    background: #1e3a5f; color: #7dd3fc; border: none; cursor: pointer;
}
.odk-pt-mini-btn:hover { background: #2563eb; }

/* ── Cost Row ── */
#odk-pt-cost-row {
    display: flex; gap: 6px; align-items: stretch;
}
#odk-pt-dondeck-zone { min-width: 72px; flex-shrink: 0; }
#odk-pt-cost-zone {
    flex: 1; background: rgba(255,255,255,.04);
    border: 1px dashed rgba(255,255,255,.15);
    border-radius: 8px; padding: 4px 6px;
    display: flex; flex-direction: column; gap: 4px;
}
#odk-pt-cost-cards {
    display: flex; flex-wrap: wrap; gap: 4px; align-items: center;
    min-height: 36px;
}
.odk-pt-don-card { cursor: pointer; transition: all .2s; }
.odk-pt-don-card:hover { box-shadow: 0 0 8px rgba(139,92,246,.6); }

/* ── Cards ── */
.odk-pt-card {
    position: relative; display: block;
    border-radius: 6px; overflow: hidden;
    cursor: pointer; transition: transform .15s, box-shadow .15s;
    box-shadow: 0 2px 6px rgba(0,0,0,.5);
}
.odk-pt-card img { width: 100%; display: block; }
.odk-pt-card:hover { transform: scale(1.05); box-shadow: 0 4px 16px rgba(0,0,0,.8); }
.odk-pt-card.rested { transform: rotate(90deg); margin: 12px 6px; }
.odk-pt-card.rested:hover { transform: rotate(90deg) scale(1.05); }
.odk-pt-card.new-card {
    box-shadow: 0 0 12px rgba(74,222,128,.6);
    outline: 2px dashed rgba(74,222,128,.8);
    outline-offset: -2px;
}
/* Summoning sickness indicator — Zzz badge top-left of new char */
.odk-pt-card.new-card::before {
    content: '💤';
    position: absolute;
    top: 2px; left: 2px;
    background: rgba(0,0,0,.7);
    color: #4ade80;
    font-size: 10px;
    padding: 1px 4px;
    border-radius: 3px;
    z-index: 4;
    pointer-events: none;
}
.odk-pt-card-noimg {
    width: 64px; aspect-ratio: 5/7; background: #1e293b;
    display: flex; align-items: center; justify-content: center;
    font-size: 9px; color: #64748b; padding: 4px; text-align: center;
    line-height: 1.3;
}
.odk-pt-power {
    position: absolute; bottom: 2px; left: 2px;
    background: rgba(0,0,0,.8); color: #facc15;
    font-size: 9px; font-weight: 700; padding: 1px 4px; border-radius: 3px;
}
.odk-pt-don-badge {
    position: absolute; top: 2px; right: 2px;
    background: #4c1d95; color: #c4b5fd;
    font-size: 8px; font-weight: 700; padding: 1px 4px; border-radius: 3px;
}
.odk-pt-count-badge {
    background: #0f172a; color: #f1f5f9; font-size: 11px; font-weight: 700;
    padding: 1px 8px; border-radius: 10px; border: 1px solid #334155;
}
.odk-pt-slot-hint { font-size: 9px; color: #334155; }

/* ── Hand Area ── */
#odk-pt-hand-area {
    background: #050d05; border-top: 2px solid rgba(255,255,255,.08);
    padding: 6px 8px; flex-shrink: 0; position: relative;
}
#odk-pt-hand-label {
    font-size: 10px; font-weight: 700; color: #4b5563;
    text-transform: uppercase; letter-spacing: .08em; margin-bottom: 4px;
}
#odk-pt-hand {
    display: flex; gap: 4px; overflow-x: auto; padding-bottom: 4px;
    scrollbar-width: thin; scrollbar-color: #334155 transparent;
}
.odk-pt-hand-card {
    flex-shrink: 0; width: 60px; position: relative;
    border-radius: 6px; overflow: hidden; cursor: pointer;
    border: 2px solid transparent; transition: all .15s;
    box-shadow: 0 2px 8px rgba(0,0,0,.5);
}
.odk-pt-hand-card img { width: 100%; display: block; }
.odk-pt-hand-card:hover { border-color: #f59e0b; transform: translateY(-6px); }
.odk-pt-hand-card.selected {
    border-color: #f59e0b; transform: translateY(-10px);
    box-shadow: 0 8px 20px rgba(245,158,11,.4);
}
.odk-pt-card-type-badge {
    position: absolute; bottom: 0; left: 0; right: 0;
    font-size: 8px; font-weight: 700; text-align: center;
    padding: 2px; text-transform: uppercase; letter-spacing: .04em;
}
.odk-pt-type-character { background: rgba(16,185,129,.85); color: #fff; }
.odk-pt-type-event      { background: rgba(234,179,8,.85);  color: #000; }
.odk-pt-type-stage      { background: rgba(99,102,241,.85); color: #fff; }
.odk-pt-type-leader     { background: rgba(239,68,68,.85);  color: #fff; }
.odk-pt-hand-empty { font-size: 12px; color: #1f2937; padding: 8px; }

/* ── Card action panel ── */
#odk-pt-card-actions, #odk-pt-field-actions {
    display: flex; gap: 4px; flex-wrap: wrap;
    padding: 4px; background: #0f172a; border-radius: 8px;
    border: 1px solid #334155; z-index: 100;
}
#odk-pt-card-actions {
    position: absolute; bottom: 100%; left: 0; margin-bottom: 4px;
}
#odk-pt-field-actions { position: absolute; top: 0; left: 0; }
.odk-pt-action-btn {
    font-size: 10px; padding: 4px 8px; border-radius: 4px;
    background: #1e293b; color: #e2e8f0; border: 1px solid #334155;
    cursor: pointer; white-space: nowrap; transition: all .15s;
}
.odk-pt-action-btn:hover { background: #f59e0b; color: #000; border-color: #f59e0b; }

/* ── Toast ── */
#odk-pt-toast {
    position: fixed; bottom: 80px; left: 50%; transform: translateX(-50%) translateY(20px);
    background: #0f172a; color: #f1f5f9; font-size: 13px; font-weight: 600;
    padding: 8px 20px; border-radius: 20px; border: 1px solid #334155;
    opacity: 0; transition: all .3s; pointer-events: none; white-space: nowrap;
    z-index: 1000000;
}
#odk-pt-toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ───────────────────────────────────────────────────────────────────────────
   Playmat — official OPCG playsheet background + absolute-positioned zones
   Image source: /wp-content/uploads/2026/05/playsheet-1536x1108.jpg (1.386:1)
   Modal: fixed-width popup, no mobile responsive needed (per user spec).
   Zone positions are % of #odk-pt-board to scale with the image.
   ─────────────────────────────────────────────────────────────────────────── */

/* Modal overlay — center the mat. Toggled via .show class from JS. */
#odk-playtest-modal {
    position: fixed; inset: 0; z-index: 999999;
    background: rgba(0,0,0,.85); backdrop-filter: blur(8px);
    display: none; flex-direction: row;
    align-items: flex-start; justify-content: center;
    padding: 20px; box-sizing: border-box; overflow: auto;
    font-family: 'Noto Sans Thai', sans-serif;
}
#odk-playtest-modal.show { display: flex; }

/* Mat container: topbar + board + hand stacked */
#odk-pt-mat {
    width: 100%;
    max-width: 1100px;
    background: #0a1a0a;
    border: 2px solid rgba(255, 255, 255, .08);
    border-radius: 12px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* The board itself — playmat image as background */
#odk-pt-board {
    position: relative; width: 100%;
    aspect-ratio: 1024 / 739;
    background-image: url('/wp-content/uploads/2026/05/playsheet-1536x1108.jpg');
    background-size: 100% 100%;
    background-repeat: no-repeat;
}

/* All direct children of board are absolute-positioned */
#odk-pt-board > * {
    position: absolute;
    box-sizing: border-box;
}

/* Make zones transparent — image already labels & frames everything */
#odk-pt-board > .odk-pt-zone,
#odk-pt-board > #odk-pt-cost-zone {
    background: transparent !important;
    border: none !important;
    padding: 0;
    display: flex; align-items: center; justify-content: center;
}
#odk-pt-board #odk-pt-char-row {
    background: transparent !important;
    border: none !important;
    padding: 0;
}

/* ── Zone positions (% of board) ── */

/* LIFE — far left, vertical */
#odk-pt-board > #odk-pt-life-zone {
    left: 0%; top: 6.5%; width: 12%; height: 52%;
    flex-direction: column; gap: 0;
}
#odk-pt-board #odk-pt-life-stack {
    width: 100%; height: 100%;
    display: flex; flex-direction: column; gap: 0; align-items: center;
    justify-content: center;
}

/* CHARACTER AREA — top, big, 5 horizontal slots */
#odk-pt-board > #odk-pt-char-row {
    left: 18%; top: 3%; width: 76%; height: 30%;
}
#odk-pt-board #odk-pt-char-slots {
    width: 100%; height: 100%;
    display: flex; gap: 1.5%; align-items: center; justify-content: center;
}
#odk-pt-board .odk-pt-char-slot {
    height: 95%; max-width: 18%;
    aspect-ratio: 5/7;
}

/* LEADER, STAGE, DECK — middle row right of phase column */
#odk-pt-board > #odk-pt-leader-zone {
    left: 49.8%; top: 36%; width: 14%; height: 28%;
}
#odk-pt-board > #odk-pt-stage-zone {
    left: 66.5%; top: 36%; width: 14%; height: 28%;
}
#odk-pt-board > #odk-pt-deck-zone {
    left: 83%; top: 36%; width: 14%; height: 28%;
    flex-direction: column; gap: 4px;
}
#odk-pt-board #odk-pt-leader-card,
#odk-pt-board #odk-pt-stage-card,
#odk-pt-board #odk-pt-deck-pile {
    width: 100%; height: 100%;
}

/* Cards rendered by JS inside slots — fill the slot fully */
#odk-pt-board .odk-pt-card-slot > .odk-pt-card,
#odk-pt-board #odk-pt-leader-card > .odk-pt-card,
#odk-pt-board .odk-pt-char-slot > .odk-pt-card {
    width: 100%; height: 100%;
}
#odk-pt-board .odk-pt-card img {
    width: 100%; height: 100%; object-fit: contain;
}
#odk-pt-board .odk-pt-card-noimg {
    width: 100%; height: 100%; aspect-ratio: auto;
    font-size: 11px;
}

/* DON!! DECK — bottom-left */
#odk-pt-board > #odk-pt-dondeck-zone {
    left: -2.5%; top: 65%; width: 25%; height: 34%;
    flex-direction: column; gap: 4px;
}
#odk-pt-board #odk-pt-dondeck-zone .odk-pt-don-back {
    width: 55%; height: 80%;
    font-size: 14px;
}

/* COST AREA — bottom-center */
#odk-pt-board > #odk-pt-cost-zone {
    left: 29%; top: 66%; width: 56%; height: 28%;
    align-items: stretch !important;
}
#odk-pt-board #odk-pt-cost-cards {
    width: 86%; height: 100%;
    padding: 2.5%; display: flex; flex-wrap: wrap; gap: 2px;
    align-items: center; justify-content: flex-start;
}

/* TRASH — bottom-right */
#odk-pt-board > #odk-pt-trash-zone {
    left: 81%; top: 66%; width: 18%; height: 32%;
    flex-direction: column; gap: 4px;
}
#odk-pt-board #odk-pt-trash-pile {
    width: 80%; height: 88%;
}

/* Count badges — overlay on cards */
#odk-pt-board .odk-pt-count-badge {
    position: absolute;
    top: 4px; right: 4px;
    z-index: 5;
    font-size: 11px;
}
/* dondeck has a smaller centered card-back (55% width) — pull badge inward
   so it sits on the don-back's top-right corner, not the zone's. */
#odk-pt-board #odk-pt-dondeck-zone .odk-pt-count-badge {
    top: 0%;
    right: 16.5%;
}

/* Draw button — small pill below the deck pile (manual jaw for ability-driven draws) */
#odk-pt-board #odk-pt-draw {
    position: absolute; bottom: -22px; left: 50%; transform: translateX(-50%);
    font-size: 9px; padding: 1px 6px;
    white-space: nowrap;
}

/* ── Card-back images (user-provided) ── */
.odk-pt-card-back {
    background: url('/wp-content/uploads/2026/05/b-card.jpg.jpg') center/cover no-repeat !important;
    border: 1px solid rgba(0,0,0,.4) !important;
}
.odk-pt-card-back::after { display: none !important; }   /* drop the fake inner border */
.odk-pt-card-back .odk-pt-deck-logo { display: none; }   /* drop the centered emoji over real image */

/* Life stack —
   Cards 1..N-1 are flat strips (back-only sliver) so they look like
   stacked life under the top card. The bottom-most card (`.last`,
   tagged by deck script) is the about-to-be-drawn card — render full
   card aspect 5/7 to match the OPCG playmat visual. */
#odk-pt-board #odk-pt-life-stack > .odk-pt-life-card:not(.last) {
    width: 100% !important;
    height: 42px !important;
    aspect-ratio: auto !important;
    box-sizing: border-box !important;
    background: url(/wp-content/uploads/2026/05/b-card.jpg.jpg) top center / 100% auto no-repeat !important;
    border: 1px solid rgba(0, 0, 0, .4) !important;
    border-radius: 4px 4px 0 0 !important;
    transform: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
#odk-pt-board #odk-pt-life-stack > .odk-pt-life-card.last {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: 5 / 7 !important;
    flex: 0 0 auto !important;
    box-sizing: border-box !important;
    background: url(/wp-content/uploads/2026/05/b-card.jpg.jpg) center / cover no-repeat !important;
    border: 1px solid rgba(0, 0, 0, .4) !important;
    border-radius: 6px !important;
    transform: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
#odk-pt-board #odk-pt-life-stack > *::after,
#odk-pt-board #odk-pt-life-stack > *::before { display: none !important; }

.odk-pt-don-back {
    background: url(/wp-content/uploads/2026/05/doncard-b.jpg) center / cover no-repeat !important;
    border: 1px solid rgba(0, 0, 0, .4) !important;
    color: transparent !important;        /* hide DON!! text since image has it */
    text-shadow: none !important;
}
.odk-pt-don-card {
    width: 80px !important;
    height: 109px !important;
    background: url(/wp-content/uploads/2026/05/doncard.webp) center / cover no-repeat !important;
    border: 1px solid rgba(0, 0, 0, .4) !important;
    border-radius: 4px !important;
    color: transparent !important;
    text-shadow: none !important;
}

/* ── Opponent life badge in topbar ── */
.odk-pt-opp-life-wrap {
    background: #4a1a1a; color: #fecaca; font-size: 11px; font-weight: 700;
    padding: 3px 10px; border-radius: 20px;
    border: 1px solid #7f1d1d; white-space: nowrap;
}
.odk-pt-opp-life-wrap #odk-pt-opp-life { color: #fef2f2; }

/* ── Game Over / Win overlay ── */
#odk-pt-gameover, #odk-pt-win {
    position: absolute; inset: 0;
    background: rgba(0, 0, 0, .82); backdrop-filter: blur(6px);
    display: none;
    align-items: center; justify-content: center;
    z-index: 1000000;
    pointer-events: auto;
}
#odk-pt-gameover.show, #odk-pt-win.show { display: flex; }
.odk-pt-win-card {
    border-color: #22c55e !important;
    box-shadow: 0 0 64px rgba(34, 197, 94, .4) !important;
}
.odk-pt-win-card .odk-pt-go-title {
    color: #bbf7d0 !important;
    text-shadow: 0 0 20px rgba(34, 197, 94, .6) !important;
}
.odk-pt-go-card {
    background: linear-gradient(160deg, #1f1115 0%, #150a0e 100%);
    border: 2px solid #ef4444;
    border-radius: 16px;
    padding: 32px 40px;
    text-align: center;
    box-shadow: 0 0 64px rgba(239, 68, 68, .4);
    max-width: 380px;
}
.odk-pt-go-icon { font-size: 48px; margin-bottom: 8px; }
.odk-pt-go-title {
    font-size: 28px; font-weight: 900; color: #fecaca;
    letter-spacing: .12em; margin-bottom: 6px;
    text-shadow: 0 0 20px rgba(239, 68, 68, .6);
}
.odk-pt-go-sub { font-size: 13px; color: #94a3b8; margin-bottom: 22px; }
.odk-pt-go-actions { display: flex; gap: 8px; justify-content: center; }
.odk-pt-go-actions button { font-size: 13px; padding: 8px 16px; }

/* ── Trigger prompt ── */
#odk-pt-trigger-prompt {
    position: fixed; inset: 0;
    background: rgba(0, 0, 0, .82); backdrop-filter: blur(6px);
    display: none;
    align-items: center; justify-content: center;
    z-index: 1000003;
}
#odk-pt-trigger-prompt.show { display: flex; }
.odk-pt-tg-card {
    background: linear-gradient(160deg, #2a1f0e 0%, #1f1607 100%);
    border: 2px solid #facc15;
    border-radius: 16px;
    padding: 22px 26px;
    max-width: 520px; width: 92%;
    box-shadow: 0 0 60px rgba(250, 204, 21, .35);
}
.odk-pt-tg-header {
    font-size: 18px; font-weight: 800; color: #fef3c7;
    text-align: center; margin-bottom: 14px;
    letter-spacing: .04em;
    text-shadow: 0 0 16px rgba(250, 204, 21, .5);
}
.odk-pt-tg-body { display: flex; gap: 16px; align-items: flex-start; }
.odk-pt-tg-img {
    width: 140px; aspect-ratio: 5/7; object-fit: contain;
    border-radius: 6px; background: #020617;
    flex-shrink: 0;
}
.odk-pt-tg-img[src=""] { display: none; }
.odk-pt-tg-info { flex: 1; min-width: 0; }
.odk-pt-tg-name {
    font-size: 16px; font-weight: 800; color: #f8fafc;
    margin-bottom: 6px; line-height: 1.3;
}
.odk-pt-tg-meta {
    font-size: 11px; color: #fbbf24;
    margin-bottom: 10px; display: flex; flex-wrap: wrap; gap: 5px;
}
.odk-pt-tg-meta span {
    background: rgba(250, 204, 21, .15); border: 1px solid rgba(250, 204, 21, .3);
    padding: 2px 7px; border-radius: 10px;
}
.odk-pt-tg-text {
    font-size: 12px; line-height: 1.55; color: #fef3c7;
    background: rgba(0, 0, 0, .3); border-radius: 6px;
    padding: 8px 10px; max-height: 200px; overflow-y: auto;
}
.odk-pt-tg-actions {
    display: flex; gap: 8px; justify-content: center;
    margin-top: 16px;
}
.odk-pt-tg-actions button { font-size: 13px; padding: 9px 16px; }

/* ── Blocker prompt ── */
#odk-pt-blocker-prompt {
    position: fixed; inset: 0;
    background: rgba(0, 0, 0, .8); backdrop-filter: blur(6px);
    display: none;
    align-items: center; justify-content: center;
    z-index: 1000002;
}
#odk-pt-blocker-prompt.show { display: flex; }
.odk-pt-bp-card {
    background: linear-gradient(160deg, #0f1f2a 0%, #0a1620 100%);
    border: 2px solid #38bdf8;
    border-radius: 16px;
    padding: 22px 28px;
    max-width: 440px; width: 90%;
    box-shadow: 0 0 48px rgba(56, 189, 248, .35);
}
.odk-pt-bp-title {
    font-size: 18px; font-weight: 800; color: #e0f2fe;
    text-align: center; margin-bottom: 6px;
}
.odk-pt-bp-sub {
    font-size: 12px; color: #7dd3fc;
    text-align: center; margin-bottom: 18px;
}
.odk-pt-bp-stats {
    background: #0a1622; border: 1px solid #1e3a5f; border-radius: 8px;
    padding: 10px 12px; margin-bottom: 14px;
    font-size: 12px; color: #cbd5e1; line-height: 1.6;
}
.odk-pt-bp-stats b { color: #f1f5f9; }
.odk-pt-bp-stats .deficit { color: #fbbf24; }
.odk-pt-bp-stats .ok { color: #4ade80; }
.odk-pt-bp-options { display: flex; flex-direction: column; gap: 8px; }
.odk-pt-bp-options button {
    font-size: 13px; padding: 10px 14px; text-align: left;
    background: #1e3a5f; color: #f1f5f9; border: 1px solid #38bdf8;
    border-radius: 8px; cursor: pointer; transition: background .15s;
}
.odk-pt-bp-options button:hover { background: #2563eb; }
.odk-pt-bp-options button.no-block {
    background: transparent; border-color: #475569; color: #94a3b8;
}
.odk-pt-bp-options button.no-block:hover { background: #1e293b; }

/* ── Game log panel ── */
#odk-pt-log {
    position: fixed;
    top: 80px; left: 24px;
    width: 260px;
    max-height: calc(100vh - 120px);
    background: #0f172a;
    border: 1px solid #1f2d40;
    border-radius: 12px;
    padding: 10px 12px;
    z-index: 1000001;
    color: #e2e8f0;
    display: none;
    flex-direction: column;
    gap: 6px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, .6);
    font-family: 'Noto Sans Thai', sans-serif;
    display: flex;        /* parent #odk-playtest-modal display:none auto-hides this */
}
.odk-pt-log-header {
    display: flex; justify-content: space-between; align-items: center;
    border-bottom: 1px solid #1f2d40;
    padding-bottom: 6px;
    font-size: 12px; font-weight: 700;
    color: #f1f5f9;
}
.odk-pt-log-header button { font-size: 10px; padding: 2px 8px; }
#odk-pt-log-list {
    list-style: none; padding: 0; margin: 0;
    overflow-y: auto;
    font-size: 11px; line-height: 1.45;
    flex: 1;
    scrollbar-width: thin; scrollbar-color: #334155 transparent;
}
#odk-pt-log-list li {
    padding: 4px 2px;
    border-bottom: 1px solid #1e293b;
    color: #cbd5e1;
    word-wrap: break-word;
}
#odk-pt-log-list li:first-child { color: #f8fafc; background: rgba(245, 158, 11, .06); }
.odk-pt-log-time { color: #64748b; font-family: monospace; margin-right: 4px; font-size: 10px; }

/* ── Hover card preview ── */
#odk-pt-card-preview {
    position: fixed;
    top: 80px;
    right: 24px;
    width: 280px;
    background: #0f172a;
    border: 1px solid #1f2d40;
    border-radius: 12px;
    padding: 12px;
    z-index: 1000001;
    pointer-events: none;
    display: none;
    flex-direction: column;
    gap: 8px;
    box-shadow: 0 8px 32px rgba(0, 0, 0, .6);
    color: #e2e8f0;
    font-family: 'Noto Sans Thai', sans-serif;
}
#odk-pt-card-preview.show { display: flex; }
#odk-pt-card-preview .odk-pt-cp-img {
    width: 100%; aspect-ratio: 5/7; object-fit: contain;
    border-radius: 6px; background: #020617;
}
#odk-pt-card-preview .odk-pt-cp-img[src=""] { display: none; }
#odk-pt-card-preview .odk-pt-cp-id {
    font-size: 11px; color: #64748b; font-family: monospace;
}
#odk-pt-card-preview .odk-pt-cp-name {
    font-size: 14px; font-weight: 700; color: #f1f5f9; line-height: 1.3;
}
#odk-pt-card-preview .odk-pt-cp-meta {
    font-size: 11px; color: #94a3b8;
    display: flex; flex-wrap: wrap; gap: 6px;
}
#odk-pt-card-preview .odk-pt-cp-meta span {
    background: #1e293b; padding: 2px 8px; border-radius: 10px;
}
#odk-pt-card-preview .odk-pt-cp-text {
    font-size: 12px; line-height: 1.5; color: #cbd5e1;
    max-height: 180px; overflow-y: auto;
    border-top: 1px solid #1f2d40; padding-top: 8px;
}
#odk-pt-card-preview .odk-pt-cp-text:empty { display: none; }

/* ── Rested cards smaller (rotated 90°) ──
   scale(0.7) is calibrated so the 7×5 rotated bounding box fits cleanly
   inside the 5×7 slot without being clipped by overflow:hidden. */
#odk-pt-board .odk-pt-card.rested,
#odk-pt-board .odk-pt-don-card.rested {
    transform: rotate(90deg) scale(0.7);
    margin: 0 !important;
}
.odk-pt-card.rested { transform: rotate(90deg) scale(0.7); margin: 6px 0; }
.odk-pt-don-card.rested {
    transform: rotate(90deg) scale(0.7);
    margin: 4px 0; opacity: .85;
}

/* ── Deck-share: Match Stats panel ────────────────────────────────────── */
.odk-share-mstats{background:linear-gradient(180deg,#0f172a 0%,#0b1220 100%);border:1px solid #1f2d40;border-radius:12px;padding:16px 18px;margin-bottom:20px}
.odk-share-mstats-head{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:800;color:#f1f5f9;margin-bottom:12px;letter-spacing:.02em}
.odk-share-mstats-disclaimer{font-size:10px;font-weight:500;color:#64748b;background:rgba(100,116,139,.15);padding:2px 8px;border-radius:8px;letter-spacing:.04em}
.odk-share-mstats-summary{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.odk-share-mstats-cell{flex:1;min-width:64px;background:rgba(0,0,0,.28);border:1px solid #1e293b;border-radius:8px;padding:10px 6px;text-align:center;display:flex;flex-direction:column;gap:3px;align-items:center}
.odk-share-mstats-cell b{font-size:22px;font-weight:900;line-height:1}
.odk-share-mstats-cell i{font-size:9px;font-style:normal;color:#94a3b8;letter-spacing:.08em;font-weight:700}
.odk-msc-w b{color:#4ade80}
.odk-msc-l b{color:#f87171}
.odk-msc-d b{color:#fbbf24}
.odk-msc-rate{background:linear-gradient(135deg,rgba(245,158,11,.18),rgba(245,158,11,.05));border-color:#78350f}
.odk-msc-rate b{color:#fbbf24;font-size:20px}
.odk-msc-total b{color:#cbd5e1}
.odk-share-mstats-recent-title{font-size:10px;color:#64748b;text-transform:uppercase;letter-spacing:.08em;margin:14px 0 8px;font-weight:700}
.odk-share-mstats-list{display:flex;flex-direction:column;gap:6px}
.odk-msr-row{display:flex;align-items:center;gap:10px;background:rgba(15,23,42,.7);border:1px solid #1e293b;border-radius:6px;padding:7px 10px;font-size:12px}
.odk-msr-result{flex-shrink:0;width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:11px;letter-spacing:0}
.odk-msr-w{background:#16a34a;color:#fff;box-shadow:0 0 0 1px rgba(34,197,94,.3)}
.odk-msr-l{background:#dc2626;color:#fff;box-shadow:0 0 0 1px rgba(248,113,113,.3)}
.odk-msr-d{background:#ca8a04;color:#fff;box-shadow:0 0 0 1px rgba(251,191,36,.3)}
.odk-msr-opp{flex:1;color:#e2e8f0;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.odk-msr-meta{font-size:10px;color:#64748b;flex-shrink:0;letter-spacing:.02em}
@media (max-width:520px){
  .odk-share-mstats-summary{gap:6px}
  .odk-share-mstats-cell{padding:8px 4px;min-width:56px}
  .odk-share-mstats-cell b{font-size:18px}
  .odk-msr-meta{display:none}
}
