/* === Porygon Labs — Pokeball Dark Theme === */

:root {
    --bg-primary: #1a1a1a;
    --bg-secondary: #222222;
    --bg-card: #2c2c2c;
    --bg-input: #141414;
    --border: #3a3a3a;
    --text-primary: #f0f0f0;
    --text-secondary: #a0a0a0;
    --text-muted: #666666;
    --accent: #4DB6AC;
    --accent-hover: #6ECAC2;
    --danger: #e74c3c;
    --success: #2ecc71;
    --warning: #f39c12;
    --type-normal: #a8a878;
    --type-fire: #f08030;
    --type-water: #6890f0;
    --type-electric: #f8d030;
    --type-grass: #78c850;
    --type-ice: #98d8d8;
    --type-fighting: #c03028;
    --type-poison: #a040a0;
    --type-ground: #e0c068;
    --type-flying: #a890f0;
    --type-psychic: #f85888;
    --type-bug: #a8b820;
    --type-rock: #b8a038;
    --type-ghost: #705898;
    --type-dragon: #7038f8;
    --type-dark: #705848;
    --type-steel: #b8b8d0;
    --type-fairy: #ee99ac;
    --dmg-safe: #2ecc71;
    --dmg-caution: #f1c40f;
    --dmg-danger: #e67e22;
    --dmg-lethal: #e74c3c;
    --status-field: #6A8EE6;
    --status-back: #7f8c8d;
    --status-dead: #e74c3c;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
    background: var(--bg-primary);
    color: var(--text-primary);
    height: 100vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

/* === Header === */
header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 16px;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.header-title {
    display: flex;
    align-items: center;
    gap: 8px;
}

header h1 {
    font-size: 1.2rem;
    color: var(--accent);
    font-weight: 600;
}

.version-badge {
    font-size: 0.7rem;
    color: var(--text-muted);
    background: var(--bg-primary);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 2px 6px;
    cursor: pointer;
    transition: all 0.15s;
}

.version-badge:hover {
    color: var(--accent);
    border-color: var(--accent);
}

.changelog-entries {
    max-height: 400px;
    overflow-y: auto;
}

.changelog-entry {
    margin-bottom: 16px;
}

.changelog-entry h4 {
    font-size: 0.95rem;
    color: var(--accent);
    margin-bottom: 6px;
}

.changelog-entry ul {
    padding-left: 20px;
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.changelog-entry li {
    margin-bottom: 4px;
}

.header-actions {
    display: flex;
    gap: 8px;
}

.header-actions button {
    padding: 4px 12px;
    font-size: 0.85rem;
    background: var(--bg-card);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
}

.header-actions button:hover {
    background: var(--border);
    color: var(--text-primary);
}

.btn-kofi {
    padding: 4px 12px;
    font-size: 0.85rem;
    background: var(--bg-card);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    text-decoration: none;
    transition: all 0.15s;
}

.btn-kofi:hover {
    background: var(--border);
    color: var(--text-primary);
}

/* === Main Layout === */
main {
    display: grid;
    grid-template-columns: minmax(280px, 1fr) auto minmax(350px, 1.4fr) auto minmax(280px, 1fr);
    grid-template-rows: 1fr;
    gap: 4px;
    padding: 8px;
    flex: 1;
    overflow: auto;
    min-height: 0;
}

.panel {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 12px;
    overflow-y: auto;
    min-height: 0;
}

#my-team-panel,
#opp-team-panel {
    overflow-y: auto;
    min-height: 0;
}

.panel h2 {
    font-size: 1rem;
    margin-bottom: 10px;
    color: var(--accent);
    border-bottom: 1px solid var(--border);
    padding-bottom: 6px;
}

/* === Team Header (both sides) === */
.team-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0;
}

.team-header h2 {
    margin-bottom: 0;
    border-bottom: none;
    padding-bottom: 0;
}

.team-header-actions {
    display: flex;
    gap: 6px;
}

/* === Input Mode Toggle === */
.team-input-toggle {
    display: flex;
    gap: 0;
    margin: 8px 0;
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
}

.input-mode-btn {
    flex: 1;
    padding: 5px 0;
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    background: var(--bg-primary);
    color: var(--text-muted);
    border: none;
    cursor: pointer;
    transition: all 0.15s;
}

.input-mode-btn:hover {
    color: var(--text-secondary);
}

.input-mode-btn.active {
    background: var(--accent);
    color: white;
}

