:root{--primary: #2563eb;--primary-dark: #1d4ed8;--bg-dark: #0f172a;--bg-light: #f8fafc;--text-main: #334155;--text-light: #94a3b8;--white: #ffffff;--border: #e2e8f0}body{margin:0;font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-light);color:var(--text-main)}*{box-sizing:border-box}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer}.btn-primary{background-color:var(--primary);color:var(--white);border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;transition:background-color .2s}.btn-primary:hover{background-color:var(--primary-dark)}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:.5rem;font-size:1rem}.error{color:#ef4444;margin-bottom:1rem;padding:.75rem;background-color:#fee2e2;border-radius:.5rem}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:var(--bg-dark)}.auth-card{background:var(--white);padding:2rem;border-radius:1rem;width:100%;max-width:400px;box-shadow:0 4px 6px -1px #0000001a}.auth-card h2{margin-top:0;text-align:center;color:var(--bg-dark)}.dashboard-layout{display:flex;min-height:100vh}.sidebar{width:250px;background-color:var(--bg-dark);color:var(--white);padding:1.5rem;display:flex;flex-direction:column;transition:width .3s ease,padding .3s ease;position:relative}.sidebar.collapsed{width:80px;padding:1.5rem .5rem}.sidebar-toggle{position:absolute;top:1rem;right:-15px;background:var(--bg-dark);border:2px solid var(--white);color:var(--white);width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1rem;z-index:100;transition:all .2s}.sidebar-toggle:hover{background:var(--primary);transform:scale(1.1)}.sidebar .brand{font-size:1.5rem;font-weight:700;margin-bottom:2rem;white-space:nowrap;overflow:hidden;text-align:center}.sidebar .user-info{margin-bottom:2rem;color:var(--text-light);font-size:.9rem;white-space:nowrap;overflow:hidden;text-align:center}.sidebar ul{list-style:none;padding:0;margin:0;flex:1}.sidebar li{margin-bottom:.5rem}.sidebar a{display:block;padding:.75rem 1rem;color:var(--text-light);border-radius:.5rem;text-decoration:none;transition:all .2s;white-space:nowrap;overflow:hidden;text-align:center}.sidebar.collapsed a{padding:.75rem .5rem;font-size:1.5rem}.sidebar a:hover{background-color:#ffffff1a;color:var(--white)}.btn-logout{background:none;border:1px solid rgba(255,255,255,.2);color:var(--white);padding:.75rem;border-radius:.5rem;margin-top:auto;white-space:nowrap;overflow:hidden;text-align:center}.sidebar.collapsed .btn-logout{font-size:1.5rem;padding:.75rem .5rem}.btn-logout:hover{background-color:#ffffff1a}.content{flex:1;padding:2rem;overflow-y:auto}.bookings-table{background:var(--white);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}table{width:100%;border-collapse:collapse}th,td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}th{background-color:#f1f5f9;font-weight:600;color:var(--text-main)}tr:last-child td{border-bottom:none}.settings-section{background:#fff;padding:1.5rem;border-radius:.5rem;margin-bottom:2rem;box-shadow:0 1px 3px #0000001a}.add-form{display:flex;gap:1rem;margin-bottom:1rem}.table-list{display:grid;gap:.5rem}.table-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f8fafc;border-radius:.25rem}.btn-danger{background-color:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:.25rem}.table-selector{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.table-chip{padding:.5rem 1rem;border:1px solid #e2e8f0;border-radius:1rem;cursor:pointer;transition:all .2s}.table-chip.selected{background-color:var(--primary);color:#fff;border-color:var(--primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:.5rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.btn-secondary{background:#e2e8f0;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600}.btn-small{padding:.25rem .5rem;font-size:.8rem;background:#e2e8f0;border:none;border-radius:.25rem;cursor:pointer}.floor-plan-editor{display:flex;height:calc(100vh - 100px);gap:1rem}.toolbar{width:250px;background:#f8fafc;padding:1rem;border-right:1px solid #e2e8f0}.canvas-container{flex:1;background-color:#e5e5f7;background-image:radial-gradient(#444cf7 .5px,transparent .5px),radial-gradient(#444cf7 .5px,#e5e5f7 .5px);background-size:20px 20px;background-position:0 0,10px 10px;position:relative;overflow:hidden;border:1px solid #cbd5e1;border-radius:.5rem}.table-node{box-shadow:0 4px 6px -1px #0000001a;transition:box-shadow .2s,border-color .2s;font-weight:700;flex-direction:column}.table-node.selected{border-color:#2563eb!important;box-shadow:0 0 0 4px #2563eb33;z-index:10}.properties-panel{display:flex;flex-direction:column;gap:1rem}.properties-panel label{display:flex;flex-direction:column;font-size:.9rem;font-weight:500}.properties-panel input,.properties-panel select{margin-top:.25rem;padding:.5rem;border:1px solid #cbd5e1;border-radius:.25rem}.view-toggle{display:flex;background:#e2e8f0;padding:.25rem;border-radius:.5rem;gap:.25rem}.view-toggle button{border:none;background:transparent;padding:.5rem 1rem;border-radius:.25rem;cursor:pointer;font-weight:500;color:#64748b}.view-toggle button.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0000001a}.status-badge{padding:.25rem .5rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-confirmed{background:#dbeafe;color:#1e40af}.status-seated{background:#dcfce7;color:#166534}.status-cancelled{background:#fee2e2;color:#991b1b}.status-finished{background:#f1f5f9;color:#475569}.settings-page{max-width:800px}.hours-grid{display:flex;flex-direction:column;gap:1rem}.day-row{display:flex;align-items:flex-start;gap:1rem;padding:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem}.day-label{width:150px;display:flex;align-items:center;gap:.5rem}.shifts-container{flex:1;display:flex;flex-direction:column;gap:.5rem}.shift-row{display:flex;gap:1rem;align-items:center}.shift-row label{display:flex;flex-direction:column;font-size:.8rem;color:#64748b}.shift-row input{padding:.25rem;border:1px solid #cbd5e1;border-radius:.25rem}.closed-badge{background:#f1f5f9;color:#64748b;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem}.switch{position:relative;display:inline-block;width:40px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.4s}.slider:before{position:absolute;content:"";height:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s}input:checked+.slider{background-color:#22c55e}input:checked+.slider:before{transform:translate(16px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.hint{font-size:.875rem;color:#64748b;margin-bottom:.5rem}.compact{margin-bottom:.5rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;background:#fff;padding:1rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a}.date-nav{display:flex;align-items:center;gap:.5rem}.date-picker{padding:.5rem;border:1px solid #e2e8f0;border-radius:.25rem;font-family:inherit}.stats-bar{display:flex;gap:2rem}.stat-item{display:flex;flex-direction:column;align-items:center}.stat-label{font-size:.75rem;text-transform:uppercase;color:#64748b;font-weight:600}.stat-value{font-size:1.25rem;font-weight:700;color:#0f172a}.no-data{text-align:center;padding:2rem;color:#64748b;font-style:italic}.timeline-container{display:flex;flex-direction:column;overflow-x:auto;background:#fff;border:1px solid #e2e8f0;border-radius:.5rem}.timeline-header{display:flex;border-bottom:1px solid #e2e8f0;background:#f8fafc;position:sticky;top:0;z-index:10}.timeline-corner{width:100px;min-width:100px;padding:.5rem;font-weight:700;border-right:1px solid #e2e8f0;background:#f8fafc;position:sticky;left:0;z-index:20}.timeline-ruler{position:relative;height:40px}.time-marker{position:absolute;top:0;bottom:0;padding-left:4px;font-size:.75rem;color:#64748b;border-left:1px solid #e2e8f0}.timeline-body{display:flex;flex-direction:column}.timeline-row{display:flex;border-bottom:1px solid #f1f5f9;height:60px}.timeline-row-label{width:100px;min-width:100px;padding:.5rem;display:flex;align-items:center;justify-content:center;font-weight:500;border-right:1px solid #e2e8f0;background:#fff;position:sticky;left:0;z-index:10}.timeline-row-content{position:relative;height:100%}.grid-line{position:absolute;top:0;bottom:0;border-left:1px solid #f1f5f9}.timeline-booking{position:absolute;top:4px;bottom:4px;background:#3b82f6;color:#fff;border-radius:4px;padding:2px 4px;font-size:.75rem;overflow:hidden;cursor:pointer;box-shadow:0 1px 2px #0000001a;transition:transform .1s;z-index:5}.timeline-booking:hover{transform:scale(1.02);z-index:10}.timeline-booking.status-confirmed{background:#3b82f6}.timeline-booking.status-seated{background:#22c55e}.timeline-booking.status-finished{background:#94a3b8}.timeline-booking.status-cancelled{background:#ef4444;opacity:.5}.booking-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.current-time-line{position:absolute;top:0;bottom:0;width:2px;background:#ef4444;z-index:30;pointer-events:none}.current-time-line:after{content:"";position:absolute;top:-4px;left:-4px;width:10px;height:10px;background:#ef4444;border-radius:50%}.past-fade{position:absolute;top:0;bottom:0;left:0;background:#f1f5f980;z-index:4;pointer-events:none}.booking-details{font-size:.7rem;opacity:.9}@media(min-width:769px)and (max-width:1024px){.dashboard-layout{display:grid;grid-template-columns:60px 1fr}.sidebar{width:60px}.sidebar .brand,.sidebar .user-info,.sidebar ul li a:after{display:none}.sidebar ul li a{justify-content:center;padding:15px 0}.sidebar-toggle{display:none}.stats-bar{grid-template-columns:repeat(2,1fr)}.reports-grid{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-layout{flex-direction:column}.sidebar{width:100%;padding:1rem;position:fixed;top:0;left:0;z-index:1000;height:auto;max-height:60px;overflow:hidden;transition:max-height .3s ease}.sidebar.collapsed{width:100%;max-height:60px}.sidebar:not(.collapsed){max-height:100vh;overflow-y:auto}.sidebar-toggle{position:absolute;top:1rem;right:1rem}.sidebar .brand{font-size:1.2rem}.sidebar ul{margin-top:1rem}.content{margin-top:70px;padding:1rem;width:100%}.dashboard-header{flex-direction:column;gap:1rem}.date-nav{width:100%;justify-content:space-between}.date-picker{flex:1;max-width:200px}.stats-bar{flex-wrap:wrap;gap:.5rem}.stat-item{flex:1 1 calc(50% - .5rem);min-width:120px}.actions{width:100%}.view-toggle{flex-wrap:wrap;gap:.5rem}.view-toggle button{flex:1;min-width:70px}.bookings-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.bookings-table table{min-width:800px}.bookings-table th,.bookings-table td{padding:.5rem;font-size:.85rem}.modal-content{width:95%;max-width:95%;margin:1rem;max-height:90vh;overflow-y:auto}.form-row{flex-direction:column}.form-row .form-group{width:100%}.floor-plan-editor{flex-direction:column}.canvas-container{width:100%;height:400px}.properties-panel{width:100%;position:static;max-height:none}.timeline-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.timeline-grid{min-width:1200px}.settings-section{padding:1rem}.table-list{gap:.5rem}.notifications-panel{right:0!important;left:0!important;width:100%!important;max-width:100%!important;border-radius:0!important;top:60px!important}.customer-management{padding:1rem}.customer-management .settings-section{grid-template-columns:1fr!important}}@media(max-width:480px){h2{font-size:1.5rem}h3{font-size:1.2rem}.btn-primary,.btn-secondary{padding:.6rem 1rem;font-size:.9rem}.btn-small{padding:.3rem .6rem;font-size:.75rem}.stat-item{flex:1 1 100%}.stat-value{font-size:1.5rem}.bookings-table th,.bookings-table td{padding:.4rem;font-size:.75rem}input,select,textarea{font-size:16px}.form-group label{font-size:.9rem}.modal-content{padding:1rem}.modal-header h3{font-size:1.2rem}.auth-card{padding:1.5rem;margin:1rem}.widget-generator pre{font-size:.75rem;padding:10px}}@media(hover:none)and (pointer:coarse){button,.btn-primary,.btn-secondary,.btn-icon{min-height:44px;min-width:44px}.table-item{padding:1rem}.view-toggle button{padding:.75rem 1rem}.btn-primary,.btn-secondary,.stat-item,.table-item{-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}}@media(max-width:768px)and (orientation:landscape){.sidebar:not(.collapsed){max-height:80px}.content{margin-top:90px}.modal-content{max-height:85vh}}@media print{.sidebar,.dashboard-header .actions,.btn-primary,.btn-secondary,.sidebar-toggle{display:none!important}.content{margin:0;padding:0}.bookings-table{overflow:visible}}.date-picker-container{display:flex;align-items:center;gap:15px;background:#fff;padding:12px 20px;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #f1f5f9}.date-label{font-weight:600;color:#475569;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.date-inputs{display:flex;align-items:center;gap:12px}.date-input-wrapper{position:relative;display:flex;align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:0 12px;transition:all .2s ease}.date-input-wrapper:hover{border-color:#cbd5e1;background:#fff}.date-input-wrapper:focus-within{border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.date-input-icon{color:#64748b;margin-right:8px;font-size:1.1rem;pointer-events:none}.date-input{border:none;outline:none;background:transparent;font-family:inherit;font-size:.95rem;color:#334155;padding:8px 0;cursor:pointer;min-width:130px}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.5;transition:opacity .2s}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}.date-separator{color:#94a3b8;font-weight:500;font-size:.9rem}.date-controls{display:flex;flex-direction:column;gap:12px;align-items:flex-end}.quick-select{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.quick-select button{padding:6px 14px;font-size:.85rem;font-weight:500;background:#fff;border:1px solid #e2e8f0;border-radius:20px;color:#64748b;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000000d}.quick-select button:hover{background:#f8fafc;color:#3b82f6;border-color:#bfdbfe;transform:translateY(-1px)}.quick-select button:active{transform:translateY(0)}@media(max-width:768px){.reports-header{flex-direction:column;align-items:flex-start;gap:20px}.date-controls{align-items:flex-start;width:100%}.date-picker-container{width:100%;flex-direction:column;align-items:flex-start;gap:15px}.date-inputs{width:100%;flex-direction:column}.date-input-wrapper,.date-input{width:100%}.quick-select{justify-content:flex-start}}.btn-icon-action{background:none;border:none;cursor:pointer;font-size:1.1rem;padding:4px;border-radius:4px;transition:background .2s}.btn-icon-action:hover{background:#f1f5f9}.btn-icon-action.btn-danger:hover{background:#fee2e2}.settings-accordion{display:flex;flex-direction:column;gap:1rem}.accordion-item{border:1px solid #e2e8f0;border-radius:8px;background:#fff;overflow:hidden}.accordion-header{padding:1rem;background:#f8fafc;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-weight:600}.accordion-header:hover{background:#f1f5f9}.accordion-content{padding:1rem;border-top:1px solid #e2e8f0}.accordion-header .icon{font-size:1.2rem;color:#64748b}
