:root{
  /* Marca y acentos (tono del sitio web: azul/indigo) */
  --navy:#0b1220; --navy-2:#0e1626; --navy-3:#17223a;
  --accent:#4f7cff; --accent-2:#4f7cff; --accent-ink:#3b62e0;
  --green:#15a06a; --red:#e0453a; --amber:#e08a1e; --pink:#d65478; --info:#4f7cff;
  /* Escala de grises (slate refinado) */
  --g50:#f8fafc; --g100:#f1f4f8; --g200:#e7ebf1; --g300:#d3dae4; --g400:#9aa6b8; --g500:#64748b; --g600:#475569; --g700:#334155; --g900:#0f172a;
  --bg:#f6f7f9; --card:#ffffff; --card-alt:#f3f5f9; --line:#e8ebf1; --text:#1e293b; --muted:#64748b;
  --radius:14px; --radius-sm:10px; --control-h:40px;
  /* Sombras suaves en capas */
  --shadow-1:0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.06);
  --shadow:0 1px 2px rgba(15,23,42,.04), 0 4px 14px rgba(15,23,42,.06);
  --shadow-2:0 12px 40px rgba(15,23,42,.16);
  --ring:0 0 0 3px rgba(79,124,255,.18);
  --sp1:4px; --sp2:8px; --sp3:12px; --sp4:16px; --sp5:24px;
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14.5px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4{letter-spacing:-.018em;color:var(--g900)}
::selection{background:rgba(79,124,255,.22)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--g300);border-radius:99px;border:2px solid transparent;background-clip:content-box}
::-webkit-scrollbar-thumb:hover{background:var(--g400)}