.team-input-area.hidden {
    display: none;
}

/* === Paste Area === */
#paste-input, #opp-paste-input {
    width: 100%;
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 8px;
    font-family: 'Consolas', 'Courier New', monospace;
    font-size: 0.8rem;
    resize: vertical;
}

#paste-input:focus, #opp-paste-input:focus {
    outline: none;
    border-color: var(--accent);
}

#btn-parse, #btn-parse-opp {
    margin-top: 6px;
    margin-bottom: 12px;
    padding: 6px 16px;
    background: var(--accent);
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    font-size: 0.85rem;
}

#btn-parse:hover, #btn-parse-opp:hover {
    background: var(--accent-hover);
}

/* === Pokemon Cards === */
.pokemon-card {
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 10px;
    margin-bottom: 8px;
    transition: border-color 0.15s, opacity 0.15s;
    position: relative;
}

.pokemon-card:hover {
    border-color: var(--accent);
}

.pokemon-card.status-field {
    border-left: 3px solid var(--status-field);
}

.pokemon-card.status-back {
    border-left: 3px solid var(--status-back);
    opacity: 0.75;
}

.pokemon-card.status-dead {
    border-left: 3px solid var(--status-dead);
    opacity: 0.45;
}

.card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}

.card-name {
    font-weight: 600;
    font-size: 0.95rem;
}

