*{box-sizing:border-box;margin:0;padding:0}
:root{
  /* ── Colors ──────────────────────────────────────────────── */
  --navy:#0f3d2e;--navy-mid:#1a6144;--navy-light:#2a8f5e;
  --gold:#c4a252;--gold-light:#d4b86a;--gold-pale:#faf7ef;
  --ink:#0f3d2e;--slate:#3d5248;--mist:#5e6e64;--fog:#ece6d4;
  --white:#ffffff;--off:#f5f2ea;
  --green:#1a7a4a;--green-bg:#e8f5ee;
  --red:#c0392b;--red-bg:#fdecea;
  --amber:#b45309;--amber-bg:#fef3c7;
  --blue:#1e40af;--blue-bg:#eff6ff;
  --purple:#6d28d9;--purple-bg:#f5f3ff;
  --teal:#0f766e;--teal-bg:#f0fdfa;
  /* ── Typography scale (9 sizes consolidados) ────────────── */
  --text-xs:11px;--text-sm:12px;--text-base:13px;--text-md:14px;
  --text-lg:16px;--text-xl:18px;--text-2xl:22px;--text-3xl:28px;--text-hero:34px;
  /* ── Spacing scale ──────────────────────────────────────── */
  --s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-8:32px;--s-10:40px;--s-12:48px;
  /* ── Radius ─────────────────────────────────────────────── */
  --r:10px;--r-lg:16px;--r-xl:24px;
  /* ── Elevations ─────────────────────────────────────────── */
  --shadow-sm:0 1px 3px rgba(15,61,46,.08),0 1px 2px rgba(15,61,46,.06);
  --shadow:0 4px 16px rgba(15,61,46,.10),0 2px 6px rgba(15,61,46,.06);
  --shadow-lg:0 12px 40px rgba(15,61,46,.16),0 4px 12px rgba(15,61,46,.08);
  /* ── Motion ─────────────────────────────────────────────── */
  --transition:all .2s cubic-bezier(.4,0,.2,1);
  --focus-ring:0 0 0 3px rgba(196,162,82,.4);
}

/* ── DARK MODE ──────────────────────────────────────────────
   Activado vía: <html data-theme="dark"> (init en index.html)
   ──────────────────────────────────────────────────────────── */
