.frontend-body{--bg-primary: #121212;--bg-secondary: #1e1e1e;--text-primary: #e0e0e0;--text-secondary: #ffffff;--accent-color: #8b56cc;--accent-hover: #9a67ea;--error-color: #cf6679;--success-color: #03dac6;--border-color: #8b56cc;--bg-tertiary: #252525;--bg-selected: #4d4d4d;--bg-hover: #454545;--text-on-accent: #ffffff;--border-disabled: #4a5568;--text-disabled: #4a5568;--error-hover: #d32f2f;background-color:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,system-ui,sans-serif;line-height:1.6;margin:0;padding:0;min-height:100vh}.app{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--text-primary: #333333;--text-secondary: #444444;--accent-color: #4CAF50;--accent-hover: #45a049;--error-color: #f44336;--success-color: #2E7D32}.backend-body{background-color:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,system-ui,sans-serif;line-height:1.5;margin:0;padding:0;min-height:100vh}.menu-container{padding:20px;max-width:auto;margin:0 auto}.menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.menu-header h2{color:#333;font-size:24px;margin:0}.btn-new{color:#fff;border:none;padding:10px 15px;border-radius:4px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:5px;opacity:1;transition:opacity .2s}.btn-new.disabled{opacity:.6}.btn-new.servido{background-color:#3c3}.btn-new.servido:hover{background-color:#2db82d}.btn-new.en_preparacion{background-color:#f93}.btn-new.en_preparacion:hover{background-color:#e68a2e}.btn-new.pendiente{background-color:#f33}.btn-new.pendiente:hover{background-color:#e62e2e}.btn-new.cerrado{background-color:#9ca3af}.btn-new.cerrado:hover{background-color:#8a919b}.btn-new.cancelado{background-color:#900;color:#fff;text-decoration:line-through}.btn-new.cancelado:hover{background-color:maroon}.plus-icon{font-size:18px}.menu-actions{margin-bottom:20px}.btn-toggle{background-color:#f0f0f0;border:1px solid #ddd;padding:8px 12px;border-radius:4px;cursor:pointer}.btn-toggle.active{background-color:#e0e0e0}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.menu-card{border-radius:8px;padding:15px;transition:transform .2s ease}.menu-card:hover{transform:translateY(-5px)}.menu-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;gap:8px}.menu-card-header h3{margin:0;font-size:18px;color:#333;flex:1;line-height:1.3;max-height:2.6em;padding-right:10px;word-wrap:break-word;overflow-wrap:break-word}.estado-badge{padding:3px 8px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase}.estado-badge.servido{background-color:#3c3;color:#fff}.estado-badge.en_preparacion{background-color:#f93;color:#fff}.estado-badge.pendiente{background-color:#f33;color:#fff}.estado-badge.cerrada{background-color:#666;color:#fff}.estado-badge.pagada{background-color:gold;color:#333;font-weight:700}.estado-badge.cerrado{background-color:#9ca3af;color:#fff}.estado-badge.cancelado{background-color:#900;color:#fff;text-decoration:line-through}.estado-badge.disponible{background-color:#4caf50;color:#fff}.estado-badge.no-disponible{background-color:#f44336;color:#fff}.menu-card-body{display:flex;flex-direction:column;gap:8px}.menu-info{display:flex;justify-content:space-between;gap:10px}.menu-info span:last-child{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1}.config-value{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:700;color:#555}.boolean-field-container{margin:10px 0}.boolean-field{display:flex;align-items:center;gap:8px;padding:6px 10px;background-color:#f8f9fa;border-radius:6px;border:1px solid #e9ecef;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;width:fit-content}.boolean-field:hover{background-color:#e9ecef;border-color:#dee2e6}.boolean-checkbox{width:18px;height:18px;margin:0;cursor:pointer;accent-color:#007bff;vertical-align:middle}.boolean-label{font-weight:600;color:#495057;font-size:14px;letter-spacing:.5px;line-height:1;vertical-align:middle}.boolean-field:has(.boolean-checkbox:checked){background-color:#e7f3ff;border-color:#007bff}.boolean-field:has(.boolean-checkbox:checked) .boolean-label{color:#007bff;font-weight:700}.info-label{font-weight:700;color:#555;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}.menu-actions{display:flex;gap:10px;margin-top:10px}.menu-actions button{padding:5px 10px;border:none;border-radius:4px;cursor:pointer;font-size:14px}.menu-actions button:first-child{background-color:#2196f3;color:#fff}.menu-actions button:last-child{background-color:#f44336;color:#fff}.popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.menu-editor-popup{width:90%;max-width:500px;padding:20px;border-radius:8px;box-shadow:0 4px 8px #0003}.menu-editor-popup h2{margin-top:0;color:#333}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:700}.form-group input,.form-group select{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.form-actions button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer}.form-actions button:first-child{background-color:#e41717}.form-actions button:last-child{background-color:#4caf50;color:#fff}.extras-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.extras-popup-content{background-color:#e6e6e6;padding:25px;border-radius:12px;max-width:500px;width:90%;margin:0 auto;box-shadow:0 4px 12px #00000026;color:#212529}.extras-popup-content h2{margin-top:0;color:#212529;margin-bottom:20px}.extras-popup-content h3{margin-top:20px;margin-bottom:10px;color:#333;font-size:1.1em}.extras-popup-content ul{list-style:none;padding:0;margin:0}.extras-popup-content li{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #eee}.extras-popup-content li:last-child{border-bottom:none}.extras-popup-content li button{background-color:#dc3545;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:.8em}.extras-popup-content select{width:calc(100% - 80px);padding:8px;border:1px solid #ddd;border-radius:4px;margin-right:10px}.extras-popup-content button{padding:8px 15px;border:none;border-radius:4px;cursor:pointer;background-color:#007bff;color:#fff}.extras-popup-content .popup-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.extras-popup-content .popup-actions button:first-child{background-color:#6c757d}.extras-popup-content .popup-actions button:last-child{background-color:#28a745}.mesa-editor{max-width:500px;margin:20px auto;padding:20px;background-color:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a}.mesa-editor h2{margin-top:0;color:#333}.warning{color:#dc3545;font-size:14px;margin-top:0;padding:10px 12px;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;width:100%;box-sizing:border-box}.warning p{margin:0;line-height:1.4}.mesa-editor-popup{background-color:#e6e6e6;padding:20px;border-radius:12px;max-width:600px;max-height:90vh;margin:0 auto;box-shadow:0 4px 12px #00000026;color:#212529;display:flex;flex-direction:column;overflow:hidden}.mesa-editor-popup h2{margin-top:0;color:#212529}.mesa-editor-popup .form-group{background-color:#fff;padding:20px;border-radius:8px;margin-bottom:0;box-shadow:0 1px 4px #0000000d;flex:1;overflow-y:auto;max-height:calc(95vh - 200px)}.mesa-editor-popup .form-row{display:flex;gap:20px;margin-bottom:16px;align-items:flex-start}.mesa-editor-popup .form-row:last-child{margin-bottom:0}.mesa-editor-popup .form-col{flex:1;min-width:0;display:flex;flex-direction:column}.mesa-editor-popup .form-col label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mesa-editor-popup .form-col input[type=number]{width:100%;min-width:60px;max-width:120px;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box}.mesa-editor-popup .form-col input:not([type=number]):not(.nombre-input),.mesa-editor-popup .form-col select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box;background-color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mesa-editor-popup .form-col select{-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;cursor:pointer}.mesa-editor-popup .form-col input:focus,.mesa-editor-popup .form-col select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.mesa-editor-popup .form-col.form-col-full{flex:0 0 50%;max-width:calc(50% - 10px)}.mesa-editor-popup .form-col input:disabled,.mesa-editor-popup .form-col select:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.mesa-editor-popup .form-group label{display:block;margin-bottom:8px;font-weight:600}.mesa-editor-popup .form-group input,.mesa-editor-popup .form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;background-color:#fff}.mesa-editor-popup .form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;flex-shrink:0}.mesa-editor-popup .form-actions button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.mesa-editor-popup .form-actions button[type=button]{background-color:#6c757d;color:#fff}.pedido-items-list{list-style:none;padding:10px 15px;border:1px solid #eee;border-radius:4px;margin:0 -15px;max-height:300px;overflow-y:auto;background-color:#f9f9f9;width:calc(100% + 30px);box-sizing:border-box}.pedido-items-list li{padding:8px 0;border-bottom:1px solid #eee;display:flex;flex-direction:column;align-items:flex-start;width:100%;box-sizing:border-box}.pedido-items-list li:last-child{border-bottom:none}.pedido-items-list .item-content{display:flex;justify-content:space-between;width:100%;align-items:center;box-sizing:border-box}.pedido-items-list .item-details{flex:1;display:flex;justify-content:space-between;align-items:center;padding-right:10px;box-sizing:border-box}.pedido-items-list .item-actions{flex-shrink:0;box-sizing:border-box}.mesa-table .pedido-items-list{max-height:200px;margin:0;padding:5px;background-color:transparent}.mesa-table .pedido-items-list li{padding:4px 0;border-bottom:1px solid #f0f0f0;font-size:.9em;display:flex;justify-content:space-between;align-items:center;width:100%}.mesa-table .pedido-items-list li:last-child{border-bottom:none}.mesa-table .pedido-items-list .item-name{flex:1;text-align:left}.mesa-table .pedido-items-list .item-price{min-width:60px;text-align:right;font-weight:700;color:#1e293b}.extras-container{width:100%;margin-top:5px;padding-left:0}.extras-list-popup{list-style-type:none;padding:5px 0 0 15px;margin:0;border-top:1px solid #eee;font-size:.9em;width:100%}.extras-list-popup li{color:#333;padding:2px 0}@media (max-height: 700px){.mesa-editor-popup{max-height:85vh;padding:15px}.mesa-editor-popup .form-group{max-height:calc(85vh - 180px)}.pedido-items-list{max-height:none;overflow-y:visible}}@media (max-height: 600px){.mesa-editor-popup{max-height:80vh;padding:10px}.mesa-editor-popup .form-group{max-height:calc(80vh - 160px)}.pedido-items-list{max-height:none;overflow-y:visible}}.mesa-editor-popup .form-actions button[type=submit]{background-color:#0d6efd;color:#fff}.mesa-editor-popup .form-actions button:disabled{opacity:.7;cursor:not-allowed}.mesa-container{padding:8px 16px;max-width:auto;margin:0 auto}.mesa-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:8px}.mesa-buttons{display:flex;gap:10px;margin-left:auto}.plus-icon{font-size:1.2em}.mesa-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.mesa-card{position:relative;border-radius:10px;padding:15px;cursor:pointer;box-shadow:0 4px 8px #0000001a;transition:transform .2s ease}.mesa-card:hover{transform:translateY(-5px)}.mesa-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:12px;border-radius:8px 8px 0 0}.mesa-card-header.pendiente{background-color:#fcc;border-bottom:2px solid #ff3333}.mesa-card-header.en_preparacion{background-color:#fc9;border-bottom:2px solid #ff9933}.mesa-card-header.servido{background-color:#cfc;border-bottom:2px solid #33cc33}.mesa-card-header.cerrada{background-color:#b6b6b6;border-bottom:2px solid rgb(80,80,80)}.mesa-card-header.cancelado{background-color:#ffb3b3;border-bottom:2px solid #660000}.mesa-card-header.cancelado button{color:#fff!important}.mesa-card-header.cerrado{background-color:#e5e7eb;border-bottom:2px solid #9ca3af}.mesa-card-header h3{margin:0;font-size:1.25em;color:#000}.estado-badge{padding:4px 8px;border-radius:12px;font-size:.8em;font-weight:700;color:#fff}.estado-badge.libre{background-color:#4caf50}.estado-badge.ocupada{background-color:#f44336}.estado-badge.reservada{background-color:#ffc107;color:#333}.estado-badge.pedidos{display:inline-block;padding:4px 8px;border-radius:12px;font-size:.9rem;font-weight:500;background-color:#e3f2fd;color:#1565c0}.mesa-card-body{border-radius:8px}.mesa-info{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.95em;padding-bottom:8px}.mesa-info:not(:last-child){border-bottom:1px solid #e2e8f0;padding:3px}.info-label{font-weight:700;color:#555;display:flex;align-items:center}.mesa-header h2{margin:0;font-size:1.5em;color:#0369a1}.customer-group{background-color:#f0f9ff;border-radius:10px;padding:0;box-shadow:0 4px 8px #0000001a}.pedido-card{border-radius:10px;margin:14px;border:1px solid #e2e8f0;box-shadow:0 4px 8px #0000001a;transition:transform .2s ease;background-color:#fff}.pedido-card:hover{transform:translateY(-5px)}.info-value{color:#1e293b;font-weight:500}.pedido-items{margin-top:10px;padding-top:10px;border-top:1px solid #acacac;width:100%}.pedido-items h4{margin-bottom:5px;color:#555;font-size:.95em}.pedido-items ul{padding-left:0;margin:0;width:100%}.pedido-item{margin-bottom:5px;padding:3px 0;list-style-type:none;display:flex;justify-content:space-between;align-items:center;width:100%}.item-name{flex:1;text-align:left}.item-price{min-width:60px;text-align:right;font-weight:700;color:#1e293b}.extras-list-inline{display:inline;list-style-type:none;padding-left:5px;margin:0}.extras-list-inline li{display:inline;font-size:.8em;color:#555}.extras-list-inline li:before{content:" / "}.extras-list-inline li:first-child:before{content:""}.extras-list-popup{list-style-type:none;padding:5px 0 0;margin:5px 0 0;border-top:1px solid #eee;font-size:.9em;width:100%;box-sizing:border-box}.extras-list-popup li{color:#333;padding:2px 50px 2px 0;position:relative;width:100%;box-sizing:border-box}.extras-list-popup .extra-name{display:inline-block;text-align:left}.extras-list-popup .extra-price{position:absolute;right:43px;top:50%;transform:translateY(-50%);min-width:60px;text-align:right;font-weight:700;color:#1e293b}.view-dropdown{position:relative;display:inline-block}.view-dropdown button{display:flex;align-items:center;gap:5px}.view-dropdown-content{display:none;position:absolute;background-color:#fff;min-width:160px;box-shadow:0 8px 16px #0003;z-index:1;border-radius:4px;overflow:hidden}.view-dropdown-content a{color:#333;padding:8px 12px;text-decoration:none;display:flex;align-items:center;gap:8px}.view-dropdown-content a:hover{background-color:#f1f1f1}.view-dropdown:hover .view-dropdown-content{display:block}.mesa-list{width:100%;margin-top:8px}.mesa-table{width:100%;border-collapse:collapse;box-shadow:0 2px 4px #0000001a}.mesa-table th{background-color:#0369a1;color:#fff;padding:12px;text-align:left;cursor:pointer;-webkit-user-select:none;user-select:none}.mesa-table th:hover{background-color:#0284c7}.mesa-table td{padding:10px 12px;border-bottom:1px solid #e2e8f0;vertical-align:middle}.mesa-table td.text-center,.mesa-table th.text-center{text-align:center}.mesa-table td.text-left,.mesa-table th.text-left{text-align:left}.mesa-table tr:nth-child(odd){background-color:#e2e2e2}.mesa-table tr:nth-child(2n){background-color:#fff}.mesa-table tr:hover{background-color:#f8f9fa}.cuentas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.cuenta-card{position:relative;background-color:#dbdbdb;border-radius:8px;padding:15px;box-shadow:0 2px 4px #0000001a;transition:transform .2s ease}.cuenta-card:hover{transform:translateY(-3px);box-shadow:0 4px 8px #00000026}.cuenta-card h3{margin:0 0 10px;color:#333;font-size:1.1em}.cuenta-status{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.8em;font-weight:700;color:#000;margin-bottom:10px}.cuenta-info{display:flex;flex-direction:column;gap:5px;font-size:.9em;color:#555}.cuenta-info span{display:flex;justify-content:space-between}.selection-checkbox{position:absolute;top:10px;right:10px;width:24px;height:24px;background-color:#fffc;border:1px solid #ccc;border-radius:50%;display:flex;justify-content:center;align-items:center;cursor:pointer;font-size:16px;font-weight:700;color:#007bff;z-index:2}.cuenta-card.selected .selection-checkbox{background-color:#007bff;color:#fff;border-color:#0056b3}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100vh;width:100%;box-sizing:border-box;padding:0}.password-input-container{position:relative;display:flex;align-items:center;width:100%}.password-input-container input{width:100%;padding-right:40px;box-sizing:border-box}.toggle-password-btn{position:absolute;right:8px;background:none;border:none;cursor:pointer;color:#666;font-size:18px;display:flex;align-items:center;justify-content:center;padding:4px;border-radius:4px;transition:color .2s,background-color .2s}.toggle-password-btn:hover{color:#333;background-color:#0000000d}.toggle-password-btn:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.mesa-card-footer{background-color:#f8f9fa;border-top:2px solid #0369a1;padding:12px 15px;border-radius:0 0 8px 8px;margin-top:10px}.total-cuenta{display:flex;justify-content:space-between;align-items:center;font-weight:700;font-size:1.1em;color:#1e293b}.total-cuenta-label{color:#0369a1;font-size:1em}.total-cuenta-value{color:#059669;font-size:1.2em;font-weight:700;background-color:#d1fae5;padding:4px 12px;border-radius:20px;border:1px solid #10b981}.login-box{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px;text-align:center;margin:2rem auto;box-sizing:border-box}.login-box h1{margin-bottom:1.5rem;color:#333;font-size:1.75rem}.login-box form{display:flex;flex-direction:column;gap:1rem;width:100%}.login-box .input-group{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;width:100%}.login-box .input-group label{font-weight:500;color:#555;font-size:.95rem}.login-box .input-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.login-box .input-group input:focus{outline:none;border-color:#eb512a;box-shadow:0 0 0 2px #eb512a1a}.login-box .btn-primary{width:100%;padding:.875rem;font-size:1rem;margin-top:.5rem}.mesa-select-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background-color:#fff;padding:20px;border-radius:8px;box-shadow:0 5px 15px #0000004d;z-index:1001;width:80%;max-width:600px}.mesa-select-popup .popup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.mesa-select-popup .close-button{background:none;border:none;font-size:1.5rem;cursor:pointer}.mesa-select-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;max-height:400px;overflow-y:auto}.mesa-select-card{padding:15px;border:1px solid #ddd;border-radius:4px;text-align:center;cursor:pointer;transition:background-color .2s,color .2s;font-size:1rem;background-color:#f9f9f9}.mesa-select-card:hover{background-color:#e0e0e0}.mesa-select-card.selected{background-color:#007bff;color:#fff;border-color:#0056b3}.mesa-card .selection-checkbox{position:absolute;top:10px;left:10px;width:20px;height:20px;border:2px solid #fff;background-color:#0003;border-radius:50%;cursor:pointer;display:flex;justify-content:center;align-items:center;color:#fff;font-weight:700}.mesa-card.selected{outline:2px solid #007bff;box-shadow:0 0 10px #007bff80}.mesa-table tr.selected{background-color:#cce5ff!important}.blinking-bell{animation:blink 1s infinite}@keyframes blink{0%{opacity:1}50%{opacity:0}to{opacity:1}}.cuenta-card.selected{box-shadow:0 0 0 3px #007bff,0 4px 8px #0003;border-color:#007bff;transform:translateY(-2px)}.mesa-table tr.selected{background-color:#a8d1ff!important;box-shadow:0 0 5px #007bff80}.mesa-table tr.selected td{color:#000}.items-list-grid{display:flex;flex-direction:column;gap:8px;margin-top:5px}.grid-item{padding:5px;border-left:3px solid #ddd;background-color:#f9f9f9;border-radius:4px}.extras-list-grid{margin-top:3px;padding-left:10px;border-left:2px solid #eee;display:flex;flex-direction:column;gap:2px}.extra-item{display:block}.mesero-editor-popup{background-color:#f8f9fa;padding:25px;border-radius:12px;max-width:500px;width:90%;max-height:90vh;margin:0 auto;box-shadow:0 4px 12px #00000026;color:#212529;display:flex;flex-direction:column;overflow:hidden}.mesero-editor-popup h2{margin-top:0;margin-bottom:20px;color:#212529;font-size:1.5rem}.mesero-editor-popup form{display:flex;flex-direction:column;overflow-y:auto;max-height:calc(90vh - 100px)}.mesero-editor-popup .form-group{margin-bottom:15px;flex-shrink:0}.mesero-editor-popup .form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151}.mesero-editor-popup .form-group input[type=text],.mesero-editor-popup .form-group input[type=password]{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;box-sizing:border-box;background-color:#fff}.mesero-editor-popup .form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.mesero-editor-popup .checkbox-field{display:flex;align-items:center;gap:12px}.mesero-editor-popup .checkbox-field label{margin-bottom:0}.mesero-editor-popup .checkbox-field input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#007bff}.mesero-editor-popup .form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;flex-shrink:0;padding-top:15px;border-top:1px solid #e5e7eb}.mesero-editor-popup .form-actions button{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.mesero-editor-popup .btn-save{background-color:#0d6efd;color:#fff}.mesero-editor-popup .btn-save:hover:not(:disabled){background-color:#0b5ed7}.mesero-editor-popup .btn-cancel{background-color:#6c757d;color:#fff}.mesero-editor-popup .btn-cancel:hover{background-color:#5c636a}.mesero-editor-popup .btn-delete{background-color:#dc3545;color:#fff;position:relative;padding-right:35px}.mesero-editor-popup .btn-delete:hover:not(:disabled){background-color:#bb2d3b}.mesero-editor-popup .btn-delete:disabled{background-color:#ccc;color:#666;cursor:not-allowed}.mesero-editor-popup .delete-button-container,.mesero-editor-popup .delete-button-wrapper{display:flex;flex-direction:column;gap:5px}.mesero-editor-popup .delete-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:12px}.mesero-editor-popup .delete-warning-text{font-size:12px;color:#dc3545;text-align:center}.mesero-delete-popup{background-color:#f8f9fa;padding:25px;border-radius:12px;max-width:450px;width:90%;margin:0 auto;box-shadow:0 4px 12px #00000026;color:#212529}.mesero-delete-popup h2{margin-top:0;margin-bottom:15px;color:#212529}.mesero-delete-popup p{margin-bottom:10px}.mesero-delete-popup .warning-text{color:#dc3545;font-size:.9rem}.mesero-delete-popup .btn-delete-confirm{background-color:#dc3545;color:#fff}.mesero-delete-popup .btn-delete-confirm:hover{background-color:#bb2d3b}@media (max-height: 600px){.mesero-editor-popup{max-height:95vh;padding:20px}.mesero-editor-popup form{max-height:calc(95vh - 80px)}}@media (max-width: 480px){.login-box{margin:1rem;padding:1.5rem;max-width:calc(100% - 2rem)}.login-box h1{font-size:1.5rem;margin-bottom:1rem}.login-box .input-group input{padding:.625rem;font-size:16px}}@media (max-width: 360px){.login-box{margin:.75rem;padding:1.25rem;max-width:calc(100% - 1.5rem)}.login-box h1{font-size:1.25rem}.login-box .input-group label{font-size:.875rem}}.admin-chat-container{position:fixed;bottom:20px;right:20px;width:350px;height:500px;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:12px;box-shadow:0 8px 32px #0000001a,0 2px 8px #0000000d;z-index:1000;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.admin-chat-container.closed{height:60px;cursor:pointer}.admin-chat-container:hover{box-shadow:0 12px 48px #00000026,0 4px 12px #00000014}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#ffffff26,#ffffff0d);border-bottom:1px solid rgba(255,255,255,.1);cursor:pointer;transition:background-color .2s ease}.chat-header:hover{background:linear-gradient(135deg,#fff3,#ffffff1a)}.header-content{display:flex;align-items:center;gap:12px}.header-icon{color:#2563eb;opacity:.9;position:relative}@keyframes blink-red{0%{color:#2563eb}50%{color:#dc2626}to{color:#2563eb}}.header-icon.has-unread{animation:blink-red 1s infinite}.unread-badge{position:absolute;top:-5px;right:-5px;background-color:#dc2626;color:#fff;border-radius:50%;width:18px;height:18px;display:flex;justify-content:center;align-items:center;font-size:11px;font-weight:700;border:2px solid white;box-shadow:0 2px 4px #0000001a}.header-text h3{margin:0;font-size:16px;font-weight:600;color:#1f2937;line-height:1.2}.status-indicator{display:flex;align-items:center;gap:4px;font-size:12px;color:#6b7280;margin-top:2px}.status-dot{width:6px;height:6px;background:#10b981;border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.header-toggle{color:#6b7280;transition:transform .3s ease}.toggle-icon{transition:transform .3s ease}.toggle-icon.open{transform:rotate(180deg)}.mesero-selector-container{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1);background:#ffffff0d}.mesero-selector{width:100%;padding:8px 12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a;font-size:14px;color:#1f2937;outline:none;transition:all .2s ease}.mesero-selector:focus{border-color:#2563eb;background:#ffffff26;box-shadow:0 0 0 2px #2563eb1a}.selected-mesero-indicator{margin-top:4px;font-size:12px;color:#6b7280;font-style:italic}.chat-body{display:flex;flex-direction:column;height:calc(100% - 60px);background:#ffffff0d}.messages-container{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.messages-container::-webkit-scrollbar{width:4px}.messages-container::-webkit-scrollbar-track{background:#0000000d;border-radius:2px}.messages-container::-webkit-scrollbar-thumb{background:#0003;border-radius:2px}.message{display:flex;max-width:80%}.message.admin{align-self:flex-end}.message.mesero{align-self:flex-start}.message.clickable{cursor:pointer;transition:transform .1s ease}.message.clickable:hover{transform:translate(2px)}.message-content{padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.4;word-wrap:break-word}.message-header{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-size:11px;font-weight:600}.mesero-name{color:#059669}.admin-label{color:#2563eb}.recipient-label{color:#fff}.broadcast-badge{background:#f59e0b;color:#fff;padding:2px 6px;border-radius:10px;font-size:10px;font-weight:500}.message.admin .message-content{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border-bottom-right-radius:4px}.message.mesero .message-content{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-bottom-left-radius:4px}.message.mesero.clickable .message-content{background:#e5e7eb;color:#1f2937;border:1px solid #d1d5db}.message.mesero.clickable:hover .message-content{background:#f3f4f6}.message.message-all .message-content{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-bottom-left-radius:4px;border-bottom-right-radius:4px;align-self:center;max-width:90%}.message-text{margin:0}.message-time{display:block;font-size:11px;opacity:.7;margin-top:4px}.message.admin .message-time,.message.mesero .message-time{color:#fffc}.message.mesero.clickable .message-time{color:#6b7280}.chat-input-container{display:flex;gap:8px;padding:16px;border-top:1px solid rgba(255,255,255,.1);background:#ffffff0d}.chat-input{flex:1;padding:10px 14px;border:1px solid rgba(255,255,255,.2);border-radius:20px;background:#ffffff1a;font-size:14px;color:#1f2937;outline:none;transition:all .2s ease}.chat-input::placeholder{color:#6b7280}.chat-input:focus{border-color:#2563eb;background:#ffffff26;box-shadow:0 0 0 2px #2563eb1a}.send-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#2563eb;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.send-button:hover:not(:disabled){background:#3b82f6;transform:translateY(-1px)}.send-button:active:not(:disabled){transform:translateY(0)}.send-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.5}@media (max-width: 480px){.admin-chat-container{width:calc(100vw - 32px);right:16px;bottom:16px;left:16px;height:480px}}@media (max-width: 768px){.admin-chat-container{width:320px}}@media (max-width: 390px){.admin-chat-container{width:calc(100vw - 20px);right:10px;bottom:10px;left:10px;height:450px}}@media (prefers-color-scheme: dark){.admin-chat-container{background:#111827cc;border-color:#ffffff1a}.header-text h3{color:#f9fafb}.chat-input{color:#f9fafb;background:#ffffff1a}}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.admin-chat-container{animation:slideUp .3s ease-out}.nuevo-pedido-container{max-width:100%;margin:0 auto;padding:0 1.5rem 1rem;background:var(--bg-primary);color:var(--text-primary);min-height:auto;font-family:Segoe UI,system-ui,sans-serif;line-height:1.6;display:flex;flex-direction:column;justify-content:flex-start}.nuevo-pedido-container h1,.nuevo-pedido-container h2,.nuevo-pedido-container h3,.nuevo-pedido-container h4,.nuevo-pedido-container h5,.nuevo-pedido-container h6{margin:0 0 1rem;font-weight:600;color:var(--text-secondary)}.nuevo-pedido-container h1{color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-weight:600;font-size:1.8rem;letter-spacing:-.5px}.nuevo-pedido-container a{color:var(--accent-color);text-decoration:none;transition:color .2s ease}.nuevo-pedido-container a:hover{color:var(--accent-hover);text-decoration:underline}.nuevo-pedido-container p{margin:0 0 1rem}.nuevo-pedido-container ul,.nuevo-pedido-container ol{padding-left:1.5rem;margin:0 0 1rem}.nuevo-pedido-container li{margin-bottom:.5rem;padding:.75rem 1rem;background-color:var(--bg-secondary);border-radius:6px;transition:all .2s ease;list-style-type:none;border-left:3px solid var(--accent-color)}.nuevo-pedido-container li:hover{background-color:var(--bg-tertiary);transform:translate(4px);box-shadow:0 2px 4px #0003}.nuevo-pedido-container li:not(:last-child){margin-bottom:.75rem}.clientes-section ul{padding:0;margin:0}.clientes-section li{padding:.75rem 1rem;border-bottom:1px solid var(--border-color);border-top:1px solid var(--border-color);border-right:1px solid var(--border-color);transition:all .2s ease}.clientes-section li:hover{background:var(--bg-tertiary)}.button-group{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;margin-bottom:1rem}.action-button:active{transform:translateY(0)}.success-action-button{background:var(--success-color);color:var(--bg-primary);border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);text-align:center;box-shadow:0 2px 4px #0003}@media (max-width: 768px){.nuevo-pedido-container{padding:0 1rem .5rem}.nuevo-pedido-container h1{font-size:1.5rem;margin-bottom:1rem}.action-button{padding:.8rem}.clientes-section{padding:1rem;margin-bottom:.75rem}.button-group{gap:.5rem;margin-top:.75rem;margin-bottom:.75rem}}.loading-message{color:var(--success-color);text-align:center;font-style:italic}.error-message{color:var(--error-color);text-align:center;font-weight:500}.menu-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000}.menu-popup-container{position:relative;display:flex;justify-content:center;align-items:center;width:100%;max-width:100vw;box-sizing:border-box}.menu-popup-content{background-color:var(--bg-secondary);padding:10px 20px 20px;border-radius:12px;width:95%;max-width:1200px;max-height:70vh;overflow-y:auto;overflow-x:hidden;position:relative;box-shadow:0 4px 20px #00000080;border:1px solid var(--accent-color);text-align:center;display:flex;flex-direction:column;align-items:center;box-sizing:border-box;margin:0 auto}.menu-popup-close{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:absolute;top:-20px;right:20px;background:var(--accent-color);border:none;color:var(--text-on-accent);font-size:20px;padding:8px;z-index:1002;box-shadow:0 2px 8px #0000004d}.menu-popup-close:hover{background:var(--accent-hover);transform:scale(1.1)}.menu-popup-home{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;position:absolute;top:-20px;right:20px;background:var(--accent-color);border:none;color:var(--text-on-accent);font-size:20px;padding:8px;z-index:1002;box-shadow:0 2px 8px #0000004d}.menu-popup-home:hover{background:var(--accent-hover);transform:scale(1.1)}.category-group{margin-bottom:25px}.category-title{color:var(--accent-color);border-bottom:1px solid var(--border-color);padding-bottom:8px;font-size:1.1rem}.pedidos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-top:15px}.pedidos-grid .menu-item-image{width:100%;height:auto;border-radius:8px 8px 0 0;margin-bottom:10px;display:block}.pedidos-grid .menu-item{flex-direction:column}.menu-item{display:flex;justify-content:space-between;align-items:center;padding:12px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-primary);transition:all .2s ease}.menu-item:hover{border-color:var(--accent-color);transform:translateY(-2px)}.menu-item button{background-color:var(--accent-color);color:var(--text-on-accent);border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s ease}.menu-item button:hover{background-color:var(--accent-hover);transform:scale(1.05)}.menu-item span{font-weight:500}.pedido-items{max-height:0;overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out;opacity:0;padding-left:1rem;margin-top:.5rem;font-size:.9em}.pedido-items.expanded{max-height:500px;opacity:1}.clientes-section ul li.selected{background-color:#3f3f3f;font-weight:700;font-size:1.2em;color:#fff}.clientes-section ul li{cursor:pointer;padding:8px;margin:4px 0;border-radius:4px;transition:background-color .2s}.clientes-section ul li:hover{background-color:var(--bg-hover)}.quantity-controls{display:flex;align-items:center;gap:8px}.quantity-controls button{width:28px;height:28px;border-radius:50%;border:1px solid var(--accent-color);background:var(--bg-secondary);color:var(--accent-color);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.quantity-controls button:hover{background:var(--accent-color);color:var(--text-on-accent);transform:scale(1.1)}.quantity-controls button:disabled{opacity:.5;cursor:not-allowed;border-color:var(--border-disabled);color:var(--text-disabled);position:relative}.quantity-controls button:disabled:after{content:"✓";position:absolute;font-size:10px;right:-5px;top:-5px;color:var(--text-disabled)}.quantity-controls button:disabled:hover{background:transparent;transform:none}.quantity-controls span{min-width:32px;text-align:center;font-weight:500;font-size:1rem;display:inline-flex;align-items:center;justify-content:center;line-height:1;margin:0 4px}.menu-popup-buttons{display:flex;justify-content:center;margin-top:20px;gap:10px;padding:0 20px 20px;width:100%;flex-wrap:wrap}.menu-popup-buttons button{flex:1;padding:12px;border:none;border-radius:8px;font-weight:700;cursor:pointer;transition:all .2s;font-size:1rem}.menu-popup-buttons .cancel-button.category-selection-button{flex:unset;width:150px;min-width:150px;max-width:150px}.menu-popup-buttons button:active{transform:translateY(0)}.confirm-button{background-color:var(--accent-color);color:#fff}.confirm-button:hover{background-color:var(--accent-hover);transform:translateY(-2px);box-shadow:0 2px 4px #0003}.confirm-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;pointer-events:none;background-color:#6c757d}.success-action-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;pointer-events:none;background-color:#6c757d}.cancel-button{background-color:var(--error-color);color:#fff}.cancel-button:hover{background-color:var(--error-hover);transform:translateY(-2px);box-shadow:0 2px 4px #0003}.thank-you-step{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;text-align:center;color:var(--text-primary)}.thank-you-step h3{color:var(--accent-color);margin-bottom:1rem;font-size:1.5rem}.thank-you-step p{margin-bottom:2rem;font-size:1.1rem}.estado-badge{padding:6px 12px;border-radius:16px;font-size:.9rem;font-weight:600;text-transform:capitalize;display:inline-block;margin:4px 0}.estado-badge.pendiente{background-color:#dc2626;color:#fff}.estado-badge.en_preparacion{background-color:#997e26;color:#fff}.estado-badge.listo,.estado-badge.servido{background-color:#166534;color:#fff}.estado-badge.entregado{background-color:#2563eb33;color:#2563eb}.estado-badge.cerrada{background-color:#4b5563;color:#fff}.estado-badge.cancelado{background-color:#4b5563;color:#fff;text-decoration:line-through}.status-dropdown{position:absolute;border-radius:8px;box-shadow:0 4px 12px #0003;z-index:10;margin-top:5px;right:0;min-width:150px;overflow:hidden}.status-option{display:block;width:100%;padding:10px 15px;text-align:left;background-color:transparent;border:none;color:var(--text-primary);cursor:pointer;transition:background-color .2s ease;font-size:.9rem;text-transform:capitalize}.status-option:hover{background-color:var(--bg-tertiary)}.status-option.pendiente{color:#dc2626}.status-option.en_preparacion{color:#997e26}.status-option.listo{color:#166534}.status-option.entregado{color:#2563eb}.status-option.cancelado{color:#4b5563}.pedido-header{position:relative}.not-you-link{color:#fff;cursor:pointer;padding:.5rem 1rem;margin-top:-.5rem;background:transparent;border:none;transition:color .2s ease}.not-you-link:hover{color:var(--accent-hover);text-decoration:none}.mesa-numero-circulo{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background-color:var(--error-color);color:var(--text-on-accent);font-size:1.2rem;font-weight:700;margin-left:10px;box-shadow:0 2px 5px #0003}.header-image{width:100%;height:auto;display:block}.category-selection{text-align:center}.category-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1rem}.category-button{background:var(--accent-color);color:var(--text-on-accent);border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);text-align:center;box-shadow:0 2px 4px #0003}.category-button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.menu-item{display:flex;flex-direction:column;justify-content:space-between}.menu-item .menu-item-text{display:flex;flex-direction:column;align-items:center;width:100%}.menu-item .menu-item-name{margin-bottom:4px;font-size:1.1em;font-weight:500;text-align:center;width:100%}.menu-item .menu-item-detail{font-size:.9em;color:var(--text-secondary);text-align:center;width:100%;line-height:1.3}.menu-item-footer{display:flex;flex-direction:column;gap:.5rem;align-items:center;width:100%}.menu-item-footer .menu-item-price{font-weight:700;color:var(--error-color);font-size:1.1rem}.popup-header{display:flex;flex-direction:column;align-items:center;margin-bottom:1rem;text-align:center}.popup-header h3,.popup-header h4{margin:0;text-align:center;width:100%}.menu-popup-content h3{text-align:center;width:100%;margin-bottom:1rem}.menu-popup-content p{text-align:center;width:100%;margin-bottom:1.5rem}.menu-popup-content .estado-badge{width:fit-content}.order-summary-icons{display:flex;align-items:center;gap:1rem;justify-content:center}.order-summary-icons span{display:flex;align-items:center;gap:.3rem;font-size:1rem;font-weight:400;color:var(--text-primary)}.order-total{margin-top:2rem;padding:1rem;background-color:var(--bg-tertiary);border-radius:8px;border-top:2px solid var(--accent-color);text-align:right}.order-total h4{margin:0;color:#fff;font-size:1.3rem;font-weight:700}.extras-controls{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;justify-content:center}.extras-controls label{display:inline-flex;align-items:center;padding:.3rem 1rem;border:1px solid #3b3b3b;border-radius:20px;cursor:pointer;transition:all .3s ease;background-color:var(--bg-secondary);color:#919191;font-size:.9rem;font-weight:500;-webkit-user-select:none;user-select:none}.extras-controls label:hover{background-color:var(--bg-tertiary);transform:translateY(-1px)}.extras-controls label input{display:none}.extras-controls label:has(input:checked){border-color:var(--success-color);background-color:#28a7451a;color:var(--success-color);font-weight:600}.extras-controls label:has(input:disabled){opacity:.5;cursor:not-allowed;background-color:var(--bg-tertiary)}.extras-controls label:has(input:disabled):hover{transform:none;background-color:var(--bg-tertiary)}.extras-controls label:has(input[type=radio]){border-style:solid}.extras-controls label:has(input[type=checkbox]){border-style:dashed}@media (max-width: 768px){.extras-controls{gap:.3rem;justify-content:center}.extras-controls label{padding:.4rem .8rem;font-size:.85rem}}.menu-item-header{display:flex;flex-direction:column;width:100%;margin-bottom:.5rem;padding:.5rem 0;border-bottom:1px solid var(--border-color)}.menu-item-header .menu-item-name{font-weight:600;color:var(--text-primary);font-size:1.2rem;margin-bottom:.25rem}.menu-item-header span:last-child{color:var(--error-color);font-weight:500;font-size:.9rem;text-align:center}.extra-summary-item{display:inline-flex;align-items:center;padding:.3rem 1rem;border:1px solid var(--success-color);border-radius:20px;background-color:#28a7451a;color:var(--success-color);font-size:.8rem;font-weight:600;margin:.2rem;-webkit-user-select:none;user-select:none}.item-extras-summary{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.5rem;justify-content:center}.new-client-form{background:var(--bg-secondary);border-radius:12px;padding:.1rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000004d}.new-client-form h3{color:var(--accent-color);margin:0 0 1rem;font-size:1.2rem;font-weight:500;text-align:center}.new-client-form .form-group{margin-bottom:1rem}.new-client-form label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:500;text-align:left}.new-client-form input,.new-client-form select,.new-client-form textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);color:var(--text-primary);font-size:1rem;transition:border-color .2s ease;box-sizing:border-box}.new-client-form input:focus,.new-client-form select:focus,.new-client-form textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f61a}.new-client-form .form-actions{display:flex;gap:1rem;margin-top:1.5rem}.new-client-form .submit-button{background:var(--accent-color);color:var(--text-on-accent);border:none;padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;flex:1}.new-client-form .submit-button:hover{background:var(--accent-hover);transform:translateY(-1px)}.new-client-form .cancel-button{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color);padding:.75rem 1.5rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;flex:1}.new-client-form .cancel-button:hover{background:var(--bg-secondary);border-color:var(--accent-color)}@media (max-width: 768px){.new-client-form{padding:1rem}.new-client-form .form-actions{flex-direction:column}}.qr-payment-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.qr-payment-container{background:#fff;border-radius:12px;padding:16px;max-width:480px;width:90%;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 30px #0000004d}.qr-payment-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:#666;padding:8px;border-radius:50%;transition:background-color .2s}.qr-payment-close:hover{background-color:#f0f0f0}.qr-payment-content{text-align:center}.qr-payment-content h2{color:#333;margin-bottom:16px;font-size:1.5rem}.qr-instructions{color:#666;margin-bottom:24px;font-size:.9rem;line-height:1.4}.qr-display-area{margin:10px 0}.qr-static-wrapper,.qr-dynamic-wrapper{margin:5px auto;padding:5px;text-align:center}.qr-static-wrapper .qr-code-container,.qr-dynamic-wrapper .qr-code-container{margin:0 auto;padding:10px;background:#e4e4e4;border-radius:8px;display:inline-block}.qr-code-container{margin:10px auto;padding:10px;background:#e4e4e4;border-radius:8px;display:inline-block}.payment-details{text-align:left;margin:1px 0;padding:16px;background:#f8f9fa;border-radius:8px}.payment-details h3{color:#333;margin-bottom:16px;font-size:1.1rem}.bank-info,.payment-info{margin-bottom:16px}.bank-info p,.payment-info p{margin:8px 0;color:#555;font-size:.9rem}.bank-info strong,.payment-info strong{color:#333}.qr-payment-buttons{margin-top:12px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.qr-payment-buttons--sticky{position:relative;z-index:10}.qr-payment-buttons-inner{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;width:100%}.download-button{background-color:#28a745;color:#fff;border:none;padding:10px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s;display:flex;align-items:center;gap:6px}.download-button:hover{background-color:#218838}.confirm-button{background-color:#007bff;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.confirm-button:hover{background-color:#0056b3}.qr-clickable{cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.qr-clickable:hover{transform:scale(1.02)}.qr-clickable .qr-code-container{position:relative}.qr-clickable .qr-code-container:after{content:"🔍";position:absolute;bottom:8px;right:8px;font-size:1.2rem;opacity:.7;pointer-events:none}.qr-zoom-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;justify-content:center;align-items:center;z-index:1100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.qr-zoom-container{background:#fff;border-radius:16px;padding:30px;max-width:500px;width:90%;position:relative;box-shadow:0 20px 60px #0006;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.qr-zoom-close{position:absolute;top:16px;right:16px;background:#f0f0f0;border:none;cursor:pointer;color:#666;padding:10px;border-radius:50%;transition:background-color .2s,color .2s;display:flex;align-items:center;justify-content:center}.qr-zoom-close:hover{background-color:#e0e0e0;color:#333}.qr-zoom-content{text-align:center}.qr-zoom-title{color:#333;margin-bottom:24px;font-size:1.4rem;font-weight:600}.qr-zoom-qr-wrapper{background:#f8f9fa;border-radius:12px;padding:24px;margin-bottom:24px;display:inline-block}.qr-zoom-qr-wrapper svg,.qr-zoom-imagen{max-width:100%;height:auto;display:block}.qr-zoom-imagen{max-width:320px;max-height:320px;width:auto;height:auto}.qr-zoom-monto{margin-bottom:16px}.qr-zoom-monto-label{display:block;color:#666;font-size:.95rem;margin-bottom:8px}.qr-zoom-monto-valor{display:block;color:#28a745;font-size:2rem;font-weight:700}.qr-zoom-instruccion{color:#888;font-size:.9rem;margin:0}@media (max-width: 600px){.qr-payment-container{padding:12px;width:95%}.qr-payment-content h2{font-size:1.3rem}.qr-code-container,.payment-details{padding:12px}.qr-payment-buttons{flex-direction:column;align-items:center}.download-button,.confirm-button{width:100%;max-width:200px}.qr-zoom-container{padding:20px;width:95%}.qr-zoom-title{font-size:1.2rem}.qr-zoom-qr-wrapper{padding:16px}.qr-zoom-monto-valor{font-size:1.6rem}}.qr-notification{padding:16px 20px;border-radius:10px;margin:0 0 20px;text-align:center;font-weight:500;font-size:1rem;animation:slideInDown .4s ease-out;display:flex;flex-direction:column;align-items:center;gap:8px;box-shadow:0 4px 12px #00000026}@keyframes slideInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.qr-notification--exito{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:2px solid #28a745;color:#155724}.qr-notification--error{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:2px solid #dc3545;color:#721c24}.qr-notification--info{background:linear-gradient(135deg,#d1ecf1,#bee5eb);border:2px solid #17a2b8;color:#0c5460}.qr-notification svg{flex-shrink:0}.qr-notification__timer{font-size:.85rem;opacity:.8;margin-top:4px;font-style:italic}@media (max-width: 600px){.qr-notification{padding:12px 16px;font-size:.95rem;margin:0 0 16px}.qr-notification__timer{font-size:.8rem}}.mesas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:15px;margin-top:20px;justify-items:center;justify-content:center}.mesa-square{width:100px;height:100px;display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:1.5rem;font-weight:700;border-radius:8px;background-color:var(--bg-tertiary);color:var(--text-primary);transition:all .2s ease;position:relative}.mesa-indicators-container{display:flex;justify-content:center;gap:6px;margin-bottom:6px;height:15px;width:100%}.mesa-indicator-rect{width:35px;height:12px;border-radius:3px}.mesa-indicator-rect.status-atendido{background-color:#f93;box-shadow:0 0 2px #0000004d}.mesa-indicator-rect.status-servido{background-color:#3c3;box-shadow:0 0 2px #0000004d}.mesa-square.mesa-libre{border:2px dashed var(--accent-color)}.mesa-square.mesa-ocupada{border:2px solid var(--error-color);background-color:var(--error-color-light)}.mesa-square:hover{transform:translateY(-3px);box-shadow:0 4px 8px #0003}@keyframes blink-border{0%{border-color:var(--error-color)}50%{border-color:transparent}to{border-color:var(--error-color)}}.mesa-square.mesa-llamada-activa{animation:blink-border 1s infinite}@keyframes blink-red-bg{0%{background-color:var(--error-color-light);color:var(--text-primary)}50%{background-color:var(--error-color);color:#fff}to{background-color:var(--error-color-light);color:var(--text-primary)}}.mesa-square.chat-unread-active{animation:blink-red-bg 1s infinite;border-color:var(--error-color)}.unread-badge{position:absolute;top:-5px;right:-5px;background-color:red;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;justify-content:center;align-items:center;font-size:12px;font-weight:700;border:2px solid white;box-shadow:0 2px 4px #0003}.mesa-square.mesa-con-pedido{box-shadow:0 0 10px var(--accent-color)}.mesa-square.con-pedidos-pendientes{border:2px solid #cf6679;background-color:#cf66791a}.mesa-square.con-pedidos-en-preparacion{border:2px solid #ff9933;background-color:#ff99331a}.mesa-square.todos-servidos{border:2px solid #33cc33;background-color:#33cc331a}.mesa-square.filter-active{background-color:var(--error-color);color:var(--bg-primary);border:2px solid var(--accent-color-dark)}.popupmesero-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}body.menu-popup-open{overflow:hidden;position:fixed;width:100%;height:100%}.popupmesero-content{border:2px solid var(--error-color);background-color:var(--bg-primary);padding-left:1rem;padding-right:1rem;padding-bottom:1rem;border-radius:8px;box-shadow:0 4px 15px #0000004d;max-width:500px;width:90%;text-align:center;max-height:80vh;overflow-y:auto;display:flex;flex-direction:column}.popupmesero-content h3{color:var(--error-color)}.popupmesero-content ul{list-style:none;padding:0;margin:0}.popupmesero-content li{background-color:var(--bg-secondary);padding:.8rem 1rem;margin-bottom:.5rem;border-radius:5px;font-size:1rem}.pedido-item-container{background-color:var(--bg-secondary);padding:.8rem 1rem;margin-bottom:.5rem;border-radius:5px;cursor:pointer;transition:background-color .2s ease}.pedido-item-container:hover{background-color:var(--bg-tertiary)}.pedido-header{display:flex;justify-content:space-between;align-items:center;width:100%}.cliente-nombre{font-weight:700;color:var(--text-primary);text-align:left;flex-grow:1}.pedido-items{list-style:none;padding:0;margin-top:.5rem;font-size:.9em;max-height:0;overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out;opacity:0}.pedido-details-condensed{max-height:0;overflow:hidden;transition:max-height .3s ease-out,opacity .3s ease-out;opacity:0;margin-top:.5rem;font-size:.9em;width:100%}.pedido-details-condensed.expanded{max-height:500px;opacity:1;overflow-y:auto}.pedido-summary{display:flex;justify-content:space-between;padding:.2rem 0;border-bottom:1px dashed var(--border-color);margin-bottom:.2rem;font-weight:700}.mesero-pedido-items-list{list-style:none;padding:10px;border:1px solid var(--border-color);border-radius:4px;margin:0;max-height:300px;overflow-y:auto;background-color:var(--bg-secondary);width:100%;box-sizing:border-box}.mesero-pedido-items-list li{background-color:transparent;padding:8px 0;margin-bottom:0;border-bottom:1px solid var(--border-color);display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;width:100%;box-sizing:border-box;gap:8px}.mesero-pedido-items-list li:last-child{border-bottom:none}.mesero-pedido-items-list li:hover{background-color:var(--bg-tertiary);transform:none;box-shadow:none}.mesero-pedido-item-details{flex:1;display:flex;flex-direction:column;align-items:flex-start;min-width:0}.mesero-pedido-item-details>*{word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.nota-icon{margin-left:10px;font-size:1.2rem;color:#007bff;cursor:pointer;transition:all .2s ease;flex-shrink:0;padding:4px;border-radius:4px;background-color:transparent}.nota-icon:hover{color:#0056b3;background-color:#007bff1a}.extras-list{margin-top:6px;width:100%}.extra-item{display:flex;align-items:center;justify-content:flex-start;background-color:#0dcaf026;border-left:3px solid #0dcaf0;padding:4px 8px;margin-top:4px;border-radius:0 4px 4px 0;font-size:.85em}.extra-item:before{content:"➕";margin-right:6px;font-size:.9em;flex-shrink:0}.extra-text{color:#0dcaf0;flex:1;text-align:left;word-wrap:break-word;overflow-wrap:break-word}.meseros-content-wrapper{padding-top:70px}.filter-controls{display:flex;justify-content:center;align-items:center;padding:.4rem .5rem;position:fixed;top:0;width:100%;background-color:var(--bg-primary);z-index:999;box-shadow:0 2px 5px #0000001a;box-sizing:border-box}.filter-buttons-container{display:flex;gap:15px}.filter-controls .logout-button{border:2px solid var(--border-color)!important;background-color:var(--bg-tertiary);color:var(--text-primary);margin:0}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000;color:#fff}.spinner{border:8px solid rgba(255,255,255,.3);border-top:8px solid white;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin-bottom:20px}.nota-popup-buttons-container{display:flex;justify-content:center;gap:.5rem;margin-top:.5rem}.nota-action-button{padding:.5rem 1rem;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.nota-edit-button{background-color:#007bff}.nota-edit-button:hover{background-color:#0056b3}.nota-delete-button{background-color:#dc3545}.nota-delete-button:hover{background-color:#c82333}.nota-add-button{padding:.5rem 1rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.nota-add-button:hover{background-color:#0056b3}.nota-add-button:disabled{background-color:#6c757d;cursor:not-allowed}.nota-close-button{padding:.5rem 1rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.nota-close-button:hover{background-color:#5a6268}.status-dropdown .estado-badge{padding:7.2px 14.4px;border-radius:19.2px;font-size:1.08rem;font-weight:600;text-transform:capitalize;display:inline-block;margin:4.8px 0;cursor:pointer;transition:all .2s ease;min-width:90px;text-align:center}.status-dropdown .estado-badge:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.status-dropdown .estado-badge.pendiente{background-color:#dc2626;color:#fff}.status-dropdown .estado-badge.en_preparacion{background-color:#997e26;color:#fff}.status-dropdown .estado-badge.servido{background-color:#166534;color:#fff}.status-dropdown .estado-badge.cerrada{background-color:#4b5563;color:#fff}.status-dropdown .estado-badge.cancelado{background-color:#4b5563;color:#fff;text-decoration:line-through}.payment-call-button{background-color:#28a745!important;border-color:#28a745!important}.payment-call-button:hover{background-color:#218838!important;border-color:#1e7e34!important}.payment-icon{position:absolute;top:-8px;right:-8px;background-color:#28a745;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;border:2px solid var(--bg-primary);box-shadow:0 2px 4px #0003;z-index:10}.mesero-pedido-item{display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;width:100%}.notas-list{margin-top:6px;width:100%}.nota-item{display:flex;align-items:center;justify-content:space-between;background-color:#ffc10726;border-left:3px solid #ffc107;padding:4px 8px;margin-top:4px;border-radius:0 4px 4px 0;font-size:.85em}.nota-item:before{content:"📝";margin-right:6px;font-size:.9em;flex-shrink:0}.nota-text{color:#ffc107;flex:1;text-align:left;word-wrap:break-word;overflow-wrap:break-word}.nota-delete-btn{background:none;border:none;color:#dc3545;font-size:1.2rem;cursor:pointer;padding:0 4px;margin-left:8px;line-height:1;opacity:.7;transition:opacity .2s ease;flex-shrink:0}.nota-delete-btn:hover{opacity:1}.inline-nota-input-container{display:flex;align-items:center;gap:8px;margin-top:8px;width:100%}.inline-nota-input{flex:1;padding:6px 10px;border:1px solid #ffc107;border-radius:4px;background-color:var(--bg-primary);color:var(--text-primary);font-size:.9em;min-width:0}.inline-nota-input:focus{outline:none;border-color:#ffc107;box-shadow:0 0 0 2px #ffc10733}.inline-nota-actions{display:flex;gap:4px;flex-shrink:0}.inline-nota-confirm,.inline-nota-cancel{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s ease}.inline-nota-confirm{background-color:#28a745;color:#fff}.inline-nota-confirm:hover:not(:disabled){background-color:#218838}.inline-nota-confirm:disabled{background-color:#6c757d;cursor:not-allowed}.inline-nota-cancel{background-color:#dc3545;color:#fff}.inline-nota-cancel:hover{background-color:#c82333}.nota-icon.active{color:#ffc107;background-color:#ffc10733}.mesero-chat-container{width:100%;max-width:600px;margin:0 auto;background:transparent;border-radius:8px;box-shadow:0 2px 8px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;height:70vh;display:flex;flex-direction:column}.mesero-chat-container .messages-container{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#ffffff05}.mesero-chat-container .messages-container::-webkit-scrollbar{width:4px}.mesero-chat-container .messages-container::-webkit-scrollbar-track{background:#0000000d;border-radius:2px}.mesero-chat-container .messages-container::-webkit-scrollbar-thumb{background:#0003;border-radius:2px}.mesero-chat-container .message{display:flex;max-width:80%;margin-bottom:8px}.mesero-chat-container .message.received{align-self:flex-start;margin-right:auto}.mesero-chat-container .message.sent{align-self:flex-end;margin-left:auto}.mesero-chat-container .message-content{padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.4;word-wrap:break-word;max-width:100%}.mesero-chat-container .message.received .message-content{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;border-bottom-left-radius:4px}.mesero-chat-container .message.message-all .message-content{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-bottom-left-radius:4px;border-bottom-right-radius:4px;align-self:center;max-width:90%}.mesero-chat-container .message.sent .message-content{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-bottom-right-radius:4px}.mesero-chat-container .message-header{display:flex;align-items:center;gap:6px;margin-bottom:4px;font-size:12px;font-weight:600;color:#ffffffe6}.mesero-chat-container .message-text{margin:0;color:inherit}.mesero-chat-container .sender-label{color:#ffffffe6}.mesero-chat-container .message-time{display:block;font-size:11px;opacity:.7;margin-top:4px;color:#fffc}.mesero-chat-container .chat-input-container{display:flex;gap:8px;padding:16px;border-top:1px solid rgba(255,255,255,.1);background:#ffffff0d;border-radius:0 0 8px 8px}.mesero-chat-container .chat-input{flex:1;padding:12px 16px;border:1px solid rgba(255,255,255,.2);border-radius:20px;background:#ffffff1a;font-size:14px;color:#1f2937;outline:none;transition:all .2s ease}.mesero-chat-container .chat-input::placeholder{color:#6b7280}.mesero-chat-container .chat-input:focus{border-color:#2563eb;background:#ffffff26;box-shadow:0 0 0 2px #2563eb1a}.mesero-chat-container .send-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#2563eb;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .2s ease}.mesero-chat-container .send-button:hover:not(:disabled){background:#3b82f6;transform:translateY(-1px)}.mesero-chat-container .send-button:active:not(:disabled){transform:translateY(0)}.mesero-chat-container .send-button:disabled{background:#9ca3af;cursor:not-allowed;opacity:.5}@media (max-width: 768px){.mesero-chat-container{height:65vh;max-width:100%}}@media (prefers-color-scheme: dark){.mesero-chat-container .chat-header h3{color:#f9fafb}.mesero-chat-container .chat-input{color:#f9fafb;background:#ffffff1a}}.checkin-container{max-width:100%;margin:0 auto;padding:0 1.5rem 1rem;background:var(--bg-primary);color:var(--text-primary);min-height:auto;font-family:Segoe UI,system-ui,sans-serif;line-height:1.6;display:flex;flex-direction:column;justify-content:flex-start}.checkin-container h1{color:var(--text-secondary);text-align:center;margin-bottom:2rem;font-weight:600;font-size:1.8rem;letter-spacing:-.5px}.checkin-container h2,.checkin-container h3,.checkin-container h4{margin:0 0 1rem;font-weight:600;color:var(--text-secondary)}.header-image{width:100%;height:auto;display:block;max-height:300px;object-fit:cover}.clientes-section{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000004d}.clientes-section h3{color:var(--accent-color);margin:0 0 1rem;font-size:1.2rem;font-weight:500}.action-button{background:var(--accent-color);color:var(--text-on-accent);border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);text-align:center;box-shadow:0 2px 4px #0003}.action-button:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.action-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.success-action-button{background:var(--success-color);color:var(--bg-primary);border:none;padding:1rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);text-align:center;box-shadow:0 2px 4px #0003;width:100%}.success-action-button:hover{background:#23e0cf;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.loading-message{color:var(--success-color);text-align:center;font-style:italic;font-size:1.1rem}.estado-badge{padding:4px 10px;border-radius:16px;font-size:.85rem;font-weight:600;text-transform:capitalize;display:inline-block}.estado-badge.confirmada{background-color:#166534;color:#fff}.faq-container{background:var(--bg-tertiary);padding:1.5rem;border-radius:8px;margin-bottom:1.5rem;text-align:left}.faq-title{margin:0 0 1rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:.5rem}.faq-list{list-style:none;padding:0;margin:0}.faq-item{display:flex;align-items:flex-start;padding:.75rem 0;border-bottom:1px solid var(--border-color);color:var(--text-secondary)}.faq-item:last-child{border-bottom:none}.faq-item:first-child{padding-top:0}.faq-icon{color:var(--accent-color);margin-right:.75rem;font-size:1.1rem;margin-top:2px;flex-shrink:0}.faq-text{font-size:.95rem;line-height:1.5}.manual-code-input-container{display:flex;flex-direction:column;gap:10px;margin-top:1rem}.manual-code-input-wrapper{position:relative;display:flex;align-items:center;width:100%}.manual-code-input{width:100%;padding:.75rem 3rem .75rem .75rem;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-size:1rem;box-sizing:border-box}.camera-button-inside{position:absolute;right:.5rem;top:50%;transform:translateY(-50%);background:transparent;border:none;color:#00d4ff;font-size:1.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:.25rem;border-radius:4px;transition:all .2s ease;z-index:2}.camera-button-inside:hover:not(:disabled){background:#00d4ff1a;color:#0ff}.camera-button-inside:disabled{opacity:.4;cursor:not-allowed}.verify-button{margin:0;width:100%}@media (max-width: 768px){.checkin-container{padding:0 1rem .5rem}.checkin-container h1{font-size:1.5rem;margin-bottom:1rem}}.tickets-list-checkin{display:flex;flex-direction:column;gap:.75rem}.ticket-item-checkin{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-primary);border-radius:8px;border:1px solid var(--border-color);gap:1rem}.ticket-info-checkin{display:flex;align-items:center;gap:.75rem;flex:1}.ticket-icon-checkin{color:var(--accent-color);font-size:1.2rem;flex-shrink:0}.ticket-details-checkin{display:flex;flex-direction:column;gap:.25rem}.ticket-localidad{font-weight:600;color:var(--text-primary);font-size:.95rem}.ticket-sector{font-size:.85rem;color:var(--text-secondary)}.ticket-actions-checkin{flex-shrink:0}.checkin-button{background:var(--success-color);color:var(--bg-primary);border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap}.checkin-button:hover{background:#23e0cf;transform:translateY(-1px);box-shadow:0 2px 4px #0003}.checkin-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.checkin-finalizado-message{color:#dc3545;font-weight:600;font-size:.9rem;white-space:nowrap}@media (max-width: 768px){.ticket-item-checkin{flex-direction:column;align-items:flex-start;gap:.5rem}.ticket-actions-checkin{width:100%}.checkin-button{width:100%;text-align:center}.checkin-finalizado-message{text-align:center;display:block;width:100%}}.programar-qr-popup{background-color:#fff;padding:25px;border-radius:12px;width:500px;max-width:90vw;text-align:center;box-shadow:0 10px 25px #0003;position:relative;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.programar-qr-header h3{margin:0 0 20px;color:#2c3e50;font-size:1.5rem;font-weight:600;border-bottom:1px solid #eee;padding-bottom:15px}.programar-qr-error{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb;padding:12px;border-radius:6px;margin-bottom:20px;font-size:.9rem;text-align:left;display:flex;align-items:center}.programar-qr-error:before{content:"⚠️";margin-right:10px}.date-selection-container{margin:20px 0;text-align:left;background-color:#f8f9fa;padding:20px;border-radius:8px;border:1px solid #e9ecef}.date-selection-label{display:block;margin-bottom:10px;font-weight:600;color:#495057;font-size:1rem}.date-input{padding:12px 15px;border:2px solid #dee2e6;border-radius:8px;font-size:16px;width:100%;box-sizing:border-box;transition:all .2s ease;color:#495057;background-color:#fff;cursor:pointer}.date-input:focus{border-color:#2196f3;outline:none;box-shadow:0 0 0 4px #2196f326}.date-input:hover{border-color:#adb5bd}.selected-date-display{margin-top:12px;color:#2196f3;font-size:.95rem;font-weight:500;display:flex;align-items:center}.selected-date-display:before{content:"📅";margin-right:8px}.programar-qr-actions{display:flex;justify-content:center;gap:15px;margin-top:25px;padding-top:20px;border-top:1px solid #eee}.programar-qr-btn{padding:12px 24px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;min-width:120px;box-shadow:0 2px 4px #0000001a}.programar-qr-btn:active{transform:translateY(1px);box-shadow:0 1px 2px #0000001a}.btn-generate{background-color:#2196f3;color:#fff}.btn-generate:hover{background-color:#1976d2;box-shadow:0 4px 8px #2196f34d}.btn-generate:disabled{background-color:#90caf9;cursor:not-allowed;box-shadow:none}.btn-cancel{background-color:#6c757d;color:#fff}.btn-cancel:hover{background-color:#5a6268;box-shadow:0 4px 8px #6c757d4d}.btn-print{background-color:#28a745;color:#fff}.btn-print:hover{background-color:#218838;box-shadow:0 4px 8px #28a7454d}.btn-back{background-color:#6c757d;color:#fff}.btn-back:hover{background-color:#5a6268}.btn-close{background-color:#dc3545;color:#fff}.btn-close:hover{background-color:#c82333;box-shadow:0 4px 8px #dc35454d}.qr-preview-container{background-color:#fff;padding:10px}.qr-header{text-align:center;margin-bottom:15px;padding-bottom:15px;border-bottom:2px solid #333}.qr-header h1{font-size:20px;font-weight:800;margin:0 0 8px;color:#000;text-transform:uppercase;letter-spacing:.5px}.qr-date-info{font-size:14px;margin:5px 0;color:#333;font-weight:600}.wifi-box{margin:15px 0;padding:10px;background-color:#f8f9fa;border:1px dashed #333;border-radius:6px;font-size:12px}.wifi-title{margin:0 0 5px;font-weight:800;text-transform:uppercase}.wifi-details{margin:0;font-family:monospace;font-size:13px}.qr-instruction{font-size:14px;margin:10px 0 0;color:#555;font-style:italic}.qr-code-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px 0}.qr-code-frame{padding:15px;background-color:#fff;border-radius:12px;border:2px solid #000;display:inline-block}.qr-info-mesa{font-size:18px;font-weight:800;margin:15px 0 5px;color:#000;text-transform:uppercase}.qr-url-text{font-size:11px;color:#666;word-break:break-all;max-width:250px;margin:0 auto;font-family:monospace}.qr-footer{text-align:center;margin-top:15px;padding-top:15px;border-top:2px solid #333}.qr-footer p{font-size:14px;font-weight:700;color:#000;margin:0;text-transform:uppercase}.pedido-card .toggle-pedidos-btn{background-color:#007bff;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.9em;margin:8px 0;transition:background-color .2s;display:flex;align-items:center;justify-content:center;width:100%}.pedido-card .toggle-pedidos-btn:hover{background-color:#0056b3}.pedido-card .toggle-pedidos-btn.hidden{display:none}.pedido-card .pedidos-antiguos{max-height:0;overflow:hidden;transition:max-height .3s ease-out;opacity:.7}.pedido-card .pedidos-antiguos.expanded{max-height:1000px}.pedido-card .pedidos-antiguos .pedido-card{border-left:3px solid #666;margin-top:8px;padding-left:8px;background-color:#f8f9fa}.pedido-card .pedidos-antiguos .pedido-card:hover{background-color:#e9ecef}.status-popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1100}.status-popup-content{background-color:#fff;padding:24px;border-radius:16px;width:90%;max-width:400px;box-shadow:0 4px 20px #0003;animation:slideUp .3s ease-out}.status-popup-title{margin-top:0;margin-bottom:8px;text-align:center;color:#333}.status-popup-subtitle{text-align:center;color:#666;margin-bottom:24px;font-size:1.1em}.status-popup-actions{display:flex;flex-direction:column;gap:12px}.btn-mark-servido{padding:16px;background-color:#3c3;color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 6px #33cc334d}.btn-mark-atendido{padding:16px;background-color:#f90;color:#fff;border:none;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 4px 6px #ff99004d}.btn-cancel-status{padding:14px;background-color:#f5f5f5;color:#555;border:none;border-radius:12px;font-size:16px;margin-top:8px;cursor:pointer;font-weight:500}.status-badge-button{border:none;cursor:pointer;font-size:inherit;font-family:inherit;box-shadow:0 2px 4px #0000001a;transition:transform .1s;display:inline-flex;align-items:center;gap:6px}.status-badge-button:active{transform:scale(.95)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.selection-checkbox.disabled{cursor:not-allowed;opacity:.5;background-color:#ccc}input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}@keyframes blink{0%{opacity:1}50%{opacity:.3}to{opacity:1}}.closed-orders-summary-container{margin-bottom:15px;width:100%}.closed-orders-list{width:100%;border:1px solid #ddd;border-radius:8px;padding:15px;background-color:#f9f9f9;overflow-y:visible;box-sizing:border-box;overflow-x:hidden}.pedido-detail{border:1px solid #ddd;border-radius:6px;padding:15px;margin-bottom:15px;background-color:#fff;box-shadow:0 2px 4px #0000001a}.pedido-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #eee}.pedido-header h4{margin:0;font-size:1.1em;color:#333}.pedido-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.pedido-info-grid div{font-size:.9em}.estado-badge.cerrada{background-color:#666;color:#fff;padding:2px 6px;border-radius:3px;font-size:.8em}.pedido-items-section{margin-top:10px}.pedido-items-list{list-style:none;padding:0;margin:10px 0;width:100%;box-sizing:border-box;overflow-x:hidden;max-height:none;overflow-y:visible}.pedido-item{margin-bottom:10px;padding:10px;border-bottom:1px solid #eee;background-color:#f8f8f8;border-radius:4px;width:100%;box-sizing:border-box;overflow-x:hidden}.item-content{display:flex;justify-content:space-between;align-items:center;width:100%;box-sizing:border-box;overflow-x:hidden}.item-details{display:flex;justify-content:space-between;width:100%;box-sizing:border-box;overflow-x:hidden;flex-wrap:wrap}.item-name{font-weight:700;color:#333;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:10px}.item-price{color:#666;font-weight:700;flex-shrink:0;min-width:fit-content}.item-name{font-weight:700;color:#333}.item-price{color:#666;font-weight:700}.extras-container{margin-left:15px;margin-top:5px}.extras-list{list-style:none;padding:0;margin:5px 0}.extras-list li{font-size:.9em;color:#666;margin-bottom:2px}.extra-name{font-style:italic}.extra-price{font-weight:700;color:#888}@media (max-width: 768px){.pedido-info-grid{grid-template-columns:1fr;gap:5px}.closed-orders-list,.pedido-detail{padding:10px}}.grand-total-container{display:flex;justify-content:space-between;align-items:center;background-color:#333;color:#fff;padding:15px 20px;border-radius:8px;margin-top:20px;box-shadow:0 4px 6px #0000001a;border:1px solid #222}.grand-total-label{font-size:1.2em;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.grand-total-amount{font-size:1.4em;font-weight:800;color:#4caf50;text-shadow:0 1px 2px rgba(0,0,0,.3)}.categoria-container{background-color:#e6e6e6;padding:25px;border-radius:12px;max-width:1000px;max-height:90vh;margin:20px auto;box-shadow:0 4px 12px #00000026;color:#212529;overflow-y:auto}.categoria-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.categoria-header h2{margin:0;font-size:1.5em;color:#0369a1}.categoria-buttons{display:flex;gap:10px}.categoria-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:20px;padding:20px;margin:0 auto;max-width:1000px}@media (max-width: 768px){.categoria-grid{grid-template-columns:1fr;gap:15px;padding:15px}}.categoria-card{position:relative;border-radius:12px;padding:20px;cursor:pointer;box-shadow:0 4px 8px #0000001a;transition:transform .2s ease,box-shadow .2s ease;background-color:#fff;border:1px solid #e2e8f0;height:fit-content;min-height:180px}.categoria-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #00000026}.categoria-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid rgba(0,0,0,.1)}.categoria-card-header h3{margin:0;font-size:1.1em;color:#1e293b;font-weight:600}.status{padding:4px 8px;border-radius:12px;font-size:.8em;font-weight:700;color:#fff}.status.active{background-color:#4caf50}.status.inactive{background-color:#f44336}.categoria-card-body{display:flex;flex-direction:column;gap:8px}.categoria-info{display:flex;justify-content:space-between;align-items:center;font-size:.9em;padding:4px 0}.categoria-info:not(:last-child){border-bottom:1px solid #f1f5f9}.categoria-info .info-label{font-weight:600;color:#64748b;min-width:80px}.categoria-info .info-value{color:#334155;text-align:right;flex:1}.categoria-actions{display:flex;gap:8px;margin-top:12px;justify-content:flex-end}.categoria-actions button{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.8em;font-weight:500;transition:background-color .2s}.categoria-actions button.edit-btn{background-color:#2196f3;color:#fff}.categoria-actions button.edit-btn:hover{background-color:#1976d2}.categoria-actions button.delete-btn{background-color:#f44336;color:#fff}.categoria-actions button.delete-btn:hover{background-color:#d32f2f}.categoria-editor-popup{background-color:#e6e6e6;padding:25px;border-radius:12px;max-width:500px;max-height:90vh;margin:0 auto;box-shadow:0 4px 12px #00000026;color:#212529;overflow-y:auto}.categoria-editor-popup h2{margin-top:0;color:#212529;margin-bottom:20px}.categoria-editor-popup .form-group{background-color:#fff;padding:15px;border-radius:8px;margin-bottom:12px;box-shadow:0 1px 4px #0000000d}.categoria-editor-popup .form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151}.categoria-editor-popup .form-group input[type=checkbox]{width:auto;margin-right:8px}.categoria-editor-popup .form-group label[for]{display:block;margin-bottom:8px;font-weight:600;color:#374151}.categoria-editor-popup .form-group label:has(input[type=checkbox]){display:flex;align-items:center;margin-bottom:0;cursor:pointer}.categoria-editor-popup .form-group input,.categoria-editor-popup .form-group textarea{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;font-size:14px;box-sizing:border-box}.categoria-editor-popup .form-group textarea{resize:vertical;min-height:60px;overflow-wrap:break-word}.categoria-editor-popup .form-group input:focus,.categoria-editor-popup .form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.categoria-editor-popup .form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.categoria-editor-popup .form-actions button{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s;min-width:80px}.categoria-editor-popup .form-actions button[type=button]{background-color:#6c757d;color:#fff}.categoria-editor-popup .form-actions button[type=button]:hover{background-color:#5a6268}.categoria-editor-popup .form-actions button[type=submit]{background-color:#0d6efd;color:#fff}.categoria-editor-popup .form-actions button[type=submit]:hover{background-color:#0b5ed7}.categoria-editor-popup .form-actions button:disabled{opacity:.6;cursor:not-allowed}.categoria-editor-popup .form-actions button.delete-btn{background-color:#dc3545;color:#fff}.categoria-editor-popup .form-actions button.delete-btn:hover{background-color:#bb2d3b}.icon-selector{display:flex;gap:10px;margin-top:5px}.icon-option{display:flex;flex-direction:column;align-items:center;padding:10px;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .3s ease;min-width:80px}.icon-option:hover{border-color:#06c}.icon-option.selected{border-color:#06c;background-color:#e6f2ff}.icon-option svg{font-size:24px;margin-bottom:5px;color:#666}.icon-option.selected svg{color:#06c}.icon-option span{font-size:12px;color:#666}.categoria-card-icon{font-size:24px;margin-right:10px;color:#666}.categoria-card-header{display:flex;align-items:center;margin-bottom:10px}.categoria-card-header h3{margin:0;display:flex;align-items:center}.order-buttons{display:flex;gap:5px;margin-right:10px}.arrow-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s ease}.arrow-btn:hover:not(:disabled){background:#f0f0f0;border-color:#06c}.arrow-btn:disabled{opacity:.5;cursor:not-allowed}.categoria-card{transition:box-shadow .2s ease}.categoria-card:hover{box-shadow:0 2px 4px #0000001a}.categoria-actions{display:flex;align-items:center;gap:10px;margin-top:10px}.sector-container{background-color:#e6e6e6;padding:25px;border-radius:12px;max-width:1000px;margin:20px auto;box-shadow:0 4px 12px #00000026;color:#212529}.sector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sector-header h2{margin:0;font-size:1.5em;color:#0369a1}.sector-buttons{display:flex;gap:10px}.sector-grid{display:grid;grid-template-columns:repeat(2,minmax(250px,1fr));gap:16px}@media (max-width: 768px){.sector-grid{grid-template-columns:1fr}}.sector-card{position:relative;border-radius:10px;padding:16px;cursor:pointer;box-shadow:0 2px 6px #0000001a;transition:transform .2s ease,box-shadow .2s ease;background-color:#fff;border:1px solid #e2e8f0}.sector-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #00000026}.sector-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid rgba(0,0,0,.1)}.sector-card-header h3{margin:0;font-size:1.1em;color:#1e293b;font-weight:600}.sector-card-body{display:flex;flex-direction:column;gap:8px}.sector-info{display:flex;justify-content:space-between;align-items:center;font-size:.9em;padding:4px 0}.sector-info:not(:last-child){border-bottom:1px solid #f1f5f9}.sector-info .info-label{font-weight:600;color:#64748b;min-width:80px}.sector-info .info-value{color:#334155;text-align:right;flex:1}.sector-color-preview{display:inline-block;width:24px;height:24px;border-radius:4px;border:1px solid #cbd5e1;margin-left:8px}.sector-editor-popup{background-color:#e6e6e6;padding:25px;border-radius:12px;max-width:600px;margin:0 auto;box-shadow:0 4px 12px #00000026;color:#212529}.sector-editor-popup h2{margin-top:0;color:#212529;margin-bottom:20px}.sector-editor-popup .form-group{background-color:#fff;padding:20px;border-radius:8px;margin-bottom:12px;box-shadow:0 1px 4px #0000000d}.sector-editor-popup .form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151}.sector-editor-popup .form-group input,.sector-editor-popup .form-group textarea{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:6px;background-color:#fff;font-size:14px}.sector-editor-popup .form-group input:focus,.sector-editor-popup .form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sector-editor-popup .color-input-group{display:flex;align-items:center;gap:12px}.sector-editor-popup .color-input-group input[type=color]{width:50px;height:50px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer}.sector-editor-popup .form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.sector-editor-popup .form-actions button{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s;min-width:80px}.sector-editor-popup .form-actions button[type=button]{background-color:#6c757d;color:#fff}.sector-editor-popup .form-actions button[type=button]:hover{background-color:#5a6268}.sector-editor-popup .form-actions button[type=submit]{background-color:#0d6efd;color:#fff}.sector-editor-popup .form-actions button[type=submit]:hover{background-color:#0b5ed7}.sector-editor-popup .form-actions button:disabled{opacity:.6;cursor:not-allowed}.sector-editor-popup .form-actions button.delete-btn{background-color:#dc3545;color:#fff}.sector-editor-popup .form-actions button.delete-btn:hover{background-color:#bb2d3b}.sector-editor-popup .form-row{display:flex;gap:15px;margin-bottom:12px}.sector-editor-popup .form-row:last-child{margin-bottom:0}.sector-editor-popup .form-col{flex:1;min-width:0}.sector-editor-popup .form-col label{display:block;margin-bottom:6px;font-size:14px;font-weight:600;color:#374151}.sector-editor-popup .form-col input[type=number]{width:70px;padding:8px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.sector-editor-popup .form-col input[type=number]:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sector-editor-popup .form-col input:not([type=number]):not([type=color]),.sector-editor-popup .form-col select{width:100%;padding:8px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}.sector-editor-popup .form-col input:not([type=number]):not([type=color]):focus,.sector-editor-popup .form-col select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.sector-editor-popup .form-col input,.sector-editor-popup .form-col select{box-sizing:border-box}:root{--plomo: #6c757d;--plomo-light: #8a9aab;--plomo-dark: #495057;--naranja: #fd7e14;--naranja-light: #ffc078;--naranja-dark: #e8590c;--verde: #28a745;--verde-light: #69db7c;--verde-dark: #1e7e34;--rojo: #dc3545;--rojo-light: #ffa8a8;--rojo-dark: #c92a2a;--bg-primary: #f8f9fa;--bg-card: #ffffff;--text-primary: #212529;--text-secondary: #6c757d;--border-color: #dee2e6;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--transition: all .2s ease-in-out}.evento-container{padding:20px;background-color:var(--bg-primary);min-height:100%}.evento-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border-color);flex-wrap:wrap;gap:15px}.evento-header h2{margin:0;color:var(--text-primary);font-size:1.75rem;font-weight:600}.evento-buttons{display:flex;gap:10px;flex-wrap:wrap}.btn-new{padding:10px 20px;border:none;border-radius:6px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.btn-new:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-new:active{transform:translateY(0)}.btn-new.inactive{opacity:.5;filter:grayscale(30%)}.btn-new.btn-reset{padding:10px 14px;display:flex;align-items:center;justify-content:center}.btn-new.btn-reset:hover{background-color:#0056b3!important}.evento-list{display:flex;flex-direction:column;gap:15px}.evento-card{background-color:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);overflow:hidden;transition:var(--transition)}.evento-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.evento-card.estado-detenido{border-left:4px solid var(--plomo)}.evento-card.estado-venta{border-left:4px solid var(--naranja)}.evento-card.estado-checkin{border-left:4px solid var(--verde)}.evento-card.estado-finalizado{border-left:4px solid var(--rojo)}.evento-card.estado-detenido .evento-card-header{background-color:#e9ecef;border-bottom-color:var(--plomo)}.evento-card.estado-detenido .evento-card-header h3,.evento-card.estado-detenido .evento-card-header .evento-elenco span{color:var(--plomo-dark)}.evento-card.estado-venta .evento-card-header{background-color:#fff3cd;border-bottom-color:var(--naranja)}.evento-card.estado-venta .evento-card-header h3,.evento-card.estado-venta .evento-card-header .evento-elenco span{color:var(--naranja-dark)}.evento-card.estado-checkin .evento-card-header{background-color:#d4edda;border-bottom-color:var(--verde)}.evento-card.estado-checkin .evento-card-header h3,.evento-card.estado-checkin .evento-card-header .evento-elenco span{color:var(--verde-dark)}.evento-card.estado-finalizado .evento-card-header{background-color:#f8d7da;border-bottom-color:var(--rojo)}.evento-card.estado-finalizado .evento-card-header h3,.evento-card.estado-finalizado .evento-card-header .evento-elenco span{color:var(--rojo-dark)}.evento-card-header{padding:12px 20px;border-bottom:3px solid transparent;background-color:#fafbfc;transition:var(--transition)}.evento-info-principal{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.evento-info-principal h3{margin:0;color:var(--text-primary);font-size:1.25rem;font-weight:600}.evento-elenco{display:flex;gap:8px;color:var(--text-secondary);font-size:14px}.evento-card-body{padding:20px}.evento-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.evento-detail{display:flex;flex-direction:column;gap:4px}.info-label{color:var(--text-secondary);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.evento-detail span:not(.info-label){color:var(--text-primary);font-size:14px;font-weight:500}.fecha-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border:2px solid transparent;height:20px;line-height:1;margin-top:-2px}.fecha-badge.estado-detenido{background-color:#e9ecef;border-color:var(--plomo);color:var(--plomo-dark)}.fecha-badge.estado-venta{background-color:#fff3cd;border-color:var(--naranja);color:var(--naranja-dark)}.fecha-badge.estado-checkin{background-color:#d4edda;border-color:var(--verde);color:var(--verde-dark)}.fecha-badge.estado-finalizado{background-color:#f8d7da;border-color:var(--rojo);color:var(--rojo-dark)}.estado-badge.detenido{background-color:var(--plomo)}.estado-badge.venta{background-color:var(--naranja)}.estado-badge.checkin{background-color:var(--verde)}.estado-badge.finalizado{background-color:var(--rojo)}.evento-empty{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px}@media (max-width: 768px){.evento-header{flex-direction:column;align-items:stretch}.evento-header h2{text-align:center}.evento-buttons{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:5px;width:100%}.evento-buttons::-webkit-scrollbar{display:none}.evento-buttons .btn-new{flex:0 0 auto;padding:8px 12px;font-size:12px;white-space:nowrap}.evento-buttons .btn-new.btn-reset{padding:8px 10px}.evento-info-principal{flex-direction:column;align-items:flex-start}.evento-details{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.evento-container{padding:15px}.evento-buttons{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;gap:6px}.evento-buttons::-webkit-scrollbar{display:none}.evento-buttons .btn-new{flex:0 0 auto;padding:6px 10px;font-size:11px;white-space:nowrap}.evento-buttons .btn-new.btn-reset{padding:6px 8px}.evento-details{grid-template-columns:1fr}}.evento-card{animation:fadeIn .3s ease-in-out}.evento-card:hover .estado-badge{transform:scale(1.05)}.estado-badge{transition:var(--transition)}.evento-card.evento-editable{cursor:pointer}.evento-card.evento-editable:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-3px);border-color:var(--plomo-light)}.evento-card.evento-editable .evento-card-header:after{content:"✎ Editar";font-size:12px;color:var(--plomo);background-color:#e9ecef;padding:4px 8px;border-radius:4px;opacity:0;transition:var(--transition)}.evento-card.evento-editable:hover .evento-card-header:after{opacity:1}.evento-card.evento-editable .evento-info-principal h3{padding-right:10px}.evento-estado-controls{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.estado-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:6px;cursor:pointer;transition:var(--transition);font-size:14px;color:#fff;box-shadow:var(--shadow-sm)}.estado-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.estado-btn:active{transform:translateY(0)}.estado-btn-venta{background-color:var(--naranja)}.estado-btn-venta:hover{background-color:var(--naranja-dark)}.estado-btn-play{background-color:var(--verde)}.estado-btn-play:hover{background-color:var(--verde-dark)}.estado-btn-pausa{background-color:#ffc107;color:#212529}.estado-btn-pausa:hover{background-color:#e0a800}.estado-btn-pausa-checkin{background-color:var(--verde);color:#fff}.estado-btn-pausa-checkin:hover{background-color:var(--verde-dark)}.estado-btn-stop{background-color:var(--rojo)}.estado-btn-stop:hover{background-color:var(--rojo-dark)}select:disabled{background-color:#e9ecef;cursor:not-allowed}textarea:disabled{background-color:#e9ecef;cursor:not-allowed}@keyframes autoBlink{0%,to{opacity:1;box-shadow:0 0 #3b82f6b3}50%{opacity:.6;box-shadow:0 0 20px 5px #3b82f6e6}}.auto-blink{animation:autoBlink .8s ease-in-out infinite}.auto-indicator{position:relative}.auto-indicator:after{content:"";position:absolute;top:-2px;right:-2px;width:8px;height:8px;background-color:#10b981;border-radius:50%;border:2px solid white;box-shadow:0 0 5px #10b981cc}.auto-indicator.auto-blink:after{animation:autoBlink .8s ease-in-out infinite}.pagination-container{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 0;border-top:1px solid #e0e0e0;margin-top:20px}.pagination-info{font-size:14px;color:#666}.pagination-controls{display:flex;gap:6px;align-items:center}.pagination-btn{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 12px;border:1px solid #ddd;background:#fff;color:#333;font-size:14px;cursor:pointer;border-radius:6px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#f5f5f5;border-color:#bbb}.pagination-btn.active{background:#007bff;color:#fff;border-color:#007bff}.pagination-btn svg{width:16px;height:16px}@media (max-width: 576px){.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-btn{min-width:40px;height:40px}}.popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.popup-overlay.secondary-overlay{z-index:1100}.evento-categoria-popup{background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;min-width:0}.popup-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background-color:#f8f9fa;border-bottom:1px solid #dee2e6}.popup-header h2{margin:0;font-size:1.5rem;color:#212529;font-weight:600}.btn-close{background:none;border:none;font-size:1.25rem;color:#6c757d;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.btn-close:hover{background-color:#e9ecef;color:#dc3545}.evento-categoria-popup-content{padding:24px;overflow-y:auto;width:auto;box-sizing:border-box;min-width:0}.categoria-actions-header{margin-bottom:20px}.btn-new-categoria{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background-color:#28a745;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-new-categoria:hover:not(:disabled){background-color:#218838;transform:translateY(-1px);box-shadow:0 4px 8px #28a7454d}.btn-new-categoria:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.categoria-form-container{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin-bottom:24px}.categoria-form-container h3{margin:0 0 16px;font-size:1.1rem;color:#495057}.form-row{display:flex;gap:16px;margin-bottom:16px}.form-group{flex:1}.form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#495057}.form-group input{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 3px #007bff26}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.btn-cancel{padding:10px 20px;background-color:#6c757d;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-cancel:hover{background-color:#5a6268}.btn-save{padding:10px 24px;background-color:#007bff;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-save:hover:not(:disabled){background-color:#0056b3}.btn-save:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.categorias-list h3{margin:0 0 16px;font-size:1.1rem;color:#495057}.loading-text,.empty-text{text-align:center;padding:40px;color:#6c757d;font-size:14px}.categorias-por-tipo{display:flex;flex-direction:column;gap:24px}.categoria-tipo-section{background-color:#f8f9fa;border-radius:8px;padding:16px;border:1px solid #dee2e6}.tipo-header{margin:0 0 12px;padding-bottom:8px;border-bottom:2px solid}.tipo-badge{display:inline-block;padding:4px 12px;border-radius:4px;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.tipo-header.tipo-base{border-bottom-color:#28a745}.tipo-header.tipo-base .tipo-badge{background-color:#28a745;color:#fff}.tipo-header.tipo-fee{border-bottom-color:#fd7e14}.tipo-header.tipo-fee .tipo-badge{background-color:#fd7e14;color:#fff}.tipo-header.tipo-promo{border-bottom-color:#6f42c1}.tipo-header.tipo-promo .tipo-badge{background-color:#6f42c1;color:#fff}.empty-tipo{text-align:center;padding:20px;color:#6c757d;font-size:14px;font-style:italic}.categorias-grid{display:flex;flex-direction:column;gap:8px}.evento-categoria-card{background-color:#fff;border:1px solid #dee2e6;border-radius:8px;padding:10px 16px;display:grid;grid-template-columns:2fr 1fr 1.2fr 1.5fr auto;align-items:center;gap:12px;transition:all .2s ease}.evento-categoria-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.evento-categoria-card.en-uso{border-left:4px solid #fd7e14}.evento-categoria-card.en-evento-activo{border-left:4px solid #dc3545}.evento-categoria-card.en-uso:not(.en-evento-activo){border-left:4px solid #17a2b8}.evento-categoria-card.tipo-fee-card{border-left:4px solid #fd7e14}.evento-categoria-card.tipo-promo-card{border-left:4px solid #6f42c1}.categoria-nombre{margin:0;font-size:.95rem;color:#212529;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.precio{font-size:.95rem;color:#28a745;font-weight:600;text-align:left}.evento-categoria-card.tipo-fee-card .precio{color:#fd7e14}.evento-categoria-card.tipo-promo-card .precio{color:#6f42c1}.uso-indicator,.evento-activo-indicator{display:flex;align-items:center}.badge-uso{display:inline-block;padding:3px 8px;background-color:#17a2b8;color:#fff;font-size:11px;border-radius:4px;font-weight:500;white-space:nowrap}.badge-evento-activo{display:inline-block;padding:3px 8px;background-color:#dc3545;color:#fff;font-size:11px;border-radius:4px;font-weight:500;white-space:nowrap}.form-group select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box;background-color:#fff;cursor:pointer}.form-group select:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 3px #007bff26}.form-group select:disabled{background-color:#e9ecef;cursor:not-allowed}.categoria-actions{display:flex;gap:8px;justify-content:flex-end}.btn-edit,.btn-delete{width:36px;height:36px;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:14px}.btn-edit{background-color:#ffc107;color:#212529}.btn-edit:hover:not(:disabled){background-color:#e0a800}.btn-edit:disabled{background-color:#e9ecef;color:#adb5bd;cursor:not-allowed}.btn-delete{background-color:#dc3545;color:#fff}.btn-delete:hover:not(:disabled){background-color:#c82333}.btn-delete:disabled{background-color:#e9ecef;color:#adb5bd;cursor:not-allowed}.confirm-dialog,.warning-dialog{background-color:#fff;border-radius:12px;padding:24px;max-width:500px;width:90%;box-shadow:0 10px 40px #0003}.confirm-dialog h3,.warning-dialog h3{margin:0 0 16px;font-size:1.25rem;color:#212529}.confirm-dialog p,.warning-dialog p{margin:0 0 12px;color:#495057;line-height:1.5}.warning-text{color:#dc3545!important;font-weight:500}.info-text{color:#6c757d!important;font-size:14px;font-style:italic}.uso-list{background-color:#f8f9fa;border-radius:8px;padding:16px;margin:16px 0;max-height:200px;overflow-y:auto}.uso-item{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #dee2e6}.uso-item:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.uso-item strong{display:block;color:#212529;margin-bottom:4px}.sala-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sala-header strong{margin-bottom:0}.uso-item ul{margin:4px 0 0;padding-left:20px}.uso-item li{color:#6c757d;font-size:14px}.estado-badge-small{display:inline-block;padding:2px 6px;font-size:11px;border-radius:4px;font-weight:500;margin-left:8px}.estado-badge-small.venta{background-color:#fd7e14;color:#fff}.estado-badge-small.checkin{background-color:#28a745;color:#fff}.estado-badge-small.detenido{background-color:#6c757d;color:#fff}.estado-badge-small.finalizado{background-color:#17a2b8;color:#fff}.dialog-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.btn-delete-confirm{padding:10px 20px;background-color:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-delete-confirm:hover:not(:disabled){background-color:#c82333}.btn-delete-confirm:disabled{background-color:#6c757d;cursor:not-allowed;opacity:.6}.btn-ok{padding:10px 24px;background-color:#007bff;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-ok:hover{background-color:#0056b3}.uso-tooltip-container{position:relative;display:inline-block}.uso-tooltip-container:hover .uso-tooltip{display:block}.uso-tooltip{display:none;position:absolute;bottom:100%;left:50%;transform:translate(-50%);background-color:#fff;border:1px solid #dee2e6;border-radius:8px;padding:12px;min-width:280px;max-width:350px;box-shadow:0 8px 24px #00000026;z-index:100;margin-bottom:8px}.uso-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border-width:6px;border-style:solid;border-color:#ffffff transparent transparent transparent}.tooltip-evento{padding:8px;border-bottom:1px solid #dee2e6;margin-bottom:8px}.tooltip-evento:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.tooltip-evento strong{display:block;color:#212529;font-size:13px;margin-bottom:4px}.tooltip-sala{display:block;color:#6c757d;font-size:12px;margin-bottom:2px}.tooltip-fecha{display:block;color:#495057;font-size:12px;margin-bottom:4px}.tooltip-estado{display:inline-block;padding:2px 6px;font-size:10px;border-radius:3px;font-weight:500}.tooltip-estado.venta{background-color:#fd7e14;color:#fff}.tooltip-estado.checkin{background-color:#28a745;color:#fff}@media (max-width: 768px){.evento-categoria-popup{max-width:100%;max-height:100vh;border-radius:0}.form-row{flex-direction:column;gap:12px}.categorias-grid{flex-direction:column}.evento-categoria-popup-content{padding:16px}}.btn-toggle-activo{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-toggle-activo.activo{color:#28a745}.btn-toggle-activo.inactivo{color:#6c757d}.btn-toggle-activo:hover{transform:scale(1.1)}.categoria-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.categoria-header .categoria-nombre{flex:1}.evento-categoria-card.inactiva{opacity:.6;background-color:#f8f9fa}.evento-categoria-card.inactiva .categoria-nombre{color:#6c757d;text-decoration:line-through}.tipo-header.tipo-cortesia{border-bottom-color:#e91e63}.tipo-header.tipo-cortesia .tipo-badge{background-color:#e91e63;color:#fff}.evento-categoria-card.tipo-cortesia-card{border-left:4px solid #e91e63}.empty-cortesia{text-align:center;padding:20px}.btn-create-cortesia{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background-color:#e91e63;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:12px}.btn-create-cortesia:hover{background-color:#c2185b;transform:translateY(-1px);box-shadow:0 4px 8px #e91e634d}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500;color:#495057}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.detalles-modal{background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.detalles-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background-color:#f8f9fa;border-bottom:1px solid #dee2e6}.detalles-modal-header h3{margin:0;font-size:1.25rem;color:#212529;font-weight:600}.detalles-modal-content{padding:24px;overflow-y:auto;flex:1}.detalles-info{margin:0 0 20px;color:#6c757d;font-size:14px}.categorias-base-list{display:flex;flex-direction:column;gap:8px}.categoria-base-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;transition:all .2s ease}.categoria-base-item.asignado,.categoria-base-item.asignado.activo{background-color:#e8f5e9;border-color:#4caf50}.categoria-base-item.asignado:not(.activo){background-color:#ffebee;border-color:#ef5350;opacity:.7}.categoria-base-info{display:flex;flex-direction:column;gap:4px}.categoria-base-nombre{font-weight:600;color:#212529;font-size:14px}.categoria-base-precio{color:#28a745;font-size:13px;font-weight:500}.categoria-base-actions{display:flex;align-items:center;gap:8px}.btn-toggle-detalle{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.btn-toggle-detalle.activo{color:#28a745}.btn-toggle-detalle.inactivo{color:#ef5350}.btn-add{width:32px;height:32px;background-color:#28a745;color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:14px}.btn-add:hover{background-color:#218838;transform:scale(1.05)}.btn-remove{width:32px;height:32px;background-color:#dc3545;color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:14px}.btn-remove:hover{background-color:#c82333;transform:scale(1.05)}.detalles-modal-footer{padding:16px 24px;background-color:#f8f9fa;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end}.form-modal{background-color:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.form-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;background-color:#f8f9fa;border-bottom:1px solid #dee2e6}.form-modal-header h3{margin:0;font-size:1.25rem;color:#212529;font-weight:600}.form-modal-content{padding:24px;overflow-y:auto;flex:1}.form-modal-content .form-row{display:flex;gap:16px;margin-bottom:16px}.form-modal-content .form-group{flex:1}.form-modal-content .form-group label{display:block;margin-bottom:6px;font-size:14px;font-weight:500;color:#495057}.form-modal-content .form-group input,.form-modal-content .form-group select{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.form-modal-content .form-group input:focus,.form-modal-content .form-group select:focus{outline:none;border-color:#80bdff;box-shadow:0 0 0 3px #007bff26}.form-modal-footer{padding:16px 24px;background-color:#f8f9fa;border-top:1px solid #dee2e6;display:flex;justify-content:flex-end;gap:12px}.uso-section{margin:12px 0}.uso-section h4{margin:8px 0;font-size:14px;color:#495057;font-weight:600}.uso-list-compact{list-style:none;margin:0;background-color:#f8f9fa;border-radius:6px;padding:12px}.uso-list-compact li{padding:6px 0;border-bottom:1px solid #dee2e6;font-size:14px;color:#495057}.uso-list-compact li:last-child{border-bottom:none}.badge-inactivo{color:#6c757d;font-style:italic;font-size:12px}.btn-toggle-activo:disabled{opacity:.5;cursor:not-allowed}.btn-toggle-activo:disabled:hover{transform:none}.duplicar-popup{max-width:600px;width:90%}.duplicar-popup .popup-body{padding:20px;min-height:300px}.duplicar-popup .pasos-indicador{display:flex;align-items:center;justify-content:center;padding:20px;background:#f8f9fa;border-bottom:1px solid #e9ecef}.duplicar-popup .paso{display:flex;flex-direction:column;align-items:center;gap:4px}.duplicar-popup .paso-numero{width:32px;height:32px;border-radius:50%;background:#dee2e6;color:#6c757d;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.duplicar-popup .paso.activo .paso-numero{background:#007bff;color:#fff}.duplicar-popup .paso.completado .paso-numero{background:#28a745;color:#fff}.duplicar-popup .paso-label{font-size:12px;color:#6c757d;font-weight:500}.duplicar-popup .paso.activo .paso-label{color:#007bff}.duplicar-popup .paso-linea{width:60px;height:2px;background:#dee2e6;margin:0 10px 20px}.duplicar-popup .paso-contenido{animation:fadeIn .3s ease}.duplicar-popup .paso-contenido h4{margin:0 0 8px;color:#333;font-size:18px}.duplicar-popup .paso-descripcion{color:#6c757d;margin-bottom:16px;font-size:14px}.duplicar-popup .eventos-lista-scroll{max-height:300px;overflow-y:auto;border:1px solid #e9ecef;border-radius:8px;padding:8px}.duplicar-popup .eventos-vacio{padding:40px;text-align:center;color:#6c757d}.duplicar-popup .evento-item{padding:12px;border:1px solid #e9ecef;border-radius:6px;margin-bottom:8px;cursor:pointer;transition:all .2s ease;background:#fff}.duplicar-popup .evento-item:hover{border-color:#007bff;background:#f8f9ff;transform:translate(4px)}.duplicar-popup .evento-item:last-child{margin-bottom:0}.duplicar-popup .evento-item-info{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.duplicar-popup .evento-item-nombre{font-weight:600;color:#333;font-size:15px}.duplicar-popup .evento-item-fecha{font-size:13px;color:#6c757d}.duplicar-popup .evento-item-meta{display:flex;gap:8px;align-items:center}.duplicar-popup .evento-item-estado{font-size:11px;padding:2px 8px;border-radius:12px;font-weight:500;text-transform:uppercase}.duplicar-popup .evento-item-sala{font-size:12px;color:#6c757d}.duplicar-popup .estado-detenido{background:#6c757d;color:#fff}.duplicar-popup .estado-venta{background:#fd7e14;color:#fff}.duplicar-popup .estado-checkin{background:#28a745;color:#fff}.duplicar-popup .evento-seleccionado-info{background:#e7f3ff;border:1px solid #b8daff;border-radius:6px;padding:12px;margin-bottom:20px}.duplicar-popup .evento-seleccionado-info p{margin:4px 0;font-size:14px}.duplicar-popup .form-group{margin-bottom:16px}.duplicar-popup .form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333;font-size:14px}.duplicar-popup .form-input{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.duplicar-popup .form-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.duplicar-popup .form-actions{display:flex;justify-content:space-between;margin-top:24px;gap:12px}.duplicar-popup .btn-secondary,.duplicar-popup .btn-primary,.duplicar-popup .btn-success{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;transition:all .2s}.duplicar-popup .btn-secondary{background:#6c757d;color:#fff}.duplicar-popup .btn-secondary:hover:not(:disabled){background:#5a6268}.duplicar-popup .btn-primary{background:#007bff;color:#fff;margin-left:auto}.duplicar-popup .btn-primary:hover{background:#0056b3}.duplicar-popup .btn-success{background:#28a745;color:#fff;margin-left:auto}.duplicar-popup .btn-success:hover:not(:disabled){background:#218838}.duplicar-popup .btn-secondary:disabled,.duplicar-popup .btn-success:disabled{opacity:.6;cursor:not-allowed}.duplicar-popup .confirmacion-resumen{display:flex;align-items:flex-start;gap:16px;margin:20px 0;padding:16px;background:#f8f9fa;border-radius:8px}.duplicar-popup .resumen-seccion{flex:1;padding:12px;background:#fff;border-radius:6px;border:1px solid #e9ecef}.duplicar-popup .resumen-seccion h5{margin:0 0 12px;color:#333;font-size:14px;border-bottom:1px solid #e9ecef;padding-bottom:8px}.duplicar-popup .resumen-seccion p{margin:6px 0;font-size:13px;color:#555}.duplicar-popup .resumen-nuevo{border-color:#28a745;background:#f0fff4}.duplicar-popup .resumen-flecha{color:#007bff;font-size:20px;padding-top:40px}.duplicar-popup .confirmacion-aviso{background:#fff3cd;border:1px solid #ffc107;border-radius:6px;padding:12px;margin-bottom:20px}.duplicar-popup .confirmacion-aviso p{margin:0 0 8px;font-size:13px;color:#856404}.duplicar-popup .confirmacion-aviso ul{margin:0;padding-left:20px}.duplicar-popup .confirmacion-aviso li{font-size:12px;color:#856404;margin:4px 0}.duplicar-popup .spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 600px){.duplicar-popup .confirmacion-resumen{flex-direction:column}.duplicar-popup .resumen-flecha{transform:rotate(90deg);padding:0;align-self:center}.duplicar-popup .paso-linea{width:30px}}:root{--silla-size: 30px;--cell-size-sillas: 40px;--mesa-size: 60px;--silla-mesa-size: 18px;--silla-offset-sur: 2px;--silla-offset-norte: 8px;--silla-offset-oeste: 7px;--silla-offset-este: 3px;--silla-spacing-4: 6px;--silla-offset-vertical-4: -12px;--silla-offset-horizontal-4: -12px;--silla-font-size: 11px;--silla-con-fila-font-size: 11px;--mesa-font-size: 15px}.am-container{width:100%;height:100vh;background-color:#f5f5f5;padding:20px;box-sizing:border-box}.am-editor{display:flex;flex-direction:column;height:100%;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a}.am-toolbar{display:flex;gap:10px;padding:15px;background:#f8f9fa;border-bottom:1px solid #dee2e6;border-radius:8px 8px 0 0;align-items:center}.am-toolbar button{padding:8px 16px;border:1px solid #007bff;background:#007bff;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s}.am-toolbar button:hover{background:#0056b3;border-color:#0056b3}.am-mapa-area{flex:1;position:relative;background:#f8f9fa;border:2px dashed #dee2e6;margin:15px;border-radius:4px;overflow:auto;min-height:500px}.am-sector-rnd{z-index:1}.am-sector-seleccionado{box-shadow:0 0 0 3px #007bff;border:2px solid #007bff}.am-sector-content-wrapper{width:100%;height:100%;border:2px solid #6c757d;border-radius:8px;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden}.am-sector-header{background:#6c757dcc;color:#fff;padding:0 8px;font-size:12px;font-weight:700;border-radius:6px 6px 0 0;margin-bottom:0;text-align:center;cursor:move;flex-shrink:0;z-index:10;position:relative;display:flex;align-items:center;justify-content:center}.am-sector-items{flex:1;position:relative;width:100%;height:100%}.am-mesa-rnd{z-index:2}.am-mesa-seleccionada{box-shadow:0 0 0 3px #007bff;border-radius:15%}.am-mesa-content{width:100%;height:100%;border:2px solid #333;display:flex;align-items:center;justify-content:center;font-size:var(--mesa-font-size);font-weight:700;color:#fff;text-shadow:1px 1px 1px rgba(0,0,0,.5);box-sizing:border-box;position:relative}.am-mesa-content:hover{box-shadow:0 4px 8px #0003}.am-mesa-en-arrastre{z-index:10!important}.am-mesa-en-arrastre .am-mesa-content{box-shadow:0 0 0 4px #28a745,0 4px 12px #0000004d;transform:scale(1.08);transition:transform .1s ease}.am-mesa-numero{z-index:2;pointer-events:none}.am-silla{position:absolute;border:1px solid #333;width:var(--silla-mesa-size);height:var(--silla-mesa-size)}.am-silla-rnd{z-index:2}.am-silla-seleccionada{box-shadow:0 0 0 3px #007bff;border-radius:50%}.am-silla-content{border:1px solid #333;cursor:move;width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:var(--silla-font-size);color:#fff;font-weight:700;border-radius:50%}.am-silla-content:hover{transform:scale(1.1);box-shadow:0 2px 4px #0003}.am-silla-en-arrastre{z-index:10!important}.am-silla-en-arrastre .am-silla-content{box-shadow:0 0 0 4px #28a745,0 4px 12px #0000004d;transform:scale(1.15);transition:transform .1s ease}.am-escenario-rnd{z-index:1}.am-escenario-content{width:100%;height:100%;border:2px solid #6f42c1;border-radius:4px;background:#6f42c11a;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#6f42c1;cursor:move;-webkit-user-select:none;user-select:none;box-sizing:border-box}.am-escenario-content:hover{border-color:#5a2d91;background:#6f42c133}@media (max-width: 768px){.am-container{padding:10px}.am-toolbar{flex-direction:column;gap:5px}.am-toolbar button{width:100%}.am-mapa-area{margin:10px;min-height:300px}}.am-sector-objeto-content{width:100%;height:100%;border:2px solid #6c757d;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:move;-webkit-user-select:none;user-select:none;box-sizing:border-box}.sector-editor-popup{background:#fff;padding:20px;border-radius:8px;box-shadow:0 4px 20px #0003;width:500px;max-width:90%;max-height:90vh;overflow-y:auto}.sector-popup-content{display:flex;flex-direction:column;gap:15px}.form-section{border:1px solid #dee2e6;border-radius:6px;padding:15px;background-color:#f8f9fa}.form-section-title{font-size:14px;font-weight:700;color:#495057;margin-bottom:10px;border-bottom:1px solid #dee2e6;padding-bottom:5px}.dimmed-section{opacity:.5;pointer-events:none;transition:opacity .3s ease}.color-hex-input{width:80px;padding:4px 8px;border:1px solid #ced4da;border-radius:4px;font-family:monospace;text-transform:uppercase}.checkbox-wrapper{display:flex;align-items:center;gap:8px;cursor:pointer;margin-bottom:10px;font-weight:500}.sector-popup-content{max-height:70vh;overflow-y:auto;padding-right:10px}.form-section{margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.form-section h3{margin-top:0;margin-bottom:15px;font-size:16px;color:#495057;border-bottom:2px solid #dee2e6;padding-bottom:8px}.row-config-container{transition:opacity .3s ease}.row-config-container.dimmed{opacity:.5;pointer-events:none}.color-input-wrapper{display:flex;align-items:center;gap:10px}.hex-input{width:80px;padding:4px 8px;border:1px solid #ced4da;border-radius:4px;font-family:monospace;text-transform:uppercase}button:disabled{opacity:.6;cursor:not-allowed}input:disabled{background-color:#e9ecef;cursor:not-allowed}.undo-redo-buttons{display:flex;gap:5px}.btn-undo,.btn-redo{padding:8px 12px;border:1px solid #6c757d;background:#6c757d;color:#fff;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s;white-space:nowrap}.btn-undo:hover:not(:disabled),.btn-redo:hover:not(:disabled){background:#5a6268;border-color:#545b62}.btn-undo:disabled,.btn-redo:disabled{background:#adb5bd;border-color:#adb5bd;cursor:not-allowed;opacity:.6}.btn-undo[title]:hover:after,.btn-redo[title]:hover:after{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:1000}.re-container{display:flex;flex-direction:column;height:100vh;background-color:#f5f5f5}.re-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#fff;border-bottom:2px solid #dee2e6;box-shadow:0 2px 4px #0000001a}.re-header h2{margin:0;color:#212529;font-size:1.5rem;font-weight:600}.re-header-controls{display:flex;align-items:center;gap:15px}.re-evento-select{padding:10px 15px;border:2px solid #dee2e6;border-radius:6px;font-size:14px;min-width:300px;background-color:#fff;cursor:pointer;transition:border-color .2s}.re-evento-select:hover{border-color:#007bff}.re-evento-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.re-evento-select:disabled{background-color:#e9ecef;cursor:not-allowed}.re-carrito-btn{position:relative;padding:10px 15px;border:none;background:#007bff;color:#fff;border-radius:6px;cursor:pointer;font-size:18px;transition:all .2s;display:flex;align-items:center;justify-content:center}.re-carrito-btn:hover{background:#0056b3;transform:translateY(-1px)}.re-carrito-badge{position:absolute;top:-5px;right:-5px;background:#dc3545;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.re-content{flex:1;overflow:hidden;position:relative}.re-loading,.re-empty{display:flex;align-items:center;justify-content:center;height:100%;font-size:18px;color:#6c757d}.re-mapa-container{display:flex;flex-direction:column;height:100%}.re-toolbar{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:#f8f9fa;border-bottom:1px solid #dee2e6}.re-zoom-controls{display:flex;align-items:center;gap:10px}.re-zoom-controls span{font-size:14px;color:#495057;min-width:80px}.re-zoom-controls button{padding:5px 12px;border:1px solid #007bff;background:#fff;color:#007bff;border-radius:4px;cursor:pointer;font-size:16px;font-weight:700;transition:all .2s}.re-zoom-controls button:hover{background:#007bff;color:#fff}.re-leyenda{display:flex;gap:20px}.re-leyenda-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#495057}.re-leyenda-color{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,.2)}.re-snapshot-btn{display:flex;align-items:center;gap:8px;padding:8px 15px;background:#6f42c1;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s}.re-snapshot-btn:hover{background:#5a32a3;transform:translateY(-1px);box-shadow:0 2px 8px #6f42c166}.re-snapshot-btn:active{transform:translateY(0)}.re-snapshot-btn svg{font-size:16px}.re-mapa-area{flex:1;position:relative;background:#f8f9fa;border:2px dashed #dee2e6;margin:15px;border-radius:4px;overflow:auto;min-height:500px}.re-scalable-content{background:#fff}.re-sector{z-index:1}.re-sector-content{width:100%;height:100%;border:2px solid #6c757d;border-radius:8px;display:flex;flex-direction:column;box-sizing:border-box;overflow:hidden}.re-sector-header{background:#6c757dcc;color:#fff;padding:0 8px;font-size:12px;font-weight:700;border-radius:6px 6px 0 0;text-align:center;flex-shrink:0;z-index:10;position:relative;display:flex;align-items:center;justify-content:center}.re-sector-items{flex:1;position:relative;width:100%;height:100%}.re-sector-grid{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.re-sector-objeto{width:100%;height:100%;border:2px solid #6c757d;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;box-sizing:border-box}.re-mesa{z-index:2}.re-mesa-content{width:100%;height:100%;border:2px solid #333;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;color:#fff;text-shadow:1px 1px 1px rgba(0,0,0,.5);position:relative;box-sizing:border-box}.re-mesa-numero{z-index:2;pointer-events:none}.re-silla-mesa{position:absolute;border:1px solid #333;border-radius:50%;transition:transform .1s}.re-silla-mesa:hover{transform:scale(1.15);box-shadow:0 2px 8px #0000004d;z-index:10}.re-silla{border:1px solid #333;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;font-weight:700;transition:transform .1s}.re-silla:hover{transform:scale(1.15);box-shadow:0 2px 8px #0000004d;z-index:10}.re-escenario{z-index:1}.re-escenario-content{width:100%;height:100%;border:2px solid #6f42c1;border-radius:4px;background:#6f42c11a;display:flex;align-items:center;justify-content:center;font-weight:700;box-sizing:border-box}.re-carrito-panel{position:fixed;top:0;right:0;width:350px;height:100vh;background:#fff;box-shadow:-2px 0 10px #0000001a;z-index:10000;display:flex;flex-direction:column}.re-carrito-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-bottom:1px solid #dee2e6}.re-carrito-header h3{margin:0;font-size:18px;color:#212529}.re-carrito-cerrar{background:none;border:none;font-size:20px;color:#6c757d;cursor:pointer;padding:5px;transition:color .2s}.re-carrito-cerrar:hover{color:#dc3545}.re-carrito-items{flex:1;overflow-y:auto;padding:15px}.re-carrito-vacio{text-align:center;color:#6c757d;font-style:italic;padding:30px 0}.re-carrito-item{padding:12px;background:#f8f9fa;border-radius:6px;margin-bottom:10px;border:1px solid #e9ecef}.re-carrito-item-content{display:flex;flex-direction:column;gap:4px}.re-carrito-item-header{display:flex;justify-content:space-between;align-items:flex-start}.re-carrito-item-info{display:flex;flex-direction:column;gap:2px;flex:1}.re-carrito-item-categorias{margin-top:4px}.re-carrito-item-tipo{font-weight:600;color:#212529;font-size:14px}.re-carrito-item-sector{font-size:12px;color:#6c757d}.re-carrito-item-mesa{font-size:12px;color:#007bff}.re-carrito-item-precio{display:flex;align-items:center;gap:8px}.re-carrito-item-precio span{font-weight:600;color:#28a745;font-size:16px}.re-carrito-item-remove{background:#dc3545;border:none;color:#fff;padding:5px 8px;border-radius:4px;cursor:pointer;font-size:12px;transition:background .2s;display:flex;align-items:center;justify-content:center}.re-carrito-item-remove:hover{background:#c82333}.re-cortesia-badge{background:#28a745;color:#fff;font-size:10px;padding:2px 6px;border-radius:10px;font-weight:600}.re-carrito-footer{padding:15px 20px;background:#f8f9fa;border-top:1px solid #dee2e6;position:sticky;bottom:0;z-index:10;box-shadow:0 -2px 10px #0000001a}.re-carrito-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;font-size:18px}.re-carrito-total span:first-child{font-weight:600;color:#212529}.re-carrito-total-monto{font-weight:700;color:#28a745;font-size:22px}.re-carrito-comprar{width:100%;padding:12px;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.re-carrito-comprar:hover{background:#218838}.re-carrito-comprar:disabled{background:#6c757d;cursor:not-allowed}@media (max-width: 768px){.re-header{flex-direction:column;gap:10px;padding:10px}.re-header h2{font-size:1.2rem}.re-header-controls{flex-direction:column;width:100%}.re-evento-select,.re-select__control{min-width:unset!important;width:100%!important}.re-select__menu-portal{max-width:95vw!important}.re-select__menu{min-width:unset!important;width:auto!important;max-width:95vw!important}.re-toolbar{flex-direction:column;gap:10px}.re-leyenda{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 15px;width:100%;max-width:320px;margin:0 auto}.re-leyenda-item{font-size:12px;gap:6px;justify-content:center}.re-leyenda-color{width:14px;height:14px}.re-carrito-panel{width:100%;height:100%;max-height:100vh}.re-carrito-footer{position:fixed;bottom:0;left:0;right:0;width:100%;box-sizing:border-box;background:#f8f9fa;padding:15px 20px;box-shadow:0 -4px 12px #00000026;z-index:10001}.re-carrito-items{padding-bottom:140px}}.re-popup-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:11000}.re-popup-container{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #0000004d}.re-popup-seleccion{max-width:600px}.re-popup-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#f8f9fa;border-bottom:1px solid #dee2e6;border-radius:8px 8px 0 0}.re-popup-header h3{margin:0;font-size:18px;color:#212529}.re-popup-cerrar{background:none;border:none;font-size:20px;color:#6c757d;cursor:pointer;padding:5px;transition:color .2s}.re-popup-cerrar:hover{color:#dc3545}.re-popup-content{flex:1;overflow-y:auto;padding:20px}.re-form-group{margin-bottom:15px}.re-form-group label{display:block;margin-bottom:5px;font-weight:600;color:#495057;font-size:14px}.re-form-group input{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:4px;font-size:14px;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.re-form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.re-form-group input::placeholder{color:#adb5bd}.re-busqueda-container{margin-bottom:15px}.re-busqueda-input{position:relative;display:flex;align-items:center}.re-busqueda-input svg{position:absolute;left:12px;color:#6c757d;font-size:16px}.re-busqueda-input input{padding-left:35px}.re-clientes-lista{max-height:350px;overflow-y:auto;border:1px solid #dee2e6;border-radius:4px}.re-cargando,.re-sin-resultados{text-align:center;padding:30px;color:#6c757d;font-style:italic}.re-cliente-item{display:flex;align-items:center;padding:12px 15px;border-bottom:1px solid #e9ecef;cursor:pointer;transition:background .2s}.re-cliente-item:last-child{border-bottom:none}.re-cliente-item:hover{background:#f8f9fa}.re-cliente-item.re-cliente-seleccionado{background:#007bff;border-color:#0056b3}.re-cliente-item.re-cliente-seleccionado .re-cliente-nombre{color:#fff}.re-cliente-item.re-cliente-seleccionado .re-cliente-detalles{color:#ffffffe6}.re-cliente-item.re-cliente-seleccionado .re-cliente-icono{background:#fff;color:#007bff}.re-cliente-item.re-cliente-dimming{opacity:.4}.re-cliente-icono{width:40px;height:40px;background:#007bff;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;margin-right:15px;flex-shrink:0}.re-cliente-info{flex:1;display:flex;flex-direction:column;gap:3px}.re-cliente-nombre{font-weight:600;color:#212529;font-size:15px}.re-cliente-detalles{font-size:13px;color:#6c757d}.re-popup-footer{display:flex;gap:10px;padding:15px 20px;background:#f8f9fa;border-top:1px solid #dee2e6;border-radius:0 0 8px 8px}.re-popup-footer button{flex:1;padding:10px 15px;border:none;border-radius:4px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.re-btn-seleccionar-cliente{background:#6c757d;color:#fff}.re-btn-seleccionar-cliente:hover{background:#5a6268}.re-btn-reservar{background:#28a745;color:#fff}.re-btn-reservar:hover:not(:disabled){background:#218838}.re-btn-reservar:disabled{background:#6c757d;cursor:not-allowed}.re-btn-volver{background:#17a2b8;color:#fff}.re-btn-volver:hover{background:#138496}@media (max-width: 768px){.re-popup-container{width:95%;max-height:95vh}.re-popup-footer{flex-direction:column}.re-popup-footer button{width:100%}}.re-paginacion-container{display:flex;flex-direction:column;align-items:center;gap:10px;padding:15px;background:#f8f9fa;border-top:1px solid #dee2e6;border-radius:0 0 4px 4px}.re-paginacion-info{font-size:13px;color:#6c757d;text-align:center}.re-paginacion-controles{display:flex;align-items:center;gap:15px}.re-paginacion-btn{padding:8px 16px;border:1px solid #007bff;background:#fff;color:#007bff;border-radius:4px;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s}.re-paginacion-btn:hover:not(:disabled){background:#007bff;color:#fff}.re-paginacion-btn:disabled{border-color:#6c757d;color:#6c757d;cursor:not-allowed;background:#e9ecef}.re-paginacion-pagina{font-size:14px;font-weight:600;color:#495057;min-width:100px;text-align:center}.ticket-categorias{padding:8px 0 0}.ticket-categorias.tc-disabled{opacity:.6;pointer-events:none}.tc-loading{padding:8px 0;text-align:center;color:#6c757d;font-size:12px}.tc-seccion{margin-bottom:6px}.tc-seccion:last-child{margin-bottom:0}.tc-promos{padding-bottom:6px;border-bottom:1px dashed #dee2e6}.tc-cortesia{padding-top:2px}.tc-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;font-weight:600}.tc-checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#dc3545;flex-shrink:0}.tc-checkbox-text{color:#dc3545;display:flex;align-items:center;gap:8px}.tc-promo-label .tc-checkbox-text{color:#dc3545}.tc-opciones{display:flex;flex-direction:column;gap:4px}.tc-precio-badge{padding:2px 6px;border-radius:10px;font-size:10px;font-weight:600;margin-left:8px}.tc-descuento{background:#d4edda;color:#155724}@media (max-width: 768px){.tc-checkbox-text{flex-wrap:wrap}.tc-precio-badge{margin-left:auto}}:root{--color-reservado: #fd7e14;--color-reservado-light: #ffc078;--color-reservado-dark: #e8590c;--color-comprado: #17a2b8;--color-comprado-light: #7fdbf0;--color-comprado-dark: #138496;--color-checkin: #28a745;--color-checkin-light: #69db7c;--color-checkin-dark: #1e7e34;--color-caducado: #6c757d;--color-caducado-light: #adb5bd;--color-caducado-dark: #495057;--color-ingresos: #6f42c1;--color-ingresos-light: #a98eda;--color-ingresos-dark: #5a32a3;--color-pendiente: #fd7e14;--color-pendiente-light: #ffc078;--color-pendiente-dark: #e8590c;--color-confirmada: #28a745;--color-confirmada-light: #69db7c;--color-confirmada-dark: #1e7e34;--color-anulada: #dc3545;--color-anulada-light: #f5c6cb;--color-anulada-dark: #bd2130;--color-cortesia: #9c27b0;--color-cortesia-light: #e1bee7;--color-cortesia-dark: #7b1fa2;--bg-primary: #f8f9fa;--bg-card: #ffffff;--text-primary: #212529;--text-secondary: #6c757d;--border-color: #dee2e6;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--transition: all .2s ease-in-out}.tickets-container{padding:20px;background-color:var(--bg-primary);min-height:100%}.tickets-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border-color);flex-wrap:wrap;gap:15px}.tickets-header h2{margin:0;color:var(--text-primary);font-size:1.75rem;font-weight:600;display:flex;align-items:center;gap:10px}.tickets-header h2 svg{color:var(--color-comprado)}.tickets-filters{background-color:var(--bg-card);padding:20px;border-radius:10px;box-shadow:var(--shadow-sm);margin-bottom:20px;border:1px solid var(--border-color)}.evento-selector{display:flex;flex-direction:column;gap:8px}.evento-selector label{font-weight:600;color:var(--text-primary);font-size:14px}.evento-dropdown{padding:12px 16px;border:2px solid var(--border-color);border-radius:8px;font-size:14px;background-color:var(--bg-card);color:var(--text-primary);cursor:pointer;transition:var(--transition);min-width:300px}.evento-dropdown:hover{border-color:var(--color-comprado)}.evento-dropdown:focus{outline:none;border-color:var(--color-comprado);box-shadow:0 0 0 3px #17a2b833}.evento-dropdown:disabled{opacity:.6;cursor:not-allowed}.view-mode-selector{display:flex;gap:10px;margin-top:15px;padding-top:15px;border-top:1px solid var(--border-color);align-items:center;flex-wrap:wrap}.search-filter{display:flex;align-items:center;gap:8px;margin-left:auto;padding:8px 12px;background-color:var(--bg-primary);border:2px solid var(--border-color);border-radius:8px;transition:var(--transition);min-width:250px}.search-filter:focus-within{border-color:var(--color-comprado);box-shadow:0 0 0 3px #17a2b833}.search-filter .search-icon{color:var(--text-secondary);font-size:14px;flex-shrink:0}.search-filter .search-input{border:none;background:transparent;outline:none;font-size:14px;color:var(--text-primary);width:100%;min-width:150px}.search-filter .search-input::placeholder{color:var(--text-secondary)}.view-mode-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:2px solid var(--border-color);border-radius:8px;background-color:var(--bg-card);color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition)}.view-mode-btn:hover{border-color:var(--color-comprado);color:var(--color-comprado)}.view-mode-btn.active{background-color:var(--color-comprado);border-color:var(--color-comprado);color:#fff}.evento-info-bar{display:flex;flex-wrap:wrap;gap:20px;background-color:var(--bg-card);padding:15px 20px;border-radius:10px;box-shadow:var(--shadow-sm);margin-bottom:20px;border:1px solid var(--border-color);border-left:4px solid var(--color-comprado)}.evento-info-item{display:flex;align-items:center;gap:8px}.evento-info-item .info-label{font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.evento-info-item .info-value{color:var(--text-primary);font-weight:500;font-size:14px}.tickets-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:15px;margin-bottom:25px}.stat-card{background-color:var(--bg-card);padding:20px;border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);text-align:center;transition:var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card .stat-value{display:block;font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:5px}.stat-card .stat-label{display:block;font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stat-card.estado-reservado{border-top:3px solid var(--color-reservado)}.stat-card.estado-reservado .stat-value{color:var(--color-reservado)}.stat-card.estado-comprado{border-top:3px solid var(--color-comprado)}.stat-card.estado-comprado .stat-value{color:var(--color-comprado)}.stat-card.estado-checkin{border-top:3px solid var(--color-checkin)}.stat-card.estado-checkin .stat-value{color:var(--color-checkin)}.stat-card.estado-caducado{border-top:3px solid var(--color-caducado)}.stat-card.estado-caducado .stat-value{color:var(--color-caducado)}.stat-card.ingresos{border-top:3px solid var(--color-ingresos)}.stat-card.ingresos .stat-value{color:var(--color-ingresos)}.tickets-list{display:flex;flex-direction:column;gap:15px}.ticket-card{background-color:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);overflow:hidden;transition:var(--transition);animation:fadeIn .3s ease-in-out}.ticket-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.ticket-card.estado-reservado{border-left:4px solid var(--color-reservado)}.ticket-card.estado-comprado{border-left:4px solid var(--color-comprado)}.ticket-card.estado-checkin{border-left:4px solid var(--color-checkin)}.ticket-card.estado-caducado{border-left:4px solid var(--color-caducado)}.ticket-card.estado-anulada{border-left:4px solid var(--color-anulada)}.ticket-card.estado-reservado .ticket-card-header{background-color:#fff3cd;border-bottom-color:var(--color-reservado)}.ticket-card.estado-comprado .ticket-card-header{background-color:#e3f2fd;border-bottom-color:var(--color-comprado)}.ticket-card.estado-checkin .ticket-card-header{background-color:#d4edda;border-bottom-color:var(--color-checkin)}.ticket-card.estado-caducado .ticket-card-header{background-color:#e9ecef;border-bottom-color:var(--color-caducado)}.ticket-card.estado-anulada .ticket-card-header{background-color:#f8d7da;border-bottom-color:var(--color-anulada)}.ticket-card-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:2px solid transparent;background-color:#fafbfc;flex-wrap:wrap;gap:10px}.ticket-info-principal{display:flex;align-items:center;gap:15px}.ticket-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;background-color:var(--color-comprado)}.ticket-card.estado-reservado .ticket-icon{background-color:var(--color-reservado)}.ticket-card.estado-comprado .ticket-icon{background-color:var(--color-comprado)}.ticket-card.estado-checkin .ticket-icon{background-color:var(--color-checkin)}.ticket-card.estado-caducado .ticket-icon{background-color:var(--color-caducado)}.ticket-card.estado-anulada .ticket-icon{background-color:var(--color-anulada)}.ticket-cliente h4{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:8px}.ticket-cliente .ticket-id{font-size:12px;color:var(--text-secondary);font-weight:400;display:flex;align-items:center;gap:6px}.ticket-cliente .ticket-codigo-reserva{font-family:monospace;font-weight:600;color:var(--color-comprado);background-color:#17a2b81a;padding:2px 6px;border-radius:4px;font-size:11px}.icon-small{font-size:14px;color:var(--text-secondary)}.ticket-card-body{padding:20px}.ticket-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px}.ticket-detail{display:flex;flex-direction:column;gap:4px}.ticket-detail .info-label{color:var(--text-secondary);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:6px}.ticket-detail span:not(.info-label){color:var(--text-primary);font-size:14px;font-weight:500}.ticket-detail .localidad-info{display:flex;align-items:center;gap:6px;color:var(--color-comprado);font-weight:600}.ticket-detail .precio{color:var(--color-ingresos);font-weight:700;font-size:1.1rem}.ticket-detail .precio.precio-cortesia{color:var(--color-cortesia);font-style:italic}.estado-badge{display:inline-block;padding:6px 12px;border-radius:20px;color:#fff;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;box-shadow:var(--shadow-sm)}.estado-badge.small{padding:4px 8px;font-size:10px}.estado-badge.reservado{background-color:var(--color-reservado)}.estado-badge.comprado{background-color:var(--color-comprado)}.estado-badge.checkin{background-color:var(--color-checkin)}.estado-badge.caducado{background-color:var(--color-caducado)}.estado-badge.detenido{background-color:#6c757d}.estado-badge.venta{background-color:#fd7e14}.estado-badge.finalizado{background-color:#dc3545}.estado-badge.pendiente{background-color:var(--color-pendiente)}.estado-badge.confirmada{background-color:var(--color-confirmada)}.estado-badge.anulada,.estado-badge.anulado{background-color:var(--color-anulada)}.tickets-empty{text-align:center;padding:60px 20px;color:var(--text-secondary);font-size:16px;background-color:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.tickets-empty .empty-icon{font-size:48px;color:var(--border-color);margin-bottom:15px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.reservas-list{display:flex;flex-direction:column;gap:15px}.reserva-card{background-color:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);overflow:hidden;transition:var(--transition);animation:fadeIn .3s ease-in-out}.reserva-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.reserva-card.estado-pendiente{border-left:4px solid var(--color-pendiente)}.reserva-card.estado-confirmada{border-left:4px solid var(--color-confirmada)}.reserva-card.estado-anulada{border-left:4px solid var(--color-anulada)}.reserva-card.estado-pendiente .reserva-card-header{background-color:#fff3cd;border-bottom-color:var(--color-pendiente)}.reserva-card.estado-confirmada .reserva-card-header{background-color:#d4edda;border-bottom-color:var(--color-confirmada)}.reserva-card.estado-anulada .reserva-card-header{background-color:#f8d7da;border-bottom-color:var(--color-anulada)}.reserva-card-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:2px solid transparent;background-color:#fafbfc;flex-wrap:wrap;gap:10px;cursor:pointer;transition:var(--transition)}.reserva-card.estado-pendiente .reserva-card-header:hover{background-color:#ffeaa7}.reserva-card.estado-confirmada .reserva-card-header:hover{background-color:#b8e0c8}.reserva-card.estado-anulada .reserva-card-header:hover{background-color:#f5c6cb}.reserva-info-principal{display:flex;align-items:center;gap:15px}.reserva-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;background-color:var(--color-comprado)}.reserva-card.estado-pendiente .reserva-icon{background-color:var(--color-pendiente);box-shadow:0 0 0 3px #fd7e144d}.reserva-card.estado-confirmada .reserva-icon{background-color:var(--color-confirmada);box-shadow:0 0 0 3px #28a7454d}.reserva-card.estado-anulada .reserva-icon{background-color:var(--color-anulada);box-shadow:0 0 0 3px #dc35454d}.reserva-card.estado-pendiente:hover{border-left-color:var(--color-pendiente-dark);box-shadow:0 4px 12px #fd7e1426}.reserva-card.estado-confirmada:hover{border-left-color:var(--color-confirmada-dark);box-shadow:0 4px 12px #28a74526}.reserva-card.estado-anulada:hover{border-left-color:var(--color-anulada-dark);box-shadow:0 4px 12px #dc354526}.estado-badge.pendiente{background-color:var(--color-pendiente);box-shadow:0 2px 4px #fd7e144d}.estado-badge.confirmada{background-color:var(--color-confirmada);box-shadow:0 2px 4px #28a7454d}.estado-badge.anulada{background-color:var(--color-anulada);box-shadow:0 2px 4px #dc35454d}.stat-card.estado-pendiente{border-top:3px solid var(--color-pendiente)}.stat-card.estado-pendiente .stat-value{color:var(--color-pendiente)}.stat-card.estado-confirmada{border-top:3px solid var(--color-confirmada)}.stat-card.estado-confirmada .stat-value{color:var(--color-confirmada)}.stat-card.estado-anulada{border-top:3px solid var(--color-anulada)}.stat-card.estado-anulada .stat-value{color:var(--color-anulada)}.reserva-cliente h4{margin:0;color:var(--text-primary);font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:8px}.reserva-cliente .reserva-codigo{font-size:12px;color:var(--text-secondary);font-weight:500;font-family:monospace;background-color:#0000000d;padding:2px 6px;border-radius:4px}.reserva-info-secundaria{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.reserva-summary{display:flex;gap:15px;font-size:13px;color:var(--text-secondary)}.reserva-tickets-count,.reserva-total{display:flex;align-items:center;gap:5px}.reserva-total{font-weight:600;color:var(--color-ingresos)}.reserva-card-body{padding:20px}.reserva-main-info{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;margin-bottom:15px}.reserva-main-info .reserva-details{flex:1;margin-bottom:0;min-width:200px}.reserva-main-info .reserva-actions{margin-top:0;padding-top:0;border-top:none;align-self:flex-start;min-width:200px;flex-shrink:0}.reserva-details{display:grid;grid-template-columns:repeat(4,1fr);gap:15px;margin-bottom:15px}@media (max-width: 1200px){.reserva-details{grid-template-columns:repeat(2,1fr)}}.reserva-detail{display:flex;flex-direction:column;gap:4px}.expand-btn{margin-top:10px;padding:8px 16px;background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:13px;cursor:pointer;transition:var(--transition)}.expand-btn:hover{background-color:var(--border-color)}.reserva-tickets-detalle{margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.reserva-tickets-detalle h5{margin:0 0 15px;color:var(--text-primary);font-size:14px;font-weight:600}.tickets-detalle-list{display:flex;flex-direction:column;gap:10px}.ticket-detalle-item{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background-color:var(--bg-primary);border-radius:8px;border-left:3px solid var(--border-color)}.ticket-detalle-item.estado-reservado{border-left-color:var(--color-reservado)}.ticket-detalle-item.estado-comprado{border-left-color:var(--color-comprado)}.ticket-detalle-item.estado-checkin{border-left-color:var(--color-checkin)}.ticket-detalle-item.estado-caducado{border-left-color:var(--color-caducado)}.ticket-detalle-item.estado-anulada{border-left-color:var(--color-anulada)}.ticket-detalle-info{display:flex;flex-direction:column;gap:4px}.ticket-detalle-localidad{font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px}.ticket-detalle-sector{font-size:12px;color:var(--text-secondary)}.ticket-detalle-status{display:flex;align-items:center;gap:10px}.ticket-detalle-precio{font-weight:700;color:var(--color-ingresos)}.ticket-detalle-precio.precio-cortesia{color:var(--color-cortesia);font-style:italic}.no-tickets{text-align:center;color:var(--text-secondary);font-style:italic;padding:20px}.cortesia-badge{display:inline-block;background-color:var(--color-cortesia);color:#fff;font-size:10px;font-weight:600;padding:2px 8px;border-radius:12px;margin-left:8px;text-transform:uppercase;letter-spacing:.5px}.cortesia-badge-header{display:inline-block;background-color:var(--color-cortesia);color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;margin-left:10px;text-transform:uppercase;letter-spacing:.5px}.promo-badge{display:inline-block;background:linear-gradient(135deg,#009688,#00796b);color:#fff;font-size:10px;font-weight:600;padding:2px 8px;border-radius:12px;margin-left:8px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0096884d}.promo-badge-header{display:inline-block;background:linear-gradient(135deg,#009688,#00796b);color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;margin-left:10px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0096884d}.fee-badge{display:inline-block;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;font-size:10px;font-weight:600;padding:2px 8px;border-radius:12px;margin-left:8px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #ff98004d}.fee-badge-header{display:inline-block;background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff;font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px;margin-left:10px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #ff98004d}.ticket-card.ticket-cortesia{border-left:4px solid var(--color-cortesia)}.ticket-card.ticket-cortesia .ticket-card-header{background-color:var(--color-cortesia-light);border-bottom-color:var(--color-cortesia)}.ticket-card.ticket-cortesia .ticket-icon{background-color:var(--color-cortesia)}.ticket-detalle-item.ticket-cortesia{border-left-color:var(--color-cortesia);background-color:#9c27b00d}.reserva-actions{display:flex;gap:10px;margin-top:15px;padding-top:15px;border-top:1px solid var(--border-color);justify-content:flex-end}.reserva-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:6px;cursor:pointer;transition:var(--transition);font-size:16px;color:#fff}.reserva-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.reserva-btn-vista-previa{background-color:#17a2b8}.reserva-btn-vista-previa:hover{background-color:#138496}.reserva-btn-checkin{background-color:#17a2b8}.reserva-btn-checkin:hover{background-color:#138496}.reserva-btn-checkin:disabled{background-color:#6c757d;cursor:not-allowed}.reserva-btn-copiar{background-color:#28a745}.reserva-btn-copiar:hover{background-color:#218838}.reserva-btn-pdf{background-color:#dc3545}.reserva-btn-pdf:hover{background-color:#c82333}.reserva-btn-confirmar{background-color:#28a745}.reserva-btn-confirmar:hover{background-color:#218838}.reserva-btn-anular{background-color:#6c757d}.reserva-btn-anular:hover{background-color:#5a6268}@media (max-width: 768px){.tickets-header{flex-direction:column;align-items:flex-start}.tickets-stats{grid-template-columns:repeat(2,1fr)}.evento-info-bar{flex-direction:column;gap:10px}.ticket-card-header,.reserva-card-header{flex-direction:column;align-items:flex-start}.reserva-info-secundaria{align-items:flex-start;width:100%}.ticket-details,.reserva-details{grid-template-columns:1fr}.evento-dropdown{min-width:100%}.view-mode-selector{flex-direction:column;align-items:stretch}.view-mode-btn{width:100%;justify-content:center}.search-filter{margin-left:0;width:100%;min-width:auto}.ticket-detalle-item{flex-direction:column;align-items:flex-start;gap:10px}.reserva-main-info{flex-direction:column;gap:15px}.reserva-main-info .reserva-actions{align-self:flex-start;justify-content:flex-start;width:100%}}@media (max-width: 480px){.tickets-container{padding:15px}.tickets-stats{grid-template-columns:1fr}.stat-card{padding:15px}.ticket-info-principal,.reserva-info-principal{flex-direction:column;align-items:flex-start}.reserva-summary{flex-direction:column;gap:5px}}.stat-card.filter-card{cursor:pointer;transition:all .2s ease-in-out}.stat-card.filter-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.stat-card.filter-card.active{transform:translateY(-3px);box-shadow:0 8px 16px #0000001a;border-bottom:2px solid transparent}.stat-card.filter-card.active.estado-pendiente{background-color:#fff8e1;border-top-width:4px}.stat-card.filter-card.active.estado-confirmada{background-color:#e8f5e9;border-top-width:4px}.stat-card.filter-card.active.estado-anulada{background-color:#ffebee;border-top-width:4px}.stat-card.filter-card.active.estado-reservado{background-color:#fff3cd;border-top-width:4px}.stat-card.filter-card.active.estado-comprado{background-color:#e3f2fd;border-top-width:4px}.stat-card.filter-card.active.estado-checkin{background-color:#d4edda;border-top-width:4px}.stat-card.filter-card.active.estado-caducado{background-color:#e9ecef;border-top-width:4px}.stat-card.filter-card.active.cortesia{background-color:#9c27b01a;border-top-width:4px;border-top-color:var(--color-cortesia)}.stat-card.filter-card.active.cortesia .stat-value{color:var(--color-cortesia)}.stat-card.filter-card.cortesia:hover{border-top-color:var(--color-cortesia)}.stat-card.filter-card:not(.estado-pendiente):not(.estado-confirmada):not(.estado-anulada):not(.estado-reservado):not(.estado-comprado):not(.estado-checkin):not(.estado-caducado).active{background-color:#e3f2fd;border-top:4px solid var(--color-comprado)}.stat-card.filter-card:not(.estado-pendiente):not(.estado-confirmada):not(.estado-anulada):not(.estado-reservado):not(.estado-comprado):not(.estado-checkin):not(.estado-caducado).active .stat-value{color:var(--color-comprado)}.processing-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:9999}.processing-content{background:#fff;padding:40px 60px;border-radius:12px;display:flex;flex-direction:column;align-items:center;gap:20px;box-shadow:0 4px 20px #0000004d}.processing-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.processing-text{font-size:18px;font-weight:600;color:#333;margin:0}.pagination-container{display:flex;flex-direction:column;gap:15px;margin-top:25px;padding:20px;background-color:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);min-height:120px;position:relative;z-index:1;animation:none!important;transition:none!important}.pagination-container:focus-within{outline:none}.pagination-container *{box-sizing:border-box;animation:none!important}.pagination-container,.pagination-container *,.pagination-info,.pagination-controls,.pagination-btn,.pagination-page-btn,.pagination-limit-select-wrapper,.pagination-limit-select{transition:none!important;animation:none!important}.pagination-info{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;font-size:14px;color:var(--text-secondary)}.pagination-limit-select-wrapper{position:relative;display:inline-block;width:130px;min-width:130px;max-width:130px;height:34px;min-height:34px;max-height:34px;isolation:isolate;transform:translateZ(0);backface-visibility:hidden}.pagination-limit-select{position:absolute;top:0;left:0;width:100%;height:100%;padding:6px 28px 6px 12px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:13px;cursor:pointer;transition:none;appearance:none;-webkit-appearance:none;-moz-appearance:none;transform:translateZ(0);backface-visibility:hidden}.pagination-limit-select:hover{border-color:var(--color-comprado)}.pagination-limit-select:focus{outline:none;border-color:var(--color-comprado);box-shadow:0 0 0 3px #17a2b833}.pagination-limit-select-wrapper:after{content:"";position:absolute;right:10px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--text-secondary);pointer-events:none;z-index:2}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap}.pagination-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;border:1px solid var(--border-color);border-radius:8px;background-color:var(--bg-primary);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition)}.pagination-btn:hover:not(:disabled){background-color:var(--color-comprado);border-color:var(--color-comprado);color:#fff}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-pages{display:flex;align-items:center;gap:5px}.pagination-page-btn{min-width:36px;height:36px;padding:0 10px;border:1px solid var(--border-color);border-radius:6px;background-color:var(--bg-primary);color:var(--text-primary);font-size:13px;font-weight:500;cursor:pointer;transition:var(--transition)}.pagination-page-btn:hover{background-color:var(--border-color)}.pagination-page-btn.active{background-color:var(--color-comprado);border-color:var(--color-comprado);color:#fff}.pagination-ellipsis{color:var(--text-secondary);padding:0 5px;font-size:14px}@media (max-width: 768px){.pagination-container{padding:15px}.pagination-info{flex-direction:column;align-items:flex-start;gap:10px}.pagination-controls{flex-direction:column;width:100%}.pagination-btn{width:100%;justify-content:center}.pagination-pages{order:-1;flex-wrap:wrap;justify-content:center}}@media (max-width: 480px){.pagination-page-btn{min-width:32px;height:32px;padding:0 8px;font-size:12px}.pagination-btn{padding:8px 12px;font-size:12px}}.ventas-table-container{background-color:var(--bg-card);border-radius:10px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);overflow:hidden;margin-bottom:20px}.ventas-table{width:100%;border-collapse:collapse;font-size:13px}.ventas-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:10}.ventas-table th{padding:14px 10px;text-align:left;font-weight:600;color:var(--text-primary);text-transform:uppercase;font-size:11px;letter-spacing:.5px;border-bottom:2px solid var(--border-color);white-space:nowrap}.ventas-table th:not(:last-child){border-right:1px solid var(--border-color)}.ventas-table td{padding:12px 10px;border-bottom:1px solid var(--border-color);color:var(--text-primary);vertical-align:middle}.ventas-table td:not(:last-child){border-right:1px solid #f0f0f0}.ventas-table tbody tr{transition:var(--transition)}.ventas-table tbody tr:hover{background-color:#f8f9fa}.ventas-table tbody tr.estado-reservado{border-left:4px solid var(--color-reservado)}.ventas-table tbody tr.estado-comprado{border-left:4px solid var(--color-comprado)}.ventas-table tbody tr.estado-checkin{border-left:4px solid var(--color-checkin)}.ventas-table tbody tr.estado-caducado{border-left:4px solid var(--color-caducado)}.ventas-table tbody tr.estado-anulado{border-left:4px solid var(--color-anulada)}.ventas-table tbody tr.fila-cortesia{background-color:#9c27b00d}.ventas-table tbody tr.fila-cortesia:hover{background-color:#9c27b01a}.ventas-table td.numero{text-align:right;font-family:Consolas,Monaco,monospace;font-weight:500}.ventas-table td.descuento{color:#dc3545;font-weight:600}.ventas-table td.fee{color:#28a745;font-weight:600}.ventas-table td.precio-final{color:var(--color-ingresos);font-weight:700;font-size:14px}.ventas-table td.cortesia-col{text-align:center}.descuento-con-promo{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.descuento-con-promo .promo-nombre{font-size:10px;color:#009688;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.descuento-con-promo .monto{color:#dc3545;font-weight:600}.fee-con-nombre{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.fee-con-nombre .fee-nombre{font-size:10px;color:#ff9800;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.fee-con-nombre .monto{color:#28a745;font-weight:600}.cortesia-badge-table{display:inline-block;background-color:var(--color-cortesia);color:#fff;font-size:10px;font-weight:600;padding:3px 10px;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.cortesia-text{color:var(--color-cortesia);font-weight:600;font-style:italic}@media (max-width: 1200px){.ventas-table{font-size:12px}.ventas-table th,.ventas-table td{padding:10px 8px}}@media (max-width: 992px){.ventas-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.ventas-table{min-width:1100px}}.tickets-stats.ventas-stats .stat-card.estado-comprado{border-top:3px solid var(--color-checkin)}.tickets-stats.ventas-stats .stat-card.estado-comprado .stat-value{color:var(--color-checkin)}.tickets-stats.ventas-stats .stat-card.ingresos-brutos{border-top:3px solid #17a2b8}.tickets-stats.ventas-stats .stat-card.ingresos-brutos .stat-value{color:#17a2b8}.tickets-stats.ventas-stats .stat-card.descuentos{border-top:3px solid #dc3545}.tickets-stats.ventas-stats .stat-card.descuentos .stat-value{color:#dc3545}.tickets-stats.ventas-stats .stat-card.cortesia{border-top:3px solid var(--color-cortesia)}.tickets-stats.ventas-stats .stat-card.cortesia .stat-value{color:var(--color-cortesia)}.ventas-header-actions{display:flex;justify-content:flex-end;margin-bottom:15px;padding:0 5px}.export-excel-btn{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#28a745,#218838);color:#fff;border:none;padding:10px 18px;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:var(--transition);box-shadow:var(--shadow-sm)}.export-excel-btn:hover:not(:disabled){background:linear-gradient(135deg,#218838,#1e7e34);box-shadow:var(--shadow-md);transform:translateY(-1px)}.export-excel-btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.export-excel-btn:disabled{background:linear-gradient(135deg,#6c757d,#5a6268);cursor:not-allowed;opacity:.7}.export-excel-btn svg{font-size:18px}@media (max-width: 768px){.ventas-header-actions{justify-content:stretch}.export-excel-btn{width:100%;justify-content:center}}.usuario-badge{display:inline-block;background-color:#6c757d;color:#fff;font-size:11px;font-weight:500;padding:3px 8px;border-radius:4px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:help}.usuario-badge:hover{background-color:#5a6268}.config-tabs{display:flex;gap:10px;margin-bottom:20px;border-bottom:1px solid #ddd;padding-bottom:10px;overflow-x:auto}.config-tab-button{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:16px;font-weight:500;color:#666;border-radius:4px;transition:all .2s ease;white-space:nowrap}.config-tab-button:hover{background-color:#f0f0f0;color:#333}.config-tab-button.active{background-color:#06c;color:#fff}.config-tab-content{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.sync-container{padding:20px;background-color:var(--bg-primary, #f8f9fa);min-height:100%}.sync-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border-color, #dee2e6);flex-wrap:wrap;gap:15px}.sync-header h2{margin:0;color:var(--text-primary, #212529);font-size:1.75rem;font-weight:600;display:flex;align-items:center;gap:10px}.sync-icon{color:var(--color-comprado, #17a2b8)}.sync-filters{background-color:var(--bg-card, #ffffff);padding:20px;border-radius:10px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1));margin-bottom:20px;border:1px solid var(--border-color, #dee2e6)}.sync-filters .evento-selector{width:100%;max-width:500px}.sync-filters .evento-selector label{display:block;font-weight:600;color:var(--text-primary, #212529);font-size:14px;margin-bottom:8px}.sync-info-bar{display:flex;flex-wrap:wrap;gap:20px;background-color:var(--bg-card, #ffffff);padding:15px 20px;border-radius:10px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1));margin-bottom:20px;border:1px solid var(--border-color, #dee2e6);border-left:4px solid var(--color-comprado, #17a2b8)}.sync-info-item{display:flex;align-items:center;gap:8px}.sync-info-item .info-label{font-weight:600;color:var(--text-secondary, #6c757d);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.sync-info-item .info-value{color:var(--text-primary, #212529);font-weight:500;font-size:14px}.sync-info-item .info-value.success{color:#28a745;font-weight:700}.sync-info-item .info-value.error{color:#dc3545;font-weight:700}.sync-table-container{background-color:var(--bg-card, #ffffff);border-radius:10px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1));border:1px solid var(--border-color, #dee2e6);overflow:hidden;margin-bottom:20px}.sync-table{width:100%;border-collapse:collapse;font-size:13px}.sync-table thead{background-color:#f8f9fa;position:sticky;top:0;z-index:10}.sync-table th{padding:14px 10px;text-align:left;font-weight:600;color:var(--text-primary, #212529);text-transform:uppercase;font-size:11px;letter-spacing:.5px;border-bottom:2px solid var(--border-color, #dee2e6);white-space:nowrap}.sync-table th:not(:last-child){border-right:1px solid var(--border-color, #dee2e6)}.sync-table td{padding:12px 10px;border-bottom:1px solid var(--border-color, #dee2e6);color:var(--text-primary, #212529);vertical-align:middle}.sync-table td:not(:last-child){border-right:1px solid #f0f0f0}.sync-table tbody tr{transition:all .2s ease-in-out}.sync-table tbody tr:hover{background-color:#f8f9fa}.sync-table tbody tr.fila-coincide{border-left:4px solid #28a745}.sync-table tbody tr.fila-difiere{border-left:4px solid #dc3545;background-color:#dc35450d}.sync-table tbody tr.fila-difiere:hover{background-color:#dc35451a}.sync-table td.elemento-col{font-weight:500;min-width:200px}.sync-table td.valor-col{text-align:center;font-family:Consolas,Monaco,monospace;font-weight:500;min-width:120px}.sync-table td.estado-col{text-align:center;min-width:100px}.estado-badge{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.estado-badge.coincide{background-color:#d4edda;color:#155724}.estado-badge.difiere{background-color:#f8d7da;color:#721c24}.sync-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background-color:var(--bg-card, #ffffff);border-radius:10px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1));border:1px solid var(--border-color, #dee2e6);gap:20px}.sync-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid var(--color-comprado, #17a2b8);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-loading p{color:var(--text-secondary, #6c757d);font-size:16px;margin:0}.sync-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background-color:#f8d7da;border-radius:10px;border:1px solid #f5c6cb;gap:15px;color:#721c24}.sync-error svg{font-size:48px}.sync-error p{margin:0;font-size:16px;text-align:center}.sync-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;background-color:var(--bg-card, #ffffff);border-radius:10px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1));border:1px solid var(--border-color, #dee2e6);color:var(--text-secondary, #6c757d);gap:15px}.sync-empty .empty-icon{font-size:48px;color:var(--border-color, #dee2e6)}.sync-empty p{margin:0;font-size:16px;text-align:center}.sync-resultado{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;border-radius:10px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1));border:2px solid;text-align:center;gap:10px}.sync-resultado.success{background-color:#d4edda;border-color:#28a745;color:#155724}.sync-resultado.error{background-color:#f8d7da;border-color:#dc3545;color:#721c24}.resultado-icono{font-size:64px;margin-bottom:10px}.sync-resultado h3{margin:0;font-size:1.5rem;font-weight:700;text-transform:uppercase;letter-spacing:1px}.sync-resultado p{margin:0;font-size:14px;max-width:600px}@media (max-width: 768px){.sync-container{padding:15px}.sync-header{flex-direction:column;align-items:flex-start}.sync-header h2{font-size:1.4rem}.sync-info-bar{flex-direction:column;gap:10px}.sync-info-item{width:100%;justify-content:space-between}.sync-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.sync-table{min-width:600px}.sync-table th,.sync-table td{padding:10px 8px;font-size:12px}.sync-filters .evento-selector{max-width:100%}.sync-resultado{padding:30px 20px}.sync-resultado h3{font-size:1.2rem}.resultado-icono{font-size:48px}}@media (max-width: 480px){.sync-container{padding:10px}.sync-filters{padding:15px}.sync-table th,.sync-table td{padding:8px 6px;font-size:11px}.estado-badge{padding:4px 8px;font-size:10px}}