.card-item {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.card-types {
    display: flex;
    gap: 4px;
    margin-bottom: 6px;
}

.type-badge {
    font-size: 0.75rem;
    padding: 2px 8px;
    border-radius: 3px;
    color: white;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.type-Normal { background: var(--type-normal); color: #333; }
.type-Fire { background: var(--type-fire); }
.type-Water { background: var(--type-water); }
.type-Electric { background: var(--type-electric); color: #333; }
.type-Grass { background: var(--type-grass); }
.type-Ice { background: var(--type-ice); color: #333; }
.type-Fighting { background: var(--type-fighting); }
.type-Poison { background: var(--type-poison); }
.type-Ground { background: var(--type-ground); color: #333; }
.type-Flying { background: var(--type-flying); }
.type-Psychic { background: var(--type-psychic); }
.type-Bug { background: var(--type-bug); }
.type-Rock { background: var(--type-rock); }
.type-Ghost { background: var(--type-ghost); }
.type-Dragon { background: var(--type-dragon); }
.type-Dark { background: var(--type-dark); }
.type-Steel { background: var(--type-steel); color: #333; }
.type-Fairy { background: var(--type-fairy); }

/* === Regulation Warning Banner === */
.reg-warning {
    font-size: 0.8rem;
    color: var(--warning);
    background: rgba(243, 156, 18, 0.12);
    border: 1px solid rgba(243, 156, 18, 0.3);
    border-radius: 4px;
    padding: 3px 8px;
    margin-bottom: 6px;
    text-align: center;
    font-weight: 500;
}

/* === Card Stats with Boost Buttons === */
.card-stats {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 2px;
    margin-bottom: 6px;
    font-size: 0.8rem;
    text-align: center;
}

.stat-label {
    color: var(--text-muted);
    text-transform: uppercase;
    font-weight: 600;
}

.stat-value {
    color: var(--text-primary);
    font-weight: 500;
}

.card-stats-boost {
    margin-bottom: 6px;
}

.stat-row {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 2px;
    text-align: center;
}

.stat-header-row {
    margin-bottom: 1px;
}

.stat-col-label {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    font-weight: 600;
}

.stat-value-row .stat-val {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--text-primary);
}

.stat-val.boosted-up { color: var(--success); }
.stat-val.boosted-down { color: var(--danger); }

.stat-boost-row {
    margin-top: 2px;
}

.boost-btns {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 2px;
}

.boost-btn {
    width: 20px;
    height: 20px;
    font-size: 0.75rem;
    font-weight: 700;
    background: var(--bg-primary);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: 3px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    line-height: 1;
}

.boost-btn:hover {
    background: var(--border);
    color: var(--text-primary);
}

.boost-val {
    font-size: 0.7rem;
    min-width: 18px;
    text-align: center;
    color: var(--text-muted);
    font-weight: 600;
}

.boost-val.boosted-up { color: var(--success); }
.boost-val.boosted-down { color: var(--danger); }

/* === Nature Indicators === */
.nature-plus {
    color: var(--success) !important;
}

.nature-minus {
    color: var(--danger) !important;
}

.nature-plus sup, .nature-minus sup {
    font-size: 0.6rem;
    vertical-align: super;
    margin-left: 1px;
}

/* === Estimated Stats === */
.stats-label {
    font-size: 0.7rem;
    color: var(--accent);
    font-style: italic;
    margin-bottom: 2px;
    text-align: center;
}

.stat-estimated {
    color: var(--accent) !important;
    font-style: italic;
}

/* === Base Stats Summary (when no calculated stats) === */
.base-stats-summary {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 2px;
    font-family: 'Consolas', 'Courier New', monospace;
}

/* === Speed Range Display === */
.speed-range-display {
    font-size: 0.8rem;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.stat-section-label {
    font-size: 0.75rem;
    color: var(--text-muted);
    text-transform: uppercase;
    font-weight: 600;
    margin-top: 4px;
    margin-bottom: 1px;
}

.est-spread {
    font-weight: 400;
    text-transform: none;
    color: var(--text-muted);
}

.card-stats.est .stat-value {
    color: var(--accent);
}

.card-ability {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 4px;
    padding: 2px 6px;
    border-radius: 4px;
    border: 1px solid transparent;
    transition: all 0.15s;
}

.card-ability.toggleable {
    cursor: pointer;
}

.card-ability.toggleable:hover {
    border-color: var(--border);
    background: rgba(255, 255, 255, 0.03);
}

.card-ability.ability-active,
.move-tag.ability-active {
    color: var(--success);
    border-color: var(--success);
    background: rgba(46, 204, 113, 0.1);
    box-shadow: 0 0 6px rgba(46, 204, 113, 0.3);
    font-weight: 600;
}

.card-tera {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-bottom: 4px;
}

.card-moves {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    margin-top: 4px;
}

.move-tag {
    font-size: 0.8rem;
    padding: 2px 8px;
    border-radius: 3px;
    background: var(--bg-primary);
    color: var(--text-secondary);
    border: 1px solid var(--border);
}

/* === Remove button (both sides) === */
.card-remove {
    position: absolute;
    top: 2px;
    right: 2px;
    background: none;
    border: none;
    color: var(--text-muted);
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
    z-index: 2;
    padding: 4px 8px;
}

.card-remove:hover {
    color: var(--danger);
}

/* === Status Buttons === */
.status-buttons {
    display: flex;
    gap: 4px;
    margin-bottom: 6px;
}

.status-btn {
    flex: 1;
    padding: 4px 0;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: 2px solid var(--border);
    border-radius: 4px;
    background: var(--bg-primary);
    color: var(--text-muted);
    cursor: pointer;
    transition: all 0.15s;
}

.status-btn:hover {
    border-color: var(--text-secondary);
    color: var(--text-secondary);
}

.status-btn.field {
    border-color: var(--status-field);
    color: var(--status-field);
    opacity: 0.4;
}
.status-btn.field.active {
    background: var(--status-field);
    color: white;
    border-color: var(--status-field);
    opacity: 1;
}

.status-btn.back {
    border-color: var(--status-back);
    color: var(--status-back);
    opacity: 0.4;
}
.status-btn.back.active {
    background: var(--status-back);
    color: white;
    border-color: var(--status-back);
    opacity: 1;
}

.status-btn.dead {
    border-color: var(--status-dead);
    color: var(--status-dead);
    opacity: 0.4;
}
.status-btn.dead.active {
    background: var(--status-dead);
    color: white;
    border-color: var(--status-dead);
    opacity: 1;
}

/* === Search (both sides) === */
#my-search-area, #opp-search-area {
    margin-bottom: 12px;
    position: relative;
}

#my-search, #opp-search {
    width: 100%;
    padding: 8px;
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    font-size: 0.85rem;
}

#my-search:focus, #opp-search:focus {
    outline: none;
    border-color: var(--accent);
}

.search-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 0 0 4px 4px;
    max-height: 200px;
    overflow-y: auto;
    z-index: 100;
}

.search-dropdown.hidden {
    display: none;
}

.search-result {
    padding: 6px 10px;
    cursor: pointer;
    font-size: 0.85rem;
}

.search-result:hover,
.search-result.highlighted {
    background: var(--accent);
    color: white;
}

/* === Stat mini (base stats summary) === */
.stat-mini {
    color: var(--text-primary);
    font-weight: 500;
}

/* === Expected Tera Types === */
.expected-tera {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 4px;
    flex-wrap: wrap;
}

.expected-label {
    font-size: 0.8rem;
    color: var(--text-muted);
}

.tera-chip {
    font-size: 0.65rem !important;
    padding: 2px 8px !important;
    cursor: pointer;
    opacity: 0.6;
    transition: all 0.15s;
}

.tera-chip:hover {
    opacity: 0.9;
}

.tera-chip.tera-chip-selected {
    opacity: 1;
    outline: 1px solid rgba(255, 255, 255, 0.4);
}

.tera-chip.tera-chip-active {
    opacity: 1;
    outline: 2px solid rgba(255, 255, 255, 0.8);
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.4), 0 0 16px currentColor;
    transform: scale(1.1);
}

/* === Details Toggle (both sides) === */
.details-toggle {
    font-size: 0.8rem;
    color: var(--accent);
    cursor: pointer;
    margin: 4px 0;
    user-select: none;
    display: inline-block;
}

.details-toggle:hover {
    color: var(--accent-hover);
    text-decoration: underline;
}

.opp-details, .my-details, .card-details {
    display: none;
}

.opp-details.expanded, .my-details.expanded, .card-details.expanded {
    display: block;
}

/* === Edit Stats Button === */
.edit-stats-btn {
    padding: 4px 10px;
    font-size: 0.8rem;
    background: var(--bg-primary);
    color: var(--accent);
    border: 1px solid var(--accent);
    border-radius: 4px;
    cursor: pointer;
    margin-bottom: 6px;
}

.edit-stats-btn:hover {
    background: var(--accent);
    color: white;
}

/* === Usage sections === */
.usage-section {
    margin-top: 6px;
    border-top: 1px solid var(--border);
    padding-top: 6px;
}

.usage-section h4 {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin-bottom: 4px;
    text-transform: uppercase;
}

.usage-row {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    padding: 2px 0;
}

.usage-row input[type="checkbox"] {
    width: 14px;
    height: 14px;
    accent-color: var(--accent);
}

.usage-row .usage-name {
    flex: 1;
    color: var(--text-primary);
}

.usage-row .usage-pct {
    color: var(--text-muted);
    min-width: 40px;
    text-align: right;
}

.usage-row.confirmed .usage-name {
    color: var(--success);
}

.usage-row.ruled-out .usage-name {
    color: var(--danger);
    text-decoration: line-through;
}

.card-notes {
    margin-top: 6px;
}

.card-notes textarea {
    width: 100%;
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 4px 6px;
    font-size: 0.85rem;
    resize: vertical;
    min-height: 28px;
}

.card-notes textarea:focus {
    outline: none;
    border-color: var(--accent);
}

/* Editable fields in cards */
.card-editable {
    display: flex;
    gap: 6px;
    align-items: center;
    margin-bottom: 4px;
}

.card-editable label {
    font-size: 0.85rem;
    color: var(--text-muted);
    min-width: 50px;
}

.card-editable input, .card-editable select {
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 3px 6px;
    font-size: 0.85rem;
    flex: 1;
}

.card-editable input:focus, .card-editable select:focus {
    outline: none;
    border-color: var(--accent);
}

/* === Card Details (expanded section) === */
.card-details {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid var(--border);
}

/* === Autocomplete === */
.autocomplete-wrap {
    position: relative;
    flex: 1;
}

.autocomplete-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--bg-card);
    border: 1px solid var(--border);
    border-radius: 0 0 4px 4px;
    max-height: 180px;
    overflow-y: auto;
    z-index: 200;
}