/* ===== Topbar ===== */
.topbar{height:58px;background:rgba(11,18,32,.92);backdrop-filter:saturate(140%) blur(8px);color:#fff;display:flex;align-items:center;gap:12px;padding:0 16px;position:sticky;top:0;z-index:30;border-bottom:1px solid rgba(255,255,255,.06)}
.brand{font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:9px;flex:1;font-size:15px}
.brand .dot{width:9px;height:9px;border-radius:50%;background:#22d3ee;box-shadow:0 0 0 3px rgba(34,211,238,.22),0 0 12px rgba(34,211,238,.5)}
.icon-btn{background:transparent;border:0;color:#c7d2e5;font-size:20px;cursor:pointer;padding:7px;border-radius:9px;display:inline-flex;align-items:center;transition:background .15s,color .15s}
.icon-btn:hover{background:rgba(255,255,255,.08);color:#fff}
.ghost-btn{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.16);padding:7px 13px;border-radius:9px;cursor:pointer;font-weight:600;font-size:13px;transition:background .15s}
.ghost-btn:hover{background:rgba(255,255,255,.14)}
.demo-toggle{display:flex;background:rgba(255,255,255,.07);border-radius:99px;padding:3px;gap:2px}
.demo-toggle button{border:0;background:transparent;color:#9fb0c9;font-size:12px;font-weight:600;padding:5px 12px;border-radius:99px;cursor:pointer;transition:background .15s,color .15s}
.demo-toggle button:hover{color:#fff}
.demo-toggle button.active{background:var(--accent);color:#fff}
@media(max-width:820px){.demo-toggle{display:none}}

/* ===== Layout / Sidebar ===== */
.layout{display:flex;min-height:calc(100% - 58px)}
.sidebar{width:236px;background:var(--navy);height:calc(100vh - 58px);overflow-y:auto;padding:12px 12px 20px;position:sticky;top:58px;border-right:1px solid rgba(255,255,255,.05);scrollbar-width:thin}
.sidebar::-webkit-scrollbar{width:7px}.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12)}
.sidebar a{display:flex;align-items:center;gap:11px;color:#9fb0c9;text-decoration:none;padding:8px 12px;border-radius:10px;margin:1px 0;font-weight:500;font-size:13.7px;transition:background .15s,color .15s;position:relative}
.sidebar a.navhidden{display:none}
.sidebar a svg{width:18px;height:18px;flex:none;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;opacity:.85}
.sidebar a:hover{background:rgba(255,255,255,.05);color:#e8eefc}
.sidebar a.active{background:rgba(79,124,255,.14);color:#fff}
.sidebar a.active svg{opacity:1;color:var(--accent)}
.sidebar a.active::before{content:"";position:absolute;left:-12px;top:9px;bottom:9px;width:3px;border-radius:0 3px 3px 0;background:var(--accent)}
.nav-sep{color:#5b6c87;font-size:10.5px;font-weight:700;letter-spacing:.12em;margin:14px 8px 4px;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:4px 4px;border-radius:6px;user-select:none}
.nav-sep:hover{color:#8295b3;background:rgba(255,255,255,.03)}
.nav-sep .chev{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;transition:transform .2s}
.nav-sep.collapsed .chev{transform:rotate(-90deg)}

.view{flex:1;padding:26px 28px;max-width:1240px;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.loader{color:var(--muted);padding:40px;text-align:center}

.backbar{position:sticky;top:58px;z-index:12;margin:-26px -28px 14px;padding:12px 28px;background:rgba(246,247,249,.9);backdrop-filter:blur(6px);border-bottom:1px solid var(--line)}
@media(max-width:1023px){.backbar{margin:-18px -18px 14px;padding:10px 18px}}
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:22px;flex-wrap:wrap}
.page-head h1{font-size:24px;margin:0;font-weight:700}
.page-head .sub{color:var(--muted);font-size:13.5px;margin-top:3px}

/* ===== Botones ===== */
.btn{background:var(--accent);color:#fff;border:0;padding:9px 16px;border-radius:10px;font-weight:600;cursor:pointer;font-size:13.5px;min-height:var(--control-h);display:inline-flex;align-items:center;justify-content:center;gap:7px;box-shadow:0 1px 2px rgba(79,124,255,.25);transition:transform .12s,box-shadow .15s,background .15s,filter .15s}
.btn:hover{background:var(--accent-ink);box-shadow:0 4px 14px rgba(79,124,255,.32)}
.btn:active{transform:translateY(1px)}
.btn.sec{background:var(--g100);color:var(--g700);box-shadow:none;border:1px solid var(--line)}
.btn.sec:hover{background:var(--g200)}
.btn.green{background:var(--green);box-shadow:0 1px 2px rgba(21,160,106,.25)}.btn.green:hover{filter:brightness(.95)}
.btn.red{background:var(--red);box-shadow:0 1px 2px rgba(224,69,58,.25)}.btn.red:hover{filter:brightness(.95)}
.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:8px;min-height:0}

/* ===== Tarjetas / stats ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(218px,1fr));gap:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:760px){.grid2{grid-template-columns:1fr}}
.stat{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:17px 19px;box-shadow:var(--shadow-1);transition:box-shadow .18s,transform .18s,border-color .18s}
.stat:hover{box-shadow:var(--shadow);transform:translateY(-1px);border-color:var(--g200)}
.stat .k{color:var(--muted);font-size:12px;font-weight:600;letter-spacing:.02em}
.stat .v{font-size:27px;font-weight:750;margin-top:7px;color:var(--g900);letter-spacing:-.02em;line-height:1.1}
.stat .v.green{color:var(--green)} .stat .v.red{color:var(--red)} .stat .v.amber{color:var(--amber)}
.stat .x{color:var(--muted);font-size:12px;margin-top:4px}

.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-1);overflow:hidden;margin-top:16px}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--line);font-size:13.8px}
th{background:transparent;color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;border-bottom:1px solid var(--line)}
thead tr{background:var(--g50)}
tr:last-child td{border-bottom:0}
tbody tr{transition:background .12s}
tbody tr:hover{background:var(--g50);cursor:pointer}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}

/* ===== Pills / badges ===== */
.pill{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11.5px;font-weight:600;letter-spacing:.01em;line-height:1.4}
.pill.gray{background:var(--g100);color:var(--g600)}
.pill.blue{background:rgba(79,124,255,.12);color:#2f51c9}
.pill.green{background:rgba(21,160,106,.13);color:#0f7a4f}
.pill.amber{background:rgba(224,138,30,.15);color:#9a5a05}
.pill.red{background:rgba(224,69,58,.12);color:#bf2d22}
.pill.pink{background:rgba(214,84,120,.13);color:#a83663}

/* ===== Formularios ===== */
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:6px}
input,select,textarea{font-family:inherit;font-size:13.8px;padding:9px 12px;border:1px solid var(--g200);border-radius:var(--radius-sm);background:#fff;width:100%;color:var(--text);transition:border-color .15s,box-shadow .15s}
input,select{height:var(--control-h)}
input[type=checkbox],input[type=radio]{height:auto;width:auto;accent-color:var(--accent)}
textarea{min-height:74px;resize:vertical;line-height:1.5}
select{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:34px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%2364748b' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat:no-repeat;background-position:right 12px center;cursor:pointer}
input::placeholder,textarea::placeholder{color:var(--g400)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:var(--ring)}
.search{max-width:280px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
label{font-size:12.5px;font-weight:600;color:var(--g700);display:block;margin-bottom:5px}
.field{margin-bottom:2px}

/* ===== Modal ===== */
.modal{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px;animation:fade .15s ease}
.modal[hidden]{display:none}
.modal-card{background:#fff;border-radius:16px;width:100%;max-width:660px;max-height:90vh;overflow:auto;box-shadow:var(--shadow-2);animation:pop .18s cubic-bezier(.2,.8,.2,1)}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:none}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:2}
.modal-head h3{margin:0;font-size:17px;font-weight:700}
.modal-body{padding:20px}
.modal-foot{display:flex;justify-content:flex-end;gap:9px;margin-top:20px}
.lines-table input{padding:6px 8px}

/* ===== Estado vacío + skeleton ===== */
.empty{padding:36px;text-align:center;color:var(--muted)}
.empty-box{padding:48px 24px;text-align:center;color:var(--muted)}
.empty-box svg{width:52px;height:52px;opacity:.4;margin-bottom:10px;stroke:var(--g400);fill:none;stroke-width:1.4}
.empty-box .et{font-weight:700;color:var(--g700);font-size:15px}
.empty-box .es{font-size:13px;margin:4px 0 14px}
.skeleton{background:linear-gradient(90deg,var(--g100) 25%,#e9edf3 37%,var(--g100) 63%);background-size:400% 100%;animation:sk 1.3s ease infinite;border-radius:10px}
@keyframes sk{0%{background-position:100% 0}100%{background-position:0 0}}
.sk-row{height:46px;margin:8px 0}
.sk-card{height:96px}

/* ===== Toast ===== */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--g900);color:#fff;padding:12px 20px;border-radius:11px;box-shadow:var(--shadow-2);z-index:60;font-weight:600;font-size:13.5px;animation:toastIn .25s cubic-bezier(.2,.8,.2,1)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,12px)}to{opacity:1;transform:translate(-50%,0)}}
.toast.err{background:var(--red)}

.bar{height:8px;background:var(--g100);border-radius:99px;overflow:hidden;margin-top:6px}
.bar>span{display:block;height:100%;background:linear-gradient(90deg,var(--accent),#6f93ff);border-radius:99px;transition:width .4s ease}

/* ===== Tabs / RAG / workspace ===== */
.tabs{display:flex;gap:6px;border-bottom:1px solid var(--line);margin:18px 0 0;flex-wrap:wrap}
.tab{padding:10px 14px;border:0;background:transparent;color:var(--muted);font-weight:600;font-size:13.8px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s}
.tab:hover{color:var(--g900)}
.tab.active{color:var(--accent-ink);border-bottom-color:var(--accent)}
.tabpane{padding-top:18px}
.rag{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:13px}
.rag .dot{width:10px;height:10px;border-radius:50%}
.rag.Verde .dot{background:var(--green);box-shadow:0 0 0 3px rgba(21,160,106,.16)} .rag.Ambar .dot{background:var(--amber);box-shadow:0 0 0 3px rgba(224,138,30,.16)} .rag.Rojo .dot{background:var(--red);box-shadow:0 0 0 3px rgba(224,69,58,.16)}
.rag.Verde{color:var(--green)} .rag.Ambar{color:var(--amber)} .rag.Rojo{color:var(--red)}
.wshead{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-1);padding:20px 22px}
.wshead .meta{display:flex;gap:20px;flex-wrap:wrap;color:var(--muted);font-size:13px;margin-top:10px}
.mat-col{background:var(--g50);border:1px solid var(--line);border-radius:12px;padding:11px;min-height:84px}
.mat-col h5{margin:2px 4px 9px;font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:600}
.mat-item{background:#fff;border:1px solid var(--line);border-radius:9px;padding:8px 10px;margin-bottom:7px;font-size:13px;cursor:pointer;box-shadow:var(--shadow-1);transition:transform .12s,box-shadow .15s}
.mat-item:hover{transform:translateY(-1px);box-shadow:var(--shadow)}

/* fila clicable genérica (chat/buzón) */
.canrow{transition:background .12s}
.canrow:hover{background:var(--g100)}

/* ===== Chat moderno ===== */
.chat{display:grid;grid-template-columns:262px 1fr;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--card);box-shadow:var(--shadow-1);height:calc(100vh - 210px);min-height:480px;margin-top:8px}
.chat-side{border-right:1px solid var(--line);background:var(--g50);overflow:auto;padding:10px}
.chan{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;cursor:pointer;font-size:13.5px;color:var(--g700);font-weight:500;transition:background .12s;margin-bottom:2px}
.chan:hover{background:var(--g100)} .chan.active{background:rgba(79,124,255,.12);color:var(--accent-ink);font-weight:600}
.chan .ch{width:24px;height:24px;border-radius:7px;background:var(--g200);color:var(--g500);display:grid;place-items:center;font-size:13px;font-weight:700;flex:none}
.chan.active .ch{background:var(--accent);color:#fff}
.chat-main{display:flex;flex-direction:column;min-width:0}
.chat-head{padding:14px 18px;border-bottom:1px solid var(--line);font-weight:700;display:flex;align-items:center;gap:9px;color:var(--g900)}
.chat-msgs{flex:1;overflow:auto;padding:18px;background:var(--bg);display:flex;flex-direction:column}
.msg{display:flex;gap:10px;margin-bottom:14px;max-width:78%}
.msg .av{width:32px;height:32px;border-radius:50%;flex:none;font-size:12px}
.msg .b{background:#fff;border:1px solid var(--line);border-radius:5px 14px 14px 14px;padding:9px 13px;box-shadow:var(--shadow-1);font-size:14px;line-height:1.45}
.msg .who{font-size:11.5px;color:var(--muted);margin-bottom:3px;font-weight:600;display:flex;gap:7px;align-items:baseline}
.msg .who time{font-weight:400;font-size:10.5px;opacity:.8}
.msg.mio{margin-left:auto;flex-direction:row-reverse}
.msg.mio .b{background:var(--accent);color:#fff;border:0;border-radius:14px 5px 14px 14px}
.msg.mio .who{display:none}
.chat-compose{display:flex;gap:10px;padding:13px 16px;border-top:1px solid var(--line);background:var(--card)}
.chat-compose input{border-radius:99px;background:var(--g50)}

/* ===== Calendario de equipo ===== */
.calbar{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.calbar .mname{font-weight:700;font-size:17px;min-width:170px;text-transform:capitalize}
.cal{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-1)}
.cal .dow{background:var(--g50);padding:9px;text-align:center;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.cal .day{background:#fff;min-height:100px;min-width:0;padding:6px 8px;font-size:12px;position:relative;overflow:hidden}
.cal .day.out{background:var(--g50)}
.cal .day.wknd{background:repeating-linear-gradient(45deg,#f1f4f8,#f1f4f8 6px,#eef1f6 6px,#eef1f6 12px)}
.cal .day.wknd .dn{color:var(--g400)}
.cal .dow.wknd{color:var(--g400)}
.kcard.flash{animation:flash 1.6s ease}
@keyframes flash{0%,100%{box-shadow:var(--shadow-1)}25%,60%{box-shadow:0 0 0 3px var(--accent),var(--shadow)}}
.cal .day.today .dn{background:var(--accent);color:#fff;border-radius:50%;width:22px;height:22px;display:inline-grid;place-items:center}
.cal .day.fest{background:rgba(224,69,58,.045)}
.cal .day .dn{font-weight:600;color:var(--g700);font-size:12.5px}
.cal .day.out .dn{color:var(--g400)}
.cal .festn{font-size:10px;color:var(--red);font-weight:600;margin-top:2px;line-height:1.2}
.cal .ev{margin-top:4px;font-size:10.5px;padding:2px 7px;border-radius:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.cal .ev.vac{background:rgba(21,160,106,.15);color:#0f7a4f}
.cal .ev.baja{background:rgba(224,138,30,.16);color:#9a5a05}
.cal .ev.permiso{background:var(--g100);color:var(--g600)}
.cal .ev.entrega{background:rgba(79,124,255,.13);color:#2f51c9}
.cal .ev.visita{background:rgba(124,92,255,.14);color:#6d4fd6}
.callegend{display:flex;gap:16px;flex-wrap:wrap;margin-top:12px;font-size:12px;color:var(--muted)}
.callegend span{display:inline-flex;align-items:center;gap:6px}
.callegend i{width:11px;height:11px;border-radius:3px;display:inline-block}

/* ===== Notificaciones / chip usuario ===== */
.bell-wrap{position:relative}
.badge{position:absolute;top:1px;right:1px;background:var(--red);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 0 0 2px var(--navy)}
.bell-panel{position:absolute;right:0;top:48px;width:350px;max-height:70vh;overflow:auto;background:#fff;color:var(--text);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow-2);z-index:45}
.bell-panel .nh{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700}
.noti{padding:12px 16px;border-bottom:1px solid var(--line);font-size:13.5px;cursor:pointer;transition:background .12s}
.noti:hover{background:var(--g50)}
.noti.unread{background:rgba(79,124,255,.05)}
.noti .nt{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-ink)}
.noti .nm{margin-top:3px;color:var(--text)}
.noti .nd{color:var(--muted);font-size:11.5px;margin-top:4px}
.user-chip{display:flex;align-items:center;gap:9px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;padding:5px 9px 5px 5px;border-radius:99px;transition:background .15s}
.user-chip:hover{background:rgba(255,255,255,.08)}
.user-chip .av,.av{display:inline-flex;align-items:center;justify-content:center;font-weight:700;overflow:hidden}
.av .avimg{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.av-lg{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#4f7cff,#7c5cff);color:#fff;font-size:24px;flex:none}
.user-chip .av{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#4f7cff,#7c5cff);color:#fff;font-size:11.5px}

/* ===== Login ===== */
.login-overlay{position:fixed;inset:0;background:radial-gradient(1200px 600px at 20% -10%,#16244a,transparent),radial-gradient(900px 500px at 100% 100%,#1a2b57,transparent),#0b1220;display:flex;align-items:center;justify-content:center;z-index:100;padding:18px}
.login-overlay[hidden]{display:none}
.login-card{background:rgba(255,255,255,.98);border-radius:20px;padding:34px;width:100%;max-width:392px;box-shadow:0 30px 80px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.5)}
.login-brand{font-weight:800;font-size:20px;display:flex;align-items:center;gap:9px;color:var(--g900);letter-spacing:-.02em}
.login-brand .dot{width:10px;height:10px;border-radius:50%;background:linear-gradient(135deg,#22d3ee,#4f7cff)}
.login-sub{color:var(--muted);margin:5px 0 20px;font-size:13.5px}
.login-card label{margin-top:12px}
.login-hint{text-align:center;color:var(--muted);font-size:12px;margin:16px 0 0}

/* ===== Kanban ===== */
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;align-items:start}
.kcol{background:var(--g50);border:1px solid var(--line);border-radius:14px;padding:11px;min-height:140px}
.kcol h4{margin:2px 6px 11px;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);display:flex;justify-content:space-between;font-weight:600}
.kcard{background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 12px;margin-bottom:10px;box-shadow:var(--shadow-1);cursor:pointer;transition:transform .12s,box-shadow .15s,border-color .15s}
.kcard:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:var(--g200)}
.kcard .tt{font-weight:600;font-size:13.8px;color:var(--g900)}
.kcard .meta{display:flex;justify-content:space-between;align-items:center;margin-top:9px;font-size:11.5px;color:var(--muted)}
.kcard .resp{display:inline-flex;align-items:center;gap:5px}
.kcard .resp .av{width:21px;height:21px;border-radius:50%;background:linear-gradient(135deg,#4f7cff,#7c5cff);color:#fff;font-size:10px}
.kcard.entrega{border-left:3px solid var(--amber)}
.klabels{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:8px}
.klabel{height:7px;width:34px;border-radius:99px}
.kbadges{display:flex;gap:6px;flex-wrap:wrap;margin-top:9px}
.kbadge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--g600);background:var(--g100);padding:2px 7px;border-radius:7px}
.kbadge svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.8}
.kbadge.red{background:rgba(224,69,58,.12);color:#bf2d22} .kbadge.green{background:rgba(21,160,106,.13);color:#0f7a4f}
/* checklist editor */
.clitem{display:flex;align-items:center;gap:9px;padding:6px 0;border-bottom:1px solid var(--line)}
.clitem input[type=text]{border:0;padding:4px 0;height:auto;background:transparent}
.clitem.done input[type=text]{text-decoration:line-through;color:var(--muted)}
.chip-lab{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600;color:#fff}
.labpal{display:flex;gap:4px}
.labpal .swatch{width:22px;height:22px;border-radius:6px;border:2px solid transparent;cursor:pointer;padding:0}
.labpal .swatch.sel{border-color:var(--g900);box-shadow:0 0 0 2px #fff inset}

/* matriz de permisos */
.permgrid{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.permhead,.permrow{display:grid;grid-template-columns:1.4fr repeat(4,68px) 70px;align-items:center}
.permhead{background:var(--g50);padding:10px 14px;font-size:11.5px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;text-align:center}
.permhead>div:first-child{text-align:left}
.permrow{padding:6px 14px;border-top:1px solid var(--line)}
.permrow:hover{background:var(--g50)}
.permmod{font-weight:600;color:var(--g900);font-size:13.5px}
.permcell{display:flex;justify-content:center;align-items:center;cursor:pointer;margin:0}
.permcell input{width:18px;height:18px;cursor:pointer}
.permall{justify-self:center}
.kmove{display:flex;gap:5px;margin-top:9px}
.kmove button{flex:1;font-size:11px;padding:5px;border:1px solid var(--line);background:#fff;border-radius:7px;cursor:pointer;color:var(--g600);transition:background .15s,color .15s}
.kmove button:hover{background:var(--accent);color:#fff;border-color:transparent}
.prio{width:8px;height:8px;border-radius:50%;display:inline-block}
.prio.Alta,.prio.Urgente{background:var(--red)} .prio.Normal{background:var(--accent)} .prio.Baja{background:var(--g400)}
@media(max-width:980px){.kanban{grid-template-columns:1fr 1fr}}

/* ===== Off-canvas ===== */
#menuBtn{display:none}
.scrim{position:fixed;inset:58px 0 0 0;background:rgba(15,23,42,.5);z-index:39;opacity:0;pointer-events:none;transition:opacity .2s}
.scrim.show{opacity:1;pointer-events:auto}
body.no-scroll{overflow:hidden}
@media(max-width:1023px){
  #menuBtn{display:inline-flex;align-items:center}
  .sidebar{position:fixed;left:0;top:58px;z-index:40;height:calc(100vh - 58px);width:256px;
    transform:translateX(-100%);transition:transform .22s ease;box-shadow:var(--shadow-2)}
  .sidebar.open{transform:translateX(0)}
  .view{padding:18px;max-width:100%}
}
@media(max-width:860px){ .form-grid{grid-template-columns:1fr} }

/* Selector de días en calendario (vacaciones) */
.daypick{border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px;background:var(--card);user-select:none;-webkit-user-select:none;touch-action:none}
.dp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.dp-title{font-weight:700;color:var(--navy);font-size:14px}
.dp-nav{width:30px;height:30px;border:1px solid var(--line);background:#fff;border-radius:8px;cursor:pointer;font-size:18px;line-height:1;color:var(--navy);padding:0}
.dp-nav:hover{background:var(--card-alt)}
.dp-wd{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.dp-wd span{text-align:center;font-size:11px;font-weight:600;color:var(--muted)}
.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.dp-cell{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;border-radius:8px;font-size:13px;cursor:pointer;border:1px solid transparent;color:var(--text);position:relative}
.dp-cell:hover:not(.off):not(.empty){background:var(--card-alt)}
.dp-cell.empty{cursor:default}
.dp-cell.wknd,.dp-cell.fest{color:#aab2c0;background:repeating-linear-gradient(45deg,#f3f5f9,#f3f5f9 4px,#eef1f6 4px,#eef1f6 8px)}
.dp-cell.fest{color:var(--red)}
.dp-cell.past{color:#c3c9d4;cursor:default}
.dp-cell.off{cursor:default}
.dp-cell.prev{box-shadow:inset 0 0 0 2px var(--red);color:var(--red);font-weight:700}
.dp-cell.sel{background:var(--navy);color:#fff;font-weight:700;border-color:var(--navy)}
.dp-cell.sel.prev{box-shadow:inset 0 0 0 2px var(--red)}

/* Fichaje: modalidad y caja NFC */
.modchips{display:inline-flex;gap:0;border:1px solid var(--line);border-radius:999px;overflow:hidden;margin-top:4px}
.modchips button{border:0;background:#fff;color:var(--muted);font-weight:600;font-size:12.5px;padding:7px 14px;cursor:pointer;width:auto;border-radius:0}
.modchips button.active{background:var(--navy);color:#fff}
.nfcbox{margin-top:16px;text-align:left;font-size:12.5px;color:var(--muted)}
.nfcbox summary{cursor:pointer;font-weight:600;color:var(--navy)}
.nfcbox p{margin:8px 0}
.nfcbox code{display:block;background:var(--card-alt);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:12px;word-break:break-all;color:var(--text)}

/* Filtros de listado */
.listbar{display:flex;gap:8px;align-items:center;margin:14px 0 0;flex-wrap:wrap}
.listbar .f-buscar{max-width:280px;height:var(--control-h)}
.listbar .f-estado{max-width:200px;height:var(--control-h)}
.listbar .f-count{color:var(--muted);font-size:12.5px}
.listbar + .panel{margin-top:10px}

/* Toggle de vista (tarjetas/lista) */
.vtoggle{display:inline-flex;border:1px solid var(--line);border-radius:999px;overflow:hidden;margin-right:8px}
.vtoggle button{border:0;background:#fff;color:var(--muted);font-weight:600;font-size:12.5px;padding:8px 14px;cursor:pointer;width:auto;border-radius:0}
.vtoggle button.active{background:var(--navy);color:#fff}
