*,*:before,*:after{box-sizing:border-box}:root{--navy: #1B3A6B;--navy-light: #2451A3;--accent: #3B82F6;--teal: #0F9E72;--teal-light: #E1F7F0;--teal-border: #9FE1CB;--amber: #B45309;--amber-light: #FEF3C7;--amber-border: #FCD34D;--red: #DC2626;--green: #16A34A;--gray-50: #F8FAFC;--gray-100: #F1F5F9;--gray-200: #E2E8F0;--gray-300: #CBD5E1;--gray-500: #64748B;--gray-700: #334155;--bg: #EEF2F9;--surface: #FFFFFF;--border: #DDE3EE;--text: #0F172A;--text-2: #475569;--text-3: #94A3B8;--rs: 8px;--r: 12px;--sh: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);--sh-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.05);--sh-lg: 0 12px 24px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.06)}html{-webkit-tap-highlight-color:transparent}body{margin:0;font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.55}button,input,textarea,select{font:inherit}button{cursor:pointer;border:0}a{color:inherit;text-decoration:none}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden;background:linear-gradient(150deg,#1b3a6b,#2451a3 45%,#1a6b5c)}.login-screen:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 20% 80%,rgba(59,130,246,.25) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(15,158,114,.2) 0%,transparent 55%)}.login-card{width:100%;max-width:420px;padding:44px 36px;background:var(--surface);border-radius:24px;box-shadow:var(--sh-lg);position:relative;z-index:1}.brand-row{display:flex;align-items:center;gap:12px;margin-bottom:32px}.brand-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--navy);color:#fff;font-size:24px;box-shadow:0 4px 12px #1b3a6b59;flex-shrink:0}.brand-text{line-height:1.1}.brand-name{font-size:20px;font-weight:800;line-height:1}.brand-name span{color:var(--accent)}.brand-tagline{font-size:11px;color:var(--text-3);font-weight:500;letter-spacing:.3px}.login-h{margin:0 0 4px;font-size:22px;font-weight:700}.login-sub{margin:0 0 26px;color:var(--text-3);font-size:13px}.lfield{display:block;margin-bottom:16px}.lfield>span,.ff span{display:block;margin-bottom:6px;color:var(--text-2);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.lfield input,.ff input,.ff textarea,.hist-inp,.hist-sel{width:100%;padding:13px 15px;border:1.5px solid var(--border);border-radius:var(--rs);background:var(--gray-50);color:var(--text);outline:none;transition:border-color .2s,box-shadow .2s,background .2s;font-size:15px}.lfield input:focus,.ff input:focus,.ff textarea:focus,.hist-inp:focus,.hist-sel:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61f;background:#fff}.lfield input.err,.dni-inp.err{border-color:var(--red)}.lfield small{display:block;margin-top:4px;color:var(--red);font-size:11px}.inline-error{display:block;margin-top:-10px;margin-bottom:12px;color:var(--red);font-size:12px}.btn-login,.btn-generar,.btn-buscar,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:var(--rs);font-weight:800;transition:transform .18s,background .18s,opacity .18s}.btn-login{width:100%;padding:14px;background:var(--navy);color:#fff;box-shadow:0 3px 10px #1b3a6b59;font-size:16px;font-weight:700;letter-spacing:.2px}.btn-generar{width:100%;padding:15px;background:var(--navy);color:#fff;box-shadow:0 3px 10px #1b3a6b4d;font-size:16px;letter-spacing:.2px}.btn-login:hover,.btn-generar:hover,.btn-buscar:hover{background:var(--navy-light);box-shadow:0 6px 16px #1b3a6b66}.btn-login:active{transform:scale(.985)}button:disabled{cursor:not-allowed;opacity:.5}.setup-box{display:grid;gap:8px;margin-bottom:18px;padding:14px;border:1px solid var(--amber-border);border-radius:var(--rs);background:var(--amber-light);color:var(--amber)}.setup-box code{padding:8px;border-radius:6px;background:#fff;color:var(--text);word-break:break-all}.setup-box input{width:100%;padding:8px;border:1px solid var(--amber-border);border-radius:6px;font-size:12px}.login-hint{margin-top:20px;padding:10px;border-radius:var(--rs);background:var(--gray-50);color:var(--text-3);text-align:center;font-size:12px}.login-hint i{vertical-align:-3px;font-size:14px}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:20;height:58px;padding:0 20px;display:flex;align-items:center;justify-content:space-between;background:var(--navy);box-shadow:0 2px 8px #0003}.hbrand,.hright,.header-user-wrap{display:flex;align-items:center;gap:10px}.hlogo{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:#ffffff26;color:#fff;font-size:16px}.hname{color:#fff;font-size:15px;font-weight:900;line-height:1}.hname span{color:#60a5fa}.htag{color:#ffffff80;font-size:9px;font-weight:500;letter-spacing:.4px;display:block;margin-top:1px}.htime{color:#fff9;font-size:12px;font-variant-numeric:tabular-nums;display:none}.huser{color:#ffffffbf;font-size:12px}.havatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff3;color:#fff;font-size:12px;font-weight:700}.btn-logout{padding:6px 11px;border:1px solid rgba(255,255,255,.18);border-radius:6px;background:#ffffff1a;color:#fffc;font-size:12px;font-weight:600;white-space:nowrap}.btn-logout:hover{background:#ffffff38}.app-body{display:flex;flex:1;min-height:0}.sidebar{width:228px;flex-shrink:0;padding:18px 10px;background:var(--surface);border-right:1px solid var(--border)}.snav-section{display:block;padding:12px 8px 5px;color:var(--text-3);font-size:9px;font-weight:800;letter-spacing:.9px;text-transform:uppercase}.snav-item{display:flex;align-items:center;gap:9px;padding:10px;border-radius:var(--rs);color:var(--text-2);font-size:13px;font-weight:500}.snav-item:hover,.snav-item.router-link-active{background:#eef4ff;color:var(--navy);font-weight:700}.snav-item i{width:20px;flex-shrink:0;font-size:17px}.snav-badge{margin-left:auto;min-width:22px;padding:2px 7px;border-radius:10px;background:var(--amber-light);color:var(--amber);font-size:10px;text-align:center}.main{flex:1;min-width:0;padding:24px;overflow-y:auto}.page-title{margin:0 0 3px;font-size:19px;font-weight:800}.page-sub{margin:0 0 22px;color:var(--text-3);font-size:13px}.reg-wrap{max-width:620px}.doc-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:14px}.doc-card{min-height:70px;padding:10px 12px;border:1.5px solid var(--border);border-radius:var(--r);background:#fff;color:var(--text-2);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2px;box-shadow:var(--sh);text-align:center;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s}.doc-card:hover{transform:translateY(-1px);border-color:var(--accent);box-shadow:var(--sh-md)}.doc-card.active{border-color:var(--navy);background:#eef4ff;color:var(--navy);box-shadow:0 0 0 1px #1b3a6b59}.doc-card-code{font-size:18px;font-weight:900;letter-spacing:.2px;line-height:1}.doc-card-meta{font-size:12px;font-weight:500;color:inherit;opacity:.8}.dni-row{display:flex;gap:10px;margin-bottom:20px;align-items:stretch}.dni-input-wrap{flex:1;min-width:0;display:flex;align-items:center;gap:8px;padding:0 12px;border:2px solid var(--border);border-radius:var(--rs);background:var(--surface);box-shadow:0 1px 2px #0f172a0a;transition:border-color .2s,box-shadow .2s}.dni-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f61a}.dni-input-wrap.err{border-color:var(--red)}.dni-prefix{padding:5px 9px;border:1px solid #C7D2FE;border-radius:6px;background:#eef4ff;color:var(--navy);font-size:12px;font-weight:800;line-height:1;flex-shrink:0}.dni-inp{flex:1;min-width:0;padding:14px 0;border:0;border-radius:0;background:transparent;font-size:17px;font-weight:600;letter-spacing:.8px;outline:none}.dni-inp:focus{box-shadow:none}.btn-buscar{min-width:112px;height:56px;padding:0 22px;background:var(--navy);color:#fff;font-size:14px;font-weight:700;white-space:nowrap;flex-shrink:0;box-shadow:0 2px 8px #1b3a6b40}.btn-buscar:active{transform:scale(.97)}.client-found,.client-new-warn{margin:18px 0;border-radius:var(--rs)}.client-found{display:flex;align-items:center;gap:13px;padding:14px 16px;border:1.5px solid var(--teal-border);background:var(--teal-light)}.cf-icon{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:var(--teal);color:#fff;font-weight:900}.cf-name{color:#0c5e45;font-weight:800}.cf-doc{color:var(--teal);font-size:12px}.client-new-warn{padding:12px 14px;border:1.5px solid var(--amber-border);background:var(--amber-light);color:var(--amber);font-size:13px;font-weight:700}.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:16px}.fgrid .full{grid-column:1 / -1}.ff label{display:block;font-size:10px;font-weight:700;color:var(--text-3);letter-spacing:.5px;text-transform:uppercase;margin-bottom:5px}.ff input,.ff textarea{font-size:14px}.ff textarea{resize:vertical;min-height:68px}.tram-section{margin-top:16px;padding-top:18px;border-top:1px solid var(--border)}.tram-heading{margin:0 0 12px;color:var(--text-2);font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;display:flex;align-items:center;gap:6px}.tram-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:8px}.tbtn{min-height:48px;padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--rs);background:var(--gray-50);color:var(--text-2);text-align:left;font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;line-height:1.3}.tbtn:hover{border-color:var(--accent);background:var(--gray-100);color:var(--navy)}.tbtn.sel{border-color:var(--navy);background:#eef4ff;color:var(--navy);font-weight:700;box-shadow:0 0 0 1px var(--navy)}.tbtn i{font-size:17px;flex-shrink:0;opacity:.75}.tbtn.sel i{opacity:1}.otros-wrap{display:block;margin-top:10px}.btn-generar{margin-top:20px}.btn-generar:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none}.ticket-ok{margin-top:20px;overflow:hidden;border:2.5px solid var(--navy);border-radius:var(--r);background:#fff}.tok-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--navy);color:#fff}.tok-num{font-size:48px;font-weight:900;line-height:1;letter-spacing:-2px}.tok-divider{width:1px;height:56px;background:#ffffff40}.tok-info{color:#fff}.tok-tramite{font-size:13px;font-weight:700;opacity:.9}.tok-cliente{margin-top:3px;opacity:.6;font-size:11px}.tok-body{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:16px 20px}.tok-meta{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.tok-m-item .val{font-size:13px;font-weight:700}.tok-m-item .lbl{color:var(--text-3);font-size:9px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.tok-pill{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid var(--amber-border);border-radius:20px;background:var(--amber-light);color:var(--amber);font-size:12px;font-weight:700}.tok-pill:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.btn-nuevo{width:100%;margin-top:14px;padding:13px;border:1px solid var(--border);border-radius:var(--rs);background:var(--gray-100);color:var(--text-2);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px}.btn-nuevo:hover{background:var(--gray-200)}.queue-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}.status-row{display:flex;gap:10px}.sstat{min-width:110px;padding:10px 16px;border-radius:var(--rs);border:1px solid var(--border);background:#fff;box-shadow:var(--sh);display:flex;align-items:center;gap:10px}.sstat .snum{display:block;font-size:22px;font-weight:900;line-height:1}.sstat .slbl{color:var(--text-3);font-size:11px;line-height:1.2}.sstat.sw .snum{color:var(--amber)}.sstat.sa .snum{color:var(--teal)}.queue-box{border:2.5px solid var(--navy);border-radius:var(--r);background:#fff;box-shadow:var(--sh-md);overflow:hidden}.queue-box-title{padding:11px 16px;background:var(--navy);color:#fff;font-size:13px;font-weight:700;letter-spacing:.2px;display:flex;align-items:center;gap:8px}.tgrid{display:grid;grid-template-columns:repeat(4,1fr)}.tcell{min-height:145px;padding:16px 12px;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:3px;background:#fff;transition:background .2s}.tcell.waiting{border-left:3px solid var(--amber)}.tcell.attending{border-left:3px solid var(--teal);background:#f0fbf7}.tcnum{font-size:22px;font-weight:900;color:var(--navy);letter-spacing:.3px}.tcdni{font-size:11px;font-weight:600;color:var(--text-2);margin-top:3px}.tcname{font-size:12px;font-weight:700;color:var(--text);line-height:1.2}.tctram{max-width:120px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:10px;color:var(--accent);font-weight:600}.tcdatetime{font-size:10px;color:var(--text-3)}.tctimer{font-size:16px;font-weight:900;color:var(--teal);font-variant-numeric:tabular-nums;letter-spacing:.5px}.btn-atender,.btn-finalizar{margin-top:8px;padding:6px 18px;border-radius:5px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;background:#fff}.btn-atender{border:1.5px solid var(--navy);color:var(--navy)}.btn-atender:hover{background:var(--navy);color:#fff}.btn-finalizar{margin-top:6px;padding:6px 16px;border:1.5px solid var(--teal);color:var(--teal)}.btn-finalizar:hover{background:var(--teal);color:#fff}.q-empty{grid-column:1 / -1;padding:48px 20px;color:var(--text-3);text-align:center}.q-empty i{display:block;margin-bottom:10px;font-size:48px;opacity:.3}.hist-ctrl{margin-bottom:14px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--r);background:#fff;display:flex;gap:12px;flex-wrap:nowrap;align-items:center}.hist-inp{flex:1 1 auto;min-width:0;padding:9px 12px;font-size:13px}.hist-sel{flex:0 0 auto;min-width:0;padding:9px 12px;font-size:13px;color:var(--text)}.hist-ctrl .hist-sel[type=date]{width:156px}.hist-ctrl select.hist-sel{width:160px}.twrap{overflow:hidden;border:1px solid var(--border);border-radius:var(--r);background:#fff;box-shadow:var(--sh)}.dtable{width:100%;border-collapse:collapse;font-size:12.5px}.dtable thead{background:var(--gray-100);border-bottom:1px solid var(--border)}.dtable th{padding:10px 12px;text-align:left;white-space:nowrap;cursor:pointer;user-select:none;color:var(--text-3);font-size:9.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.dtable th:hover{color:var(--navy)}.dtable td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.dtable tr:last-child td{border-bottom:none}.dtable tr:hover td{background:var(--gray-50)}.mono{font-family:Courier New,monospace;font-size:11.5px;color:var(--text-2)}.sbadge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700}.sbadge:before{content:"";width:5px;height:5px;border-radius:50%;background:currentColor}.sb-w{border:1px solid var(--amber-border);background:var(--amber-light);color:var(--amber)}.sb-a{border:1px solid var(--teal-border);background:var(--teal-light);color:var(--teal)}.sb-d{border:1px solid var(--gray-200);background:var(--gray-100);color:var(--gray-700)}.no-results{height:80px;color:var(--text-3);text-align:center!important}.tpag{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-top:1px solid var(--border);color:var(--text-3);font-size:12px}.pbtns{display:flex;gap:4px}.pbtn{width:28px;height:28px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-2);font-size:12px;display:flex;align-items:center;justify-content:center}.pbtn:hover{background:var(--gray-100);color:var(--navy)}.pbtn.cur{border-color:var(--navy);background:var(--navy);color:#fff}.bottom-nav{display:none;position:fixed;left:0;right:0;bottom:0;z-index:30;padding:6px 0 max(6px,env(safe-area-inset-bottom));background:#fff;border-top:1px solid var(--border);box-shadow:0 -4px 12px #00000014}.bottom-nav-inner{display:flex;justify-content:space-around;width:100%}.bnav-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:60px;padding:6px 16px;border-radius:10px;color:var(--text-3);background:none}.bnav-item.router-link-active{color:var(--navy)}.bnav-item i{font-size:22px}.bnav-item span{font-size:10px;font-weight:600;letter-spacing:.2px}.bnav-dot{position:absolute;top:0;right:22px;width:8px;height:8px;border-radius:50%;background:var(--amber);border:1.5px solid #fff}.toast-stack{position:fixed;right:18px;bottom:18px;z-index:100;display:grid;gap:10px;max-width:min(420px,calc(100vw - 36px))}.toast{display:flex;align-items:center;gap:9px;width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:var(--rs);background:#fff;color:var(--text);box-shadow:var(--sh-lg);text-align:left}.toast.success,.toast.info{border-left:3px solid var(--teal)}.toast.error{border-left:3px solid var(--red)}.toast i{font-size:18px}.toast.success i,.toast.info i{color:var(--teal)}.toast.error i{color:var(--red)}@media (max-width: 760px){.app-body{display:block}.sidebar{display:none}.main{padding:18px 14px 88px}.bottom-nav{display:flex;justify-content:space-around}.htag,.htime,.huser{display:none}.login-card{padding:34px 24px}.doc-cards{grid-template-columns:1fr}.dni-row,.queue-head{flex-direction:column}.btn-buscar{height:50px}.fgrid{grid-template-columns:1fr}.fgrid .full{grid-column:1}.tram-grid{grid-template-columns:1fr 1fr}.tgrid{grid-template-columns:repeat(2,1fr)}.hist-ctrl{overflow-x:auto}.hist-inp{min-width:220px}.status-row{width:100%;justify-content:space-between}.sstat{flex:1;justify-content:center;flex-direction:column;text-align:center;gap:2px}.twrap{overflow-x:auto}.dtable{min-width:700px}.toast-stack{left:12px;right:12px;bottom:72px}}
