:root{--primary: #be185d;--primary-d: #9d174d;--primary-l: #fce7f3;--accent: #d97706;--accent-l: #fef3c7;--verde: #15803d;--verde-l: #dcfce7;--rojo: #dc2626;--rojo-l: #fee2e2;--amarillo: #d97706;--amar-l: #fef9c3;--azul: #1d4ed8;--azul-l: #dbeafe;--gris: #6b7280;--gris-l: #f3f4f6;--sidebar: #1e0a2e;--sidebar-2: #2d1244;--sidebar-b: #3d1a5c;--sidebar-t: #c4b5d4;--sidebar-m: #7c5e96;--bg: #fdf6f9;--white: #ffffff;--border: #e9d5ea;--text: #1a0a2e;--text-s: #6b5778}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px}.app-layout{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.page-body{flex:1;overflow-y:auto;padding:20px 24px}.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.topbar-title{font-size:18px;font-weight:800;color:var(--text)}.topbar-sub{font-size:12px;color:var(--text-s);margin-top:2px}.btn{padding:8px 16px;border-radius:7px;border:none;font-size:13px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:.12s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-d)}.btn-secondary{background:var(--white);color:var(--text);border:1.5px solid var(--border)}.btn-secondary:hover{background:var(--gris-l)}.btn-danger{background:var(--rojo);color:#fff}.btn-success{background:var(--verde);color:#fff}.btn-sm{padding:4px 10px;font-size:12px;border-radius:5px}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:700}.badge-verde{background:var(--verde-l);color:var(--verde)}.badge-rojo{background:var(--rojo-l);color:var(--rojo)}.badge-amarillo{background:var(--amar-l);color:#92400e}.badge-azul{background:var(--azul-l);color:var(--azul)}.badge-rosa{background:var(--primary-l);color:var(--primary)}.badge-gris{background:var(--gris-l);color:var(--gris)}.table-wrap{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden}table{width:100%;border-collapse:collapse;font-size:13px}thead{background:var(--primary-l)}th{padding:10px 14px;text-align:left;font-size:11px;font-weight:800;color:var(--primary);text-transform:uppercase;letter-spacing:.05em}td{padding:10px 14px;border-top:1px solid var(--border);vertical-align:middle}tr:hover td{background:var(--bg)}.form-group{margin-bottom:15px}.form-label{display:block;font-size:11px;font-weight:700;color:var(--text-s);margin-bottom:5px;text-transform:uppercase;letter-spacing:.05em}.form-input{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:7px;font-size:13px;color:var(--text);background:var(--white);outline:none;transition:.15s}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-l)}.card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:20px}.section-title{font-size:14px;font-weight:800;color:var(--text);margin-bottom:14px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e0a2e8c;display:flex;align-items:center;justify-content:center;z-index:100}.modal-box{background:#fff;border-radius:14px;padding:26px;width:480px;max-width:95vw;box-shadow:0 24px 80px #00000059}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-size:16px;font-weight:800;color:var(--text)}.modal-close{background:none;border:none;font-size:20px;cursor:pointer;color:var(--gris)}.spinner-wrap{display:flex;align-items:center;justify-content:center;padding:60px}.spinner{width:36px;height:36px;border-radius:50%;border:3px solid var(--primary-l);border-top-color:var(--primary);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:14px}.alert-error{background:var(--rojo-l);color:var(--rojo);border:1px solid #fca5a5}.alert-success{background:var(--verde-l);color:var(--verde);border:1px solid #86efac}.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}.kpi-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:18px;position:relative;overflow:hidden}.kpi-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px}.kpi-rosa:after{background:var(--primary)}.kpi-verde:after{background:var(--verde)}.kpi-rojo:after{background:var(--rojo)}.kpi-amber:after{background:var(--accent)}.kpi-label{font-size:11px;color:var(--text-s);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.kpi-value{font-size:32px;font-weight:800;color:var(--text);margin:6px 0 4px}.kpi-sub{font-size:11px;color:var(--text-s)}.kpi-icon{position:absolute;right:14px;top:14px;font-size:24px;opacity:.15}.mesas-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:20px}.mesa-card{border:2px solid var(--border);border-radius:12px;padding:14px;text-align:center;cursor:pointer;transition:.15s;background:var(--white)}.mesa-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001a}.mesa-card.disponible{border-color:var(--verde)}.mesa-card.ocupada{border-color:var(--rojo);background:var(--rojo-l)}.mesa-card.reservada{border-color:var(--primary);background:var(--primary-l)}.mesa-card.selected{box-shadow:0 0 0 3px var(--primary),0 6px 20px #be185d33}.mesa-num{font-size:20px;font-weight:800}.mesa-cap{font-size:11px;color:var(--text-s);margin:3px 0 7px}.cat-pills{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.cat-pill{padding:6px 16px;border-radius:99px;border:1.5px solid var(--border);font-size:12px;font-weight:600;cursor:pointer;background:var(--white);color:var(--text-s);transition:.12s}.cat-pill.active{background:var(--primary);color:#fff;border-color:var(--primary)}.cat-pill:hover:not(.active){border-color:var(--primary);color:var(--primary)}.toggle-track{width:36px;height:20px;border-radius:20px;background:#cbd5e1;cursor:pointer;position:relative;transition:.2s;display:inline-block}.toggle-track.on{background:var(--verde)}.toggle-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:.2s}.toggle-track.on .toggle-thumb{left:19px}.pago-opts{display:flex;gap:10px;margin:14px 0}.pago-opt{flex:1;border:2px solid var(--border);border-radius:10px;padding:12px;text-align:center;cursor:pointer;transition:.12s}.pago-opt.selected{border-color:var(--primary);background:var(--primary-l)}.pago-opt-icon{font-size:22px}.pago-opt-label{font-size:12px;font-weight:700;color:var(--text-s);margin-top:4px}.pago-opt.selected .pago-opt-label{color:var(--primary)}
