:root{
  /* — paleta día (idéntica a la web aprobada) — */
  --paper:#F3EEE3; --paper2:#EBE4D2; --card:#FAF7EE;
  --ink:#03142D; --ink-70:rgba(3,20,45,.72); --ink-50:rgba(3,20,45,.52);
  --line:rgba(3,20,45,.14); --line-strong:rgba(3,20,45,.34);
  --amber:#A66A0E; --amber-b:#E8B04B;
  /* — paleta noche (SOLO instrumentos) — */
  --night:#03142D; --night2:#020B1C;
  --nline:rgba(198,208,223,.16); --nline-strong:rgba(198,208,223,.34);
  --nsilver:#C6D0DF; --ndim:#8FA5C4; --nfaint:#54698C;
  --aqua:#5FE3D0; --ice:#A8DBFF;
  /* — extensión intranet: semántica de estados (mínima) — */
  --ok:#1F6E54; --ok-bg:rgba(95,227,208,.16);
  --bad:#8C3B2E; --bad-bg:rgba(140,59,46,.10);
  --curso-bg:rgba(232,176,75,.18);
  --neutral-bg:rgba(3,20,45,.06);
  /* — tipografía — */
  --grot:'Archivo','Helvetica Neue',sans-serif;
  --mono:'IBM Plex Mono','Courier New',monospace;
  --lbl-xs:.56rem; --lbl-s:.62rem; --lbl-m:.68rem; --lbl-l:.74rem;
  --ls-tight:.05em; --ls-med:.12em; --ls-wide:.18em;
  /* — geometría herramienta — */
  --r:4px; --r-chip:6px;
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:24px; --sp-6:32px;
  --sidebar-w:236px; --topbar-h:64px;
  --shadow-pop:0 18px 50px -18px rgba(3,20,45,.45);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper); color:var(--ink);
  font-family:var(--grot); font-size:.95rem; line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
::selection{background:var(--ink);color:var(--paper)}
a{color:inherit} img{display:block;max-width:100%}
button{font:inherit;cursor:pointer;color:inherit;background:none;border:none}
:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* — grano de imprenta, más suave que en la web (herramienta) — */
body::after{
  content:"";position:fixed;inset:-50%;z-index:90;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='140' height='140' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* — utilidades de marca — */
.mono{font-family:var(--mono);font-size:var(--lbl-m);letter-spacing:var(--ls-wide);text-transform:uppercase}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:0;text-transform:none}
.amber{color:var(--amber)}
.marks{position:relative}
.mk{position:absolute;width:13px;height:13px;color:var(--line-strong);pointer-events:none;z-index:3}
.mk::before,.mk::after{content:'';position:absolute;background:currentColor}
.mk::before{left:0;right:0;top:6px;height:1px}
.mk::after{top:0;bottom:0;left:6px;width:1px}
.mk.tl{top:-7px;left:-7px}.mk.tr{top:-7px;right:-7px}
.mk.bl{bottom:-7px;left:-7px}.mk.br{bottom:-7px;right:-7px}
.dot{display:inline-block;width:7px;height:7px;background:var(--aqua);vertical-align:middle;margin-right:7px;animation:blink 1.6s steps(2,start) infinite}
.dot.a{background:var(--amber-b)}
@keyframes blink{50%{opacity:.15}}
.rise{opacity:0;transform:translateY(14px);animation:rise .6s cubic-bezier(.16,1,.3,1) forwards;animation-delay:calc(var(--i,0)*70ms)}
@keyframes rise{to{opacity:1;transform:none}}

