*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--tg-theme-bg-color, #0a0a0a);color:var(--tg-theme-text-color, #ffffff);min-height:100vh;margin:0;-webkit-text-size-adjust:100%;text-size-adjust:100%;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}#root{width:100%;min-height:100vh;padding:20px}.container{background:url(/assets/black_marble_custom-CQ3KU3wo.png) repeat;background-size:400px 400px;border-radius:12px;padding:20px;box-shadow:0 8px 32px #00000080}*{box-sizing:border-box}body{margin:0;padding:0;overflow-x:hidden;background:#000;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.container{max-width:100vw;margin:0 auto;padding:10px;min-height:100vh;background:url(/assets/black_marble_custom-CQ3KU3wo.png) center center/cover no-repeat #000;border-radius:16px;box-shadow:0 8px 32px #00000080;position:relative;z-index:1;overflow-x:hidden;padding-top:max(10px,env(safe-area-inset-top));padding-bottom:max(10px,env(safe-area-inset-bottom))}@supports (padding: max(0px)){.header{padding-top:max(10px,env(safe-area-inset-top))}}@media screen and (device-width: 375px) and (device-height: 812px),screen and (device-width: 390px) and (device-height: 844px),screen and (device-width: 414px) and (device-height: 896px),screen and (device-width: 428px) and (device-height: 926px),screen and (device-width: 393px) and (device-height: 852px),screen and (device-width: 430px) and (device-height: 932px){.header{padding-top:max(15px,env(safe-area-inset-top));margin-bottom:20px}.filters{margin-top:5px}.restaurant-photo{height:calc(100vh - 140px - env(safe-area-inset-top) - env(safe-area-inset-bottom))}}.header{display:flex;flex-direction:row;align-items:center;justify-content:space-between;margin-bottom:25px;flex-wrap:wrap;gap:15px;padding:20px 15px;background:#0000004d;border-radius:12px;border:1px solid rgba(46,204,113,.2)}h1{color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.5);font-size:22px;margin:0;flex-shrink:0;font-weight:700}.filters{display:flex;flex-direction:row;gap:12px;align-items:center;flex-wrap:wrap;justify-content:flex-end;background:none;border-radius:0;padding:0;box-shadow:none;margin:0}.date-filter,.time-filter{padding:10px 30px 10px 15px;border:2px solid rgba(46,204,113,.6);border-radius:8px;background:#2ecc7140;color:#fff;font-size:14px;min-width:100px;max-width:140px;margin:0;box-shadow:none;flex-shrink:0;font-weight:500;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6,9 12,15 18,9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:16px}.date-filter option,.time-filter option{background:#000000e6;color:#fff;padding:8px 12px;border:none}.time-filter{max-height:200px;overflow-y:auto}@media (max-width: 768px){.time-filter{max-height:150px}.date-filter option,.time-filter option{padding:10px 12px;font-size:14px}}.filters select.time-filter:last-child{min-width:120px}.restaurant-photo{position:relative;width:100%;height:calc(100vh - 120px);margin:20px 0;display:flex;align-items:center;justify-content:center;overflow:hidden;transform:translateZ(0);backface-visibility:hidden}.restaurant-image{width:100%;height:100%;object-fit:contain;border-radius:8px;max-width:100%;max-height:100%;position:relative}.table-hotspot{position:absolute;border-radius:4px;cursor:pointer;transition:all .3s ease;background:transparent;transform-origin:center;transform:translateZ(0);will-change:transform}.table-hotspot.available{border:2px solid rgba(46,204,113,.9);box-shadow:0 0 16px 4px #2ecc7166,0 0 6px 2px #2ecc7133 inset;background:#2ecc7140;transition:background .2s,box-shadow .2s}.table-hotspot.booked{border:2px solid rgba(231,76,60,.9);box-shadow:0 0 16px 4px #e74c3c66,0 0 6px 2px #e74c3c33 inset;background:#e74c3c40;transition:background .2s,box-shadow .2s}.table-1{top:20%;left:9%;width:40px;height:35px}.table-2{top:13%;right:7%;width:95px;height:43px}.table-3{top:20%;left:31%;width:72px;height:35px}.table-4{bottom:23%;left:8%;width:38px;height:30px}.table-info{background:#000000e6;border:2px solid rgba(46,204,113,.6);border-radius:12px;padding:10px;color:#fff;text-align:center;font-size:12px;box-shadow:0 4px 12px #00000080;position:relative;z-index:1000;animation:fadeIn .2s ease-in-out;transition:opacity .2s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.table-info p{color:#fff;margin-bottom:6px;font-size:12px;text-align:center}.book-btn{width:60px;padding:6px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:var(--tg-theme-button-color, #007bff);color:var(--tg-theme-button-text-color, #ffffff);font-weight:700;font-size:10px;cursor:pointer;transition:background .2s;box-shadow:0 2px 4px #0000004d;margin:0 auto;display:block;z-index:1001;position:relative}.table-5{bottom:24%;left:29.5%;width:77px;height:30px}.bar{border-radius:50%;width:21px;height:21px}.table-6{bottom:13%;right:8%}.table-7{bottom:13%;right:15%}.table-8{bottom:13%;right:22%}.table-9{bottom:13%;right:30%}.table-hotspot:hover{background:#2ecc7173!important;box-shadow:0 0 24px 8px #2ecc7199,0 0 12px 4px #2ecc714d inset;z-index:20}.table-hotspot.booked:hover{background:#e74c3c73!important;box-shadow:0 0 24px 8px #e74c3c99,0 0 12px 4px #e74c3c4d inset}.book-btn:hover:not(:disabled){opacity:.9}.book-btn:disabled{background:#6c757d;cursor:not-allowed}.photo-carousel{width:280px;height:160px;margin-bottom:10px;border-radius:12px;background:#000c;border:1px solid rgba(0,255,0,.3);position:relative;overflow:hidden;cursor:pointer;transition:transform .2s,opacity .2s ease-in-out;-webkit-tap-highlight-color:transparent;z-index:1002;animation:carouselFadeIn .3s ease-in-out}@keyframes carouselFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.photo-carousel:hover{transform:scale(1.02)}.photo-carousel:active{transform:scale(.98)}.photo-carousel:focus{outline:none}@media (max-width: 768px){.photo-carousel{touch-action:manipulation;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.photo-carousel:active{transform:scale(.95);transition:transform .1s}}.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;background:#000c;border:2px solid #fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:20px;font-weight:700;opacity:.9;transition:all .2s;z-index:1003;box-shadow:0 2px 8px #0000004d;line-height:1;text-align:center;padding:0;margin:0}.carousel-arrow:hover{background:#000000f2;box-shadow:0 6px 16px #000000b3}.carousel-arrow:active{background:#000000f7;opacity:1}.carousel-prev{left:8px}.carousel-next{right:8px}.table-photo{width:100%;height:100%;object-fit:cover;position:absolute;opacity:0;transition:opacity .3s;border-radius:16px;cursor:pointer}.table-photo.active{opacity:1}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:flex-start;justify-content:center;padding-top:150px;z-index:1000;-webkit-overflow-scrolling:touch;overflow:hidden}.modal-content{background:url(/assets/black_marble_custom-CQ3KU3wo.png) repeat;background-size:400px 400px;border-radius:12px;padding:20px;max-width:350px;width:90%;box-shadow:0 8px 32px #00000080;transform:translateZ(0);-webkit-transform:translateZ(0);backface-visibility:hidden;-webkit-backface-visibility:hidden}.modal-content h2{color:#fff;margin-bottom:15px;text-align:center;font-size:18px}.modal-content p{color:#ffffffe6;margin-bottom:15px;line-height:1.4}.checkbox-label{display:flex;align-items:center;color:#fff;margin-bottom:20px;font-size:14px}.checkbox-label input{margin-right:10px}.modal-btn{width:100%;padding:12px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:var(--tg-theme-button-color, #007bff);color:var(--tg-theme-button-text-color, #ffffff);font-weight:700;cursor:pointer;transition:background .2s}.modal-btn:disabled{background:#6c757d;cursor:not-allowed}.booking-info{background:#ffffff1a;padding:10px;border-radius:6px;margin-bottom:15px}.booking-info p{margin:5px 0;font-size:14px}.form-input,.form-select{width:100%;padding:10px;margin-bottom:15px;border:1px solid rgba(255,255,255,.3);border-radius:6px;background:#ffffff1a;color:#fff;font-size:14px;font-size:16px;-webkit-appearance:none;-moz-appearance:none;appearance:none;transform:translateZ(0);-webkit-transform:translateZ(0)}.form-input::placeholder{color:#fff9;font-size:16px}.duration-selector{margin-bottom:20px}.duration-selector label{display:block;color:#fff;margin-bottom:8px;font-size:14px}@media (max-width: 600px){.header{flex-direction:column;align-items:stretch;gap:12px;padding:15px 12px;margin-bottom:20px}.filters{justify-content:center;gap:8px}.date-filter,.time-filter{font-size:13px;min-width:80px;max-width:110px;padding:8px 12px}h1{font-size:20px}.photo-carousel{width:98vw;max-width:99vw;height:300px;margin-bottom:10px}.carousel-arrow{width:60px;height:60px;font-size:44px;top:80%}.book-btn-overlay{bottom:15px;right:15px;padding:10px 20px;font-size:16px;min-width:80px}.modal-overlay{padding-top:50px;align-items:flex-start}.modal-content{max-width:95%;width:95%;padding:15px;margin:0 10px;transform:none;-webkit-transform:none}.form-input,.form-select{font-size:16px;padding:12px;margin-bottom:12px;-webkit-text-size-adjust:100%;text-size-adjust:100%}}@media (max-width: 430px){.container{max-width:100vw;padding:4px}.header{margin-bottom:15px;gap:10px;padding:12px 10px}.filters{gap:6px;justify-content:center}.date-filter,.time-filter{font-size:12px;min-width:70px;max-width:100px;padding:6px 10px}h1{font-size:18px}.restaurant-photo{height:calc(100vh - 120px);margin:10px 0}.modal-content{max-width:98vw;padding:8px;transform:none!important;-webkit-transform:none!important}.book-btn,.modal-btn{font-size:9px;padding:8px}.photo-carousel{width:99vw;max-width:99vw;height:270px;margin-bottom:8px}.carousel-arrow{width:50px;height:50px;font-size:36px;top:82%;background:#000000e6;border:2px solid #fff;box-shadow:0 2px 6px #00000080;font-weight:700}.book-btn-overlay{bottom:12px;right:12px;padding:8px 16px;font-size:14px;min-width:70px}.form-input,.form-select{font-size:16px!important;padding:10px!important;margin-bottom:10px!important;-webkit-text-size-adjust:100%!important;text-size-adjust:100%!important;transform:none!important;-webkit-transform:none!important}.modal-overlay{padding-top:20px}}@media (max-width: 375px){.container{padding:2px}.header{margin-bottom:10px;gap:8px;padding:10px 8px}.filters{gap:4px;justify-content:center}.date-filter,.time-filter{font-size:11px;min-width:60px;max-width:90px;padding:5px 8px}h1{font-size:16px}.restaurant-photo{height:calc(100vh - 100px);margin:6px 0}.modal-content{padding:4px}.book-btn,.modal-btn{font-size:8px;padding:6px}.photo-carousel{width:98vw;max-width:98vw;height:240px;margin-bottom:4px}.carousel-arrow{width:40px;height:40px;font-size:28px;top:85%;background:#000000e6;border:2px solid #fff;box-shadow:0 2px 4px #00000080;font-weight:700}.book-btn-overlay{bottom:10px;right:10px;padding:6px 12px;font-size:12px;min-width:60px}.table-info{top:-48px;padding:4px;font-size:10px}}@media (max-width: 320px){.container{padding:1px}.header{margin-bottom:8px;gap:6px;padding:8px 6px}.filters{gap:3px;justify-content:center}.date-filter,.time-filter{font-size:10px;min-width:55px;max-width:80px;padding:4px 6px}h1{font-size:14px}.restaurant-photo{height:calc(100vh - 80px);margin:2px 0}.modal-content{padding:2px}.book-btn,.modal-btn{font-size:7px;padding:4px}.photo-carousel{width:90vw;max-width:280px;height:140px;margin-bottom:4px}.carousel-arrow{width:28px;height:28px;font-size:16px;background:#000c;border:2px solid #fff;box-shadow:0 2px 6px #0006;font-weight:700;line-height:1;text-align:center;padding:0;margin:0}.book-btn-overlay{bottom:6px;left:50%;transform:translate(-50%);padding:4px 8px;font-size:10px;min-width:50px}.table-info{top:-36px;padding:2px;font-size:9px}}@media (min-width: 768px){.container{max-width:800px;padding:20px}.restaurant-photo{height:calc(100vh - 200px);margin:30px 0}.restaurant-image{max-width:90%;max-height:90%}h1{font-size:24px;margin-bottom:15px}.filters{gap:15px}.date-filter,.time-filter{font-size:16px;padding:10px;min-width:120px}}@media (min-width: 1024px){.container{max-width:1200px}.restaurant-photo{height:calc(100vh - 250px)}.restaurant-image{max-width:85%;max-height:85%}}@media (max-width: 768px){.table-hotspot{transform:translateZ(0) scale(1)}}@media (max-width: 480px){.table-hotspot{transform:translateZ(0) scale(.95)}}@media (max-width: 320px){.table-hotspot{transform:translateZ(0) scale(.9)}}.custom-time-select{position:relative;display:inline-block}.custom-select-trigger{cursor:pointer;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:space-between;background-image:none!important;padding-right:15px!important}.select-arrow{font-size:10px;transition:transform .2s;margin-left:8px}.custom-select-trigger:hover .select-arrow{transform:rotate(180deg)}.custom-dropdown{position:absolute;top:100%;left:0;right:0;z-index:1000;margin-top:2px}.dropdown-content{background:#000000f2;border:2px solid rgba(46,204,113,.6);border-radius:8px;max-height:200px;overflow-y:auto;box-shadow:0 4px 12px #0000004d}.dropdown-option{padding:10px 15px;color:#fff;cursor:pointer;transition:background .2s;border-bottom:1px solid rgba(255,255,255,.1)}.dropdown-option:last-child{border-bottom:none}.dropdown-option:hover{background:#2ecc714d}.dropdown-option.selected{background:#2ecc7180;font-weight:700}.dropdown-content::-webkit-scrollbar{width:6px}.dropdown-content::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.dropdown-content::-webkit-scrollbar-thumb{background:#2ecc7199;border-radius:3px}.dropdown-content::-webkit-scrollbar-thumb:hover{background:#2ecc71cc}@media (max-width: 768px){.dropdown-content{max-height:120px}.dropdown-option{padding:8px 12px;font-size:13px}}@media (max-width: 430px){.dropdown-content{max-height:100px}.dropdown-option{padding:6px 10px;font-size:12px}}@media (max-width: 375px){.dropdown-content{max-height:80px}.dropdown-option{padding:5px 8px;font-size:11px}}@media (max-width: 320px){.dropdown-content{max-height:70px}.dropdown-option{padding:4px 6px;font-size:10px}}.book-btn-overlay{position:absolute;bottom:8px;left:50%;transform:translate(-50%);padding:6px 12px;border:2px solid #fff;border-radius:8px;background:#3498db;color:#fff;font-weight:700;font-size:12px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #0000004d;z-index:1004;min-width:60px;text-align:center}.book-btn-overlay:hover:not(:disabled){background:var(--tg-theme-button-color, #0056b3);transform:scale(1.05);box-shadow:0 4px 12px #00000080}.book-btn-overlay:active:not(:disabled){transform:scale(.95)}.book-btn-overlay:disabled{background:#6c757d;cursor:not-allowed;opacity:.7;transform:none}@media (max-width: 768px){.book-btn-overlay{bottom:10px;right:10px;padding:6px 12px;font-size:11px;min-width:50px}}@media (max-width: 430px){.book-btn-overlay{bottom:8px;right:8px;padding:5px 10px;font-size:10px;min-width:45px}}@media (max-width: 375px){.book-btn-overlay{bottom:6px;right:6px;padding:4px 8px;font-size:9px;min-width:40px}}