[data-theme="dark"]{
  --navy:#1f5340;--navy-mid:#2a6a52;--navy-light:#3aa170;
  --gold:#d4b86a;--gold-light:#e4c87a;--gold-pale:#1a2520;
  --ink:#e8e4d6;--slate:#b8b5a5;--mist:#8a9088;--fog:#2a3a32;
  --white:#162822;--off:#0c1814;
  --green:#3aa170;--green-bg:#1a3a2a;
  --red:#e74c3c;--red-bg:#3a1a1a;
  --amber:#d4a437;--amber-bg:#3a2a14;
  --blue:#5a7fff;--blue-bg:#1a2a4a;
  --purple:#a37ddf;--purple-bg:#2a1a4a;
  --teal:#3aa1a1;--teal-bg:#1a3a3a;
  --shadow-sm:0 1px 3px rgba(0,0,0,.4),0 1px 2px rgba(0,0,0,.25);
  --shadow:0 4px 16px rgba(0,0,0,.5),0 2px 6px rgba(0,0,0,.3);
  --shadow-lg:0 12px 40px rgba(0,0,0,.6),0 4px 12px rgba(0,0,0,.4);
}
[data-theme="dark"] .sidebar{background:#0a1612}
[data-theme="dark"] .drawer-header,[data-theme="dark"] thead th,[data-theme="dark"] .profile-header{background:#1f5340}
[data-theme="dark"] .cart-fab{background:#1f5340}
[data-theme="dark"] .product-card-img{background:#0a1612}
[data-theme="dark"] .login-page{background:#0a1612}
[data-theme="dark"] .modal-close{background:#2a3a32;color:var(--mist)}
[data-theme="dark"] .login-tabs,[data-theme="dark"] .stat-card{background:var(--white)}
[data-theme="dark"] .login-tab.active{background:#1f5340;color:var(--gold-light)}
[data-theme="dark"] tbody tr:hover{background:#1a2520}
[data-theme="dark"] .skeleton{background:linear-gradient(90deg,#1a2520 25%,#243530 50%,#1a2520 75%)}
[data-theme="dark"] .form-control:hover{border-color:#3a4a42}
html,body{height:100%;font-family:'DM Sans',system-ui,sans-serif;background:var(--off);color:var(--ink);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--fog);border-radius:10px}
::-webkit-scrollbar-thumb:hover{background:#d8d3bf}

/* ── A11y: focus visible consistente ─────────────────────── */
:focus{outline:none}
button:focus-visible,a:focus-visible,select:focus-visible,input:focus-visible,textarea:focus-visible{outline:none;box-shadow:var(--focus-ring)}
.form-control:focus-visible{border-color:var(--gold);box-shadow:var(--focus-ring)}

/* ─── LAYOUT ─── */
#app{display:flex;flex-direction:column;min-height:100vh}
.shell{display:flex;flex:1;overflow:hidden}
.sidebar{width:240px;min-width:240px;background:var(--navy);display:flex;flex-direction:column;height:100vh;position:sticky;top:0}
.main-content{flex:1;overflow-y:auto;height:100vh;padding:32px}

/* ─── SIDEBAR ─── */
.sidebar-logo{padding:24px 24px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.logo-mark{font-family:'DM Serif Display',serif;font-size:var(--text-2xl);color:var(--white)}
.logo-mark em{color:var(--gold);font-style:italic}
.logo-sub{font-size:var(--text-xs);color:rgba(255,255,255,.55);letter-spacing:1.5px;text-transform:uppercase;margin-top:2px}
.sidebar-user{padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:10px}
.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:600;color:var(--navy);flex-shrink:0}
.user-info{min-width:0}
.user-name{font-size:var(--text-base);font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-nav{flex:1;padding:12px;overflow-y:auto}
.nav-section-label{font-size:var(--text-xs);font-weight:600;color:rgba(255,255,255,.55);letter-spacing:1.5px;text-transform:uppercase;padding:12px 12px 6px}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:var(--transition);color:rgba(255,255,255,.7);font-size:var(--text-base);font-weight:500;margin-bottom:2px;border:none;background:transparent;width:100%;text-align:left}
.nav-item svg{width:16px;height:16px;flex-shrink:0;opacity:.75}
.nav-item:hover{background:rgba(255,255,255,.08);color:var(--white)}
.nav-item.active{background:rgba(201,151,58,.15);color:var(--gold-light)}
.nav-item.active svg{opacity:1}
.nav-badge{margin-left:auto;background:var(--gold);color:var(--navy);font-size:var(--text-xs);font-weight:700;padding:2px 7px;border-radius:10px}
.sidebar-footer{padding:10px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:4px}
.btn-theme,.btn-logout{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;border-radius:8px;border:none;background:transparent;color:rgba(255,255,255,.55);font-size:var(--text-base);cursor:pointer;transition:var(--transition);font-family:inherit;text-align:left}
.btn-theme svg,.btn-logout svg{width:15px;height:15px;flex-shrink:0;opacity:.75}
.btn-theme:hover{background:rgba(196,162,82,.12);color:var(--gold-light)}
.btn-theme:hover svg{opacity:1}
.btn-logout:hover{background:var(--red-bg);color:var(--red)}

/* ─── TOPBAR ─── */
.topbar{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:12px;flex-wrap:wrap}
.topbar-title{font-family:'DM Serif Display',serif;font-size:var(--text-3xl);color:var(--navy);line-height:1.2}
.topbar-sub{font-size:var(--text-base);color:var(--mist);margin-top:3px}
.topbar-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:10px 18px;border-radius:8px;border:none;cursor:pointer;font-size:var(--text-base);font-weight:600;transition:var(--transition);font-family:inherit;white-space:nowrap;letter-spacing:.2px}
.btn svg{width:14px;height:14px}
.btn-primary{background:var(--navy);color:var(--white)}.btn-primary:hover{background:var(--navy-mid)}
.btn-gold{background:var(--gold);color:var(--white)}.btn-gold:hover{background:var(--gold-light);color:var(--navy)}
.btn-outline{background:var(--white);color:var(--navy);border:1.5px solid var(--fog)}.btn-outline:hover{border-color:var(--navy);background:var(--navy);color:var(--white)}
.btn-ghost{background:transparent;color:var(--slate);border:1.5px solid var(--fog)}.btn-ghost:hover{background:var(--fog)}
.btn-danger{background:var(--red-bg);color:var(--red)}.btn-danger:hover{background:var(--red);color:var(--white)}
.btn-success{background:var(--green-bg);color:var(--green)}.btn-success:hover{background:var(--green);color:var(--white)}
.btn-teal{background:var(--teal-bg);color:var(--teal)}.btn-teal:hover{background:var(--teal);color:var(--white)}
.btn-sm{padding:7px 13px;font-size:var(--text-sm)}.btn-xs{padding:5px 10px;font-size:var(--text-xs);border-radius:6px}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ─── CARDS ─── */
.card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--fog);box-shadow:var(--shadow-sm);transition:var(--transition)}
.card:hover{box-shadow:var(--shadow);border-color:#d8d3bf}
[data-theme="dark"] .card:hover{border-color:#3a4a42}
.card-header{padding:20px 24px;border-bottom:1px solid var(--fog);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:var(--text-md);font-weight:600;color:var(--navy)}
[data-theme="dark"] .card-title{color:var(--gold-light)}
.card-body{padding:24px}

/* ─── STAT CARDS ─── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:28px}
.stat-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--fog);padding:22px 24px;transition:var(--transition)}
.stat-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.stat-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.stat-icon svg{width:18px;height:18px}
.stat-value{font-size:var(--text-2xl);font-weight:600;color:var(--navy);font-family:'DM Serif Display',serif;line-height:1.1}
.stat-label{font-size:var(--text-sm);color:var(--mist);font-weight:500;margin-top:4px}
.stat-delta{font-size:var(--text-sm);font-weight:600;margin-top:4px;color:var(--mist)}

/* ─── FORMS ─── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-label{font-size:var(--text-sm);font-weight:600;color:var(--slate);letter-spacing:.3px}
.req{color:var(--red)}
.form-control{padding:10px 14px;border:1.5px solid var(--fog);border-radius:8px;font-size:var(--text-md);font-family:inherit;color:var(--ink);background:var(--white);transition:var(--transition);outline:none;width:100%}
.form-control:hover{border-color:#c8d0c4}
.form-control:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(15,61,46,.08)}
.form-control.error{border-color:var(--red);box-shadow:0 0 0 3px rgba(192,57,43,.1)}
.form-control::placeholder{color:var(--mist)}
select.form-control{cursor:pointer}
textarea.form-control{resize:vertical;min-height:80px}
.form-hint{font-size:var(--text-sm);color:var(--mist)}
.form-section{margin-bottom:24px}
.form-section-title{font-size:var(--text-xs);font-weight:700;color:var(--mist);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--fog)}

/* ─── TABLES ─── */
.table-wrap{overflow-x:auto;border-radius:var(--r-lg);border:1px solid var(--fog)}
table{width:100%;border-collapse:collapse;background:var(--white)}
thead th{background:var(--navy);color:rgba(255,255,255,.85);font-size:var(--text-sm);font-weight:600;letter-spacing:.7px;text-transform:uppercase;padding:14px 16px;text-align:left;white-space:nowrap}
thead th:first-child{border-radius:var(--r-lg) 0 0 0}
thead th:last-child{border-radius:0 var(--r-lg) 0 0}
tbody tr{border-bottom:1px solid var(--fog);transition:var(--transition)}
tbody tr:last-child{border-bottom:none}
tbody tr:hover{background:var(--off)}
tbody td{padding:14px 16px;font-size:var(--text-base);color:var(--ink)}
.td-muted{color:var(--mist)}.td-bold{font-weight:600}
.table-actions{display:flex;gap:6px}
.chk-col{width:36px;text-align:center}
input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--navy)}

/* ─── BADGES ─── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:600;line-height:1.2}
.badge svg{width:11px;height:11px;flex-shrink:0;opacity:.9}
.badge:not(:has(svg))::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;opacity:.75}
.badge-pending{background:var(--amber-bg);color:var(--amber)}
.badge-processing{background:var(--blue-bg);color:var(--blue)}
.badge-assembled{background:var(--purple-bg);color:var(--purple)}
.badge-assigned{background:rgba(15,118,110,.12);color:var(--teal)}
.badge-shipping{background:rgba(124,58,237,.1);color:#7c3aed}
.badge-delivered{background:var(--green-bg);color:var(--green)}
.badge-cancelled{background:#f3f4f6;color:#6b7280;text-decoration:line-through}
.badge-neutral{background:var(--fog);color:var(--slate)}
.badge-admin{background:rgba(201,151,58,.15);color:var(--gold)}
.badge-vendor{background:var(--teal-bg);color:var(--teal)}

/* ─── SEARCH/FILTER ─── */
.search-bar{display:flex;gap:10px;align-items:center;margin-bottom:20px;flex-wrap:wrap}
.search-input-wrap{position:relative;flex:1;min-width:200px}
.search-input-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--mist)}
.search-input{width:100%;padding:10px 14px 10px 36px;border:1.5px solid var(--fog);border-radius:8px;font-size:var(--text-base);font-family:inherit;outline:none;background:var(--white);transition:var(--transition)}
.search-input:focus{border-color:var(--navy)}
.filter-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px}
.chip{padding:6px 14px;border-radius:20px;border:1.5px solid var(--fog);background:var(--white);font-size:var(--text-sm);font-weight:500;cursor:pointer;color:var(--slate);transition:var(--transition)}
.chip:hover{border-color:var(--navy);color:var(--navy)}
.chip.active{background:var(--navy);color:var(--white);border-color:var(--navy)}

/* ─── PRODUCT GRID ─── */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}
.product-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--fog);overflow:hidden;transition:var(--transition)}
.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.product-card-img{height:175px;background:var(--off);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.product-card-img img{width:100%;height:100%;object-fit:contain;padding:10px;transition:transform .3s}
.product-card:hover .product-card-img img{transform:scale(1.04)}
.product-card-img-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--fog)}.product-card-img-placeholder svg{width:42px;height:42px}
.img-count-badge{position:absolute;top:8px;right:8px;background:rgba(13,31,60,.65);color:var(--white);font-size:var(--text-xs);font-weight:600;padding:2px 8px;border-radius:8px}
.product-card-body{padding:14px}
.product-card-brand{font-size:var(--text-xs);font-weight:700;color:var(--gold);letter-spacing:.9px;text-transform:uppercase;margin-bottom:3px}
.product-card-name{font-size:var(--text-base);font-weight:600;color:var(--navy);line-height:1.35;min-height:36px}
.product-card-code{font-size:var(--text-xs);color:var(--mist);margin-bottom:6px}
.product-card-price{font-size:var(--text-xl);font-weight:600;color:var(--green);font-family:'DM Serif Display',serif}
.product-card-price-original{font-size:var(--text-sm);color:var(--mist);text-decoration:line-through}
.product-card-footer{padding:12px 14px;border-top:1px solid var(--fog);display:flex;align-items:center;gap:6px}
.stock-indicator{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.stock-ok{background:var(--green)}.stock-low{background:var(--amber)}.stock-out{background:var(--red)}
.qty-control{display:flex;align-items:center;gap:5px;margin-left:auto}
.qty-btn{width:26px;height:26px;border:1.5px solid var(--fog);background:var(--white);border-radius:6px;cursor:pointer;font-size:var(--text-md);font-weight:700;display:flex;align-items:center;justify-content:center;color:var(--navy);transition:var(--transition)}
.qty-btn:hover{background:var(--navy);color:var(--white);border-color:var(--navy)}
.qty-num{width:32px;text-align:center;font-size:var(--text-sm);font-weight:600;border:1.5px solid var(--fog);border-radius:5px;padding:3px 0}

/* ─── CART DRAWER ─── */
.cart-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;background:var(--navy);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-lg);transition:var(--transition);border:none;z-index:200}
.cart-fab:hover{background:var(--navy-mid);transform:scale(1.06)}
.cart-fab svg{width:22px;height:22px;color:var(--white)}
.cart-fab-badge{position:absolute;top:-4px;right:-4px;background:var(--gold);color:var(--navy);border-radius:50%;width:22px;height:22px;font-size:var(--text-xs);font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--white);transition:var(--transition)}
@keyframes badge-bump{0%,100%{transform:scale(1)}35%{transform:scale(1.35);background:var(--gold-light)}}
.cart-fab-badge.bumped{animation:badge-bump .45s cubic-bezier(.34,1.56,.64,1)}
@keyframes mob-badge-bump{0%,100%{transform:scale(1)}35%{transform:scale(1.3)}}
.mobile-nav-btn .mob-badge.bumped{animation:mob-badge-bump .4s cubic-bezier(.34,1.56,.64,1)}
.drawer-overlay{position:fixed;inset:0;background:rgba(13,31,60,.4);z-index:300;display:none;backdrop-filter:blur(2px)}
.drawer-overlay.open{display:block}
.drawer{position:fixed;right:0;top:0;bottom:0;width:440px;background:var(--white);z-index:301;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.drawer.open{transform:translateX(0)}
.drawer-header{background:var(--navy);padding:20px 24px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.drawer-header h3{font-family:'DM Serif Display',serif;font-size:var(--text-xl);color:var(--white)}
.drawer-close{background:transparent;border:none;color:rgba(255,255,255,.6);font-size:var(--text-2xl);cursor:pointer;line-height:1;transition:var(--transition)}
.drawer-close:hover{color:var(--white)}
.drawer-body{flex:1;overflow-y:auto;padding:16px}
.drawer-footer{padding:16px 20px;border-top:1px solid var(--fog);background:var(--white);flex-shrink:0}
.cart-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--fog)}
.cart-item:last-child{border-bottom:none}
.cart-item-info{flex:1}
.cart-item-brand{font-size:var(--text-xs);font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:.7px}
.cart-item-name{font-size:var(--text-base);font-weight:600;color:var(--navy);line-height:1.3}
.cart-item-unit-price{font-size:var(--text-sm);color:var(--mist)}
.cart-item-subtotal{font-size:var(--text-md);font-weight:600;color:var(--green);align-self:center}
.cart-item-remove{background:none;border:none;color:var(--mist);cursor:pointer;font-size:var(--text-xl);padding:0;transition:var(--transition);align-self:flex-start;line-height:1}
.cart-item-remove:hover{color:var(--red)}
.cart-total-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0}
.cart-total-value{font-size:var(--text-2xl);font-weight:600;font-family:'DM Serif Display',serif;color:var(--navy)}
.cart-empty{text-align:center;padding:48px 20px;color:var(--mist)}
.cart-empty svg{width:48px;height:48px;margin-bottom:12px;opacity:.25}

