/* SETUP */
.selected-ops{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.selected-op{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--bg3);border-radius:6px;font-size:13px}
.selected-op-info{display:flex;flex-direction:column;gap:2px}
.selected-op-meta{display:flex;gap:8px;font-size:11px;color:var(--text2);margin-top:2px;flex-wrap:wrap}
.btn-icon{background:transparent;border:none;color:var(--text2);cursor:pointer;padding:2px;display:flex;align-items:center}
.btn-icon:hover{color:var(--red)}
.divider{height:1px;background:var(--border);margin:1rem 0}

/* COMPOSITION STATUS */
.comp-status{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.comp-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:500}
.comp-tag.ok{background:rgba(63,185,80,0.1);color:var(--green);border:1px solid rgba(63,185,80,0.3)}
.comp-tag.err{background:rgba(233,69,96,0.1);color:var(--red);border:1px solid rgba(233,69,96,0.3)}

/* EQUIPMENT POOL SETUP */
.equip-row{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--bg3);border-radius:6px;margin-bottom:4px}
.equip-row-name{flex:1;font-size:13px}
.equip-row-desc{font-size:11px;color:var(--text2);max-width:160px;text-align:right}
.equip-counter{font-size:12px;font-weight:600;color:var(--yellow);min-width:16px;text-align:center}

/* EQUIPMENT SELECTION MODAL */
.equip-selection-cols{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-top:0.75rem}
.equip-sel-team-title{font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:0.05em}
.equip-sel-add-row{display:flex;gap:6px;margin-bottom:8px;align-items:center}
.equip-sel-select{flex:1;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:6px 8px;border-radius:6px;font-size:12px;min-width:0}
.equip-preview{font-size:11px;color:var(--text2);margin-bottom:8px;padding:6px 8px;background:var(--bg3);border-radius:6px;min-height:28px;line-height:1.4}
.equip-sel-tags{display:flex;flex-direction:column;gap:4px;min-height:64px;margin-bottom:8px}
.equip-sel-tag{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;font-size:12px;gap:6px}
.equip-sel-tag span{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.equip-sel-remove{background:transparent;border:none;color:var(--text2);cursor:pointer;font-size:16px;padding:0 2px;line-height:1;flex-shrink:0}
.equip-sel-remove:hover{color:var(--red)}
.equip-counter{font-size:11px;color:var(--text2);text-align:right;margin-top:2px}
.equip-counter.full{color:var(--green);font-weight:600}

/* STRATEGY PHASE MODAL */
.strategy-phase-cols{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:0.75rem}
.strategy-phase-team-title{font-size:12px;font-weight:600;color:var(--text2);margin-bottom:8px;text-transform:uppercase}
.ploy-item.ploy-active{border-color:var(--green);background:rgba(63,185,80,0.08)}

/* COMBAT MODAL */
.combat-modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:12px;width:960px;max-width:98vw;max-height:90vh;display:flex;flex-direction:column}
.combat-3col{display:grid;grid-template-columns:200px 1fr 200px;gap:0;flex:1;min-height:0;overflow:hidden}
.combat-center-col{padding:0 1.25rem 1.25rem;overflow-y:auto;min-width:0}
.combat-side-col{padding:0.75rem;overflow-y:auto;display:flex;flex-direction:column;gap:6px;border-top:1px solid var(--border)}
.combat-side-attacker{border-right:1px solid var(--border);border-left:3px solid var(--blue)}
.combat-side-defender{border-left:1px solid var(--border);border-right:3px solid var(--red)}
.combat-side-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--text2);margin-bottom:4px}
.combat-ploy-card{padding:8px 10px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:border-color 0.15s}
.combat-ploy-card:hover:not(.combat-ploy-used){border-color:rgba(88,166,255,0.5);background:rgba(88,166,255,0.06)}
.combat-side-defender .combat-ploy-card:hover:not(.combat-ploy-used){border-color:rgba(233,69,96,0.5);background:rgba(233,69,96,0.06)}
.combat-ploy-used{opacity:0.35;cursor:default}
.combat-ploy-header{display:flex;align-items:baseline;gap:6px;margin-bottom:4px}
.combat-ploy-cp{font-size:10px;font-weight:700;color:var(--blue);background:rgba(88,166,255,0.1);border:1px solid rgba(88,166,255,0.25);border-radius:4px;padding:1px 5px;flex-shrink:0}
.combat-side-defender .combat-ploy-cp{color:var(--red);background:rgba(233,69,96,0.1);border-color:rgba(233,69,96,0.25)}
.combat-ploy-name{font-size:12px;font-weight:600;line-height:1.3}
.combat-ploy-desc{font-size:10px;color:var(--text2);line-height:1.4}
.combat-cols{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border-radius:8px;overflow:hidden;margin-bottom:1rem}
.combat-col{padding:0.75rem 1rem;background:var(--bg3)}
.combat-col-attacker{border-left:3px solid var(--blue)}
.combat-col-defender{border-left:3px solid var(--red)}
.combat-col-title{font-size:10px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:4px}
.combat-op-name{font-size:13px;font-weight:600;margin-bottom:2px}
.combat-team-name{font-size:11px;color:var(--text2);margin-bottom:6px}
.combat-stats{display:flex;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text2)}
.combat-stats span{background:var(--bg2);padding:2px 6px;border-radius:4px}

