.restaurant-hero{position:relative;height:400px;width:100%}.restaurant-cover{width:100%;height:100%;object-fit:cover}.restaurant-hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,var(--bg-primary) 0,rgba(0,0,0,.2) 100%);display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:40px}.restaurant-title{font-size:48px;font-weight:800;letter-spacing:-1px;margin-bottom:8px}.restaurant-info{font-size:18px;color:var(--text-secondary)}.booking-container{margin-top:-60px;position:relative;z-index:10;display:flex;justify-content:flex-end}.booking-content{width:100%;max-width:400px;padding:32px}.booking-content h3{font-size:24px;margin-bottom:8px}.subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:24px}.discounts-list{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.discount-item{display:flex;justify-content:space-between;align-items:center;padding:16px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s ease}.discount-item:hover{background:hsla(0,0%,100%,.05);border-color:var(--accent)}.time{font-weight:600;font-size:16px}.percentage{color:var(--accent);font-weight:700;background:var(--accent-glow);padding:4px 8px;border-radius:4px}.w-full{width:100%}.mt-4{margin-top:16px}.booking-widget{width:100%;max-width:400px;padding:32px;display:flex;flex-direction:column;gap:20px}.booking-widget h3{font-size:24px;margin-bottom:8px;border-bottom:1px solid hsla(0,0%,100%,.1);padding-bottom:12px}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label,.time-slots-section label{font-size:14px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.booking-input{background:rgba(0,0,0,.2);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;color:#fff;padding:12px 16px;font-size:16px;outline:none;transition:border-color .2s ease}.booking-input:focus{border-color:var(--accent)}::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.time-slots-section{display:flex;flex-direction:column;gap:12px}.time-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.time-slot{position:relative;background:hsla(0,0%,100%,.05);border:1px solid hsla(0,0%,100%,.1);border-radius:8px;padding:12px 4px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.time-slot:hover{background:hsla(0,0%,100%,.1)}.time-slot.selected{background:var(--accent-glow);border-color:var(--accent)}.time-text{font-weight:600;font-size:15px}.has-discount{border-color:rgba(255,60,0,.3)}.discount-badge{font-size:11px;color:#f50;font-weight:700;margin-top:4px}.time-slot.selected .discount-badge{color:#fff}button:disabled{opacity:.5;cursor:not-allowed}.success-state{align-items:center;text-align:center;justify-content:center;min-height:400px}.success-icon{font-size:64px;margin-bottom:16px}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{width:90%;max-width:450px;padding:32px}.summary-card{background:rgba(0,0,0,.3);border-radius:12px;padding:20px;margin:20px 0;display:flex;flex-direction:column;gap:12px}.summary-row{display:flex;justify-content:space-between;font-size:16px}.summary-row span{color:var(--text-secondary)}.discount-row{margin-top:12px;padding-top:12px;border-top:1px dashed hsla(0,0%,100%,.2)}.discount-row,.discount-row span{color:var(--accent)}.modal-actions{display:flex;gap:16px}.modal-actions button{flex:1 1}.navbar{position:-webkit-sticky;position:sticky;top:16px;z-index:100;margin:0 16px;border-radius:16px}.nav-content{display:flex;align-items:center;justify-content:space-between;height:72px}.logo{font-size:24px;font-weight:700;letter-spacing:-.5px}.logo-accent{color:var(--accent)}.nav-links{display:flex;gap:32px}.nav-item{color:var(--text-secondary);font-weight:500;transition:color .2s ease}.nav-item:hover{color:var(--text-primary)}.nav-actions{display:flex;gap:16px;align-items:center}.user-greeting{font-weight:500;color:var(--text-primary);margin-right:8px}.bookings-page{padding-top:100px;padding-bottom:60px;min-height:100vh}.bookings-header{margin-bottom:32px}.bookings-header h1{font-size:42px;font-weight:800;letter-spacing:-1px}.bookings-subtitle{color:var(--text-secondary);font-size:16px;margin-top:8px}.filter-tabs{display:flex;gap:8px;margin-bottom:32px;flex-wrap:wrap}.filter-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:100px;font-size:14px;font-weight:500;color:var(--text-secondary);border:1px solid var(--border);background:transparent;transition:all .3s ease}.filter-tab:hover{background:hsla(0,0%,100%,.04);border-color:var(--text-secondary)}.filter-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 14px var(--accent-glow)}.tab-count{background:hsla(0,0%,100%,.15);padding:2px 8px;border-radius:100px;font-size:12px;font-weight:600}.filter-tab.active .tab-count{background:hsla(0,0%,100%,.25)}.bookings-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px;min-height:50vh}.empty-icon{font-size:64px;margin-bottom:20px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.bookings-empty-state h2{font-size:24px;font-weight:600;margin-bottom:8px}.bookings-empty-state p{color:var(--text-secondary);font-size:16px;margin-bottom:24px;max-width:400px}.bookings-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:80vh;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.bookings-list{display:flex;flex-direction:column;gap:16px}.booking-card{display:flex;overflow:hidden;transition:all .3s ease}.booking-card:hover{border-color:hsla(0,0%,100%,.15);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3)}.booking-card.cancelled{opacity:.6}.booking-card-image{position:relative;width:200px;min-height:180px;flex-shrink:0}.booking-card-image img{width:100%;height:100%;object-fit:cover}.booking-status-badge{position:absolute;top:12px;left:12px;padding:4px 12px;border-radius:100px;font-size:12px;font-weight:600;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.status-confirmed{background:rgba(16,185,129,.2);color:#6ee7b7;border:1px solid rgba(16,185,129,.3)}.status-completed{background:rgba(99,102,241,.2);color:#a5b4fc;border:1px solid rgba(99,102,241,.3)}.status-cancelled{background:rgba(239,68,68,.2);color:#fca5a5;border:1px solid rgba(239,68,68,.3)}.booking-card-details{flex:1 1;padding:20px 24px;display:flex;flex-direction:column;gap:16px}.booking-restaurant-name{font-size:20px;font-weight:600}.booking-cuisine{font-size:14px;color:var(--text-secondary);margin-top:2px}.booking-info-grid{display:flex;gap:24px;flex-wrap:wrap}.booking-info-item{display:flex;flex-direction:column;gap:4px}.info-label{font-size:12px;color:var(--text-secondary);font-weight:500}.info-value{font-size:14px;font-weight:600}.discount-value{color:var(--accent)}.booking-card-actions{display:flex;gap:12px;margin-top:auto}.btn-sm{font-size:13px}.btn-cancel{background:rgba(239,68,68,.12);color:#fca5a5;border:1px solid rgba(239,68,68,.3);border-radius:8px;font-weight:500;transition:all .3s ease}.btn-cancel:hover{background:rgba(239,68,68,.25);border-color:rgba(239,68,68,.5)}@media (max-width:640px){.booking-card{flex-direction:column}.booking-card-image{width:100%;height:160px}.booking-info-grid{gap:16px}.filter-tabs{gap:6px}.filter-tab{padding:8px 14px;font-size:13px}.bookings-header h1{font-size:32px}}.restaurant-card{display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease;cursor:pointer;text-decoration:none}.restaurant-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.4);border-color:hsla(0,0%,100%,.15)}.card-image-wrapper{position:relative;height:200px;width:100%}.card-image{width:100%;height:100%;object-fit:cover}.card-badge{position:absolute;top:12px;right:12px;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;border:1px solid var(--border)}.card-content{padding:20px}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.card-title{font-size:20px;font-weight:600;margin:0}.rating{background:rgba(16,185,129,.15);color:var(--success);padding:4px 8px;border-radius:6px;font-weight:600;font-size:14px}.card-subtitle{color:var(--text-secondary);font-size:14px;margin-bottom:16px}.discounts-section{border-top:1px solid var(--border);padding-top:16px}.discount-label{font-size:12px;color:var(--accent);font-weight:600;display:block;margin-bottom:8px}.discount-tags{display:flex;flex-wrap:wrap;gap:8px}.discount-tag{background:var(--accent-glow);color:#ffb3c1;font-size:12px;padding:4px 8px;border-radius:4px;font-weight:500}.search-box-container{position:relative;width:100%;max-width:1000px;margin:0 auto}.expanded-search{display:flex;align-items:center;padding:.75rem;border-radius:50px;background:hsla(0,0%,100%,.15);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid hsla(0,0%,100%,.2);box-shadow:0 8px 32px rgba(0,0,0,.1);gap:.5rem;transition:all .3s ease}.expanded-search:focus-within{background:hsla(0,0%,100%,.25);box-shadow:0 12px 48px rgba(0,0,0,.15);border-color:hsla(0,0%,100%,.4)}.search-input-group{position:relative;flex:1.5 1;display:flex;align-items:center}.location-input{flex:1 1}.divider{width:1px;height:24px;background:hsla(0,0%,100%,.3);margin:0 .5rem}.search-input,.search-select{background:transparent;border:none;color:#fff;font-size:1rem;padding:.5rem 1rem;width:100%;outline:none}.search-input::placeholder{color:hsla(0,0%,100%,.7)}.search-select{flex:1 1;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .5rem center;background-size:1.2rem;padding-right:2rem}.search-select option{background:#1e1e1e;padding:10px}.search-btn{border-radius:40px;padding:.75rem 2rem;font-weight:600;letter-spacing:.5px;white-space:nowrap}.dropdown-panel{position:absolute;top:calc(100% + 15px);left:0;width:100%;background:rgba(20,20,25,.95);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;box-shadow:0 10px 40px rgba(0,0,0,.5);z-index:100;overflow:hidden;animation:fadeInDown .2s ease-out}.dropdown-header{padding:1rem 1.25rem .5rem;font-size:.8rem;text-transform:uppercase;letter-spacing:1px;color:hsla(0,0%,100%,.5);font-weight:600}.dropdown-list{list-style:none;padding:0;margin:0 0 .5rem;max-height:250px;overflow-y:auto}.dropdown-list li{padding:.75rem 1.25rem;cursor:pointer;display:flex;align-items:center;gap:.75rem;color:hsla(0,0%,100%,.9);transition:all .2s ease}.dropdown-list li:hover{background:hsla(0,0%,100%,.1);padding-left:1.5rem}.history-icon,.location-icon{font-size:1.1rem;opacity:.7}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-list::-webkit-scrollbar{width:6px}.dropdown-list::-webkit-scrollbar-track{background:transparent}.dropdown-list::-webkit-scrollbar-thumb{background:hsla(0,0%,100%,.2);border-radius:10px}@media (max-width:900px){.expanded-search{flex-direction:column;border-radius:20px;padding:1rem;align-items:stretch}.divider{width:100%;height:1px;margin:.5rem 0}.search-input,.search-select{padding:.75rem}.dropdown-panel,.search-btn{margin-top:.5rem}.dropdown-panel{position:static;box-shadow:none;border:1px solid hsla(0,0%,100%,.05)}}.search-input-icon{margin-left:.75rem;font-size:1.1rem;opacity:.7}.search-input{padding-left:.5rem!important}.location-input-wrapper{display:flex;align-items:center;position:relative}.detect-location-btn{background:rgba(245,61,90,.15)!important;color:var(--accent)!important;border:1px solid rgba(245,61,90,.3)!important;border-radius:20px;font-size:.75rem;font-weight:600;padding:.35rem .85rem;margin-right:.5rem;white-space:nowrap;display:flex;align-items:center;gap:.35rem;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 10px rgba(245,61,90,.1)}.detect-location-btn:hover{background:var(--accent)!important;color:#fff!important;border-color:var(--accent)!important;box-shadow:0 4px 15px var(--accent-glow);transform:translateY(-1px)}.detect-location-btn:active{transform:translateY(0)}.detect-location-dropdown-item{color:var(--accent)!important;font-weight:600!important;border-bottom:1px solid hsla(0,0%,100%,.05)}.detect-location-dropdown-item:hover{background:rgba(245,61,90,.1)!important;padding-left:1.5rem}.recent-searches-row{display:flex;align-items:center;gap:.75rem;margin-top:1rem;padding:0 .5rem;flex-wrap:wrap}.recent-label{font-size:.8rem;font-weight:500;color:var(--text-secondary);letter-spacing:.5px}.recent-pills{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.recent-pill-btn{background:hsla(0,0%,100%,.04);border:1px solid hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.85);font-size:.75rem;padding:.35rem .85rem;border-radius:30px;transition:all .2s ease;font-weight:450}.recent-pill-btn:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.2);color:#fff;transform:scale(1.03)}.recent-pill-btn:active{transform:scale(.97)}.clear-pills-btn{color:hsla(0,0%,100%,.4);font-size:.75rem;font-weight:500;padding:.35rem .5rem;transition:color .2s ease;margin-left:.25rem}.clear-pills-btn:hover{color:var(--accent)}.animate-fade-in{animation:fadeInPills .35s cubic-bezier(.4,0,.2,1) forwards}@keyframes fadeInPills{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.spinner-dots{display:inline-block;width:12px;height:12px;border:2px solid;border-right:2px solid transparent;border-radius:50%;animation:spinDots .6s linear infinite}@keyframes spinDots{to{transform:rotate(1turn)}}@media (max-width:900px){.recent-searches-row{flex-direction:column;align-items:flex-start;gap:.5rem}.detect-location-btn{width:100%;margin-right:0;margin-top:.25rem;justify-content:center}}.suggestion-item{display:flex!important;align-items:center;gap:.75rem;padding:.75rem 1.25rem;border-bottom:1px solid hsla(0,0%,100%,.03);transition:all .2s ease}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:hsla(0,0%,100%,.05);padding-left:1.5rem}.suggestion-item-icon{font-size:1.2rem;opacity:.8;color:var(--accent)}.suggestion-details{display:flex;flex-direction:column;gap:.15rem;flex:1 1}.suggestion-name{font-size:.95rem;font-weight:600;color:#fff}.suggestion-meta{font-size:.75rem;color:hsla(0,0%,100%,.5);font-weight:400}.hero{padding:80px 0 60px;text-align:center;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(245,61,90,.15) 0,transparent 70%);z-index:-1}.hero-title{font-size:64px;font-weight:800;line-height:1.1;letter-spacing:-2px;margin-bottom:24px}.hero-subtitle{font-size:20px;color:var(--text-secondary);max-width:600px;margin:0 auto 48px}.search-bar{display:flex;align-items:center;max-width:800px;margin:0 auto;padding:8px;border-radius:12px;box-shadow:0 20px 40px rgba(0,0,0,.4)}.search-input{flex:1 1;background:transparent;border:none;color:#fff;padding:16px 24px;font-size:16px;outline:none}.search-input::placeholder{color:hsla(0,0%,100%,.4)}.search-select{background:transparent;border:none;color:var(--text-secondary);padding:16px;border-left:1px solid var(--border);outline:none;font-size:16px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-select option{background:var(--bg-secondary);color:#fff}.search-btn{padding:16px 32px}.trending-section{padding:60px 24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.section-header h2{font-size:32px;font-weight:700;letter-spacing:-1px}.restaurants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:24px;gap:24px}.btn-sm{padding:8px 16px;font-size:14px}