/* Ordey Operador — Sistema de diseño (marca) */
:root{
  --primary:#006d37; --primary-container:#2ecc71; --on-primary:#ffffff; --on-primary-container:#005027;
  --secondary:#505f78; --tertiary:#006397; --surface:#f8f9fa; --surface-1:#ffffff; --surface-2:#eef1f0;
  --on-surface:#191c1d; --on-surface-variant:#6b7785; --outline:#c3c8c4; --outline-variant:#dde3df;
  --error:#ba1a1a; --amber:#b45309; --purple:#6750a4;
  --radius:14px; --radius-lg:20px; --radius-pill:999px;
  --shadow:0 2px 10px rgba(20,30,25,.08); --shadow-lg:0 8px 28px rgba(20,30,25,.16);
  --safe-b:env(safe-area-inset-bottom,0px); --safe-t:env(safe-area-inset-top,0px);
  --tabbar-h:64px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--surface);color:var(--on-surface);
  overscroll-behavior-y:none;-webkit-font-smoothing:antialiased;
}
#app{min-height:100%;display:flex;flex-direction:column}
.material-symbols-outlined{font-variation-settings:'FILL' 0,'wght' 400,'GRAD' 0,'opsz' 24;user-select:none}
.fill{font-variation-settings:'FILL' 1}
a{color:var(--tertiary);text-decoration:none}
button{font-family:inherit}
.hidden{display:none!important}

/* App bar */
.appbar{position:sticky;top:0;z-index:30;background:var(--surface-1);border-bottom:1px solid var(--outline-variant);
  padding:calc(12px + var(--safe-t)) 16px 12px;display:flex;align-items:center;gap:12px}
.appbar h1{font-size:18px;font-weight:700;margin:0;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.appbar .iconbtn{color:var(--on-surface-variant)}
.iconbtn{background:none;border:none;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--on-surface);cursor:pointer}
.iconbtn:active{background:var(--surface-2)}

/* Tab bar */
.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--surface-1);border-top:1px solid var(--outline-variant);
  display:flex;height:calc(var(--tabbar-h) + var(--safe-b));padding-bottom:var(--safe-b);box-shadow:0 -2px 10px rgba(20,30,25,.06)}
.tabbar a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--on-surface-variant);font-size:11px;font-weight:600}
.tabbar a.active{color:var(--primary)}
.tabbar a.active .material-symbols-outlined{font-variation-settings:'FILL' 1}

/* Topbar de marca (logo + avatar) */
.topbar{position:sticky;top:0;z-index:30;background:var(--surface-1);border-bottom:1px solid var(--outline-variant);
  padding:calc(8px + var(--safe-t)) 14px 8px;display:flex;align-items:center;gap:10px;min-height:52px}
.topbar.floating{position:absolute;left:8px;right:8px;top:calc(8px + var(--safe-t));border:1px solid var(--outline-variant);
  border-radius:16px;box-shadow:var(--shadow);padding:8px 12px}
.topbar .brand{height:24px;object-fit:contain}
.topbar .tb-title{flex:1;font-weight:700;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:none;overflow:hidden;border:none;cursor:pointer}
.avatar img{width:100%;height:100%;object-fit:cover}

/* Screen container */
.screen{flex:1;display:flex;flex-direction:column;padding-bottom:calc(var(--tabbar-h) + var(--safe-b))}
.screen.full{padding-bottom:0}
.pad{padding:16px}
.scroll{overflow-y:auto;-webkit-overflow-scrolling:touch}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius);
  padding:14px 18px;font-size:15px;font-weight:600;cursor:pointer;width:100%;transition:transform .05s}
