/* ============================================================================
 * KM100 · Centro de Operaciones — Estilos
 * Consola operativa sobria en papel cálido. Tipografía precisa, reglas finas,
 * color funcional (rojo Km100 + estados). Sin degradados decorativos ni glow.
 * Armoniza con la app "Flotas y Talleres · Bahía de Control".
 * ==========================================================================*/
:root{
  color-scheme:light;
  --paper:#f7f4ec; --paper-2:#f1ede2;
  --card:#fffdf8; --card-2:#faf7ef;
  --line:#e6e1d4; --line-2:#d7d1c0; --line-ink:#15130f;
  --ink:#15130f; --ink-2:#56503f; --ink-3:#8a8472; --ink-4:#a9a392;
  --red:#e63027; --red-dk:#b9211a; --red-soft:#fbe9e6;
  --good:#1a7f37; --good-soft:#e4f0e6;
  --warn:#9a6a12; --warn-soft:#f7eccf;
  --inv:#1a7f37; --inv-soft:#e4f0e6;
  --fleet:#b9211a; --fleet-soft:#fbe9e6;
  --r:10px; --r-s:7px; --r-pill:999px;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --serif:'Fraunces','Iowan Old Style',Georgia,serif;
  --mono:'JetBrains Mono',ui-monospace,'Cascadia Mono',Consolas,monospace;
  --e:cubic-bezier(.2,.7,.2,1);
  --sh-s:0 1px 2px rgba(21,19,15,.04);
  --sh:0 6px 20px -10px rgba(21,19,15,.22),0 1px 2px rgba(21,19,15,.05);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:14px;line-height:1.5;font-variant-numeric:tabular-nums;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
button,input{font:inherit;color:inherit}
svg{display:block}
.mono{font-family:var(--mono)}
.hidden{display:none!important}
.tnum{font-variant-numeric:tabular-nums}

/* micro-label en mono mayúsculas */
.kicker{font:600 10px/1 var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}

/* —— Marca —— */
.brand{display:flex;align-items:center;gap:9px}
.brand .mk{width:28px;height:28px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;
  background:var(--ink);color:#fff}
.brand .mk svg{width:16px;height:16px}
.brand .wm{font-weight:700;font-size:15px;letter-spacing:-.02em;line-height:1}
.brand .wm em{font-style:normal;color:var(--red)}
.brand .tag{font:600 9px/1 var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);
  border:1px solid var(--line-2);border-radius:4px;padding:3px 6px;background:var(--card)}

/* ====================== LOGIN ====================== */
.auth{min-height:100dvh;display:grid;place-items:center;padding:24px;
  background:
    linear-gradient(0deg,var(--paper-2),transparent 40%),
    repeating-linear-gradient(0deg,transparent 0 38px,rgba(21,19,15,.014) 38px 39px);
}
.auth-card{width:372px;max-width:100%;background:var(--card);border:1px solid var(--line);
  border-radius:14px;box-shadow:var(--sh);overflow:hidden;animation:rise .45s var(--e) both}
.auth-top{height:3px;background:var(--red)}
.auth-in{padding:28px 30px 24px}
.auth-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}
.auth-title{font-family:var(--serif);font-weight:600;font-size:22px;letter-spacing:-.01em;margin:20px 0 3px}
.auth-desc{color:var(--ink-2);font-size:12.5px}
.field{margin-bottom:13px}
.field label{display:block;font:600 10px/1 var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:7px}
.input{position:relative;display:flex;align-items:center}
.input>svg,.input .lead{position:absolute;left:12px;width:15px;height:15px;color:var(--ink-3);pointer-events:none}
.input input{width:100%;padding:11px 12px 11px 36px;background:var(--card-2);border:1px solid var(--line-2);
  border-radius:var(--r-s);font-size:14px;outline:none;transition:border-color .14s,box-shadow .14s,background .14s}
.input input:focus{border-color:var(--red);background:var(--card);box-shadow:0 0 0 3px var(--red-soft)}
.input .toggle{position:absolute;right:5px;left:auto;width:28px;height:28px;display:grid;place-items:center;
  background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--ink-3);pointer-events:auto;transition:color .14s,background .14s}
