/* Tarificador KT – UI (añadidos para ordenar plantilla y acciones) */
:root{
  --bg:#0b1020; --card:#0f172a; --surface:#111827; --muted:#93a3b9; --text:#e5e7eb;
  --brand:#7c3aed; --brand-2:#22d3ee; --ok:#10b981; --warn:#f59e0b; --err:#ef4444;
  --bd:rgba(148,163,184,.28); --radius:14px; --shadow:0 12px 30px rgba(2,6,23,.32);
}
@media (prefers-color-scheme: light){
  :root{ --bg:#f8fafc; --card:#fff; --surface:#fff; --muted:#64748b; --text:#0f172a; --bd:#e5e7eb; --shadow:0 8px 24px rgba(15,23,42,.06) }
}
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;color:var(--text);
  background: radial-gradient(1200px 600px at 20% -10%, rgba(124,58,237,.22), transparent 60%),
              radial-gradient(1000px 500px at 110% 10%, rgba(34,211,238,.18), transparent 60%),
              var(--bg);
  font:16px/1.45 system-ui,-apple-system,Segoe UI,Inter,Roboto,Arial,sans-serif;
}

.container{max-width:1100px;margin-inline:auto;padding:24px}
.header{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:var(--shadow)}
.logo svg{width:26px;height:26px;color:white}
h1{font-size:clamp(20px,2.4vw,28px);margin:0}
.sub{color:var(--muted);font-size:.95rem}

.card{background:var(--card);border:1px solid var(--bd);border-radius:var(--radius);box-shadow:var(--shadow)}
.section{padding:16px 16px 14px}
.section h2{margin:0 0 10px;font-size:1rem;color:var(--muted);font-weight:600;letter-spacing:.02em}

/* Toolbar de parámetros */
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-top:10px}
.actions{display:flex;align-items:flex-end;gap:10px}
.spacer{flex:1}

/* Fields */
.field{display:flex;flex-direction:column;gap:6px;min-width:min(420px,100%)}
.field.small{min-width:180px}
.field.grow{min-width:260px;flex:1}
label{font-size:.84rem;color:var(--muted)}

input,select,button{
  border:1px solid var(--bd); background:var(--surface); color:var(--text);
  padding:10px 12px; border-radius:12px; outline:none; transition:box-shadow .15s,border-color .15s,transform .04s;
}
input::placeholder{color:color-mix(in oklab,var(--muted) 65%,transparent)}
input:focus,select:focus{border-color:color-mix(in oklab,var(--brand) 70%,white 20%);box-shadow:0 0 0 3px color-mix(in oklab,var(--brand) 18%,transparent)}
button{
  background:linear-gradient(180deg, color-mix(in oklab,var(--brand) 92%, black 10%), color-mix(in oklab,var(--brand) 88%, black 16%));
  border:1px solid color-mix(in oklab,var(--brand) 80%, black 10%); color:white; cursor:pointer; font-weight:600;
}
button:hover{filter:brightness(1.05)} button:active{transform:translateY(1px)} button:disabled{opacity:.55;cursor:not-allowed}
.status{font-size:.88rem;color:var(--muted);margin-left:.25rem}
.status.tiny{font-size:.82rem;margin-left:10px}

/* Botones secundarios/terciarios */
.btn-secondary{
  background:transparent; color:var(--text);
  border:1px dashed color-mix(in oklab,var(--brand-2) 60%, var(--bd) 40%);
}
.btn-secondary:hover{background:rgba(34,211,238,.08)}
.btn-secondary:active{transform:translateY(1px)}
.btn-ghost{
  background:transparent; color:var(--brand-2);
  border:1px solid color-mix(in oklab,var(--brand-2) 60%, var(--bd) 40%);
}
.btn-ghost:hover{background:rgba(34,211,238,.08)}

