:root{--bg:#0f1117;--surface:#1a1d27;--surface2:#22263a;--border:#2e3250;--accent:#6c63ff;--accent2:#4ecca3;--danger:#ff4d6d;--warn:#ffbe0b;--success:#06d6a0;--text:#e8eaf6;--text2:#8b8fa8;--radius:12px;--radius-sm:8px}
[data-theme="carbon"]{--bg:#1E1E2E;--surface:#2A2A3E;--surface2:#32324A;--border:#3E3E5A;--accent:#6C8EBF;--accent2:#4FC3A1;--text:#E2E4F0;--text2:#9499B8}
[data-theme="navy"]{--bg:#0D1B2A;--surface:#1A2744;--surface2:#1E3058;--border:#2A4070;--accent:#4FC3F7;--accent2:#4ecca3;--text:#E1EEF9;--text2:#7A9EC5}
[data-theme="day"]{--bg:#F5F5F5;--surface:#FFFFFF;--surface2:#EAEAEE;--border:#D0D0DC;--accent:#5C6BC0;--accent2:#26A69A;--danger:#D32F2F;--warn:#F57C00;--success:#2E7D32;--text:#1A1A2E;--text2:#555577}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
/* NAV */
#nav{display:flex;background:var(--surface);border-bottom:1px solid var(--border);padding:0 16px;height:56px;align-items:center;gap:8px}
#nav-buttons::-webkit-scrollbar{height:4px}
#nav-buttons::-webkit-scrollbar-track{background:transparent}
#nav-buttons::-webkit-scrollbar-thumb{background:var(--accent);border-radius:4px}
#nav .logo{font-weight:800;font-size:1.2rem;color:var(--accent);margin-right:16px;flex-shrink:0;white-space:nowrap}
.nav-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text2);cursor:pointer;font-size:.88rem;font-weight:500;transition:all .15s;white-space:nowrap}
.nav-btn:hover{background:var(--surface2);color:var(--text)}.nav-btn.active{background:var(--accent);color:#fff}
.nav-btn .badge{background:var(--danger);color:#fff;border-radius:99px;font-size:.7rem;padding:1px 6px;min-width:18px;text-align:center}
#nav .spacer{flex:1;min-width:8px}#clock{color:var(--text2);font-size:.85rem;flex-shrink:0;white-space:nowrap}
#user-info{display:flex;align-items:center;gap:8px;margin-left:12px;padding:6px 12px;background:var(--surface2);border-radius:var(--radius-sm);border:1px solid var(--border)}
#user-info .user-name{font-size:.82rem;font-weight:600}
#user-info .user-role{font-size:.72rem;color:var(--text2)}
#btn-logout{background:none;border:none;color:var(--text2);cursor:pointer;padding:4px 8px;border-radius:4px;font-size:.82rem}
#btn-logout:hover{color:var(--danger)}
/* PAGES */
.page{display:none;padding:20px;height:calc(100vh - 56px);overflow-y:auto}
.page.active{display:flex;flex-direction:column;gap:16px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.card-title{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text2);margin-bottom:12px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:.88rem;font-weight:600;transition:all .15s}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#5a52e0}
.btn-success{background:var(--success);color:#000}.btn-danger{background:var(--danger);color:#fff}
.btn-warn{background:var(--warn);color:#000}.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-sm{padding:5px 12px;font-size:.8rem}
.btn:disabled{opacity:.4;cursor:not-allowed}
input,select,textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:9px 12px;font-size:.88rem;width:100%;transition:border .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
label{font-size:.82rem;color:var(--text2);margin-bottom:4px;display:block}
/* MESAS */
#floor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}
.mesa-card{background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius);padding:14px;cursor:pointer;transition:all .15s;text-align:center;user-select:none}
.mesa-card:hover{border-color:var(--accent);transform:translateY(-2px)}
.mesa-card.occupied{border-color:var(--warn);background:rgba(255,190,11,.08)}
.mesa-card.ready{border-color:var(--success);background:rgba(6,214,160,.08)}
.mesa-card .mesa-status{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.mesa-card.libre .mesa-status{color:var(--text2)}.mesa-card.occupied .mesa-status{color:var(--warn)}.mesa-card.ready .mesa-status{color:var(--success)}
.mesa-card .mesa-total{font-size:.8rem;color:var(--text2);margin-top:4px}
/* ORDEN */
#order-layout{display:grid;grid-template-columns:1fr 340px;gap:16px;flex:1;overflow:hidden}
#menu-panel{overflow-y:auto}#order-panel{display:flex;flex-direction:column;gap:12px;overflow:hidden}
.cat-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.cat-tab{padding:6px 14px;border-radius:99px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;font-size:.82rem;font-weight:500;transition:all .15s}
.cat-tab:hover,.cat-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.menu-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:all .15s}
.menu-item:hover{border-color:var(--accent);transform:translateY(-1px)}
.menu-item.unavailable{background:rgba(220,53,69,.08);border-color:rgba(220,53,69,.25);cursor:not-allowed;opacity:.75}.menu-item.unavailable:hover{transform:none;border-color:rgba(220,53,69,.35)}.menu-item.unavailable .item-name{color:var(--danger)}.menu-item.unavailable .item-price{color:rgba(220,53,69,.7)}
.menu-item .item-name{font-size:.88rem;font-weight:600;margin-bottom:4px}.menu-item .item-price{font-size:.95rem;font-weight:700;color:var(--accent2)}
.order-items{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.order-row{background:var(--surface2);border-radius:var(--radius-sm);padding:10px 12px;display:flex;align-items:center;gap:10px}
.order-row .item-info{flex:1}.order-row .item-info .name{font-size:.85rem;font-weight:600}.order-row .item-info .note{font-size:.75rem;color:var(--text2)}
.qty-ctrl{display:flex;align-items:center;gap:6px}
.qty-ctrl button{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center}
.qty-ctrl button:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.qty-ctrl .qty{min-width:20px;text-align:center;font-weight:700;font-size:.9rem}
.order-row .row-price{font-size:.88rem;font-weight:700;color:var(--accent2);min-width:64px;text-align:right}
.order-row .del-btn{background:none;border:none;color:var(--text2);cursor:pointer;font-size:.85rem;padding:2px}
.order-row .del-btn:hover{color:var(--danger)}
.order-footer{border-top:1px solid var(--border);padding-top:12px}
.order-total-row{display:flex;justify-content:space-between;margin-bottom:4px;font-size:.85rem}
.order-total-row.grand{font-weight:800;font-size:1.05rem;color:var(--accent2);margin-top:8px;border-top:1px solid var(--border);padding-top:8px}
.order-actions{display:flex;gap:8px;margin-top:12px}.order-actions .btn{flex:1;justify-content:center}
.empty-order{text-align:center;color:var(--text2);padding:40px 20px;font-size:.9rem}
/* MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:100;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;width:340px;display:flex;flex-direction:column;gap:14px}
.modal h3{font-size:1rem;font-weight:700}.modal-actions{display:flex;gap:8px;justify-content:flex-end}
/* KDS */
#kds-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.kds-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);overflow:hidden}
.kds-card.new{border-color:var(--accent)}.kds-card.in_progress{border-color:var(--warn)}.kds-card.ready{border-color:var(--success)}.kds-card.cancelled{border-color:var(--danger);opacity:.92}
.kds-header{padding:10px 14px;display:flex;justify-content:space-between;align-items:center}
.kds-card.new .kds-header{background:rgba(108,99,255,.15)}.kds-card.in_progress .kds-header{background:rgba(255,190,11,.12)}.kds-card.ready .kds-header{background:rgba(6,214,160,.12)}.kds-card.cancelled .kds-header{background:rgba(255,69,58,.18)}
.kds-mesa{font-weight:800;font-size:1rem}.kds-timer{font-size:.8rem;font-weight:700}
.kds-timer.warn{color:var(--warn)}.kds-timer.danger{color:var(--danger)}
.kds-items{padding:10px 14px;display:flex;flex-direction:column;gap:6px}
.kds-item{display:flex;align-items:center;gap:8px;font-size:.85rem}
.kds-item .check-btn{width:20px;height:20px;border-radius:4px;border:2px solid var(--border);background:none;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.kds-item.done .check-btn{background:var(--success);border-color:var(--success)}.kds-item.done .item-text{text-decoration:line-through;color:var(--text2)}
.kds-item .qty-badge{background:var(--accent);color:#fff;border-radius:4px;padding:1px 6px;font-size:.72rem;font-weight:700}
.kds-item .item-note{font-size:.72rem;color:var(--text2)}.kds-footer{padding:10px 14px;border-top:1px solid var(--border)}
.kds-empty{text-align:center;color:var(--text2);padding:60px 20px;grid-column:1/-1}
/* COBRO */
#cobro-layout{display:grid;grid-template-columns:1fr 380px;gap:16px;flex:1;overflow:hidden}
#cobro-list{overflow-y:auto}#cobro-panel{overflow-y:auto;display:flex;flex-direction:column;gap:12px}
.cobro-table-btn{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin-bottom:8px;transition:all .15s}
.cobro-table-btn:hover{border-color:var(--accent)}.cobro-table-btn.selected{border-color:var(--accent);background:rgba(108,99,255,.1)}.cobro-table-btn.disabled-cobro{opacity:.65;cursor:not-allowed;border-color:var(--warn)}.cobro-table-btn.disabled-cobro:hover{border-color:var(--warn)}
.tip-btns{display:flex;gap:6px;flex-wrap:wrap}
.tip-btn{flex:1;min-width:60px;padding:8px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface2);color:var(--text);cursor:pointer;font-size:.82rem;font-weight:600;text-align:center;transition:all .15s}
.tip-btn:hover,.tip-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.pay-methods{display:flex;gap:8px}
.pay-method{flex:1;padding:14px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface2);cursor:pointer;text-align:center;transition:all .15s}
.pay-method:hover{border-color:var(--accent)}.pay-method.selected{border-color:var(--accent);background:rgba(108,99,255,.12)}
.pay-method i{font-size:1.4rem;display:block;margin-bottom:4px;color:var(--accent2)}.pay-method span{font-size:.8rem;font-weight:600}
.summary-row{display:flex;justify-content:space-between;margin-bottom:6px;font-size:.88rem}
.summary-row.grand{font-weight:800;font-size:1.1rem;color:var(--accent2);border-top:1px solid var(--border);padding-top:8px;margin-top:8px}
.change-display{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;text-align:center}
.change-display .change-label{font-size:.78rem;color:var(--text2);margin-bottom:4px}.change-display .change-val{font-size:1.5rem;font-weight:800;color:var(--success)}
/* MENU ADMIN */
#menu-admin-layout{display:grid;grid-template-columns:220px 1fr;gap:16px;flex:1;overflow:hidden}
#cat-panel{overflow-y:auto}
.cat-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s}
.cat-item:hover{background:var(--surface2)}.cat-item.selected{background:rgba(108,99,255,.15);color:var(--accent);font-weight:600}
.cat-item .cat-count{font-size:.75rem;color:var(--text2);background:var(--surface2);padding:1px 7px;border-radius:99px}
#items-panel{overflow-y:auto}
.admin-item-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);background:var(--surface2);margin-bottom:8px}
.admin-item-row .item-name{flex:1;font-weight:600;font-size:.9rem}.admin-item-row .item-price{font-weight:700;color:var(--accent2);min-width:70px}
.toggle{position:relative;width:40px;height:22px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:99px;cursor:pointer;transition:.2s}
.toggle-slider:before{content:'';position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.toggle input:checked+.toggle-slider{background:var(--success)}.toggle input:checked+.toggle-slider:before{transform:translateX(18px)}
/* REPORTES */
.rep-main-tabs{display:flex;gap:4px;background:var(--surface2);border-radius:var(--radius);padding:4px}
.rep-main-tab{padding:7px 18px;border-radius:calc(var(--radius) - 2px);cursor:pointer;font-size:.85rem;font-weight:600;color:var(--text2);transition:all .15s;display:flex;align-items:center;gap:6px}
.rep-main-tab:hover{color:var(--text)}
.rep-main-tab.active{background:var(--surface);color:var(--accent);box-shadow:0 1px 4px rgba(0,0,0,.12)}
.rep-sub-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 0 12px}
.rep-period-tabs{display:flex;gap:6px}.rep-tab{padding:7px 16px;border-radius:99px;border:1px solid var(--border);background:var(--surface2);color:var(--text2);cursor:pointer;font-size:.82rem;font-weight:600;transition:all .15s}
.rep-tab:hover,.rep-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.rep-custom-range{display:none;gap:8px;align-items:center}.rep-custom-range.open{display:flex}
/* Rentabilidad */
.rent-semaforo{display:inline-block;padding:2px 10px;border-radius:99px;font-size:.75rem;font-weight:700}
.rent-verde{background:rgba(16,185,129,.15);color:#059669}
.rent-amarillo{background:rgba(245,158,11,.15);color:#d97706}
.rent-rojo{background:rgba(239,68,68,.15);color:#dc2626}
.rent-sin-receta{background:rgba(148,163,184,.15);color:#64748b}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.kpi-label{font-size:.75rem;color:var(--text2);font-weight:600;text-transform:uppercase;letter-spacing:.07em;margin-bottom:6px}
.kpi-value{font-size:1.6rem;font-weight:800}.kpi-sub{font-size:.75rem;color:var(--text2);margin-top:2px}
.kpi-card.accent .kpi-value{color:var(--accent2)}.kpi-card.warn .kpi-value{color:var(--warn)}.kpi-card.success .kpi-value{color:var(--success)}.kpi-card.purple .kpi-value{color:var(--accent)}
.rep-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.rep-grid-3{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.rep-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}.rep-row:last-child{border-bottom:none}
.rep-rank{width:22px;height:22px;border-radius:50%;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;flex-shrink:0}
.rep-rank.gold{background:#f59e0b;color:#000}.rep-rank.silver{background:#94a3b8;color:#000}.rep-rank.bronze{background:#b45309;color:#fff}
.rep-bar-wrap{flex:1;height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}.rep-bar{height:100%;border-radius:3px;background:var(--accent);transition:width .4s}
.pay-method-row{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:.85rem}
.pay-method-row .pay-bar-wrap{flex:1;height:10px;background:var(--surface2);border-radius:5px;overflow:hidden}.pay-method-row .pay-bar{height:100%;border-radius:5px}
.history-table{width:100%;border-collapse:collapse;font-size:.83rem}
.history-table th{text-align:left;padding:6px 10px;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text2);border-bottom:1px solid var(--border)}
.history-table td{padding:8px 10px;border-bottom:1px solid var(--border)}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover td{background:var(--surface2)}
.hour-chart{display:flex;align-items:flex-end;gap:4px;height:100px;padding-top:8px}
.hour-bar-col{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;min-width:22px}
.hour-bar{width:100%;background:var(--accent);border-radius:3px 3px 0 0;transition:height .3s;min-height:2px}.hour-bar:hover{background:var(--accent2)}
.hour-label{font-size:.6rem;color:var(--text2);white-space:nowrap}
/* USUARIOS */
.users-table{width:100%;border-collapse:collapse}
.users-table th{text-align:left;padding:8px 12px;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text2);border-bottom:1px solid var(--border)}
.users-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:.88rem}
.users-table tr:last-child td{border-bottom:none}.users-table tr:hover td{background:var(--surface2)}
.role-chip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:700}
.role-Administrador{background:rgba(108,99,255,.2);color:var(--accent)}
.role-Cajero{background:rgba(6,214,160,.2);color:var(--success)}
.role-Mesero{background:rgba(255,190,11,.2);color:var(--warn)}
.role-Cocina{background:rgba(255,77,109,.2);color:var(--danger)}
.status-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:700}
.status-active{background:rgba(6,214,160,.15);color:var(--success)}
.status-inactive{background:rgba(139,143,168,.15);color:var(--text2)}
/* LOGIN */
#login-screen{position:fixed;inset:0;background:var(--bg);z-index:500;display:flex;align-items:center;justify-content:center}
#login-screen.hidden{display:none}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px 36px;width:360px;display:flex;flex-direction:column;gap:20px}
.login-logo{text-align:center;font-size:1.8rem;font-weight:800;color:var(--accent)}
.login-logo i{margin-right:8px}
.login-subtitle{text-align:center;font-size:.85rem;color:var(--text2);margin-top:-12px}
.login-field{display:flex;flex-direction:column;gap:6px}
.login-error{background:rgba(255,77,109,.12);border:1px solid var(--danger);border-radius:var(--radius-sm);padding:10px 14px;font-size:.85rem;color:var(--danger);display:none}
.login-error.show{display:block}
#btn-login{width:100%;justify-content:center;padding:12px;font-size:.95rem}
/* PRINT */
@media print{body>*:not(#ticket-print){display:none!important}#ticket-print{display:block!important;font-family:monospace;font-size:12px;max-width:300px;margin:0 auto}}
#ticket-print{display:none}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.chip-new{background:rgba(108,99,255,.2);color:var(--accent)}.chip-in_progress{background:rgba(255,190,11,.2);color:var(--warn)}.chip-ready{background:rgba(6,214,160,.2);color:var(--success)}
#toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 20px;font-size:.88rem;font-weight:500;opacity:0;transition:opacity .2s;z-index:200;pointer-events:none}
#toast.show{opacity:1}
#toast.show.interactive{pointer-events:auto;cursor:default}
.flex-row{display:flex;gap:10px;align-items:center}.mt-8{margin-top:8px}
.page-header{display:flex;justify-content:space-between;align-items:center}.section-title{font-size:1.1rem;font-weight:700}
#loading-overlay{position:fixed;inset:0;background:rgba(15,17,23,.9);z-index:300;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px}
#loading-overlay.hidden{display:none}
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
/* ── Para Llevar ─────────────────────────────────────── */
#llevar-layout{display:grid;grid-template-columns:300px 1fr;gap:16px;height:calc(100vh - 140px);}
#llevar-list-panel{overflow-y:auto;padding:0;}
#llevar-detail-panel{overflow-y:auto;}
.llevar-card{padding:12px 14px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s;}
.llevar-card:hover{background:var(--bg2);}
.llevar-card.selected{background:var(--accent-bg,#e3f2fd);border-left:3px solid var(--accent2,#1565c0);}
.llevar-num{font-size:1.1rem;font-weight:800;color:var(--accent2,#1565c0);}
.llevar-status{font-size:.72rem;padding:2px 8px;border-radius:12px;font-weight:700;}
.llevar-detail-header{background:var(--bg2);border-radius:10px;padding:14px;margin-bottom:14px;}
#llevar-add-row{display:flex;gap:8px;align-items:center;margin-bottom:10px;flex-wrap:wrap;}
#llevar-add-row select{flex:1;min-width:140px;}
#llevar-add-row input[type=number]{width:60px;}
#llevar-add-row input[type=text]{flex:1;min-width:80px;}
.llevar-item-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);}
.llevar-status-bar{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;}
.llevar-status-bar .btn{flex:1;min-width:80px;font-size:.8rem;}

/* ── Acordeón Sistema ──────────────────────────────────────────────────────── */
.acc-item{border:1px solid var(--border);border-radius:10px;margin-bottom:8px;overflow:hidden;transition:box-shadow .15s;}
.acc-item-open{box-shadow:0 2px 12px rgba(0,0,0,.08);}
.acc-header{width:100%;display:flex;align-items:center;justify-content:space-between;
  padding:13px 16px;background:var(--bg2);border:none;cursor:pointer;text-align:left;
  gap:10px;transition:background .15s;}
.acc-header:hover{background:var(--base-200);}
.acc-item-open .acc-header{background:var(--bg2);border-bottom:1px solid var(--border);color:var(--accent);}
.acc-header-icon{font-size:.95rem;color:var(--accent);width:18px;text-align:center;}
.acc-header-label{display:block;font-size:.9rem;font-weight:700;line-height:1.2;}
.acc-header-desc{display:block;font-size:.72rem;opacity:.55;font-weight:400;margin-top:1px;}
.acc-chevron{font-size:.8rem;opacity:.5;transition:transform .2s ease;flex-shrink:0;}
.acc-item-open .acc-chevron{opacity:1;color:var(--accent);}
.acc-body{display:none;padding:0;}
.acc-body.open{display:block;}

/* ── Mesas — Vista mesero (zonas y plantas) ───────────────────────────────── */
.zona-tabs{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap;}
.zona-tab{padding:6px 16px;border-radius:20px;border:1.5px solid var(--border);background:transparent;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--text2);transition:all .15s;}
.zona-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);}
.floor-subgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;padding:4px 0 10px;}
.planta-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text2);margin:8px 0 4px;padding-left:2px;}

/* Zonas lado a lado — desktop first */
.zonas-layout{display:grid;grid-template-columns:1fr 1fr;gap:18px;align-items:stretch;}
.zona-section{border-radius:10px;overflow:hidden;border:2px solid var(--border);}
.zona-header{padding:10px 18px;font-weight:700;font-size:1rem;display:flex;align-items:center;gap:8px;letter-spacing:.02em;}
.zona-section.zona-A{border-color:#93c5fd;}
.zona-section.zona-A .zona-header{background:#dbeafe;color:#1e40af;}
.zona-section.zona-B{border-color:#fcd34d;}
.zona-section.zona-B .zona-header{background:#fef3c7;color:#92400e;}
.zona-section.zona-sin{border-color:var(--border);}
.zona-section.zona-sin .zona-header{background:var(--surface2);color:var(--text2);}
.zona-body{padding:12px 12px 6px;}
/* Tarjeta de mesa */
.mesa-icon{font-size:1.4rem;line-height:1;}
.mesa-name{font-weight:700;font-size:.8rem;margin-top:5px;word-break:break-word;line-height:1.25;}

/* ── Admin Mesas — barra de agregar ─────────────────────────────────────── */
.maa-add-bar{display:flex;gap:8px;align-items:center;padding-bottom:14px;border-bottom:1px solid var(--border);margin-bottom:14px;flex-wrap:wrap;}
.maa-add-bar input{flex:1;min-width:160px;padding:6px 10px;border-radius:6px;border:1px solid var(--border);background:var(--bg2);color:var(--text1);}
.maa-add-bar select{padding:6px 8px;border-radius:6px;border:1px solid var(--border);background:var(--bg2);color:var(--text1);font-size:.85rem;}

/* ── Admin Mesas — acordeones ───────────────────────────────────────────── */
.maa-list{display:flex;flex-direction:column;gap:8px;}
.maa-accordion{border:1.5px solid var(--maa-border,var(--border));border-radius:8px;overflow:hidden;}
.maa-header{width:100%;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface2);border:none;cursor:pointer;font-size:.88rem;font-weight:600;text-align:left;transition:background .15s;}
.maa-header:hover{background:var(--bg2);}
.maa-header.open{background:var(--bg2);}
.maa-title{display:flex;align-items:center;gap:8px;flex:1;}
.maa-badge{font-size:.75rem;color:var(--text2);font-weight:500;white-space:nowrap;}
.maa-chevron{font-size:.75rem;color:var(--text2);transition:transform .2s;margin-left:4px;}
.maa-header.open .maa-chevron{transform:rotate(180deg);}
.maa-body{display:none;border-top:1px solid var(--border);}
.maa-body.open{display:block;}

/* ── Croquis de Mesas (editor admin) ─────────────────────────────────────── */
.croquis-toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 0 14px;flex-wrap:wrap;gap:8px;}
.croquis-pool-wrap{margin-bottom:16px;}
.croquis-pool-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text2);margin-bottom:6px;}
.croquis-pool{display:flex;flex-wrap:wrap;gap:6px;min-height:44px;background:var(--bg2);border-radius:8px;padding:8px;border:1.5px dashed var(--border);}
.croquis-panels-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:680px){.croquis-panels-grid{grid-template-columns:1fr;}}
.croquis-panel-wrap{display:flex;flex-direction:column;}
.croquis-panel-label{font-size:.8rem;font-weight:700;margin-bottom:6px;}
.croquis-panel{position:relative;width:100%;height:260px;border-radius:10px;border:2px dashed rgba(0,0,0,.12);overflow:hidden;}
.croquis-panel-hint{position:absolute;bottom:8px;right:10px;font-size:.7rem;color:rgba(0,0,0,.3);pointer-events:none;user-select:none;}
.croquis-table{display:inline-flex;align-items:center;justify-content:center;border-radius:8px;padding:4px 10px;font-size:.78rem;font-weight:700;cursor:grab;user-select:none;transition:box-shadow .1s;white-space:nowrap;}
.croquis-table:hover{box-shadow:0 4px 12px rgba(0,0,0,.2);}
.croquis-table--placed{position:absolute;}

/* ── Impresión ────────────────────────────────────────────────────────────── */
@media print {
  nav,.page-header,.acc-header,.croquis-toolbar,.croquis-pool-wrap{display:none!important;}
  .croquis-panels-grid{grid-template-columns:1fr 1fr!important;gap:8px!important;}
  .croquis-panel{height:220px!important;border:1.5px solid #ccc!important;}
  *{box-shadow:none!important;}
}
