/* ===== Puente Venezuela — Estilos (v2, diseño pulido) ===== */
:root{
  --azul:#0c2b56;        /* coordinación */
  --azul-2:#1850a8;
  --azul-3:#2f6fd6;
  --azul-claro:#eaf2fc;
  --amarillo:#f6b510;    /* atención */
  --amarillo-2:#ffcf3f;
  --amarillo-bg:#fff7e1;
  --rojo:#d8362a;        /* urgencia */
  --rojo-bg:#fdecea;
  --verde:#1f9d57;       /* completado */
  --verde-bg:#e6f6ec;
  --gris:#eef1f6;        /* fondo */
  --gris-2:#dde3ec;
  --gris-txt:#5a6678;
  --texto:#16202e;
  --blanco:#ffffff;
  --sombra:0 1px 3px rgba(12,43,86,.07), 0 6px 16px rgba(12,43,86,.06);
  --sombra-2:0 10px 34px rgba(12,43,86,.16);
  --radio:16px;
  --radio-s:11px;
  --max:1000px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  font-family:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:
    radial-gradient(1200px 420px at 50% -160px, #e7eefb 0%, rgba(231,238,251,0) 70%),
    var(--gris);
  color:var(--texto);line-height:1.5;font-size:16px;-webkit-font-smoothing:antialiased;
}
.app-root{min-height:100vh;display:flex;flex-direction:column}
a{color:var(--azul-2)}
img{max-width:100%}

.container{width:100%;max-width:var(--max);margin:0 auto;padding:18px 16px 28px}
.section{margin-bottom:18px}
.muted{color:var(--gris-txt);font-size:.92rem}
.center{text-align:center}
.hidden{display:none !important}

/* Topbar */
.topbar{background:linear-gradient(100deg,var(--azul),#13386e);color:#fff;position:sticky;top:0;z-index:30;box-shadow:0 2px 16px rgba(12,43,86,.22);border-bottom:3px solid var(--amarillo)}
.topbar-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:10px;padding:11px 16px}
.topbar .brand{display:flex;align-items:center;gap:11px;cursor:pointer;font-weight:800;letter-spacing:.2px;font-size:1.02rem}
.topbar .flag{width:32px;height:22px;border-radius:4px;overflow:hidden;flex:0 0 auto;box-shadow:0 0 0 1px rgba(255,255,255,.3)}
.topbar .brand small{display:block;font-weight:500;opacity:.82;font-size:.68rem;letter-spacing:.2px}
.topbar .spacer{flex:1}
.btn-back{background:rgba(255,255,255,.16);color:#fff;border:none;border-radius:9px;padding:8px 13px;font-size:.9rem;cursor:pointer;font-weight:700}
.btn-back:hover{background:rgba(255,255,255,.28)}

.flag .s{height:33.34%}
.flag .y{background:#ffcc00}.flag .b{background:#0a37c4}.flag .r{background:#d31931}

/* Hero */
.hero{position:relative;overflow:hidden;color:#fff;padding:30px 18px 34px;text-align:center;
  background:
    radial-gradient(700px 280px at 18% -40px, rgba(255,255,255,.16), transparent 60%),
    radial-gradient(620px 260px at 92% 120%, rgba(47,111,214,.5), transparent 60%),
    linear-gradient(155deg,#0c2b56 0%, #16407e 60%, #1a4f9c 100%);
  box-shadow:var(--sombra-2)}
.hero .flag-band{height:9px;background:linear-gradient(90deg,#ffcc00 33.33%,#0a37c4 33.33% 66.66%,#d31931 66.66%);position:absolute;top:0;left:0;right:0}
.hero h1{font-size:1.62rem;margin:10px 0 6px;font-weight:800;letter-spacing:-.3px;text-shadow:0 2px 18px rgba(0,0,0,.25)}
.hero .sub{opacity:.94;font-size:1rem;margin:0 auto;max-width:580px}
.hero .msg{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);border-radius:var(--radio);padding:13px 16px;margin:18px auto 0;max-width:640px;font-size:.94rem;backdrop-filter:blur(4px)}

/* Cards */
.card{background:#fff;border-radius:var(--radio);box-shadow:var(--sombra);padding:18px;margin-bottom:14px;border:1px solid rgba(221,227,236,.7)}
.card h2{font-size:1.18rem;margin:0 0 10px;letter-spacing:-.2px}
.card h3{font-size:1.02rem;margin:0 0 9px}
.grid{display:grid;gap:12px}
@media(min-width:680px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}.grid-4{grid-template-columns:repeat(4,1fr)}}

/* Home big buttons */
.home-actions{display:grid;gap:14px;margin-top:18px}
@media(min-width:680px){.home-actions{grid-template-columns:1fr 1fr}}
.big-btn{display:flex;gap:15px;align-items:center;text-align:left;background:#fff;border:1px solid var(--gris-2);border-radius:var(--radio);padding:18px 20px;cursor:pointer;transition:transform .16s, box-shadow .16s, border-color .16s;box-shadow:var(--sombra);width:100%;position:relative;overflow:hidden}
.big-btn::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:var(--azul-2);opacity:.9}
.big-btn:hover{transform:translateY(-3px);box-shadow:var(--sombra-2);border-color:var(--azul-3)}
.big-btn .ic{width:56px;height:56px;border-radius:14px;flex:0 0 auto;display:flex;align-items:center;justify-content:center;font-size:1.7rem;color:#fff;box-shadow:0 6px 16px rgba(12,43,86,.18)}
.big-btn .ic.azul{background:linear-gradient(135deg,var(--azul),var(--azul-3))}
.big-btn .ic.amarillo{background:linear-gradient(135deg,#e9a200,var(--amarillo-2))}
.big-btn .ic.verde{background:linear-gradient(135deg,#178048,#27b366)}
.big-btn .ic.rojo{background:linear-gradient(135deg,#b9261c,#e2483c)}
.big-btn .t{font-weight:800;font-size:1.12rem;display:block;margin-bottom:3px;letter-spacing:-.2px}
.big-btn .d{color:var(--gris-txt);font-size:.9rem;line-height:1.35}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radio-s);padding:13px 18px;font-size:1rem;font-weight:700;cursor:pointer;transition:filter .15s, transform .1s, box-shadow .15s;text-decoration:none;font-family:inherit}
.btn:active{transform:scale(.985)}
.btn-primary{background:linear-gradient(135deg,var(--azul-2),var(--azul-3));color:#fff;box-shadow:0 4px 14px rgba(24,80,168,.28)}
.btn-primary:hover{filter:brightness(1.05)}
.btn-amarillo{background:linear-gradient(135deg,#eaa400,var(--amarillo));color:#3a2c00}
.btn-verde{background:linear-gradient(135deg,#188a4b,var(--verde));color:#fff}
.btn-rojo{background:linear-gradient(135deg,#bc281d,var(--rojo));color:#fff}
.btn-ghost{background:#fff;color:var(--azul);border:1.5px solid var(--gris-2)}
.btn-ghost:hover{background:var(--azul-claro);border-color:var(--azul-3)}
.btn-sm{padding:8px 13px;font-size:.85rem;border-radius:9px}
.btn-block{width:100%}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}

/* Forms */
.field{margin-bottom:14px}
.field label{display:block;font-weight:700;margin-bottom:6px;font-size:.92rem;color:#26344a}
.field .req{color:var(--rojo)}
input[type=text],input[type=tel],input[type=email],input[type=number],input[type=password],select,textarea{
  width:100%;padding:12px 13px;border:1.5px solid var(--gris-2);border-radius:var(--radio-s);font-size:16px;background:#fff;color:var(--texto);font-family:inherit;transition:border-color .15s, box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--azul-3);box-shadow:0 0 0 3.5px rgba(47,111,214,.16)}
textarea{min-height:86px;resize:vertical}
.help{font-size:.82rem;color:var(--gris-txt);margin-top:5px}
.err-msg{color:var(--rojo);font-size:.85rem;margin-top:5px;font-weight:700}
.input-error{border-color:var(--rojo) !important}

/* Category picker */
.cat-pick{border:1.5px solid var(--gris-2);border-radius:var(--radio-s);padding:11px 13px;margin-bottom:8px;background:#fff;transition:.14s}
.cat-pick.active{border-color:var(--azul-3);background:var(--azul-claro);box-shadow:0 2px 10px rgba(47,111,214,.1)}
.cat-pick.paused{opacity:.72;background:var(--gris);border-style:dashed}
.cat-pick .row{display:flex;align-items:center;justify-content:space-between;gap:10px;cursor:pointer}
.cat-pick .name{font-weight:700}
.cat-pick .qty{margin-top:10px}
.cat-pick.paused .row{cursor:not-allowed}

/* Alerts */
.alert{border-radius:var(--radio-s);padding:13px 15px;margin:13px 0;font-size:.92rem;display:flex;gap:11px;align-items:flex-start}
.alert .ic{font-size:1.15rem;flex:0 0 auto;line-height:1.3}
.alert-amarillo{background:var(--amarillo-bg);border:1px solid #f1d488;color:#5b4500}
.alert-rojo{background:var(--rojo-bg);border:1px solid #f3b6b0;color:#8a1c14}
.alert-azul{background:var(--azul-claro);border:1px solid #bcd3f2;color:#143f7a}
.alert-verde{background:var(--verde-bg);border:1px solid #aedabf;color:#19663a}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:3px 11px;font-size:.77rem;font-weight:800;letter-spacing:.2px}
.b-rojo{background:var(--rojo-bg);color:var(--rojo)}
.b-amarillo{background:var(--amarillo-bg);color:#856200}
.b-verde{background:var(--verde-bg);color:var(--verde)}
.b-gris{background:var(--gris-2);color:var(--gris-txt)}
.b-azul{background:var(--azul-claro);color:var(--azul-2)}

/* Levels */
.level-row{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid var(--gris-2)}
.level-row:last-child{border-bottom:none}
.level-row .nm{flex:1;font-weight:700}
.bar{height:10px;border-radius:6px;background:var(--gris-2);overflow:hidden;width:100%}
.bar > span{display:block;height:100%;border-radius:6px;transition:width .5s}
.dot{width:12px;height:12px;border-radius:50%;flex:0 0 auto}
.dot.rojo{background:var(--rojo)}.dot.amarillo{background:var(--amarillo)}.dot.verde{background:var(--verde)}.dot.gris{background:#9fabbb}

/* Goal */
.goal{position:relative;overflow:hidden;color:#fff;border-radius:var(--radio);padding:22px;text-align:center;
  background:radial-gradient(420px 160px at 80% -20px, rgba(246,181,16,.35), transparent 60%),linear-gradient(135deg,var(--azul),var(--azul-2));box-shadow:var(--sombra-2)}
.goal .num{font-size:2.5rem;font-weight:800;line-height:1;letter-spacing:-.5px}
.goal .pbar{height:18px;background:rgba(255,255,255,.2);border-radius:10px;margin:14px 0 8px;overflow:hidden}
.goal .pbar > span{display:block;height:100%;background:linear-gradient(90deg,var(--amarillo),var(--amarillo-2));border-radius:10px;transition:width .6s}
.goal .state{font-weight:800}

/* Stats */
.stats{display:grid;grid-template-columns:1fr 1fr;gap:11px}
@media(min-width:560px){.stats{grid-template-columns:repeat(3,1fr)}}
@media(min-width:820px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{background:#fff;border-radius:var(--radio-s);padding:15px;box-shadow:var(--sombra);border-left:4px solid var(--azul-2)}
.stat.amarillo{border-left-color:var(--amarillo)}.stat.rojo{border-left-color:var(--rojo)}.stat.verde{border-left-color:var(--verde)}
.stat .v{font-size:1.75rem;font-weight:800;line-height:1;letter-spacing:-.5px}
.stat .l{font-size:.8rem;color:var(--gris-txt);margin-top:4px;line-height:1.25}

/* Accordion */
.acc{border:1px solid var(--gris-2);border-radius:var(--radio-s);margin-bottom:8px;overflow:hidden;background:#fff}
.acc summary{padding:13px 15px;font-weight:700;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:"+";font-size:1.2rem;color:var(--azul-2)}
.acc[open] summary::after{content:"–"}
.acc .acc-body{padding:0 15px 15px;font-size:.92rem;color:var(--gris-txt)}

/* Tables */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radio-s)}
table.tbl{width:100%;border-collapse:collapse;font-size:.88rem;min-width:520px}
table.tbl th,table.tbl td{padding:10px 11px;text-align:left;border-bottom:1px solid var(--gris-2);white-space:nowrap}
table.tbl th{background:var(--azul-claro);color:var(--azul);font-weight:800;position:sticky;top:0}
table.tbl tr:hover td{background:#f7faff}

/* Tabs */
.tabs{display:flex;gap:7px;overflow-x:auto;padding-bottom:9px;margin-bottom:14px;-webkit-overflow-scrolling:touch}
.tab{flex:0 0 auto;padding:9px 15px;border-radius:999px;border:1.5px solid var(--gris-2);background:#fff;font-size:.88rem;font-weight:700;cursor:pointer;color:var(--gris-txt);transition:.14s}
.tab:hover{border-color:var(--azul-3);color:var(--azul-2)}
.tab.active{background:linear-gradient(135deg,var(--azul-2),var(--azul-3));color:#fff;border-color:var(--azul-2)}

/* Toast */
#toast-root{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:120;display:flex;flex-direction:column;gap:8px;width:92%;max-width:430px}
.toast{background:var(--azul);color:#fff;padding:13px 16px;border-radius:var(--radio-s);box-shadow:var(--sombra-2);font-weight:700;font-size:.92rem;animation:slideup .25s}
.toast.ok{background:linear-gradient(135deg,#188a4b,var(--verde))}.toast.err{background:linear-gradient(135deg,#bc281d,var(--rojo))}.toast.warn{background:linear-gradient(135deg,#eaa400,var(--amarillo));color:#3a2c00}
@keyframes slideup{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* Modal */
#modal-root .overlay{position:fixed;inset:0;background:rgba(12,43,86,.55);z-index:100;display:flex;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(2px)}
#modal-root .modal{background:#fff;border-radius:var(--radio);max-width:580px;width:100%;max-height:90vh;overflow:auto;box-shadow:var(--sombra-2)}
#modal-root .modal-head{padding:16px 18px;border-bottom:1px solid var(--gris-2);display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;background:#fff}
#modal-root .modal-head h3{margin:0}
#modal-root .modal-body{padding:18px}
#modal-root .x{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--gris-txt);line-height:1}

/* Codes */
.code-box{background:var(--azul-claro);border:2px dashed var(--azul-3);border-radius:var(--radio);padding:18px;text-align:center;margin:14px 0}
.code-box .code{font-size:1.9rem;font-weight:800;color:var(--azul);letter-spacing:1.5px}
.pin-box{background:var(--amarillo-bg);border:2px dashed var(--amarillo);border-radius:var(--radio);padding:14px;text-align:center;margin:12px 0}
.pin-box .pin{font-size:1.7rem;font-weight:800;letter-spacing:7px;color:#856200}

/* Loading */
.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;color:var(--gris-txt)}
.spinner{width:40px;height:40px;border:4px solid var(--gris-2);border-top-color:var(--azul-2);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Footer */
.foot{margin-top:auto;background:linear-gradient(100deg,var(--azul),#13386e);color:rgba(255,255,255,.82);text-align:center;padding:20px 16px;font-size:.82rem;border-top:3px solid var(--amarillo)}
.foot .partners{font-weight:800;color:#fff;margin-bottom:5px}

/* Empty */
.empty{text-align:center;padding:32px 16px;color:var(--gris-txt)}
.empty .big{font-size:2.1rem;margin-bottom:6px}

/* Helpers */
.flex{display:flex;gap:10px;align-items:center}
.flex-wrap{flex-wrap:wrap}
.between{justify-content:space-between}
.mt{margin-top:12px}.mt-s{margin-top:6px}.mb{margin-bottom:12px}
.nowrap{white-space:nowrap}
.pill-row{display:flex;flex-wrap:wrap;gap:6px}

/* Quick actions */
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.qa{padding:16px 10px;border-radius:var(--radio-s);border:none;font-weight:800;font-size:.92rem;cursor:pointer;color:#fff;text-align:center;line-height:1.2;box-shadow:var(--sombra);transition:transform .1s, filter .15s}
.qa:active{transform:scale(.97)}
.qa:hover{filter:brightness(1.05)}
.qa.amarillo{background:linear-gradient(135deg,#eaa400,var(--amarillo));color:#3a2c00}.qa.rojo{background:linear-gradient(135deg,#bc281d,var(--rojo))}.qa.azul{background:linear-gradient(135deg,var(--azul-2),var(--azul-3))}.qa.verde{background:linear-gradient(135deg,#188a4b,var(--verde))}.qa.gris{background:linear-gradient(135deg,#5b6b80,#71839b)}

/* ===== PRINT ===== */
.print-only{display:none}
@media print{
  body{background:#fff}
  .no-print,.topbar,.foot,#toast-root{display:none !important}
  .print-only{display:block}
  .container{max-width:100%;padding:0}
  .pallet-report,.pallet-label{box-shadow:none !important;page-break-after:always;margin:0}
}
.pallet-report{border:2px solid var(--azul);border-radius:10px;padding:22px;background:#fff}
.pallet-report h1{font-size:1.25rem;color:var(--azul);margin:0 0 4px;text-align:center}
.pallet-report .rcode{font-size:2rem;font-weight:800;text-align:center;color:var(--azul);margin:6px 0}
.pallet-report table{width:100%;border-collapse:collapse;margin-top:10px}
.pallet-report td{padding:7px 8px;border-bottom:1px solid #ddd;font-size:.92rem;vertical-align:top}
.pallet-report td.k{font-weight:700;width:42%;color:var(--azul)}
.pallet-label{border:4px solid #000;border-radius:8px;padding:22px;background:#fff;text-align:center}
.pallet-label .lcode{font-size:3rem;font-weight:900;letter-spacing:1px}
.pallet-label .lcat{font-size:1.6rem;font-weight:800;margin:6px 0;text-transform:uppercase}
.pallet-label .lrow{font-size:1.15rem;margin:6px 0;font-weight:700}
.pallet-label .qr-space{width:130px;height:130px;border:2px dashed #888;margin:14px auto 6px;display:flex;align-items:center;justify-content:center;color:#888;font-size:.8rem}
.pallet-label .lcontains{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;margin:10px 0;font-size:1.05rem;font-weight:700}