/* ─── MODAL ─── */
.modal-overlay{position:fixed;inset:0;background:rgba(13,31,60,.5);z-index:400;display:none;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(3px)}
.modal-overlay.open{display:flex}
.modal{background:var(--white);border-radius:var(--r-xl);width:100%;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;max-height:92vh;animation:modal-in .22s cubic-bezier(.4,0,.2,1)}
@keyframes modal-in{from{opacity:0;transform:scale(.96) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-sm{max-width:460px}.modal-md{max-width:620px}.modal-lg{max-width:780px}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--fog);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-header h3{font-family:'DM Serif Display',serif;font-size:var(--text-xl);color:var(--navy)}
.modal-close{background:var(--fog);border:none;color:var(--slate);font-size:var(--text-lg);cursor:pointer;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition);line-height:1}
.modal-close:hover{background:var(--red-bg);color:var(--red)}
.modal-body{padding:24px;overflow-y:auto;flex:1}
.modal-footer{padding:16px 24px;border-top:1px solid var(--fog);display:flex;justify-content:flex-end;gap:8px;flex-shrink:0;flex-wrap:wrap}
@media(max-width:768px){
  .modal-footer{flex-direction:column-reverse;gap:6px;padding:14px 16px}
  .modal-footer .btn{width:100%;justify-content:center}
}

