.material-symbols-outlined{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;font-size:20px;line-height:1}
*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
:root{
  --navy:#0f1e35;--navy2:#162b48;--navy3:#1e3a5f;
  --gold:#ffcc00;--gold2:#f0bc00;--gold3:#ffe566;
  --cream:#fbf9f4;--cream2:#f5f3ee;--cream3:#eae8e3;--cream4:#e4e2dd;
  --text:#1b1c19;--text2:#43474f;--text3:#747781;
  --border:rgba(0,0,0,.07);--border2:rgba(0,0,0,.04);
  --green:#1a6b3c;--green2:#22a05a;--green-dim:rgba(26,107,60,.1);
  --red:#ba1a1a;--red2:#dc2626;--red-dim:rgba(186,26,26,.08);
  --blue:#002d62;--blue-dim:rgba(0,45,98,.08);
  --purple:#6b21a8;--purple-dim:rgba(107,33,168,.08);
  --shadow-xs:0 1px 2px rgba(0,0,0,.04);
  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --shadow-md:0 8px 24px rgba(0,0,0,.08);
  --shadow-lg:0 20px 60px rgba(0,0,0,.12);
  --r-sm:0.5rem;--r-md:0.75rem;--r-lg:1rem;--r-xl:1.25rem;--r-2xl:1.75rem;--r-full:9999px;
  --transition:all .18s cubic-bezier(.4,0,.2,1);
}
body{font-family:'Manrope',sans-serif;background:var(--cream);color:var(--text);min-height:100vh;display:flex}
#app-root{display:flex;flex:1;width:100%;min-height:100vh}

