:root{--bg: #0e0b14;--panel: #16111f;--card: #1c1629;--line: #2a2138;--text: #f0ecf6;--muted: #9b90ad;--pink: #ff3ba0;--purple: #a64dff;--cyan: #36d6ff;--grad: linear-gradient(135deg, #36d6ff, #a64dff, #ff3ba0);--danger: #ff5d6c;--mono: ui-monospace, "SF Mono", "Cascadia Code", "Roboto Mono", Menlo, Consolas, monospace;--sans: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer}img{display:block}.loading{display:grid;place-items:center;height:100%;color:var(--muted)}.login-wrap{min-height:100%;display:grid;place-items:center;padding:24px;background:radial-gradient(900px 400px at 30% -10%,rgba(54,214,255,.1),transparent),radial-gradient(900px 500px at 80% 110%,rgba(255,59,160,.12),transparent),var(--bg)}.login-card{width:100%;max-width:370px;text-align:center;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:30px 28px;box-shadow:0 20px 60px #00000080}.login-logo{width:200px;max-width:80%;margin:4px auto 6px;filter:drop-shadow(0 0 18px rgba(166,77,255,.4))}.login-sub{color:var(--muted);margin:0 0 22px;font-size:13px;letter-spacing:.04em}.field{display:block;margin-bottom:14px;text-align:left}.field span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}.field input,.ctrl input,.ctrl select{width:100%;padding:10px 12px;background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:10px;font-size:14px;outline:none}.field input:focus,.ctrl input:focus,.ctrl select:focus{border-color:var(--purple);box-shadow:0 0 0 3px #a64dff38}.btn{width:100%;margin-top:8px;padding:12px;color:#fff;border:none;border-radius:10px;font-weight:650;font-size:14px;background:var(--grad);box-shadow:0 8px 22px #a64dff59}.btn:disabled{opacity:.6;cursor:default}.error{color:var(--danger);font-size:13px;margin:4px 0 10px}.shell{display:flex;min-height:100%}.sidebar{width:230px;flex:none;background:var(--panel);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:22px;position:sticky;top:0;height:100vh}.logo-box{padding:6px 8px 2px}.logo{width:100%;filter:drop-shadow(0 0 12px rgba(166,77,255,.35))}.nav{display:flex;flex-direction:column;gap:10px;flex:1}.nav-btn{display:flex;align-items:center;gap:11px;width:100%;padding:11px 13px;border-radius:12px;color:var(--muted);font-size:14px;font-weight:550;text-align:left;background:linear-gradient(180deg,#1b1428,#140f1f);border:1px solid var(--line);box-shadow:inset 0 1px #ffffff0a,0 4px 10px #0006;transition:transform .12s,box-shadow .12s,color .12s,border-color .12s}.nav-btn svg{width:19px;height:19px;flex:none}.nav-btn:hover{color:var(--text);border-color:#3a2d50;transform:translateY(-1px)}.nav-btn:active{transform:translateY(0)}.nav-btn.active{color:#fff;border-color:transparent;background:linear-gradient(180deg,#241636,#190f26) padding-box,var(--grad) border-box;box-shadow:0 0 0 1px #a64dff66,0 6px 18px #a64dff4d,0 0 22px #ff3ba02e}.nav-btn.active svg{color:var(--pink)}.side-foot{display:flex;align-items:center;justify-content:space-between;gap:8px}.user{display:flex;flex-direction:column;line-height:1.3;min-width:0}.user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-rol{font-size:11px;color:var(--purple);text-transform:capitalize}.link{background:none;border:1px solid var(--line);color:var(--text);padding:7px 12px;border-radius:8px;font-size:13px;white-space:nowrap}.link:hover{border-color:var(--purple);color:var(--purple)}.link:disabled{opacity:.4;cursor:default}.content{flex:1;min-width:0}.section{padding:22px 24px}.section-head h1{margin:0 0 18px;font-size:22px;font-weight:650;letter-spacing:.01em}.coming{display:flex;flex-direction:column;gap:12px;align-items:flex-start;padding:30px 0;color:var(--muted)}.badge{font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:999px;color:#fff;background:var(--grad)}.controls{display:flex;align-items:flex-end;gap:16px;flex-wrap:wrap;margin-bottom:20px}.ctrl span{display:block;font-size:11px;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em}.ctrl select,.ctrl input{min-width:160px}.count{font-family:var(--mono);color:var(--muted);font-size:13px;margin-left:auto}.empty{color:var(--muted);text-align:center;padding:60px 20px;font-size:14px}.grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.cell{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:0;overflow:hidden;text-align:left;transition:border-color .12s,transform .12s}.cell:hover{border-color:var(--purple);transform:translateY(-2px)}.cell:focus-visible{outline:2px solid var(--purple);outline-offset:2px}.cell img{width:100%;aspect-ratio:16 / 10;object-fit:cover;background:#0a0810}.cell .ts{display:block;font-family:var(--mono);font-size:12px;color:var(--muted);padding:8px 10px}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#06040aed;display:flex;flex-direction:column;padding:16px}.lb-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.lb-ts{font-family:var(--mono);font-size:14px;color:var(--cyan)}.lb-close{background:none;border:1px solid var(--line);color:var(--text);padding:7px 13px;border-radius:8px;font-size:13px}.lb-img{flex:1;min-height:0;max-width:100%;object-fit:contain;margin:0 auto;border-radius:8px}.lb-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:12px}.lb-pos{font-family:var(--mono);font-size:13px;color:var(--muted)}@media (max-width: 720px){.sidebar{width:64px;padding:14px 8px}.logo-box,.nav-btn span,.user,.side-foot .link span{display:none}.nav-btn{justify-content:center;padding:12px}.side-foot{justify-content:center}}@media (max-width: 520px){.grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.count{width:100%;margin:0}}.room-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}.room-btn{padding:8px 14px;border-radius:9px;background:var(--card);border:1px solid var(--line);color:var(--muted);font-size:13px;font-weight:550;transition:color .12s,border-color .12s,transform .1s}.room-btn:hover{color:var(--text);border-color:#3a2d50}.room-btn.on{color:#fff;border-color:transparent;background:linear-gradient(180deg,#241636,#190f26) padding-box,var(--grad) border-box;box-shadow:0 0 14px #a64dff47}.turnos{display:flex;flex-wrap:wrap;gap:6px}.turno-btn{padding:9px 12px;border-radius:8px;background:var(--bg);border:1px solid var(--line);color:var(--muted);font-size:13px;transition:color .12s,border-color .12s,background .12s}.turno-btn:hover{color:var(--text);border-color:#3a2d50}.turno-btn.on{color:#fff;border-color:var(--purple);background:#a64dff24;box-shadow:inset 0 0 0 1px #a64dff4d}.tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid var(--line);padding-bottom:12px;flex-wrap:wrap}.tab{padding:8px 15px;border-radius:8px;background:transparent;border:1px solid transparent;color:var(--muted);font-size:14px;font-weight:550}.tab:hover{color:var(--text)}.tab.on{color:#fff;border-color:var(--purple);background:#a64dff1f}.tab-body{max-width:880px}.tab-body.narrow{max-width:460px}.form-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.form-row input,.form-row select{padding:9px 12px;background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:9px;font-size:14px;outline:none}.form-row input:focus,.form-row select:focus{border-color:var(--purple);box-shadow:0 0 0 3px #a64dff33}.form-row input[type=number]{width:110px}.sufijo{color:var(--muted);font-size:14px}.btn-sm{padding:9px 16px;border:none;border-radius:9px;color:#fff;font-weight:600;font-size:14px;background:var(--grad);box-shadow:0 6px 16px #a64dff4d}.ayuda{color:var(--muted);font-size:13px;margin:0 0 14px;line-height:1.5}.ayuda.peligro{color:var(--danger)}.ok-msg{color:var(--cyan);font-size:13px;margin-top:6px}.tabla{width:100%;border-collapse:collapse;font-size:14px}.tabla th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em;padding:8px 10px;border-bottom:1px solid var(--line)}.tabla td{padding:10px;border-bottom:1px solid var(--line)}.tabla tr.inactivo{opacity:.45}.tabla .rol{text-transform:capitalize;color:var(--purple)}.link.sm{padding:5px 10px;font-size:12px}.card-form{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px;max-width:520px;margin-bottom:26px}.card-form h3{margin:0 0 14px;font-size:15px;font-weight:600}.sub{font-size:15px;font-weight:600;margin:0 0 14px}.ta{width:100%;min-height:64px;resize:vertical;padding:10px 12px;margin-bottom:12px;background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:9px;font-size:14px;font-family:inherit;outline:none}.ta:focus{border-color:var(--purple);box-shadow:0 0 0 3px #a64dff33}.citas-list{display:flex;flex-direction:column;gap:12px;max-width:720px}.cita{display:flex;align-items:center;justify-content:space-between;gap:14px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:13px 15px}.cita.big{display:block}.cita-head{display:flex;align-items:center;justify-content:space-between;gap:14px}.cita-main{display:flex;flex-direction:column;gap:3px}.cita-modelo{font-weight:600;font-size:14px}.cita-fecha{font-family:var(--mono);font-size:13px;color:var(--muted)}.cita-motivo{color:var(--text);font-size:14px;margin:10px 0}.cita-acciones{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.link.danger{color:var(--danger)}.link.danger:hover{border-color:var(--danger)}.badge2{font-size:12px;font-weight:600;padding:4px 10px;border-radius:999px;white-space:nowrap}.b-pend{background:#e8a23d29;color:#e8a23d}.b-ok{background:#36d6ff29;color:var(--cyan)}.b-done{background:#78dc7829;color:#7adc7a}.b-cancel{background:#ff5d6c29;color:var(--danger)}.card-form.wide{max-width:100%}.cita-sub{font-size:12px;color:var(--muted)}
