*{margin:0;padding:0;box-sizing:border-box}html,body,#root{min-height:100vh;height:100%}body{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif}.App{width:100%;min-height:100vh}.App.light{background-color:#fef3e2;color:#8b4513}.App.dark{background-color:#0f1419;color:#f4e4bc;min-height:100vh}.content{padding:2rem;text-align:center}.navbar{display:flex;align-items:center;width:100%;padding:1.5rem 2rem;border-bottom:2px solid #f3c623;position:sticky;top:0;height:80px;box-sizing:border-box;background-color:#fef3e2;z-index:100}:root{--navbar-height: 80px}.navbar-logo{flex-shrink:0;display:flex;align-items:center;height:100%}.navbar-logo .logo-text{font-size:1.5rem;line-height:1;margin:0;display:flex;align-items:center}.navbar-logo .palm-i{font-size:1.3rem}.App.dark .navbar{border-bottom-color:#2c3e50;background-color:#0f1419}.nav-center{display:flex;gap:3rem;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%)}@media (min-width: 1201px){.nav-center{left:calc(50% - 175px)}.navbar.instructions-page .nav-center,.navbar.guestbook-navbar .nav-center{left:50%}}@media (min-width: 769px) and (max-width: 1200px){.nav-center{left:50%}}.navbar-controls{display:flex;align-items:center;gap:1rem;margin-left:auto;height:100%}.nav-button{text-decoration:none;font-size:1.8rem;font-weight:600;color:#fa812f;transition:color .3s ease;display:flex;align-items:center;line-height:1;margin:0}.nav-button:hover{color:#ffb22c}.App.dark .nav-button{color:#d68910}.App.dark .nav-button:hover{color:#f39c12}.language-flags{display:flex;gap:.5rem;align-items:center}.flag-button{background:none;border:2px solid transparent;font-size:1.5rem;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .3s ease;opacity:.6;display:flex;align-items:center;justify-content:center;height:36px;width:36px;line-height:1;margin:0}.flag-button:hover{opacity:1;transform:scale(1.1)}.flag-button.active{opacity:1;border-color:#f39c12;background-color:#f39c121a}.App.dark .flag-button.active{border-color:#f39c12;background-color:#f39c1233}.theme-toggle{background:none;border:none;font-size:2rem;cursor:pointer;padding:.5rem;border-radius:4px;transition:background-color .3s ease;display:flex;align-items:center;justify-content:center;height:44px;width:44px;line-height:1;margin:0}.App.light .theme-toggle:hover{background-color:#f3c62333}.App.dark .theme-toggle:hover{background-color:#f39c1233}@media (max-width: 768px){.nav-center,.navbar-controls{display:none}.mobile-menu-toggle{display:flex;align-items:center;margin-left:auto}}.mobile-menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem;z-index:1001}.hamburger{display:flex;flex-direction:column;width:24px;height:18px;position:relative;justify-content:space-between}.hamburger span{display:block;height:3px;width:100%;background-color:#fa812f;transition:all .3s ease;border-radius:2px}.App.dark .hamburger span{background-color:#f39c12}.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.mobile-menu{position:absolute;top:100%;left:0;right:0;background:#f0dcbef2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid #f3c623;border-left:2px solid #f3c623;border-right:2px solid #f3c623;border-radius:0 0 12px 12px;box-shadow:0 8px 24px #00000026;z-index:1000;max-height:0;overflow:hidden;opacity:0;transform:translateY(-20px);transition:all .5s cubic-bezier(.4,0,.2,1);padding:0 2rem}.mobile-menu.open{max-height:600px;opacity:1;transform:translateY(0);padding:2rem}.App.dark .mobile-menu{background:#0a0f14f2;border-color:#2c3e50;box-shadow:0 8px 24px #0000004d}.mobile-nav-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(243,198,35,.3)}.App.dark .mobile-nav-section{border-bottom-color:#2c3e504d}.mobile-nav-buttons{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.mobile-nav-buttons .nav-button{padding:1.2rem 1.5rem;font-size:1.1rem;border:none;border-radius:12px;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#fff;text-decoration:none;font-weight:700;text-align:center;transition:all .3s ease;box-shadow:0 4px 15px #ffb22c4d;position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:center}.mobile-nav-buttons .nav-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.mobile-nav-buttons .nav-button:hover:before{left:100%}.App.dark .mobile-nav-buttons .nav-button{background:linear-gradient(135deg,#e67e22,#f39c12);color:#0f1419;box-shadow:0 4px 15px #e67e224d}.mobile-nav-buttons .nav-button:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 6px 20px #ffb22c80}.App.dark .mobile-nav-buttons .nav-button:hover{box-shadow:0 6px 20px #e67e2280}.mobile-nav-buttons .nav-button:active{transform:translateY(-1px) scale(1);transition:all .1s ease}.mobile-language-section{margin-bottom:1.5rem}.mobile-section-title{display:block;font-weight:700;margin-bottom:1rem;color:#fa812f;font-size:1.1rem;text-transform:uppercase;letter-spacing:.5px}.App.dark .mobile-section-title{color:#f39c12}.mobile-language-flags{display:flex;justify-content:center;gap:2rem;align-items:center}.mobile-language-flags .flag-button{background:none;border:none;font-size:2rem;cursor:pointer;transition:all .3s ease;opacity:.6;padding:0;margin:0}.mobile-language-flags .flag-button:hover{transform:scale(1.3);opacity:1}.mobile-language-flags .flag-button.active{opacity:1;transform:scale(1.4)}.mobile-theme-section{margin-top:1rem;margin-bottom:1rem;padding-bottom:.5rem}.mobile-theme-toggle{width:100%;padding:1rem;font-size:1.1rem;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;border:none;border-radius:12px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffb22c4d;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;justify-content:center;gap:.5rem}.mobile-theme-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffb22c66}.App.dark .mobile-theme-toggle{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d}.App.dark .mobile-theme-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 20px #e67e2266}.home-page{width:100%}.home-content{display:flex;width:100%;position:relative;min-height:calc(100vh - var(--navbar-height, 80px))}.main-content{flex:1;padding:1rem;flex-shrink:0;display:flex;flex-direction:column;align-items:center}.welcome-section{text-align:center;margin-bottom:1rem;max-width:800px;width:100%}.welcome-section h1{font-size:3rem;margin-bottom:1.5rem;color:#fa812f}.App.dark .welcome-section h1{color:#f39c12}.welcome-text{font-size:1.2rem;line-height:1.6;max-width:600px;margin:0 auto 2rem;color:#8b4513}.App.dark .welcome-text{color:#f4e4bc}.cta-button{display:inline-block;padding:1rem 2rem;background-color:#ffb22c;color:#8b4513;text-decoration:none;border-radius:8px;font-size:1.1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 6px #f3c6234d}.cta-button:hover{background-color:#fa812f;color:#fff;transform:translateY(-2px);box-shadow:0 6px 12px #f3c62366}.App.dark .cta-button{background-color:#e67e22;color:#f4e4bc}.App.dark .cta-button:hover{background-color:#f39c12;color:#0f1419}.section-divider{width:100%;max-width:600px;height:2px;background:linear-gradient(90deg,transparent,rgba(243,198,35,.3),transparent);margin:2rem auto;border-radius:1px}.App.dark .section-divider{background:linear-gradient(90deg,transparent,rgba(44,62,80,.4),transparent)}.features-section{margin:1rem 0 1.5rem;max-width:800px;width:100%}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.8rem;margin-top:1.5rem}.feature-card{background:#f3c62314;border:2px solid rgba(243,198,35,.2);border-radius:10px;padding:1rem;text-align:center;transition:all .3s ease;box-shadow:0 4px 12px #f3c6231a;display:flex;flex-direction:column;align-items:center;gap:.5rem}.feature-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px #f3c62333;border-color:#f3c62366}.App.dark .feature-card{background:#2c3e501a;border-color:#2c3e504d;box-shadow:0 4px 12px #2c3e501a}.App.dark .feature-card:hover{box-shadow:0 6px 20px #2c3e5033;border-color:#2c3e5080}.feature-icon{font-size:1.8rem;margin-bottom:.3rem;color:#fa812f;display:flex;align-items:center;justify-content:center}.App.dark .feature-icon{color:#f39c12}.feature-content h3{font-size:1.1rem;margin-bottom:.3rem;color:#8b4513;font-weight:600}.App.dark .feature-content h3{color:#f4e4bc}.feature-content p{color:#8b4513;line-height:1.3;font-size:.8rem;margin:0}.App.dark .feature-content p{color:#f4e4bc}.villa-description-section{margin:1.5rem 0;max-width:800px;width:100%}.villa-description-content{background:transparent;border:none;border-radius:0;padding:0;box-shadow:none}.App.dark .villa-description-content{background:transparent;border:none;box-shadow:none}.villa-description-content p{color:#8b4513;line-height:1.7;font-size:1.1rem;margin-bottom:1.5rem;text-align:left}.App.dark .villa-description-content p{color:#f4e4bc}.villa-description-content p:last-child{margin-bottom:0}.villa-intro{font-weight:600;font-size:1.2rem!important;color:#fa812f!important}.App.dark .villa-intro{color:#f39c12!important}.rental-section{margin:1.5rem 0;text-align:center;max-width:800px;width:100%}.rental-text{color:#8b4513;line-height:1.6;font-size:1.1rem;margin-bottom:1.5rem;text-align:center}.App.dark .rental-text{color:#f4e4bc}.rental-link{display:inline-block;padding:1rem 2rem;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;text-decoration:none;border-radius:25px;font-size:1.1rem;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #ffb22c4d;text-transform:uppercase;letter-spacing:.5px}.rental-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffb22c66;color:#fff}.App.dark .rental-link{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d}.App.dark .rental-link:hover{box-shadow:0 6px 20px #e67e2266;color:#0f1419}.cta-section{margin:1.5rem 0;text-align:center}.carousel-container{max-width:800px;width:100%}.sidebar{width:350px;background:#fef3e2;border-left:3px solid #f3c623;padding:2rem;flex-shrink:0;margin-top:calc(-1 * var(--navbar-height, 80px));padding-top:calc(2rem + var(--navbar-height, 80px))}.App.dark .sidebar{background:#0f1419;border-left-color:#2c3e50}.info-panel{background:transparent;border:none;padding:0;box-shadow:none;position:static}.info-panel h3{color:#fa812f;margin-bottom:1rem;font-size:1.3rem;text-align:left;padding-bottom:.5rem}.App.dark .info-panel h3{color:#f39c12}.map-container{border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a;border:2px solid #f3c623}.App.dark .map-container{border-color:#2c3e50}.map-container iframe{display:block}.mobile-info-panel{display:none;width:100%;margin-top:1.5rem;padding:2rem;background:#fef3e2;border-radius:8px}.App.dark .mobile-info-panel{background:#1e2a3a}@media (max-width: 1200px){.home-content{flex-direction:column}.main-content{width:100%;max-width:1000px;margin:0 auto;align-items:center}.sidebar{display:none}.mobile-info-panel{display:block}.mobile-info-panel .info-panel{max-width:600px;margin:0 auto}}@media (max-width: 768px){.main-content{max-width:none;padding:.5rem}.welcome-section h1{font-size:2.2rem}.welcome-text{font-size:1.1rem;padding:0 1rem}.features-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.6rem}.feature-card{padding:.8rem}.feature-icon{font-size:1.5rem;width:1.5rem;height:1.5rem}.feature-content h3{font-size:1rem}.feature-content p{font-size:.75rem}.mobile-info-panel{padding:1rem;margin-top:1rem}}@media (max-width: 480px){.welcome-section h1{font-size:1.8rem}.welcome-text{font-size:1rem}.cta-button{padding:.75rem 1.5rem;font-size:1rem}}.carousel-container{max-width:800px;margin:0 auto}.carousel{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0003;background:transparent;touch-action:pan-y pinch-zoom;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.App.dark .carousel{background:transparent;box-shadow:0 8px 32px #0006}.carousel-images{position:relative;width:100%;height:400px;overflow:hidden;background-color:transparent;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;cursor:pointer}@media (max-width: 768px){.carousel-images{height:calc(100vh - var(--navbar-height, 80px) - 120px);max-height:400px}}@media (max-width: 768px) and (orientation: landscape){.carousel-images{height:calc(100vh - 180px)!important;max-height:calc(100vh - 180px)!important;min-height:unset!important}.carousel-container{margin-top:0}.carousel{box-shadow:0 4px 16px #0003}}.carousel-slide{position:absolute;top:0;left:0;width:100%;height:100%;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;will-change:transform,opacity;background-color:transparent}.carousel-slide img{width:100%;height:100%;object-fit:cover;display:block;background-color:transparent;pointer-events:none;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none}.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:none;color:#fff;border:none;border-radius:0;width:60px;height:60px;font-size:2.5rem;font-weight:200;z-index:10;text-shadow:0 3px 10px rgba(0,0,0,.9);opacity:.7;box-shadow:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;padding:0;line-height:1;min-width:44px;min-height:44px}.carousel-btn:hover{opacity:1;transform:translateY(-50%) scale(1.1);text-shadow:0 4px 15px rgba(0,0,0,1);background:none}.carousel-btn.prev{left:.5rem}.carousel-btn.next{right:.5rem}.fullscreen-toggle-btn{position:absolute;top:1rem;right:1rem;background:#0009;color:#fff;border:none;border-radius:50%;width:44px;height:44px;font-size:1.2rem;z-index:10;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);pointer-events:auto;touch-action:manipulation}.fullscreen-toggle-btn:hover{background:#000c;transform:scale(1.1)}.carousel:before{content:"";position:absolute;inset:0;background:#ffffff1a;opacity:0;transition:opacity .2s ease;pointer-events:none;z-index:5}.carousel:active:before{opacity:1}@media (max-width: 768px){.carousel-btn{width:50px;height:50px;min-width:50px;min-height:50px;font-size:2rem}.carousel-btn.prev{left:.25rem}.carousel-btn.next{right:.25rem}.fullscreen-toggle-btn{width:40px;height:40px;font-size:1rem;top:.5rem;right:.5rem;z-index:10;pointer-events:auto;touch-action:manipulation}@media (max-width: 480px){.carousel-btn{width:40px;height:40px;min-width:40px;min-height:40px;font-size:1.5rem}}}.fullscreen-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000;z-index:9999;display:flex;flex-direction:column;overflow:hidden;touch-action:none;pointer-events:auto;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.fullscreen-header{position:absolute;top:0;left:0;right:0;height:60px;background:linear-gradient(to bottom,rgba(0,0,0,.8),transparent);display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:10;pointer-events:none}.fullscreen-close-btn{background:#fff3;color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;pointer-events:auto}.fullscreen-close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.fullscreen-counter{color:#fff;font-size:1rem;font-weight:500;text-shadow:0 2px 4px rgba(0,0,0,.5)}.fullscreen-carousel{position:relative;display:flex;align-items:center;justify-content:center;width:100vw;height:100vh}.fullscreen-image-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;max-width:100vw;max-height:100vh;touch-action:none;pointer-events:auto;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.fullscreen-image{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none;touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.fullscreen-btn{position:absolute;top:50%;transform:translateY(-50%);background:#0009;color:#fff;border:none;border-radius:50%;width:60px;height:60px;font-size:2rem;z-index:10;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);min-width:60px;min-height:60px}.fullscreen-btn:hover{background:#000c;transform:translateY(-50%) scale(1.1)}.fullscreen-btn.prev{left:1rem}.fullscreen-btn.next{right:1rem}@media (max-width: 768px){.fullscreen-header{height:50px;padding:0 .5rem}.fullscreen-close-btn{width:35px;height:35px;font-size:1rem}.fullscreen-counter{font-size:.9rem}.fullscreen-btn{width:50px;height:50px;min-width:50px;min-height:50px;font-size:1.5rem}.fullscreen-btn.prev{left:.5rem}.fullscreen-btn.next{right:.5rem}}@media (max-width: 480px){.fullscreen-image{width:100vw!important;height:100vh!important;transform:none!important}.fullscreen-btn{width:45px;height:45px;min-width:45px;min-height:45px;font-size:1.3rem}}body.fullscreen-active{overflow:hidden;position:fixed;width:100%;height:100%}@supports (-webkit-touch-callout: none){.fullscreen-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;-webkit-overflow-scrolling:touch}.fullscreen-image{-webkit-user-select:none;-webkit-touch-callout:none;width:100vw;height:100vh}}.fullscreen-overlay{touch-action:pan-x;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.fullscreen-image-container{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;will-change:transform}.fullscreen-image{pointer-events:none;-webkit-user-drag:none;-khtml-user-drag:none;-moz-user-drag:none;-o-user-drag:none;user-drag:none}.instructions-page h1{text-align:center;margin-bottom:3rem;padding-bottom:1rem;border-bottom:3px solid #f3c623;color:#fa812f}.App.dark .instructions-page h1{color:#f39c12;border-bottom-color:#2c3e50}.instruction-section{margin-bottom:4rem;position:relative}.instruction-section:before{content:"";display:block;width:100%;height:2px;background:linear-gradient(90deg,transparent,#f3c623,transparent);margin-bottom:2rem}.App.dark .instruction-section:before{background:linear-gradient(90deg,transparent,#2c3e50,transparent)}.instruction-section:first-of-type:before{display:none}.emergency-section{background:linear-gradient(135deg,#fff5e6,#ffe6cc);border:3px solid #ff6b35;border-radius:12px;padding:2rem;margin-bottom:3rem;box-shadow:0 8px 25px #ff6b3526}.App.dark .emergency-section{background:linear-gradient(135deg,#2c1810,#1a0f0a);border-color:#e67e22;box-shadow:0 8px 25px #e67e2233}.emergency-section h2{color:#ff6b35!important;font-size:2.2rem!important;text-align:center;margin-bottom:1.5rem;text-shadow:0 2px 4px rgba(255,107,53,.2)}.App.dark .emergency-section h2{color:#e67e22!important;text-shadow:0 2px 4px rgba(230,126,34,.3)}.emergency-section .instruction-card{border-color:#ff6b35;background:#fff;box-shadow:0 4px 12px #ff6b3533}.App.dark .emergency-section .instruction-card{background:#1e2a3a;border-color:#e67e22;box-shadow:0 4px 12px #e67e2233}.instruction-section h2{margin-bottom:1rem;padding-left:2rem;font-size:2rem;color:#fa812f;text-align:center}.App.dark .instruction-section h2{color:#f39c12}.instructions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;padding:2rem;margin-top:.5rem}.instruction-card{background:#fff;border:2px solid #f3c623;border-radius:8px;padding:1.5rem;color:#8b4513;box-shadow:0 4px 6px #f3c62333}.instruction-card h3{color:#fa812f}.instruction-card button{background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;border:none;font-weight:600;padding:.75rem 1.5rem;border-radius:25px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;margin-top:1rem;box-shadow:0 4px 15px #ffb22c4d;text-transform:uppercase;letter-spacing:.5px;font-size:.9rem;animation:subtlePulse 3s ease-in-out infinite}.instruction-card button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.instruction-card button:hover:before{left:100%}.instruction-card button:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 20px #ffb22c66;color:#fff}.instruction-card button:active{transform:translateY(0) scale(1);transition:all .1s ease}@keyframes subtlePulse{0%,to{box-shadow:0 4px 15px #ffb22c4d}50%{box-shadow:0 4px 15px #ffb22c80}}.App.dark .instruction-card{background:#1e2a3a;border-color:#2c3e50;color:#f4e4bc;box-shadow:0 4px 6px #2c3e504d}.App.dark .instruction-card h3{color:#f39c12}.App.dark .instruction-card button{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d;animation:subtlePulseDark 3s ease-in-out infinite}.App.dark .instruction-card button:hover{box-shadow:0 6px 20px #e67e2266;color:#0f1419}@keyframes subtlePulseDark{0%,to{box-shadow:0 4px 15px #e67e224d}50%{box-shadow:0 4px 15px #e67e2280}}.phone-link{color:#e67e22;text-decoration:none;font-weight:600;transition:all .3s ease}.phone-link:hover{color:#d35400;text-decoration:underline}.App.dark .phone-link{color:#f39c12}.App.dark .phone-link:hover{color:#e67e22}.modal-overlay{position:fixed;inset:0;background:#0000;display:flex;justify-content:center;align-items:center;z-index:1000;transform:scale(1);animation:blowUpOverlay .5s cubic-bezier(.165,.84,.44,1) forwards}@keyframes blowUpOverlay{0%{background:#0000}to{background:#000000b3}}.modal-content{background:#fff;border:2px solid #F3C623;border-radius:16px;color:#8b4513;position:relative;box-shadow:0 20px 60px #0000004d;padding:2rem;max-width:500px;margin:1rem;transform:scale(0);animation:blowUpModal .5s cubic-bezier(.165,.84,.44,1) forwards}@keyframes blowUpModal{0%{transform:scale(0)}to{transform:scale(1)}}.modal-content h3{color:#fa812f;margin-bottom:1rem;font-size:1.5rem}.modal-content p{margin-bottom:1.5rem;line-height:1.6}.modal-content button{background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;border:none;font-weight:600;padding:.75rem 2rem;border-radius:25px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffb22c4d;position:relative;overflow:hidden;text-transform:uppercase;letter-spacing:.5px;font-size:.9rem}.modal-content button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s ease}.modal-content button:hover:before{left:100%}.modal-content button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffb22c66;color:#fff}.modal-overlay.closing{animation:blowUpOverlayOut .3s cubic-bezier(.165,.84,.44,1) forwards}.modal-overlay.closing .modal-content{animation:blowUpModalOut .3s cubic-bezier(.165,.84,.44,1) forwards}@keyframes blowUpOverlayOut{0%{background:#000000b3}to{background:#0000}}@keyframes blowUpModalOut{0%{transform:scale(1);opacity:1}to{transform:scale(0);opacity:0}}.App.dark .modal-content{background:#1e2a3a;border-color:#2c3e50;color:#f4e4bc;box-shadow:0 20px 60px #00000080}.App.dark .modal-content h3{color:#f39c12}.App.dark .modal-content button{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d}.App.dark .modal-content button:hover{box-shadow:0 6px 20px #e67e2266;color:#0f1419}@media (max-width: 768px){.navbar{padding:1rem}.desktop-controls{display:none}.mobile-menu-toggle,.mobile-menu{display:block}.content,.home-page{padding:1rem;width:100%;overflow-x:hidden}.main-content{max-width:100%;width:100%;padding:1rem}.welcome-section h1{font-size:2.2rem}.welcome-text{font-size:1.1rem;padding:0 1rem}.carousel-container{width:100%;max-width:100%}.carousel-images{height:calc(100vh - 330px);max-height:400px;min-height:200px;width:100%}.carousel-btn{font-size:2rem;padding:.5rem;width:50px;height:50px}.carousel-btn.prev{left:.5rem}.carousel-btn.next{right:.5rem}.instructions-grid{grid-template-columns:1fr;padding:1rem;gap:1rem}.instruction-section h2{padding-left:1rem;font-size:1.5rem}.modal-content{max-width:calc(100vw - 2rem);margin:1rem;padding:1.5rem}.sidebar{display:none}}@media (max-width: 480px){.navbar{padding:.75rem}.nav-center{gap:2rem}.nav-button{font-size:1.5rem}.content h1{font-size:2rem}.welcome-section h1{font-size:1.8rem}.welcome-text{font-size:1rem}.carousel-images{height:calc(100vh - 280px);max-height:300px;min-height:150px}.cta-button{padding:.75rem 1.5rem;font-size:1rem}.instruction-card{padding:1rem}.instruction-section h2{font-size:1.3rem}}@media (max-width: 812px) and (orientation: landscape){.home-page{padding:0!important;overflow:hidden}.main-content{padding:.5rem!important}.welcome-section{margin-bottom:0!important}.welcome-section h1{font-size:1.2rem!important;margin:.25rem 0!important}.welcome-text,.cta-button{display:none!important}.carousel-container{margin-top:.5rem!important;max-width:100%!important}.carousel-images{height:calc(100vh - 120px)!important;max-height:calc(100vh - 120px)!important;min-height:calc(100vh - 120px)!important;width:100%!important}.carousel-dots{padding:.25rem!important;min-height:20px!important}.dot{width:8px!important;height:8px!important;min-width:8px!important;min-height:8px!important;max-width:8px!important;max-height:8px!important}.carousel-btn{width:35px!important;height:35px!important;font-size:1.5rem!important}}@media (max-width: 768px) and (orientation: portrait){.carousel-images{height:calc(100vh - 330px);max-height:350px;min-height:200px}}.guestbook-page{min-height:100vh;padding:2rem 1rem;background:#fef3e2;color:#8b4513;font-family:Inter,system-ui,-apple-system,sans-serif;transition:all .3s ease}.App.dark .guestbook-page{background:#0f1419;color:#f4e4bc}.guestbook-container{max-width:900px;margin:0 auto;position:relative}.guestbook-header{text-align:center;margin-bottom:3rem;padding:2rem 1rem}.guestbook-header h1{font-size:3.5rem;margin-bottom:1.5rem;color:#fa812f;font-weight:700;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(250,129,47,.2)}.App.dark .guestbook-header h1{color:#f39c12;text-shadow:0 2px 4px rgba(243,156,18,.3)}.guestbook-header p{font-size:1.3rem;color:#8b4513;line-height:1.7;font-weight:500;max-width:700px;margin:0 auto;opacity:.9}.App.dark .guestbook-header p{color:#f4e4bc;opacity:.95}.write-access-section{background:#fff;border-radius:12px;padding:2.5rem;margin:2rem 0;box-shadow:0 4px 15px #f3c62333;border:2px solid #f3c623;text-align:center}.App.dark .write-access-section{background:#1e2a3a;border-color:#2c3e50;box-shadow:0 4px 15px #2c3e504d}.write-access-section h2{font-size:1.8rem;margin-bottom:1rem;color:#fa812f;font-weight:600}.App.dark .write-access-section h2{color:#f39c12}.write-access-section p{margin-bottom:1.5rem;color:#8b4513;font-size:1.1rem}.App.dark .write-access-section p{color:#f4e4bc}.access-form{display:flex;flex-direction:column;gap:1rem;max-width:400px;margin:0 auto}.access-form input{padding:14px 18px;border:2px solid #f3c623;border-radius:8px;font-size:1rem;background:#fff;color:#8b4513;transition:all .3s ease;font-weight:500}.App.dark .access-form input{border-color:#2c3e50;background:#1e2a3a;color:#f4e4bc}.access-form input:focus{outline:none;border-color:#fa812f;background:#fff;box-shadow:0 0 0 3px #fa812f1a}.App.dark .access-form input:focus{border-color:#f39c12;background:#1e2a3a;box-shadow:0 0 0 3px #f39c121a}.access-btn{padding:14px 28px;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffb22c4d}.App.dark .access-btn{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d}.access-btn:hover{background:linear-gradient(135deg,#fa812f,#ffb22c);transform:translateY(-2px);box-shadow:0 6px 20px #ffb22c66;color:#fff}.App.dark .access-btn:hover{background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 6px 20px #e67e2266;color:#0f1419}.guestbook-form{background:#fff;border-radius:12px;padding:2.5rem;margin-bottom:3rem;box-shadow:0 4px 15px #f3c62333;border:2px solid #f3c623}.App.dark .guestbook-form{background:#1e2a3a;border-color:#2c3e50;box-shadow:0 4px 15px #2c3e504d}.guestbook-form h2{font-size:2rem;margin-bottom:2rem;color:#fa812f;font-weight:600;text-align:center}.App.dark .guestbook-form h2{color:#f39c12}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.6rem;font-weight:600;color:#8b4513;font-size:1rem}.App.dark .form-group label{color:#f4e4bc}.form-group input,.form-group textarea{width:100%;padding:14px 18px;border:2px solid #f3c623;border-radius:8px;font-size:1rem;background:#fff;color:#8b4513;transition:all .3s ease;font-weight:500}.App.dark .form-group input,.App.dark .form-group textarea{border-color:#2c3e50;background:#1e2a3a;color:#f4e4bc}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#fa812f;background:#fff;box-shadow:0 0 0 3px #fa812f1a}.App.dark .form-group input:focus,.App.dark .form-group textarea:focus{border-color:#f39c12;background:#1e2a3a;box-shadow:0 0 0 3px #f39c121a}.form-group textarea{min-height:120px;resize:vertical;line-height:1.6}.rating-input{display:flex;align-items:center;gap:.5rem;justify-content:center;margin-top:1rem}.star-btn{background:none;border:none;font-size:1.8rem;cursor:pointer;color:#8b45134d;transition:all .3s ease;padding:.3rem;border-radius:50%}.App.dark .star-btn{color:#f4e4bc4d}.star-btn:hover{color:gold;transform:scale(1.1);background:#ffd7001a}.star-btn.filled{color:gold;text-shadow:0 0 8px rgba(255,215,0,.4)}.file-input-wrapper{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.file-input-button{padding:10px 20px;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #ffb22c4d}.App.dark .file-input-button{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 2px 8px #e67e224d}.file-input-button:hover:not(:disabled){background:linear-gradient(135deg,#fa812f,#ffb22c);transform:translateY(-1px);box-shadow:0 4px 12px #ffb22c66;color:#fff}.App.dark .file-input-button:hover:not(:disabled){background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 4px 12px #e67e2266;color:#0f1419}.file-input-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.file-input-text{color:#8b4513;font-size:.9rem;font-weight:500}.App.dark .file-input-text{color:#f4e4bc}.image-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1.5rem}.image-item{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:1;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease;border:2px solid #f3c623}.App.dark .image-item{border-color:#2c3e50;box-shadow:0 2px 8px #0000004d}.image-item:hover{transform:scale(1.02)}.image-item img{width:100%;height:100%;object-fit:cover}.remove-image{position:absolute;top:6px;right:6px;background:#dc3545e6;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:12px;transition:all .3s ease}.remove-image:hover{background:#dc3545;transform:scale(1.1)}.submit-btn{width:100%;padding:16px 28px;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ffb22c4d;margin-top:1rem}.App.dark .submit-btn{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#fa812f,#ffb22c);transform:translateY(-2px);box-shadow:0 6px 20px #ffb22c66;color:#fff}.App.dark .submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 6px 20px #e67e2266;color:#0f1419}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.guestbook-entries{margin-top:3rem}.guestbook-entries h2{font-size:2rem;margin-bottom:2rem;color:#fa812f;font-weight:600;text-align:center}.App.dark .guestbook-entries h2{color:#f39c12}.entries-list{display:flex;flex-direction:column;gap:2.5rem}.entry{animation:fadeInUp .6s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.entry{background:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 8px 25px #f3c62326;border:1px solid rgba(243,198,35,.2);transition:all .3s ease;position:relative}.App.dark .entry{background:#1e2a3a;border-color:#2c3e504d;box-shadow:0 8px 25px #2c3e5033}.entry:hover{transform:translateY(-2px);box-shadow:0 12px 35px #f3c62333}.App.dark .entry:hover{box-shadow:0 12px 35px #2c3e5040}.entry-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(243,198,35,.1)}.entry-name{font-size:1.4rem;font-weight:600;color:#fa812f;margin:0;letter-spacing:-.01em}.App.dark .entry-name{color:#f39c12}.entry-title{font-size:1.3rem;font-weight:600;color:#fa812f;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid rgba(243,198,35,.3)}.App.dark .entry-title{color:#f39c12;border-bottom-color:#f39c1266}.entry-meta{display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap}.entry-date{color:#8b4513;font-size:.9rem;font-weight:500;background:#f3c6230d;padding:.3rem .8rem;border-radius:6px;border:1px solid rgba(243,198,35,.1)}.App.dark .entry-date{color:#f4e4bc}.entry-message{line-height:1.7;margin-bottom:1.5rem;color:#8b4513;font-size:1rem;background:#f3c62308;padding:1.5rem;border-radius:12px;border-left:3px solid #fa812f}.App.dark .entry-message{color:#f4e4bc;background:#2c3e501a;border-left-color:#f39c12}.stars{display:flex;gap:2px}.star{color:#8b45134d;font-size:1.3rem;transition:all .4s cubic-bezier(.4,0,.2,1);filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.App.dark .star{color:#f4e4bc66;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.star.filled{color:gold;text-shadow:0 0 12px rgba(255,215,0,.6);filter:drop-shadow(0 3px 6px rgba(255,215,0,.4))}.App.dark .star.filled{color:#ffed4e;text-shadow:0 0 20px rgba(255,237,78,.8),0 0 30px rgba(255,237,78,.6);filter:drop-shadow(0 4px 8px rgba(255,237,78,.5))}.entry-images{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(243,198,35,.1)}.image-container{aspect-ratio:1;border-radius:16px;overflow:hidden;cursor:pointer;transition:all .5s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #0000001f;border:2px solid #f3c623;position:relative}.image-container:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,#f3c6231a,#fa812f1a);opacity:0;transition:opacity .3s ease;z-index:1;pointer-events:none}.App.dark .image-container{border-color:#2c3e50;box-shadow:0 6px 20px #00000040}.image-container:hover{transform:scale(1.1);box-shadow:0 12px 35px #f3c62359}.image-container:hover:before{opacity:1}.App.dark .image-container:hover{box-shadow:0 12px 35px #2c3e5059}.entry-image{width:100%;height:100%;object-fit:cover}.image-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000e6;display:flex;justify-content:center;align-items:center;z-index:999999;cursor:pointer;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);touch-action:none}.modal-content{position:relative;max-width:95vw;max-height:95vh;border-radius:12px;overflow:visible;box-shadow:0 20px 60px #00000080;display:flex;justify-content:center;align-items:center;touch-action:none;pointer-events:auto}.modal-content img{max-width:95vw;max-height:95vh;width:auto;height:auto;object-fit:contain;border-radius:8px;touch-action:none;pointer-events:none;user-select:none;-webkit-user-select:none}.modal-close-btn{position:absolute;top:-40px;right:0;background:#ffffffe6;border:none;font-size:1.5rem;color:#8b4513;cursor:pointer;padding:.5rem;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 2px 8px #0003;transition:all .2s ease}.modal-close-btn:hover{background:#fff;transform:scale(1.1)}.App.dark .modal-close-btn{background:#2c3e50e6;color:#f4e4bc}.App.dark .modal-close-btn:hover{background:#2c3e50}.back-link{display:inline-block;margin-top:2rem;padding:14px 28px;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease;box-shadow:0 4px 15px #ffb22c4d}.App.dark .back-link{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d}.back-link:hover{background:linear-gradient(135deg,#fa812f,#ffb22c);transform:translateY(-2px);box-shadow:0 6px 20px #ffb22c66;color:#fff}.App.dark .back-link:hover{background:linear-gradient(135deg,#f39c12,#e67e22);box-shadow:0 6px 20px #e67e2266;color:#0f1419}.loading{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:1.2rem;color:#8b4513;font-weight:500}.App.dark .loading{color:#f4e4bc}.no-entries{text-align:center;color:#8b4513;font-style:italic;padding:2.5rem;background:#fff;border-radius:12px;font-size:1.1rem;border:2px solid #f3c623;box-shadow:0 4px 15px #f3c62333}.App.dark .no-entries{color:#f4e4bc;background:#1e2a3a;border-color:#2c3e50;box-shadow:0 4px 15px #2c3e504d}@media (max-width: 768px){.guestbook-page{padding:1rem}.guestbook-header h1{font-size:2.2rem}.guestbook-form,.write-access-section{padding:1.5rem}.entry-header{flex-direction:column;align-items:flex-start}.entry-meta{justify-content:flex-start}.entry-images{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.access-form{max-width:100%}.entry-message{padding:1rem;font-size:.95rem}}.logo{display:inline-block}.logo-text{font-family:Arial Black,Helvetica,sans-serif;font-size:2.5rem;font-weight:900;color:#2c2c2c;letter-spacing:.05em;line-height:1}.App.dark .logo-text{color:#f4e4bc}.navbar-logo .logo-text{font-size:1.5rem}.restaurant-section{margin:2rem 0;padding:1.5rem;background:transparent;border-radius:12px;border:none;box-shadow:none}.App.dark .restaurant-section{background:transparent;border:none;box-shadow:none}.desktop-restaurant-section{display:block}.desktop-restaurant-section .restaurant-section{margin:0;padding:1rem}.desktop-restaurant-section .restaurant-header h2{font-size:1.6rem;margin-bottom:.5rem}.desktop-restaurant-section .restaurant-header p{font-size:.85rem;margin-bottom:1.2rem}.desktop-restaurant-section .restaurant-grid{grid-template-columns:1fr;gap:.8rem;margin-bottom:1.2rem}.desktop-restaurant-section .restaurant-card{padding:.8rem}.desktop-restaurant-section .restaurant-info h4{font-size:1.1rem}.desktop-restaurant-section .restaurant-description{font-size:.8rem}.desktop-restaurant-section .restaurant-details span{font-size:.7rem;padding:.15rem .5rem}.desktop-restaurant-section .restaurant-stars .star{font-size:.9rem}.desktop-restaurant-section .rating-text{font-size:.75rem}.desktop-restaurant-section .feature-tag{font-size:.65rem;padding:.1rem .4rem}.mobile-restaurant-section{display:none}.restaurant-header{text-align:center;margin-bottom:2.5rem}.restaurant-header h2{font-size:2.5rem;color:#fa812f;margin-bottom:1rem;font-weight:700}.App.dark .restaurant-header h2{color:#f39c12}.restaurant-header p{font-size:1.1rem;color:#8b4513;line-height:1.6}.App.dark .restaurant-header p{color:#f4e4bc}.restaurant-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.restaurant-card{background:#f3c6230d;border-radius:8px;padding:1rem;border:1px solid rgba(243,198,35,.2);box-shadow:0 2px 8px #f3c6231a;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.restaurant-card:hover{transform:translateY(-2px);box-shadow:0 4px 15px #f3c62326;border-color:#f3c6234d}.App.dark .restaurant-card{background:#2c3e501a;border-color:#2c3e504d;box-shadow:0 2px 8px #2c3e501a}.App.dark .restaurant-card:hover{box-shadow:0 4px 15px #2c3e5033;border-color:#2c3e5066}.restaurant-info h4{font-size:1.4rem;color:#fa812f;margin-bottom:.5rem;font-weight:600}.App.dark .restaurant-info h4{color:#f39c12}.restaurant-description{color:#8b4513;font-size:.95rem;line-height:1.5;margin-bottom:1rem}.App.dark .restaurant-description{color:#f4e4bc}.restaurant-details{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1rem}.restaurant-details span{background:#f3c6231a;color:#8b4513;padding:.3rem .8rem;border-radius:6px;font-size:.85rem;font-weight:500;border:1px solid rgba(243,198,35,.2)}.App.dark .restaurant-details span{background:#2c3e504d;color:#f4e4bc;border-color:#2c3e5066}.restaurant-stars{display:flex;align-items:center;gap:.2rem;margin-bottom:1rem}.restaurant-stars .star{color:#8b45134d;font-size:1.1rem;transition:color .3s ease}.App.dark .restaurant-stars .star{color:#f4e4bc4d}.restaurant-stars .star.filled{color:gold;text-shadow:0 0 8px rgba(255,215,0,.4)}.App.dark .restaurant-stars .star.filled{color:#ffed4e;text-shadow:0 0 12px rgba(255,237,78,.6)}.rating-text{margin-left:.5rem;color:#8b4513;font-weight:600;font-size:.9rem}.App.dark .rating-text{color:#f4e4bc}.special-features{display:flex;flex-wrap:wrap;gap:.5rem}.feature-tag{background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;padding:.2rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600}.App.dark .feature-tag{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc}.restaurant-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;display:flex;justify-content:center;align-items:center;z-index:999999;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:modalFadeIn .3s ease-out;pointer-events:auto}@keyframes modalFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0px);backdrop-filter:blur(0px);transform:scale(.95)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transform:scale(1)}}.modal-content{background:#fff;border-radius:20px;padding:0;max-width:600px;width:90%;max-height:85vh;overflow:hidden;position:relative;box-shadow:0 25px 80px #0006;animation:modalSlideIn .3s ease-out;border:3px solid #f3c623;z-index:1000000;pointer-events:auto}@keyframes modalSlideIn{0%{transform:scale(.9) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.App.dark .modal-content{background:#1e2a3a;border-color:#2c3e50;box-shadow:0 25px 80px #0009}.modal-close{position:absolute;top:1rem;right:1rem;background:#ffffffe6;border:none;font-size:1.2rem;color:#8b4513;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s ease;width:35px;height:35px;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 2px 8px #0003}.modal-close:hover{background:#f3c62333;transform:scale(1.1)}.App.dark .modal-close{background:#1e2a3ae6;color:#f4e4bc}.modal-header{background:linear-gradient(135deg,#ffb22c,#fa812f);padding:2rem 2rem 1.5rem;border-radius:17px 17px 0 0;position:relative;margin-bottom:0}.App.dark .modal-header{background:linear-gradient(135deg,#e67e22,#f39c12)}.modal-header h3{font-size:2rem;color:#8b4513;margin:0;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1)}.App.dark .modal-header h3{color:#f4e4bc;text-shadow:0 2px 4px rgba(0,0,0,.3)}.modal-body{padding:2rem;max-height:60vh;overflow-y:auto}.modal-description{color:#8b4513;line-height:1.7;margin-bottom:2rem;font-size:1.1rem;font-weight:500;background:#f3c62314;padding:1.5rem;border-radius:12px;border-left:4px solid #fa812f}.App.dark .modal-description{color:#f4e4bc;background:#2c3e5033;border-left-color:#f39c12}.modal-details{margin-bottom:2rem;background:#f3c6230d;padding:1.5rem;border-radius:12px;border:1px solid rgba(243,198,35,.15)}.App.dark .modal-details{background:#2c3e5026;border-color:#2c3e504d}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.8rem 0;border-bottom:1px solid rgba(243,198,35,.15)}.detail-item:last-child{border-bottom:none;padding-bottom:0}.App.dark .detail-item{border-bottom-color:#2c3e5033}.detail-item strong{color:#8b4513;font-weight:600;font-size:1rem}.App.dark .detail-item strong{color:#f4e4bc}.modal-features{margin-bottom:2rem}.modal-features strong{display:block;color:#8b4513;margin-bottom:1rem;font-weight:600;font-size:1.1rem}.App.dark .modal-features strong{color:#f4e4bc}.features-list{display:flex;flex-wrap:wrap;gap:.8rem}.modal-actions{display:flex;gap:1rem;flex-wrap:wrap;padding-top:1rem;border-top:2px solid rgba(243,198,35,.15)}.App.dark .modal-actions{border-top-color:#2c3e504d}.action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.5rem;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;text-decoration:none;border-radius:8px;font-weight:600;transition:all .3s ease;border:none;cursor:pointer;font-size:.9rem}.action-btn:hover{background:linear-gradient(135deg,#fa812f,#ffb22c);transform:translateY(-2px);box-shadow:0 4px 12px #ffb22c4d;color:#8b4513}.App.dark .action-btn{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc}.App.dark .action-btn:hover{background:linear-gradient(135deg,#f39c12,#e67e22);color:#f4e4bc}@media (max-width: 768px){.desktop-restaurant-section{display:none}.mobile-restaurant-section{display:block}.restaurant-section{margin:2rem 0;padding:1.5rem}.restaurant-header h2{font-size:2rem}.restaurant-grid{grid-template-columns:1fr;gap:1rem}.restaurant-card{padding:1.2rem}.modal-content{width:95%;max-height:90vh}.modal-header{padding:1.5rem 1.5rem 1rem}.modal-header h3{font-size:1.6rem}.modal-body{padding:1.5rem;max-height:65vh}.modal-actions{flex-direction:column}.action-btn{justify-content:center}}.feedback-page{min-height:100vh;padding:2rem 1rem}.feedback-page .container{max-width:600px;margin:0 auto;background:#fff;border-radius:16px;padding:2rem;box-shadow:0 8px 32px #0000001a;border:1px solid #f3c623}.App.dark .feedback-page .container{background:#1e2a3a;border:1px solid #2c3e50}.feedback-form h2{color:#8b4513;margin-bottom:1rem;font-size:2rem;text-align:center;font-weight:700}.App.dark .feedback-form h2{color:#f39c12}.feedback-form p{color:#6c757d;margin-bottom:2rem;text-align:center;line-height:1.6}.App.dark .feedback-form p{color:#bdc3c7}.feedback-form .form-group{margin-bottom:1.5rem}.feedback-form label{display:block;margin-bottom:.5rem;font-weight:600;color:#8b4513;font-size:1rem}.App.dark .feedback-form label{color:#f39c12}.feedback-form select,.feedback-form textarea,.feedback-form input{width:100%;padding:.75rem;border:2px solid #f3c623;border-radius:8px;font-size:1rem;transition:all .3s ease;background:#fff;color:#8b4513}.App.dark .feedback-form select,.App.dark .feedback-form textarea,.App.dark .feedback-form input{background:#2c3e50;color:#f4e4bc;border-color:#2c3e50}.feedback-form select:focus,.feedback-form textarea:focus,.feedback-form input:focus{outline:none;border-color:#fa812f;box-shadow:0 0 0 3px #fa812f1a}.App.dark .feedback-form select:focus,.App.dark .feedback-form textarea:focus,.App.dark .feedback-form input:focus{border-color:#e67e22;box-shadow:0 0 0 3px #e67e221a}.feedback-form textarea{resize:vertical;min-height:120px}.feedback-form button{width:100%;padding:1rem 2rem;background:linear-gradient(135deg,#ffb22c,#fa812f);color:#8b4513;border:none;border-radius:25px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 4px 15px #ffb22c4d}.App.dark .feedback-form button{background:linear-gradient(135deg,#e67e22,#f39c12);color:#f4e4bc;box-shadow:0 4px 15px #e67e224d}.feedback-form button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ffb22c66}.App.dark .feedback-form button:hover:not(:disabled){box-shadow:0 6px 20px #e67e2266}.feedback-form button:disabled{opacity:.7;cursor:not-allowed;transform:none}.success-message{background:#27ae601a;border:1px solid #27ae60;border-radius:8px;padding:1rem;margin-top:1rem;text-align:center;color:#27ae60;font-weight:600}.error-message{background:#e74c3c1a;border:1px solid #e74c3c;border-radius:8px;padding:1rem;margin-top:1rem;text-align:center;color:#e74c3c;font-weight:600}@media (max-width: 768px){.feedback-page{padding:1rem .5rem}.feedback-page .container{padding:1.5rem;margin:0 .5rem}.feedback-form h2{font-size:1.5rem}.feedback-form button{padding:.875rem 1.5rem;font-size:.9rem}}:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff}body{margin:0;padding:0}h1{font-size:3.2em;line-height:1.1}
