:root{--ink: #0f2832;--ink-soft: #45575f;--ink-faint: #7c8d95;--line: #e2e8ec;--line-strong: #ccd6db;--paper: #f3f7fa;--paper-raised: #ffffff;--primary: #106080;--primary-soft: #15789b;--primary-deep: #0b475f;--primary-tint: #dcecf3;--cyan: #45b6d8;--cyan-tint: #e0f2f9;--accent: #e0a92e;--accent-tint: #fbf0d6;--danger: #b23b2e;--ok: #2f7d52;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 2px rgba(16, 96, 128, .05), 0 8px 24px rgba(16, 96, 128, .08);--shadow-lift: 0 10px 40px rgba(16, 96, 128, .16);--font: "Hanken Grotesk", ui-sans-serif, system-ui, sans-serif;--mono: "Spline Sans Mono", ui-monospace, monospace}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;font-size:15px;line-height:1.5}button{font-family:inherit;cursor:pointer}input,select,button{font-size:15px}.mono{font-family:var(--mono);font-feature-settings:"tnum" 1}.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid transparent;border-radius:var(--radius-sm);padding:9px 16px;font-weight:600;letter-spacing:-.01em;transition:transform .06s ease,background .15s ease,box-shadow .15s ease}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-soft)}.btn-ghost{background:transparent;color:var(--ink-soft);border-color:var(--line-strong)}.btn-ghost:hover{background:var(--paper-raised);color:var(--ink)}.btn:disabled{opacity:.55;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--ink-faint)}.input,.select{width:100%;padding:10px 12px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--paper-raised);color:var(--ink);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-tint)}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.7}.badge-accent{background:var(--accent-tint);color:#9a5510}.badge-muted{background:var(--line);color:var(--ink-soft)}.auth-wrap{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(1100px 600px at 50% -25%,var(--cyan-tint),transparent 60%),linear-gradient(180deg,var(--primary-tint),var(--paper))}.auth-card{width:100%;max-width:380px;background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-lift);padding:32px}.auth-brand{display:flex;justify-content:center;margin-bottom:6px}.auth-logo{width:100%;max-width:240px;height:auto;display:block}.auth-sub{color:var(--ink-faint);font-size:13px;text-align:center;margin-bottom:24px}.auth-card form{display:flex;flex-direction:column;gap:16px}.alert{border-radius:var(--radius-sm);padding:10px 12px;font-size:13.5px}.alert-error{background:#f7e4e1;color:#8a2c22}.shell{display:grid;grid-template-columns:232px 1fr;min-height:100%}.sidebar{background:var(--primary-deep);color:#cfe2ea;display:flex;flex-direction:column;padding:20px 16px;position:sticky;top:0;align-self:start;height:100vh;overflow-y:auto;box-sizing:border-box}.sidebar-logo{background:#fff;border-radius:10px;padding:12px 14px;margin-bottom:20px}.sidebar-logo img{width:100%;height:auto;display:block}.nav{display:flex;flex-direction:column;gap:2px;flex:1}.nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);color:#bcd6e0;text-decoration:none;font-weight:600;transition:background .15s ease,color .15s ease}.nav a:hover{background:#ffffff14;color:#fff}.nav a.active{background:#ffffff24;color:#fff;box-shadow:inset 3px 0 0 0 var(--cyan)}.sidebar-foot{border-top:1px solid rgba(255,255,255,.14);padding-top:14px;margin-top:14px}.sidebar-foot .who{font-size:12.5px;color:#9cc3d2;padding:0 8px 10px;word-break:break-all}.sidebar-foot .who .rol{display:inline-block;margin-top:4px}.logout{width:100%;text-align:left;background:transparent;color:#cfe2de;border:1px solid rgba(255,255,255,.18);border-radius:var(--radius-sm);padding:9px 12px;font-weight:600}.logout:hover{background:#ffffff14;color:#fff}.main{padding:32px 36px;overflow:auto}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.page-head h1{font-size:24px;letter-spacing:-.02em;margin:0}.page-head .count{color:var(--ink-faint);font-size:13px;margin-top:2px}.toolbar{display:flex;gap:10px;margin-bottom:14px}.toolbar .input{max-width:320px}.table-card{background:var(--paper-raised);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}table{width:100%;border-collapse:collapse}thead th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-faint);font-weight:700;padding:13px 18px;border-bottom:1px solid var(--line);background:#fbfaf4}tbody td{padding:13px 18px;border-bottom:1px solid var(--line)}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#fbfaf4}.cell-code{font-family:var(--mono);font-weight:600;color:var(--primary)}.empty{padding:48px;text-align:center;color:var(--ink-faint)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#14201f52;display:flex;justify-content:flex-end;z-index:50;animation:fade .15s ease}.drawer{width:420px;max-width:92vw;height:100%;background:var(--paper-raised);box-shadow:var(--shadow-lift);padding:28px;overflow:auto;animation:slide .2s cubic-bezier(.2,.8,.2,1)}.drawer h2{margin:0 0 4px;font-size:19px;letter-spacing:-.02em}.drawer .sub{color:var(--ink-faint);font-size:13px;margin-bottom:22px}.drawer form{display:flex;flex-direction:column;gap:16px}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.check{display:flex;align-items:center;gap:9px}.check input{width:16px;height:16px;accent-color:var(--primary)}.check label{font-size:14px;color:var(--ink)}.drawer-actions{display:flex;gap:10px;margin-top:8px}.drawer-actions .btn{flex:1;justify-content:center}@keyframes fade{0%{opacity:0}to{opacity:1}}@keyframes slide{0%{transform:translate(24px);opacity:.6}to{transform:none;opacity:1}}.center-screen{min-height:100%;display:grid;place-items:center;color:var(--ink-faint)}.topbar,.nav-overlay{display:none}@media (max-width: 900px){.shell{grid-template-columns:1fr}.topbar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:40;background:var(--primary-deep);padding:9px 14px}.topbar .hamb{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:9px;border:none;background:#ffffff1f;color:#fff;cursor:pointer}.topbar .hamb:active{background:#ffffff38}.topbar-logo{background:#fff;border-radius:8px;padding:5px 9px;line-height:0}.topbar-logo img{height:22px;width:auto;display:block}.sidebar{position:fixed;top:0;left:0;z-index:60;width:270px;max-width:84vw;height:100vh;transform:translate(-100%);transition:transform .22s ease}.sidebar.open{transform:translate(0);box-shadow:0 0 50px #00000073}.nav-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:55;background:#08141e80}.main{padding:18px 16px}.page-head{flex-wrap:wrap;gap:8px;margin-bottom:16px}.page-head h1{font-size:20px}}@media (prefers-reduced-motion: reduce){.sidebar{transition:none}}@media (max-width: 760px){.dom-controls{gap:12px}.dom-controls>*{flex:1 1 100%!important;min-width:0!important;width:100%}.dom-controls .btn{width:100%}}.dom-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