.autocomplete-dropdown.hidden {
    display: none;
}

.autocomplete-item {
    padding: 6px 8px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--text-primary);
}

.autocomplete-item:hover {
    background: var(--accent);
    color: white;
}

/* === Move Editor === */
.move-editor {
    margin-bottom: 6px;
}

.move-editor-label {
    font-size: 0.85rem;
    color: var(--text-muted);
    font-weight: 600;
    margin-bottom: 3px;
}

.move-editor-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    margin-bottom: 4px;
}

.move-tag.removable {
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding-right: 2px;
}

.move-remove-btn {
    background: none;
    border: none;
    color: var(--text-muted);
    font-size: 0.85rem;
    cursor: pointer;
    padding: 0 2px;
    line-height: 1;
}

.move-remove-btn:hover {
    color: var(--danger);
}

/* === Usage Badge === */
.usage-badge {
    font-size: 0.7rem;
    color: var(--accent);
    font-weight: 600;
    margin-left: 2px;
    opacity: 0.85;
}

/* === Raw Count Badge === */
.raw-count-badge {
    font-size: 0.75rem;
    color: var(--accent);
    background: rgba(77, 182, 172, 0.15);
    border: 1px solid rgba(77, 182, 172, 0.3);
    border-radius: 3px;
    padding: 1px 6px;
    font-weight: 600;
    white-space: nowrap;
}

