/* ── DESIGN TOKENS + BOOTSTRAP OVERRIDES ── */
:root{
  --brand:#5C3D2E; --brand-dark:#3D2818; --brand-soft:#7A5A47; --cream:#F5ECD7;
  --bg:#FAF6EF; --surface:#fff; --text:#2C2C2C; --muted:#6c757d;
  --ok:#1e8449; --bad:#c0392b;
  --ease:cubic-bezier(.2,.7,.2,1);

  /* Override Bootstrap CSS vars con la paleta de marca */
  --bs-primary:#5C3D2E;
  --bs-primary-rgb:92,61,46;
  --bs-body-bg:#FAF6EF;
  --bs-body-color:#2C2C2C;
  --bs-body-font-family:'Inter',system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  --bs-body-font-size:14px;
  --bs-border-radius:10px;
  --bs-border-radius-sm:6px;
  --bs-border-radius-lg:14px;
  --bs-link-color:#5C3D2E;
  --bs-link-hover-color:#3D2818;
  --bs-focus-ring-color:rgba(92,61,46,.25);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:var(--bs-body-font-family);font-size:14px;}

/* ── NAVBAR (sobre .navbar de Bootstrap) ── */
.fh-nav{background:var(--brand);min-height:60px;box-shadow:0 1px 0 var(--brand-dark),0 2px 8px rgba(0,0,0,.06);padding:.4rem 0;z-index:1030;}
.fh-nav .container-fluid{padding-inline:1rem;}
.fh-brand{color:var(--cream)!important;text-decoration:none;font-weight:700;}
.fh-brand:hover{color:#fff!important;}
.fh-brand-text{font-family:Georgia,serif;font-size:15px;letter-spacing:.06em;}
.fh-logo{width:34px;height:34px;border-radius:8px;object-fit:contain;background:var(--cream);}
.fh-logo-fallback{display:flex;align-items:center;justify-content:center;background:var(--brand-dark);color:var(--cream);font-size:14px;font-weight:700;}
.fh-tab{position:relative;color:rgba(245,236,215,.75)!important;font-weight:600;font-size:13.5px;padding:.55rem .9rem!important;border-radius:8px;background:none;border:0;display:inline-flex;align-items:center;gap:.45rem;transition:color .15s var(--ease),background .15s var(--ease);}
.fh-tab i{font-size:1rem;opacity:.85;}
.fh-tab:hover{color:var(--cream)!important;background:rgba(245,236,215,.08);}
.fh-tab.active{color:var(--cream)!important;background:rgba(245,236,215,.12);}
.fh-tab.active::after{content:"";position:absolute;left:.9rem;right:.9rem;bottom:2px;height:2px;background:var(--cream);border-radius:2px;}

.fh-icon-btn{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;padding:0;border:1px solid rgba(245,236,215,.25);background:transparent;color:var(--cream);border-radius:10px;font-size:1.15rem;transition:background .15s,border-color .15s;}
.fh-icon-btn:hover,.fh-icon-btn:focus{background:rgba(245,236,215,.12);border-color:rgba(245,236,215,.55);color:#fff;}
.fh-icon-btn .bi{line-height:1;}
.fh-menu-btn{font-size:1.35rem;}

.fh-blue{color:var(--cream);font-size:12.5px;}
.fh-dot{width:8px;height:8px;border-radius:50%;background:#27ae60;display:inline-block;box-shadow:0 0 0 3px rgba(39,174,96,.18);animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}
.fh-blue .fh-icon-btn{width:30px;height:30px;font-size:.95rem;border-radius:6px;}
.fh-sync-badge{font-size:11px;font-weight:700;color:var(--cream);}

/* ── OFFCANVAS DRAWER ── */
.fh-drawer{width:min(320px,86vw);background:var(--surface);}
.fh-drawer .offcanvas-header{padding:1rem 1.25rem;}
.fh-drawer .offcanvas-title{font-family:Georgia,serif;letter-spacing:.04em;color:var(--brand);}
.fh-drawer-list{display:flex;flex-direction:column;padding:.5rem 0;overflow-y:auto;}
.fh-d-item{position:relative;display:flex;align-items:center;gap:.7rem;background:none;border:0;text-align:left;padding:.75rem 1.25rem;font-size:14px;font-weight:600;color:var(--text);transition:background .15s,color .15s;cursor:pointer;}
.fh-d-item i{font-size:1.1rem;color:var(--brand-soft);width:1.2rem;text-align:center;}
.fh-d-item:hover{background:var(--cream);}
.fh-d-item.active{background:var(--cream);color:var(--brand);}
.fh-d-item.active i{color:var(--brand);}
.fh-d-item.active::before{content:"";position:absolute;left:0;top:.5rem;bottom:.5rem;width:3px;background:var(--brand);border-radius:0 3px 3px 0;}
.fh-d-sep{height:1px;background:#eee;margin:.4rem 1.25rem;}
.fh-drawer-foot{padding:.85rem 1.25rem;background:#fafafa;}
.fh-drawer-foot .btn{font-size:12.5px;font-weight:600;border:1px solid #d8d3c5!important;background:#fff;color:var(--text);padding:.5rem .75rem;justify-content:center;}
.fh-drawer-foot .btn:hover{background:var(--cream);border-color:var(--brand-soft)!important;color:var(--brand);opacity:1;}
.page{display:none;max-width:900px;margin:24px auto;padding:0 16px 48px;}
#page-inv,#page-mov,#page-prov,#page-hist{max-width:100%;padding:0 24px 48px;}
.page.active{display:block;}
.card{background:#fff;border-radius:10px;border:1px solid #ddd;padding:20px 24px;margin-bottom:18px;}
.stitle{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#888;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid #eee;}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:13px;}
.g4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:13px;}
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:12px;color:#555;font-weight:600;}
.iw{position:relative;}
.iw .px{position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px;color:#999;pointer-events:none;}
.iw input{padding-left:26px!important;}
input[type=number],input[type=text],input[type=date],select,textarea{padding:9px 10px;border:1px solid #ccc;border-radius:6px;font-size:14px;width:100%;background:#fff;transition:border-color .2s;font-family:Arial,sans-serif;}
input:focus,select:focus,textarea:focus{outline:none;border-color:#3483fa;box-shadow:0 0 0 2px #3483fa22;}
input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;}
.btn{border:none;border-radius:7px;padding:10px 18px;font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:opacity .15s,transform .1s;}
.btn:hover{opacity:.88;}.btn:active{transform:scale(.97);}
.btn-blue{background:#3483fa;color:#fff;}.btn-green{background:#1e8449;color:#fff;}
.btn-out{background:none;border:1px solid #ccc;color:#555;}.btn-red{background:none;border:1px solid #e74c3c;color:#e74c3c;}
.btn-sm{padding:5px 12px;font-size:12px;font-weight:600;border-radius:5px;}
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;}
.metric{background:#f8f9fa;border-radius:8px;padding:10px 14px;border:1px solid #eee;}
.metric .ml{font-size:11px;color:#888;font-weight:600;text-transform:uppercase;margin-bottom:4px;}
.metric .mv{font-size:18px;font-weight:700;color:#2C2C2C;}
.metric .ms{font-size:11px;color:#aaa;margin-top:3px;}
.metric.ok{background:#eafaf1;border-color:#a9dfbf;}.metric.ok .mv{color:#1e8449;}
.metric.bad{background:#fdedec;border-color:#f1948a;}.metric.bad .mv{color:#c0392b;}
.breakdown{border:1px solid #eee;border-radius:8px;overflow:hidden;}
.br{display:flex;justify-content:space-between;padding:7px 14px;font-size:13px;border-bottom:1px solid #f0f0f0;}
.br:last-child{border:none;}
.br-total{border:none!important;font-weight:700!important;font-size:15px!important;background:#f8f9fa!important;}
.neg{color:#c0392b;}.pos{color:#1e8449;}
.top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px;}
.top-bar h2{font-size:18px;font-weight:700;}
.summary-bar{background:#2C2C2C;color:#fff;border-radius:8px;padding:14px 20px;display:flex;gap:28px;flex-wrap:wrap;margin-bottom:16px;}
.si .sl{font-size:11px;color:#aaa;display:block;}.si .sv{font-size:16px;font-weight:700;}
.tbl-wrap{overflow-x:auto;border-radius:8px;border:1px solid #ddd;min-height:50px;}
table{width:100%;border-collapse:collapse;min-width:600px;}
th{background:#2C2C2C;color:#fff;padding:10px 12px;font-size:12px;font-weight:600;text-align:left;white-space:nowrap;}
td{padding:9px 12px;font-size:13px;border-bottom:1px solid #f0f0f0;vertical-align:middle;}
.td-name{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
tr:last-child td{border:none;}tr:nth-child(even) td{background:#fafafa;}tr:hover td{background:#f0f7ff;}
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;}
.b-ok{background:#eafaf1;color:#1e8449;}.b-low{background:#fef9e7;color:#b7950b;}.b-out{background:#fdedec;color:#c0392b;}
.b-in{background:#eafaf1;color:#1e8449;}.b-sal{background:#fdedec;color:#c0392b;}.b-adj{background:#ebf5fb;color:#2980b9;}
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1050;align-items:center;justify-content:center;}
.overlay.open{display:flex;}
/* Override de .modal de Bootstrap (que pone display:none/position:fixed y rompería los modales custom) */
.overlay > .modal{display:block!important;position:static!important;background:#fff;border-radius:12px;padding:24px;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;margin:16px;z-index:auto;pointer-events:auto;inset:auto;transform:none;}
.overlay > .modal h3{font-size:16px;font-weight:700;margin-bottom:18px;padding-bottom:10px;border-bottom:1px solid #eee;}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px;}
.toast{position:fixed;bottom:24px;right:24px;background:#2C2C2C;color:#fff;padding:12px 20px;border-radius:8px;font-size:13px;z-index:400;opacity:0;transition:opacity .3s;pointer-events:none;}
.toast.show{opacity:1;}
.prod-selector{background:#f8f9fa;border:1px solid #ddd;border-radius:10px;padding:16px;margin-bottom:18px;}
.ps-top{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;}
.prod-card{display:none;align-items:center;gap:16px;background:#fff;border:1px solid #ddd;border-radius:10px;padding:14px 18px;margin-bottom:16px;}
.prod-card.visible{display:flex;}
.prod-card img{width:72px;height:72px;object-fit:cover;border-radius:8px;border:1px solid #eee;flex-shrink:0;}
.pc-info{flex:1;}.pc-name{font-size:16px;font-weight:700;color:#2C2C2C;}.pc-cat{font-size:12px;color:#888;margin-bottom:6px;}
.pc-prices{display:flex;gap:20px;flex-wrap:wrap;}.pc-price{display:flex;flex-direction:column;}
.ppl{font-size:11px;color:#888;font-weight:600;text-transform:uppercase;}.ppv{font-size:18px;font-weight:700;color:#2C2C2C;}
.pago-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;}
.pago-tab{padding:7px 14px;border-radius:20px;border:1px solid #ddd;font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;background:#fff;}
.pago-tab.active{background:#2C2C2C;color:#fff;border-color:#2C2C2C;}
.foto-upload{border:2px dashed #ddd;border-radius:8px;padding:20px;text-align:center;cursor:pointer;transition:border-color .2s;position:relative;}
.foto-upload:hover{border-color:#3483fa;}
.foto-upload input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.fecha-auto{background:#eafaf1;border:1px solid #a9dfbf;border-radius:6px;padding:8px 14px;font-size:13px;color:#1e8449;font-weight:600;display:inline-block;margin-bottom:12px;}
.ra{display:flex;gap:6px;}.empty{text-align:center;color:#aaa;font-size:13px;padding:32px;}
/* ── GRUPOS DÍA ── */
.day-group{margin-bottom:20px;}
.day-header{display:flex;align-items:center;gap:12px;padding:10px 16px;background:#2C2C2C;color:#fff;border-radius:8px 8px 0 0;font-size:13px;font-weight:700;}
.day-header .dh-date{font-size:15px;color:#5C3D2E;}
.day-header .dh-pills{display:flex;gap:8px;margin-left:auto;flex-wrap:wrap;}
.day-header .dh-pill{background:rgba(255,255,255,.1);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:600;color:#fff;}
.day-header .dh-pill.green{background:#1e8449;}
.day-header .dh-pill.red{color:#f87171;}
.day-body{border:1px solid #ddd;border-top:none;border-radius:0 0 8px 8px;overflow:hidden;}
.day-body table{min-width:700px;}
.day-body th{background:#2d2d2d;}
.scan-bar{display:flex;align-items:center;gap:12px;background:var(--cream);border:1.5px solid #d8c9a8;border-radius:12px;padding:12px 16px;margin-bottom:14px;box-shadow:0 1px 3px rgba(92,61,46,.07);}
.scan-bar .scan-icon{font-size:20px;flex-shrink:0;opacity:.7;}
.scan-bar input{flex:1;border:1.5px solid #ddd;border-radius:8px;padding:9px 14px;font-size:14px;font-family:var(--bs-body-font-family);letter-spacing:0;background:#fff;color:var(--text);}
.scan-bar input::placeholder{color:#aaa;font-style:italic;}
.scan-bar input:focus{border-color:var(--brand-soft);outline:none;box-shadow:0 0 0 3px rgba(92,61,46,.1);}
.scan-bar .scan-hint{font-size:11px;font-weight:600;color:var(--brand-soft);white-space:nowrap;letter-spacing:.03em;background:rgba(92,61,46,.08);padding:4px 8px;border-radius:5px;}
.scan-flash{animation:scanFlash .4s ease;}
@keyframes scanFlash{0%{background:#F5ECD7}50%{background:#eafaf1;border-color:#1e8449}100%{background:#F5ECD7;border-color:#5C3D2E}}
.scan-flash-bad{animation:scanFlashBad .4s ease;}
@keyframes scanFlashBad{0%{background:#F5ECD7}50%{background:#fdedec;border-color:#e74c3c}100%{background:#F5ECD7;border-color:#5C3D2E}}
/* ── RESPONSIVE: tablet (≤768px) ── */
@media(max-width:768px){
  .fh-nav .container-fluid{padding-inline:.75rem;}
  .fh-logo{width:30px;height:30px;}
  .fh-brand-text{font-size:13px;}
  .fh-blue{font-size:11px;gap:.4rem!important;}
  .fh-sync-badge{display:none;}
  .page{padding:0 12px 32px;margin:14px auto;}
  #page-inv,#page-mov,#page-prov,#page-hist{padding:0 12px 32px;}
  .card{padding:16px;margin-bottom:14px;}
  .g4{grid-template-columns:1fr 1fr;}
  .metrics{grid-template-columns:repeat(2,1fr);}
  .summary-bar{gap:14px;padding:12px 14px;font-size:12px;}
  .si .sv{font-size:14px;}
  table{min-width:520px;}
  td{padding:8px 10px;font-size:12px;}
  th{padding:8px 10px;font-size:11px;}
  .overlay > .modal{padding:18px;margin:8px;max-height:96vh;}
  .top-bar h2{font-size:16px;}
}
/* ── RESPONSIVE: phone (≤480px) ── */
@media(max-width:480px){
  body{font-size:13px;}
  input[type=number],input[type=text],input[type=date],select,textarea{font-size:16px;}
  .fh-nav .container-fluid{padding-inline:.5rem;}
  .fh-brand-text{display:none;}
  #blue-label{max-width:90px;overflow:hidden;text-overflow:ellipsis;}
  .page,#page-inv,#page-mov,#page-prov,#page-hist{padding:0 8px 24px;margin:10px auto;}
  .card{padding:12px;border-radius:8px;}
  .g2,.g3,.g4{grid-template-columns:1fr;gap:10px;}
  .metrics{grid-template-columns:1fr 1fr;gap:8px;}
  .metric{padding:8px 10px;}
  .metric .mv{font-size:15px;}
  .summary-bar{gap:10px;padding:10px 12px;flex-direction:column;align-items:flex-start;}
  .si{width:100%;display:flex;justify-content:space-between;align-items:baseline;gap:8px;}
  .si .sl{display:inline;}
  .prod-card{flex-direction:column;align-items:flex-start;padding:12px;}
  .prod-card img{width:100%;height:160px;}
  .pc-prices{gap:14px;}
  .overlay > .modal{padding:14px;margin:6px;border-radius:10px;}
  .overlay > .modal h3{font-size:15px;margin-bottom:14px;}
  .modal-actions{flex-direction:column-reverse;gap:8px;}
  .modal-actions .btn{width:100%;justify-content:center;}
  .btn{padding:11px 14px;font-size:13px;}
  .btn-sm{padding:7px 10px;}
  .scan-bar .scan-hint{display:none;}
  .scan-bar{padding:8px 10px;gap:8px;}
  .pago-tabs{gap:6px;}
  .pago-tab{padding:6px 10px;font-size:12px;}
  table{min-width:460px;}
  .td-name{max-width:130px;}
  .toast{left:12px;right:12px;bottom:12px;text-align:center;}
  .day-header{flex-wrap:wrap;padding:8px 12px;font-size:12px;}
  .day-header .dh-date{font-size:13px;}
  .day-header .dh-pills{margin-left:0;width:100%;}
}

/* ── FECA tweak: min tap targets en mobile ── */
@media(max-width:768px){
  .btn{min-height:44px;}
  .pago-tab{min-height:40px;}
  .fh-d-item{min-height:48px;}
}

/* ── POLISH: refresh visual sobre componentes existentes ── */
.card{border:1px solid #ece6da;border-radius:12px;box-shadow:0 1px 2px rgba(60,40,25,.04),0 4px 14px rgba(60,40,25,.04);}
.metric{background:#fff;border:1px solid #ece6da;border-radius:10px;box-shadow:0 1px 2px rgba(60,40,25,.03);}
.metric .ml{color:#8b7d6b;}
.metric .mv{color:var(--brand);}
.stitle{color:var(--brand-soft);border-bottom-color:#eee;}
.top-bar h2{color:var(--brand);font-family:Georgia,serif;letter-spacing:.01em;}
.summary-bar{background:linear-gradient(135deg,#3D2818,#5C3D2E);border-radius:12px;box-shadow:0 4px 14px rgba(60,40,25,.18);}
th{background:var(--brand);}
.day-header{background:var(--brand);}
.day-body th{background:var(--brand-dark);}
tr:hover td{background:#fbf7ee;}

input[type=number],input[type=text],input[type=date],input[type=email],input[type=password],select,textarea{border-color:#d8d3c5;border-radius:8px;transition:border-color .15s,box-shadow .15s;}
input:focus,select:focus,textarea:focus{border-color:var(--brand-soft)!important;box-shadow:0 0 0 3px rgba(92,61,46,.15)!important;}

.btn{border-radius:8px;letter-spacing:.01em;}
.btn-blue{background:var(--brand);color:var(--cream);}
.btn-blue:hover{background:var(--brand-dark);opacity:1;}
.btn-green{background:var(--ok);}
.btn-green:hover{background:#176b3a;opacity:1;}
.btn-out{border:1px solid #d8d3c5;color:var(--text);border-radius:8px;}
.btn-out:hover{background:var(--cream);border-color:var(--brand-soft);color:var(--brand);opacity:1;}

.pago-tab{border-radius:999px;border-color:#d8d3c5;}
.pago-tab.active{background:var(--brand);color:var(--cream);border-color:var(--brand);}

.modal{border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.25);}
.modal h3{color:var(--brand);}

.scan-bar{background:#fff;border:1px solid #ece6da;border-radius:10px;}
.scan-bar input{border-color:#d8d3c5;border-radius:8px;}

.page{margin-top:18px;}

.day-header .dh-date{color:var(--cream);}
.day-header .dh-pill{background:rgba(245,236,215,.18);}

.toast{background:var(--brand-dark);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.25);}