/* ═══ SIDEBAR ═══ */
.sidebar{width:220px;min-width:220px;background:var(--navy);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100;overflow:hidden}
.sidebar-logo{border-bottom:1px solid rgba(255,255,255,.06);padding:1.25rem 1.4rem}
.sidebar-logo-inner{display:flex;align-items:center;gap:.75rem}
.sidebar-logo-img{width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.sidebar-logo-img img{width:38px;height:38px;object-fit:contain}
.sidebar-logo-text{display:flex;flex-direction:column}
.sidebar-logo-title{font-family:'Manrope',sans-serif;font-size:.78rem;font-weight:800;color:var(--gold);letter-spacing:.04em;line-height:1.1}
.sidebar-logo-sub{font-family:'Manrope',sans-serif;font-size:.62rem;font-weight:600;color:rgba(255,255,255,.45);letter-spacing:.02em;margin-top:.1rem}
.nav-section-label{padding:.8rem 1.3rem .2rem;font-size:.58rem;font-weight:800;color:rgba(255,204,0,.45);letter-spacing:.12em;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:.75rem;padding:.58rem 1.3rem;cursor:pointer;font-size:.83rem;font-weight:600;color:rgba(255,255,255,.5);transition:var(--transition);border-left:3px solid transparent;width:100%}
.nav-item:hover{color:rgba(255,255,255,.9);background:rgba(255,255,255,.05)}
.nav-item.active{color:var(--gold);background:rgba(255,204,0,.06);border-left:3px solid var(--gold);font-weight:700}
.nav-item .ms{font-size:18px;flex-shrink:0}
.nav-icon{display:flex;align-items:center;justify-content:center;width:18px;flex-shrink:0;opacity:.6;transition:opacity .18s}
.nav-item:hover .nav-icon,.nav-item.active .nav-icon{opacity:1}
.sidebar-cta{margin:.8rem 1rem}
.sidebar-cta button{width:100%;background:var(--gold);color:var(--navy);padding:.6rem 1rem;border-radius:var(--r-md);border:none;font-family:'Manrope',sans-serif;font-size:.8rem;font-weight:800;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.4rem;transition:var(--transition)}
.sidebar-cta button:hover{background:var(--gold3);transform:scale(1.01)}
.sidebar-footer{margin-top:auto;padding:.9rem 1.1rem;border-top:1px solid rgba(255,255,255,.06)}
.sidebar-footer-link{display:flex;align-items:center;gap:.65rem;padding:.5rem .75rem;border-radius:var(--r-sm);color:rgba(255,255,255,.35);font-size:.8rem;font-weight:500;cursor:pointer;transition:var(--transition)}
.sidebar-footer-link:hover{color:rgba(255,255,255,.7);background:rgba(255,255,255,.04)}

/* ═══ MAIN ═══ */
.main{margin-left:220px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:rgba(251,249,244,.85);-webkit--webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:.75rem 1.75rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}
.topbar-left{display:flex;align-items:center;gap:.75rem}
.topbar-title{font-family:'Manrope',sans-serif;font-size:1.15rem;font-weight:600;color:var(--navy);letter-spacing:-.02em}
.topbar-right{display:flex;align-items:center;gap:.65rem}
.topbar-icon-btn{width:36px;height:36px;border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text3);cursor:pointer;transition:var(--transition)}
.topbar-icon-btn:hover{background:var(--cream3);color:var(--gold2)}
.topbar-date{font-size:.72rem;font-weight:700;color:#92650a;padding:.3rem .75rem;background:rgba(255,204,0,.12);border-radius:var(--r-full);border:1px solid rgba(255,204,0,.2)}
.content{padding:1.4rem 1.6rem;flex:1;background:var(--cream)}

/* ═══ PAGE ═══ */
.page{display:none}
.page.active{display:block;animation:fadeSlide .22s ease}
@keyframes fadeSlide{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}

/* ═══ PAGE HEADER ═══ */
.page-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}
.page-header-left p{font-size:.58rem;font-weight:800;color:#92650a;text-transform:uppercase;letter-spacing:.14em;margin-bottom:.3rem}
.page-header-left h2{font-family:'Manrope',sans-serif;font-size:1.65rem;font-weight:900;color:var(--navy);letter-spacing:-.03em;line-height:1.1}
.page-header-right{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.page-header-count{font-size:.75rem;font-weight:700;color:var(--text3);margin-left:.35rem}

/* ═══ TOOLBAR CLIENTES ═══ */
.toolbar-select{background:#fff;border:1.5px solid var(--cream4);border-radius:var(--r-full);padding:.35rem .85rem;font-size:.72rem;font-weight:700;color:var(--text2);outline:none;font-family:'Manrope',sans-serif;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;transition:border-color .15s}
.toolbar-select:focus{border-color:var(--navy)}
.cl-toolbar{display:flex;align-items:center;gap:.55rem;margin-bottom:1rem;flex-wrap:wrap}
.cl-search-wrap{flex:1;min-width:180px}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.1rem;border-radius:var(--r-md);border:none;font-family:'Manrope',sans-serif;font-size:.7rem;font-weight:800;cursor:pointer;transition:var(--transition);white-space:nowrap;text-transform:uppercase;letter-spacing:.06em}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(6,20,35,.25)}
.btn-gold{background:var(--gold);color:var(--navy);font-weight:800}
.btn-gold:hover{background:var(--gold3);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--text2);border:1.5px solid var(--cream4)}
.btn-ghost:hover{background:var(--cream3);border-color:var(--cream4);color:var(--gold2)}
.btn-success{background:var(--green);color:#fff}
.btn-success:hover{background:var(--green2)}
.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(186,26,26,.15)}
.btn-danger:hover{background:var(--red);color:#fff}
.btn-sm{padding:.3rem .75rem;font-size:.67rem}
.btn-icon{padding:.38rem;width:32px;height:32px;justify-content:center}

/* ═══ STATS GRID ═══ */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(175px,1fr));gap:.9rem;margin-bottom:1.5rem}
/* Bento dashboard */
.dash-bento{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;gap:.9rem}
.dash-card{background:#fff;border-radius:var(--r-2xl);padding:1.4rem 1.5rem;border:1px solid var(--border2);box-shadow:var(--shadow-xs);transition:var(--transition)}
.dash-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.dash-card-hero{grid-column:span 2;background:#fff}
.dash-card-dark{background:var(--navy);color:#fff}
.dash-card-stats{display:flex;align-items:center;gap:1rem;padding:1.2rem 1.5rem}
.dash-card-wide{grid-column:span 2}
.dash-stat-item{flex:1;text-align:center}
.dash-stat-sep{width:1px;height:50px;background:var(--border2);flex-shrink:0}
/* Stock alert items */
.stock-alert{display:flex;align-items:center;justify-content:space-between;background:rgba(255,255,255,.06);border-radius:var(--r-md);padding:.55rem .75rem}
.stock-alert-name{font-size:.78rem;font-weight:700;color:#fff}
.stock-alert-qty{font-size:.65rem;color:rgba(255,255,255,.4);margin-top:.08rem}
.stock-alert-badge{font-size:.6rem;font-weight:800;background:rgba(255,204,0,.15);color:var(--gold);border:1px solid rgba(255,204,0,.2);padding:.15rem .45rem;border-radius:3px;text-transform:uppercase;letter-spacing:.06em}
.stat-card{background:#fff;border-radius:var(--r-2xl);padding:1.35rem 1.5rem;position:relative;overflow:hidden;box-shadow:var(--shadow-xs);border:1px solid var(--border2);transition:var(--transition);cursor:default}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.stat-card-icon{width:42px;height:42px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem}
.stat-card.gold .stat-card-icon{background:rgba(255,204,0,.15);color:var(--gold)}
.stat-card.green .stat-card-icon{background:var(--green-dim);color:var(--green)}
.stat-card.navy .stat-card-icon{background:var(--blue-dim);color:var(--gold2)}
.stat-card.red .stat-card-icon{background:var(--red-dim);color:var(--red)}
.stat-card.purple .stat-card-icon{background:var(--purple-dim);color:var(--purple)}
.stat-label{font-size:.58rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.14em;margin-bottom:.5rem}
.stat-value{font-family:'Manrope',sans-serif;font-size:2rem;font-weight:700;color:var(--navy);line-height:1}
.stat-sub{font-size:.7rem;color:var(--text3);margin-top:.3rem}

/* ═══ TARJETAS ═══ */
.card{background:#fff;border-radius:var(--r-2xl);padding:1.4rem 1.6rem;margin-bottom:1rem;box-shadow:var(--shadow-xs);border:1px solid var(--border2)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.1rem}
.card-title{font-family:'Manrope',sans-serif;font-size:1rem;font-weight:700;color:var(--navy)}

/* ═══ BADGES ═══ */
.badge{display:inline-flex;align-items:center;gap:.2rem;padding:.18rem .55rem;border-radius:3px;font-size:.6rem;font-weight:800;white-space:nowrap;letter-spacing:.07em;text-transform:uppercase}
.badge-gold{background:rgba(255,204,0,.15);color:var(--navy);border:1px solid rgba(255,204,0,.3)}
.badge-green{background:var(--green-dim);color:var(--green);border:1px solid rgba(26,107,60,.2)}
.badge-red{background:var(--red-dim);color:var(--red);border:1px solid rgba(186,26,26,.15)}
.badge-blue{background:var(--blue-dim);color:var(--navy);border:1px solid rgba(0,45,98,.15)}
.badge-purple{background:var(--purple-dim);color:var(--purple);border:1px solid rgba(107,33,168,.15)}
.badge-gray{background:var(--cream3);color:var(--text3);border:1px solid var(--cream4)}
.badge-navy{background:var(--navy);color:#fff}

/* ═══ TABLE ═══ */
.table-wrap{overflow-x:auto;border-radius:var(--r-2xl);background:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--border2)}
table{width:100%;border-collapse:separate;border-spacing:0;font-size:.82rem}
thead{background:var(--navy)}
th{padding:.7rem 1.1rem;text-align:left;font-size:.6rem;font-weight:800;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.12em;white-space:nowrap}
th:first-child{border-radius:var(--r-2xl) 0 0 0;color:rgba(255,204,0,.7)}
th:last-child{border-radius:0 var(--r-2xl) 0 0}
td{padding:.65rem 1.1rem;border-bottom:1px solid var(--border2);vertical-align:middle;color:var(--text)}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .12s}
tbody tr:hover td{background:var(--cream2)}

/* ═══ FORMS ═══ */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grid.cols1{grid-template-columns:1fr}
.form-grid.cols3{grid-template-columns:1fr 1fr 1fr}
.field{display:flex;flex-direction:column;gap:.3rem}
.field label{font-size:.62rem;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.1em}
.field input,.field select,.field textarea{background:var(--cream2);border:1.5px solid var(--cream4);border-radius:var(--r-md);padding:.55rem .9rem;color:var(--navy);font-family:'Manrope',sans-serif;font-size:.86rem;font-weight:500;outline:none;transition:border-color .15s,box-shadow .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(255,204,0,.15)}
.field input::placeholder{color:var(--text3);font-weight:400}
.field input::-webkit-input-placeholder{color:var(--text3);font-weight:400}
.field textarea{resize:vertical;min-height:68px}
.field-span2{grid-column:span 2}

/* ═══ MODAL ═══ */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(6,20,35,.5);-webkit--webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex;animation:fadeSlide .2s ease}
.modal{background:#fff;border-radius:var(--r-2xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.modal-lg{max-width:780px}
.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border2);display:flex;align-items:center;justify-content:space-between;background:var(--cream2);border-radius:var(--r-2xl) var(--r-2xl) 0 0}
.modal-header h3{font-family:'Manrope',sans-serif;font-weight:700;font-size:.98rem;color:var(--navy)}
.modal-body{padding:1.5rem}
.modal-footer{padding:.9rem 1.5rem;border-top:1px solid var(--border2);display:flex;justify-content:flex-end;gap:.5rem;background:var(--cream2);border-radius:0 0 var(--r-2xl) var(--r-2xl)}
.modal-close{background:transparent;border:none;color:var(--text3);font-size:1rem;cursor:pointer;padding:.25rem .3rem;border-radius:var(--r-sm);transition:color .15s;display:flex;align-items:center}
.modal-close:hover{color:var(--navy)}

/* ═══ POS — BENTO CATALOGUE ═══ */
.pos-layout{display:grid;grid-template-columns:1fr 360px;gap:1.25rem;height:calc(100vh - 112px)}
.pos-productos{overflow-y:auto;padding-right:.3rem}
.pos-cat-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:1.1rem}
.pos-cat-title p{font-size:.6rem;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.12em;margin-bottom:.2rem}
.pos-cat-title h3{font-family:'Manrope',sans-serif;font-size:1.35rem;font-weight:700;color:var(--navy)}
.cat-filter-bar{display:flex;gap:.35rem}
.cat-filter-btn{background:var(--cream3);border:none;border-radius:var(--r-md);padding:.35rem .85rem;font-family:'Manrope',sans-serif;font-size:.68rem;font-weight:700;color:var(--text2);cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.04em}
.cat-filter-btn:hover,.cat-filter-btn.active{background:var(--navy);color:#fff}

/* Product bento grid */
.producto-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:.9rem}
.producto-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-xs);border:1px solid var(--border2);display:flex;flex-direction:column}
.producto-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold)}
.producto-card .prod-img{width:100%;aspect-ratio:1/1;background:var(--cream2);overflow:hidden;position:relative;border-bottom:1px solid var(--border2)}
.producto-card .prod-img img{width:100%;height:100%;object-fit:contain;padding:.8rem;transition:transform .4s ease}
.producto-card:hover .prod-img img{transform:scale(1.06)}
.prod-stock-badge{position:absolute;top:.5rem;left:.5rem;font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:.18rem .5rem;border-radius:var(--r-sm)}
.prod-stock-badge.instock{background:rgba(34,160,90,.12);color:var(--green)}
.prod-stock-badge.lowstock{background:rgba(255,204,0,.15);color:var(--gold2)}
.prod-stock-badge.nostock{background:var(--red-dim);color:var(--red)}
.producto-card .prod-body{padding:.8rem .9rem .95rem;flex:1;display:flex;flex-direction:column}
.producto-card .nombre{font-weight:800;font-size:.85rem;color:var(--navy);line-height:1.25;margin-bottom:.15rem}
.producto-card .categoria{font-size:.63rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem}
.producto-card .prod-precio-from{font-family:'Manrope',sans-serif;font-size:.8rem;color:var(--text3)}
.tallas-grid{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.4rem}
.talla-btn{background:var(--cream2);border:1px solid var(--cream4);border-radius:4px;padding:.18rem .42rem;font-size:.67rem;font-weight:700;color:var(--text2);cursor:pointer;transition:var(--transition);line-height:1.4;font-family:'Manrope',sans-serif}
.talla-btn:hover{border-color:var(--navy);color:var(--navy);background:#fff}
.talla-btn.sin-stock{opacity:.3;cursor:not-allowed}
.talla-precio-hint{font-size:.6rem;color:var(--text3);display:block;margin-top:.08rem;font-weight:500}

/* ═══ TRANSACTION PANEL ═══ */
.pos-carrito{background:var(--cream2);border-radius:var(--r-2xl);display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-md)}
.transaction-header{padding:1rem 1.2rem;background:#0d1e33}
.transaction-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:.85rem}
.transaction-title{font-family:'Manrope',sans-serif;font-size:.73rem;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:.1em}
.transaction-count{display:none}
.clear-btn{background:transparent;border:1.5px solid rgba(255,255,255,.25);color:rgba(255,255,255,.7);font-size:.72rem;font-weight:700;padding:.3rem .75rem;border-radius:var(--r-md);cursor:pointer;font-family:'Manrope',sans-serif;transition:var(--transition)}
.clear-btn:hover{border-color:rgba(255,255,255,.35);color:rgba(255,255,255,.8)}