/* ============ SHELL ============ */
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{
  position:sticky;top:0;height:100vh;display:flex;flex-direction:column;
  background:var(--paper2);border-right:1px solid var(--line);z-index:60;
}
.side-brand{display:flex;align-items:center;gap:.7rem;padding:1rem .9rem;border-bottom:1px solid var(--line)}
.logo-chip{width:48px;height:48px;flex:none;display:grid;place-items:center;background:#02132C;border-radius:var(--r-chip)}
.logo-chip img{width:40px;height:40px}
.side-brand b{font-weight:800;text-transform:uppercase;letter-spacing:.04em;font-size:.86rem;line-height:1.1;display:block}
.side-brand small{display:block;font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-wide);color:var(--ink-50);text-transform:uppercase}
.side-nav{list-style:none;padding:.7rem .55rem;display:flex;flex-direction:column;gap:2px}
.nav-item{
  display:flex;align-items:center;gap:.6rem;text-decoration:none;
  font-family:var(--mono);font-size:var(--lbl-l);letter-spacing:var(--ls-med);text-transform:uppercase;
  color:var(--ink-70);padding:.55rem .65rem;border-left:2px solid transparent;border-radius:2px;
  transition:background .15s linear,color .15s linear;
}
.nav-item .nav-idx{font-size:var(--lbl-xs);color:var(--ink-50)}
.nav-item:hover{background:rgba(3,20,45,.07)}
.nav-item.active{background:var(--ink);color:var(--paper);border-left-color:var(--amber-b)}
.nav-item.active .nav-idx{color:var(--amber-b)}
.presence{margin-top:auto;border-top:1px solid var(--line);padding:.8rem .9rem 1rem}
.presence-title{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink-50);margin-bottom:.6rem}
.presence-item{display:flex;gap:.55rem;align-items:flex-start;padding:.4rem 0;border-top:1px dashed var(--line)}
.presence-item:first-of-type{border-top:none}
.presence-item .p-name{font-weight:700;font-size:.78rem;line-height:1.2}
.presence-item .p-doing{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-tight);color:var(--ink-50);text-transform:none;line-height:1.45}
.ava{
  width:26px;height:26px;flex:none;display:grid;place-items:center;border-radius:var(--r-chip);
  background:var(--ink);font-family:var(--mono);font-size:var(--lbl-xs);font-weight:600;letter-spacing:.03em;
}
.ava--ac{color:var(--amber-b)} .ava--sb{color:var(--ice)} .ava--sc{color:var(--aqua)}
.ava.lg{width:36px;height:36px;font-size:var(--lbl-m)}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:50;height:var(--topbar-h);
  display:flex;align-items:center;gap:1rem;padding:0 clamp(1rem,2.5vw,2rem);
  background:rgba(243,238,227,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);
}
.page-id{display:flex;flex-direction:column;gap:1px;min-width:0}
.page-tag{font-family:var(--mono);font-size:var(--lbl-s);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--amber);font-weight:600}
.page-title{font-size:1.1rem;font-weight:800;text-transform:uppercase;letter-spacing:.03em;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-meta{margin-left:auto;display:flex;align-items:center;gap:.9rem}
.clock{font-family:var(--mono);font-size:var(--lbl-m);letter-spacing:var(--ls-med);text-transform:uppercase;color:var(--ink-50);white-space:nowrap}
.content{padding:clamp(1rem,2.5vw,2rem);display:flex;flex-direction:column;gap:var(--sp-5)}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--sp-4)}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}
.col-9{grid-column:span 9}.col-12{grid-column:span 12}

/* — regla de sección dentro de una pantalla (eco de SEC.XX) — */
.secrule{
  border-top:1px solid var(--line-strong);
  display:flex;justify-content:space-between;align-items:center;gap:12px;padding:.55rem 0 0;
  font-family:var(--mono);font-size:var(--lbl-s);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink-50);
}
.secrule .tag{color:var(--amber);font-weight:600}

/* ============ COMPONENTES ============ */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);position:relative}
.card-hd{display:flex;align-items:center;gap:.7rem;padding:.75rem 1rem;border-bottom:1px solid var(--line)}
.card-hd .t{font-family:var(--mono);font-size:var(--lbl-s);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink-70);font-weight:600}
.card-hd .aux{margin-left:auto;font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-med);text-transform:uppercase;color:var(--ink-50)}
.card-bd{padding:1rem}
.card-bd.flush{padding:0}