.input .toggle:hover{color:var(--ink);background:var(--paper-2)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:11px 16px;
  border:1px solid var(--ink);border-radius:var(--r-s);font-weight:600;font-size:13.5px;cursor:pointer;
  background:var(--ink);color:#fff;transition:transform .1s var(--e),box-shadow .18s,background .16s,opacity .16s}
.btn:hover{background:#000;transform:translateY(-1px);box-shadow:var(--sh-s)}
.btn:active{transform:translateY(0)}
.btn[disabled]{opacity:.6;cursor:progress;transform:none}
.btn.primary{background:var(--red);border-color:var(--red)}
.btn.primary:hover{background:var(--red-dk)}
.btn.full{margin-top:6px}
.btn-ghost{background:var(--card);color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{background:var(--paper-2)}
.btn .spin{width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}
.btn-ghost .spin,.alert .spin{border-color:rgba(21,19,15,.25);border-top-color:var(--ink)}
.alert{display:none;align-items:center;gap:8px;margin:2px 0 11px;padding:9px 11px;border-radius:var(--r-s);
  font-size:12.5px;font-weight:500;background:var(--red-soft);border:1px solid #f3cdc8;color:var(--red-dk)}
.alert.show{display:flex;animation:rise .2s var(--e)}
.alert svg{width:15px;height:15px;flex-shrink:0}

.demo{margin-top:16px;border-top:1px solid var(--line);padding-top:13px}
.demo summary{cursor:pointer;color:var(--ink-3);font:600 10px/1 var(--mono);letter-spacing:.1em;text-transform:uppercase;list-style:none;display:flex;align-items:center;gap:6px}
.demo summary::-webkit-details-marker{display:none}
.demo summary:hover{color:var(--ink)}
.demo summary svg{width:12px;height:12px;transition:transform .2s}
.demo[open] summary svg{transform:rotate(90deg)}
.demo-grid{margin-top:10px;display:flex;flex-direction:column;gap:5px}
.demo-row{display:flex;align-items:center;gap:9px;padding:7px 9px;border:1px solid var(--line);border-radius:var(--r-s);background:var(--card-2);cursor:pointer;transition:border-color .14s,background .14s}
.demo-row:hover{border-color:var(--line-ink);background:var(--card)}
.demo-row .du{font:600 12px var(--mono);color:var(--ink)}
.demo-row .dr{margin-left:auto;font-size:10.5px;color:var(--ink-3)}
.demo-row .chip{font:700 8.5px/1 var(--mono);padding:3px 5px;border-radius:4px;letter-spacing:.03em}
.chip.c-inv{background:var(--inv-soft);color:var(--inv)}
.chip.c-fleet{background:var(--fleet-soft);color:var(--fleet)}

/* ====================== SHELL / HUB ====================== */
.shell{min-height:100dvh;display:flex;flex-direction:column;animation:fade .35s var(--e) both}
.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;height:56px;
  padding:0 clamp(16px,4vw,34px);background:var(--card);border-bottom:1px solid var(--line);box-shadow:var(--sh-s)}
.topbar .sep{width:1px;height:22px;background:var(--line-2)}
.clock{display:flex;align-items:center;gap:7px;font:500 12px var(--mono);color:var(--ink-2);letter-spacing:.01em}
.clock .c-date{color:var(--ink-3)}
.topbar .grow{flex:1}
.sess{display:flex;align-items:center;gap:9px;padding:5px 6px 5px 11px;border:1px solid var(--line);border-radius:var(--r-pill);background:var(--card-2)}
.sess .who{display:flex;flex-direction:column;line-height:1.15;text-align:right}
.sess .who .nm{font-weight:600;font-size:12.5px}
.sess .who .rl{font:500 9.5px var(--mono);color:var(--ink-3);letter-spacing:.02em}
.sess .av{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  background:var(--ink);color:#fff;font:700 11px var(--mono)}
.sdot{display:inline-flex;align-items:center;gap:6px;font:600 10px var(--mono);letter-spacing:.04em;text-transform:uppercase;color:var(--good)}
.sdot i{width:6px;height:6px;border-radius:50%;background:var(--good);box-shadow:0 0 0 3px var(--good-soft)}
.iconbtn{width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-s);border:1px solid var(--line-2);
  background:var(--card);color:var(--ink-2);cursor:pointer;transition:color .14s,background .14s,border-color .14s,transform .1s}
.iconbtn:hover{color:var(--red-dk);background:var(--red-soft);border-color:#f0c9c4;transform:translateY(-1px)}
.iconbtn svg{width:16px;height:16px}

.wrap{flex:1;width:100%;max-width:1000px;margin:0 auto;padding:clamp(22px,4vw,40px) clamp(16px,4vw,34px) 56px}
.sec{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:16px}
.sec h1{font-family:var(--serif);font-weight:600;font-size:clamp(20px,3.4vw,26px);letter-spacing:-.01em}
.sec .meta{font:500 11px var(--mono);color:var(--ink-3);letter-spacing:.02em;white-space:nowrap}
.sec .meta b{color:var(--ink);font-weight:700}

.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}

/* —— Panel de módulo —— */
.mod{position:relative;display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;transition:border-color .18s var(--e),box-shadow .18s,transform .18s;
  animation:rise .45s var(--e) both}
.mod:nth-child(2){animation-delay:.06s}
.mod::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--ac);opacity:.0;transition:opacity .18s}
.mod.inv{--ac:var(--inv);--ac-soft:var(--inv-soft)}
.mod.fleet{--ac:var(--fleet);--ac-soft:var(--fleet-soft)}
.mod.enterable{cursor:pointer}
.mod.enterable:hover{border-color:var(--line-ink);box-shadow:var(--sh);transform:translateY(-2px)}
.mod.enterable:hover::before{opacity:1}
.mod-in{padding:18px 18px 0;display:flex;flex-direction:column;gap:13px;flex:1}
.mod-hd{display:flex;align-items:flex-start;gap:13px}
.mod-ic{width:46px;height:46px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;
  background:var(--ac-soft);color:var(--ac);border:1px solid color-mix(in srgb,var(--ac) 24%,transparent)}
.mod-ic svg{width:24px;height:24px}
.mod-tt{flex:1;min-width:0}
.mod-tt h2{font-family:var(--serif);font-weight:600;font-size:19px;letter-spacing:-.01em;line-height:1.05}
.mod-tt .sub{font:500 11px var(--mono);color:var(--ink-3);letter-spacing:.02em;margin-top:4px}
.mod-code{font:700 9.5px/1 var(--mono);letter-spacing:.06em;color:var(--ink-2);background:var(--paper-2);
  border:1px solid var(--line-2);border-radius:4px;padding:4px 6px;align-self:flex-start}
.facets{display:flex;flex-wrap:wrap;gap:5px}
.facets span{font:500 10.5px var(--mono);color:var(--ink-2);background:var(--card-2);border:1px solid var(--line);
  border-radius:5px;padding:4px 7px;letter-spacing:.01em}
.authnote{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ink-3)}
.authnote svg{width:13px;height:13px;color:var(--ink-4)}

