:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app{min-height:100vh;display:flex;flex-direction:column;width:100%}.main-content{flex:1;padding:2rem;max-width:1200px;margin:0 auto;width:100%}.navbar{background-color:#2c3e50;padding:.5rem 0;box-shadow:0 2px 4px #0000001a;width:100%}.nav-container{max-width:100%;margin:0;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{color:#fff;font-size:1.5rem;font-weight:700;text-decoration:none;display:flex;align-items:center;gap:.75rem}.nav-logo-img{height:40px;width:auto;object-fit:contain;border:2px solid white;border-radius:50%;padding:.5rem;background-color:#ffffff1a}.nav-logo-text{font-size:1.5rem;font-weight:700}.nav-menu{display:flex;list-style:none;gap:2rem;margin:0;padding:0;align-items:center}.nav-link{color:#fff;text-decoration:none;transition:color .3s}.nav-link:hover{color:#3498db}.btn-link{background:none;border:none;cursor:pointer;font-size:1rem;padding:0}.hero{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;margin-bottom:3rem}.hero h1{font-size:3rem;margin-bottom:1rem}.hero p{font-size:1.5rem;margin-bottom:2rem}.cta-buttons{display:flex;gap:1rem;justify-content:center}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:3rem}.feature{padding:2rem;background:#f8f9fa;border-radius:8px;text-align:center}.feature h3{margin-bottom:1rem;color:#2c3e50}.menu-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.menu-header-actions{display:flex;gap:1rem;align-items:center}.cart-button{position:relative;font-weight:600}.cart-success{position:fixed;top:100px;right:20px;z-index:1000;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.menu h1{color:#2c3e50;margin:0}.menu-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.menu-item{padding:0;background:#fff;border:1px solid #e0e0e0;border-radius:8px;transition:transform .3s,box-shadow .3s;overflow:hidden}.menu-item:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.menu-item-image{width:100%;height:200px;overflow:hidden;background:#f0f0f0}.menu-item-image img{width:100%;height:100%;object-fit:cover;display:block}.menu-item h3{color:#2c3e50;margin:1rem 1.5rem .5rem}.menu-item .description{color:#666;margin:0 1.5rem 1rem}.menu-item .price{font-size:1.25rem;font-weight:700;color:#27ae60;margin:0 1.5rem}.menu-item .category{display:inline-block;padding:.25rem .75rem;background:#3498db;color:#fff;border-radius:12px;font-size:.875rem;margin:.5rem 1.5rem 1rem}.add-to-cart-btn{width:calc(100% - 3rem);margin:0 1.5rem 1.5rem}.unavailable{color:#e74c3c;font-weight:600;text-align:center;margin:0 1.5rem 1.5rem}.login-page{display:flex;justify-content:center;align-items:center;min-height:60vh}.login-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a;width:100%;max-width:400px}.login-container h2{text-align:center;margin-bottom:1.5rem;color:#2c3e50}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#2c3e50;font-weight:500}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.form-group textarea{resize:vertical;min-height:100px}.form-group input:focus,.form-group textarea:focus{outline:2px solid #3498db;outline-offset:2px;border-color:#3498db;box-shadow:0 0 0 3px #3498db33}.form-group input:focus-visible,.form-group textarea:focus-visible{outline:2px solid #3498db;outline-offset:2px}.form-actions{display:flex;gap:1rem;margin-top:1rem}.form-actions .btn{flex:1}.form-group-checkbox{margin-bottom:1.5rem}.form-group-checkbox label{display:flex;align-items:flex-start;cursor:pointer;font-weight:500}.form-group-checkbox input[type=checkbox]{width:auto;margin-right:.75rem;margin-top:.25rem;cursor:pointer;min-width:18px;height:18px}.form-group-checkbox input[type=checkbox]:focus{outline:2px solid #3498db;outline-offset:2px}.form-group-checkbox input[type=checkbox]:focus-visible{outline:2px solid #3498db;outline-offset:2px}.checkbox-label{color:#2c3e50;font-weight:500}.help-text{margin-top:.5rem;font-size:.875rem;color:#666;line-height:1.4}.form-group-checkbox .help-text{margin-left:1.75rem}.image-preview{margin-top:1rem;border:2px solid #e0e0e0;border-radius:8px;padding:.5rem;background:#f8f9fa;max-width:300px}.image-preview img{width:100%;height:auto;border-radius:4px;display:block}.auth-link{text-align:center;margin-top:1rem;color:#666}.auth-link a{color:#3498db;text-decoration:none}.auth-link a:hover{text-decoration:underline}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;text-decoration:none;display:inline-block;transition:background-color .3s}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6;color:#fff}.btn-secondary:hover{background-color:#7f8c8d}.btn:disabled{background-color:#bdc3c7;cursor:not-allowed;opacity:.6}.btn:focus{outline:2px solid #2c3e50;outline-offset:2px}.btn:focus-visible{outline:2px solid #2c3e50;outline-offset:2px}.btn-primary:focus,.btn-primary:focus-visible{outline-color:#2980b9}.error{background-color:#e74c3c;color:#fff;padding:1rem;border-radius:4px;margin-bottom:1rem;text-align:center}.error-message{background-color:#fee;color:#c33;padding:1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #e74c3c}.success-message{background-color:#d4edda;color:#155724;padding:1rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #28a745}.reservations-container{width:100%;max-width:1200px;margin:0 auto}.reservations-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.reservation-form-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a}.reservation-form-section h1{color:#2c3e50;margin-bottom:.5rem}.section-description{color:#666;margin-bottom:2rem}.reservation-form{margin-top:1.5rem}.reservation-form select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit;background-color:#fff;cursor:pointer}.reservation-form select:focus{outline:2px solid #3498db;outline-offset:2px;border-color:#3498db}.available-tables-header{background:#e7f3ff;border-left:4px solid #3498db;padding:.75rem 1rem;margin-bottom:1rem;border-radius:4px}.available-tables-header p{margin:0;color:#2c3e50;font-weight:600;font-size:.95rem}.table-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:.75rem;padding:1rem;background:#f8f9fa;border-radius:8px}.table-icon{position:relative;aspect-ratio:1;background:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;padding:.5rem}.table-icon:hover:not(.unavailable){border-color:#3498db;transform:translateY(-2px);box-shadow:0 4px 12px #3498db4d}.table-icon.selected{border-color:#27ae60;background:linear-gradient(135deg,#d4edda,#c3e6cb);box-shadow:0 4px 12px #27ae604d}.table-icon.unavailable{background:#f8d7da;border-color:#dc3545;cursor:not-allowed;opacity:.6}.table-icon-inner{display:flex;flex-direction:column;align-items:center;gap:.25rem;width:100%;position:relative}.table-number{font-size:1.25rem;font-weight:700;color:#2c3e50}.table-icon.selected .table-number{color:#27ae60}.table-icon.unavailable .table-number{color:#721c24}.table-info{display:flex;flex-direction:column;align-items:center;gap:.15rem;font-size:.65rem}.table-capacity{font-weight:600;color:#555;font-size:.65rem}.table-location{display:flex;align-items:center;gap:.25rem;font-size:.6rem;color:#888;text-transform:uppercase}.location-icon{font-size:.9rem}.table-unavailable-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#dc3545;font-weight:700;pointer-events:none}.selected-table-info{margin-top:1rem;padding:.75rem;background:#d4edda;color:#155724;border-radius:4px;text-align:center;font-weight:600;border-left:4px solid #28a745}.date-first-message{padding:2rem;background:#fff3cd;border:2px dashed #ffc107;border-radius:8px;text-align:center;margin-top:1rem}.date-first-message p{margin:0;color:#856404;font-size:1rem;font-weight:500}.no-tables-message{padding:2rem;background:#f8f9fa;border:2px solid #ddd;border-radius:8px;text-align:center;margin-top:1rem;color:#666;font-style:italic}.my-reservations-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a;max-height:700px;overflow-y:auto}.my-reservations-section h2{color:#2c3e50;margin-bottom:1.5rem}.no-reservations{color:#666;text-align:center;padding:2rem;background:#f8f9fa;border-radius:4px}.reservations-list{display:flex;flex-direction:column;gap:1rem}.reservation-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;background:#fafafa;transition:box-shadow .3s}.reservation-card:hover{box-shadow:0 4px 12px #0000001a}.reservation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.reservation-header h3{margin:0;color:#2c3e50;display:flex;align-items:center;gap:.5rem}.table-location-icon-badge{display:inline-flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:6px;padding:.25rem .4rem;font-size:1rem;cursor:help;transition:all .2s ease}.table-location-icon-badge:hover{background:#e0e0e0;transform:scale(1.1)}.status-badge{padding:.35rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;text-transform:uppercase}.status-pending{background-color:#fff3cd;color:#856404}.status-confirmed{background-color:#d1ecf1;color:#0c5460}.status-cancelled{background-color:#f8d7da;color:#721c24}.status-completed{background-color:#d4edda;color:#155724}.reservation-details{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.detail-row{display:flex;justify-content:space-between;gap:1rem}.detail-label{font-weight:600;color:#555;min-width:140px}.detail-value{color:#333;text-align:right;flex:1}.btn-cancel{width:100%;margin-top:.5rem}.admin-reservations-container{width:100%}.admin-reservations-content{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.admin-header h1{color:#2c3e50;margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:8px;text-align:center;box-shadow:0 4px 6px #0000001a}.stat-card.stat-pending{background:linear-gradient(135deg,#f093fb,#f5576c)}.stat-card.stat-confirmed{background:linear-gradient(135deg,#4facfe,#00f2fe)}.stat-card.stat-completed{background:linear-gradient(135deg,#43e97b,#38f9d7)}.stat-card.stat-cancelled{background:linear-gradient(135deg,#fa709a,#fee140)}.stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{font-size:.875rem;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.filters-section{background:#f8f9fa;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.filters-row{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:1rem;align-items:end}.filter-group{display:flex;flex-direction:column}.filter-group label{font-weight:600;color:#2c3e50;margin-bottom:.5rem;font-size:.875rem}.filter-group input,.filter-group select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.btn-clear-filters{padding:.75rem 1rem;white-space:nowrap}.reservations-table-container{overflow-x:auto;margin-bottom:1rem}.reservations-table{width:100%;border-collapse:collapse;background:#fff}.reservations-table thead{background:#2c3e50;color:#fff}.reservations-table th{padding:1rem;text-align:left;font-weight:600;white-space:nowrap}.reservations-table td{padding:1rem;border-bottom:1px solid #e0e0e0}.reservations-table tbody tr:hover{background:#f8f9fa}.customer-name{font-weight:600;color:#2c3e50}.customer-email{color:#666;font-size:.875rem}.table-number{font-weight:600;color:#3498db}.reservation-datetime{white-space:nowrap}.guests-count{text-align:center;font-weight:600}.special-requests{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#666;font-size:.875rem}.no-results{text-align:center;padding:3rem;color:#666}.no-results p{margin:0;font-size:1.125rem}.results-count{text-align:center;color:#666;font-size:.875rem;padding:1rem;background:#f8f9fa;border-radius:4px}.loading{text-align:center;padding:3rem;color:#666;font-size:1.25rem}@media(max-width:968px){.reservations-content,.filters-row{grid-template-columns:1fr}.btn-clear-filters{width:100%}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.stat-value{font-size:2rem}.reservations-table{font-size:.875rem}.reservations-table th,.reservations-table td{padding:.75rem .5rem}}@media(max-width:640px){.admin-header{flex-direction:column;gap:1rem;align-items:stretch}.admin-header .btn{width:100%}.stats-grid{grid-template-columns:1fr}.main-content{padding:1rem}}.checkout-container{padding:2rem 0;min-height:80vh}.checkout-content{max-width:1200px;margin:0 auto}.checkout-content h1{color:#2c3e50;margin-bottom:2rem;font-size:2rem}.checkout-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.cart-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a}.cart-section h2{color:#2c3e50;margin-bottom:1.5rem;font-size:1.5rem}.empty-cart{text-align:center;color:#95a5a6;padding:2rem;font-size:1.1rem}.cart-items{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.cart-item{display:grid;grid-template-columns:2fr 2fr 1fr;gap:1rem;padding:1rem;border:1px solid #ddd;border-radius:4px;align-items:center}.cart-item-info h3{margin:0 0 .5rem;color:#2c3e50;font-size:1rem}.cart-item-price{color:#95a5a6;font-size:.9rem;margin:0}.cart-item-controls{display:flex;flex-direction:column;gap:.5rem;align-items:center}.quantity-controls{display:flex;align-items:center;gap:.5rem}.quantity-btn{background-color:#3498db;color:#fff;border:none;width:30px;height:30px;border-radius:4px;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background-color .3s}.quantity-btn:hover{background-color:#2980b9}.quantity-btn:disabled{background-color:#bdc3c7;cursor:not-allowed}.quantity{min-width:30px;text-align:center;font-weight:600;color:#2c3e50}.btn-remove{background:none;border:1px solid #e74c3c;color:#e74c3c;padding:.25rem .75rem;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .3s}.btn-remove:hover{background-color:#e74c3c;color:#fff}.cart-item-total{text-align:right;font-weight:600;color:#2c3e50;font-size:1.1rem}.order-type-section{margin:2rem 0;padding:1.5rem;background-color:#f8f9fa;border-radius:4px}.order-type-section h3{color:#2c3e50;margin-bottom:1rem;font-size:1.1rem}.order-type-options{display:flex;gap:1.5rem;margin-bottom:1rem}.radio-option{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#2c3e50}.radio-option input[type=radio]{cursor:pointer;width:18px;height:18px}.cart-total{border-top:2px solid #3498db;padding-top:1rem;margin-top:1rem}.cart-total h3{text-align:right;color:#2c3e50;font-size:1.5rem;margin:0}.payment-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a}.payment-section h2{color:#2c3e50;margin-bottom:1.5rem;font-size:1.5rem}.payment-init{text-align:center;padding:2rem 0}.payment-init .help-text{margin-bottom:1.5rem;color:#95a5a6}.payment-form{display:flex;flex-direction:column;gap:1.5rem}.payment-element-container{padding:1rem 0}.pay-button{width:100%;padding:1rem;font-size:1.1rem;font-weight:600}.payment-error{margin:1rem 0}.stripe-payment-wrapper{margin-top:1rem}.test-mode-notice{margin-top:1.5rem;padding:1rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;border-left:4px solid #ffc107}.test-mode-notice p{margin:0;color:#856404;font-size:.9rem}.test-mode-notice strong{color:#856404}.payment-success-container{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:2rem}.success-card{background:#fff;padding:3rem;border-radius:8px;box-shadow:0 2px 12px #0000001a;text-align:center;max-width:500px;width:100%}.success-icon{width:80px;height:80px;background:linear-gradient(135deg,#43e97b,#38f9d7);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem;color:#fff;margin:0 auto 1.5rem;font-weight:700}.success-card h1{color:#27ae60;margin-bottom:1rem;font-size:2rem}.success-message{color:#2c3e50;margin-bottom:2rem;font-size:1.1rem}.order-details{background-color:#f8f9fa;padding:1.5rem;border-radius:4px;margin-bottom:2rem}.order-number{font-size:1.2rem;color:#2c3e50;margin-bottom:.5rem}.order-number strong{color:#3498db}.success-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}@media(max-width:968px){.checkout-grid{grid-template-columns:1fr}.cart-item{grid-template-columns:1fr;gap:.75rem}.cart-item-total{text-align:left}.order-type-options{flex-direction:column;gap:.75rem}}@media(max-width:640px){.checkout-content h1{font-size:1.5rem}.cart-section,.payment-section{padding:1rem}.success-card{padding:2rem 1rem}.success-icon{width:60px;height:60px;font-size:2rem}.success-card h1{font-size:1.5rem}.success-actions{flex-direction:column}.success-actions .btn{width:100%}}