.instrument{
  background:linear-gradient(160deg,var(--night),var(--night2));color:var(--nsilver);
  border:1px solid var(--nline-strong);border-radius:var(--r);padding:.9rem 1rem;position:relative;overflow:hidden;
}
.instrument .i-lbl{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ndim)}
.instrument .i-val{font-family:var(--mono);font-size:clamp(1.3rem,2.2vw,1.7rem);font-weight:600;color:var(--moonc, #EDE6D3);margin:.2rem 0 0;font-variant-numeric:tabular-nums}
.instrument .i-val .u{font-size:.7em;color:var(--ndim)}
.instrument .i-sub{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-tight);color:var(--nfaint);margin-top:.25rem;text-transform:none}
.instrument .i-sub .up{color:var(--aqua)} .instrument .i-sub .warn{color:var(--amber-b)}

.badge{
  display:inline-block;font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-med);
  text-transform:uppercase;font-weight:600;padding:.18rem .5rem;border-radius:2px;border:1px solid;white-space:nowrap;
}
.badge--neutral{color:var(--ink-70);background:var(--neutral-bg);border-color:var(--line-strong)}
.badge--curso{color:var(--amber);background:var(--curso-bg);border-color:var(--amber)}
.badge--ok{color:var(--ok);background:var(--ok-bg);border-color:var(--ok)}
.badge--bad{color:var(--bad);background:var(--bad-bg);border-color:var(--bad)}

.btn{
  display:inline-flex;align-items:center;gap:.45rem;
  font-family:var(--mono);font-size:var(--lbl-m);letter-spacing:var(--ls-med);text-transform:uppercase;font-weight:600;
  padding:.55rem .95rem;border:1px solid var(--ink);border-radius:3px;background:var(--card);color:var(--ink);
  transition:background .15s linear,color .15s linear;
}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn--primary{background:var(--ink);color:var(--paper)}
.btn--primary:hover{background:var(--paper);color:var(--ink)}
.btn--ghost{border-color:var(--line-strong);background:transparent;color:var(--ink-70)}
.btn--ghost:hover{background:var(--neutral-bg);color:var(--ink)}
.btn--danger{border-color:var(--bad);color:var(--bad);background:transparent}
.btn--danger:hover{background:var(--bad);color:var(--paper)}
.btn.sm{padding:.3rem .55rem;font-size:var(--lbl-xs)}

.table{width:100%;border-collapse:collapse}
.table th{
  font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-wide);text-transform:uppercase;
  color:var(--ink-50);font-weight:600;text-align:left;padding:.55rem .8rem;border-bottom:1px solid var(--line-strong);
}
.table td{padding:.65rem .8rem;border-bottom:1px solid var(--line);vertical-align:middle;font-size:.86rem}
.table tbody tr{transition:background .12s linear;cursor:pointer}
.table tbody tr:hover{background:var(--paper2)}
.table .num{text-align:right}
.table .row-title{font-weight:700}
.table .row-sub{display:block;font-family:var(--mono);font-size:var(--lbl-xs);color:var(--ink-50);letter-spacing:var(--ls-tight);text-transform:none}

.field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.9rem}
.field>label{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink-50);font-weight:600}
.input,.select,.textarea{
  font-family:var(--grot);font-size:.9rem;color:var(--ink);
  background:var(--paper);border:1px solid var(--line-strong);border-radius:3px;padding:.55rem .7rem;width:100%;
}
.input:focus,.select:focus,.textarea:focus{outline:2px solid var(--amber);outline-offset:0;border-color:var(--amber)}
.textarea{min-height:90px;resize:vertical}
.input.mono,.select.mono{font-family:var(--mono);font-size:.82rem;letter-spacing:0;text-transform:none}