/* === Invalid Input === */
.invalid-input {
    border-color: var(--danger) !important;
    box-shadow: 0 0 0 1px var(--danger);
}

/* === Regulation Select === */
#regulation-select {
    padding: 4px 8px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
}

#regulation-select:focus {
    outline: none;
    border-color: var(--accent);
}

#regulation-select:hover {
    background: var(--border);
    color: var(--text-primary);
}

/* === Center Panel === */
#center-panel {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 0;
    overflow: hidden;
}

#damage-panel {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
}

#speed-panel {
    flex-shrink: 0;
    min-height: 120px;
    max-height: 250px;
    overflow-y: auto;
}

/* Damage controls */
#damage-controls {
    display: flex;
    gap: 16px;
    align-items: center;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.damage-direction label {
    font-size: 0.8rem;
    margin-right: 10px;
    cursor: pointer;
}

.inline-check {
    font-size: 0.8rem;
    cursor: pointer;
}

/* Damage table */
#damage-table-container {
    overflow-x: auto;
}

.defender-header-row td {
    position: sticky;
    top: 0;
    z-index: 2;
    background: var(--bg-primary);
}

/* Tera toggles near damage table */
.damage-tera-inline {
    font-weight: 400;
    font-size: 0.75rem;
    color: var(--text-secondary);
    cursor: pointer;
    margin-left: 8px;
}

.damage-tera-inline input {
    accent-color: var(--accent);
    vertical-align: middle;
}

.damage-tera-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 6px 0;
    margin-bottom: 4px;
}

.damage-tera-toggle {
    font-size: 0.82rem;
    color: var(--text-secondary);
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 4px;
}

.damage-tera-toggle input {
    accent-color: var(--accent);
}

.placeholder-text {
    color: var(--text-muted);
    font-size: 0.85rem;
    text-align: center;
    padding: 20px;
}

.damage-assumption {
    font-size: 0.82rem;
    color: var(--text-muted);
    padding: 4px 6px;
    margin-bottom: 6px;
    background: var(--bg-card);
    border-radius: 4px;
    border-left: 3px solid var(--accent);
}

.damage-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.85rem;
}

.damage-table th,
.damage-table td {
    padding: 4px 6px;
    border: 1px solid var(--border);
    text-align: center;
}

.damage-table th {
    background: var(--bg-card);
    color: var(--text-secondary);
    font-weight: 600;
    position: sticky;
    top: 0;
}

.damage-table th.row-header {
    text-align: left;
    min-width: 120px;
}

.damage-table td.move-cell {
    text-align: left;
    font-weight: 500;
}

.dmg-safe { background: rgba(46, 204, 113, 0.15); color: var(--dmg-safe); }
.dmg-caution { background: rgba(241, 196, 15, 0.15); color: var(--dmg-caution); }
.dmg-danger { background: rgba(230, 126, 34, 0.15); color: var(--dmg-danger); }
.dmg-lethal { background: rgba(231, 76, 60, 0.2); color: var(--dmg-lethal); font-weight: 700; }
.dmg-immune { color: var(--text-muted); }

/* Speed order */
#speed-order-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.speed-entry {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 8px;
    background: var(--bg-card);
    border-radius: 4px;
    font-size: 0.85rem;
}

.speed-entry.mine {
    border-left: 3px solid var(--status-field);
}

.speed-entry.opponent {
    border-left: 3px solid var(--danger);
}

.speed-name {
    flex: 1;
    font-weight: 500;
}

.speed-value {
    color: var(--text-secondary);
    min-width: 40px;
    text-align: right;
}

/* === Clear Button === */
.btn-clear {
    padding: 4px 10px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--danger);
    border: 1px solid var(--danger);
    border-radius: 4px;
    cursor: pointer;
    opacity: 0.7;
}

.btn-clear:hover {
    background: var(--danger);
    color: white;
    opacity: 1;
}

.btn-export-team {
    padding: 4px 10px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--accent);
    border: 1px solid var(--accent);
    border-radius: 4px;
    cursor: pointer;
    opacity: 0.7;
}