/* ─── IMG UPLOAD ─── */
.img-upload-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;margin-top:6px}
.img-thumb{position:relative;border-radius:7px;overflow:hidden;aspect-ratio:1;background:var(--off);border:1px solid var(--fog)}
.img-thumb img{width:100%;height:100%;object-fit:cover}
.img-thumb-remove{position:absolute;top:3px;right:3px;width:20px;height:20px;background:rgba(192,57,43,.9);border:none;border-radius:50%;color:var(--white);cursor:pointer;font-size:var(--text-xs);display:flex;align-items:center;justify-content:center}
.img-add-btn{aspect-ratio:1;border:2px dashed var(--fog);border-radius:7px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:var(--mist);font-size:var(--text-xs);gap:4px;transition:var(--transition)}
.img-add-btn:hover{border-color:var(--navy);color:var(--navy)}
.img-add-btn svg{width:20px;height:20px}

/* ─── IMAGE VIEWER ─── */
.img-viewer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.93);z-index:500;display:none;align-items:center;justify-content:center}
.img-viewer-overlay.open{display:flex}
.img-viewer-close{position:fixed;top:14px;right:18px;background:rgba(255,255,255,.14);border:none;color:var(--white);font-size:var(--text-2xl);cursor:pointer;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.img-viewer-img{max-width:90vw;max-height:85vh;border-radius:7px;object-fit:contain}
.img-viewer-nav{position:fixed;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.14);border:none;color:var(--white);font-size:var(--text-2xl);cursor:pointer;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center}
#img-viewer-prev{left:14px}#img-viewer-next{right:14px}
.img-viewer-counter{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.6);font-size:var(--text-sm)}