.modal-veil{
  position:fixed;inset:0;z-index:200;display:none;place-items:center;
  background:rgba(3,20,45,.45);backdrop-filter:blur(4px);padding:1rem;
}
.modal-veil.open{display:grid}
.modal{
  background:var(--card);border:1px solid var(--line-strong);border-radius:var(--r);
  width:min(680px,100%);max-height:min(86vh,900px);display:flex;flex-direction:column;
  box-shadow:var(--shadow-pop);animation:pop .35s cubic-bezier(.16,1,.3,1);
}
.modal.wide{width:min(920px,100%)}
@keyframes pop{from{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:none}}
.modal-hd{display:flex;align-items:center;gap:.7rem;padding:.85rem 1.1rem;border-bottom:1px solid var(--line-strong)}
.modal-hd .t{font-family:var(--mono);font-size:var(--lbl-m);letter-spacing:var(--ls-wide);text-transform:uppercase;font-weight:700}
.modal-hd .t .tagn{color:var(--amber);margin-right:.5rem}
.modal-close{margin-left:auto;font-family:var(--mono);font-size:var(--lbl-m);color:var(--ink-50);padding:.2rem .5rem}
.modal-close:hover{color:var(--ink)}
.modal-bd{padding:1.1rem;overflow-y:auto}
.modal-ft{display:flex;gap:.6rem;justify-content:flex-end;padding:.85rem 1.1rem;border-top:1px solid var(--line)}

.tabs{display:flex;gap:.15rem;border-bottom:1px solid var(--line-strong);overflow-x:auto}
.tab{
  font-family:var(--mono);font-size:var(--lbl-m);letter-spacing:var(--ls-med);text-transform:uppercase;
  padding:.55rem .85rem;color:var(--ink-50);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;
}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--ink);border-bottom-color:var(--amber);font-weight:700}
.tabpane{display:none}.tabpane.active{display:block}

.kanban{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(215px,1fr);gap:var(--sp-3);overflow-x:auto;padding-bottom:.5rem;align-items:start}
.kcol{background:var(--paper2);border:1px solid var(--line);border-radius:var(--r);min-height:180px}
.kcol-hd{
  display:flex;align-items:center;gap:.5rem;padding:.55rem .7rem;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:var(--lbl-s);letter-spacing:var(--ls-wide);text-transform:uppercase;font-weight:700;color:var(--ink-70);
}
.kcol-hd .count{margin-left:auto;color:var(--amber);font-weight:600}
.kcol-bd{padding:.55rem;display:flex;flex-direction:column;gap:.55rem}
.kcard{
  background:var(--card);border:1px solid var(--line);border-radius:3px;padding:.6rem .7rem;
  transition:box-shadow .15s linear,transform .15s linear;cursor:grab;
}
.kcard:hover{box-shadow:0 8px 22px -12px rgba(3,20,45,.4);transform:translateY(-1px)}
.kcard.dragging{opacity:.55;cursor:grabbing}
.kcard .k-title{font-weight:700;font-size:.83rem;line-height:1.25}
.kcard .k-meta{font-family:var(--mono);font-size:var(--lbl-xs);color:var(--ink-50);letter-spacing:var(--ls-tight);text-transform:none;margin-top:.3rem;display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}
.kmove{display:flex;gap:.3rem;margin-top:.45rem}
.kmove button{font-family:var(--mono);font-size:var(--lbl-xs);border:1px solid var(--line-strong);border-radius:2px;padding:.1rem .45rem;color:var(--ink-70)}
.kmove button:hover{background:var(--ink);color:var(--paper)}

.meter{height:8px;background:var(--neutral-bg);border:1px solid var(--line);border-radius:2px;overflow:hidden}
.meter-fill{height:100%;background:var(--amber);transition:width .8s cubic-bezier(.16,1,.3,1)}
.meter-fill.ok{background:var(--ok)}

.stat{display:flex;flex-direction:column;gap:.15rem}
.stat-num{font-family:var(--mono);font-size:1.35rem;font-weight:600;font-variant-numeric:tabular-nums}
.stat-lbl{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-wide);text-transform:uppercase;color:var(--ink-50)}

.timeline{list-style:none;position:relative;padding-left:1.1rem}
.timeline::before{content:'';position:absolute;left:4px;top:6px;bottom:6px;width:1px;background:var(--line-strong)}
.tl-item{position:relative;padding:.45rem 0 .45rem .4rem}
.tl-item::before{content:'';position:absolute;left:-1.1rem;top:.85rem;width:9px;height:9px;background:var(--paper);border:2px solid var(--amber);border-radius:50%}
.tl-item.ok::before{border-color:var(--ok);background:var(--ok)}
.tl-when{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-med);text-transform:uppercase;color:var(--ink-50)}
.tl-what{font-size:.86rem;line-height:1.4}
.tl-what b{font-weight:700}