.btn-export-team:hover {
    background: var(--accent);
    color: white;
    opacity: 1;
}

/* === Random Team Button === */
.btn-random-team {
    padding: 4px 10px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--warning);
    border: 1px solid var(--warning);
    border-radius: 4px;
    cursor: pointer;
    opacity: 0.8;
    font-weight: 600;
}

.btn-random-team:hover {
    background: var(--warning);
    color: white;
    opacity: 1;
}

/* === Toast Notification === */
.toast {
    position: fixed;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    background: var(--success);
    color: white;
    padding: 8px 20px;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    z-index: 2000;
    opacity: 0;
    transition: opacity 0.3s, transform 0.3s;
    pointer-events: none;
}

.toast.toast-error {
    background: var(--danger);
}

.toast.toast-visible {
    opacity: 1;
    transform: translateX(-50%) translateY(0);
}

/* === Tera Toggle === */
.tera-toggle-wrap {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 4px;
}

.tera-toggle-wrap label {
    font-size: 0.85rem;
    color: var(--text-muted);
}

.tera-toggle-btn {
    padding: 3px 10px;
    font-size: 0.75rem;
    border-radius: 3px;
    border: 1px solid var(--border);
    background: var(--bg-primary);
    color: var(--text-secondary);
    cursor: pointer;
    transition: all 0.15s;
}

.tera-toggle-btn.active {
    background: var(--accent);
    color: white;
    border-color: var(--accent);
}

.tera-toggle-btn:hover {
    border-color: var(--accent);
}

/* === Field Bar (Top) === */
#field-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    padding: 8px 16px;
    background: var(--bg-secondary);
    border-bottom: 1px solid var(--border);
    align-items: center;
    flex-shrink: 0;
}

.field-group {
    display: flex;
    align-items: center;
    gap: 4px;
}

.field-label {
    font-size: 0.85rem;
    color: var(--text-muted);
    font-weight: 600;
}

.field-toggle {
    padding: 3px 8px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: 3px;
    cursor: pointer;
    transition: all 0.15s;
}

.field-toggle:hover {
    border-color: var(--accent);
}

.field-toggle.active {
    background: var(--accent);
    color: white;
    border-color: var(--accent);
}

.field-toggle.special {
    font-weight: 600;
}

.field-toggle.special.active {
    background: var(--danger);
    border-color: var(--danger);
}

.small-btn {
    width: 24px;
    height: 24px;
    font-size: 0.9rem;
    background: var(--bg-card);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 3px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}

.small-btn:hover {
    background: var(--border);
}

#turn-count {
    font-size: 0.9rem;
    min-width: 20px;
    text-align: center;
    font-weight: 600;
}

/* === Field Abilities Bar === */
#field-abilities-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 16px;
    background: var(--bg-card);
    border-bottom: 1px solid var(--border);
}

#field-abilities-bar.hidden {
    display: none;
}

#field-abilities-list {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}

.field-ability-tag {
    font-size: 0.8rem;
    padding: 3px 10px;
    border-radius: 3px;
    font-weight: 600;
}

.field-ability-tag.mine {
    background: rgba(106, 142, 230, 0.2);
    color: var(--status-field);
    border: 1px solid var(--status-field);
}

.field-ability-tag.opponent {
    background: rgba(231, 76, 60, 0.2);
    color: var(--danger);
    border: 1px solid var(--danger);
}

/* === EV/IV Editor Modal === */
.ev-editor-grid {
    margin-bottom: 12px;
}

.ev-row {
    display: grid;
    grid-template-columns: 50px 50px 60px 60px 50px;
    gap: 8px;
    align-items: center;
    padding: 3px 0;
}

.ev-row.ev-header-row {
    border-bottom: 1px solid var(--border);
    padding-bottom: 6px;
    margin-bottom: 4px;
}

.ev-col-label {
    font-size: 0.8rem;
    color: var(--text-muted);
    font-weight: 600;
    text-transform: uppercase;
}

.ev-stat-name {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--text-primary);
}

.ev-base {
    font-size: 0.85rem;
    color: var(--text-secondary);
    text-align: center;
}

.ev-input {
    width: 100%;
    padding: 3px 4px;
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 3px;
    font-size: 0.85rem;
    text-align: center;
}

.ev-input:focus {
    outline: none;
    border-color: var(--accent);
}

/* Remove spinner arrows from number inputs */
.ev-input::-webkit-outer-spin-button,
.ev-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
.ev-input[type=number] {
    -moz-appearance: textfield;
}

