
/* ── Accesibilidad ───────────────────────────────────────── */
/* Reset para <button> usados como tarjetas/items */
button.nav-item,
button.ll-row,
button.ac-card,
button.buque-card,
button.a-item,
button.bg-item,
button.sb-user,
button.ui-item,
button.mo {
  font: inherit;
  color: inherit;
  background-color: transparent;
  background-image: none;
  border: 0;
  text-align: left;
  cursor: pointer;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
}

/* Cards .hm-card: NO tocar background aquí — las clases variantes
   (.hm-card-op, .hm-card-alm, .hm-card-air...) tienen que aplicar
   sus degradados via cascada normal. Solo reset estructural. */
button.hm-card {
  font: inherit;
  color: inherit;
  border: 0;
  padding: 0;
  text-align: left;
  cursor: pointer;
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
}

/* Botones de icono pequeños: sin width:100% */
button.evt-color-swatch,
button.ib {
  font: inherit;
  color: inherit;
  border: 0;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}

/* Focus visible para teclado (no afecta a clicks de ratón) */
*:focus { outline: none; }
*:focus-visible {
  outline: 2px solid var(--b500, #3b82f6);
  outline-offset: 2px;
  border-radius: 6px;
}
.nav-item:focus-visible,
.hm-card:focus-visible,
.ll-row:focus-visible,
.ac-card:focus-visible,
.buque-card:focus-visible {
  outline-offset: -2px;
}

/* Skip link (oculto hasta foco) */
.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--b600, #2563eb);
  color: #fff;
  padding: 8px 16px;
  z-index: 99999;
  border-radius: 0 0 6px 0;
  text-decoration: none;
}
.skip-link:focus { top: 0; }

*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --safe-top:env(safe-area-inset-top,0px);--safe-bot:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);
  --w:#fff;--g50:#f8f9fa;--g100:#f1f3f5;--g200:#e9ecef;--g300:#dee2e6;--g400:#ced4da;
  --g500:#adb5bd;--g600:#6c757d;--g700:#495057;--g800:#343a40;--g900:#212529;
  --b50:#e7f1ff;--b100:#c5dbff;--b500:#3b82f6;--b600:#2563eb;--b700:#1d4ed8;
  --gr50:#f0fdf4;--gr500:#22c55e;--gr600:#16a34a;--gr700:#15803d;
  --am50:#fffbeb;--am500:#f59e0b;--am600:#d97706;
  --rd50:#fef2f2;--rd500:#ef4444;--rd600:#dc2626;
  --tl500:#14b8a6;--tl600:#0d9488;
  /* Estado buque: azul proceso, verde embarcado, rojo cancelado, naranja aplazado, gris no iniciado */
  --st-proceso-bg:#e3f2fd;--st-proceso-c:#0d47a1;--st-proceso-bd:#90caf9;--st-proceso-bar:#1565c0;
  --st-embarcado-bg:#e8f5e9;--st-embarcado-c:#1b5e20;--st-embarcado-bd:#a5d6a7;--st-embarcado-bar:#2e7d32;
  --st-cancelado-bg:#ffebee;--st-cancelado-c:#b71c1c;--st-cancelado-bd:#ef9a9a;--st-cancelado-bar:#c62828;
  --st-aplazado-bg:#fff3e0;--st-aplazado-c:#e65100;--st-aplazado-bd:#ffcc80;--st-aplazado-bar:#ef6c00;
  --st-noiniciado-bg:#f5f5f5;--st-noiniciado-c:#424242;--st-noiniciado-bd:#bdbdbd;--st-noiniciado-bar:#9e9e9e;
  --f:'Inter',sans-serif;--mono:'DM Mono',monospace;
  --r:8px;--rl:12px;--rxl:16px;
  --sh0:0 1px 3px rgba(0,0,0,.08);--sh:0 2px 8px rgba(0,0,0,.10);--shl:0 8px 24px rgba(0,0,0,.12);
  --sw:240px;--sw-collapsed:64px;--hh:56px;
}
html,body{height:100%;background:var(--g50);color:var(--g900);font-family:var(--f);font-size:14px}
/* PWA safe-area para iPhone notch y barra de gestos */
body{
  padding-top: var(--safe-top);
  padding-bottom: var(--safe-bot);
  padding-left: var(--safe-left);
  padding-right: var(--safe-right);
}
/* App screens use overflow:hidden individually, but body must allow scroll for home */
#screen-login,#app{overflow:hidden}

/* ── STATUS BADGES ── */
.st-proceso{background:var(--st-proceso-bg);color:var(--st-proceso-c);border:1px solid var(--st-proceso-bd)}
.st-embarcado{background:var(--st-embarcado-bg);color:var(--st-embarcado-c);border:1px solid var(--st-embarcado-bd)}
.st-cancelado{background:var(--st-cancelado-bg);color:var(--st-cancelado-c);border:1px solid var(--st-cancelado-bd)}
.st-aplazado{background:var(--st-aplazado-bg);color:var(--st-aplazado-c);border:1px solid var(--st-aplazado-bd)}
.st-noiniciado{background:var(--st-noiniciado-bg);color:var(--st-noiniciado-c);border:1px solid var(--st-noiniciado-bd)}

/* ── LOGIN ── */
#screen-login{position:fixed;inset:0;background:var(--w);display:flex;align-items:center;justify-content:center;z-index:999;padding:20px}
.li-wrap{width:100%;max-width:400px}
.li-logo{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.li-mark{width:52px;height:52px;background:var(--b600);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--w)}
.li-logotext{font-size:18px;font-weight:700;line-height:1.2}
.li-logotext small{display:block;font-size:12px;color:var(--g500);font-weight:400}
.li-title{font-size:24px;font-weight:700;margin-bottom:4px;text-align:center}
.li-sub{font-size:14px;color:var(--g500);margin-bottom:28px;text-align:center}
.li-card{background:var(--w);border:1px solid var(--g200);border-radius:var(--rxl);padding:32px;box-shadow:var(--shl)}
.li-err{color:var(--rd600);font-size:12px;margin-top:10px;min-height:16px;font-weight:500}

/* ── HOME ── */
#screen-home{position:fixed;inset:0;background:var(--g50);display:none;flex-direction:column;z-index:998;overflow-y:auto}
.hm-hdr{background:var(--w);border-bottom:1px solid var(--g200);padding:0 16px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;min-height:var(--hh);position:sticky;top:0;z-index:10;flex-wrap:wrap;gap:8px}
.hm-logo{display:flex;align-items:center;gap:12px}
.hm-lmark{width:32px;height:32px;background:var(--b600);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--w)}
.hm-contact{display:flex;gap:16px;font-size:11px;color:var(--g500)}
.hm-contact span{display:flex;align-items:center;gap:4px}
.hm-cert{background:#cc0000;color:#fff;font-size:9px;font-weight:600;padding:3px 7px;border-radius:4px;line-height:1.4;text-align:center}
.hm-user{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--g600)}
.hm-av{width:30px;height:30px;border-radius:50%;background:var(--b600);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--w)}
.hm-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:32px 16px 48px}
.hm-greeting{font-size:14px;color:var(--b600);font-weight:600;text-align:center;margin-top:8px;letter-spacing:.02em}
.hm-title{font-size:28px;font-weight:800;text-align:center;margin-bottom:4px;margin-top:4px;color:var(--g900);letter-spacing:-.5px}