.ledger{list-style:none}
.ledger-row{display:flex;gap:.9rem;align-items:baseline;padding:.65rem .2rem;border-bottom:1px dashed var(--line-strong)}
.ledger-row .l-idx{font-family:var(--mono);font-size:var(--lbl-s);color:var(--amber);font-weight:700;flex:none;letter-spacing:var(--ls-med)}
.ledger-row .l-when{font-family:var(--mono);font-size:var(--lbl-xs);color:var(--ink-50);flex:none}
.ledger-row .l-what{font-size:.86rem}

.drop{
  border:1.5px dashed var(--line-strong);border-radius:var(--r);background:var(--paper);
  display:grid;place-items:center;text-align:center;padding:1.6rem 1rem;cursor:pointer;
  transition:border-color .15s linear,background .15s linear;
}
.drop:hover,.drop.over{border-color:var(--amber);background:var(--curso-bg)}
.drop .d-ico{font-family:var(--mono);font-size:1.3rem;color:var(--amber)}
.drop .d-txt{font-family:var(--mono);font-size:var(--lbl-s);letter-spacing:var(--ls-med);text-transform:uppercase;color:var(--ink-50);margin-top:.4rem}

.sigpad{width:100%;height:180px;background:var(--paper);border:1.5px dashed var(--line-strong);border-radius:3px;cursor:crosshair;touch-action:none;display:block}
.sig-hint{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-med);text-transform:uppercase;color:var(--ink-50);text-align:center;margin-top:.4rem}
.sigslot{border:1px solid var(--line);border-radius:3px;background:var(--paper);min-height:64px;display:grid;place-items:center;padding:.4rem}
.sigslot img{max-height:56px}
.sigslot .pend{font-family:var(--mono);font-size:var(--lbl-xs);letter-spacing:var(--ls-med);text-transform:uppercase;color:var(--ink-50)}

.toast{
  position:fixed;left:50%;bottom:1.2rem;transform:translate(-50%,140%);z-index:300;
  background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:var(--lbl-m);
  letter-spacing:var(--ls-med);text-transform:uppercase;padding:.7rem 1.1rem;border-radius:3px;
  box-shadow:var(--shadow-pop);transition:transform .4s cubic-bezier(.16,1,.3,1);max-width:min(92vw,560px);text-align:center;
}
.toast.show{transform:translate(-50%,0)}
.toast b{color:var(--amber-b)}

/* ============ RESPONSIVE ============ */
@media (max-width:1000px){
  .col-3,.col-4,.col-5{grid-column:span 6}
  .col-6,.col-7,.col-8,.col-9{grid-column:span 12}
}
@media (max-width:760px){
  .app{display:block}
  .sidebar{position:sticky;top:0;height:auto;flex-direction:row;align-items:center;gap:.2rem;border-right:none;border-bottom:1px solid var(--line);overflow:hidden}
  .side-brand{border-bottom:none;padding:.55rem .7rem;flex:none}
  .side-brand .brand-txt{display:none}
  .logo-chip{width:38px;height:38px}.logo-chip img{width:31px;height:31px}
  .side-nav{flex-direction:row;overflow-x:auto;padding:.4rem .3rem;flex:1;scrollbar-width:none}
  .side-nav::-webkit-scrollbar{display:none}
  .nav-item{border-left:none;border-bottom:2px solid transparent;padding:.45rem .55rem;white-space:nowrap}
  .nav-item.active{border-bottom-color:var(--amber-b)}
  .nav-item .nav-idx{display:none}
  .presence{display:none}
  .topbar{height:auto;padding:.6rem 1rem;flex-wrap:wrap;gap:.5rem}
  .clock{display:none}
  .grid .col-3,.grid .col-4,.grid .col-5,.grid .col-6,.grid .col-7,.grid .col-8,.grid .col-9{grid-column:span 12}
  .kanban{grid-auto-columns:82vw}
}
/* ============ MOVIMIENTO REDUCIDO ============ */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;transition-delay:0ms!important}
  .rise{opacity:1;transform:none}
}