.ev-final {
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--accent);
    text-align: center;
}

.ev-nature-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-top: 8px;
    border-top: 1px solid var(--border);
}

.ev-nature-row label {
    font-size: 0.85rem;
    color: var(--text-secondary);
}

.ev-nature-row select {
    padding: 4px 8px;
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 3px;
    font-size: 0.85rem;
}

.ev-nature-row select:focus {
    outline: none;
    border-color: var(--accent);
}

.ev-total {
    font-size: 0.85rem;
    color: var(--text-secondary);
    margin-left: auto;
}

/* === Modal === */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0,0,0,0.6);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 1000;
}

.modal.hidden {
    display: none;
}

.modal-content {
    background: var(--bg-secondary);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 20px;
    width: 500px;
    max-width: 90vw;
}

.modal-content h3 {
    margin-bottom: 12px;
    color: var(--accent);
}

.modal-content textarea {
    width: 100%;
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 8px;
    font-family: monospace;
    font-size: 0.8rem;
}

.modal-actions {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    justify-content: flex-end;
}

.modal-actions button {
    padding: 6px 16px;
    border-radius: 4px;
    border: 1px solid var(--border);
    cursor: pointer;
    font-size: 0.85rem;
}

.modal-actions button:first-child {
    background: var(--accent);
    color: white;
    border-color: var(--accent);
}

.modal-actions button:last-child {
    background: var(--bg-card);
    color: var(--text-secondary);
}

/* === Bug Report Form === */
.bug-report-form {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.bug-report-form label {
    font-size: 0.85rem;
    color: var(--text-secondary);
    font-weight: 600;
}

.bug-report-form input,
.bug-report-form textarea {
    width: 100%;
    background: var(--bg-input);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 8px;
    font-size: 0.85rem;
    font-family: inherit;
}

.bug-report-form input:focus,
.bug-report-form textarea:focus {
    outline: none;
    border-color: var(--accent);
}

.bug-report-form textarea {
    resize: vertical;
}

/* === Shortcuts Modal === */
.shortcuts-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
    max-height: 350px;
    overflow-y: auto;
}

.shortcut-row {
    display: flex;
    align-items: center;
    gap: 12px;
    font-size: 0.85rem;
}

.shortcut-row kbd {
    display: inline-block;
    min-width: 80px;
    text-align: center;
    padding: 3px 8px;
    font-size: 0.8rem;
    font-family: 'Consolas', 'Courier New', monospace;
    background: var(--bg-primary);
    color: var(--text-primary);
    border: 1px solid var(--border);
    border-radius: 4px;
    white-space: nowrap;
}

.shortcut-row span {
    color: var(--text-secondary);
}

/* === Scrollbar === */
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}

::-webkit-scrollbar-track {
    background: var(--bg-primary);
}

::-webkit-scrollbar-thumb {
    background: var(--border);
    border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--text-muted);
}

/* === Collapsible Panel Edge Tabs (desktop) === */
.panel-edge-tab {
    width: 16px;
    background: var(--bg-card);
    color: var(--text-muted);
    border: 1px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    padding: 0;
    transition: all 0.15s;
    align-self: stretch;
}

.panel-edge-tab:hover {
    background: var(--border);
    color: var(--text-primary);
}

/* === Mobile Collapse Button (header) === */
.btn-collapse-mobile {
    display: none;
    padding: 4px 8px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    line-height: 1;
}

.btn-collapse-mobile:hover {
    background: var(--border);
    color: var(--text-primary);
}

/* === Collapsible Panels === */
.panel.collapsed .team-header,
.panel.collapsed .team-input-toggle,
.panel.collapsed .team-input-area,
.panel.collapsed #my-team-cards,
.panel.collapsed #opp-team-cards {
    display: none;
}

.panel.collapsed {
    min-width: 0;
    width: 0;
    padding: 0;
    border: none;
    background: none;
    overflow: hidden;
}

/* === Unlock Limit Button === */
.btn-opp-unlimited {
    padding: 4px 10px;
    font-size: 0.8rem;
    background: var(--bg-card);
    color: var(--text-secondary);
    border: 1px solid var(--border);
    border-radius: 4px;
    cursor: pointer;
    opacity: 0.7;
}

.btn-opp-unlimited:hover {
    opacity: 1;
    border-color: var(--accent);
}

.btn-opp-unlimited.active {
    background: var(--accent);
    color: white;
    border-color: var(--accent);
    opacity: 1;
}

