:root {
    --bg: #0a0a12;
    --bg2: #10101e;
    --bg3: #161628;
    --bg4: #1c1c34;
    --border: #252545;
    --border2: #333358;
    --text: #e4e4f0;
    --text2: #a0a0c0;
    --text3: #6a6a8e;
    --red: #ef4444;
    --green: #22c55e;
    --blue: #3b82f6;
    --yellow: #eab308;
    --purple: #a855f7;
    --cyan: #06b6d4;
    --orange: #f97316;
    --pink: #ec4899;
    --r: 10px;
    --t-normal:#a8a878;--t-fire:#f08030;--t-water:#6890f0;--t-electric:#f8d030;
    --t-grass:#78c850;--t-ice:#98d8d8;--t-fighting:#c03028;--t-poison:#a040a0;
    --t-ground:#e0c068;--t-flying:#a890f0;--t-psychic:#f85888;--t-bug:#a8b820;
    --t-rock:#b8a038;--t-ghost:#705898;--t-dragon:#7038f8;--t-dark:#705848;
    --t-steel:#b8b8d0;--t-fairy:#ee99ac;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);font-size:14px}
.mono{font-family:'JetBrains Mono',monospace}

/* Nav */
.top-nav{display:flex;align-items:center;gap:16px;padding:0 24px;height:52px;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.nav-brand{display:flex;align-items:center;gap:10px;margin-right:8px}
.brand-text{font-weight:800;font-size:1.1rem;background:linear-gradient(135deg,#ef4444,#f97316);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pokeball-icon{width:26px;height:26px;border-radius:50%;position:relative;overflow:hidden;border:2px solid #555;flex-shrink:0}
.pb-top{position:absolute;top:0;width:100%;height:50%;background:var(--red)}
.pb-bot{position:absolute;bottom:0;width:100%;height:50%;background:#eee}
.pb-line{position:absolute;top:50%;transform:translateY(-50%);width:100%;height:2px;background:#333;z-index:2}
.pb-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:#eee;border:2px solid #333;border-radius:50%;z-index:3}
.nav-tabs{display:flex;gap:2px;flex:1}
.nav-tab{padding:8px 16px;background:none;border:none;color:var(--text3);font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;border-radius:6px;transition:all .15s}
.nav-tab:hover{color:var(--text);background:var(--bg3)}
.nav-tab.active{color:#fff;background:var(--red)}
.nav-right{margin-left:auto}
.trainer-tag{font-size:.75rem;font-weight:600;color:var(--text3);background:var(--bg3);padding:5px 14px;border-radius:16px;border:1px solid var(--border)}
.app-main{padding:20px 24px;min-height:calc(100vh - 52px)}

/* Tab panels */
.tab-panel{display:none}.tab-panel.active{display:block}

/* Shared */
.section-title{font-size:1.1rem;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.section-title small{font-size:.75rem;color:var(--text3);font-weight:500}
.card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:16px}
.card-sm{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:12px}
.row{display:flex;gap:16px;flex-wrap:wrap}
.col{flex:1;min-width:0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.mb-16{margin-bottom:16px}
.mb-24{margin-bottom:24px}
.text-center{text-align:center}
.text-muted{color:var(--text3)}
.text-sm{font-size:.8rem}
.text-xs{font-size:.7rem}
.fw-700{font-weight:700}
.uppercase{text-transform:uppercase;letter-spacing:.05em}

.type-badge{display:inline-block;padding:2px 10px;border-radius:20px;font-size:.65rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.04em;text-shadow:0 1px 2px rgba(0,0,0,.4);white-space:nowrap;cursor:default}
.type-badge-lg{padding:5px 16px;font-size:.75rem}

/* Input */
.input{padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.9rem;font-family:inherit;outline:none;width:100%;transition:border-color .15s}
.input:focus{border-color:var(--red)}
.input::placeholder{color:var(--text3)}
.btn{padding:8px 18px;border:1px solid var(--border);border-radius:8px;background:var(--bg3);color:var(--text);font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}
.btn:hover{border-color:var(--text3);background:var(--bg4)}
.btn-red{background:var(--red);border-color:var(--red);color:#fff}
.btn-red:hover{background:#dc2626;border-color:#dc2626}
.btn-sm{padding:5px 12px;font-size:.7rem}

/* ===== POKEDEX TAB ===== */
.dex-controls{display:flex;gap:10px;margin-bottom:16px;flex-wrap:wrap;align-items:center}
.dex-search{flex:1;min-width:200px;padding:10px 14px 10px 38px;background:var(--bg2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:.85rem;font-family:inherit;outline:none;transition:border-color .15s;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236a6a8e' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:12px center}
.dex-search:focus{border-color:var(--red)}
.dex-search::placeholder{color:var(--text3)}
.gen-filters{display:flex;gap:4px}
.gen-btn{padding:6px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:6px;color:var(--text3);font-size:.7rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .12s}
.gen-btn:hover{color:var(--text);border-color:var(--text3)}
.gen-btn.active{background:var(--red);border-color:var(--red);color:#fff}
.type-filter-row{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:16px}
.type-filter-btn{padding:4px 10px;border-radius:14px;border:2px solid transparent;font-size:.65rem;font-weight:700;color:#fff;cursor:pointer;opacity:.5;transition:all .12s;text-transform:uppercase}
.type-filter-btn:hover,.type-filter-btn.active{opacity:1;border-color:#fff}

.dex-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}
.poke-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:12px;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.poke-card:hover{border-color:rgba(239,68,68,.5);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.3)}
.poke-card-num{font-size:.65rem;font-weight:700;color:var(--text3)}
.poke-card-img{display:flex;justify-content:center;padding:4px 0}
.poke-card-img img{width:80px;height:80px;image-rendering:pixelated;filter:drop-shadow(0 3px 8px rgba(0,0,0,.4));transition:transform .2s}
.poke-card:hover img{transform:scale(1.1)}
.poke-card-name{font-weight:700;font-size:.85rem;text-transform:capitalize;text-align:center;margin-bottom:6px}
.poke-card-types{display:flex;gap:4px;justify-content:center}

.load-more{display:block;margin:24px auto 0;padding:12px 36px;background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;color:#fff;font-size:.85rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .2s;box-shadow:0 4px 16px rgba(239,68,68,.25)}
.load-more:hover{transform:translateY(-2px);box-shadow:0 6px 24px rgba(239,68,68,.35)}

/* Poke detail modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);z-index:100;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-bg.open{opacity:1;pointer-events:all}
.modal-box{background:var(--bg3);border:1px solid var(--border);border-radius:14px;width:600px;max-width:95vw;max-height:92vh;overflow-y:auto;transform:scale(.93);transition:transform .2s}
.modal-bg.open .modal-box{transform:scale(1)}
.modal-top{padding:24px 24px 12px;text-align:center;position:relative}
.modal-close{position:absolute;top:12px;right:12px;background:var(--bg4);border:1px solid var(--border);border-radius:50%;width:30px;height:30px;color:var(--text3);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s}
.modal-close:hover{background:var(--red);color:#fff;border-color:var(--red)}
.modal-img{width:140px;height:140px;image-rendering:pixelated;filter:drop-shadow(0 6px 20px rgba(0,0,0,.5))}
.modal-num{font-size:.75rem;font-weight:700;color:var(--text3)}
.modal-name{font-size:1.5rem;font-weight:800;text-transform:capitalize;margin:4px 0 10px}
.modal-types{display:flex;gap:6px;justify-content:center;margin-bottom:10px}
.modal-meta{display:flex;gap:20px;justify-content:center;color:var(--text3);font-size:.8rem}
.modal-meta b{color:var(--text);font-weight:600}
.modal-body{padding:4px 24px 24px}
.modal-section{margin-bottom:18px}
.modal-section h3{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin-bottom:10px;font-weight:700}

.stat-row{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.stat-lbl{width:36px;font-size:.65rem;font-weight:700;color:var(--text3);text-align:right;text-transform:uppercase}
.stat-val{width:30px;font-size:.8rem;font-weight:700;text-align:right;font-family:'JetBrains Mono',monospace}
.stat-bar{flex:1;height:7px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden}
.stat-fill{height:100%;border-radius:4px;transition:width .4s}
.s-hp .stat-fill{background:linear-gradient(90deg,#4ade80,#22c55e)}
.s-atk .stat-fill{background:linear-gradient(90deg,#f87171,#ef4444)}
.s-def .stat-fill{background:linear-gradient(90deg,#fbbf24,#f59e0b)}
.s-spa .stat-fill{background:linear-gradient(90deg,#60a5fa,#3b82f6)}
.s-spd .stat-fill{background:linear-gradient(90deg,#c084fc,#a855f7)}
.s-spe .stat-fill{background:linear-gradient(90deg,#f472b6,#ec4899)}
.stat-total{text-align:right;font-size:.8rem;font-weight:700;margin-top:4px;color:var(--text2)}

.ability-tag{background:var(--bg4);border:1px solid var(--border);padding:5px 12px;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:capitalize;display:inline-block;margin:0 4px 4px 0}
.ability-tag.hidden{border-color:rgba(168,85,247,.4);background:rgba(168,85,247,.1);color:#c4b5fd}
.moves-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}
.move-item{font-size:.75rem;padding:5px 10px;background:var(--bg2);border-radius:5px;text-transform:capitalize;color:var(--text2)}

.modal-nav{display:flex;justify-content:space-between;padding:0 24px 16px}
.modal-nav .btn{min-width:100px}

/* Weakness/Resistance display */
.wr-grid{display:flex;gap:4px;flex-wrap:wrap}
.wr-item{display:flex;align-items:center;gap:4px;background:var(--bg2);border-radius:6px;padding:3px 8px;font-size:.7rem;font-weight:600}
.wr-mult{font-family:'JetBrains Mono',monospace;font-size:.65rem}
.wr-mult.super{color:#ef4444}.wr-mult.resist{color:#22c55e}.wr-mult.immune{color:#60a5fa}

/* ===== TYPE CHART TAB ===== */
.tc-wrapper{overflow-x:auto;margin-bottom:24px;border:1px solid var(--border);border-radius:var(--r)}
.tc-table{border-collapse:separate;border-spacing:0;width:100%}
.tc-table th,.tc-table td{width:54px;min-width:54px;height:40px;text-align:center;font-weight:700;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
.tc-table th{background:var(--bg2);color:var(--text2);padding:4px}
.tc-table thead th:first-child{position:sticky;left:0;z-index:3;background:var(--bg2);width:80px;min-width:80px}
.tc-table thead th{position:sticky;top:0;z-index:2}
.tc-table tbody th{position:sticky;left:0;z-index:1;background:var(--bg2);width:80px;min-width:80px}
.tc-table tbody tr{transition:background .1s}
.tc-table tbody tr:hover td{background-color:rgba(255,255,255,.03)}
.tc-table tbody tr:hover th{background:var(--bg4)}
.tc-cell{font-family:'JetBrains Mono',monospace;font-size:.9rem;cursor:default;transition:all .1s;position:relative}
.tc-cell:hover{transform:scale(1.15);z-index:1;box-shadow:0 0 12px rgba(0,0,0,.5)}
.tc-2x{background:rgba(239,68,68,.25);color:#fca5a5;font-weight:800}
.tc-4x{background:rgba(239,68,68,.45);color:#fecaca;font-weight:800}
.tc-half{background:rgba(34,197,94,.18);color:#86efac}
.tc-quarter{background:rgba(34,197,94,.3);color:#bbf7d0}
.tc-0{background:rgba(30,30,50,.6);color:#555}
.tc-1{color:rgba(255,255,255,.12)}
.tc-legend{display:flex;gap:20px;margin-top:16px;font-size:.8rem;color:var(--text2);flex-wrap:wrap;padding:0 4px}
.tc-legend span{display:flex;align-items:center;gap:8px}
.tc-legend-dot{width:16px;height:16px;border-radius:4px;display:inline-block}
/* Column highlight via JS */
.tc-table td.tc-col-highlight{background-color:rgba(255,255,255,.05)!important}

/* ===== TEAM BUILDER TAB ===== */
.team-slots{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:20px}
.team-slot{background:var(--bg3);border:2px dashed var(--border);border-radius:var(--r);padding:16px 8px;text-align:center;min-height:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:all .15s;position:relative}
.team-slot:hover{border-color:var(--text3)}
.team-slot.filled{border-style:solid;border-color:var(--border2)}
.team-slot .remove-btn{position:absolute;top:6px;right:6px;width:20px;height:20px;border-radius:50%;background:var(--red);border:none;color:#fff;font-size:.7rem;cursor:pointer;display:none;align-items:center;justify-content:center}
.team-slot.filled .remove-btn{display:flex}
.team-slot img{width:64px;height:64px;image-rendering:pixelated}
.team-slot .slot-name{font-size:.75rem;font-weight:700;text-transform:capitalize}
.team-slot .slot-placeholder{color:var(--text3);font-size:.75rem}
.team-analysis{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.team-analysis .card h3{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);margin-bottom:10px;font-weight:700}
.coverage-row{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.coverage-type{width:60px}
.coverage-bar-wrap{flex:1;height:8px;background:var(--bg2);border-radius:4px;overflow:hidden}
.coverage-bar{height:100%;border-radius:4px}
.coverage-val{width:28px;text-align:right;font-size:.7rem;font-family:'JetBrains Mono',monospace;font-weight:600}

/* ===== COMPARE TAB ===== */
.compare-container{display:grid;grid-template-columns:1fr 60px 1fr;gap:0;align-items:start}
.compare-side{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:20px}
.compare-vs{display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:900;color:var(--text3);padding-top:80px}
.compare-pokemon{text-align:center;margin-bottom:16px}
.compare-pokemon img{width:120px;height:120px;image-rendering:pixelated;filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}
.compare-pokemon h2{font-size:1.2rem;text-transform:capitalize;margin:8px 0 4px}
.compare-stat-row{display:flex;align-items:center;margin-bottom:6px;gap:6px}
.compare-stat-left{flex:1;display:flex;align-items:center;gap:6px;justify-content:flex-end}
.compare-stat-right{flex:1;display:flex;align-items:center;gap:6px}
.compare-stat-label{width:40px;text-align:center;font-size:.65rem;font-weight:700;color:var(--text3);text-transform:uppercase;flex-shrink:0}
.compare-bar-l{height:7px;border-radius:4px;margin-left:auto}
.compare-bar-r{height:7px;border-radius:4px}
.compare-val{font-size:.8rem;font-weight:700;font-family:'JetBrains Mono',monospace;width:28px;text-align:center}
.compare-winner{color:var(--green)}
.compare-loser{color:var(--red)}

/* ===== NATURES TAB ===== */
.nature-table-wrap{overflow-x:auto}
.nature-table{border-collapse:collapse;width:100%;font-size:.8rem}
.nature-table th,.nature-table td{padding:8px 12px;border:1px solid var(--border);text-align:center}
.nature-table th{background:var(--bg2);color:var(--text2);font-size:.7rem;text-transform:uppercase;font-weight:700;position:sticky;top:0}
.nature-table td{background:var(--bg3)}
.nature-up{color:#4ade80;font-weight:700}
.nature-down{color:#f87171;font-weight:700}
.nature-neutral{color:var(--text3)}
.nature-name{font-weight:600;text-align:left!important}
.ev-card{text-align:center;padding:20px}
.ev-card h4{font-size:.9rem;margin-bottom:8px}
.ev-card .big-num{font-size:2rem;font-weight:800;font-family:'JetBrains Mono',monospace}
.ev-formula{background:var(--bg2);border-radius:8px;padding:12px;font-family:'JetBrains Mono',monospace;font-size:.8rem;color:var(--text2);margin-top:12px}

/* ===== CALCULATOR TAB ===== */
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.calc-field{margin-bottom:12px}
.calc-field label{display:block;font-size:.7rem;font-weight:600;color:var(--text3);text-transform:uppercase;margin-bottom:4px}
.calc-field select,.calc-field input[type="number"]{width:100%;padding:8px 12px;background:var(--bg2);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:inherit;font-size:.85rem;outline:none}
.calc-field select:focus,.calc-field input[type="number"]:focus{border-color:var(--red)}
.calc-result{background:var(--bg2);border-radius:var(--r);padding:20px;text-align:center;margin-top:16px}
.calc-dmg{font-size:2.5rem;font-weight:900;font-family:'JetBrains Mono',monospace}
.calc-range{font-size:.85rem;color:var(--text2);margin-top:4px}
.calc-details{font-size:.75rem;color:var(--text3);margin-top:8px}

/* Autocomplete */
.ac-wrap{position:relative}
.ac-list{position:absolute;top:100%;left:0;right:0;background:var(--bg2);border:1px solid var(--border);border-radius:0 0 8px 8px;max-height:200px;overflow-y:auto;z-index:20;display:none}
.ac-list.show{display:block}
.ac-item{padding:8px 12px;cursor:pointer;font-size:.8rem;text-transform:capitalize;display:flex;align-items:center;gap:8px}
.ac-item:hover{background:var(--bg4)}
.ac-item img{width:32px;height:32px;image-rendering:pixelated}

/* Spinner */
.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* Scrollbar */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

@media(max-width:900px){
    .team-slots{grid-template-columns:repeat(3,1fr)}
    .compare-container{grid-template-columns:1fr}
    .compare-vs{padding:12px 0;font-size:1rem}
    .calc-grid{grid-template-columns:1fr}
    .grid-3{grid-template-columns:1fr 1fr}
    .top-nav{flex-wrap:wrap;height:auto;padding:8px 16px}
    .nav-tabs{order:3;width:100%;overflow-x:auto;padding-bottom:4px}
}
@media(max-width:600px){
    .team-slots{grid-template-columns:repeat(2,1fr)}
    .team-analysis{grid-template-columns:1fr}
    .dex-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}
    .grid-3,.grid-2{grid-template-columns:1fr}
}