/* ─── ORDER TIMELINE ─── */
.order-timeline{display:flex;gap:0;margin:16px 0}
.timeline-step{flex:1;text-align:center;position:relative}
.timeline-step::before{content:'';position:absolute;top:14px;left:50%;right:-50%;height:2px;background:var(--fog);z-index:0}
.timeline-step:last-child::before{display:none}
.timeline-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--fog);background:var(--white);display:flex;align-items:center;justify-content:center;margin:0 auto 6px;position:relative;z-index:1;font-size:var(--text-xs);font-weight:700}
.timeline-step.done .timeline-dot{background:var(--green);border-color:var(--green);color:var(--white)}
.timeline-step.done::before{background:var(--green)}
.timeline-step.current .timeline-dot{background:var(--navy);border-color:var(--navy);color:var(--white);box-shadow:0 0 0 3px rgba(13,31,60,.14)}
.timeline-label{font-size:var(--text-xs);color:var(--mist);font-weight:500;line-height:1.3}
.timeline-step.done .timeline-label,.timeline-step.current .timeline-label{color:var(--navy);font-weight:600}

/* ─── ORDER CARDS ─── */
.order-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--fog);margin-bottom:12px;overflow:hidden;transition:var(--transition)}
.order-card:hover{box-shadow:var(--shadow)}
.order-card-header{padding:14px 18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.order-card-body{padding:14px 18px;border-top:1px solid var(--fog);background:var(--off)}
.order-id{font-size:var(--text-md);font-weight:700;color:var(--navy);font-family:'DM Serif Display',serif}
.order-client{font-size:var(--text-sm);color:var(--mist)}
.order-date{font-size:var(--text-sm);color:var(--mist);margin-left:auto}
.order-total{font-size:var(--text-md);font-weight:600;color:var(--green);font-family:'DM Serif Display',serif}
.order-items-preview{font-size:var(--text-base);color:var(--slate);line-height:1.6}

/* ─── TABS ─── */
.tabs{display:flex;gap:0;border-bottom:2px solid var(--fog);margin-bottom:22px;overflow-x:auto}
.tab-btn{padding:10px 18px;border:none;background:transparent;font-size:var(--text-base);font-weight:600;color:var(--mist);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:var(--transition);font-family:inherit;white-space:nowrap}
.tab-btn:hover{color:var(--navy)}
.tab-btn.active{color:var(--navy);border-bottom-color:var(--navy)}

/* ─── PROMO BANNER (sobrio, sin emojis animados) ─── */
.promo-banner-bar{background:linear-gradient(135deg,#0d3526 0%,#0f3d2e 60%,#0d3526 100%);border-bottom:1px solid rgba(255,255,255,.1);overflow:hidden}
.promo-banner-bar.hidden{display:none}
.promo-carousel{display:grid;grid-template-areas:"stack"}
.promo-banner-item{grid-area:stack;display:flex;align-items:center;justify-content:center;gap:14px;padding:14px 16px;box-sizing:border-box;border-top:3px solid transparent;opacity:0;transition:opacity .65s ease;pointer-events:none;text-align:center}
.promo-banner-item.active{opacity:1;pointer-events:auto}
.promo-trumpet{font-size:var(--text-xl);flex-shrink:0;display:inline-block;opacity:.85}
.promo-banner-title{font-size:var(--text-xl);font-weight:700;color:var(--gold-light);line-height:1.3;margin-bottom:4px;text-shadow:0 1px 4px rgba(0,0,0,.35)}
.promo-banner-msg{font-size:var(--text-base);color:rgba(255,255,255,.88);line-height:1.5}
.promo-dots{display:flex;justify-content:center;gap:6px;padding:4px 0 10px}
.promo-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:all .3s}
.promo-dot.active{background:var(--gold);transform:scale(1.3)}

/* ─── TOAST ─── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(16px);background:var(--navy);color:var(--white);padding:12px 22px;border-radius:9px;font-size:var(--text-md);font-weight:500;z-index:600;display:none;box-shadow:var(--shadow-lg)}
.toast.show{display:block;transform:translateX(-50%) translateY(0);animation:toast-in .25s ease}
.toast.success{background:var(--green)}.toast.error{background:var(--red)}
@keyframes toast-in{from{opacity:0;transform:translateX(-50%) translateY(16px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ─── LOGIN ─── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--navy);padding:20px;position:relative;overflow:hidden}
.login-bg-shape{position:absolute;border-radius:50%;background:rgba(201,151,58,.07)}
.login-bg-shape:nth-child(1){width:580px;height:580px;top:-200px;right:-100px}
.login-bg-shape:nth-child(2){width:380px;height:380px;bottom:-140px;left:-90px}
.login-card{background:var(--white);border-radius:var(--r-xl);padding:48px 44px;width:100%;max-width:440px;position:relative;z-index:1;box-shadow:var(--shadow-lg)}
.login-logo{font-family:'DM Serif Display',serif;font-size:var(--text-hero);color:var(--navy);text-align:center;margin-bottom:4px}
.login-logo em{color:var(--gold);font-style:italic}
.login-tagline{text-align:center;font-size:var(--text-sm);color:var(--mist);margin-bottom:32px;letter-spacing:.3px}
.login-tabs{display:flex;background:var(--off);border-radius:9px;padding:4px;gap:3px;margin-bottom:24px}
.login-tab{flex:1;padding:9px;text-align:center;border-radius:7px;cursor:pointer;font-size:var(--text-base);font-weight:600;color:var(--mist);transition:var(--transition);border:none;background:transparent;font-family:inherit}
.login-tab.active{background:var(--white);color:var(--navy);box-shadow:var(--shadow-sm)}
.login-error{background:var(--red-bg);color:var(--red);padding:10px 14px;border-radius:7px;font-size:var(--text-base);margin-bottom:14px;display:none}
.login-error.show{display:block}

/* ─── PROFILE ─── */
.profile-header{display:flex;align-items:center;gap:18px;padding:24px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-light) 100%);border-radius:var(--r-lg);color:var(--white);margin-bottom:22px}
.profile-avatar-lg{width:62px;height:62px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-size:var(--text-2xl);font-weight:600;color:var(--navy);flex-shrink:0;font-family:'DM Serif Display',serif}
.profile-header-name{font-family:'DM Serif Display',serif;font-size:var(--text-2xl)}
.profile-header-sub{font-size:var(--text-sm);opacity:.75;margin-top:2px}

