: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}}.navbar-modern{position:fixed;top:0;left:0;right:0;z-index:1000;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 20px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-container-modern{max-width:1400px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;gap:2rem}.nav-logo-modern{display:flex;align-items:center;gap:.75rem;text-decoration:none;z-index:1001}.nav-logo-img-modern{width:45px;height:45px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.nav-logo-text-modern{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px}.nav-menu-wrapper{display:flex;align-items:center;justify-content:space-between;flex:1;gap:2rem}.nav-menu-desktop{display:flex;align-items:center;gap:.5rem;list-style:none;margin:0;padding:0}.nav-menu-left{justify-content:flex-start}.nav-menu-right{justify-content:flex-end;margin-left:auto}.nav-menu-desktop .nav-item{list-style:none;position:relative}.nav-menu-desktop .nav-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;color:#fff;text-decoration:none;font-weight:500;font-size:.95rem;border-radius:8px;transition:all .3s ease;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);cursor:pointer}.nav-menu-desktop .nav-link:hover{background:#fff3;border-color:#fff6;transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.nav-menu-desktop .nav-link:active{transform:translateY(0)}.nav-icon{font-size:1.25rem;flex-shrink:0}.nav-icon-small{font-size:1rem;flex-shrink:0}.nav-icon-large{font-size:1.75rem;flex-shrink:0}.icon-only-item{list-style:none}.icon-only-link{display:flex;align-items:center;justify-content:center;padding:.75rem;color:#fff;text-decoration:none;border-radius:50%;transition:all .3s ease;background:#ffffff26;border:2px solid rgba(255,255,255,.3);cursor:pointer;position:relative}.icon-only-link:hover{background:#ffffff40;border-color:#ffffff80;transform:scale(1.1);box-shadow:0 4px 12px #0003}.cart-badge{position:absolute;top:-6px;right:-6px;background:linear-gradient(135deg,#f44336,#e91e63);color:#fff;font-size:.75rem;font-weight:700;min-width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:10px;padding:0 6px;box-shadow:0 2px 8px #f4433680;border:2px solid #667eea;line-height:1}.cart-link-mobile{position:relative;display:flex;align-items:center;gap:1rem}.cart-badge-mobile{position:absolute;right:1rem;background:linear-gradient(135deg,#f44336,#e91e63);color:#fff;font-size:.8rem;font-weight:700;min-width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:12px;padding:0 8px;box-shadow:0 2px 8px #f4433680;border:2px solid rgba(255,255,255,.3);line-height:1}.dropdown-item{position:relative}.dropdown-toggle{display:flex;align-items:center;gap:.5rem}.dropdown-menu{position:absolute;top:calc(100% + .5rem);left:0;min-width:220px;background:linear-gradient(135deg,#667eea,#764ba2);border:1px solid rgba(255,255,255,.3);border-radius:12px;box-shadow:0 8px 24px #0000004d;padding:.5rem;z-index:1002;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dropdown-menu-right{left:auto;right:0}.dropdown-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#fff;font-weight:600;font-size:.95rem;background:#ffffff1a;border-radius:8px;margin-bottom:.25rem}.dropdown-divider{height:1px;background:#fff3;margin:.5rem 0}.dropdown-item-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#fff;text-decoration:none;font-weight:500;font-size:.95rem;border-radius:8px;transition:all .3s ease;background:transparent;border:1px solid transparent;width:100%;cursor:pointer;font-family:inherit}.dropdown-item-link:hover{background:#ffffff26;border-color:#ffffff4d;transform:translate(4px)}.logout-link{color:#ffcdd2}.logout-link:hover{background:#f4433633;border-color:#f4433666}.restaurant-breadcrumb{background:#ffffff26!important;border:1px solid rgba(255,255,255,.3)!important;font-family:inherit;font-weight:600!important}.restaurant-breadcrumb:hover{background:#ffffff40!important;border-color:#ffffff80!important}.btn-link{background:#f4433633;border:1px solid rgba(244,67,54,.4);font-family:inherit}.btn-link:hover{background:#f443364d;border-color:#f4433699}.mobile-menu-toggle{display:none;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.5rem;cursor:pointer;color:#fff;z-index:1001}.toggle-icon{font-size:2rem;display:block}.mobile-menu-backdrop{display:none;position:fixed;inset:0;background:#00000080;z-index:999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nav-menu-mobile{display:none;position:fixed;top:0;right:0;height:100vh;height:100dvh;width:320px;max-width:85vw;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:-4px 0 20px #0003;padding:5rem 1.5rem 3rem;list-style:none;overflow-y:auto;overflow-x:hidden;z-index:1000;flex-direction:column;gap:.75rem;-webkit-overflow-scrolling:touch}.nav-menu-mobile .nav-item{list-style:none;width:100%}.nav-menu-mobile .nav-link{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;color:#fff;text-decoration:none;font-weight:500;font-size:1.05rem;border-radius:10px;transition:all .3s ease;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);width:100%;cursor:pointer}.nav-menu-mobile .nav-link:hover{background:#fff3;border-color:#fff6;transform:translate(-4px);box-shadow:0 4px 12px #00000026}.nav-menu-mobile .nav-icon{font-size:1.5rem}.mobile-section-header{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2)}.section-label{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;color:#fff;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;opacity:.8}.mobile-indent .nav-link{padding-left:2.5rem}.user-greeting-mobile{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(255,255,255,.2)}.user-greeting-mobile .nav-link{background:#ffffff26;border:1px solid rgba(255,255,255,.3);cursor:default}.user-greeting-mobile .nav-link:hover{transform:none}@media screen and (max-width:1024px){.nav-menu-wrapper,.nav-menu-desktop{display:none}.mobile-menu-toggle,.mobile-menu-backdrop{display:block}.nav-menu-mobile{display:flex}.nav-container-modern{padding:1rem 1.5rem}}@media screen and (max-width:480px){.nav-logo-text-modern{font-size:1.5rem}.nav-logo-img-modern{width:35px;height:35px}.nav-container-modern{padding:.75rem 1rem}.nav-menu-mobile{width:280px;padding:4.5rem 1rem 2.5rem}.nav-menu-mobile .nav-link{padding:.875rem 1rem;font-size:.95rem}}.nav-link:focus-visible,.mobile-menu-toggle:focus-visible,.dropdown-toggle:focus-visible{outline:3px solid rgba(255,255,255,.5);outline-offset:2px}html{scroll-behavior:smooth}body.mobile-menu-open{overflow:hidden}.nav-menu-mobile::-webkit-scrollbar{width:6px}.nav-menu-mobile::-webkit-scrollbar-track{background:#ffffff1a;border-radius:10px}.nav-menu-mobile::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:10px}.nav-menu-mobile::-webkit-scrollbar-thumb:hover{background:#fff6}@keyframes pulse{0%,to{box-shadow:0 0 #fff6}50%{box-shadow:0 0 0 8px #fff0}}.nav-link.active{animation:pulse 2s infinite;background:#ffffff40}.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%}}.orders-container{max-width:1200px;margin:0 auto;padding:2rem}.orders-container h1{color:#2c3e50;margin-bottom:2rem;font-size:2rem}.no-orders{text-align:center;padding:3rem;background:#fff;border-radius:8px;box-shadow:0 2px 12px #0000001a}.no-orders p{color:#666;margin-bottom:1.5rem;font-size:1.1rem}.orders-list{display:flex;flex-direction:column;gap:1.5rem}.order-card{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 12px #0000001a;transition:transform .3s,box-shadow .3s}.order-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000026}.order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.order-info h3{margin:0 0 .5rem;color:#2c3e50;font-size:1.25rem}.order-date{color:#666;margin:0;font-size:.9rem}.order-status-badge{padding:.5rem 1rem;border-radius:20px;color:#fff;font-weight:600;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.order-details{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.order-type,.order-payment{color:#555}.order-type strong,.order-payment strong{color:#2c3e50;margin-right:.5rem}.order-items-summary{margin-bottom:1rem;color:#555}.order-items-summary strong{color:#2c3e50;margin-right:.5rem}.order-items-summary p{display:inline}.order-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:2px solid #f0f0f0}.order-total{font-size:1.25rem;color:#2c3e50}.order-total strong{margin-right:.5rem}.order-details-container{max-width:1200px;margin:0 auto;padding:2rem}.order-details-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem}.order-details-header h1{color:#2c3e50;margin:0;font-size:2rem}.order-details-content{display:flex;flex-direction:column;gap:2rem}.order-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a}.order-section h2{color:#2c3e50;margin-bottom:1.5rem;font-size:1.5rem;border-bottom:2px solid #3498db;padding-bottom:.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{margin:0;border:none;padding:0}.order-status-badge-large{padding:.75rem 1.5rem;border-radius:25px;color:#fff;font-weight:700;font-size:1rem;text-transform:uppercase;letter-spacing:1px}.status-message{background-color:#e7f3ff;border-left:4px solid #3498db;padding:1rem;margin-top:1rem;border-radius:4px}.status-message p{margin:0;color:#2c3e50;font-size:1rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-label{font-weight:600;color:#666;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.info-value{color:#2c3e50;font-size:1.1rem}.order-items-table{overflow-x:auto}.order-items-table table{width:100%;border-collapse:collapse}.order-items-table thead{background-color:#f8f9fa}.order-items-table th{padding:1rem;text-align:left;font-weight:600;color:#2c3e50;border-bottom:2px solid #dee2e6}.order-items-table td{padding:1rem;border-bottom:1px solid #e0e0e0;color:#555}.order-items-table tbody tr:hover{background-color:#f8f9fa}.item-name{font-weight:600;color:#2c3e50;margin-bottom:.25rem}.item-instructions{font-size:.875rem;color:#666;font-style:italic;margin-top:.25rem}.quantity{text-align:center;font-weight:600}.price{text-align:right;color:#2c3e50}.order-summary-section{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.order-summary-section h2{color:#fff;border-bottom-color:#ffffff4d}.order-summary{display:flex;flex-direction:column;gap:1rem}.summary-row{display:flex;justify-content:space-between;align-items:center;font-size:1.1rem;color:#fff}.total-row{font-size:1.5rem;padding-top:1rem;border-top:2px solid rgba(255,255,255,.3);margin-top:.5rem}.order-actions{display:flex;justify-content:center;gap:1rem}.btn-danger{background-color:#e74c3c;color:#fff;padding:.75rem 2rem;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.btn-danger:hover{background-color:#c0392b}@media(max-width:968px){.order-details,.info-grid{grid-template-columns:1fr}.order-footer{flex-direction:column;gap:1rem;align-items:stretch}.order-footer .btn{width:100%}}@media(max-width:640px){.orders-container,.order-details-container{padding:1rem}.orders-container h1,.order-details-header h1{font-size:1.5rem}.order-card,.order-section{padding:1rem}.order-header{flex-direction:column;align-items:flex-start;gap:.75rem}.order-items-table{font-size:.875rem}.order-items-table th,.order-items-table td{padding:.75rem .5rem}.order-details-header{flex-direction:column;align-items:flex-start}.order-actions{flex-direction:column}.order-actions .btn{width:100%}}.admin-orders-container{width:100%;max-width:1400px;margin:0 auto;padding:2rem}.admin-orders-content{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 12px #0000001a}.stat-preparing{background:linear-gradient(135deg,#9b59b6,#8e44ad)!important}.stat-ready{background:linear-gradient(135deg,#27ae60,#229954)!important}.orders-table-container{overflow-x:auto;margin-bottom:1rem}.orders-table{width:100%;border-collapse:collapse;background:#fff}.orders-table thead{background:#2c3e50;color:#fff}.orders-table th{padding:1rem;text-align:left;font-weight:600;white-space:nowrap}.orders-table td{padding:1rem;border-bottom:1px solid #e0e0e0}.orders-table tbody tr:hover{background:#f8f9fa}.order-number-link{color:#3498db;font-weight:600;cursor:pointer;text-decoration:underline}.order-number-link:hover{color:#2980b9}.order-datetime{white-space:nowrap;font-size:.9rem}.items-count{text-align:center;font-weight:600}.order-amount{font-weight:600;color:#27ae60;font-size:1.1rem}.payment-info{display:flex;flex-direction:column;gap:.25rem}.payment-status{font-size:.75rem;padding:.25rem .5rem;border-radius:12px;text-align:center;font-weight:600;text-transform:uppercase}.payment-status-pending{background-color:#fff3cd;color:#856404}.payment-status-paid{background-color:#d4edda;color:#155724}.payment-status-failed{background-color:#f8d7da;color:#721c24}.status-select{padding:.5rem .75rem;border:2px solid transparent;border-radius:4px;font-size:.875rem;font-weight:600;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;transition:all .3s}.status-select:hover{opacity:.9;transform:scale(1.02)}.status-select:focus{outline:2px solid #2c3e50;outline-offset:2px}.btn-sm{padding:.5rem 1rem;font-size:.875rem}@media(max-width:1200px){.admin-orders-container{max-width:100%}.orders-table{font-size:.875rem}.orders-table th,.orders-table td{padding:.75rem .5rem}}@media(max-width:968px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.stat-value{font-size:2rem}.orders-table{font-size:.8rem}.orders-table th,.orders-table td{padding:.5rem .25rem}}@media(max-width:640px){.admin-orders-container,.admin-orders-content{padding:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.filters-row{grid-template-columns:1fr}.btn-clear-filters{width:100%}}