/* COMBAT LOG (chat bubbles) */
.combat-log{display:flex;flex-direction:column;gap:6px;padding:0.5rem 0;min-height:60px}
.combat-bubble{max-width:78%;padding:8px 12px;border-radius:10px;animation:bubbleFadeIn 0.25s ease both}
.combat-bubble-attacker{align-self:flex-start}
.combat-bubble-defender{align-self:flex-end}
.bubble-team-attacker{background:rgba(88,166,255,0.12);border:1px solid rgba(88,166,255,0.25)}
.bubble-team-defender{background:rgba(233,69,96,0.1);border:1px solid rgba(233,69,96,0.25)}
.bubble-important.bubble-team-attacker{border-color:rgba(88,166,255,0.5);background:rgba(88,166,255,0.18)}
.bubble-important.bubble-team-defender{border-color:rgba(233,69,96,0.5);background:rgba(233,69,96,0.18)}
.bubble-source{font-size:10px;color:var(--text2);margin-bottom:3px;font-weight:500}
.bubble-effect{font-size:12px;line-height:1.4}
@keyframes bubbleFadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* FP BUTTONS */
.fp-buttons-row{display:flex;flex-wrap:wrap;gap:6px;padding:0.5rem 0;border-top:1px solid var(--border);margin-top:0.5rem}
.fp-btn{padding:4px 10px;font-size:11px;border-radius:6px;border:1px solid rgba(88,166,255,0.4);background:rgba(88,166,255,0.08);color:var(--blue);cursor:pointer}
.fp-btn:hover{background:rgba(88,166,255,0.18)}
.fp-btn-defender{border-color:rgba(233,69,96,0.4);background:rgba(233,69,96,0.08);color:var(--red)}
.fp-btn-defender:hover{background:rgba(233,69,96,0.18)}
.fp-btn-used{opacity:0.35;cursor:default}
.fp-btn-label{font-size:10px;color:var(--text2);align-self:center}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:200;align-items:center;justify-content:center}
.modal-box{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.5rem;width:480px;max-height:88vh;overflow-y:auto}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}
.modal-title{font-size:15px;font-weight:500}
.modal-section{margin-bottom:1rem}
.modal-section-label{font-size:12px;font-weight:600;margin-bottom:8px;color:var(--text2);text-transform:uppercase;letter-spacing:0.05em;display:flex;align-items:center;gap:6px}
.radio-option{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg3);border-radius:6px;cursor:pointer;margin-bottom:4px;border:1px solid var(--border)}
.radio-option:hover{border-color:rgba(233,69,96,0.4)}
.radio-option input[type=radio]{accent-color:var(--red);flex-shrink:0}
.radio-option-info{flex:1;font-size:13px}
.radio-option-stats{font-size:11px;color:var(--text2);white-space:nowrap}
.fixed-weapon{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--bg3);border-radius:6px;margin-bottom:4px;font-size:13px;color:var(--text2);border:1px solid var(--border)}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border)}
