/* =====================================================================
   ALLSTOCK · Administrador Multi-Tienda — admin.css
   Estética: premium, limpia, profesional (tipo Apple / ecommerce serio)
   Paleta: verde agua #37ba98 · celeste #3790b7 · azul #3759b7
           azul oscuro #193d53 · gris tipográfico #4c4c4c
   ===================================================================== */

:root{
  /* ===== Marca ALLSTOCK · sólo acentos ===== */
  --verde:#37ba98;
  --celeste:#3790b7;
  --azul:#3759b7;

  /* ===== Superficies y texto · LIGHT (Apple / iCloud / SaaS) ===== */
  --bg:#f5f5f7;
  --bg-soft:#f6f7f9;
  --surface:#ffffff;
  --surface-elevated:#ffffff;
  --surface-muted:#f2f3f5;
  --surface-hover:#f7f8fa;

  --text:#1d1d1f;
  --text-secondary:#4c4c4c;
  --text-muted:#6e6e73;
  --text-disabled:#a1a1a6;

  --border:#e5e7eb;
  --border-strong:#d9dde3;

  /* ===== Acentos semánticos ===== */
  --primary:#193d53;
  --primary-hover:#24536d;
  --primary-soft:rgba(25,61,83,.10);
  --accent:#37ba98;
  --accent-hover:#2fa886;
  --accent-soft:rgba(55,186,152,.12);
  --success:#16876c;
  --success-soft:rgba(55,186,152,.12);
  --warning:#a76300;
  --warning-soft:rgba(167,99,0,.12);
  --danger:#b42318;
  --danger-soft:rgba(180,35,24,.10);

  /* ===== Sombras suaves ===== */
  --shadow-soft:0 8px 24px rgba(0,0,0,.06);
  --shadow-card:0 12px 32px rgba(0,0,0,.07);
  --shadow-hover:0 16px 40px rgba(0,0,0,.10);

  /* ===== Sidebar (Light: blanco glass) ===== */
  --side-bg:rgba(255,255,255,.85);
  --side-border:var(--border);
  --side-txt:#5b6470;
  --side-txt-hover:var(--text);
  --side-hover-bg:rgba(0,0,0,.045);
  --side-active-bg:var(--accent-soft);
  --side-active-txt:var(--primary);
  --side-active-border:rgba(55,186,152,.22);
  --side-group:#9aa3ad;
  --side-brand:var(--text);
  --side-brandsub:var(--text-muted);
  --side-count-bg:var(--surface-muted);
  --side-count-txt:var(--text-secondary);

  /* ===== Header (glass) ===== */
  --topbar-bg:rgba(255,255,255,.82);
  --topbar-border:var(--border);

  /* ===== Componentes ===== */
  --bar-bg:var(--primary);
  --scroll-thumb:#c9ccd2;
  --switch-track:#d9dde3;
  --switch-knob:#ffffff;
  --dash-border:#d2d7de;
  --notice-bg:var(--accent-soft);   --notice-border:rgba(55,186,152,.24);  --notice-txt:#1f6f5a;
  --noticew-bg:var(--warning-soft); --noticew-border:rgba(167,99,0,.24);   --noticew-txt:#8a5200;
  --modal-backdrop:rgba(20,23,28,.32);

  /* ===== Aliases legacy (mapean a la nueva paleta · no romper CSS) ===== */
  --bg-2:var(--surface-muted);
  --card:var(--surface);
  --line:var(--border);
  --line-2:var(--border);
  --txt:var(--text);
  --txt-soft:var(--text-secondary);
  --txt-mute:var(--text-muted);
  --gris:var(--text-secondary);
  --azul-osc:var(--text);
  --surface-2:var(--surface-muted);
  --ok:var(--success);
  --info:var(--accent);
  --warn:var(--warning);
  --sh-sm:var(--shadow-soft);
  --sh:var(--shadow-soft);
  --sh-md:var(--shadow-card);
  --sh-lg:var(--shadow-hover);

  /* ===== Radios / medidas ===== */
  --r-sm:10px;
  --r:14px;
  --r-lg:22px;
  --sidebar-w:248px;
  --topbar-h:64px;
  --grad-brand:linear-gradient(135deg,var(--verde),var(--celeste) 55%,var(--azul));
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Poppins',system-ui,sans-serif;
  background:var(--bg);
  color:var(--txt);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
a{color:var(--celeste);text-decoration:none}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--scroll-thumb);border-radius:20px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#b8c4d2}

/* =================== LAYOUT =================== */
.app{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}

/* =================== SIDEBAR =================== */
.sidebar{
  width:var(--sidebar-w);flex:0 0 var(--sidebar-w);
  background:var(--side-bg);
  color:var(--side-txt);
  border-right:1px solid var(--side-border);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;z-index:60;
}
.sidebar__brand{
  display:flex;align-items:center;gap:11px;
  padding:18px 18px 16px;border-bottom:1px solid var(--side-border);
}
.brand__logo{
  width:38px;height:38px;border-radius:11px;background:var(--grad-brand);
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:20px;
  box-shadow:0 6px 16px rgba(55,186,152,.35);
}
.brand__txt{display:flex;flex-direction:column;line-height:1.15}
.brand__txt strong{color:var(--side-brand);font-size:15px;letter-spacing:.3px}
.brand__txt span{font-size:10.5px;color:var(--side-brandsub);letter-spacing:.5px;text-transform:uppercase}
.sidebar__close{display:none;margin-left:auto;background:none;border:none;color:var(--side-txt);font-size:26px;line-height:1}

.nav{flex:1;overflow-y:auto;padding:12px 10px}
.nav__group{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--side-group);padding:14px 12px 6px;font-weight:600}
.nav__item{
  display:flex;align-items:center;gap:11px;
  padding:9px 12px;border-radius:10px;color:var(--side-txt);
  border:1px solid transparent;
  font-size:13px;font-weight:500;cursor:pointer;margin-bottom:2px;
  transition:background .15s,color .15s,border-color .15s;position:relative;
}
.nav__item:hover{background:var(--side-hover-bg);color:var(--side-txt-hover)}
.nav__item.is-active{background:var(--side-active-bg);color:var(--side-active-txt);border-color:var(--side-active-border)}
.nav__item .ico{width:18px;text-align:center;font-size:15px;flex:0 0 18px}
.nav__item .badge-count{
  margin-left:auto;background:var(--side-count-bg);color:var(--side-count-txt);
  font-size:10.5px;font-weight:600;border-radius:20px;padding:1px 7px;
}
.nav__item.is-active .badge-count{background:var(--side-active-border)}

.sidebar__foot{padding:12px 12px 16px;border-top:1px solid var(--side-border)}
.sidebar__ver{text-align:center;font-size:10px;color:var(--side-group);margin-top:9px;letter-spacing:.5px}

/* =================== TOPBAR =================== */
.topbar{
  height:var(--topbar-h);background:var(--topbar-bg);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--topbar-border);
  display:flex;align-items:center;gap:14px;padding:0 18px;
  position:sticky;top:0;z-index:40;
}
.topbar__menu{display:none;background:none;border:none;font-size:22px;color:var(--gris)}
.topbar__actions{margin-left:auto;display:flex;align-items:center;gap:8px}

/* store picker */
.storepick{position:relative}
.storepick__label{display:block;font-size:9.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--txt-mute);margin-bottom:1px;font-weight:600}
.storepick__btn{
  display:flex;align-items:center;gap:8px;background:var(--bg);
  border:1px solid var(--line);border-radius:10px;padding:6px 11px;
  font-size:13px;font-weight:600;color:var(--azul-osc);transition:.15s;
  white-space:nowrap;
}
#storeName{display:inline-block;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;vertical-align:middle}
.storepick__btn:hover{border-color:var(--accent)}
.storepick__dot{width:9px;height:9px;border-radius:50%;background:var(--txt-mute);flex:0 0 9px}
.storepick__caret{color:var(--txt-mute);font-size:11px}
.storepick__menu{
  position:absolute;top:calc(100% + 7px);left:0;min-width:240px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-md);
  padding:6px;z-index:50;display:none;
}
.storepick__menu.is-open{display:block;animation:pop .14s ease}
.storepick__opt{display:flex;align-items:center;gap:9px;padding:9px 11px;border-radius:9px;cursor:pointer;font-size:13px;font-weight:500}
.storepick__opt:hover{background:var(--bg)}
.storepick__opt.is-sel{background:var(--bg-2);font-weight:600}
.storepick__opt .dot{width:9px;height:9px;border-radius:50%;flex:0 0 9px}
.storepick__opt small{margin-left:auto;color:var(--txt-mute);font-size:11px}