/* === Responsive === */
@media (max-width: 1400px) {
    body {
        height: auto;
        min-height: 100vh;
        overflow: auto;
    }
    main {
        grid-template-columns: 1fr 1fr;
        overflow: visible;
    }
    .panel-edge-tab {
        display: none;
    }
    .btn-collapse-mobile {
        display: inline-block;
    }
    .panel {
        overflow-y: visible;
        min-height: auto;
    }
    .panel.collapsed {
        width: auto;
        padding: 12px;
        border: 1px solid var(--border);
        background: var(--bg-secondary);
        overflow: visible;
    }
    .panel.collapsed .team-header {
        display: flex;
    }
    #my-team-panel,
    #opp-team-panel {
        overflow-y: visible;
        min-height: auto;
    }
    #center-panel {
        grid-column: 1 / -1;
        order: 3;
        overflow: visible;
    }
    #damage-panel {
        overflow-y: visible;
    }
    #speed-panel {
        max-height: none;
        overflow-y: visible;
    }
}

@media (max-width: 768px) {
    main {
        grid-template-columns: 1fr !important;
    }
    .panel-edge-tab {
        display: none;
    }

    /* Header: wrap title + actions */
    header {
        flex-wrap: wrap;
        gap: 8px;
    }
    header h1 {
        width: 100%;
    }
    .header-actions {
        flex-wrap: wrap;
        justify-content: center;
        width: 100%;
    }
    .header-actions button {
        padding: 6px 14px;
        font-size: 0.82rem;
    }
    #regulation-select {
        padding: 6px 10px;
        font-size: 0.82rem;
    }

    /* Field bar: stack but keep tappable */
    #field-bar {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        padding: 8px 12px;
    }
    .field-label {
        font-size: 0.8rem;
    }
    .field-group {
        gap: 3px;
    }
    .field-toggle {
        padding: 6px 8px;
        font-size: 0.8rem;
        min-height: 36px;
    }
    .small-btn {
        width: 28px;
        height: 28px;
    }

    /* Cards: larger boost buttons for tap targets */
    .boost-btn {
        width: 28px;
        height: 28px;
        font-size: 0.75rem;
    }
    .boost-val {
        font-size: 0.75rem;
        min-width: 18px;
    }
    .stat-val {
        font-size: 0.85rem;
    }

    /* Damage table: reduce row-header min-width, smaller font */
    .damage-table th.row-header {
        min-width: 80px;
    }
    .damage-table {
        font-size: 0.8rem;
    }
    .damage-table th,
    .damage-table td {
        padding: 3px 4px;
    }

    /* Modals: fluid width */
    .modal-content {
        width: auto;
        max-width: 95vw;
        padding: 14px;
    }

    /* EV editor grid: flexible columns */
    .ev-row {
        grid-template-columns: 40px 40px 1fr 1fr 40px;
        gap: 6px;
    }
    .ev-stat-name {
        font-size: 0.8rem;
    }
    .ev-base {
        font-size: 0.8rem;
    }
    .ev-input {
        font-size: 0.8rem;
    }
    .ev-final {
        font-size: 0.85rem;
    }

    /* Card expanded/editable sections: stack vertically */
    .card-editable {
        flex-direction: column;
        align-items: stretch;
        gap: 2px;
    }
    .card-editable label {
        min-width: unset;
    }
    .autocomplete-wrap {
        width: 100%;
    }
}

/* === Small phones === */
@media (max-width: 480px) {
    /* Header: compact */
    header {
        padding: 6px 10px;
    }
    header h1 {
        font-size: 1rem;
    }
    .header-actions button {
        padding: 5px 10px;
        font-size: 0.75rem;
    }
    #regulation-select {
        padding: 5px 6px;
        font-size: 0.75rem;
    }

    /* Field bar: tighter layout */
    #field-bar {
        gap: 6px;
        padding: 6px 8px;
    }
    .field-group {
        flex-wrap: wrap;
        gap: 3px;
    }
    .field-toggle {
        padding: 5px 6px;
        font-size: 0.75rem;
    }

    /* Cards: slightly reduced padding */
    .pokemon-card {
        padding: 8px;
    }

    /* Damage table: even smaller */
    .damage-table {
        font-size: 0.75rem;
    }
    .damage-table th,
    .damage-table td {
        padding: 2px 3px;
    }
    .damage-table th.row-header {
        min-width: 70px;
    }
}