.mod-ft{margin-top:auto;display:flex;align-items:center;gap:10px;padding:13px 18px;border-top:1px solid var(--line);background:var(--card-2)}
.access{display:inline-flex;align-items:center;gap:7px;font:600 11px var(--mono);letter-spacing:.03em;text-transform:uppercase}
.access i{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.access.ok{color:var(--good)} .access.ok i{background:var(--good);box-shadow:0 0 0 3px var(--good-soft)}
.access.grant{color:var(--warn)} .access.grant i{background:var(--warn);box-shadow:0 0 0 3px var(--warn-soft)}
.access.no{color:var(--ink-3)} .access.no i{background:var(--ink-4)}
.mod-act{margin-left:auto;display:inline-flex;align-items:center;gap:8px}
.kbd{font:600 10px var(--mono);color:var(--ink-3);border:1px solid var(--line-2);border-radius:5px;padding:2px 6px;background:var(--card)}
.enter{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:var(--r-s);font-weight:600;font-size:12.5px;
  cursor:pointer;border:1px solid var(--ink);background:var(--ink);color:#fff;transition:transform .1s var(--e),background .15s,box-shadow .18s}
.enter:hover{background:#000;transform:translateY(-1px);box-shadow:var(--sh-s)}
.enter svg{width:15px;height:15px;transition:transform .18s var(--e)}
.enter:hover svg{transform:translateX(3px)}
.enter.locked{background:var(--card);color:var(--ink);border-color:var(--line-2)}
.enter.locked:hover{background:var(--paper-2);border-color:var(--line-ink)}
.mod.locked .mod-ic{filter:grayscale(.5);opacity:.85}
.lockmark{position:absolute;top:14px;right:14px;width:26px;height:26px;border-radius:7px;display:grid;place-items:center;
  background:var(--paper-2);border:1px solid var(--line-2);color:var(--ink-3)}
.lockmark svg{width:14px;height:14px}

.footnote{padding:16px clamp(16px,4vw,34px);border-top:1px solid var(--line);
  font:500 11px var(--mono);color:var(--ink-4);letter-spacing:.02em}
.footnote b{color:var(--ink-2);font-weight:700}

/* ====================== MODAL step-up ====================== */
.scrim{position:fixed;inset:0;z-index:80;display:grid;place-items:center;padding:20px;
  background:rgba(21,19,15,.34);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  opacity:0;pointer-events:none;transition:opacity .2s var(--e)}
.scrim.show{opacity:1;pointer-events:auto}
.modal{width:372px;max-width:100%;background:var(--card);border:1px solid var(--line-2);border-radius:14px;
  box-shadow:var(--sh);overflow:hidden;transform:translateY(12px) scale(.99);transition:transform .24s var(--e)}
.scrim.show .modal{transform:none}
.modal-top{height:3px;background:var(--ac,var(--red))}
.modal.inv{--ac:var(--inv)} .modal.fleet{--ac:var(--fleet)}
.modal-in{padding:22px 24px 20px}
.modal-hd{display:flex;align-items:center;gap:11px;margin-bottom:6px}
.modal-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;
  background:var(--ac-soft,var(--red-soft));color:var(--ac,var(--red));flex-shrink:0}
.modal.inv .modal-ic{--ac-soft:var(--inv-soft)} .modal.fleet .modal-ic{--ac-soft:var(--fleet-soft)}
.modal-ic svg{width:20px;height:20px}
.modal h3{font-family:var(--serif);font-weight:600;font-size:17px;letter-spacing:-.01em}
.modal .sub{color:var(--ink-2);font-size:12.5px;margin:2px 0 16px}
.modal .row{display:flex;gap:10px;margin-top:4px}
.modal .row .btn{flex:1}

/* ====================== Toast ====================== */
.toast{position:fixed;left:50%;top:16px;transform:translateX(-50%) translateY(-18px);z-index:120;
  display:flex;align-items:center;gap:10px;max-width:92vw;padding:10px 14px;border-radius:var(--r);
  background:var(--card);border:1px solid var(--line-2);box-shadow:var(--sh);
  font-size:13px;font-weight:600;color:var(--ink);opacity:0;pointer-events:none;transition:opacity .26s var(--e),transform .26s var(--e)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .ic{width:18px;height:18px;flex-shrink:0;display:grid;place-items:center;border-radius:5px}
.toast .ic svg{width:13px;height:13px}
.toast.t-warn .ic{background:var(--warn-soft);color:var(--warn)}
.toast.t-info .ic{background:var(--good-soft);color:var(--good)}
.toast.t-err .ic{background:var(--red-soft);color:var(--red-dk)}

/* ====================== Launch (barra superior) ====================== */
.launchbar{position:fixed;left:0;top:0;height:3px;width:0;z-index:200;background:var(--ac,var(--red));
  box-shadow:0 0 8px var(--ac,var(--red));transition:width .5s var(--e),opacity .3s;opacity:0}
.launchbar.go{opacity:1;width:100%}
.launchbar.inv{--ac:var(--inv)} .launchbar.fleet{--ac:var(--fleet)}
.shell.dimming{opacity:.55;transition:opacity .4s var(--e)}

/* ====================== Animaciones ====================== */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* ====================== Responsive ====================== */
@media(max-width:720px){
  .grid{grid-template-columns:1fr}
  .clock .c-date{display:none}
  .sess .who{display:none}
  .topbar{height:54px;gap:10px}
  .kbd{display:none}
}
@media(max-width:380px){ .auth-in{padding:24px 20px 20px} }

/* ====================== Accesibilidad ====================== */
:focus-visible{outline:2px solid var(--red);outline-offset:2px;border-radius:5px}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}