.btn:active{transform:scale(.985)}
.btn-primary{background:var(--primary-container);color:var(--on-primary-container)}
.btn-solid{background:var(--primary);color:#fff}
.btn-tonal{background:var(--surface-2);color:var(--on-surface)}
.btn-outline{background:transparent;color:var(--on-surface);border:1px solid var(--outline)}
.btn-danger{background:#ffe5e5;color:var(--error)}
.btn[disabled]{opacity:.55;pointer-events:none}
.btn-sm{padding:9px 12px;font-size:13px;width:auto;border-radius:10px}

/* Cards & rows */
.card{background:var(--surface-1);border:1px solid var(--outline-variant);border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.row{display:flex;align-items:center;gap:12px;padding:14px 16px}
.row+.row{border-top:1px solid var(--outline-variant)}
.muted{color:var(--on-surface-variant)}
.tiny{font-size:12px}
.title{font-size:15px;font-weight:600}
.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Chips */
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:600}
.chip .material-symbols-outlined{font-size:14px}
.chip-pending{background:#eceff1;color:#5b6770}
.chip-assigned{background:#e2eef6;color:#006397}
.chip-in_route{background:#fdeede;color:#b45309}
.chip-arrived{background:#eee7f7;color:#6750a4}
.chip-completed{background:#e3f5ea;color:#005027}
.chip-failed{background:#ffe5e5;color:#ba1a1a}
.chip-returned{background:#d7f0ec;color:#0f766e}

/* Sequence badge */
.seq{width:30px;height:30px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex:none}

/* FAB */
.fab{position:fixed;right:16px;bottom:calc(var(--tabbar-h) + var(--safe-b) + 16px);z-index:35;background:var(--primary);color:#fff;
  border:none;border-radius:18px;height:56px;padding:0 20px;display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;box-shadow:var(--shadow-lg)}

/* Map */
.map{position:absolute;inset:0}
.map-wrap{position:relative;flex:1;min-height:0}

/* Bottom sheet — siempre por encima del tab bar, nunca lo tapa */
.sheet{position:fixed;left:0;right:0;bottom:calc(var(--tabbar-h) + var(--safe-b));z-index:45;background:var(--surface-1);
  border-radius:22px 22px 0 0;box-shadow:0 -6px 30px rgba(20,30,25,.18);
  height:78vh;max-height:78vh;will-change:transform;display:flex;flex-direction:column}
.sheet-drag{touch-action:none;cursor:grab;flex:none;user-select:none}
.sheet-drag:active{cursor:grabbing}
.sheet-grip{padding:10px 0 6px;display:flex;justify-content:center}
.sheet-grip span{width:42px;height:5px;border-radius:3px;background:var(--outline)}
.sheet-head{padding:0 16px 10px;display:flex;align-items:center;gap:10px}
.sheet-body{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 12px 16px;flex:1}

/* Forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:600;color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}
.input,.field input,.field select,.field textarea{width:100%;padding:13px 14px;border:1px solid var(--outline-variant);border-radius:12px;background:var(--surface-1);font-size:15px;color:var(--on-surface)}
.input:focus,.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(46,204,113,.18)}
.field .err{color:var(--error);font-size:12px;margin-top:4px}

/* Toast */
#toast{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(var(--tabbar-h) + var(--safe-b) + 18px);z-index:60;
  background:#191c1d;color:#fff;padding:11px 18px;border-radius:12px;font-size:14px;box-shadow:var(--shadow-lg);opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;max-width:90vw;text-align:center}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.error{background:#ba1a1a}

/* Loading */
.spinner{width:34px;height:34px;border:3px solid var(--outline-variant);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:40px auto}
@keyframes spin{to{transform:rotate(360deg)}}
.skeleton{background:linear-gradient(90deg,#eceef0 25%,#f5f6f7 37%,#eceef0 63%);background-size:400% 100%;animation:sk 1.2s infinite;border-radius:10px}
@keyframes sk{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* Empty state */
.empty{text-align:center;color:var(--on-surface-variant);padding:48px 24px}
.empty .material-symbols-outlined{font-size:46px;opacity:.4;display:block;margin-bottom:8px}

/* Modal sheet (for forms/signature) */
.modal{position:fixed;inset:0;z-index:70;background:rgba(0,0,0,.45);display:flex;align-items:flex-end;justify-content:center}
.modal .panel{background:var(--surface-1);width:100%;max-width:560px;border-radius:22px 22px 0 0;max-height:92vh;display:flex;flex-direction:column;padding-bottom:var(--safe-b)}
.modal .panel-head{padding:16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--outline-variant);flex:none}
.modal .panel-body{overflow-y:auto;padding:16px}

/* Connectivity banner */
.offline-banner{background:var(--amber);color:#fff;font-size:12px;font-weight:600;text-align:center;padding:6px}

/* Navegación dentro de la app */
.pend-banner{position:absolute;left:8px;right:8px;top:calc(64px + var(--safe-t));z-index:25;display:flex;align-items:center;gap:6px;justify-content:center;
  background:var(--amber);color:#fff;border:none;border-radius:12px;padding:9px 12px;font-size:13px;font-weight:700;box-shadow:var(--shadow)}
.nav-overlay{position:fixed;inset:0;z-index:80;background:#000;display:flex;flex-direction:column}
.nav-map{position:absolute;inset:0}
.nav-top{position:absolute;top:0;left:0;right:0;padding:calc(10px + var(--safe-t)) 14px 12px;background:linear-gradient(180deg,rgba(0,109,55,.97),rgba(0,109,55,.9));color:#fff}
.nav-step{font-size:17px;font-weight:700;line-height:1.25;display:flex;align-items:flex-start;gap:8px}
.nav-step b{font-weight:800}
.nav-dist{font-size:13px;opacity:.92;margin-top:4px;margin-left:32px}
.nav-bottom{position:absolute;left:10px;right:10px;bottom:calc(12px + var(--safe-b));background:var(--surface-1);border-radius:16px;box-shadow:var(--shadow-lg);padding:12px 14px;display:flex;align-items:center;gap:8px}
.login{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;
  width:100%;max-width:440px;margin:0 auto;padding:24px 20px calc(24px + var(--safe-b));box-sizing:border-box}
.login .card{width:100%}
.login .logo{height:72px;object-fit:contain;margin:0 auto 30px;display:block}
.pw-wrap{position:relative}
.pw-wrap input{padding-right:44px}
.pw-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--on-surface-variant);width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px}
.btn-text{background:none;border:none;color:var(--primary);font-weight:600;width:100%;padding:8px}
/* Diálogo propio (reemplaza confirm/alert del navegador) */
.dlg-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(20,30,25,.5);backdrop-filter:blur(2px)}
.dlg{background:var(--surface,#fff);border-radius:18px;max-width:340px;width:100%;padding:22px;text-align:center;box-shadow:0 24px 60px rgba(20,30,25,.3);animation:dlgPop .18s cubic-bezier(.2,.9,.3,1.2)}
@keyframes dlgPop{from{opacity:0;transform:translateY(8px) scale(.97)}to{opacity:1;transform:none}}
.dlg .dlg-ic{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;background:#e7f0ff;color:#006397}
.dlg .dlg-ic.danger{background:#ffdad6;color:#ba1a1a}
.dlg h3{font-size:17px;font-weight:700;margin:0 0 6px}
.dlg p{color:var(--on-surface-variant);font-size:14px;margin:0 0 18px;line-height:1.45}
.dlg-actions{display:flex;gap:10px}
.dlg-actions .btn{flex:1}
.check{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--on-surface-variant);margin:4px 0 14px;cursor:pointer}
.check input{width:18px;height:18px;accent-color:var(--primary)}

/* Buscador y stepper de productos */
.search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border-radius:12px;padding:10px 12px;margin-bottom:10px}
.search input{border:none;background:none;flex:1;font-size:15px;outline:none;color:var(--on-surface)}
.stepper{display:flex;align-items:center;gap:0;border:1px solid var(--outline-variant);border-radius:10px;overflow:hidden}
.stepper button{width:34px;height:34px;border:none;background:var(--surface-1);color:var(--primary);font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center}
.stepper button:active{background:var(--surface-2)}
.stepper input{width:46px;text-align:center;border:none;border-left:1px solid var(--outline-variant);border-right:1px solid var(--outline-variant);font-size:15px;font-weight:600;outline:none;padding:6px 0}
.total-bar{position:sticky;bottom:0;background:var(--surface-1);border-top:1px solid var(--outline-variant);padding:12px 4px;display:flex;align-items:center;gap:12px;margin-top:8px}
