:root{
  /* Forza Horizon — fondo profundo azulado/violeta + degradado festival (morado→magenta→naranja) */
  --bg:#0a0912; --bg2:#110f1d; --panel:#171327; --panel2:#1e1933;
  --line:#2c2542; --txt:#efeaf7; --muted:#9890ad; --dim:#665d7e;
  --accent:#a855f7; --accent-d:#8b3df0; --accent2:#ff3d9a;
  --orange:#ff7a1a; --cyan:#22d3ee; --magenta:#ff3d9a;
  --warn:#ffb020; --bad:#ff5470; --good:#5be3a6;
  --grad:linear-gradient(100deg,#7c3aed 0%,#c026d3 45%,#ff5470 75%,#ff7a1a 100%);
  --radius:14px; --radius-s:9px;
  font-synthesis:none;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:
    radial-gradient(1100px 520px at 88% -12%, #ff3d9a22, transparent),
    radial-gradient(900px 520px at 5% -8%, #7c3aed26, transparent),
    var(--bg);
  color:var(--txt);
  font-family:"Segoe UI",system-ui,-apple-system,"Helvetica Neue",Arial,sans-serif;
  font-size:15px; line-height:1.5; -webkit-font-smoothing:antialiased;
}
a{color:var(--accent2)}
button{font-family:inherit}
.mono{font-family:"SF Mono",ui-monospace,Menlo,Consolas,monospace}

/* ---- Layout ---- */
header.top{
  position:sticky;top:0;z-index:30;background:rgba(10,9,18,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.bar{max-width:1180px;margin:0 auto;display:flex;align-items:center;gap:18px;padding:12px 20px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:.5px}
.brand .logo{width:30px;height:30px;border-radius:8px;background:var(--grad);color:#fff;
  display:grid;place-items:center;font-weight:900;font-size:14px;box-shadow:0 0 22px #c026d355}
.brand small{display:block;color:var(--muted);font-weight:600;font-size:11px;letter-spacing:1.5px}
nav.tabs{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}
nav.tabs button{
  background:transparent;border:1px solid transparent;color:var(--muted);
  padding:8px 14px;border-radius:999px;cursor:pointer;font-weight:700;font-size:13.5px;transition:.15s;
}
nav.tabs button:hover{color:var(--txt);background:var(--panel)}
nav.tabs button.active{color:#fff;background:var(--grad);box-shadow:0 4px 18px #c026d344}
main{max-width:1180px;margin:0 auto;padding:24px 20px 80px}
.view{display:none;animation:fade .25s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

h1.title{font-size:22px;margin:0 0 4px;letter-spacing:.3px}
.sub{color:var(--muted);margin:0 0 20px;font-size:13.5px}
.section-h{display:flex;align-items:center;gap:10px;margin:26px 0 12px;font-size:13px;font-weight:800;
  letter-spacing:1.5px;text-transform:uppercase;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.section-h::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,var(--accent),transparent);opacity:.5}

/* ---- Controls ---- */
.row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.4px}
input,select,textarea{
  background:var(--panel);border:1px solid var(--line);color:var(--txt);
  padding:10px 12px;border-radius:var(--radius-s);font-size:14px;outline:none;transition:.15s;
}
input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #a855f733}
input::placeholder{color:var(--dim)}
.btn{background:var(--grad);color:#fff;border:none;padding:11px 18px;border-radius:var(--radius-s);
  font-weight:800;cursor:pointer;font-size:14px;transition:.15s;letter-spacing:.3px;box-shadow:0 2px 14px #c026d333}
.btn:hover{filter:brightness(1.1);transform:translateY(-1px)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--txt);box-shadow:none}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent2)}
.btn.sm{padding:7px 12px;font-size:12.5px}
.btn.bad{background:transparent;border:1px solid #5a2a3a;color:#ff8aa3;box-shadow:none}
.btn.bad:hover{border-color:var(--bad);color:var(--bad)}

/* ---- Cards / grid ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:14px}
/* --- Carta estilo TCG (marco + glow por clase + foil holográfico) --- */
.card{position:relative;cursor:pointer;padding:14px;border-radius:16px;overflow:hidden;
  transition:transform .16s ease, box-shadow .16s ease;
  background:linear-gradient(180deg,var(--panel2),var(--panel));
  border:1.5px solid color-mix(in srgb, var(--cls,#888) 50%, var(--line));
  box-shadow:inset 0 0 0 1px #ffffff0a, inset 0 22px 42px -30px color-mix(in srgb, var(--cls,#fff) 60%, transparent), 0 2px 0 #0006}
.card::before{content:"";position:absolute;inset:0;border-radius:16px;pointer-events:none;z-index:3;mix-blend-mode:screen;
  background:linear-gradient(115deg,transparent 32%, color-mix(in srgb, var(--cls,#fff) 26%, transparent) 46%, transparent 60%);
  background-size:250% 250%;background-position:130% 0;opacity:0;transition:opacity .2s}
.card:hover{transform:translateY(-4px) scale(1.015);
  box-shadow:0 16px 40px #000b, 0 0 26px -4px color-mix(in srgb, var(--cls,#888) 55%, transparent)}
.card:hover::before{opacity:.95;animation:holo 1.05s ease}
@keyframes holo{from{background-position:130% 0}to{background-position:-50% 0}}
.card .pill.cls{box-shadow:0 0 12px -3px var(--cls,transparent)}
.card-img{height:120px;margin:-15px -15px 12px;background-size:cover;background-position:center;
  border-bottom:1px solid var(--line);border-radius:var(--radius) var(--radius) 0 0}
.card-img.ph{display:grid;place-items:center}
.card-img.ph span{font-size:42px;opacity:.45}
.card .num{position:absolute;top:9px;right:12px;font-size:11px;color:var(--dim);font-weight:800}
.card.has-img .num{background:#000a;color:#fff;padding:2px 8px;border-radius:99px;backdrop-filter:blur(4px)}
.card .make{font-size:11.5px;color:var(--muted);font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.card .make .dex{color:var(--dim);margin-right:5px;font-family:"SF Mono",ui-monospace,Menlo,monospace}
.card .model{font-size:16px;font-weight:800;margin:1px 0 8px;line-height:1.25}
.card .model .emoji{margin-right:4px;-webkit-text-fill-color:initial}
.card .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.pibar{height:5px;border-radius:99px;background:#ffffff10;overflow:hidden;margin:2px 0 9px}
.pibar i{display:block;height:100%;border-radius:99px}
.card .quick{margin-top:11px;width:100%;border:1px solid var(--line);background:#ffffff08;color:var(--txt);
  padding:7px;border-radius:var(--radius-s);font-weight:800;font-size:12.5px;cursor:pointer;transition:.15s;letter-spacing:.3px}
.card .quick:hover{background:var(--grad);border-color:transparent;color:#fff;box-shadow:0 3px 14px #c026d344}
.pw{color:var(--cyan);font-weight:700}
.pill{font-size:10.5px;font-weight:800;padding:3px 8px;border-radius:999px;letter-spacing:.4px;text-transform:uppercase}
.pill.dt{background:#0c1d20;color:var(--cyan);border:1px solid #16383c}
.pill.cls{background:#1d1230;color:#c79bff;border:1px solid #3a2358}
.pill.disc{background:#27101c;color:var(--magenta);border:1px solid #4a1c33}
.pill.unk{background:#2a1018;color:#ff8aa3;border:1px solid #5a2a3a}
.pill.src{background:#15121f;color:var(--dim);border:1px solid var(--line)}
.meta-line{display:flex;gap:10px;flex-wrap:wrap;color:var(--muted);font-size:12.5px;margin-top:4px}
.meta-line b{color:var(--txt);font-weight:700}

/* ---- Chips (disciplina) ---- */
.chips{display:flex;gap:7px;flex-wrap:wrap}
.chip{background:var(--panel);border:1px solid var(--line);color:var(--muted);padding:8px 13px;border-radius:999px;
  cursor:pointer;font-weight:700;font-size:13px;transition:.15s;white-space:nowrap}
.chip:hover{color:var(--txt);border-color:var(--accent)}
.chip.on{background:var(--grad);color:#fff;border-color:transparent;box-shadow:0 3px 14px #c026d340}

/* ---- Recommended strip (pokedex) ---- */
.rec-strip{background:linear-gradient(100deg,#7c3aed1f,#ff547014);border:1px solid var(--line);
  border-radius:var(--radius);padding:13px 15px;margin-bottom:16px}
.rec-strip h4{margin:0 0 9px;font-size:13px;color:var(--accent2);letter-spacing:.4px}
.rec-list{display:flex;gap:9px;flex-wrap:wrap}
.rec-pill{display:inline-flex;flex-direction:column;gap:1px;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:7px 11px;font-size:12.5px;min-width:130px}
.rec-pill b{color:var(--txt);font-weight:800}
.rec-pill span{color:var(--dim);font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}

/* ---- Tune sheet (resultado en formato menú del juego) ---- */
.tune-sheet{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:4px}
.tg{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius-s);padding:12px 13px}
.tg-head{display:flex;align-items:center;gap:9px;margin:0 0 9px;font-weight:800;font-size:13.5px}
.tg-num{width:22px;height:22px;border-radius:6px;background:var(--grad);color:#fff;display:grid;place-items:center;font-size:12px;font-weight:900;flex:0 0 auto}
.tg-row{display:flex;justify-content:space-between;gap:10px;padding:5px 0;border-top:1px solid var(--line)}
.tg-row:first-of-type{border-top:none}
.tg-row .k{color:var(--muted);font-size:12.5px}
.tg-row .v{font-weight:800;font-family:"SF Mono",ui-monospace,Menlo,monospace;color:#d9b3ff;text-align:right;font-size:13px}
.tg-row .v .note{display:block;color:var(--cyan);font-size:11px;font-weight:600;margin-top:2px;font-family:inherit}
@media(max-width:680px){.tune-sheet{grid-template-columns:1fr}}

/* ---- Result panel ---- */
.result{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px;margin-top:18px}
.result .head{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:14px}
.result .head h2{margin:0;font-size:20px}
.head-thumb{width:88px;height:62px;border-radius:10px;background-size:cover;background-position:center;border:1px solid var(--line);flex:0 0 auto}
.result .actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
table.tune{width:100%;border-collapse:collapse;font-size:13.5px}
table.tune td,table.tune th{padding:9px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
table.tune th{color:var(--muted);font-size:11px;letter-spacing:1px;text-transform:uppercase;font-weight:800}
table.tune td.k{color:var(--muted);width:42%}
table.tune td.v{font-weight:800;font-family:"SF Mono",ui-monospace,Menlo,monospace;color:#d9b3ff}
table.tune .note{display:block;color:var(--cyan);font-size:11.5px;font-weight:600;margin-top:3px;font-family:inherit}
.box{background:var(--bg2);border:1px solid var(--line);border-radius:var(--radius-s);padding:14px;margin-top:12px}
.box h4{margin:0 0 8px;font-size:13px;letter-spacing:.5px;color:var(--accent2)}
ol.steps{margin:0;padding-left:20px}ol.steps li{margin:4px 0}
ul.clean{margin:6px 0;padding-left:18px}ul.clean li{margin:3px 0}
.warns .w{background:#1c1606;border:1px solid #3a2e0a;color:var(--warn);padding:9px 12px;border-radius:8px;margin:6px 0;font-weight:600;font-size:13px}
.warns .w.bad{background:#220810;border-color:#4a0e22;color:#ff8aa3}

/* ---- Reference tables ---- */
table.ref{width:100%;border-collapse:collapse;font-size:13px;margin:8px 0}
table.ref th{background:var(--panel2);color:var(--accent2);text-align:left;padding:9px 10px;font-size:11px;letter-spacing:.6px;text-transform:uppercase}
table.ref td{padding:8px 10px;border-bottom:1px solid var(--line);color:var(--txt)}
table.ref tr:hover td{background:var(--panel)}

/* ---- Stars / saved ---- */
.stars{display:inline-flex;gap:3px}
.stars span{cursor:pointer;font-size:18px;color:var(--dim);transition:.1s;line-height:1}
.stars span.on{color:var(--orange);text-shadow:0 0 10px #ff7a1a66}
.stars.ro span{cursor:default}
.saved-item{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px;margin-bottom:12px}
.saved-item .si-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.saved-item .si-head .name{font-weight:800;font-size:15px}
.saved-item textarea{width:100%;margin-top:8px;min-height:48px;resize:vertical}
.empty{color:var(--muted);text-align:center;padding:40px 20px;border:1px dashed var(--line);border-radius:var(--radius)}

/* ---- Modal ---- */
.modal-bg{position:fixed;inset:0;background:#000a;backdrop-filter:blur(3px);display:none;z-index:50;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.modal-bg.open{display:flex}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:22px;max-width:640px;width:100%}
.modal h3{margin:0 0 14px}
.modal-img{height:200px;background-size:cover;background-position:center;border:1px solid var(--line);border-radius:var(--radius-s);margin-bottom:4px}
.modal-img.ph{display:grid;place-items:center;gap:2px;background:var(--bg2)}
.modal-img.ph span{font-size:50px;opacity:.45}
.modal-img.ph small{color:var(--dim);font-weight:700}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid .field{width:100%}
.form-grid input,.form-grid select{width:100%}
.modal .foot{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}

.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(40px);
  background:var(--grad);color:#fff;font-weight:800;padding:11px 20px;border-radius:999px;
  opacity:0;transition:.3s;z-index:60;box-shadow:0 8px 30px #000a}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.filters input,.filters select{flex:0 0 auto}
.filters input.search{flex:1 1 220px;min-width:180px}
.count{color:var(--muted);font-size:12.5px;margin-left:auto;align-self:center}
.hint{color:var(--dim);font-size:12px;margin-top:6px}
@media(max-width:560px){.form-grid{grid-template-columns:1fr}.bar{flex-wrap:wrap}}