/* search */
.search{position:relative;flex:1;max-width:380px}
.search__ico{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--txt-mute);font-size:16px}
.search input{
  width:100%;padding:9px 12px 9px 36px;border:1px solid var(--line);
  border-radius:10px;background:var(--bg);font-size:13px;color:var(--txt);transition:.15s;
}
.search input:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px var(--accent-soft)}
.search__results{
  position:absolute;top:calc(100% + 7px);left:0;right:0;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-md);
  padding:6px;z-index:50;display:none;max-height:360px;overflow:auto;
}
.search__results.is-open{display:block}
.search__res{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;cursor:pointer;font-size:13px}
.search__res:hover{background:var(--bg)}
.search__res small{color:var(--txt-mute);margin-left:auto}
.search__empty{padding:14px;text-align:center;color:var(--txt-mute);font-size:12.5px}

/* user chip */
.user{display:flex;align-items:center;gap:9px;padding-left:6px;border-left:1px solid var(--line);margin-left:4px}
.user__avatar{width:34px;height:34px;border-radius:50%;background:var(--grad-brand);color:#fff;display:grid;place-items:center;font-weight:700}
.user__meta{display:flex;flex-direction:column;line-height:1.2}
.user__meta strong{font-size:13px}
.user__meta span{font-size:10.5px;color:var(--txt-mute)}

/* =================== BOTONES =================== */
.btn{
  display:inline-flex;align-items:center;gap:7px;justify-content:center;
  border:1px solid transparent;border-radius:10px;padding:8px 14px;
  font-size:12.5px;font-weight:600;background:var(--bg);color:var(--gris);transition:.15s;white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn--primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-soft)}
.btn--primary:hover{background:var(--primary-hover);box-shadow:var(--shadow-card)}
.btn--ghost{background:var(--surface);border-color:var(--line);color:var(--gris)}
.btn--ghost:hover{border-color:var(--accent);color:var(--azul-osc)}
.btn--soft{background:var(--bg);color:var(--azul-osc)}
.btn--danger{background:var(--danger-soft);color:var(--danger);border-color:transparent}
.btn--danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn--sm{padding:5px 10px;font-size:11.5px;border-radius:8px}
.btn--xs{padding:3px 8px;font-size:11px;border-radius:7px}
.btn--block{width:100%}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}
.btn--icon{padding:6px 9px}

/* =================== VIEW / CONTENIDO =================== */
.view{padding:24px 26px 60px;flex:1;min-width:0;animation:fade .25s ease}
.page-head{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;margin-bottom:20px}
.page-head h1{font-size:23px;font-weight:700;color:var(--azul-osc);margin:0;letter-spacing:-.3px}
.page-head p{color:var(--txt-soft);font-size:13px;margin:3px 0 0}
.page-head__actions{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.crumb{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--celeste);font-weight:600;margin-bottom:4px}

/* =================== CARDS / KPIs =================== */
.grid{display:grid;gap:16px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;margin-bottom:20px}
.kpi{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r);
  padding:16px 17px;box-shadow:var(--sh-sm);position:relative;overflow:hidden;transition:.18s;
}
.kpi:hover{box-shadow:var(--sh);transform:translateY(-2px)}
.kpi::after{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent,var(--celeste))}
.kpi__ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;font-size:18px;background:var(--accent-bg,#eef6f3);color:var(--accent,var(--verde));margin-bottom:11px}
.kpi__val{font-size:26px;font-weight:700;color:var(--azul-osc);line-height:1}
.kpi__lbl{font-size:12px;color:var(--txt-soft);margin-top:4px}
.kpi__delta{font-size:11px;font-weight:600;margin-top:6px;display:inline-flex;gap:4px;align-items:center}
.kpi__delta.up{color:var(--ok)} .kpi__delta.down{color:var(--danger)}

.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);overflow:hidden}
.panel__head{display:flex;align-items:center;gap:10px;padding:14px 17px;border-bottom:1px solid var(--line-2)}
.panel__head h3{margin:0;font-size:14.5px;color:var(--azul-osc);font-weight:600}
.panel__head .sub{font-size:11.5px;color:var(--txt-mute)}
.panel__head .right{margin-left:auto;display:flex;gap:7px;align-items:center}
.panel__body{padding:16px 17px}
.panel__body.flush{padding:0}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.col-2-1{display:grid;grid-template-columns:2fr 1fr;gap:16px}

/* =================== TOOLBAR / FILTROS =================== */
.toolbar{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:16px}
.toolbar .grow{flex:1}
.field-search{position:relative;min-width:200px;flex:1;max-width:320px}
.field-search input{width:100%;padding:8px 12px 8px 32px;border:1px solid var(--line);border-radius:9px;background:var(--surface);font-size:12.5px}
.field-search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.field-search .ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--txt-mute)}
select.input,.select{
  border:1px solid var(--line);border-radius:9px;padding:8px 11px;background:var(--surface);font-size:12.5px;color:var(--txt);
  cursor:pointer;min-width:120px;
}
select.input:focus{outline:none;border-color:var(--accent)}

/* =================== TABLAS =================== */
.tablewrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl thead th{
  text-align:left;padding:11px 14px;font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;
  color:var(--txt-mute);font-weight:600;border-bottom:1px solid var(--line);background:var(--surface-2);white-space:nowrap;
}
.tbl tbody td{padding:11px 14px;border-bottom:1px solid var(--line-2);vertical-align:middle;color:var(--txt)}
.tbl tbody tr:hover{background:var(--surface-hover)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}
.tbl .actions{display:flex;gap:5px;justify-content:flex-end}
.tbl .check{width:34px}
.cell-main{display:flex;align-items:center;gap:10px}
.thumb{width:38px;height:38px;border-radius:9px;object-fit:cover;background:var(--bg-2);flex:0 0 38px;border:1px solid var(--line)}
.thumb--ph{display:grid;place-items:center;color:var(--txt-mute);font-size:16px}
.cell-main b{font-weight:600;color:var(--azul-osc);display:block;line-height:1.25}
.cell-main small{color:var(--txt-mute);font-size:11px}