/* ─── REMITO PRINT ─── */
@media print{
  .remito-print *{font-family:'DM Sans',sans-serif;color:#000!important;background:#fff!important}
  .remito-header{border-bottom:2px solid #000;padding-bottom:12px;margin-bottom:16px}
  .remito-title{font-size:22px;font-weight:700}
  .remito-table{width:100%;border-collapse:collapse}
  .remito-table th,.remito-table td{border:1px solid #ccc;padding:6px 10px;font-size:12px;text-align:left}
  .remito-table th{background:#f0f0f0!important;font-weight:700}
  .remito-firma{margin-top:40px;border-top:1px solid #000;width:200px;padding-top:6px;font-size:11px}
}

/* ─── TABLA → TARJETAS EN MOBILE ───
   Aplicar class="table-wrap cards" en el contenedor + data-label="..." en cada td (excepto primero y último)
   Primer td = identidad (sin label), último td = acciones (sin label)
   ──────────────────────────────────────────────── */
@media(max-width:768px){
  .table-wrap.cards{border:none;border-radius:0;overflow:visible;background:transparent}
  .table-wrap.cards table{background:transparent}
  .table-wrap.cards thead{display:none}
  .table-wrap.cards tbody tr{
    display:block;background:var(--white);border:1px solid var(--fog);
    border-radius:12px;margin-bottom:10px;padding:14px 16px;
    box-shadow:var(--shadow-sm);transition:var(--transition);
  }
  .table-wrap.cards tbody tr:hover{background:var(--white);box-shadow:var(--shadow)}
  .table-wrap.cards tbody tr:last-child{border-bottom:1px solid var(--fog)}
  .table-wrap.cards tbody td{
    display:flex;justify-content:space-between;align-items:center;gap:12px;
    padding:7px 0;border:none;font-size:var(--text-base);text-align:right;
  }
  .table-wrap.cards tbody td[data-label]::before{
    content:attr(data-label);font-weight:600;color:var(--mist);
    font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.5px;
    flex-shrink:0;text-align:left;
  }
  .table-wrap.cards tbody td:first-child{
    padding-bottom:10px;margin-bottom:4px;border-bottom:1px solid var(--fog);
    justify-content:flex-start;text-align:left;
  }
  .table-wrap.cards tbody td:last-child{
    padding-top:10px;margin-top:8px;border-top:1px solid var(--fog);
    justify-content:flex-end;
  }
  .table-wrap.cards tbody td .table-actions{flex-wrap:wrap;gap:6px;justify-content:stretch;width:100%}
  .table-wrap.cards tbody td .table-actions .btn{flex:1;min-width:80px;justify-content:center;padding:7px 8px}
  .table-wrap.cards .chk-col{position:absolute;top:10px;right:10px;width:auto}
}

/* ─── CATALOG LIST VIEW ─── */
.catalog-list{display:flex;flex-direction:column;gap:6px}
.catalog-list-item{display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--fog);border-radius:10px;padding:12px 14px;justify-content:space-between}
.catalog-list-item.opacity-low{opacity:.6}

/* ─── SKELETON LOADER ─── */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg,var(--fog) 25%,#e8edf4 50%,var(--fog) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite linear;border-radius:6px}
.skeleton-row{height:48px;margin-bottom:8px;border-radius:8px}
.skeleton-card{height:80px;margin-bottom:10px;border-radius:10px}
.skeleton-text{height:14px;margin-bottom:6px;border-radius:4px}
.skeleton-text.short{width:40%}.skeleton-text.medium{width:65%}.skeleton-text.long{width:90%}

/* ─── TRANSICIÓN DE SECCIÓN ─── */
@keyframes sectionFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.section-fade{animation:sectionFadeIn .2s ease}

/* ─── MISC ─── */
.empty-state{text-align:center;padding:64px 24px;color:var(--mist)}
.empty-state-icon{width:96px;height:96px;margin:0 auto 20px;color:var(--navy);background:var(--gold-pale);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}
[data-theme="dark"] .empty-state-icon{background:#1a2520;color:var(--gold-light)}
.empty-state-icon svg{width:44px;height:44px;opacity:.55}
.empty-state-icon::after{content:'';position:absolute;inset:-6px;border-radius:50%;border:2px dashed var(--fog);opacity:.5}
.empty-state h3{font-size:var(--text-lg);font-weight:600;color:var(--slate);margin-bottom:6px}
[data-theme="dark"] .empty-state h3{color:var(--ink)}
.empty-state p{font-size:var(--text-base);color:var(--mist);max-width:320px;margin:0 auto 18px;line-height:1.55}
.divider{height:1px;background:var(--fog);margin:20px 0}
.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-16{margin-top:16px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-8{gap:8px}
.text-gold{color:var(--gold)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-muted{color:var(--mist)}.text-navy{color:var(--navy)}
.font-serif{font-family:'DM Serif Display',serif}
.fw-600{font-weight:600}
.section-card{background:var(--white);border-radius:var(--r-lg);border:1px solid var(--fog);padding:22px;margin-bottom:14px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:768px){
  .sidebar{display:none}
  .main-content{padding:16px;padding-bottom:84px}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .form-grid,.form-grid-3,.two-col{grid-template-columns:1fr}
  .drawer{width:100%}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .topbar-title{font-size:var(--text-2xl)}
}

/* ─── MOBILE BOTTOM NAV ─── */
.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--navy);z-index:150;border-top:1px solid rgba(255,255,255,.1);padding-bottom:env(safe-area-inset-bottom);box-shadow:0 -2px 12px rgba(0,0,0,.15)}
[data-theme="dark"] .mobile-nav{background:#0a1612}
.mobile-nav-inner{display:flex;align-items:stretch;height:68px}
.mobile-nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:none;background:transparent;color:rgba(255,255,255,.65);cursor:pointer;padding:8px 4px 6px;transition:var(--transition);font-family:inherit;-webkit-tap-highlight-color:transparent;position:relative}
.mobile-nav-btn svg{width:22px;height:22px;flex-shrink:0;transition:var(--transition)}
.mobile-nav-btn span{font-size:var(--text-sm);font-weight:600;letter-spacing:.1px;line-height:1}
.mobile-nav-btn.active{color:var(--gold-light)}
.mobile-nav-btn.active svg{transform:scale(1.08)}
.mobile-nav-btn::after{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%) scaleX(0);width:32px;height:3px;background:var(--gold);border-radius:0 0 3px 3px;transition:transform .25s cubic-bezier(.34,1.56,.64,1)}
.mobile-nav-btn.active::after{transform:translateX(-50%) scaleX(1)}
.mobile-nav-btn .mob-badge{position:absolute;top:6px;right:18%;background:var(--gold);color:var(--navy);font-size:var(--text-xs);font-weight:700;border-radius:9px;padding:1px 6px;min-width:18px;text-align:center;line-height:1.3}
@media(max-width:768px){
  .mobile-nav{display:block}
  .cart-fab{bottom:84px}
}

/* ─── MOBILE SIDEBAR OVERLAY (hamburger) ─── */
.mob-sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:400;display:none}
.mob-sidebar-overlay.open{display:block}
.mob-sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:var(--navy);z-index:401;transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow-y:auto}
.mob-sidebar.open{transform:translateX(0)}