.hm-sub{font-size:15px;color:var(--g500);text-align:center;margin-bottom:36px}
.hm-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;width:100%;max-width:960px;margin-top:8px}
.hm-card{position:relative;border-radius:20px;padding:0;cursor:pointer;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s;box-shadow:0 4px 20px rgba(0,0,0,.08);overflow:hidden;display:flex;flex-direction:column}
.hm-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,.15)}
.hm-card:active{transform:translateY(-2px)}
.hm-card-bg{position:absolute;inset:0;opacity:.08;pointer-events:none}
.hm-card-op{background:linear-gradient(145deg,#1e40af,#3b82f6)}
.hm-card-op .hm-card-bg{background:url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='80' cy='20' r='40' fill='white'/%3E%3C/svg%3E") no-repeat right -10px top -10px}
.hm-card-alm{background:linear-gradient(145deg,#0f766e,#14b8a6)}
.hm-card-air{background:linear-gradient(145deg,#1d4ed8,#6366f1)}
.hm-card-cfg{background:linear-gradient(145deg,#4b5563,#6b7280)}
.hm-card-icon{font-size:36px;padding:24px 24px 8px;position:relative;z-index:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}
.hm-card-body{padding:0 24px 24px;position:relative;z-index:1;flex:1;display:flex;flex-direction:column}
.hm-card .hm-ctitle{font-size:20px;font-weight:700;color:#fff;margin-bottom:4px}
.hm-card .hm-cdesc{font-size:13px;color:rgba(255,255,255,.75);margin-bottom:16px}
.hm-card-feats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}
.hm-card-feats span{background:rgba(255,255,255,.18);color:#fff;font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2)}
.hm-card-cta{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.2);color:#fff;font-size:13px;font-weight:600;padding:8px 18px;border-radius:10px;border:1px solid rgba(255,255,255,.3);transition:background .15s;margin-top:auto;align-self:flex-start;backdrop-filter:blur(4px)}
.hm-card:hover .hm-card-cta{background:rgba(255,255,255,.3)}
.hm-ctitle{font-size:18px;font-weight:700;margin-bottom:6px}
.hm-cdesc{font-size:13px;color:var(--g500);line-height:1.6;margin-bottom:14px}
.hm-feat{font-size:12px;color:var(--g600);display:flex;align-items:center;gap:6px;margin-bottom:5px}
.hm-feat::before{content:"→";color:var(--b500);font-size:11px}
.hm-logout{font-size:12px;color:var(--g500);cursor:pointer;background:none;border:none;font-family:var(--f);text-decoration:underline}


/* ── APP LAYOUT ── */
#app{display:none;height:100vh;flex-direction:column;overflow:hidden}
#app-hdr{background:var(--w);border-bottom:1px solid var(--g100);display:flex;align-items:center;padding:0;flex-shrink:0;box-shadow:0 1px 0 var(--g100);position:sticky;top:0;z-index:1000}
.hdr-top{display:flex;align-items:center;gap:12px;padding:0 16px;height:var(--hh);width:100%;min-width:0;position:relative}
.hdr-breadcrumb{display:flex;align-items:center;gap:6px;flex:1;min-width:0;overflow:hidden}
.hdr-bc-mod{font-size:13px;color:var(--g400);font-weight:500;white-space:nowrap;transition:color .15s}
.hdr-bc-mod:hover{color:var(--b600)}
.hdr-bc-sep{color:var(--g300);font-size:14px}
.hdr-bc-cur{font-size:13px;color:var(--g800);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hdr-search{width:220px;padding:6px 12px;font-size:12px;border-radius:20px;border:1px solid var(--g200);background:var(--g50)}
.hdr-search:focus{width:280px;border-color:var(--b400);background:var(--w);transition:width .2s}
.hdr-icon-btn{width:34px;height:34px;border-radius:9px;border:1px solid var(--g200);background:var(--w);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--g600);transition:all .15s;flex-shrink:0}
.hdr-icon-btn:hover{background:var(--g100);border-color:var(--g300);color:var(--g900);transform:translateY(-1px)}
.hdr-logout:hover{background:var(--rd50);border-color:var(--rd500);color:var(--rd600)}
.hdr-user{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:10px;cursor:pointer;border:1px solid var(--g200);background:var(--w);transition:all .15s;flex-shrink:0}
.hdr-user:hover{background:var(--g50);border-color:var(--b300)}
.hdr-av{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--b600),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.hdr-user-info{display:flex;flex-direction:column;min-width:0}
.hdr-user-name{font-size:12px;font-weight:600;color:var(--g800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px}
.hdr-user-role{font-size:10px;color:var(--g400);white-space:nowrap;text-transform:capitalize}
#app-body{flex:1;display:flex;overflow:hidden}
#sidebar{width:var(--sw);background:var(--w);border-right:1px solid var(--g200);display:flex;flex-direction:column;flex-shrink:0;overflow-y:hidden;transition:width .25s cubic-bezier(.4,0,.2,1),transform .25s;z-index:50}
#sidebar.collapsed{width:var(--sw-collapsed)}
#sidebar.collapsed .nav-item-txt{opacity:0;width:0;overflow:hidden;white-space:nowrap;display:inline-block;transition:opacity .15s,width .2s}
#sidebar.collapsed .nav-item{justify-content:center;padding:10px 0;margin:2px 8px}
#sidebar.collapsed .nav-item .ni{margin:0;font-size:18px}
#sidebar.collapsed .sb-sec{opacity:0;height:0;overflow:hidden;margin:0;padding:0}
#sidebar.collapsed .sb-user .sb-name,#sidebar.collapsed .sb-user .sb-role{opacity:0;width:0;overflow:hidden;display:inline-block}
#sidebar.collapsed .sb-av{margin:0 auto}
#sidebar.collapsed .sb-user{justify-content:center;padding:12px 8px}
#sidebar.collapsed .nb{display:none!important}
#sidebar.collapsed .sidebar-toggle-btn .ti-expand{display:none}
#sidebar.collapsed .sidebar-toggle-btn .ti-collapse{display:block}
.sidebar-toggle-btn .ti-collapse{display:none}
.nav-item-txt{transition:opacity .2s,width .2s;white-space:nowrap}
#content{flex:1;overflow-y:auto;background:var(--g50)}

/* ── HEADER ── */
.app-mark{width:30px;height:30px;background:var(--b600);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--w);flex-shrink:0}
.app-ltxt{font-size:13px;font-weight:600;margin-right:4px;white-space:nowrap}
.app-contact{display:flex;gap:12px;font-size:11px;color:var(--g500);flex:1}
.app-contact a{color:var(--g500);text-decoration:none}
.app-contact a:hover{color:var(--b600)}
.bc{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--g500)}
.bc-sep{color:var(--g300)}.bc-cur{color:var(--g800);font-weight:500}
.h-right{display:flex;align-items:center;gap:6px;flex-shrink:0}

.hdr-cert{background:#cc0000;color:#fff;font-size:9px;font-weight:600;padding:3px 7px;border-radius:4px;line-height:1.4;text-align:center;white-space:nowrap}

/* ── BARRA INFERIOR MÓVIL — rediseño táctil ── */
#mob-alm-bar{
  display:none;
  position:fixed;
  bottom:0;left:0;right:0;
  background:var(--w);
  border-top:1px solid var(--g200);
  padding:4px 2px max(8px,env(safe-area-inset-bottom));
  z-index:200;
  box-shadow:0 -2px 16px rgba(0,0,0,.10);
  gap:0;
}
#mob-alm-bar.visible{display:flex;}
.mob-alm-btn{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  padding:5px 1px 4px;
  background:none;
  border:none;
  border-radius:10px;
  cursor:pointer;
  font-family:var(--f);
  color:var(--g500);
  font-size:9.5px;
  font-weight:600;
  min-width:0;
  position:relative;
  -webkit-tap-highlight-color:transparent;
  transition:color .12s;
}
.mob-alm-btn:active{transform:scale(.88);transition:transform .08s;}
.mob-alm-btn.active{color:var(--b600);}
.mob-alm-btn .mob-icon{
  font-size:0; /* resetear emojis */
  width:26px;height:26px;
  display:flex;align-items:center;justify-content:center;
  border-radius:8px;
  background:transparent;
  transition:background .12s;
  margin-bottom:1px;
}
.mob-alm-btn.active .mob-icon{background:var(--b50);}
/* SVG icons embebidos vía mask — funcionan igual en iOS y Android */
.mob-alm-btn .mob-icon::before{
  content:'';
  display:block;
  width:20px;height:20px;
  background:var(--g400);
  -webkit-mask-repeat:no-repeat;
  mask-repeat:no-repeat;
  -webkit-mask-position:center;
  mask-position:center;
  -webkit-mask-size:contain;
  mask-size:contain;
  transition:background .12s;
}
.mob-alm-btn.active .mob-icon::before{background:var(--b600);}
#mab-llegadas .mob-icon::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l9-7 9 7v11a2 2 0 01-2 2H5a2 2 0 01-2-2z'/%3E%3Cpolyline points='9,22 9,12 15,12 15,22'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3 9l9-7 9 7v11a2 2 0 01-2 2H5a2 2 0 01-2-2z'/%3E%3Cpolyline points='9,22 9,12 15,12 15,22'/%3E%3C/svg%3E")}
#mab-carga .mob-icon::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='1' y='3' width='15' height='13'/%3E%3Cpolygon points='16,8 20,8 23,11 23,16 16,16 16,8'/%3E%3Ccircle cx='5.5' cy='18.5' r='2.5'/%3E%3Ccircle cx='18.5' cy='18.5' r='2.5'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='1' y='3' width='15' height='13'/%3E%3Cpolygon points='16,8 20,8 23,11 23,16 16,16 16,8'/%3E%3Ccircle cx='5.5' cy='18.5' r='2.5'/%3E%3Ccircle cx='18.5' cy='18.5' r='2.5'/%3E%3C/svg%3E")}
#mab-embarque .mob-icon::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 8h1a4 4 0 010 8h-1'/%3E%3Cpath d='M2 8h16v9a4 4 0 01-4 4H6a4 4 0 01-4-4V8z'/%3E%3Cline x1='6' y1='1' x2='6' y2='4'/%3E%3Cline x1='10' y1='1' x2='10' y2='4'/%3E%3Cline x1='14' y1='1' x2='14' y2='4'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 8h1a4 4 0 010 8h-1'/%3E%3Cpath d='M2 8h16v9a4 4 0 01-4 4H6a4 4 0 01-4-4V8z'/%3E%3Cline x1='6' y1='1' x2='6' y2='4'/%3E%3Cline x1='10' y1='1' x2='10' y2='4'/%3E%3Cline x1='14' y1='1' x2='14' y2='4'/%3E%3C/svg%3E")}
#mab-landed .mob-icon::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='16'/%3E%3Cline x1='8' y1='12' x2='16' y2='12'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cline x1='12' y1='8' x2='12' y2='16'/%3E%3Cline x1='8' y1='12' x2='16' y2='12'/%3E%3C/svg%3E")}
#mab-scanner .mob-icon::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M23 19a2 2 0 01-2 2H3a2 2 0 01-2-2V8a2 2 0 012-2h4l2-3h6l2 3h4a2 2 0 012 2z'/%3E%3Ccircle cx='12' cy='13' r='4'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M23 19a2 2 0 01-2 2H3a2 2 0 01-2-2V8a2 2 0 012-2h4l2-3h6l2 3h4a2 2 0 012 2z'/%3E%3Ccircle cx='12' cy='13' r='4'/%3E%3C/svg%3E")}
#mab-home .mob-icon::before{-webkit-mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3,9 12,2 21,9'/%3E%3Cpath d='M19 9v12H5V9'/%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3,9 12,2 21,9'/%3E%3Cpath d='M19 9v12H5V9'/%3E%3C/svg%3E")}
.mob-alm-btn .mob-lbl{font-size:9.5px;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:52px;}

/* ── Dots paginación swipe (indicador de tab actual) ── */
#swipe-dots{
  display:none;
  position:fixed;
  bottom:calc(max(8px,env(safe-area-inset-bottom)) + 60px);
  left:50%;transform:translateX(-50%);
  gap:5px;
  z-index:199;
  pointer-events:none;
  background:rgba(0,0,0,.18);
  padding:4px 8px;
  border-radius:20px;
  backdrop-filter:blur(4px);
}
#swipe-dots.visible{display:flex;}
.swipe-dot{
  width:6px;height:6px;
  border-radius:50%;
  background:rgba(255,255,255,.45);
  transition:all .2s cubic-bezier(.4,0,.2,1);
  flex-shrink:0;
}
.swipe-dot.active{
  width:18px;
  border-radius:4px;
  background:#fff;
}

/* ── Pull-to-refresh ── */
#ptr-indicator{
  position:fixed;
  top:calc(var(--hh) + var(--safe-top));
  left:50%;transform:translateX(-50%) translateY(-60px);
  width:36px;height:36px;
  border-radius:50%;
  background:var(--w);
  box-shadow:var(--sh);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;
  z-index:150;
  transition:transform .2s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;
}
#ptr-indicator.visible{transform:translateX(-50%) translateY(12px);}
#ptr-indicator.spinning .ptr-arrow{animation:spin .6s linear infinite;}
.ptr-arrow{display:block;transition:transform .2s;}

/* ── Modal drag handle en móvil ── */
@media(max-width:768px){
  .mh::before{
    content:'';
    position:absolute;
    top:8px;left:50%;transform:translateX(-50%);
    width:36px;height:4px;
    background:var(--g300);
    border-radius:2px;
  }
  .mh{padding-top:22px;position:relative;}

  /* Botones de acción táctil — mayor altura mínima */
  .btn{min-height:44px;padding:10px 16px;font-size:14px;}
  .btn-sm{min-height:36px;padding:7px 12px;font-size:13px;}
  .btn-full{justify-content:center;}

  /* Botones de estado en tarjetas de llegada — más altos */
  .est-btn{min-height:48px !important;padding:10px 4px !important;font-size:12px !important;}

  /* Padding inferior en las vistas con barra ── */
  #content.has-mob-bar .view.active{padding-bottom:88px;}
}

@media(max-width:768px){
  #content.has-mob-bar .view.active{padding-bottom:80px;}
}

.hamburger{display:none;background:none;border:none;color:var(--g600);font-size:18px;cursor:pointer;padding:4px;flex-shrink:0}

/* ── BUTTONS ── */
.btn{padding:7px 14px;border-radius:var(--r);border:1px solid transparent;cursor:pointer;font-family:var(--f);font-size:13px;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.btn-p{background:var(--b600);color:var(--w);border-color:var(--b600)}.btn-p:hover{background:var(--b700)}
.btn-s{background:var(--w);color:var(--g700);border-color:var(--g300)}.btn-s:hover{background:var(--g50);border-color:var(--g400)}
.btn-w{background:var(--am50);color:var(--am600);border-color:#fde68a}
.btn-d{background:var(--rd50);color:var(--rd600);border-color:#fecaca}
.btn-g{background:var(--gr50);color:var(--gr700);border-color:#bbf7d0}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-full{width:100%;justify-content:center;padding:10px}

/* ── SIDEBAR ── */
.sb-sec{padding:10px 12px 3px;font-size:10px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.8px}
.nav-item{display:flex;align-items:center;gap:10px;padding:7px 12px;border-radius:10px;margin:1px 8px;cursor:pointer;color:var(--g500);font-size:13px;font-weight:500;transition:all .15s cubic-bezier(.4,0,.2,1);user-select:none;position:relative}
.nav-item:hover{background:var(--g100);color:var(--g900);transform:translateX(2px)}
.nav-item.active{background:linear-gradient(135deg,var(--b600),#6366f1);color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.35)}
.nav-item.active:hover{transform:none}
.nav-item .ni{font-size:16px;width:22px;text-align:center;flex-shrink:0;transition:transform .15s}
.nav-item:hover .ni{transform:scale(1.15)}
.nav-item.active .ni{filter:brightness(1.3)}
.nb{margin-left:auto;background:var(--rd500);color:var(--w);font-size:10px;font-weight:600;padding:1px 6px;border-radius:10px}
.sb-bot{margin-top:auto;padding:12px;border-top:1px solid var(--g200)}
.sb-user{display:flex;align-items:center;gap:9px;padding:8px;border-radius:var(--r);cursor:pointer;transition:background .15s}
.sb-user:hover{background:var(--g100)}
.sb-av{width:30px;height:30px;border-radius:50%;background:var(--b600);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--w);flex-shrink:0}
.sb-name{font-size:12px;font-weight:600;color:var(--g800)}.sb-role{font-size:11px;color:var(--g500)}

/* ── CONTENT ── */
.view{display:none;padding:28px;animation:fi .18s ease}
.view.active{display:block}
@keyframes fi{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px;flex-wrap:wrap}
.pt{font-size:20px;font-weight:700;color:var(--g900)}

/* ── KPI ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.kpi{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);padding:18px 20px;box-shadow:var(--sh0)}
.kpi.bl{border-left:3px solid var(--b500)}.kpi.gr{border-left:3px solid var(--gr500)}
.kpi.am{border-left:3px solid var(--am500)}.kpi.rd{border-left:3px solid var(--rd500)}
.kpi-lbl{font-size:12px;color:var(--g500);font-weight:500;margin-bottom:6px}
.kpi-val{font-size:28px;font-weight:700;line-height:1}
.kpi-sub{font-size:12px;margin-top:5px;font-weight:500}
.ks-g{color:var(--gr600)}.ks-a{color:var(--am600)}.ks-r{color:var(--rd600)}

/* ── TABLE ── */
.tc{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);overflow:hidden;box-shadow:var(--sh0)}
.tbl{width:100%;border-collapse:collapse}
.tbl th{padding:10px 16px;text-align:left;font-size:11px;color:var(--g500);font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--g200);background:var(--g50);white-space:nowrap}
.tbl td{padding:12px 16px;border-bottom:1px solid var(--g100);font-size:13px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:var(--g50);cursor:pointer}
.fw{font-weight:500;color:var(--g900)}.sm{font-size:12px;color:var(--g500);margin-top:2px}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.bg{background:var(--gr50);color:var(--gr700);border:1px solid #bbf7d0}
.bb{background:var(--b50);color:var(--b700);border:1px solid var(--b100)}
.ba{background:var(--am50);color:var(--am600);border:1px solid #fde68a}
.br{background:var(--rd50);color:var(--rd600);border:1px solid #fecaca}
.bgr{background:var(--g100);color:var(--g600);border:1px solid var(--g200)}
.bt{background:#f0fdfa;color:var(--tl600);border:1px solid #99f6e4}

/* ── BUQUE CARD ── */
.buque-list{display:flex;flex-direction:column;gap:10px}
.buque-card{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);padding:16px 18px;display:flex;align-items:flex-start;gap:14px;cursor:pointer;transition:all .15s;box-shadow:var(--sh0)}
.buque-card:hover{border-color:var(--b500);box-shadow:var(--sh)}
.buque-icon{width:44px;height:44px;border-radius:var(--rl);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.buque-info{flex:1;min-width:0}
.buque-name{font-size:15px;font-weight:700;color:var(--g900);margin-bottom:3px}
.buque-meta{font-size:12px;color:var(--g500)}
.ext-link{padding:3px 8px;border-radius:6px;font-size:11px;font-weight:500;background:var(--g100);border:1px solid var(--g200);color:var(--g600);text-decoration:none;white-space:nowrap;transition:all .15s;display:inline-block}
.ext-link:hover{background:var(--b50);border-color:var(--b100);color:var(--b700)}
.prog{height:5px;background:var(--g200);border-radius:3px;overflow:hidden;width:80px;display:inline-block}
.prog-f{height:100%;border-radius:3px}
.prog-g{background:var(--gr500)}.prog-a{background:var(--am500)}.prog-r{background:var(--rd500)}

/* ── KANBAN ── */
.kb-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:12px}
.kb-col{min-width:220px;max-width:260px;flex-shrink:0}
.kb-head{padding:8px 12px;border-radius:var(--r) var(--r) 0 0;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:space-between;background:var(--g100);border:1px solid var(--g200)}
.kb-body{background:var(--w);border:1px solid var(--g200);border-top:none;border-radius:0 0 var(--r) var(--r);padding:8px;min-height:80px;display:flex;flex-direction:column;gap:6px}
.kb-item{background:var(--g50);border:1px solid var(--g200);border-radius:var(--r);padding:10px 12px;cursor:pointer;transition:all .12s}
.kb-item:hover{border-color:var(--b500);background:var(--b50)}

/* ── CALENDAR ── */
.cal-nav{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.cal-btn{background:var(--w);border:1px solid var(--g300);color:var(--g700);border-radius:var(--r);padding:5px 12px;cursor:pointer;font-family:var(--f);font-size:13px}
.cal-btn:hover{background:var(--g50)}
.cal-vbtn.active-view{background:var(--b600);color:#fff;border-color:var(--b700)}
.cal-m{font-size:16px;font-weight:700;flex:1}
.cal-legend{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.cal-leg-item{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;border:1px solid transparent}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-dh{text-align:center;font-size:10px;font-weight:600;color:var(--g400);padding:6px 0;text-transform:uppercase}
.cal-day{background:var(--w);border:1px solid var(--g200);border-radius:var(--r);min-height:100px;padding:6px 8px;transition:background .1s}
.cal-day.today{border-color:var(--b500);border-width:2px}
.cal-day.om{background:var(--g50);opacity:.4}
.cal-day.drag-over{background:var(--b50);outline:2px dashed var(--b500)}
.cal-dn{font-size:12px;font-weight:600;color:var(--g600);margin-bottom:4px}
.cal-dn-today{background:var(--b600);color:#fff;width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px}
/* Cal event tags with status colors */
.cal-ev{font-size:10px;padding:3px 6px;border-radius:4px;margin-bottom:2px;cursor:grab;line-height:1.4;display:block;border-left:3px solid transparent;user-select:none}
.cal-ev:active{cursor:grabbing;opacity:.7}
.cal-ev.st-proceso{background:var(--st-proceso-bg);color:var(--st-proceso-c);border-left-color:var(--st-proceso-bar)}
.cal-ev.st-embarcado{background:var(--st-embarcado-bg);color:var(--st-embarcado-c);border-left-color:var(--st-embarcado-bar)}
.cal-ev.st-cancelado{background:var(--st-cancelado-bg);color:var(--st-cancelado-c);border-left-color:var(--st-cancelado-bar)}
.cal-ev.st-aplazado{background:var(--st-aplazado-bg);color:var(--st-aplazado-c);border-left-color:var(--st-aplazado-bar)}
.cal-ev.st-noiniciado{background:var(--st-noiniciado-bg);color:var(--st-noiniciado-c);border-left-color:var(--st-noiniciado-bar)}
.cal-ev:hover{filter:brightness(.96)}
.cal-user-ev{font-size:10px;padding:4px 6px;border-radius:5px;margin-bottom:2px;line-height:1.35;display:block;color:#fff;cursor:pointer;box-shadow:0 1px 3px rgba(0,0,0,.12)}
.cal-user-ev:hover{filter:brightness(.94)}
.cal-user-ev small{display:block;font-size:9px;opacity:.82;margin-top:1px}

/* ── TIMELINE ── */
.tl-wrap{overflow-x:auto;background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);padding:16px;box-shadow:var(--sh0)}
.tl-ruler{display:flex;border-bottom:1px solid var(--g200);margin-left:170px;margin-bottom:10px}
.tl-rd{flex-shrink:0;text-align:center;font-size:10px;color:var(--g400);font-weight:500;padding:4px 0;border-right:1px solid var(--g100)}
.tl-row{display:flex;align-items:center;margin-bottom:7px}
.tl-lbl{width:170px;flex-shrink:0;font-size:12px;font-weight:600;color:var(--g700);padding-right:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tl-track{flex:1;position:relative;height:28px}
.tl-bar{position:absolute;height:22px;top:3px;border-radius:6px;display:flex;align-items:center;padding:0 10px;font-size:10px;font-weight:600;cursor:pointer;white-space:nowrap;overflow:hidden;transition:filter .15s}
.tl-bar:hover{filter:brightness(.95)}
.tl-b{background:var(--b50);border:1px solid var(--b100);color:var(--b700)}
.tl-g{background:var(--gr50);border:1px solid #bbf7d0;color:var(--gr700)}
.tl-today{position:absolute;top:0;bottom:0;width:2px;background:var(--rd500);opacity:.5}

/* ── ALERTS ── */
.a-item{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);padding:14px 16px;display:flex;align-items:center;gap:12px;margin-bottom:8px;cursor:pointer;transition:all .15s;box-shadow:var(--sh0)}
.a-item:hover{transform:translateX(2px);box-shadow:var(--sh)}
.a-item.crit{border-left:4px solid var(--rd500);background:var(--rd50)}
.a-item.wrn{border-left:4px solid var(--am500);background:var(--am50)}
.a-item.info{border-left:4px solid var(--b400)}
.a-icon{font-size:18px;flex-shrink:0;width:28px;text-align:center}
.a-info{flex:1}.a-title{font-weight:600;font-size:13px;margin-bottom:2px}.a-detail{font-size:12px;color:var(--g500)}

/* ── ALMACÉN ── */
.ac-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-bottom:24px}
.ac-card{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);padding:18px 14px;text-align:center;cursor:pointer;transition:all .15s;box-shadow:var(--sh0)}
.ac-card:hover{border-color:var(--b400);box-shadow:var(--sh);transform:translateY(-1px)}
.ac-icon{font-size:28px;margin-bottom:10px}.ac-lbl{font-size:13px;font-weight:600;color:var(--g800);margin-bottom:3px}.ac-desc{font-size:11px;color:var(--g500)}
.ll-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--g100);cursor:pointer;transition:background .12s}
.ll-row:last-child{border-bottom:none}.ll-row:hover{background:var(--g50)}
.ll-info{flex:1;min-width:0}.ll-ref{font-weight:600;font-size:13px;color:var(--g900)}.ll-sub{font-size:11px;color:var(--g500);margin-top:2px}
.ll-acts{display:flex;gap:6px}
.ib{width:32px;height:32px;border-radius:var(--r);border:1px solid var(--g300);background:var(--w);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .12s;flex-shrink:0}
.ib:hover{border-color:var(--b400);background:var(--b50)}

/* ── UBICACIONES ── */
.ug{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.uc{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);padding:16px;cursor:pointer;transition:all .15s;box-shadow:var(--sh0)}
.uc:hover{border-color:var(--b400);box-shadow:var(--sh)}
.uz{font-size:11px;font-weight:600;color:var(--g500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.ucv{font-size:24px;font-weight:700}.us{font-size:12px;color:var(--g500);margin-top:3px}
.ui-list{margin-top:10px;display:flex;flex-direction:column;gap:3px}
.ui-item{font-size:11px;padding:3px 8px;background:var(--g50);border-radius:6px;color:var(--g700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ── FLOTA ── */
.fg{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.fc{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);overflow:hidden;cursor:pointer;transition:all .15s;box-shadow:var(--sh0)}
.fc:hover{border-color:var(--b400);box-shadow:var(--sh)}
.fc-top{padding:14px 16px;background:var(--g50);border-bottom:1px solid var(--g200);display:flex;align-items:center;gap:10px}
.fc-body{padding:14px 16px}
.fc-row{display:flex;justify-content:space-between;margin-bottom:8px;font-size:12px}
.fc-rl{color:var(--g500);font-weight:500}.fc-rv{font-weight:600;color:var(--g800);font-family:var(--mono);font-size:11px}
.fc-links{display:flex;gap:6px;flex-wrap:wrap;padding:10px 16px;border-top:1px solid var(--g200)}

/* ── MODAL ── */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:20000;align-items:center;justify-content:center;padding:16px;backdrop-filter:blur(2px)}
.mo.open{display:flex}
.modal{background:var(--w);border:1px solid var(--g200);border-radius:var(--rxl);width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:var(--shl)}
.mh{padding:18px 22px;border-bottom:1px solid var(--g200);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--w);z-index:1}
.mt{font-size:16px;font-weight:700;color:var(--g900)}
.mc{background:none;border:none;color:var(--g400);font-size:22px;cursor:pointer;line-height:1;padding:0 4px;transition:color .12s}
.mc:hover{color:var(--g800)}
.mb{padding:22px}
.mf{padding:14px 22px;border-top:1px solid var(--g200);display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;background:var(--g50);border-radius:0 0 var(--rxl) var(--rxl)}

/* ── FORMS ── */
.fg2{margin-bottom:16px}
.fl2{display:block;font-size:12px;font-weight:600;color:var(--g700);margin-bottom:5px}
.fi{width:100%;padding:8px 12px;background:var(--w);border:1px solid var(--g300);border-radius:var(--r);color:var(--g900);font-family:var(--f);font-size:13px;outline:none;transition:border-color .15s;box-shadow:var(--sh0)}
.fi:focus{border-color:var(--b500);box-shadow:0 0 0 3px var(--b50)}
.fi::placeholder{color:var(--g400)}
textarea.fi{resize:vertical;min-height:72px}
.fs{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236c757d' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}
.fr2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fdiv{border:none;border-top:1px solid var(--g200);margin:18px 0}
.acc-bar{display:flex;gap:8px;flex-wrap:wrap;padding:10px 0;margin-bottom:4px}
.acc-btn{flex:1;min-width:90px;padding:10px 8px;border:1px solid var(--g200);border-radius:var(--r);background:var(--g50);cursor:pointer;font-size:12px;font-weight:600;color:var(--g700);text-align:center;transition:all .12s;font-family:var(--f)}
.acc-btn:hover{background:var(--b50);border-color:var(--b300);color:var(--b700)}
.acc-btn.primary{background:var(--b600);border-color:var(--b600);color:#fff}
.dl{font-size:11px;font-weight:600;color:var(--g500);text-transform:uppercase;letter-spacing:.4px;margin-bottom:3px}
.dv{font-size:13px;font-weight:500;color:var(--g900)}
.dg{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:6px}
.df{margin-bottom:12px}
.sbar{display:flex;align-items:center;gap:8px;background:var(--w);border:1px solid var(--g300);border-radius:var(--r);padding:8px 12px;margin-bottom:14px;box-shadow:var(--sh0)}
.sbar input{background:none;border:none;outline:none;color:var(--g900);font-family:var(--f);font-size:13px;flex:1}
.sbar input::placeholder{color:var(--g400)}

/* ── FOTOS ── */
.foto-area{border:2px dashed var(--g300);border-radius:var(--r);padding:20px;text-align:center;cursor:pointer;transition:all .15s;background:var(--g50)}
.foto-area:hover{border-color:var(--b400);background:var(--b50)}
.foto-area input{display:none}
.foto-prev{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:8px;margin-top:10px}
.foto-thumb{aspect-ratio:1;border-radius:var(--r);overflow:hidden;background:var(--g200)}
.foto-thumb img{width:100%;height:100%;object-fit:cover}
.foto-st{font-size:11px;color:var(--gr600);font-weight:500;margin-top:5px}

/* ── STATS ── */
.cg{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.cc{background:var(--w);border:1px solid var(--g200);border-radius:var(--rl);padding:18px;box-shadow:var(--sh0)}
.ct{font-size:12px;font-weight:600;color:var(--g500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}
.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.bar-lbl{width:120px;flex-shrink:0;font-size:12px;color:var(--g700);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:7px;background:var(--g100);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px}
.bar-val{width:28px;text-align:right;font-size:12px;color:var(--g500);flex-shrink:0}

/* ── MISC ── */
.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--g400);gap:10px;font-size:13px}
.spinner{width:18px;height:18px;border:2px solid var(--g200);border-top-color:var(--b500);border-radius:50%;animation:spin .65s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center;padding:48px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.empty-icon{font-size:36px;margin-bottom:12px;opacity:.3;line-height:1}
.empty-txt{font-size:14px;color:var(--g400);font-weight:500;max-width:260px;line-height:1.5}
.empty-svg{width:56px;height:56px;margin-bottom:14px;opacity:.25}
.info-box{background:var(--b50);border:1px solid var(--b100);border-radius:var(--r);padding:10px 14px;font-size:12px;color:var(--b700);margin-bottom:14px;line-height:1.5}
.warn-box{background:var(--am50);border:1px solid #fde68a;border-radius:var(--r);padding:10px 14px;font-size:12px;color:var(--am600);font-weight:500}
.nav-mod-btn{display:inline-flex;align-items:center;gap:4px}
.nav-mod-btn .mod-btn-txt{font-size:12px}
@media(max-width:768px){.nav-mod-btn .mod-btn-txt{display:none}}
/* ── TOAST ── */
.toast{position:fixed;bottom:24px;right:24px;background:#1a1a2e;color:#fff;padding:12px 20px;border-radius:10px;font-size:13px;font-weight:600;z-index:99999;opacity:0;transition:opacity .15s ease;pointer-events:none;box-shadow:0 4px 20px rgba(0,0,0,.45);max-width:340px;line-height:1.4;border:1px solid rgba(255,255,255,.12)}
.toast.show{opacity:1}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--g300);border-radius:3px}
@media(max-width:900px){
  .app-contact{display:none}
  .hdr-cert{display:none}
}
@media(max-width:768px){
  #sidebar{position:fixed;top:0;left:0;bottom:0;transform:translateX(-100%);box-shadow:var(--shl)}
  #sidebar.open{transform:translateX(0)}
  .hamburger{display:block}
  .mob-ov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.3);z-index:49}
  .mob-ov.show{display:block}
  .fr2{grid-template-columns:1fr}.dg{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .hm-cards{grid-template-columns:1fr}
  .kb-board{flex-direction:column}.kb-col{min-width:unset;max-width:unset}
  .hm-contact{display:none}
  .btn{padding:9px 14px;font-size:14px}
  .btn-sm{padding:7px 12px;font-size:13px}
  .fi{padding:10px 12px;font-size:16px}
  .fs{font-size:16px}
  .nav-item{padding:11px 12px}
  .tbl td,.tbl th{padding:10px 10px}
  .modal{max-width:100%;margin:0;border-radius:var(--rl) var(--rl) 0 0;padding-bottom:var(--safe-bot)}
  .mo{align-items:flex-end;padding:0}
  .mb{padding:18px 16px}
  .mh{padding:14px 16px}
  .mf{padding:12px 16px}
  .view{padding:16px}
  .ll-row{padding:14px 12px}
  .ib{width:40px;height:40px;font-size:18px}
  .foto-area{padding:24px 16px}
  .ac-grid{grid-template-columns:repeat(2,1fr)}
  .ac-card{padding:20px 12px}
  .ac-icon{font-size:32px}
  .fotos-tab{padding:12px 14px}
  /* Header: compact buttons, no text overlap */
  .hdr-top{padding:0 8px;gap:6px}
  #btn-crear-main{font-size:0 !important}
  #btn-crear-main::before{content:'＋';font-size:14px}
  .bc{font-size:11px;gap:4px}
  .app-mark{width:26px;height:26px;font-size:10px}
  .app-ltxt{display:none}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .h-right 
  .buque-card{flex-direction:column}
  .hm-card{padding:22px 18px}
  /* Home screen full-width cards on tiny screens */
  .hm-cards{grid-template-columns:1fr !important;max-width:100%}
}
/* PWA safe area support (iPhone notch/home bar) */
@supports(padding:max(0px)){
  .hm-hdr,#app-hdr{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right));}
  .hm-body{padding-bottom:max(48px,calc(env(safe-area-inset-bottom)+24px));}
  #sidebar{padding-bottom:env(safe-area-inset-bottom);}
  .mf{padding-bottom:max(14px,env(safe-area-inset-bottom));}
}


/* ── Sidebar toggle button ── */
.sidebar-toggle-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;border:1px solid var(--g200);background:var(--w);cursor:pointer;color:var(--g500);font-size:14px;transition:all .15s;flex-shrink:0}
.sidebar-toggle-btn:hover{background:var(--g100);color:var(--b600);border-color:var(--b200)}
#sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 14px 12px;border-bottom:1px solid var(--g100);flex-shrink:0}
#sidebar-logo{display:flex;align-items:center;gap:10px;cursor:pointer;min-width:0;overflow:hidden}
#sidebar-logo-mark{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--b600),#6366f1);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;font-size:14px;flex-shrink:0;letter-spacing:-.5px;border:1.5px solid rgba(255,255,255,.2)}
#sidebar-logo-txt{font-weight:700;font-size:14px;color:var(--g900);white-space:nowrap;overflow:hidden;transition:opacity .2s,width .2s}
#sidebar.collapsed #sidebar-logo-txt{opacity:0;width:0}
#sidebar.collapsed #sidebar-header{justify-content:center}
#sidebar.collapsed .sidebar-toggle-btn{margin:0}

/* ── sb-user mejorado ── */
.sb-bot{border-top:1px solid var(--g100);padding:10px;flex-shrink:0;margin-top:auto}
.sb-user{display:flex;align-items:center;gap:10px;padding:10px;border-radius:10px;cursor:pointer;transition:background .15s;overflow:hidden}
.sb-user:hover{background:var(--g100)}
.sb-av{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--b600),#6366f1);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.sb-name{font-size:13px;font-weight:600;color:var(--g800);white-space:nowrap;overflow:hidden;transition:opacity .2s}
.sb-role{font-size:11px;color:var(--g400);white-space:nowrap;overflow:hidden;transition:opacity .2s}


/* ══════════════════════════════════════════════════════════════
   IDENTIDAD DUAL: ALS + CUSTOMS WAY
   ══════════════════════════════════════════════════════════════ */

/* Logo CW en pantalla de login */
.li-dual-logos{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:8px}
.li-als-logo{display:flex;flex-direction:column;align-items:center;gap:4px}
.li-als-mark{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,#1d4ed8,#2563eb);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:900;font-size:18px;letter-spacing:-.5px;
  box-shadow:0 4px 14px rgba(37,99,235,.4);
}
.li-als-name{font-size:11px;font-weight:700;color:var(--g500);letter-spacing:.04em;text-transform:uppercase}
.li-dual-sep{
  width:1px;height:40px;background:var(--g200);
  margin:0 16px;flex-shrink:0;
}
.li-cw-logo{display:flex;flex-direction:column;align-items:center;gap:4px}
.li-cw-mark{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg,#0f2d6e,#312e81);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
  box-shadow:0 4px 14px rgba(15,45,110,.4);
}
.li-cw-mark::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 52 52'%3E%3Ccircle cx='26' cy='26' r='18' fill='none' stroke='rgba(255,255,255,.12)' stroke-width='1'/%3E%3Ccircle cx='26' cy='26' r='10' fill='none' stroke='rgba(255,255,255,.08)' stroke-width='1'/%3E%3C/svg%3E");
}
.li-cw-initials{position:relative;z-index:1;color:#fff;font-weight:900;font-size:22px;letter-spacing:-.5px}
.li-cw-name{font-size:11px;font-weight:700;color:var(--g500);letter-spacing:.04em;text-transform:uppercase}

/* Tagline bajo los logos */
.li-tagline{
  text-align:center;font-size:12px;color:var(--g500);
  margin-bottom:6px;font-weight:500;
}
.li-tagline strong{color:var(--g700)}

/* Home header dual */
.hm-dual-logos{display:flex;align-items:center;gap:12px}
.hm-als-pill{
  display:flex;align-items:center;gap:8px;
  background:var(--b50);border:1px solid var(--b100);
  border-radius:10px;padding:5px 10px;
}
.hm-als-pill .pill-mark{
  width:26px;height:26px;border-radius:7px;
  background:linear-gradient(135deg,#1d4ed8,#2563eb);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:10px;font-weight:900;
}
.hm-als-pill .pill-txt{font-size:12px;font-weight:700;color:var(--b700)}
.hm-cw-pill{
  display:flex;align-items:center;gap:8px;
  background:#f0f0ff;border:1px solid #c7c7ee;
  border-radius:10px;padding:5px 10px;
}
.hm-cw-pill .pill-mark{
  width:28px;height:28px;border-radius:7px;
  background:linear-gradient(135deg,#0f2d6e,#312e81);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:12px;font-weight:900;letter-spacing:-.5px;
}
.hm-cw-pill .pill-txt{font-size:12px;font-weight:700;color:#312e81}

/* Dark mode adaptations */
:root.dark .li-als-name,:root.dark .li-cw-name{color:var(--g400)!important}
:root.dark .li-tagline{color:var(--g400)!important}
:root.dark .li-tagline strong{color:var(--g600)!important}
:root.dark .li-dual-sep{background:var(--g300)!important}
:root.dark .hm-als-pill{background:#1e3a5f!important;border-color:#1d4ed8!important}
:root.dark .hm-als-pill .pill-txt{color:#93c5fd!important}
:root.dark .hm-cw-pill{background:#1e1b4b!important;border-color:#4338ca!important}
:root.dark .hm-cw-pill .pill-txt{color:#a5b4fc!important}

/* ── Modo oscuro ─────────────────────────────────────────────── */
/* ── Modo oscuro ─────────────────────────────────────────────── */
/* ── Modo oscuro ─────────────────────────────────────────────── */
:root.dark { color-scheme: dark; }

/* ── Base ── */
:root.dark body,
:root.dark #app,
:root.dark #app-body,
:root.dark #content,
:root.dark #screen-home,
:root.dark .view { background:#0f0f1a !important; }

/* ── Cabecera real: #app-hdr ── */
:root.dark #app-hdr { background:#12122a !important; border-bottom:1px solid #1e1e3f !important; }
:root.compact .view{padding:14px !important}
:root.compact .kpi{padding:12px 14px !important}
:root.compact .kpi-val{font-size:22px !important}
:root.compact .a-item{padding:10px 12px !important}
:root.compact .tbl td,.tbl th{padding:7px 10px !important}
:root.compact .ug{gap:8px !important}
:root.compact .uc{padding:10px 12px !important}
:root.dark .hm-hdr  { background:#12122a !important; border-bottom:1px solid #1e1e3f !important; }
:root.dark .hdr-top { background:#12122a !important; }
:root.dark .hdr-icon-btn { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#9aa5b4 !important; }
:root.dark .hdr-user { background:#1e1e3f !important; border-color:#2d2d5e !important; }
:root.dark .hdr-user-name { color:#e8eaf0 !important; }
:root.dark .hdr-bc-mod { color:#6b7280 !important; }
:root.dark .hdr-bc-cur { color:#c8d0da !important; }
:root.dark .hdr-bc-sep { color:#2d2d5e !important; }
:root.dark #sidebar { background:#12122a !important; }
:root.dark #sidebar-header { border-bottom-color:#1e1e3f !important; background:#12122a !important; }
:root.dark #sidebar-logo-txt { color:#e8eaf0 !important; }
:root.dark .sidebar-toggle-btn { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#9aa5b4 !important; }
:root.dark .hdr-cert { color:#6b7280 !important; border-color:#2d2d5e !important; }
:root.dark .hm-contact,
:root.dark .hm-contact span { color:#6b7280 !important; }
:root.dark #global-results { background:#1a1a2e !important; border-color:#1e1e3f !important; }

/* ── Sidebar real: #sidebar ── */
:root.dark #sidebar,
:root.dark .sbar { background:#12122a !important; border-right:1px solid #1e1e3f !important; }
:root.dark #sidebar > *:first-child { background:#0f0f1a !important; border-bottom:1px solid #1e1e3f !important; }
:root.dark .nav-item { color:#9aa5b4 !important; }
:root.dark .nav-item:hover { background:#1e1e3f !important; color:#e8eaf0 !important; }
:root.dark .nav-item.active { background:#0d2a4a !important; color:#60a5fa !important; }
:root.dark .nav-section-title,
:root.dark .nav-s { color:#4a5568 !important; font-size:10px; }
:root.dark #sidebar .ni { color:#6b7280 !important; }
:root.dark .nav-item.active .ni { color:#60a5fa !important; }

/* ── Login ── */
:root.dark #screen-login { background:#0f0f1a !important; }
:root.dark .li-card,
:root.dark .li-wrap > div { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark .li-title { color:#e8eaf0 !important; }
:root.dark .li-sub { color:#9aa5b4 !important; }

/* ── Home ── */
:root.dark #screen-home { background:#0f0f1a !important; }
:root.dark #screen-home .hm-hdr { background:#12122a !important; border-bottom:1px solid #1e1e3f !important; }
:root.dark #screen-home [style*="background:var(--g"] { background:#1a1a2e !important; }
:root.dark .hm-lmark { color:#60a5fa !important; }
:root.dark .hm-logo > div { color:#c8d0da !important; }
:root.dark .hm-body { background:#0f0f1a !important; }
:root.dark #screen-aduanas { background:#0a0f1e !important; }
:root.dark #screen-eori { background:#0a0f1e !important; }
:root.dark .hm-hdr { background:#12122a !important; border-color:#1e1e3f !important; }
:root.dark .hm-card { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark .hm-title { color:#e8eaf0 !important; }
:root.dark .hm-sub,
:root.dark .hm-cdesc { color:#9aa5b4 !important; }
:root.dark .hm-icon { filter:brightness(.7); }
:root.dark .hm-cert { color:#6b7280 !important; }
:root.dark .hm-user { color:#9aa5b4 !important; }
:root.dark .ac-card { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark .ac-lbl { color:#c8d0da !important; }
:root.dark .ac-desc { color:#9aa5b4 !important; }

/* ── Page header ── */
:root.dark .ph { background:#1a1a2e !important; border-bottom:1px solid #1e1e3f !important; }
:root.dark .pt { color:#c8d0da !important; }

/* ── KPIs ── */
:root.dark .kpi,
:root.dark #alm-kpi-grid .kpi { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark .kpi-lbl { color:#9aa5b4 !important; }
:root.dark .kpi-val { color:#e8eaf0 !important; }
:root.dark .kpi-sub { color:#6b7280 !important; }

/* ── Tarjetas buques ── */
:root.dark .buque-card { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark .buque-card * { color:#c8d0da !important; }

/* ── Listas ll-row ── */
:root.dark .ll-row { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark .ll-row:hover { background:#1e1e3f !important; }
:root.dark .ll-ref { color:#e8eaf0 !important; }
:root.dark .ll-sub { color:#9aa5b4 !important; }

/* ── Tablas ── */
:root.dark .tbl { border-color:#1e1e3f !important; }
:root.dark .tbl thead,
:root.dark .tbl th { background:#0f3460 !important; color:#c8d0da !important; border-color:#1e1e3f !important; }
:root.dark .tbl td { border-color:#1e1e3f !important; color:#c8d0da !important; background:#1a1a2e !important; }
:root.dark .tbl tr:nth-child(even) td { background:#161629 !important; }
:root.dark .tbl tr:hover td { background:#1e1e3f !important; }
:root.dark .fw { color:#e8eaf0 !important; }

/* ── Formularios ── */
:root.dark .fi { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#e8eaf0 !important; }
:root.dark .fi:focus { border-color:#60a5fa !important; outline:none !important; }
:root.dark .fs { background:#1e1e3f !important; color:#e8eaf0 !important; border-color:#2d2d5e !important; }
:root.dark .fl,
:root.dark .fl2 { color:#9aa5b4 !important; }
:root.dark .fg,
:root.dark .fg2,
:root.dark .fr2 { background:transparent !important; }
:root.dark input::placeholder,
:root.dark textarea::placeholder { color:#4a5568 !important; }
:root.dark .info-box { background:#0d2a4a !important; border-color:#1a4a6e !important; color:#c8d0da !important; }

/* ── Botones ── */
:root.dark .btn-s { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#c8d0da !important; }
:root.dark .btn-w { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#c8d0da !important; }
:root.dark .btn-g { background:#0a3d2a !important; border-color:#145c3e !important; color:#6ee7b7 !important; }
:root.dark .ib { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#9aa5b4 !important; }

/* ── Modal ── */
:root.dark .mo { background:rgba(0,0,0,.75) !important; }
:root.dark .modal { background:#1a1a2e !important; }
:root.dark .mh { background:#12122a !important; border-bottom:1px solid #1e1e3f !important; color:#e8eaf0 !important; }
:root.dark .mf { background:#12122a !important; border-top:1px solid #1e1e3f !important; }
:root.dark .mb { background:#1a1a2e !important; }

/* ── Almacén paneles ── */
:root.dark #alm-pend,
:root.dark #alm-rev,
:root.dark #alm-lis,
:root.dark #alm-listos-dash,
:root.dark #alm-exp-buque-content { background:#0f0f1a !important; }
:root.dark #mob-alm-bar { background:#12122a !important; border-top:1px solid #1e1e3f !important; }
:root.dark .mob-alm-btn { color:#9aa5b4 !important; }
:root.dark .mob-alm-btn.active { color:#60a5fa !important; }
:root.dark .fotos-tab { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark #fotos-tab-content { background:#0f0f1a !important; }

/* ── Calendario ── */
:root.dark #cal-body { background:#0f0f1a !important; }
:root.dark #cal-dheader { background:#12122a !important; border-color:#1e1e3f !important; }
:root.dark .cal-btn,
:root.dark #cal-v-15d,
:root.dark #cal-v-mes,
:root.dark #cal-v-semana { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#c8d0da !important; }
:root.dark .cal-btn.active { background:#0d2a4a !important; color:#60a5fa !important; }
:root.dark .tc { background:#1a1a2e !important; border-color:#1e1e3f !important; }
:root.dark #cal-m { background:#0f0f1a !important; }

/* ── Textos generales ── */
:root.dark .dv { color:#6b7280 !important; }
:root.dark .dl { color:#c8d0da !important; }
:root.dark .empty-txt { color:#6b7280 !important; }
:root.dark .badge.bgr { background:#2d2d5e !important; color:#c8d0da !important; }
:root.dark .bar-track { background:#1e1e3f !important; }
:root.dark .foto-area { background:#1e1e3f !important; border-color:#2d2d5e !important; color:#9aa5b4 !important; }

/* ── Scrollbar ── */
:root.dark ::-webkit-scrollbar-track { background:#12122a; }
:root.dark ::-webkit-scrollbar-thumb { background:#2d2d5e; }
:root.dark ::-webkit-scrollbar-thumb:hover { background:#3d3d7e; }

/* ── Skeleton loading ────────────────────────────────────────── */
@keyframes shimmer{0%{background-position:-1000px 0}100%{background-position:1000px 0}}
.skeleton {
  background:linear-gradient(90deg,var(--g100) 25%,var(--g200) 50%,var(--g100) 75%);
  background-size:2000px 100%;
  animation:shimmer 1.8s infinite linear;
  border-radius:var(--r);
}
.sk-line{height:13px;margin-bottom:8px;}
.sk-line.short{width:35%;}
.sk-line.medium{width:60%;}
.sk-line.long{width:88%;}
.sk-box{border-radius:var(--r);margin-bottom:10px;}
.sk-kpi{height:80px;border-radius:var(--rl);}
.sk-card{padding:14px;border:1px solid var(--g100);border-radius:var(--rl);margin-bottom:10px;}

/* ── Animaciones ─────────────────────────────────────────────── */
@keyframes fadeInUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.anim-fade-up{animation:fadeInUp .22s ease-out both;}
.anim-fade{animation:fadeIn .18s ease-out both;}

/* Modal slide-in animation */
.modal{transform:translateY(18px);opacity:0;transition:transform .22s cubic-bezier(.16,1,.3,1),opacity .2s ease;}
.mo.open .modal{transform:translateY(0);opacity:1;}

/* Card hover */
.buque-card{transition:box-shadow .15s,transform .15s;}
.buque-card:hover{box-shadow:0 4px 18px rgba(37,99,235,.12);transform:translateY(-1px);}
.kpi{transition:box-shadow .15s;}
.kpi:hover{box-shadow:0 4px 14px rgba(0,0,0,.08);}
.ll-row{transition:background .1s;}
/* hm-card transitions handled in main CSS */

/* Mobile tap feedback */
@media(max-width:768px){
  .btn:active{transform:scale(.96);}
  .mob-alm-btn:active{transform:scale(.9);}
  #fotos-tab-content{
  will-change: transform, opacity;
  transform: translateX(0);
  transition: transform .22s cubic-bezier(.4,0,.2,1), opacity .22s;
}
/* Indicador visual de swipe disponible — flechas laterales sutiles en móvil */
@media(max-width:768px){
  #fotos-tab-content{
    touch-action: pan-y; /* permite scroll vertical, no interfiere */
  }
  #fotos-tabs-top{display:none !important;} /* barra inferior reemplaza a tabs en móvil */
}
  .ib:active{transform:scale(.88);}
}

.notif-item{display:flex;gap:12px;align-items:flex-start;padding:14px 20px;border-bottom:1px solid var(--g100);cursor:pointer;transition:background .12s}
.notif-item:hover{background:var(--g50)}
.notif-item.unread{background:var(--b50)}
.notif-item.unread:hover{background:#dbeafe}
.notif-dot{width:8px;height:8px;border-radius:50%;background:#ef4444;flex-shrink:0;margin-top:5px}
.notif-dot.read{background:transparent}
@media(max-width:600px){#notif-panel{width:100%;border-left:none}}

.tbl tbody tr:hover .exp-quick-actions { display:flex !important; }
.tbl tbody tr .exp-quick-actions { display:none; }
.exp-actions-col { opacity:0; transition:opacity .15s; }
.tbl tbody tr:hover .exp-actions-col { opacity:1; }

/* ── UX refresh: home, header, dashboard y móvil ─────────────── */
.hm-brief{width:100%;max-width:960px;margin:0 0 14px;display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--w);border:1px solid var(--g200);border-radius:14px;padding:14px 16px;box-shadow:var(--sh0)}
.hm-brief-main{min-width:0}.hm-brief-k{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--b600);margin-bottom:3px}.hm-brief-t{font-size:17px;font-weight:800;color:var(--g900);letter-spacing:0}.hm-brief-d{font-size:12px;color:var(--g500);margin-top:3px;line-height:1.45}
.hm-brief-meta{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.hm-meta-pill{font-size:11px;font-weight:700;color:var(--g600);background:var(--g100);border:1px solid var(--g200);border-radius:999px;padding:5px 9px;white-space:nowrap}
.hm-quick{width:100%;max-width:960px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.hm-qbtn{border:1px solid var(--g200);background:var(--w);color:var(--g700);border-radius:10px;padding:8px 11px;font-family:var(--f);font-size:12px;font-weight:700;cursor:pointer;box-shadow:var(--sh0);display:inline-flex;gap:6px;align-items:center}
.hm-qbtn:hover{border-color:var(--b100);background:var(--b50);color:var(--b700);transform:translateY(-1px)}
.hm-card{border:1px solid rgba(255,255,255,.18);min-height:214px}.hm-card .hm-card-icon{font-size:30px;padding:20px 22px 6px}.hm-card .hm-card-body{padding:0 22px 22px}.hm-card .hm-ctitle{font-size:18px}.hm-card .hm-cdesc{min-height:34px;line-height:1.45}.hm-card-feats{gap:5px;margin-bottom:16px}.hm-card-feats span{border-radius:999px}
.hdr-home-btn{width:34px;height:34px;border:1px solid var(--g200);background:var(--w);border-radius:9px;color:var(--g600);cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hdr-home-btn:hover{background:var(--b50);border-color:var(--b100);color:var(--b700)}
.hdr-area-switch{height:34px;border:1px solid var(--g200);background:var(--w);border-radius:9px;color:var(--g700);font-family:var(--f);font-size:12px;font-weight:700;padding:0 28px 0 10px;max-width:132px}
.hdr-tools{position:relative;display:none}.hdr-tools-menu{display:none;position:absolute;right:0;top:calc(100% + 6px);background:var(--w);border:1px solid var(--g200);border-radius:10px;box-shadow:var(--shl);padding:6px;min-width:190px;z-index:9500}.hdr-tools-menu.open{display:block}.hdr-tools-menu button{width:100%;border:0;background:transparent;text-align:left;border-radius:7px;padding:9px 10px;font-family:var(--f);font-size:12px;font-weight:600;color:var(--g700);cursor:pointer}.hdr-tools-menu button:hover{background:var(--g50);color:var(--g900)}
.dash-brief{background:linear-gradient(135deg,#f8fbff,#fff);border:1px solid var(--g200);border-radius:14px;padding:16px 18px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:var(--sh0)}.dash-brief-kicker{font-size:11px;font-weight:800;color:var(--b600);letter-spacing:.08em;text-transform:uppercase;margin-bottom:3px}.dash-brief-title{font-size:19px;font-weight:800;color:var(--g900)}.dash-brief-sub{font-size:12px;color:var(--g500);margin-top:4px}.dash-brief-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.dash-filter-panel.is-collapsed{display:none}
#mob-op-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--w);border-top:1px solid var(--g200);padding:5px 3px max(8px,env(safe-area-inset-bottom));z-index:198;box-shadow:0 -2px 16px rgba(0,0,0,.10)}#mob-op-bar.visible{display:flex}.mob-op-btn{flex:1;border:0;background:transparent;color:var(--g500);font-family:var(--f);font-size:10px;font-weight:700;display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 1px;border-radius:10px;cursor:pointer}.mob-op-btn.active{color:var(--b600)}.mob-op-icon{width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:17px}.mob-op-btn.active .mob-op-icon{background:var(--b50)}
.status-chip{border-radius:999px;padding:3px 8px;font-size:11px;font-weight:800;display:inline-flex;align-items:center;gap:4px}
.onb-card{width:100%;max-width:960px;background:var(--b50);border:1px solid var(--b100);border-radius:14px;padding:12px 14px;margin:0 0 12px;display:flex;gap:12px;align-items:flex-start;justify-content:space-between}.onb-card strong{font-size:13px;color:var(--b700)}.onb-card p{font-size:12px;color:var(--g600);line-height:1.5;margin-top:2px}.onb-card button{border:0;background:transparent;color:var(--b700);font-weight:800;cursor:pointer;font-size:12px;white-space:nowrap}
:root.dark .hm-brief,:root.dark .hm-qbtn,:root.dark .hdr-home-btn,:root.dark .hdr-area-switch,:root.dark .hdr-tools-menu,:root.dark .dash-brief,:root.dark #mob-op-bar{background:#12122a!important;border-color:#1e1e3f!important;color:#c8d0da!important}:root.dark .hm-brief-t,:root.dark .dash-brief-title{color:#e8eaf0!important}:root.dark .hm-meta-pill{background:#1e1e3f!important;border-color:#2d2d5e!important;color:#c8d0da!important}:root.dark .onb-card{background:#0d2a4a!important;border-color:#1a4a6e!important}:root.dark .onb-card p{color:#c8d0da!important}
@media(max-width:1280px){.hm-contact{display:none}.hm-hdr{flex-wrap:nowrap}.hm-dual-logos{flex-shrink:0}}
@media(max-width:900px){.hdr-area-switch{max-width:104px}.hdr-tools{display:block}#density-toggle,#dark-auto-btn,#btn-recientes{display:none!important}.hm-brief{align-items:flex-start;flex-direction:column}.hm-brief-meta{justify-content:flex-start}.dash-brief{align-items:flex-start;flex-direction:column}}
@media(max-width:768px){#content.has-op-bar .view.active{padding-bottom:78px}.hm-card{min-height:190px}.hm-card-feats span:nth-child(n+4){display:none}.hm-quick{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}.hm-qbtn{white-space:nowrap}.hdr-home-btn{display:none}.hdr-area-switch{height:32px;max-width:96px}.dash-filter-panel{display:none}.dash-filter-panel.is-open{display:block}.dash-brief-title{font-size:17px}.tbl{min-width:680px}}
@media(max-width:520px){.hm-hdr{padding:8px 12px}.hm-dual-logos{gap:6px}.hm-als-pill,.hm-cw-pill{padding:4px 7px}.hm-als-pill .pill-txt,.hm-cw-pill .pill-txt{font-size:11px}.hm-cert,#hm-version{display:none!important}.hm-user span{display:none}.hm-logout{font-size:0}.hm-logout::before{content:'Salir';font-size:12px}.hm-brief{padding:12px}.hm-title{font-size:23px}.hm-sub{margin-bottom:18px}.hm-cards{gap:12px}.hm-card .hm-card-icon{padding:18px 18px 4px}.hm-card .hm-card-body{padding:0 18px 18px}.hm-card .hm-cdesc{min-height:0}.hm-card-feats span:nth-child(n+3){display:none}.hdr-area-switch{display:none}}