/* Student search in dark */
.student-search-label{font-size:.62rem;font-weight:800;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.3rem;margin-top:.6rem}
.student-search-input{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-md);padding:.45rem .8rem;color:#fff;font-family:'Manrope',sans-serif;font-size:.78rem;font-weight:500;outline:none;transition:border-color .15s}
.student-search-input:focus{border-color:var(--gold);background:rgba(255,255,255,.1)}
.student-search-input::placeholder{color:rgba(255,255,255,.3)}
.student-search-input::-webkit-input-placeholder{color:rgba(255,255,255,.3)}

.pos-carrito-items{flex:1;overflow-y:auto;padding:.65rem .8rem;background:var(--cream)}
.ledger-empty{text-align:center;padding:2rem .5rem;color:var(--text3)}
.ledger-empty .ms{font-size:36px;opacity:.15;display:block;margin-bottom:.5rem}
.ledger-empty p{font-size:.78rem}

/* Cart items */
.carrito-item{background:#fff;border-radius:var(--r-md);padding:.6rem .75rem;margin-bottom:.35rem;display:flex;align-items:center;gap:.6rem;border:1px solid var(--border2);transition:var(--transition)}
.carrito-item:hover{border-color:var(--cream4)}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:.83rem;font-weight:700;color:var(--navy);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-meta{font-size:.7rem;font-weight:500;color:var(--text3);margin-top:.06rem}
.ci-price{font-family:'Manrope',sans-serif;font-size:.92rem;font-weight:700;color:var(--navy);white-space:nowrap}
.qty-ctrl{display:flex;align-items:center;gap:.25rem}
.qty-ctrl button{background:var(--cream3);border:1px solid var(--cream4);color:var(--navy);width:22px;height:22px;border-radius:4px;cursor:pointer;font-size:.82rem;display:flex;align-items:center;justify-content:center;font-weight:800;transition:var(--transition);font-family:'Manrope',sans-serif}
.qty-ctrl button:hover{background:var(--navy);color:#fff;border-color:var(--gold2)}
.qty-ctrl span{font-size:.8rem;font-weight:800;color:var(--navy);min-width:18px;text-align:center}


/* Pedido footer */
.pos-carrito-footer{padding:.9rem 1.1rem;border-top:1px solid var(--cream4);background:var(--cream2)}
.ledger-line{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.3rem}
.ledger-line .lbl{font-size:.7rem;font-weight:600;color:var(--text3)}
.ledger-line .val{font-size:.8rem;font-weight:700;color:var(--text2)}
.ledger-total-row{display:flex;justify-content:space-between;align-items:baseline;padding:.5rem 0 .6rem;margin:.3rem 0;border-top:1px solid var(--cream4)}
.ledger-total-row .lbl{font-size:.7rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:#9a7000}
.ledger-total-row .val{font-family:'Manrope',sans-serif;font-size:1.4rem;font-weight:700;color:var(--navy)}

/* Payment methods */
.metodos-pago{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin:.55rem 0}
.metodo-btn{background:#fff;border:1.5px solid var(--cream4);border-radius:var(--r-md);padding:.65rem .4rem;text-align:center;cursor:pointer;transition:var(--transition);color:var(--text2);font-family:'Manrope',sans-serif;display:flex;flex-direction:column;align-items:center;gap:.3rem}
.mp-icon{display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.metodo-btn span{font-size:.67rem;font-weight:700}
.metodo-btn:hover{border-color:var(--navy);color:var(--navy);background:var(--cream)}
.metodo-btn:hover .mp-icon svg{stroke:var(--navy)}
.metodo-btn.sel{border-color:var(--navy);background:var(--navy);color:var(--cream)}
.metodo-btn.sel .mp-icon svg{stroke:var(--cream)}

/* Pago parcial / obs inputs en footer */
.footer-field-label{font-size:.62rem;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.25rem;margin-top:.65rem;display:block}
.footer-input{width:100%;background:#fff;border:1px solid var(--cream4);border-radius:var(--r-md);padding:.5rem .8rem;font-family:'Manrope',sans-serif;font-size:.82rem;font-weight:500;color:var(--navy);outline:none;transition:var(--transition)}
.footer-input:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(255,204,0,.12)}
.deuda-hint{font-size:.7rem;font-weight:700;margin-top:.2rem}

/* Process payment btn */
.btn-process{width:100%;padding:.75rem;background:var(--navy);color:#fff;border:none;border-radius:var(--r-md);font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:.45rem;margin-top:.5rem}
.btn-process:hover{background:var(--navy2);transform:translateY(-1px);box-shadow:0 6px 18px rgba(6,20,35,.3)}
.btn-assign{width:100%;padding:.6rem;background:transparent;color:var(--navy);border:1.5px solid var(--cream4);border-radius:var(--r-md);font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.4rem}
.btn-assign:hover{background:var(--cream2);border-color:var(--cream4)}

/* ═══ INVENTARIO ═══ */
.inv-producto{background:#fff;border-radius:var(--r-2xl);margin-bottom:.75rem;overflow:hidden;box-shadow:var(--shadow-xs);border:1px solid var(--border2);transition:var(--transition)}
.inv-producto:hover{box-shadow:var(--shadow-sm)}
.inv-producto-header{display:flex;align-items:center;justify-content:space-between;padding:.95rem 1.25rem;cursor:pointer;gap:.75rem;transition:background .15s}
.inv-producto-header:hover{background:var(--cream2)}
.inv-prod-left{display:flex;align-items:center;gap:.9rem;flex:1;min-width:0}
.inv-prod-img{width:50px;height:50px;flex-shrink:0;background:var(--cream2);border-radius:var(--r-md);border:1px solid var(--border2);overflow:hidden;display:flex;align-items:center;justify-content:center}
.inv-prod-img img{width:100%;height:100%;object-fit:contain;padding:.3rem}
.inv-prod-img-placeholder{font-size:1.4rem;color:var(--text3)}
.inv-prod-info{min-width:0;flex:1}
.inv-producto-nombre{font-weight:800;font-size:.92rem;color:var(--navy);letter-spacing:-.01em}
.inv-producto-cat{font-size:.62rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-top:.1rem}
.inv-prod-stats{display:flex;align-items:center;gap:.35rem;margin-top:.3rem;flex-wrap:wrap}
.inv-stat{font-size:.72rem;color:var(--text2);font-weight:600}
.inv-stat strong{color:var(--navy);font-weight:800}
.inv-stat-sep{color:var(--cream4)}
.inv-prod-right{display:flex;align-items:center;gap:.4rem;flex-shrink:0}
.inv-toggle-icon{font-size:.7rem;color:var(--text3);transition:var(--transition)}
.inv-tallas{border-top:1px solid var(--border2);display:none;background:var(--cream2);padding:.9rem 1.25rem}
.inv-tallas.open{display:block;animation:fadeSlide .15s ease}
.inv-tallas-scroll{display:flex;gap:.5rem;overflow-x:auto;padding-bottom:.35rem;scrollbar-width:thin}
.inv-talla-card2{background:#fff;border:1px solid var(--border2);border-radius:var(--r-lg);padding:.65rem .8rem;flex-shrink:0;min-width:90px;text-align:center;transition:var(--transition);display:flex;flex-direction:column;align-items:center;gap:.12rem}
.inv-talla-card2:hover{border-color:var(--gold);box-shadow:0 2px 8px rgba(255,204,0,.15)}
.itc-talla{font-size:.62rem;font-weight:800;color:var(--text3);text-transform:uppercase;letter-spacing:.06em}
.itc-stock{font-family:'Manrope',sans-serif;font-size:1.75rem;font-weight:700;line-height:1;margin:.08rem 0}
.itc-stock.ok{color:var(--green)}
.itc-stock.low{color:#b07800}
.itc-stock.out{color:var(--red)}
.itc-label{font-size:.58rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.15rem}
.itc-label.ok{color:var(--green)}
.itc-label.low{color:#b07800}
.itc-label.out{color:var(--red)}
.itc-precio{font-size:.68rem;font-weight:600;color:var(--text3)}
.itc-actions{display:flex;gap:.28rem;margin-top:.4rem}
.itc-actions button{background:var(--cream2);border:1px solid var(--cream4);border-radius:4px;width:25px;height:25px;font-size:.8rem;font-weight:800;cursor:pointer;color:var(--navy);display:flex;align-items:center;justify-content:center;transition:var(--transition);font-family:'Manrope',sans-serif}
.itc-actions button:hover{background:var(--navy);color:#fff;border-color:var(--gold2)}

/* ═══ ENTREGAS ═══ */
#entregas-lista{display:grid;grid-template-columns:1fr;gap:.75rem;align-items:start}
@media(min-width:860px){#entregas-lista{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1300px){#entregas-lista{grid-template-columns:repeat(3,1fr)}}
.entrega-item{background:#fff;border-radius:var(--r-2xl);padding:1rem 1.25rem;box-shadow:var(--shadow-xs);border:1px solid var(--border2);transition:var(--transition)}
.entrega-item:hover{box-shadow:var(--shadow-sm)}
.entrega-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem;gap:.75rem}
.entrega-cliente{font-weight:800;font-size:.9rem;color:var(--navy)}
.entrega-meta{font-size:.68rem;font-weight:500;color:var(--text3);margin-top:.15rem}
.entrega-prenda{background:var(--cream2);border:1px solid var(--border2);border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:600;color:var(--text2)}

/* ═══ TOAST ═══ */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--navy);border-radius:var(--r-lg);padding:.75rem 1.2rem;font-size:.8rem;font-weight:600;color:#fff;box-shadow:var(--shadow-lg);z-index:999;transform:translateY(120%);opacity:0;transition:all .32s cubic-bezier(.34,1.56,.64,1);max-width:300px}
.toast.show{transform:translateY(0);opacity:1}
.toast.success{background:var(--green)}
.toast.error{background:var(--red)}

/* ═══ MISC ═══ */
.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--cream4);border-top-color:var(--navy);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty-state{text-align:center;padding:3rem 1rem;color:var(--text3)}
.empty-state .ms{font-size:40px;opacity:.15;display:block;margin-bottom:.65rem}
.empty-state p{font-size:.84rem}
.search-wrap{position:relative;flex:1;max-width:300px}
.search-wrap input{width:100%;padding:.46rem .85rem .46rem 2.2rem;background:#fff;border:1.5px solid var(--cream4);border-radius:var(--r-full);color:var(--navy);font-family:'Manrope',sans-serif;font-size:.8rem;font-weight:500;outline:none;transition:var(--transition)}
.search-wrap input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,204,0,.12)}
.search-wrap::before{content:'';position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23747781' stroke-width='2.5'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") center/contain no-repeat;pointer-events:none}
.divider{height:1px;background:var(--border2);margin:.9rem 0}
.tipo-talla-btn{flex:1;background:var(--cream2);border:2px solid var(--cream4);border-radius:var(--r-md);padding:.55rem .75rem;cursor:pointer;text-align:left;transition:var(--transition);font-family:'Manrope',sans-serif;color:var(--navy)}
.tipo-talla-btn:hover{border-color:var(--navy2)}
.tipo-talla-btn.active{border-color:var(--navy);background:var(--navy);color:#fff}
.text-muted{color:var(--text3);font-size:.8rem}
.flex{display:flex;align-items:center}
.gap-sm{gap:.4rem}.gap-md{gap:.7rem}
.filter-bar{display:flex;gap:.4rem;margin-bottom:1.1rem;flex-wrap:wrap;align-items:center}
.filter-btn{background:#fff;border:1.5px solid var(--cream4);border-radius:var(--r-full);padding:.28rem .85rem;font-size:.65rem;font-weight:800;color:var(--text2);cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:.08em;font-family:'Manrope',sans-serif}
.filter-btn:hover{border-color:var(--navy);color:var(--navy)}
.filter-btn.active{background:var(--navy);border-color:var(--navy);color:var(--gold)}
.venta-estado-row{display:flex;gap:.45rem;margin-bottom:1rem}
.estado-step{flex:1;padding:.5rem;text-align:center;border-radius:var(--r-md);font-size:.65rem;font-weight:800;background:var(--cream2);color:var(--text3);border:1.5px solid var(--cream4);text-transform:uppercase;letter-spacing:.04em}
.estado-step.activo.cotizacion{background:var(--purple-dim);color:var(--purple);border-color:var(--purple)}
.estado-step.activo.pagado{background:var(--blue-dim);color:var(--navy);border-color:var(--navy3)}
.estado-step.activo.entregado{background:var(--green-dim);color:var(--green);border-color:var(--green2)}
.estado-step.activo.anulado{background:var(--red-dim);color:var(--red);border-color:var(--red2)}
.prod-img-sq{width:40px;height:40px;flex-shrink:0;background:var(--cream2);border-radius:var(--r-sm);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.prod-img-sq img{width:100%;height:100%;object-fit:contain;padding:.25rem}

/* ═══ RESPONSIVE — MOBILE APP ═══ */
.hamburger{display:none!important}
.bottom-nav{display:none}
.carrito-fab{display:none}
.pos-vista-toggle{display:none}

/* ══ TABLET 769–1024 ══ */
@media(min-width:769px) and (max-width:1024px){
  .sidebar{width:200px;min-width:200px}
  .main{margin-left:200px}
  .content{padding:1.1rem}
  .dash-bento{grid-template-columns:1fr 1fr!important}
  .dash-card-hero,.dash-card-wide{grid-column:span 2!important}
}

/* ══ MOBILE ≤768 ══ */
@media(max-width:768px){

  /* ── Base: sin overflow horizontal en ningún lado ── */
  *{box-sizing:border-box}
  html,body{overflow-x:hidden!important;width:100%!important;max-width:100vw!important}

  /* ── Ocultar sidebar ── */
  .sidebar{display:none!important}
  .main{margin-left:0!important;width:100%!important;max-width:100vw!important}

  /* ── Topbar ── */
  .topbar{padding:.55rem .9rem;height:50px;left:0!important}
  .topbar-logo-mobile{display:block!important}
  .topbar-date{display:none}
  .topbar-right .topbar-icon-btn:first-child{display:none}

  /* ── Content: sin padding bottom extra excepto nav ── */
  .content{padding:.7rem .8rem 74px!important;overflow-x:hidden!important;width:100%!important}

  /* ── Bottom nav ── */
  .bottom-nav{
    display:flex!important;
    position:fixed;bottom:0;left:0;right:0;
    background:var(--navy);
    border-top:1px solid rgba(255,255,255,.07);
    height:62px;z-index:200;
    padding-bottom:env(safe-area-inset-bottom,0px);
    box-shadow:0 -2px 16px rgba(0,0,0,.25);
  }
  .bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;padding:.35rem 0;color:rgba(255,255,255,.38);transition:all .18s;border:none;background:transparent;font-family:'Manrope',sans-serif;position:relative}
  .bn-item.active{color:var(--gold)}
  .bn-item.active::after{content:'';position:absolute;top:0;left:25%;right:25%;height:2px;background:var(--gold);border-radius:0 0 3px 3px}
  .bn-icon{display:flex;align-items:center;justify-content:center}
  .bn-label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;line-height:1}

  /* ── Page headers compactos ── */
  .page-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1rem}
  .page-header-left h2{font-size:1.3rem}
  .page-header-right{width:100%;flex-wrap:nowrap;gap:.4rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
  .page-header-right::-webkit-scrollbar{display:none}
  .page-header-right .btn, .page-header-right .filter-btn{flex:0 0 auto;justify-content:center;min-width:max-content;white-space:nowrap}

  /* ── Dashboard bento → una columna ── */
  .dash-bento{grid-template-columns:1fr!important;gap:.65rem}
  .dash-card-hero,.dash-card-wide{grid-column:span 1!important}
  .dash-card-stats{flex-direction:row}
  .dash-stat-sep{height:40px}

  /* ── POS MÓVIL: sistema de 2 vistas con tabs ── */
  .pos-layout{
    display:block!important;
    height:calc(100vh - 50px - 62px - env(safe-area-inset-bottom,0px))!important;
    position:relative;overflow:hidden;
  }

  /* Tab switcher catálogo / carrito */
  .pos-vista-toggle{
    display:flex!important;
    background:#fff;border-radius:10px;padding:3px;
    margin-bottom:.65rem;border:1px solid var(--border2);
  }
  .pvt-btn{
    flex:1;padding:.45rem;border:none;border-radius:8px;cursor:pointer;
    font-family:'Manrope',sans-serif;font-size:.72rem;font-weight:800;
    text-transform:uppercase;letter-spacing:.05em;transition:all .2s;
    background:transparent;color:var(--text3);
  }
  .pvt-btn.active{background:var(--navy);color:#fff}
  .pvt-count{
    display:inline-flex;align-items:center;justify-content:center;
    background:var(--gold);color:var(--navy);
    font-size:9px;font-weight:900;
    width:16px;height:16px;border-radius:50%;margin-left:4px;
  }

  /* Vista catálogo */
  .pos-vista-catalogo{
    display:block;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding-bottom:.5rem;
  }
  .pos-vista-carrito{
    display:none;
    height:100%;
    flex-direction:column;overflow:hidden;
    background:var(--cream);
  }

  /* Cuando se activa la vista carrito */
  .pos-vista-catalogo.hidden{display:none!important}
  .pos-vista-carrito.visible{display:flex!important}

  /* Ocultar el panel carrito desktop en móvil */
  .pos-carrito{display:none!important}

  /* Cards de producto: 2 columnas */
  #pos-productos-grid{
    grid-template-columns:repeat(2,1fr)!important;
    gap:.55rem!important;
  }

  /* Carrito móvil dentro de vista */
  .carrito-mobile-wrapper{
    flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding:.7rem .8rem;background:var(--cream);
  }
  .carrito-mobile-footer{
    background:#fff;border-top:1px solid var(--border2);
    padding:.75rem .9rem;flex-shrink:0;
  }

  /* ── Tablas: sin scroll horizontal — diseño card por fila ── */
  .table-wrap{overflow:hidden!important;border-radius:var(--r-xl)}
  table{min-width:unset!important;width:100%!important;font-size:.78rem}
  /* Ocultar columnas menos importantes */
  .col-hide-mobile{display:none!important}
  th,td{padding:.55rem .7rem!important;font-size:.76rem}
  th{font-size:.54rem!important}

  /* ── Filtros: scroll horizontal suave ── */
  .filter-bar{
    display:flex!important;flex-wrap:nowrap!important;
    overflow-x:auto!important;-webkit-overflow-scrolling:touch;
    padding-bottom:.2rem;gap:.35rem;
    scrollbar-width:none;margin-bottom:.75rem;
  }
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-btn{white-space:nowrap;flex-shrink:0}
  .search-wrap{min-width:160px;flex-shrink:0}

  /* ── Inventario ── */
  .inv-producto-header{flex-wrap:nowrap}
  .inv-prod-right .btn{padding:.28rem .5rem;font-size:.62rem}
  .inv-tallas-scroll{flex-wrap:wrap!important}
  .inv-talla-card2{min-width:70px}
  .badge{font-size:.56rem;padding:.15rem .4rem}

  /* ── Stats grid: 2 cols ── */
  .stats-grid{grid-template-columns:repeat(2,1fr)!important;gap:.55rem}
  .stat-card{padding:1rem 1.1rem}
  .stat-value{font-size:1.6rem}

  /* ── Modales: bottom sheet ── */
  .modal-overlay{align-items:flex-end!important;padding:0!important}
  .modal{
    max-width:100%!important;width:100%!important;
    max-height:90vh!important;
    border-radius:20px 20px 0 0!important;
    margin:0!important;
  }
  .modal-lg{max-width:100%!important}
  .modal-header{border-radius:20px 20px 0 0!important}

  /* Modal producto: una columna */
  #modal-producto [style*="grid-template-columns:200px"]{
    display:flex!important;flex-direction:column!important;
  }
  #modal-producto .modal{max-height:90vh;overflow-y:auto}

  /* Form grids: una columna */
  .form-grid,.form-grid.cols3{grid-template-columns:1fr!important}
  .field-span2{grid-column:span 1!important}

  /* ── Dash bento cards compactas ── */
  .dash-card{padding:1rem 1.1rem}
  /* ════════════════════════════════════════
     RESPONSIVE MÓVIL — iPhone Safari
     Todos los módulos prioritarios
     ════════════════════════════════════════ */

  /* ── iPhone: evitar zoom en inputs ── */
  input,select,textarea{font-size:16px!important}

  /* ── Topbar mejorado ── */
  .topbar-title{font-size:.82rem;font-weight:800;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .topbar-badge{font-size:.6rem;padding:.15rem .45rem}

  /* ── DASHBOARD ── */
  .dash-card-hero{padding:1.1rem 1.2rem}
  .dash-hero-amount{font-size:2rem!important}
  .dash-hero-sub{font-size:.72rem}
  .dash-bento .dash-card-alert{order:-1}
  .dash-card-actividad .actividad-item{padding:.55rem 0}
  .dash-resumen-row{flex-direction:column;gap:.35rem}
  .dash-resumen-item{flex-direction:row;justify-content:space-between;align-items:center;padding:.5rem .7rem;background:var(--cream2);border-radius:8px}

  /* ── POS — mejoras iPhone ── */
  .pos-search-input{font-size:16px!important;padding:.65rem 1rem .65rem 2.5rem}
  #pos-productos-grid{grid-template-columns:repeat(2,1fr)!important;gap:.5rem!important}
  /* Cards de producto más compactas */
  .prod-card{border-radius:12px}
  .prod-card-img{aspect-ratio:1/1}
  .prod-card-body{padding:.6rem .65rem .75rem}
  .prod-card-nombre{font-size:.82rem}
  .prod-card-precio{font-size:.75rem}
  /* Tallas: scroll horizontal en móvil */
  .prod-tallas-wrap{display:flex;flex-wrap:wrap;gap:3px;max-height:72px;overflow:hidden}

  /* ── VENTAS / DEUDAS ── */
  /* Ocultar tabla, mostrar cards (el JS ya las genera) */
  .ventas-table-wrap{display:none!important}
  .ventas-cards-wrap{display:flex!important;flex-direction:column;gap:.55rem}
  /* Filtros en scroll horizontal */
  .ventas-filtros{display:flex;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:.35rem;padding-bottom:.3rem;scrollbar-width:none;margin-bottom:.75rem;flex-wrap:nowrap}
  .ventas-filtros::-webkit-scrollbar{display:none}
  .ventas-filtros .filter-btn{white-space:nowrap;flex-shrink:0;padding:.35rem .75rem;font-size:.72rem}
  /* Search en ventas */
  #ventas-search-input{width:100%!important;box-sizing:border-box}
  /* Cards de venta: más espacio táctil */
  .venta-card{padding:.8rem .9rem;border-radius:12px;min-height:72px}
  .venta-card-nombre{font-size:.88rem;font-weight:800}
  .venta-card-meta{font-size:.68rem;margin-top:.15rem}
  .venta-card-acciones{margin-top:.55rem;display:flex;gap:.4rem;flex-wrap:wrap}
  .venta-card-acciones button{padding:.38rem .7rem;font-size:.72rem;border-radius:8px;min-height:34px}

  /* ── ENTREGAS ── */
  #entregas-lista{grid-template-columns:1fr!important}
  /* Buscador + filtro */
  #page-entregas .search-wrap{width:100%!important;margin-bottom:.5rem}
  #entregas-filtro-prenda{width:100%!important;box-sizing:border-box;margin-bottom:.5rem}
  #entregas-search-alumno{width:100%!important}
  /* Cards de entrega */
  .entrega-item{border-radius:12px;padding:.8rem .9rem}
  .entrega-header{flex-direction:column;align-items:flex-start;gap:.55rem}
  .entrega-cliente{font-size:.9rem}
  .entrega-meta{font-size:.68rem}
  /* Items de prenda en entrega */
  .entrega-item > div > div[style*="display:flex;align-items:center;gap:.65rem"]{
    padding:.5rem .6rem;
  }
  /* Botón entregar: más grande para el dedo */
  .btn-success.btn-sm{
    padding:.45rem .9rem!important;
    font-size:.75rem!important;
    min-height:36px;
    border-radius:8px!important;
  }
  /* Botón "Entregar todo" */
  #entregas-lista .btn-primary{
    padding:.45rem .9rem;
    font-size:.75rem;
    min-height:36px;
  }
  /* Barra de progreso */
  .entrega-prog-bar{height:5px!important}

  /* ── INVENTARIO COMPACTO ── */
  .inv-producto{margin-bottom:.45rem!important}
  .inv-producto-header{padding:.6rem .8rem!important;gap:.5rem!important}
  .inv-prod-img{width:40px!important;height:40px!important;border-radius:6px!important}
  .inv-prod-img img{padding:.15rem!important}
  .inv-producto-nombre{font-size:.82rem!important}
  .inv-producto-cat{font-size:.55rem!important;margin-top:.05rem!important}
  .inv-prod-stats{font-size:.65rem!important;gap:.3rem!important;margin-top:.1rem!important}
  .inv-prod-right{gap:.25rem!important;flex-wrap:nowrap!important}
  .inv-prod-right .btn{padding:.2rem .45rem!important;font-size:.6rem!important;min-height:28px!important}
  .inv-tallas-scroll{
    overflow-x:auto!important;-webkit-overflow-scrolling:touch;
    flex-wrap:nowrap!important;padding-bottom:.3rem;
    scrollbar-width:none;
  }
  .inv-tallas-scroll::-webkit-scrollbar{display:none}
  .inv-talla-card2{
    flex-shrink:0!important;
    min-width:68px!important;
    padding:.4rem .5rem!important;
  }

  /* ── MOVIMIENTOS → Cards móvil ── */
  .mov-table-wrap{display:none!important}
  .mov-cards-wrap{display:flex!important;flex-direction:column;gap:.45rem}
  .mov-card{
    background:#fff;border:1px solid var(--border2);border-radius:12px;padding:.7rem .85rem;
  }
  .mov-card-top{display:flex;align-items:center;justify-content:space-between;gap:.4rem}
  .mov-card-producto{font-size:.82rem;font-weight:700;color:var(--navy)}
  .mov-card-qty{font-size:.78rem;font-weight:800}
  .mov-card-mid{display:flex;align-items:center;gap:.4rem;margin-top:.3rem;flex-wrap:wrap}
  .mov-card-bottom{font-size:.68rem;color:var(--text3);margin-top:.25rem;line-height:1.3}

  /* ── CLIENTES → Cards móvil ── */
  .cl-table-wrap{display:none!important}
  .cl-cards-wrap{display:flex!important;flex-direction:column;gap:.45rem}
  .cl-card{
    background:#fff;border:1px solid var(--border2);border-radius:12px;padding:.7rem .85rem;
  }
  .cl-card-top{display:flex;align-items:center;justify-content:space-between;gap:.4rem}
  .cl-card-nombre{font-size:.85rem;font-weight:800;color:var(--navy)}
  .cl-card-mid{display:flex;align-items:center;gap:.35rem;margin-top:.25rem;flex-wrap:wrap}
  .cl-card-bottom{font-size:.68rem;color:var(--text3);margin-top:.2rem}
  .cl-card-actions{display:flex;gap:.3rem;margin-top:.35rem}

  /* ── BOTTOM SHEETS — iPhone safe area ── */
  .bs-panel{
    padding-bottom:max(env(safe-area-inset-bottom,0px), 16px)!important;
    max-height:92vh!important;
  }
  #bs-carrito,#bs-venta,#bs-abono,#bs-cobro,
  #bs-editar-entrega,#bs-anular,#slideup-entrega{
    padding-bottom:max(env(safe-area-inset-bottom,0px),16px)!important;
  }
  /* Botones de BS más grandes */
  .bs-panel button[onclick*="confirmar"],
  .bs-panel button[onclick*="cerrar"]{
    min-height:48px;
    font-size:.85rem!important;
  }

  /* ── MODALES → bottom sheet en iPhone ── */
  .modal-overlay{
    align-items:flex-end!important;
    padding:0!important;
    padding-bottom:env(safe-area-inset-bottom,0px)!important;
  }
  .modal{
    border-radius:20px 20px 0 0!important;
    max-height:88vh!important;
    padding-bottom:env(safe-area-inset-bottom,0px)!important;
  }

  /* ── BOTONES: tamaño táctil mínimo 44px (Apple HIG) ── */
  .btn{min-height:36px}
  .btn-sm{min-height:32px!important;padding:.35rem .7rem!important}
  .btn-primary,.btn-success,.btn-gold{min-height:40px}

  /* ── Textos: legibilidad en pantalla pequeña ── */
  .badge{font-size:.6rem!important;padding:.15rem .45rem!important}
  .text-muted{font-size:.75rem}

  /* ── Page header en móvil ── */
  .page-header{margin-bottom:.75rem!important;align-items:center!important}
  .page-header-left p{font-size:.6rem!important}
  .page-header-left h2{font-size:1.25rem!important}
  .page-header-right{gap:.35rem!important}
  .page-header-right .btn-sm{padding:.3rem .6rem!important;font-size:.62rem!important}
  .page-header-count{font-size:.65rem!important}

  /* ── Toolbar clientes móvil ── */
  .cl-toolbar{flex-direction:column!important;gap:.45rem!important;margin-bottom:.75rem!important}
  .cl-toolbar .toolbar-select{width:100%!important;padding:.45rem .85rem!important}
  .cl-toolbar .btn{width:100%!important;justify-content:center!important}
  .cl-search-wrap{width:100%!important;min-width:0!important}

  /* ── Scroll suave en iOS ── */
  .page,.content,#pos-productos-grid,.inv-tallas-scroll,
  #entregas-lista,#ventas-cards-wrap,.ventas-cards-wrap{
    -webkit-overflow-scrolling:touch;
  }

}

/* Cards móvil: ocultas por defecto en desktop */
.mov-cards-wrap,.cl-cards-wrap{display:none}

/* ═══ DROPDOWN STYLES ═══ */
.pos-cliente-opt{padding:.52rem .9rem;font-size:.8rem;cursor:pointer;color:var(--text);border-bottom:1px solid var(--border2);transition:background .12s;display:flex;align-items:center;justify-content:space-between}
.pos-cliente-opt:last-child{border-bottom:none}
.pos-cliente-opt:hover{background:var(--cream2)}
.pos-cliente-opt .opt-nombre{font-weight:700;color:var(--navy)}
.pos-cliente-opt .opt-grado{font-size:.68rem;color:var(--text3);margin-top:.05rem}
.pos-cliente-opt.nuevo{color:var(--green);font-weight:700}

/* ══ BUSCADOR POS ══ */
.pos-search-bar{position:relative;margin-bottom:1rem}
.pos-search-ico{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--text3);pointer-events:none;z-index:1}
.pos-search-input{width:100%;background:#fff;border:1.5px solid var(--cream4);border-radius:var(--r-full);padding:.6rem 1rem .6rem 2.5rem;font-family:'Manrope',sans-serif;font-size:.88rem;font-weight:500;color:var(--navy);outline:none;transition:border-color .15s,box-shadow .15s;box-shadow:0 1px 3px rgba(0,0,0,.05)}
.pos-search-input::placeholder{color:var(--text3);font-weight:400}
.pos-search-input::-webkit-input-placeholder{color:var(--text3);font-weight:400}
.pos-search-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(15,30,53,.08);background:#fff}


/* ═══ BOTTOM SHEET BASE ═══ */
.bs-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:300;-webkit--webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}
.bs-panel{display:none;position:fixed;bottom:0;left:50%;transform:translateX(-50%) translateY(100%);
  width:100%;background:#fff;border-radius:20px 20px 0 0;z-index:301;
  box-shadow:0 -8px 32px rgba(0,0,0,.2);transition:transform .35s cubic-bezier(.4,0,.2,1);
  padding-bottom:env(safe-area-inset-bottom,0px);
  max-height:88vh;max-height:88dvh;
  overflow:hidden;}
/* BS Pedido: pantalla completa */
#bs-pedido{
  max-height:100vh!important;max-height:100dvh!important;
  height:100vh;height:100dvh;
  border-radius:0!important;
}
.bs-handle{display:flex;justify-content:center;padding:.7rem 0 .25rem}
.bs-handle-bar{width:40px;height:4px;background:var(--cream4);border-radius:2px}

/* ═══ FAB & BS PEDIDO MOBILE ═══ */
/* FAB y BS Pedido — solo móvil */
@media(max-width:768px){
  #fab-pedido{display:flex!important}
  #fab-badge{display:flex!important}
  /* Ocultar el toggle de vistas anterior */
  .pos-vista-toggle{display:none!important}
  /* Ocultar pos-vista-carrito (panel antiguo) */
  #pos-vista-carrito{display:none!important}
  /* El catálogo ocupa todo el espacio */
  .pos-vista-catalogo{
    display:block!important;
    height:calc(100vh - 50px - 62px - env(safe-area-inset-bottom,0px))!important;
    overflow-y:auto!important;
    -webkit-overflow-scrolling:touch!important;
    padding-bottom:80px!important;
  }
}

/* ═══ BS PEDIDO — FOOTER COMPLETO ═══ */
.bsp-footer{
  -webkit-flex-shrink:0;flex-shrink:0;
  border-top:1px solid var(--border2);
  background:#fff;
  padding:1rem 1.2rem 1.1rem;
  border-radius:0 0 20px 20px;
  display:-webkit-flex;display:flex;
  -webkit-flex-direction:column;flex-direction:column;
  gap:.85rem;
}
.bsp-totales{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;gap:.2rem;}
.bsp-totales-row{
  display:-webkit-flex;display:flex;
  -webkit-justify-content:space-between;justify-content:space-between;
  -webkit-align-items:center;align-items:center;
  font-family:'Manrope',sans-serif;font-size:.8rem;font-weight:600;color:var(--text3);
}
.bsp-totales-total{
  font-size:.72rem;font-weight:900;text-transform:uppercase;
  letter-spacing:.06em;color:var(--navy);
  padding-top:.25rem;border-top:1.5px solid var(--cream4);
}
.bsp-totales-total span:last-child{font-size:1.55rem;font-weight:900;letter-spacing:-.01em;}
.bsp-field-group{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;gap:.3rem;}
.bsp-field-label{
  font-family:'Manrope',sans-serif;font-size:.6rem;font-weight:900;
  text-transform:uppercase;letter-spacing:.1em;color:var(--text3);
}
.bsp-field-input{
  width:100%;-webkit-box-sizing:border-box;box-sizing:border-box;
  background:#fff;border:1.5px solid var(--cream4);border-radius:10px;
  padding:.6rem .85rem;font-family:'Manrope',sans-serif;
  font-size:.9rem;font-weight:500;color:var(--navy);outline:none;
  -webkit-transition:border-color .15s;transition:border-color .15s;
  resize:none;-webkit-appearance:none;appearance:none;
}
.bsp-field-input::-webkit-input-placeholder{color:#b0b8c9;}
.bsp-field-input::placeholder{color:#b0b8c9;}
.bsp-field-input:focus{border-color:var(--navy);}
.bsp-field-textarea{min-height:58px;line-height:1.4;}
.bsp-metodos-grid{
  display:-webkit-grid;display:grid;
  -webkit-grid-template-columns:repeat(2,1fr);grid-template-columns:repeat(2,1fr);
  gap:.5rem;
}
.bsp-metodo-btn{
  background:#fff;border:1.5px solid var(--cream4);border-radius:12px;
  padding:.75rem .4rem .65rem;cursor:pointer;font-family:'Manrope',sans-serif;
  font-size:.72rem;font-weight:700;color:var(--text2);
  display:-webkit-flex;display:flex;
  -webkit-flex-direction:column;flex-direction:column;
  -webkit-align-items:center;align-items:center;
  gap:.38rem;
  -webkit-transition:all .15s ease;transition:all .15s ease;
  min-height:72px;-webkit-justify-content:center;justify-content:center;
  -webkit-tap-highlight-color:transparent;
}
.bsp-metodo-btn:active{-webkit-transform:scale(.97);transform:scale(.97);}
.bsp-metodo-btn svg{opacity:.75;-webkit-transition:opacity .15s;transition:opacity .15s;}
.bsp-metodo-btn.sel{background:var(--navy)!important;border-color:var(--navy)!important;color:#fff!important;}
.bsp-metodo-btn.sel svg{stroke:#fff!important;opacity:1!important;}
/* Botones método dentro del grid 4-col del BS pedido */
#bsp-metodos .bsp-metodo-btn{
  border-radius:8px;padding:.4rem .2rem;font-size:.58rem;min-height:48px;gap:.2rem;
}
.bsp-acciones{
  display:-webkit-grid;display:grid;
  -webkit-grid-template-columns:1fr 2fr;grid-template-columns:1fr 2fr;
  gap:.5rem;
}
.bsp-btn-cotizar{
  background:#fff;border:1.5px solid var(--cream4);border-radius:12px;
  padding:.75rem;font-family:'Manrope',sans-serif;
  font-size:.82rem;font-weight:700;color:var(--text2);cursor:pointer;min-height:48px;
  -webkit-transition:background .15s;transition:background .15s;
  -webkit-tap-highlight-color:transparent;
}
.bsp-btn-cobrar{
  background:var(--navy);border:none;border-radius:12px;padding:.75rem;
  font-family:'Manrope',sans-serif;font-size:.88rem;font-weight:800;color:#fff;
  cursor:pointer;min-height:48px;
  display:-webkit-flex;display:flex;
  -webkit-align-items:center;align-items:center;
  -webkit-justify-content:center;justify-content:center;
  gap:.4rem;-webkit-transition:opacity .15s;transition:opacity .15s;
  -webkit-tap-highlight-color:transparent;
}

/* ═══ ANIMATIONS ═══ */
@keyframes slideRight{
  from{opacity:0;transform:translateX(-8px)}
  to{opacity:1;transform:translateX(0)}
}
@keyframes spinOnce{
  from{transform:rotate(-180deg);opacity:0}
  to{transform:rotate(0deg);opacity:1}
}
@keyframes slideUpFade{
  from{opacity:0;transform:translateY(16px)}
  to{opacity:1;transform:translateY(0)}
}
.reposicion-item-row{
  animation:slideUpFade .25s ease both;
}

/* ══════════════════════════════════════════════════════
   LOGIN OVERLAY · v13.6  (dos columnas)
══════════════════════════════════════════════════════ */
#login-overlay{
  position:fixed;inset:0;background:var(--cream);z-index:9999;
  display:flex;flex-direction:column;overflow:hidden;
}
.lo-blob{position:absolute;border-radius:50%;pointer-events:none}
.lo-blob-1{top:-10%;left:-5%;width:40%;padding-bottom:40%;background:rgba(15,30,53,.05);filter:blur(80px)}
.lo-blob-2{bottom:-10%;right:-5%;width:50%;padding-bottom:50%;background:rgba(255,204,0,.07);filter:blur(100px)}
.lo-grid{
  flex:1;display:grid;grid-template-columns:1fr 1fr;gap:2rem;
  padding:2.5rem 4rem;align-items:center;
  max-width:1400px;margin:0 auto;width:100%;position:relative;
}
/* — Hero izquierdo — */
.lo-hero{display:flex;flex-direction:column;justify-content:center;gap:1.75rem}
.lo-hero-content{display:flex;flex-direction:column;gap:.6rem}
.lo-hero-title{
  font-size:3.4rem;font-weight:900;line-height:1.06;
  color:var(--navy);letter-spacing:-.025em;
}
.lo-hero-accent{color:var(--gold2)}
.lo-hero-sub{
  font-size:.93rem;color:var(--text2);font-weight:500;
  max-width:360px;line-height:1.65;
}
/* Tarjeta de imagen con badge glass */
.lo-hero-img-card{
  position:relative;width:100%;border-radius:var(--r-2xl);
  overflow:hidden;box-shadow:0 24px 64px rgba(15,30,53,.14);
  aspect-ratio:4/3;background:var(--navy2);
}
.lo-hero-img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .6s ease}
.lo-hero-img-card:hover .lo-hero-img{transform:scale(1.03)}
.lo-hero-img-fallback .lo-hero-img{display:none}
.lo-hero-img-fallback{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy3) 60%,var(--gold2) 100%);
}
/* Badge de cristal flotante */
.lo-hero-glass{
  position:absolute;bottom:1rem;left:1rem;right:1rem;
  display:flex;align-items:center;gap:.85rem;
  background:rgba(255,255,255,.82);backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.6);border-radius:var(--r-lg);
  padding:.7rem 1rem;box-shadow:0 4px 16px rgba(0,0,0,.08);
}
.lo-hero-badge-icon{
  width:38px;height:38px;border-radius:50%;background:var(--gold);
  display:flex;align-items:center;justify-content:center;
  color:var(--navy);flex-shrink:0;
}
.lo-hero-badge-label{font-size:.62rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text3)}
.lo-hero-badge-value{font-size:.9rem;font-weight:800;color:var(--navy)}
.lo-hero-glass-arrow{margin-left:auto;font-size:1.1rem;color:var(--navy);font-weight:700}
/* — Formulario derecho — */
.lo-form-section{display:flex;align-items:center;justify-content:flex-end}
.lo-form-card{
  width:100%;max-width:460px;background:#fff;
  border-radius:var(--r-2xl);padding:3rem 3.25rem;
  box-shadow:0 20px 60px rgba(15,30,53,.09);
  border:1px solid rgba(0,0,0,.04);
  animation:slideUpFade .3s ease both;
}
.lo-form-logo{
  display:inline-flex;align-items:center;justify-content:center;
  width:50px;height:50px;border-radius:50%;background:var(--navy);margin-bottom:1.4rem;
}
.lo-form-title{font-size:1.75rem;font-weight:800;color:var(--navy);letter-spacing:-.025em;margin-bottom:.3rem}
.lo-form-sub{font-size:.82rem;color:var(--text2);font-weight:500;margin-bottom:1.85rem;line-height:1.55}
.lo-field{margin-bottom:1.1rem}
.lo-field label{
  display:block;font-size:.67rem;font-weight:800;
  text-transform:uppercase;letter-spacing:.09em;
  color:rgba(15,30,53,.55);margin-bottom:.38rem;margin-left:.1rem;
}
.lo-input-wrap{position:relative;display:flex;align-items:center}
.lo-input-icon{
  position:absolute;left:.95rem;color:var(--text3);pointer-events:none;
  transition:color .15s;font-family:'Material Symbols Outlined';
  font-weight:300;font-style:normal;font-size:1.05rem;line-height:1;
  font-feature-settings:'liga';-webkit-font-feature-settings:'liga';
}
.lo-input-wrap:focus-within .lo-input-icon{color:var(--navy)}
.lo-input-wrap input{
  width:100%;padding:.95rem .95rem .95rem 2.9rem;
  border-radius:var(--r-lg);background:var(--cream2);
  border:none;outline:none;
  font-family:'Manrope',sans-serif;font-size:.9rem;font-weight:600;color:var(--text);
  transition:background .15s,box-shadow .15s;
}
.lo-input-wrap input:focus{background:#fff;box-shadow:0 0 0 2.5px rgba(15,30,53,.14)}
.lo-input-wrap input::placeholder{color:var(--text3);font-weight:400}
.lo-toggle-pw{
  position:absolute;right:.75rem;background:none;border:none;cursor:pointer;
  color:var(--text3);display:flex;align-items:center;padding:.25rem;
  font-family:'Material Symbols Outlined';font-size:1.05rem;line-height:1;
  font-feature-settings:'liga';-webkit-font-feature-settings:'liga';
}
.lo-toggle-pw:hover{color:var(--navy)}
.lo-error{
  background:var(--red-dim);color:var(--red);border:1px solid rgba(186,26,26,.15);
  border-radius:var(--r-md);padding:.6rem .9rem;
  font-size:.79rem;font-weight:700;margin-bottom:.9rem;
}
.lo-btn{
  width:100%;padding:.95rem 1.5rem;border-radius:var(--r-full);
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy3) 100%);
  color:#fff;font-family:'Manrope',sans-serif;font-size:.92rem;font-weight:800;
  letter-spacing:-.01em;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:.45rem;
  box-shadow:0 8px 24px rgba(15,30,53,.22);
  transition:transform .15s,box-shadow .15s;margin-top:.35rem;
}
.lo-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 32px rgba(15,30,53,.3)}
.lo-btn:active:not(:disabled){transform:scale(.98)}
.lo-btn:disabled{opacity:.65;cursor:not-allowed}
@media(max-width:900px){
  .lo-grid{grid-template-columns:1fr;padding:1.5rem;gap:0}
  .lo-hero{display:none}
  .lo-form-section{justify-content:center}
  .lo-form-card{padding:2rem 1.75rem;max-width:100%}
  .lo-form-title{font-size:1.45rem}
}

/* ── Header: info de usuario ── */
.topbar-user-info{display:flex;align-items:center;gap:.5rem;cursor:pointer}
.topbar-user-avatar{
  width:32px;height:32px;border-radius:50%;background:var(--navy);color:var(--gold2);
  font-weight:800;font-size:.72rem;display:flex;align-items:center;justify-content:center;
  overflow:hidden;flex-shrink:0;border:2px solid rgba(255,204,0,.35);
  letter-spacing:-.02em;
}
.topbar-user-avatar img{width:100%;height:100%;object-fit:cover}
.topbar-user-rol{
  font-size:.68rem;font-weight:700;border-radius:20px;padding:.2rem .55rem;
  white-space:nowrap;
}
@media(max-width:768px){
  .topbar-user-rol{display:none}
}

/* ══════════════════════════════════════════════════════
   PANEL DE CONFIGURACIÓN · v13.5
══════════════════════════════════════════════════════ */
.cfg-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem;border-bottom:2px solid var(--cream4);padding-bottom:.65rem}
.cfg-tab{
  background:transparent;border:none;padding:.42rem .9rem;border-radius:var(--r-md);
  font-family:'Manrope',sans-serif;font-size:.78rem;font-weight:700;color:var(--text3);
  cursor:pointer;transition:all .15s;
}
.cfg-tab:hover{background:var(--cream2);color:var(--navy)}
.cfg-tab.active{background:var(--navy);color:#fff}

.cfg-user-card{
  display:flex;align-items:center;gap:.75rem;
  background:#fff;border:1px solid var(--border2);border-radius:var(--r-xl);
  padding:.8rem 1rem;margin-bottom:.55rem;flex-wrap:wrap;
}
.cfg-user-avatar{
  width:36px;height:36px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:.9rem;flex-shrink:0;
  background:var(--cream2);color:var(--navy);
}
.cfg-form-card{
  background:var(--cream2);border:1.5px solid var(--cream4);border-radius:var(--r-xl);
  padding:1.1rem 1.25rem;margin-top:.75rem;
}
.cfg-form-title{font-weight:800;font-size:.9rem;color:var(--navy);margin-bottom:.85rem}
.cfg-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.65rem}
.cfg-form-field{display:flex;flex-direction:column;gap:.3rem}
.cfg-form-field label{font-size:.68rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.cfg-form-field input,.cfg-form-field select{
  border:1.5px solid var(--cream4);border-radius:var(--r-md);
  padding:.45rem .75rem;font-family:'Manrope',sans-serif;font-size:.82rem;
  color:var(--navy);background:#fff;outline:none;
}
.cfg-error{
  background:#fef2f2;border:1px solid rgba(186,26,26,.2);border-radius:8px;
  padding:.45rem .7rem;font-size:.76rem;color:var(--red);font-weight:600;
}
.cfg-hint{
  font-size:.74rem;color:var(--text3);background:var(--cream2);
  border:1px solid var(--cream4);border-radius:8px;padding:.5rem .75rem;
}
.cfg-rol-card{
  background:#fff;border:1px solid var(--border2);border-radius:var(--r-xl);
  padding:.9rem 1.1rem;margin-bottom:.65rem;
}
.cfg-upload-btn{
  display:inline-flex;align-items:center;gap:.4rem;
  background:var(--cream2);border:1.5px dashed var(--cream4);
  border-radius:var(--r-md);padding:.45rem .85rem;
  font-size:.78rem;font-weight:700;color:var(--navy);
  cursor:pointer;transition:all .15s;
}
.cfg-upload-btn:hover{background:var(--cream3);border-color:var(--navy)}

/* ══ Chips filtro ventas · v13.7 ══ */
.vf-chip{
  background:#fff;border:1.5px solid var(--cream4);
  border-radius:var(--r-full);padding:.32rem .85rem;
  font-family:'Manrope',sans-serif;font-size:.75rem;font-weight:700;
  color:var(--text2);cursor:pointer;transition:all .15s;
}
.vf-chip:hover{border-color:var(--navy);color:var(--navy)}
.vf-chip.active{background:var(--navy);color:#fff;border-color:var(--navy)}

/* ══════════════════════════════════════════════════════
   MOBILE RESPONSIVENESS & APP-LIKE FEEL (Added via Plan)
══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* 1. Page & Safe Area Adjustments */
  .page {
    padding: 1.2rem;
    padding-bottom: calc(90px + env(safe-area-inset-bottom));
  }
  .bottom-nav {
    padding-bottom: env(safe-area-inset-bottom);
    height: calc(60px + env(safe-area-inset-bottom));
  }
  .pos-vista-carrito {
    bottom: calc(70px + env(safe-area-inset-bottom)) !important;
  }

  /* 2. Responsive Tables (Card Layout) */
  .table-wrap table {
    display: block;
    width: 100%;
  }
  .table-wrap thead {
    display: none; /* Hide headers */
  }
  .table-wrap tbody {
    display: block;
    width: 100%;
  }
  .table-wrap tr {
    display: flex;
    flex-direction: column;
    background: #fff;
    border: 1px solid var(--cream4);
    border-radius: var(--r-lg);
    margin-bottom: 1rem;
    padding: 1rem;
    box-shadow: 0 4px 12px rgba(15, 30, 53, 0.04);
  }
  .table-wrap td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.4rem 0;
    border: none;
    border-bottom: 1px solid var(--cream2);
    font-size: 0.85rem;
    text-align: right;
  }
  .table-wrap td:last-child {
    border-bottom: none;
  }
  /* The data-label attribute will be added to the HTML */
  .table-wrap td::before {
    content: attr(data-label);
    font-weight: 700;
    color: var(--text3);
    text-transform: uppercase;
    font-size: 0.7rem;
    letter-spacing: 0.05em;
    text-align: left;
    margin-right: 1rem;
  }

  /* 3. Modals as Bottom Sheets */
  .modal {
    align-items: flex-end;
    padding: 0;
  }
  .modal-content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-width: 100%;
    margin: 0;
    border-radius: 24px 24px 0 0;
    padding: 1.5rem;
    padding-bottom: calc(1.5rem + env(safe-area-inset-bottom));
    animation: slideUpFade 0.3s ease forwards;
  }
  /* Drag indicator */
  .modal-content::before {
    content: '';
    display: block;
    width: 40px;
    height: 5px;
    background: var(--cream4);
    border-radius: 10px;
    margin: 0 auto 1.2rem auto;
  }

  /* 4. Horizontal scroll for filters */
  .filter-bar {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .filter-bar::-webkit-scrollbar {
    display: none;
  }
  .filter-bar > * {
    flex-shrink: 0;
  }
  .cl-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 0.8rem;
  }
  .premium-daterange, .cl-search-wrap {
    width: 100%;
  }

  /* 5. Typography Tweaks */
  .page-title {
    font-size: 1.5rem;
  }
  .stat-val {
    font-size: 1.4rem;
  }

  /* 6. Overlapping Filters Fixes */
  .page-header {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
    margin-bottom: 1rem !important;
    height: auto !important;
  }
  .page-header-right, .filter-bar, .ventas-filtros, .inv-tallas-scroll {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    width: 100% !important;
    gap: 8px !important;
    padding: 4px 0 !important;
    scrollbar-width: none !important;
  }
  .page-header-right::-webkit-scrollbar, .filter-bar::-webkit-scrollbar, .ventas-filtros::-webkit-scrollbar, .inv-tallas-scroll::-webkit-scrollbar {
    display: none !important;
  }
  .page-header-right > *, .filter-bar > *, .ventas-filtros > *, .inv-tallas-scroll > * {
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }
}