/* =================== BADGES =================== */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:20px;line-height:1.5;white-space:nowrap}
.badge .dot{width:6px;height:6px;border-radius:50%}
.badge--ok{background:#e6f7f1;color:#1f8f72}
.badge--info{background:#e7f2f8;color:#246f8e}
.badge--warn{background:#fbf2dd;color:#a9791a}
.badge--danger{background:#fbe9e9;color:#c23b3b}
.badge--mute{background:#eef1f5;color:#76838f}
.badge--purple{background:#efeaf9;color:#6b4caa}
.badge-tienda{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:600;padding:2px 9px;border-radius:20px;background:var(--bg-2);color:var(--azul-osc)}
.badge-tienda .dot{width:7px;height:7px;border-radius:50%}

/* =================== FORMS =================== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid.one{grid-template-columns:1fr}
.form-grid.three{grid-template-columns:1fr 1fr 1fr}
.fld{display:flex;flex-direction:column;gap:5px}
.fld.col-span-2{grid-column:span 2}
.fld.col-span-full{grid-column:1 / -1}
.fld > label{font-size:11.5px;font-weight:600;color:var(--gris);display:flex;align-items:center;gap:6px}
.fld > label .hint{font-weight:400;color:var(--txt-mute);font-size:10.5px}
.fld input[type=text],.fld input[type=number],.fld input[type=date],.fld input[type=email],.fld input[type=url],.fld select,.fld textarea{
  border:1px solid var(--line);border-radius:9px;padding:9px 11px;font-size:13px;background:var(--surface);color:var(--txt);width:100%;transition:.15s;
}
.fld textarea{resize:vertical;min-height:74px}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.fld .help{font-size:10.5px;color:var(--txt-mute)}
.section-title{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--celeste);font-weight:700;margin:18px 0 4px;grid-column:1/-1;display:flex;align-items:center;gap:8px}
.section-title::after{content:'';flex:1;height:1px;background:var(--line)}

/* switch */
.switch{display:inline-flex;align-items:center;gap:8px;cursor:pointer;font-size:12.5px;color:var(--gris);font-weight:500}
.switch input{display:none}
.switch .track{width:38px;height:21px;background:var(--switch-track);border-radius:20px;position:relative;transition:.18s;flex:0 0 38px}
.switch .track::after{content:'';position:absolute;width:15px;height:15px;border-radius:50%;background:var(--switch-knob);top:3px;left:3px;transition:.18s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.switch input:checked + .track{background:var(--verde)}
.switch input:checked + .track::after{left:20px}
.switch-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px 16px}

/* color input */
.fld input[type=color]{width:46px;height:34px;border:1px solid var(--line);border-radius:8px;padding:2px;background:var(--surface);cursor:pointer}

/* dropzone / imágenes */
.dropzone{
  border:2px dashed var(--dash-border);border-radius:var(--r);padding:22px;text-align:center;color:var(--txt-mute);
  background:var(--bg);transition:.15s;cursor:pointer;
}
.dropzone:hover{border-color:var(--accent);background:var(--surface)}
.dropzone .big{font-size:30px;margin-bottom:6px}
.img-preview-row{display:flex;gap:9px;flex-wrap:wrap;margin-top:10px}
.img-chip{position:relative;width:74px;height:74px;border-radius:10px;overflow:hidden;border:1px solid var(--line);background:var(--bg-2)}
.img-chip img{width:100%;height:100%;object-fit:cover}
.img-chip .x{position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;background:rgba(25,61,83,.78);color:#fff;border:none;font-size:13px;line-height:1;display:grid;place-items:center}
.img-chip__ph{display:grid;place-items:center;height:100%;color:var(--txt-mute);font-size:11px;text-align:center;padding:4px}

/* =================== MODAL =================== */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:flex-start;justify-content:center}
.modal.is-open{display:flex}
.modal__backdrop{position:absolute;inset:0;background:var(--modal-backdrop);backdrop-filter:blur(3px);animation:fade .18s}
.modal__panel{
  position:relative;background:var(--surface);border-radius:var(--r-lg);width:min(720px,94vw);
  margin:5vh auto;box-shadow:var(--sh-lg);max-height:90vh;display:flex;flex-direction:column;animation:slideUp .22s ease;
}
.modal__panel.wide{width:min(960px,96vw)}
.modal__panel.full{width:min(1180px,97vw)}
.modal__head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line-2)}
.modal__head h3{margin:0;font-size:17px;color:var(--azul-osc);font-weight:700}
.modal__x{margin-left:auto;background:var(--bg);border:none;width:32px;height:32px;border-radius:9px;font-size:20px;color:var(--gris);line-height:1}
.modal__x:hover{background:var(--surface-hover)}
.modal__body{padding:22px;overflow-y:auto}
.modal__foot{display:flex;gap:9px;justify-content:flex-end;padding:15px 22px;border-top:1px solid var(--line-2);background:var(--surface-2);border-radius:0 0 var(--r-lg) var(--r-lg);flex-wrap:wrap}
.modal__foot .left{margin-right:auto}

.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:18px;flex-wrap:wrap}
.tab{padding:8px 14px;font-size:12.5px;font-weight:600;color:var(--txt-soft);border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px}
.tab.is-active{color:var(--azul);border-bottom-color:var(--azul)}
.tab-pane{display:none}.tab-pane.is-active{display:block;animation:fade .2s}

/* =================== TOASTS =================== */
.toasts{position:fixed;right:18px;bottom:18px;z-index:300;display:flex;flex-direction:column;gap:9px;max-width:340px}
.toast{
  background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--info);border-radius:12px;
  box-shadow:var(--sh-md);padding:12px 14px;display:flex;gap:10px;align-items:flex-start;animation:slideIn .22s ease;
}
.toast.is-out{animation:slideOut .25s ease forwards}
.toast--ok{border-left-color:var(--ok)} .toast--warn{border-left-color:var(--warn)} .toast--danger{border-left-color:var(--danger)}
.toast__ico{font-size:17px;line-height:1.2}
.toast__txt{font-size:12.5px;color:var(--txt)} .toast__txt b{display:block;color:var(--azul-osc);margin-bottom:1px}

/* =================== MISC =================== */
.empty{text-align:center;padding:48px 20px;color:var(--txt-mute)}
.empty .big{font-size:42px;margin-bottom:10px;opacity:.5}
.empty h4{color:var(--gris);margin:0 0 4px;font-size:15px}
.empty p{margin:0 0 14px;font-size:13px}
.divider{height:1px;background:var(--line);margin:16px 0}
.muted{color:var(--txt-mute)}
.tag{display:inline-block;background:var(--bg-2);color:var(--azul-osc);font-size:11px;padding:2px 8px;border-radius:7px;font-weight:500;margin:2px}
.pill-row{display:flex;gap:6px;flex-wrap:wrap}
.money{font-variant-numeric:tabular-nums;font-weight:600;color:var(--azul-osc)}
.hr-soft{border:none;border-top:1px solid var(--line-2);margin:14px 0}
.notice{background:var(--notice-bg);border:1px solid var(--notice-border);border-radius:12px;padding:12px 14px;font-size:12.5px;color:var(--notice-txt);display:flex;gap:9px;align-items:flex-start}
.notice--warn{background:var(--noticew-bg);border-color:var(--noticew-border);color:var(--noticew-txt)}
.notice .ico{font-size:16px}

/* progress / firebase sim */
.prog{height:7px;background:var(--bg-2);border-radius:20px;overflow:hidden}
.prog__bar{height:100%;background:var(--grad-brand);width:0;transition:width .3s}

/* tracking de pedido */
.track{display:flex;flex-direction:column;gap:0;padding:6px 0}
.track__step{display:flex;gap:13px;position:relative;padding-bottom:18px}
.track__step:last-child{padding-bottom:0}
.track__step::before{content:'';position:absolute;left:11px;top:24px;bottom:-2px;width:2px;background:var(--line)}
.track__step:last-child::before{display:none}
.track__dot{width:24px;height:24px;border-radius:50%;background:var(--bg-2);border:2px solid var(--line);display:grid;place-items:center;font-size:11px;color:var(--txt-mute);flex:0 0 24px;z-index:1}
.track__step.done .track__dot{background:var(--verde);border-color:var(--verde);color:#fff}
.track__step.done::before{background:var(--verde)}
.track__step.current .track__dot{background:var(--surface);border-color:var(--azul);color:var(--azul);box-shadow:0 0 0 4px rgba(55,89,183,.15)}
.track__txt b{display:block;font-size:13px;color:var(--azul-osc)}
.track__txt small{color:var(--txt-mute);font-size:11px}

/* integraciones cards */
.intg{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.intg__card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh-sm)}
.intg__top{display:flex;align-items:center;gap:11px;margin-bottom:10px}
.intg__logo{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;font-size:22px;background:var(--bg)}
.intg__card h4{margin:0;font-size:14.5px;color:var(--azul-osc)}
.intg__card p{font-size:12px;color:var(--txt-soft);margin:0 0 12px;min-height:34px}

/* variantes / lista */
.var-row td{font-size:12px}
.mini-input{border:1px solid var(--line);border-radius:7px;padding:5px 8px;font-size:12px;width:100%;background:var(--surface)}
.mini-input:focus{outline:none;border-color:var(--accent)}
.inline-edit{border:1px solid transparent;border-radius:6px;padding:4px 7px;font-size:12.5px;background:transparent;width:100%;text-align:right;font-variant-numeric:tabular-nums}
.inline-edit:hover{background:var(--surface);border-color:var(--line)}
.inline-edit:focus{outline:none;background:var(--surface);border-color:var(--accent)}

.bulk-bar{display:flex;align-items:center;gap:10px;background:var(--bar-bg);color:#fff;border-radius:12px;padding:9px 14px;margin-bottom:14px;font-size:12.5px;animation:slideUp .2s}
.bulk-bar b{color:#fff} .bulk-bar .btn{background:rgba(255,255,255,.12);color:#fff;border:none}
.bulk-bar .btn:hover{background:rgba(255,255,255,.22)}
.bulk-bar .x{margin-left:auto;background:none;border:none;color:#9fc0d2;font-size:18px}

/* =================== ANIMACIONES =================== */
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:none}}
@keyframes slideUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes slideIn{from{opacity:0;transform:translateX(30px)}to{opacity:1;transform:none}}
@keyframes slideOut{to{opacity:0;transform:translateX(30px)}}

/* =================== RESPONSIVE =================== */
.sidebar__backdrop{display:none}
@media(max-width:1024px){
  .two-col,.col-2-1{grid-template-columns:1fr}
  .three-col{grid-template-columns:1fr 1fr}
  .search{max-width:none}
}
@media(max-width:860px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:transform .25s ease;box-shadow:var(--sh-lg)}
  .sidebar.is-open{transform:none}
  .sidebar__close{display:block}
  .sidebar__backdrop.is-open{display:block;position:fixed;inset:0;background:rgba(25,61,83,.4);z-index:55}
  .topbar__menu{display:block}
  .topbar{padding:0 12px}
  #btnPreview,#btnExport,#btnImport,#btnDensity,#btnFocus{display:none}
  .moremenu{display:block}
  .user__meta{display:none}
  .storepick__label{display:none}
  .search{display:none}
}
@media(max-width:560px){
  .view{padding:16px 14px 60px}
  .three-col{grid-template-columns:1fr}
  .form-grid,.form-grid.three{grid-template-columns:1fr}
  .fld.col-span-2{grid-column:auto}
  .page-head h1{font-size:20px}
  .modal__panel{margin:0;border-radius:0;width:100vw;max-height:100vh;height:100vh}
}

/* =====================================================================
   TEMAS VISUALES  ·  body.theme-light | theme-dark | theme-sepia
   ===================================================================== */
body{transition:background .25s ease,color .25s ease}

/* ---- DARK: oscuro elegante, acentos ALLSTOCK, sin negros puros ---- */
body.theme-dark{
  --bg:#0f1419;
  --bg-soft:#11161d;
  --surface:#151b23;
  --surface-elevated:#181f28;
  --surface-muted:#202936;
  --surface-hover:#1d2530;

  --text:#f5f7fa;
  --text-secondary:#c8d0da;
  --text-muted:#8f9baa;
  --text-disabled:#667080;

  --border:rgba(255,255,255,.08);
  --border-strong:rgba(255,255,255,.13);

  --primary:#37ba98;
  --primary-hover:#42c9a6;
  --primary-soft:rgba(55,186,152,.14);
  --accent:#3790b7;
  --accent-hover:#49a6cd;
  --accent-soft:rgba(55,144,183,.16);
  --success:#37ba98;
  --success-soft:rgba(55,186,152,.16);
  --warning:#ffb454;
  --warning-soft:rgba(255,180,84,.14);
  --danger:#ff6b64;
  --danger-soft:rgba(255,107,100,.14);

  --shadow-soft:0 10px 30px rgba(0,0,0,.28);
  --shadow-card:0 16px 42px rgba(0,0,0,.32);
  --shadow-hover:0 20px 60px rgba(0,0,0,.42);

  --side-bg:rgba(17,22,29,.92);
  --side-border:rgba(255,255,255,.08);
  --side-txt:#c8d0da;
  --side-txt-hover:#f5f7fa;
  --side-hover-bg:rgba(255,255,255,.05);
  --side-active-bg:rgba(55,186,152,.14);
  --side-active-txt:#ffffff;
  --side-active-border:rgba(55,186,152,.24);
  --side-group:#6c7785;
  --side-brand:#f5f7fa;
  --side-brandsub:#8f9baa;
  --side-count-bg:rgba(255,255,255,.10);
  --side-count-txt:#c8d0da;

  --topbar-bg:rgba(17,22,29,.86);
  --topbar-border:rgba(255,255,255,.08);

  --bar-bg:#1d2530;
  --scroll-thumb:#2c3744;
  --switch-track:#2c3744; --switch-knob:#e8edf2;
  --dash-border:rgba(255,255,255,.14);
  --notice-bg:rgba(55,144,183,.12); --notice-border:rgba(55,144,183,.30); --notice-txt:#8fc8e6;
  --noticew-bg:rgba(255,180,84,.10); --noticew-border:rgba(255,180,84,.28); --noticew-txt:#ffce8a;
  --modal-backdrop:rgba(0,0,0,.55);
}
body.theme-dark ::-webkit-scrollbar-thumb{border-color:var(--bg)}
body.theme-dark .badge--ok{background:#15352b;color:#5fd3ad}
body.theme-dark .badge--info{background:#13313f;color:#6cc0e2}
body.theme-dark .badge--warn{background:#352c12;color:#e0b352}
body.theme-dark .badge--danger{background:#3a1d1d;color:#ef8a8a}
body.theme-dark .badge--mute{background:#27313d;color:#9aa8b4}
body.theme-dark .badge--purple{background:#2a2440;color:#b29ae0}
body.theme-dark .btn--danger{background:#3a1d1d;color:#ef8a8a;border-color:#562b2b}

/* ---- LIGHT SEPIA: papel cálido, cómodo para leer horas ---- */
body.theme-sepia{
  --bg:#f4efe7;
  --bg-soft:#f7f2ea;
  --surface:#fffaf3;
  --surface-elevated:#fffdf8;
  --surface-muted:#ebe2d5;
  --surface-hover:#f0e8dc;

  --text:#2b2520;
  --text-secondary:#5a5047;
  --text-muted:#7a6d61;
  --text-disabled:#a99d91;

  --border:#e2d7c8;
  --border-strong:#d4c5b2;

  --primary:#193d53;
  --primary-hover:#24536d;
  --primary-soft:rgba(25,61,83,.10);
  --accent:#37ba98;
  --accent-hover:#2fa886;
  --accent-soft:rgba(55,186,152,.13);
  --success:#2f8f73;
  --success-soft:rgba(55,186,152,.14);
  --warning:#9a6400;
  --warning-soft:rgba(190,128,24,.14);
  --danger:#a33a2f;
  --danger-soft:rgba(190,70,60,.12);

  --shadow-soft:0 8px 24px rgba(70,45,20,.07);
  --shadow-card:0 12px 32px rgba(70,45,20,.08);
  --shadow-hover:0 16px 40px rgba(70,45,20,.12);

  --side-bg:rgba(255,250,243,.86);
  --side-border:#e2d7c8;
  --side-txt:#6a5d4f;
  --side-txt-hover:#2b2520;
  --side-hover-bg:rgba(120,90,50,.07);
  --side-active-bg:rgba(55,186,152,.13);
  --side-active-txt:#193d53;
  --side-active-border:rgba(55,186,152,.24);
  --side-group:#a99884;
  --side-brand:#2b2520;
  --side-brandsub:#7a6d61;
  --side-count-bg:#ebe2d5;
  --side-count-txt:#5a5047;

  --topbar-bg:rgba(255,250,243,.84);
  --topbar-border:#e2d7c8;

  --bar-bg:var(--primary);
  --scroll-thumb:#cbb391;
  --switch-track:#d8c8a6; --switch-knob:#fffdf8;
  --dash-border:#d4c5b2;
  --notice-bg:rgba(55,186,152,.13); --notice-border:rgba(55,186,152,.26); --notice-txt:#2f7a63;
  --noticew-bg:rgba(190,128,24,.12); --noticew-border:rgba(190,128,24,.26); --noticew-txt:#7a5410;
  --modal-backdrop:rgba(70,45,20,.32);
}
body.theme-sepia .badge--info{background:#e7ddc5;color:#5a6f80}
body.theme-sepia .badge--mute{background:#e7ddc5;color:#7a6e57}

/* =====================================================================
   SELECTOR DE TEMA (topbar)
   ===================================================================== */
.themepick{position:relative}
.themepick__btn{
  display:flex;align-items:center;gap:7px;background:var(--bg);
  border:1px solid var(--line);border-radius:10px;padding:7px 11px;
  font-size:12.5px;font-weight:600;color:var(--gris);transition:.15s;
}
.themepick__btn:hover{border-color:var(--accent);color:var(--azul-osc)}
.themepick__btn .tg-ico{font-size:15px}
.themepick__menu{
  position:absolute;top:calc(100% + 7px);right:0;min-width:170px;background:var(--surface);
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-md);padding:6px;z-index:50;display:none;
}
.themepick__menu.is-open{display:block;animation:pop .14s ease}
.themepick__opt{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:9px;cursor:pointer;font-size:13px;font-weight:500;color:var(--txt)}
.themepick__opt:hover{background:var(--bg)}
.themepick__opt.is-sel{background:var(--bg-2);font-weight:600}
.themepick__opt .sw{width:16px;height:16px;border-radius:5px;border:1px solid var(--line);flex:0 0 16px}

/* botón Tutorial en page-head */
.btn-tut{display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--line);color:var(--celeste);border-radius:10px;padding:8px 13px;font-size:12.5px;font-weight:600;transition:.15s}
.btn-tut:hover{border-color:var(--accent);transform:translateY(-1px)}

/* =====================================================================
   TUTORIALES (panel/modal)
   ===================================================================== */
.tut{display:flex;flex-direction:column;gap:12px}
.tut__lead{font-size:13px;color:var(--txt-soft);line-height:1.6;margin:0}
.tut__block{border:1px solid var(--line);border-radius:14px;padding:14px 16px;background:var(--surface-2)}
.tut__block h4{margin:0 0 6px;font-size:13px;color:var(--azul-osc);display:flex;align-items:center;gap:8px}
.tut__block h4 .i{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;background:var(--accent-bg,#eef6f3);color:var(--verde);font-size:14px;flex:0 0 26px}
.tut__block p,.tut__block li{font-size:12.5px;color:var(--txt);line-height:1.6;margin:0}
.tut__block ul{margin:4px 0 0;padding-left:18px;display:flex;flex-direction:column;gap:3px}
.tut__ex{border-left:3px solid var(--verde);background:var(--bg-2);border-radius:0 10px 10px 0;padding:10px 13px;font-size:12.5px;color:var(--txt)}
.tut__ex b{color:var(--azul-osc)}
.tut__warn{border-left:3px solid var(--warn);background:var(--noticew-bg);color:var(--noticew-txt);border-radius:0 10px 10px 0;padding:10px 13px;font-size:12.5px}

/* =====================================================================
   WIKI / AYUDA
   ===================================================================== */
.wiki{display:grid;grid-template-columns:260px 1fr;gap:18px;align-items:start}
.wiki__side{position:sticky;top:84px;display:flex;flex-direction:column;gap:12px}
.wiki__search{position:relative}
.wiki__search input{width:100%;padding:9px 12px 9px 34px;border:1px solid var(--line);border-radius:10px;background:var(--surface);font-size:12.5px;color:var(--txt)}
.wiki__search input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.wiki__search .ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--txt-mute)}
.wiki__cats{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);padding:8px;display:flex;flex-direction:column;gap:2px;max-height:62vh;overflow:auto}
.wiki__cat{display:flex;align-items:center;gap:8px;padding:8px 11px;border-radius:9px;font-size:12.5px;color:var(--txt-soft);cursor:pointer;font-weight:500;transition:.12s}
.wiki__cat:hover{background:var(--bg)}
.wiki__cat.is-active{background:var(--primary);color:#fff;font-weight:600}
body.theme-dark .wiki__cat.is-active{color:#08140f}
.wiki__cat .n{margin-left:auto;font-size:10.5px;opacity:.8}
.wiki__main{min-width:0;display:flex;flex-direction:column;gap:14px}
.wiki__card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);padding:16px 18px;cursor:pointer;transition:.15s}
.wiki__card:hover{box-shadow:var(--sh);transform:translateY(-2px);border-color:var(--accent)}
.wiki__card h3{margin:0 0 4px;font-size:15px;color:var(--azul-osc)}
.wiki__card .cat{font-size:10.5px;text-transform:uppercase;letter-spacing:.6px;color:var(--celeste);font-weight:700}
.wiki__card p{margin:6px 0 0;font-size:12.5px;color:var(--txt-soft);line-height:1.6}
.wiki__article{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm);padding:22px 24px}
.wiki__article .cat{font-size:10.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--celeste);font-weight:700}
.wiki__article h2{margin:4px 0 14px;font-size:21px;color:var(--azul-osc);letter-spacing:-.3px}
.wiki__body{font-size:13px;color:var(--txt);line-height:1.7}
.wiki__body h4{margin:16px 0 6px;font-size:14px;color:var(--azul-osc)}
.wiki__body p{margin:0 0 10px}
.wiki__body ul,.wiki__body ol{margin:0 0 12px;padding-left:20px;display:flex;flex-direction:column;gap:5px}
.wiki__body code{background:var(--bg-2);padding:1px 6px;border-radius:6px;font-size:12px;color:var(--azul)}
.wiki__body .pill-row{margin:8px 0}
.wiki__actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px;padding-top:16px;border-top:1px solid var(--line-2)}
.wiki__empty{padding:40px;text-align:center;color:var(--txt-mute)}

/* =====================================================================
   TOUR INICIAL
   ===================================================================== */
.tour-dim{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:205;animation:fade .2s}
.tour-highlight{position:relative;z-index:210;outline:3px solid var(--verde);outline-offset:3px;border-radius:12px;box-shadow:0 0 0 9999px rgba(0,0,0,.5);transition:box-shadow .2s}
.tour{position:fixed;z-index:230;width:min(420px,92vw);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg);padding:20px 22px;animation:slideUp .22s ease}
.tour__step{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--celeste);font-weight:700}
.tour h3{margin:5px 0 8px;font-size:18px;color:var(--azul-osc)}
.tour p{margin:0;font-size:13px;color:var(--txt-soft);line-height:1.6}
.tour__dots{display:flex;gap:5px;margin:16px 0 14px}
.tour__dots i{width:7px;height:7px;border-radius:50%;background:var(--line);transition:.2s}
.tour__dots i.on{background:var(--verde);width:18px;border-radius:20px}
.tour__nav{display:flex;gap:8px;align-items:center}
.tour__nav .sp{flex:1}
.welcome{text-align:center;padding:8px 4px}
.welcome .em{font-size:46px;margin-bottom:6px}
.welcome h2{margin:0 0 6px;font-size:22px;color:var(--azul-osc)}
.welcome p{margin:0 auto 4px;font-size:13.5px;color:var(--txt-soft);max-width:420px;line-height:1.6}

/* ayuda contextual reforzada */
.fld .help{font-size:10.5px;color:var(--txt-mute);line-height:1.45}
.fld > label .hint{font-weight:400;color:var(--txt-mute);font-size:10.5px}

@media(max-width:860px){
  .wiki{grid-template-columns:1fr}
  .wiki__side{position:static}
  .wiki__cats{flex-direction:row;flex-wrap:wrap;max-height:none}
  .themepick__btn span.tg-name{display:none}
  .tour{left:50%!important;top:auto!important;bottom:16px;transform:translateX(-50%)}
}

/* =====================================================================
   FASE UX 1 · densidad · modo enfoque · accesibilidad · skeletons · jerarquía
   ===================================================================== */

/* ---------- DENSIDAD ---------- */
/* "comfortable" = valores por defecto. "compact" = más datos por pantalla */
body.density-compact{ font-size:13px; }
body.density-compact .view{ padding:16px 18px 48px; }
body.density-compact .page-head{ margin-bottom:14px; }
body.density-compact .cards{ gap:10px; grid-template-columns:repeat(auto-fill,minmax(185px,1fr)); margin-bottom:14px; }
body.density-compact .kpi{ padding:11px 13px; }
body.density-compact .kpi__val{ font-size:21px; }
body.density-compact .kpi__ico{ width:32px;height:32px;margin-bottom:7px;font-size:15px; }
body.density-compact .panel__head{ padding:10px 13px; }
body.density-compact .panel__body{ padding:11px 13px; }
body.density-compact .tbl thead th{ padding:7px 11px; }
body.density-compact .tbl tbody td{ padding:7px 11px; }
body.density-compact .toolbar{ margin-bottom:11px; gap:7px; }
body.density-compact .fld input,body.density-compact .fld select,body.density-compact .fld textarea{ padding:7px 9px; font-size:12.5px; }
body.density-compact .form-grid{ gap:10px; }
body.density-compact .btn{ padding:6px 11px; }
body.density-compact .two-col,body.density-compact .three-col,body.density-compact .col-2-1,body.density-compact .grid{ gap:11px; }

/* ---------- MODO ENFOQUE ---------- */
body.focus-mode .sidebar{ display:none; }
body.focus-mode .sidebar__backdrop{ display:none!important; }
body.focus-mode .search{ display:none; }
body.focus-mode .topbar{ height:54px; }
body.focus-mode .view{ padding-top:18px; }
#btnFocus.is-active{ background:var(--primary); color:#fff; border-color:transparent; }
.focus-hint{ display:none; }
body.focus-mode .focus-hint{ display:inline-flex; align-items:center; gap:6px; font-size:11px; color:var(--txt-mute); }

/* ---------- ACCESIBILIDAD · focus visible · táctil ---------- */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,
.nav__item:focus-visible,.wiki__card:focus-visible,.storepick__opt:focus-visible,.themepick__opt:focus-visible{
  outline:2px solid var(--celeste); outline-offset:2px; border-radius:8px;
}
.nav__item:focus-visible{ outline-offset:-2px; }
@media(max-width:860px){
  .btn{ min-height:42px; }
  .btn--sm,.btn--xs{ min-height:36px; }
  .fld input,.fld select,.fld textarea{ min-height:42px; }
  .nav__item{ padding:12px; }
}

/* ---------- SKELETON LOADERS ---------- */
@keyframes shimmer{ 0%{background-position:100% 0} 100%{background-position:-100% 0} }
.skeleton{ background:linear-gradient(90deg,var(--surface-2) 25%,var(--surface-hover) 50%,var(--surface-2) 75%); background-size:200% 100%; animation:shimmer 1.3s ease-in-out infinite; border-radius:8px; }
.skel-line{ height:12px; margin:8px 0; }
.skel-block{ height:64px; border-radius:var(--r); }
.skel-row{ display:flex; gap:12px; align-items:center; padding:11px 14px; border-bottom:1px solid var(--line-2); }
.skel-row .skeleton{ height:14px; }
.skel-cards{ display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:14px; }

/* ---------- JERARQUÍA: breadcrumb + tienda activa ---------- */
.page-head__top{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; margin-bottom:5px; }
.breadcrumb{ display:flex; align-items:center; gap:6px; font-size:11px; text-transform:uppercase; letter-spacing:.7px; color:var(--txt-mute); font-weight:600; }
.breadcrumb b{ color:var(--celeste); }
.breadcrumb .sep{ opacity:.5; }
.store-active{ display:inline-flex; align-items:center; gap:7px; font-size:11.5px; color:var(--txt-soft); margin-top:4px; }
.store-active .lbl{ color:var(--txt-mute); }

/* ---------- transiciones suaves globales ---------- */
.btn,.kpi,.panel,.wiki__card,.nav__item,.intg__card,.storepick__btn,.themepick__btn,.btn-tut{ transition:background .15s,border-color .15s,box-shadow .18s,transform .15s,color .15s; }
.tab{ transition:color .15s,border-color .15s; }

/* =====================================================================
   REFINAMIENTOS PREMIUM (radios, sombras, badges, modal, glass)
   ===================================================================== */
/* radios más generosos tipo Apple/Linear */
.kpi,.panel,.intg__card,.wiki__card,.wiki__cats,.wiki__article{ border-radius:18px; }
.modal__panel{ border-radius:22px; border:1px solid var(--border); }
.modal__backdrop{ backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); }
.fld input,.fld select,.fld textarea,.search input,.field-search input,select.input,.select,.storepick__btn,.themepick__btn,.btn{ border-radius:12px; }
.kpi__ico{ border-radius:13px; }

/* botones secundarios consistentes */
.btn--ghost:hover{ background:var(--surface-hover); }

/* badges soft con borde sutil (no saturados) — light */
.badge{ border:1px solid transparent; }
.badge--ok{ background:var(--success-soft); color:var(--success); border-color:rgba(55,186,152,.22); }
.badge--info{ background:var(--accent-soft); color:var(--accent); border-color:rgba(55,144,183,.20); }
.badge--warn{ background:var(--warning-soft); color:var(--warning); border-color:rgba(167,99,0,.20); }
.badge--danger{ background:var(--danger-soft); color:var(--danger); border-color:rgba(180,35,24,.18); }
.badge--mute{ background:var(--surface-muted); color:var(--text-muted); border-color:var(--border); }
.badge-tienda{ border:1px solid var(--border); }

/* dark: texto oscuro sobre el verde brillante del primario + badges/toast premium */
body.theme-dark .btn--primary{ color:#08140f; }
body.theme-dark .badge--ok{ background:var(--success-soft); color:#54d0ab; border-color:rgba(55,186,152,.30); }
body.theme-dark .badge--info{ background:var(--accent-soft); color:#74c2e6; border-color:rgba(55,144,183,.32); }
body.theme-dark .badge--warn{ background:var(--warning-soft); color:#ffce8a; border-color:rgba(255,180,84,.30); }
body.theme-dark .badge--danger{ background:var(--danger-soft); color:#ff938d; border-color:rgba(255,107,100,.30); }
body.theme-dark .badge--mute{ background:var(--surface-muted); color:#aab4c0; border-color:var(--border-strong); }
body.theme-dark .toast{ background:var(--surface-elevated); }
body.theme-dark .btn--danger{ background:var(--danger-soft); color:#ff938d; border-color:transparent; }

/* sepia: badges cálidos legibles */
body.theme-sepia .badge--info{ background:var(--accent-soft); color:#2f8f73; border-color:rgba(55,186,152,.26); }
body.theme-sepia .badge--mute{ background:var(--surface-muted); color:#7a6d61; border-color:var(--border-strong); }

/* fondo general con micro-degradado sutil (apenas perceptible) */
body.theme-dark{ background:radial-gradient(circle at 15% -10%, rgba(55,186,152,.05), transparent 38%), radial-gradient(circle at 95% -5%, rgba(55,89,183,.045), transparent 34%), var(--bg); background-attachment:fixed; }

/* primario sólido también para la barra de selección masiva (sin degradado) */
.bulk-bar{ box-shadow:var(--shadow-soft); }

/* =====================================================================
   FASE 2 · TABLAS PROFESIONALES (TablePro · progressive enhancement)
   ===================================================================== */
/* (sin sticky header: position:sticky dentro de .tablewrap{overflow} hacía que
   la 1ª fila se viera cortada/encimada sobre el encabezado · ver capturas) */
.tbl[data-tablepro] thead th{ position:static; }

/* columnas ordenables */
.tbl th.tp-sortable{ cursor:pointer; user-select:none; white-space:nowrap; transition:color .12s; }
.tbl th.tp-sortable:hover{ color:var(--text-secondary); }
.tbl th .tp-arrow{ display:inline-block; margin-left:5px; font-size:8px; opacity:0; transition:opacity .15s; vertical-align:middle; }
.tbl th.tp-asc .tp-arrow, .tbl th.tp-desc .tp-arrow{ opacity:.85; color:var(--accent); }
.tbl th.tp-asc .tp-arrow::after{ content:'▲'; }
.tbl th.tp-desc .tp-arrow::after{ content:'▼'; }

/* columna oculta */
.tp-hidden{ display:none !important; }

/* barra superior de controles · franja integrada a la tabla */
.tablepro-bar{ display:flex; align-items:center; gap:8px; justify-content:flex-end; flex-wrap:wrap; padding:9px 16px; background:var(--surface); border-bottom:1px solid var(--line-2); }
.tablepro-bar .tp-count{ margin-right:auto; font-size:12px; color:var(--text-muted); font-weight:600; }
.tp-colbtn{ position:relative; }
.tp-colmenu{ position:absolute; right:0; top:calc(100% + 6px); background:var(--surface); border:1px solid var(--border); border-radius:14px; box-shadow:var(--shadow-card); padding:8px; z-index:30; display:none; min-width:200px; max-height:320px; overflow:auto; }
.tp-colmenu.is-open{ display:block; animation:pop .14s ease; }
.tp-colmenu .tp-coltitle{ font-size:10.5px; text-transform:uppercase; letter-spacing:.6px; color:var(--text-muted); padding:4px 9px 7px; font-weight:600; }
.tp-colmenu label{ display:flex; align-items:center; gap:9px; padding:7px 9px; border-radius:9px; font-size:12.5px; color:var(--text); cursor:pointer; }
.tp-colmenu label:hover{ background:var(--surface-hover); }
.tp-colmenu input{ accent-color:var(--accent); width:15px; height:15px; }

/* barra inferior de paginación · franja integrada */
.tablepro-foot{ display:flex; align-items:center; gap:12px; flex-wrap:wrap; padding:12px 16px; border-top:1px solid var(--line-2); font-size:12.5px; color:var(--text-muted); }
.tablepro-foot b{ color:var(--text-secondary); }
.tablepro-foot .tp-size{ border:1px solid var(--border); border-radius:9px; padding:5px 8px; font-size:12px; background:var(--surface); color:var(--text); cursor:pointer; }
.tp-pages{ display:flex; gap:4px; align-items:center; margin-left:auto; }
.tp-pg{ min-width:30px; height:30px; padding:0 9px; border:1px solid var(--border); background:var(--surface); border-radius:9px; font-size:12px; font-weight:600; color:var(--text-secondary); display:inline-flex; align-items:center; justify-content:center; cursor:pointer; transition:.12s; }
.tp-pg:hover:not([disabled]):not(.is-active){ border-color:var(--accent); color:var(--text); }
.tp-pg.is-active{ background:var(--primary); color:#fff; border-color:transparent; cursor:default; }
.tp-pg[disabled]{ opacity:.4; cursor:not-allowed; }
.tp-ellipsis{ color:var(--text-muted); padding:0 2px; }

/* ---- CARDS EN TABLET Y MOBILE (sólo tablas mejoradas) ---- */
@media(max-width:900px){
  .tablewrap{ overflow-x:visible; }
  .tbl[data-tablepro] thead{ display:none; }
  .tbl[data-tablepro], .tbl[data-tablepro] tbody{ display:block; width:100%; }
  .tbl[data-tablepro] tr{ display:block; border:1px solid var(--border); border-radius:16px; margin-bottom:11px; background:var(--surface); box-shadow:var(--shadow-soft); overflow:hidden; }
  .tbl[data-tablepro] td{ display:flex; justify-content:space-between; align-items:center; gap:14px; padding:11px 15px; border:none; border-bottom:1px solid var(--line-2); text-align:right; min-height:0; }
  .tbl[data-tablepro] tr td:last-child{ border-bottom:none; }
  .tbl[data-tablepro] td::before{ content:attr(data-label); font-weight:600; color:var(--text-muted); text-align:left; font-size:11px; text-transform:uppercase; letter-spacing:.4px; flex:0 0 auto; white-space:nowrap; }
  .tbl[data-tablepro] td.actions{ justify-content:flex-end; gap:6px; }
  .tbl[data-tablepro] td.actions::before, .tbl[data-tablepro] td.check::before{ content:''; }
  .tbl[data-tablepro] td.check{ justify-content:flex-start; }
  .tbl[data-tablepro] .cell-main{ justify-content:flex-end; text-align:right; }
  .tablepro-bar{ justify-content:space-between; }
  .tablepro-foot{ justify-content:center; }
  .tp-pages{ margin-left:0; }
}
/* tablet: cards en 2 columnas para aprovechar el ancho (mobile queda en 1 col) */
@media(min-width:769px) and (max-width:900px){
  .tbl[data-tablepro] tbody{ display:grid; grid-template-columns:1fr 1fr; gap:12px; padding:12px 14px; }
  .tbl[data-tablepro] tr{ margin-bottom:0; align-self:start; }
}

/* =====================================================================
   FIX dark/sepia · resolver los alias legacy DENTRO de cada tema
   (un var() declarado en :root se congela con el valor light; hay que
    re-declararlo en el scope del tema, donde --surface/--text ya valen)
   ===================================================================== */
body.theme-dark, body.theme-sepia{
  --bg-2:var(--surface-muted);
  --card:var(--surface);
  --line:var(--border);
  --line-2:var(--border);
  --txt:var(--text);
  --txt-soft:var(--text-secondary);
  --txt-mute:var(--text-muted);
  --gris:var(--text-secondary);
  --azul-osc:var(--text);
  --surface-2:var(--surface-muted);
  --ok:var(--success);
  --info:var(--accent);
  --warn:var(--warning);
  --sh-sm:var(--shadow-soft);
  --sh:var(--shadow-soft);
  --sh-md:var(--shadow-card);
  --sh-lg:var(--shadow-hover);
}

/* =====================================================================
   MENÚ "MÁS" del header (acciones que no entran en tablet/mobile)
   ===================================================================== */
.moremenu{ position:relative; display:none; }
.moremenu__menu{ position:absolute; right:0; top:calc(100% + 7px); min-width:215px; background:var(--surface); border:1px solid var(--border); border-radius:14px; box-shadow:var(--shadow-card); padding:6px; z-index:50; display:none; }
.moremenu__menu.is-open{ display:block; animation:pop .14s ease; }
.moremenu__item{ display:flex; align-items:center; gap:11px; padding:9px 11px; border-radius:9px; cursor:pointer; font-size:13px; font-weight:500; color:var(--text); }
.moremenu__item:hover{ background:var(--surface-hover); }
.moremenu__item .i{ width:20px; text-align:center; font-size:15px; flex:0 0 20px; }
.moremenu__sep{ height:1px; background:var(--line-2); margin:5px 6px; }

/* =====================================================================
   SISTEMA RESPONSIVE  ·  escala tipográfica + espaciado por dispositivo
   (prioridad: que en celular sea cómodo, compacto y profesional)
   ===================================================================== */
:root{
  /* escala tipográfica — DESKTOP (= valores actuales, no altera la estética premium) */
  --font-page-title:23px;     /* título de página            */
  --font-section-title:17px;  /* destacados / modal          */
  --font-subtitle:14.5px;     /* head de panel/card          */
  --font-body:14px;           /* cuerpo                       */
  --font-small:12.5px;        /* labels / metadata           */
  --font-micro:11px;          /* badges / ayudas (mín. 11px)  */
  /* espaciado */
  --space-xs:6px; --space-sm:10px; --space-md:16px; --space-lg:22px; --space-xl:30px;
}
/* títulos atados a la escala (se reescalan solos por dispositivo) */
.page-head h1{ font-size:var(--font-page-title); }
.panel__head h3{ font-size:var(--font-subtitle); }
.modal__head h3{ font-size:var(--font-section-title); }

/* ---------------------------------------------------------------------
   MOBILE  (≤768px) · máximo 3 niveles: título 18 · cuerpo 14 · auxiliar 11-12
   compacto pero con zonas táctiles cómodas (botones/inputs ≥44px)
   --------------------------------------------------------------------- */
@media(max-width:768px){
  :root{
    --font-page-title:18px; --font-section-title:16px; --font-subtitle:15px;
    --font-body:14px; --font-small:12px; --font-micro:11px;
    --space-md:14px; --space-lg:16px; --space-xl:20px;
  }
  /* header compacto, sin títulos enormes */
  .topbar{ height:58px; padding:0 12px; gap:10px; }
  /* título de página: chico, prolijo, apilado */
  .page-head{ margin-bottom:14px; gap:6px 10px; align-items:flex-start; }
  .page-head h1{ letter-spacing:-.2px; }
  .page-head p{ font-size:13px; line-height:1.4; }
  .page-head__top{ margin-bottom:3px; }
  .breadcrumb{ font-size:11px; letter-spacing:.5px; }
  .store-active{ font-size:12px; }
  /* contenido con padding lateral compacto y aire vertical claro */
  .view{ padding:14px 14px 72px; }
  /* paneles/cards compactos */
  .panel__head{ padding:12px 14px; }
  .panel__body{ padding:14px 15px; }
  /* cuerpo legible 14px + botones táctiles 44px */
  .btn{ min-height:44px; font-size:14px; padding:11px 15px; }
  .btn--sm{ min-height:40px; font-size:13px; padding:8px 12px; }
  .btn--xs{ min-height:34px; font-size:12px; padding:5px 10px; }
  .btn--icon{ min-height:44px; min-width:44px; padding:9px; }
  /* inputs/selects/textarea táctiles y legibles */
  .fld input,.fld select,.fld textarea,.search input,.field-search input{ font-size:14px; min-height:44px; padding:11px 13px; }
  .fld textarea{ min-height:92px; }
  .fld > label{ font-size:12.5px; }
  .fld .help,.fld > label .hint{ font-size:12px; line-height:1.4; }
  .section-title{ font-size:11px; margin:15px 0 4px; }
  /* formularios SIEMPRE en una columna */
  .form-grid,.form-grid.three,.switch-grid{ grid-template-columns:1fr; }
  .form-grid{ gap:13px; }
  .fld.col-span-2,.fld.col-span-full{ grid-column:auto; }
  /* badges legibles (mín 11px) */
  .badge{ font-size:11px; padding:3px 9px; }
  /* KPIs grandes pero no exagerados */
  .kpi{ padding:15px 16px; }
  .kpi__val{ font-size:22px; }
  .kpi__ico{ width:34px; height:34px; font-size:16px; margin-bottom:9px; }
  .kpi__lbl{ font-size:12px; }
  /* switch con tamaño táctil cómodo */
  .switch{ font-size:13px; }
  .switch .track{ width:42px; height:24px; flex:0 0 42px; }
  .switch .track::after{ width:18px; height:18px; top:3px; left:3px; }
  .switch input:checked + .track::after{ left:21px; }
  /* MODALES adaptados: chico = bottom sheet (sube desde abajo) · grande = full screen */
  .modal{ align-items:flex-end; justify-content:center; }
  .modal__panel{
    width:100vw; max-width:100vw; max-height:88dvh; margin:0;
    border-radius:20px 20px 0 0; border:none; display:flex; flex-direction:column;
    animation:sheetUp .22s cubic-bezier(.22,1,.36,1);
  }
  .modal__panel.wide,.modal__panel.full{
    height:100dvh; max-height:100dvh; align-self:stretch; border-radius:0; animation:none;
  }
  @keyframes sheetUp{ from{ transform:translateY(100%); } to{ transform:none; } }
  .modal__head{ padding:14px 16px; flex:0 0 auto; }
  .modal__head h3{ font-size:18px; }
  .modal__x{ width:40px; height:40px; font-size:22px; }
  .modal__body{ padding:16px; flex:1 1 auto; min-height:0; }
  .modal__foot{ padding:12px 16px; flex:0 0 auto; }
  /* wiki / bienvenida con títulos contenidos */
  .wiki__article h2{ font-size:18px; }
  .wiki__cats{ flex-wrap:wrap; }
  .welcome h2{ font-size:18px; }
  /* acciones de página: cómodas y a lo ancho */
  .page-head__actions{ width:100%; margin-left:0; gap:8px; }
  .page-head__actions .btn{ flex:1 1 auto; }
}

/* ---------------------------------------------------------------------
   MOBILE CHICO  (≤480px) · apila acciones, aún más compacto
   --------------------------------------------------------------------- */
@media(max-width:480px){
  .view{ padding:12px 12px 72px; }
  .page-head__actions{ flex-direction:column; }
  .page-head__actions .btn{ width:100%; }
  .kpi__val{ font-size:21px; }
  .topbar{ gap:8px; }
}

/* =====================================================================
   MENÚ INFERIOR MOBILE  ·  FILTROS COLAPSABLES  ·  TOOLBAR RESPONSIVE
   ===================================================================== */
.botnav{ display:none; }
.flt-toggle{ display:none; }

@media(max-width:768px){
  /* ---- menú inferior fijo ---- */
  .botnav{
    display:flex; position:fixed; left:0; right:0; bottom:0; z-index:60;
    background:var(--surface); border-top:1px solid var(--border);
    box-shadow:0 -3px 16px rgba(0,0,0,.07);
    padding:5px 4px calc(5px + env(safe-area-inset-bottom,0px));
  }
  .botnav__item{
    flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
    background:none; border:none; cursor:pointer; color:var(--text-muted);
    font-size:11px; font-weight:600; min-height:50px; border-radius:13px; transition:background .15s,color .15s;
    -webkit-tap-highlight-color:transparent;
  }
  .botnav__item .i{ font-size:19px; line-height:1; }
  .botnav__item.is-active{ color:var(--primary); }
  .botnav__item.is-active .i{ transform:translateY(-1px); }
  .botnav__item:active{ background:var(--surface-hover); }
  /* el contenido deja lugar al menú inferior */
  .view{ padding-bottom:80px; }
  /* el drawer lateral (y su backdrop) tapan el menú inferior al abrirse */
  .sidebar{ z-index:70; }
  .sidebar__backdrop.is-open{ z-index:65; }

  /* ---- TOOLBAR de filtros: buscador a lo ancho + filtros colapsables ---- */
  .toolbar{ flex-wrap:wrap; gap:9px; align-items:stretch; }
  .toolbar .field-search{ flex:1 1 200px; min-width:0; }
  .toolbar .field-search input{ min-height:44px; font-size:14px; }
  .flt-toggle{
    display:inline-flex; align-items:center; gap:7px; justify-content:center;
    min-height:44px; padding:0 15px; border-radius:12px; cursor:pointer;
    border:1px solid var(--line); background:var(--surface); color:var(--azul-osc);
    font-size:14px; font-weight:600; white-space:nowrap;
  }
  .flt-toggle .badge-n{ background:var(--primary); color:#fff; border-radius:20px; font-size:11px; font-weight:700; padding:1px 7px; }
  /* por defecto los selects de la toolbar quedan ocultos en mobile (se abren con "Filtros") */
  .toolbar > select,.toolbar > .fld:not(.field-search),.toolbar > .seg,.toolbar > .chips{ display:none; flex:1 1 100%; }
  .toolbar.is-filtering{ padding-bottom:2px; }
  .toolbar.is-filtering > select,.toolbar.is-filtering > .fld:not(.field-search),.toolbar.is-filtering > .seg,.toolbar.is-filtering > .chips{ display:flex; }
  .toolbar.is-filtering > select{ display:block; min-height:44px; font-size:14px; }
}

/* en desktop nunca se ven los controles mobile, pase lo que pase */
@media(min-width:769px){
  .botnav{ display:none!important; }
  .flt-toggle{ display:none!important; }
  .toolbar > select,.toolbar > .fld:not(.field-search){ display:block; }
}

/* tabs/pasos de formularios: barra deslizable táctil en mobile */
@media(max-width:768px){
  .tabs{ flex-wrap:nowrap; overflow-x:auto; -webkit-overflow-scrolling:touch; gap:2px; margin-bottom:14px; scrollbar-width:none; }
  .tabs::-webkit-scrollbar{ display:none; }
  .tab{ font-size:13px; padding:9px 13px; white-space:nowrap; min-height:42px; display:inline-flex; align-items:center; }
}

/* ---- paso "Resumen" del editor de pedidos ---- */
.ped-resumen__total{ display:flex; flex-direction:column; gap:3px; padding:16px 18px; background:var(--accent-soft); border-radius:14px; margin-bottom:14px; }
.ped-resumen__total .lbl{ font-size:12px; color:var(--text-muted); font-weight:600; }
.ped-resumen__total b{ font-size:25px; color:var(--azul-osc); line-height:1.1; }
.ped-resumen__grid{ display:grid; grid-template-columns:1fr 1fr; gap:11px; }
.ped-resumen__grid > div{ display:flex; flex-direction:column; gap:5px; padding:12px 14px; background:var(--surface-muted); border:1px solid var(--line-2); border-radius:12px; }
.ped-resumen__grid .lbl{ font-size:10.5px; text-transform:uppercase; letter-spacing:.5px; color:var(--text-muted); font-weight:700; }
.ped-resumen__grid > div b{ font-size:15px; color:var(--azul-osc); }

/* ---- preview de importación: cards por fila (en vez de tabla apretada) ---- */
.imp-kpis{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-bottom:14px; }
.imp-rows{ display:flex; flex-direction:column; gap:8px; margin-bottom:4px; }
.imp-rows--scroll{ max-height:46vh; overflow:auto; padding-right:2px; }
.imp-row{ border:1px solid var(--line-2); border-radius:12px; padding:10px 13px; background:var(--surface); }
.imp-row--err{ border-color:rgba(180,35,24,.25); background:var(--danger-soft); }
.imp-row__top{ display:flex; align-items:center; gap:9px; }
.imp-row__top b{ font-size:13.5px; color:var(--azul-osc); }
.imp-row__price{ margin-left:auto; font-weight:700; color:var(--azul-osc); font-size:13.5px; }
.imp-row__sub{ font-size:12px; color:var(--text-muted); margin-top:5px; display:flex; align-items:center; gap:7px; flex-wrap:wrap; }
@media(max-width:768px){
  .three-col{ grid-template-columns:1fr; }       /* importador: paso a paso vertical */
  .imp-kpis{ gap:8px; }
  .imp-kpis .kpi{ padding:13px 10px; }
  .imp-kpis .kpi__val{ font-size:20px; }
  .dropzone{ min-height:120px; padding:22px 16px; }
}

/* ---- ALERTAS INTELIGENTES (dashboard) ---- */
.alert{ display:flex; gap:12px; padding:13px 15px; border-radius:13px; border:1px solid var(--line-2); background:var(--surface); align-items:flex-start; }
.alert--danger{ border-color:rgba(180,35,24,.22); background:var(--danger-soft); }
.alert--warn{ border-color:rgba(167,99,0,.20); background:var(--warning-soft); }
.alert--info{ border-color:var(--border); background:var(--surface-muted); }
.alert--ok{ border-color:rgba(55,186,152,.22); background:var(--success-soft); }
.alert__ico{ font-size:20px; line-height:1; flex:0 0 auto; margin-top:1px; }
.alert__body{ flex:1; min-width:0; }
.alert__body > b{ font-size:13.5px; color:var(--azul-osc); display:block; margin-bottom:7px; }
.alert__items{ display:flex; flex-wrap:wrap; gap:6px; }
.alert__chip,.alert__more{ display:inline-flex; align-items:center; gap:6px; font-size:11.5px; background:var(--surface); border:1px solid var(--line-2); border-radius:9px; padding:5px 10px; cursor:pointer; color:var(--txt); transition:border-color .15s,transform .15s; max-width:100%; overflow:hidden; white-space:nowrap; text-overflow:ellipsis; }
.alert__chip:hover,.alert__more:hover{ border-color:var(--accent); transform:translateY(-1px); }
.alert__chip em{ font-style:normal; font-weight:700; color:var(--accent); font-size:10.5px; }
.alert__more{ font-weight:600; color:var(--text-muted); }
@media(max-width:768px){ .alert__chip,.alert__more{ font-size:12px; padding:7px 11px; } }