/* Combo */
.combo{position:relative}
.combo input{width:100%}
.sel-pill{position:absolute; inset:3px auto auto 3px; max-width:calc(100% - 56px); padding:.35rem .55rem;
  border-radius:10px; background:rgba(148,163,184,.15); color:var(--muted); font-size:.9rem; display:none; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.combo.has-selection .sel-pill{display:inline-block}
.combo.has-selection input::placeholder{color:transparent}
.clear-btn{position:absolute; right:.35rem; top:.32rem; border:none; background:transparent; color:var(--muted); font-size:1.2rem; cursor:pointer; display:none}
.combo.has-selection .clear-btn{display:block}
.list{position:absolute; z-index:40; top:calc(100% + 6px); left:0; right:0; max-height:300px; overflow:auto;
  background:var(--card); border:1px solid var(--bd); border-radius:12px; box-shadow:var(--shadow); display:none}
.list.open{display:block}
.opt{padding:.6rem .75rem; cursor:pointer}
.opt:hover,.opt.active{background:rgba(148,163,184,.12)}
.muted{color:var(--muted)}
.loading{opacity:.6;pointer-events:none}

/* Uploader ordenado */
.uploader{
  display:flex; flex-wrap:wrap; gap:16px; align-items:flex-end; justify-content:space-between;
}
.uploader-actions{display:flex; gap:10px; align-items:flex-end}

.file-btn{
  display:inline-flex; align-items:center; gap:10px; padding:10px 14px;
  background:linear-gradient(180deg, color-mix(in oklab,var(--brand-2) 32%, white 0%), color-mix(in oklab,var(--brand-2) 14%, black 6%));
  border:1px solid color-mix(in oklab,var(--brand-2) 40%, white 20%); color:#062336;
  border-radius:12px; cursor:pointer; user-select:none; width:max-content;
  box-shadow:0 6px 16px rgba(2,6,23,.24);
}
.file-btn:hover{filter:brightness(1.03)}
.file-btn:active{transform:translateY(1px)}
.file-btn input[type="file"]{display:none}
.file-btn svg{width:18px;height:18px}
.file-name{margin-top:6px; font-size:.9rem}

/* Resultados */
.grid.two{display:grid;gap:14px;margin-top:16px;grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:820px){.grid.two{grid-template-columns:1fr}}
.card h3{margin:0 0 10px;font-size:1rem;color:var(--muted);font-weight:600}
.result{display:flex;flex-direction:column;gap:12px}
.big-number{
  font-size:clamp(22px,3.5vw,34px); font-weight:800; letter-spacing:.2px;
  background:linear-gradient(90deg,var(--brand),var(--brand-2)); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.row-pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{padding:6px 10px;border-radius:999px;background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.25);color:color-mix(in oklab,var(--brand) 85%, white 10%);font-size:.9rem}
.facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.fact{background:linear-gradient(180deg, rgba(2,6,23,.42), rgba(2,6,23,.28)); padding:10px 12px; border-radius:12px; border:1px dashed color-mix(in oklab,var(--bd) 60%, transparent)}
.fact span{display:block;color:var(--muted);font-size:.84rem}
.fact strong{font-size:1.02rem}

/* Footer */
.footer{margin-top:24px;color:var(--muted);font-size:.85rem;text-align:center}
.footer a{color:var(--brand-2);text-decoration:none}
.footer a:hover{text-decoration:underline}

:root{
  --bg:#0b1020; --card:#0f172a; --surface:#111827; --muted:#93a3b9; --text:#e5e7eb;
  --brand:#7c3aed; --brand-2:#22d3ee; --ok:#10b981; --warn:#f59e0b; --err:#ef4444;
  --bd:rgba(148,163,184,.28); --radius:14px; --shadow:0 12px 30px rgba(2,6,23,.32);
}
@media (prefers-color-scheme: light){
  :root{ --bg:#f8fafc; --card:#fff; --surface:#fff; --muted:#64748b; --text:#0f172a; --bd:#e5e7eb; --shadow:0 8px 24px rgba(15,23,42,.06) }
}
*{box-sizing:border-box} html,body{height:100%}
body{margin:0;color:var(--text);
  background: radial-gradient(1200px 600px at 20% -10%, rgba(124,58,237,.22), transparent 60%),
              radial-gradient(1000px 500px at 110% 10%, rgba(34,211,238,.18), transparent 60%),
              var(--bg);
  font:16px/1.45 system-ui,-apple-system,Segoe UI,Inter,Roboto,Arial,sans-serif;
}
.container{max-width:1200px;margin-inline:auto;padding:24px}
.header{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.logo{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand),var(--brand-2));box-shadow:var(--shadow)}
.logo svg{width:26px;height:26px;color:white}
h1{font-size:clamp(20px,2.4vw,28px);margin:0}
.sub{color:var(--muted);font-size:.95rem}
.card{background:var(--card);border:1px solid var(--bd);border-radius:var(--radius);box-shadow:var(--shadow)}
.section{padding:16px 16px 14px}
.section h2{margin:0 0 10px;font-size:1rem;color:var(--muted);font-weight:600;letter-spacing:.02em}
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-top:10px}
.actions{display:flex;align-items:flex-end;gap:10px}
.spacer{flex:1}
.field{display:flex;flex-direction:column;gap:6px;min-width:min(420px,100%)}
.field.small{min-width:180px}
.field.grow{min-width:260px;flex:1}
label{font-size:.84rem;color:var(--muted)}
input,select,button{
  border:1px solid var(--bd); background:var(--surface); color:var(--text);
  padding:10px 12px; border-radius:12px; outline:none; transition:box-shadow .15s,border-color .15s,transform .04s;
}
input::placeholder{color:color-mix(in oklab,var(--muted) 65%,transparent)}
input:focus,select:focus{border-color:color-mix(in oklab,var(--brand) 70%,white 20%);box-shadow:0 0 0 3px color-mix(in oklab,var(--brand) 18%,transparent)}
button{
  background:linear-gradient(180deg, color-mix(in oklab,var(--brand) 92%, black 10%), color-mix(in oklab,var(--brand) 88%, black 16%));
  border:1px solid color-mix(in oklab,var(--brand) 80%, black 10%); color:white; cursor:pointer; font-weight:600;
}
button:hover{filter:brightness(1.05)} button:active{transform:translateY(1px)} button:disabled{opacity:.55;cursor:not-allowed}
.status{font-size:.88rem;color:var(--muted);margin-left:.25rem}
.status.tiny{font-size:.82rem;margin-left:10px}
.btn-secondary{
  background:transparent; color:var(--text);
  border:1px dashed color-mix(in oklab,var(--brand-2) 60%, var(--bd) 40%);
}
.btn-secondary:hover{background:rgba(34,211,238,.08)}
.btn-secondary:active{transform:translateY(1px)}
.btn-ghost{
  background:transparent; color:var(--brand-2);
  border:1px solid color-mix(in oklab,var(--brand-2) 60%, var(--bd) 40%);
}
.btn-ghost:hover{background:rgba(34,211,238,.08)}
.combo{position:relative}
.combo input{width:100%}
.sel-pill{position:absolute; inset:3px auto auto 3px; max-width:calc(100% - 56px); padding:.35rem .55rem;
  border-radius:10px; background:rgba(148,163,184,.15); color:var(--muted); font-size:.9rem; display:none; white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
.combo.has-selection .sel-pill{display:inline-block}
.combo.has-selection input::placeholder{color:transparent}
.clear-btn{position:absolute; right:.35rem; top:.32rem; border:none; background:transparent; color:var(--muted); font-size:1.2rem; cursor:pointer; display:none}
.combo.has-selection .clear-btn{display:block}
.list{position:absolute; z-index:40; top:calc(100% + 6px); left:0; right:0; max-height:300px; overflow:auto;
  background:var(--card); border:1px solid var(--bd); border-radius:12px; box-shadow:var(--shadow); display:none}
.list.open{display:block}
.opt{padding:.6rem .75rem; cursor:pointer}
.opt:hover,.opt.active{background:rgba(148,163,184,.12)}
.muted{color:var(--muted)}
.loading{opacity:.6;pointer-events:none}
.uploader{display:flex; flex-wrap:wrap; gap:16px; align-items:flex-end; justify-content:space-between;}
.uploader-actions{display:flex; gap:10px; align-items:flex-end}
.file-btn{display:inline-flex; align-items:center; gap:10px; padding:10px 14px;
  background:linear-gradient(180deg, color-mix(in oklab,var(--brand-2) 32%, white 0%), color-mix(in oklab,var(--brand-2) 14%, black 6%));
  border:1px solid color-mix(in oklab,var(--brand-2) 40%, white 20%); color:#062336;
  border-radius:12px; cursor:pointer; user-select:none; width:max-content; box-shadow:0 6px 16px rgba(2,6,23,.24);
}
.file-btn:hover{filter:brightness(1.03)}
.file-btn:active{transform:translateY(1px)}
.file-btn input[type="file"]{display:none}
.file-btn svg{width:18px;height:18px}
.file-name{margin-top:6px; font-size:.9rem}
.grid.two{display:grid;gap:14px;margin-top:16px;grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:820px){.grid.two{grid-template-columns:1fr}}
.card h3{margin:0 0 10px;font-size:1rem;color:var(--muted);font-weight:600}
.result{display:flex;flex-direction:column;gap:12px}
.big-number{font-size:clamp(22px,3.5vw,34px); font-weight:800; letter-spacing:.2px;
  background:linear-gradient(90deg,var(--brand),var(--brand-2)); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.row-pills{display:flex;gap:8px;flex-wrap:wrap}
.pill{padding:6px 10px;border-radius:999px;background:rgba(124,58,237,.12);border:1px solid rgba(124,58,237,.25);color:color-mix(in oklab,var(--brand) 85%, white 10%);font-size:.9rem}
.facts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.fact{background:linear-gradient(180deg, rgba(2,6,23,.42), rgba(2,6,23,.28)); padding:10px 12px; border-radius:12px; border:1px dashed color-mix(in oklab,var(--bd) 60%, transparent)}
.fact span{display:block;color:var(--muted);font-size:.84rem}
.fact strong{font-size:1.02rem}
/* Loader overlay (ya existente) */
.loader-overlay{position:fixed; inset:0; display:none; align-items:center; justify-content:center; padding:20px;
  background:rgba(3,6,20,.55); backdrop-filter: blur(6px); z-index:9999;}
.loader-overlay.show{display:flex}
.loader-card{width:min(720px,96vw); background:var(--card); border:1px solid var(--bd); border-radius:18px; box-shadow:var(--shadow); padding:16px;}
.loader-head{display:flex; align-items:center; gap:12px; margin-bottom:10px}
.spinner{width:22px; height:22px; border-radius:999px; border:3px solid color-mix(in oklab, var(--brand) 40%, var(--bd) 60%);
  border-top-color:var(--brand); animation:spin 1s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.loader-title{font-weight:700; font-size:1rem}
.loader-sub{color:var(--muted); font-size:.9rem}
.loader-grid{display:grid; grid-template-columns: 1fr 1fr; gap:12px; margin-top:10px}
@media (max-width:680px){.loader-grid{grid-template-columns:1fr}}
.kv{background:var(--surface); border:1px dashed var(--bd); border-radius:12px; padding:10px 12px}
.kv b{display:block; font-size:.78rem; color:var(--muted); margin-bottom:4px}
.kv span{font-size:.95rem}
.steps{display:flex; gap:8px; margin-top:12px; flex-wrap:wrap}
.step{padding:6px 10px; border-radius:999px; border:1px solid var(--bd); background:rgba(148,163,184,.08); color:var(--muted); font-size:.85rem}
.step.active{border-color:color-mix(in oklab, var(--brand) 65%, white 10%); color:var(--text)}
.step.done{background:rgba(16,185,129,.14); border-color:rgba(16,185,129,.35); color:var(--ok)}
.loader-foot{display:flex; align-items:center; justify-content:flex-end; gap:8px; margin-top:12px}
.loader-foot .muted{font-size:.85rem}
button.is-loading{position:relative; color:transparent !important}
button.is-loading::after{content:""; position:absolute; inset:0; margin:auto; width:18px; height:18px; border-radius:999px;
  border:3px solid rgba(255,255,255,.35); border-top-color:#fff; animation:spin .8s linear infinite;}

/* Tabs */
.tabs{display:flex; gap:10px; margin:10px 0 16px}
.tab{padding:10px 12px; border-radius:999px; border:1px solid var(--bd); background:rgba(148,163,184,.08); color:var(--muted); cursor:pointer; font-weight:600}
.tab.active{background:linear-gradient(90deg, rgba(124,58,237,.18), rgba(34,211,238,.18)); color:var(--text); border-color:color-mix(in oklab,var(--brand) 70%, var(--bd) 30%)}
.view{display:none}
.view.show{display:block}

/* Contenedor responsive del Power BI */
.pbi-wrap{display:block; width:100%; height:75vh; border:1px solid var(--bd); border-radius:12px; overflow:hidden}
.pbi-wrap iframe{width:100%; height:100%; border:0}

/* Tarjeta ancha y rejilla de 6 */
.card.full{width:100%; margin-top:14px}
.toolbar.wrap{flex-wrap:wrap}
.result-wide{margin-top:8px}
.facts-6{display:grid; grid-template-columns:repeat(6,minmax(0,1fr)); gap:10px}
@media (max-width:1000px){ .facts-6{grid-template-columns:repeat(3,minmax(0,1fr))} }
@media (max-width:640px){ .facts-6{grid-template-columns:repeat(2,minmax(0,1fr))} }

/* Switch bonito */
.switch-field{align-items:flex-end}
.switch{position:relative; display:inline-block; width:52px; height:30px}
.switch input{opacity:0; width:0; height:0}
.switch .slider{
  position:absolute; cursor:pointer; inset:0; border-radius:999px;
  background:rgba(148,163,184,.35); transition:.2s; border:1px solid var(--bd);
}
.switch .slider:before{
  content:""; position:absolute; height:22px; width:22px; left:4px; top:3px; border-radius:50%;
  background:#fff; transition:.2s; box-shadow:0 2px 6px rgba(2,6,23,.3);
}
.switch input:checked + .slider{ background:linear-gradient(90deg, rgba(124,58,237,.55), rgba(34,211,238,.55)); }
.switch input:checked + .slider:before{ transform:translateX(22px); }
