@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Poppins:wght@300;400;500;600&display=swap";:root{font-family:Inter,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;display:flex;place-items:center;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{position:fixed;top:0;left:0;width:100%;background-color:transparent;transition:var(--transition);z-index:1000;padding:1.2rem 0}.navbar.scrolled{background-color:var(--overlay-light);padding:1rem 0;box-shadow:var(--shadow-md);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.navbar-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.navbar-logo{font-size:2rem;font-weight:600;color:var(--text-light);text-decoration:none;font-family:Playfair Display,serif;transition:var(--transition);text-shadow:2px 2px 4px rgba(0,0,0,.2)}.scrolled .navbar-logo{color:var(--primary-color);text-shadow:none}.nav-links{display:flex;gap:3rem;align-items:center}.nav-link{color:var(--text-light);text-decoration:none;font-size:.95rem;font-weight:500;text-transform:uppercase;letter-spacing:1.5px;transition:var(--transition);position:relative;padding:.5rem 0;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.scrolled .nav-link{color:var(--text-dark);text-shadow:none}.nav-link:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background-color:var(--primary-color);transition:var(--transition);opacity:0}.nav-link:hover:after{width:100%;opacity:1}.nav-link:hover,.scrolled .nav-link:hover{color:var(--primary-color)}@media (max-width: 768px){.navbar{background-color:var(--overlay-light);padding:1rem 0;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.navbar-container{flex-direction:column;padding:0 1rem}.navbar-logo{color:var(--primary-color);margin-bottom:1rem;font-size:1.8rem;text-shadow:none}.nav-links{width:100%;justify-content:center;gap:1.5rem;flex-wrap:wrap}.nav-link{color:var(--text-dark);font-size:.9rem;text-shadow:none}}.hero{height:100vh;width:100vw;margin:0;padding:0;background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;display:flex;align-items:center;justify-content:center;color:var(--text-light);text-align:center;overflow-x:hidden;position:relative}.hero:before{content:"";position:absolute;bottom:0;left:0;width:100%;height:200px;background:linear-gradient(to top,var(--overlay-dark),transparent);opacity:.8}.hero-content{max-width:900px;padding:2rem;margin:0 auto;position:relative;z-index:2}.hero-content h1{font-size:5.5rem;font-weight:600;margin-bottom:1.5rem;font-family:Playfair Display,serif;text-shadow:2px 2px 4px rgba(0,0,0,.3);line-height:1.1;opacity:0;animation:fadeInUp 1s ease forwards .5s;color:var(--text-light)}.hero-content p{font-size:1.8rem;margin-bottom:3rem;font-weight:300;text-shadow:1px 1px 2px rgba(0,0,0,.3);opacity:0;animation:fadeInUp 1s ease forwards 1s;color:var(--accent-color);letter-spacing:1px}.cta-button{padding:1.2rem 3.5rem;font-size:1.2rem;background-color:var(--primary-color);color:var(--text-light);border:none;border-radius:3px;cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:2px;font-weight:500;opacity:0;animation:fadeInUp 1s ease forwards 1.5s;position:relative;overflow:hidden;box-shadow:var(--shadow-lg)}.cta-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.3),transparent);transition:.6s}.cta-button:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 5px 20px #0006}.cta-button:hover:before{left:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.hero-content h1{font-size:3.5rem}.hero-content p{font-size:1.4rem;margin-bottom:2.5rem}.cta-button{padding:1rem 2.5rem;font-size:1.1rem}}.loading-dialog{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-content{background:#fff;padding:2rem;border-radius:16px;box-shadow:0 8px 32px #0003;text-align:center;min-width:300px;animation:slideIn .3s ease}.loading-spinner{width:48px;height:48px;border:4px solid #f3f3f3;border-top:4px solid #B8860B;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1.5rem}.loading-message{color:#333}.loading-message p{margin:0;font-size:1rem;line-height:1.5;font-weight:500}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.loading-content{min-width:280px;padding:1.5rem;margin:1rem}.loading-spinner{width:40px;height:40px;border-width:3px;margin-bottom:1rem}.loading-message p{font-size:.875rem}}.gallery{min-height:100vh;width:100vw;padding:5rem 0;background:linear-gradient(to bottom,var(--bg-cream) 0%,var(--accent-color) 100%);overflow:hidden}.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;padding:2rem 0}.gallery-item{position:relative;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition);aspect-ratio:4/3;cursor:pointer}.gallery-item:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.gallery-image{position:relative;width:100%;height:100%;overflow:hidden}.gallery-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.gallery-item:hover img{transform:scale(1.1)}.gallery-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.4) 50%,transparent 100%);padding:2rem;color:var(--text-light);opacity:0;transform:translateY(20px);transition:var(--transition)}.gallery-item:hover .gallery-overlay{opacity:1;transform:translateY(0)}.gallery-overlay h3{font-family:Playfair Display,serif;font-size:1.5rem;font-weight:600;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1100;padding:2rem;opacity:0;animation:fadeIn .3s ease forwards}.modal-content{position:relative;max-width:90vw;max-height:90vh;border-radius:15px;overflow:hidden;transform:scale(.9);animation:zoomIn .3s ease forwards}.modal-content img{width:100%;height:auto;max-height:85vh;object-fit:contain;border-radius:12px}.modal-close{position:absolute;top:-50px;right:0;width:40px;height:40px;border-radius:50%;background-color:var(--primary-color);border:none;color:var(--text-light);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);box-shadow:0 2px 10px #0000004d;z-index:1101}.modal-close:hover{background-color:var(--primary-dark);transform:rotate(90deg)}.modal-title{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);color:var(--text-light);padding:2rem;margin:0;font-family:Playfair Display,serif;font-size:1.8rem;text-align:center;opacity:0;transform:translateY(20px);animation:slideUp .5s ease forwards .2s}@keyframes zoomIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.gallery-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}@media (max-width: 768px){.gallery{padding:4rem 0}.gallery-grid{grid-template-columns:1fr;gap:1rem}.gallery-overlay{opacity:1;transform:translateY(0);padding:1.5rem}.gallery-overlay h3{font-size:1.2rem}.modal-content{width:95vw}.modal-close{top:-45px;right:0;width:35px;height:35px;font-size:20px}.modal-title{font-size:1.4rem;padding:1.5rem}}.rooms{min-height:100vh;width:100vw;padding:3rem 0;background:linear-gradient(to bottom,var(--bg-cream) 0%,var(--accent-color) 100%);overflow:hidden}.rooms-container{display:flex;gap:2rem;padding:2rem 0;justify-content:center;flex-wrap:wrap}.room-card{flex:1;min-width:300px;max-width:400px;background:var(--bg-light);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);transition:var(--transition);position:relative;transform:translateY(0)}.room-card:hover{transform:translateY(-10px);box-shadow:0 15px 30px #0003}.room-image{width:100%;height:250px;overflow:hidden;position:relative}.room-image:after{content:"";position:absolute;bottom:0;left:0;width:100%;height:30%;background:linear-gradient(to top,rgba(0,0,0,.4),transparent)}.room-image img{width:100%;height:100%;object-fit:cover;transition:var(--transition)}.room-card:hover .room-image img{transform:scale(1.1)}.room-content{padding:2rem;text-align:center}.room-content h3{font-family:Playfair Display,serif;font-size:1.8rem;color:var(--secondary-color);margin-bottom:1rem}.room-description{color:var(--text-muted);margin-bottom:1rem;font-size:1rem;line-height:1.6}.room-price{font-size:1.5rem;color:var(--primary-color);font-weight:600;margin-bottom:1.5rem}.room-button{width:100%;padding:1rem;font-size:1rem;border-radius:10px;background:linear-gradient(45deg,var(--primary-color),var(--primary-light));transition:var(--transition);border:none;color:var(--text-light);cursor:pointer;text-transform:uppercase;letter-spacing:1px;font-weight:500;position:relative;overflow:hidden}.room-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.3),transparent);transition:.6s}.room-button:hover{background:linear-gradient(45deg,var(--primary-dark),var(--primary-color));transform:translateY(-2px)}.room-button:hover:before{left:100%}@media (max-width: 1200px){.rooms-container{gap:1.5rem}.room-card{min-width:280px}}@media (max-width: 768px){.rooms{padding:4rem 0}.room-card{min-width:100%}.room-content h3{font-size:1.5rem}.room-price{font-size:1.3rem}}.btn.room-button{position:relative;overflow:hidden;transition:all .3s ease}.btn.room-button.loading{background-color:#5753e0;cursor:not-allowed;opacity:.8}.btn.room-button.loading:after{content:"";position:absolute;top:0;left:-100%;width:200%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:loading-shine 1.5s infinite}@keyframes loading-shine{0%{left:-100%}to{left:100%}}.rooms-container.loading .btn.room-button:not(.loading){opacity:.5;cursor:not-allowed}.btn.room-button:not(.loading):hover{transform:translateY(-2px);box-shadow:0 4px 12px #646cff4d}.btn.room-button:disabled{opacity:.5;cursor:not-allowed}.about{min-height:100vh;width:100vw;padding:5rem 0;background:linear-gradient(135deg,var(--secondary-color) 0%,var(--secondary-light) 100%);overflow:hidden;display:flex;align-items:flex-start}.about-content{display:flex;flex-direction:column;gap:4rem;align-items:center}.about-text{max-width:800px;text-align:center}.about .section-title{color:var(--text-light);margin-bottom:2rem}.about-description{color:var(--text-light);font-size:1.1rem;line-height:1.8;margin-bottom:1.5rem;opacity:.9}.about-features{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;width:100%}.feature-card{flex:1;min-width:250px;max-width:300px;background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:2rem;border-radius:20px;text-align:center;transition:var(--transition);border:1px solid rgba(255,255,255,.1)}.feature-card:hover{transform:translateY(-10px);background:#ffffff26;border:1px solid rgba(255,255,255,.2)}.feature-icon{font-size:2.5rem;margin-bottom:1rem;display:inline-block}.feature-card h3{color:var(--primary-light);font-size:1.3rem;margin-bottom:1rem;font-family:Playfair Display,serif}.feature-card p{color:var(--text-light);font-size:.95rem;line-height:1.6;opacity:.8}@media (max-width: 768px){.about{padding:4rem 0}.about-content{gap:3rem}.about-description{font-size:1rem;padding:0 1rem}.feature-card{min-width:100%;margin:0 1rem}}.contact{min-height:100vh;width:100vw;padding:8rem 0;background:linear-gradient(to bottom,var(--bg-cream) 0%,var(--accent-color) 100%);overflow:hidden;display:flex;align-items:flex-start}.contact-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}.contact-info{padding-right:2rem}.contact-details{margin-top:3rem}.contact-item{display:flex;align-items:flex-start;margin-bottom:2rem;padding:1.5rem;background:var(--bg-light);border-radius:15px;box-shadow:var(--shadow-md);transition:var(--transition)}.contact-item:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.contact-icon{font-size:2rem;margin-right:1.5rem;color:var(--primary-color)}.contact-item h3{font-family:Playfair Display,serif;font-size:1.2rem;color:var(--secondary-color);margin-bottom:.5rem}.contact-item p{color:var(--text-muted);font-size:1rem}.contact-form{background:var(--bg-light);padding:3rem;border-radius:20px;box-shadow:var(--shadow-lg)}.form-group input,.form-group textarea{width:100%;padding:1rem;border:2px solid var(--accent-color);border-radius:10px;font-size:1rem;font-family:Poppins,sans-serif;color:var(--text-dark);transition:var(--transition);background-color:var(--bg-cream)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);background-color:var(--bg-light);box-shadow:0 0 0 4px #b8860b1a}.form-group textarea{resize:vertical;min-height:120px}.contact-form .btn{width:100%;padding:1rem;font-size:1.1rem;border-radius:10px;background:linear-gradient(45deg,var(--primary-color),var(--primary-light));margin-top:1rem;position:relative;overflow:hidden}.contact-form .btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.3),transparent);transition:.6s}.contact-form .btn:hover{background:linear-gradient(45deg,var(--primary-dark),var(--primary-color));transform:translateY(-2px)}.contact-form .btn:hover:before{left:100%}@media (max-width: 992px){.contact-content{grid-template-columns:1fr;gap:3rem}.contact-info{padding-right:0}}@media (max-width: 768px){.contact{padding:4rem 0}.contact-form{padding:2rem}.contact-item{padding:1rem}.contact-icon{font-size:1.5rem;margin-right:1rem}.contact-details{margin-top:2rem}}.footer{background-color:#1a1a1a;color:var(--text-light);padding:4rem 0 0;margin-top:0;width:100%}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;padding-bottom:3rem}.footer-section h3{color:var(--accent-color);font-family:Playfair Display,serif;font-size:1.5rem;margin-bottom:1.5rem}.footer-description{margin-bottom:1.5rem;line-height:1.6;color:#fffc}.social-links{display:flex;gap:1rem}.social-links a{color:var(--text-light);font-size:1.5rem;transition:var(--transition)}.social-links a:hover{color:var(--accent-color);transform:translateY(-3px)}.footer-links{list-style:none;padding:0}.footer-links li{margin-bottom:.8rem}.footer-links a{color:#fffc;text-decoration:none;transition:var(--transition)}.footer-links a:hover{color:var(--accent-color);padding-left:.5rem}.contact-info{list-style:none;padding:0}.contact-info li{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;color:#fffc}.contact-icon{font-size:1.2rem}.newsletter-form{display:flex;gap:.5rem;margin-top:1rem}.newsletter-form input{flex:1;padding:.8rem;border:1px solid rgba(255,255,255,.1);border-radius:5px;background:#ffffff1a;color:var(--text-light)}.newsletter-form input::placeholder{color:#ffffff80}.btn-subscribe{padding:.8rem 1.5rem;background:var(--accent-color);border:none;border-radius:5px;color:var(--text-light);cursor:pointer;transition:var(--transition)}.btn-subscribe:hover{background:var(--primary-color);transform:translateY(-2px)}.footer-bottom{background:#141414;padding:1.5rem 0;margin-top:2rem;width:100%}.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.footer-bottom p{color:#fffc}.footer-bottom-links{display:flex;gap:2rem}.footer-bottom-links a{color:#fffc;text-decoration:none;font-size:.9rem;transition:var(--transition)}.footer-bottom-links a:hover{color:var(--accent-color)}@media (max-width: 768px){.footer-content{grid-template-columns:1fr;text-align:center}.social-links,.contact-info li{justify-content:center}.footer-bottom .container{flex-direction:column;text-align:center}.footer-bottom-links{justify-content:center}.newsletter-form{flex-direction:column}.btn-subscribe{width:100%}}.booking-page{min-height:100vh;width:100%;padding:2rem;background-color:#f5f5f5;position:absolute;top:0;left:0;right:0;overflow-x:hidden}.booking-progress{max-width:1200px;margin:0 auto 2rem;display:flex;justify-content:space-between;align-items:center;padding:0 1rem;position:relative}.progress-step{display:flex;flex-direction:column;align-items:center;position:relative;flex:1}.progress-step:before,.progress-step:after{content:"";position:absolute;top:24px;height:2px;background-color:#ddd;width:50%}.progress-step:before{left:0}.progress-step:after{right:0}.progress-step:first-child:before,.progress-step:last-child:after{display:none}.step-number{width:48px;height:48px;border-radius:50%;background-color:#fff;border:2px solid #ddd;display:flex;align-items:center;justify-content:center;font-weight:700;margin-bottom:.5rem;z-index:1;transition:all .3s ease}.step-label{font-size:.875rem;color:#666;text-align:center}.progress-step.active .step-number{background-color:#646cff;border-color:#646cff;color:#fff}.progress-step.active .step-label{color:#646cff;font-weight:700}.progress-step.completed .step-number{background-color:#4caf50;border-color:#4caf50;color:#fff}.progress-step.completed:before,.progress-step.completed:after{background-color:#4caf50}.booking-content{max-width:1200px;margin:0 auto;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;min-height:60vh}.validation-error{background-color:#ffebee;color:#d32f2f;padding:1rem;border-radius:4px;margin-bottom:1rem;font-size:.875rem;border:1px solid #ffcdd2}.rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.room-card{border:1px solid #ddd;border-radius:8px;overflow:hidden;transition:all .3s ease;cursor:pointer}.room-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.room-card.selected{border-color:#646cff;box-shadow:0 0 0 2px #646cff}.room-image{width:100%;height:200px;object-fit:cover}.room-details{padding:1.5rem;display:flex;flex-direction:column;height:100%}.room-details h3{margin:0 0 1rem;color:#333}.room-details p{margin:0 0 1rem}.room-details>p:first-of-type{height:80px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:4;line-clamp:4;-webkit-box-orient:vertical;text-overflow:ellipsis}.capacity{color:#666;font-size:.875rem}.amenities{list-style:none;padding:0;margin:0 0 1rem;display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;font-size:.875rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;margin-top:2rem}.input-group{margin-bottom:1.5rem}.input-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.input-group input[type=date]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.number-input{display:flex;align-items:center;gap:1rem;border:1px solid #ddd;border-radius:4px;padding:.5rem}.number-input button{width:32px;height:32px;border:none;background-color:#f5f5f5;border-radius:4px;cursor:pointer;font-size:1.25rem;display:flex;align-items:center;justify-content:center}.number-input button:hover{background-color:#e5e5e5}.number-input span{min-width:40px;text-align:center;font-size:1rem}.booking-summary{max-width:800px;margin:2rem auto;padding:2rem;border:1px solid #ddd;border-radius:8px;background:#fff}.receipt-columns{display:flex;gap:2rem;margin-bottom:2rem}.receipt-left,.receipt-right{flex:1;min-width:0}.receipt-left{padding-right:2rem;border-right:1px dashed #eee}.receipt-footer{padding-top:1rem;border-top:1px solid #ddd}.booking-summary h3{color:#333;margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.booking-summary h3:first-child{margin-top:0}.receipt-row{display:flex;justify-content:space-between;align-items:flex-start;padding:.5rem 0;font-size:.875rem;color:#666}.receipt-row>span:first-child{color:#333}.receipt-row.subtotal{margin-top:.5rem;padding-top:.75rem;border-top:1px dashed #ddd;font-weight:500;color:#333}.receipt-row.total{margin-top:0;padding-top:1rem;font-size:1.25rem;font-weight:700;color:#646cff}.add-on-detail{display:block;font-size:.75rem;color:#666;margin-top:.25rem}.booking-navigation{max-width:1200px;margin:2rem auto 0;display:flex;justify-content:space-between;align-items:center;gap:1rem}.booking-navigation-right{display:flex;gap:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap;min-width:140px;text-align:center}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:#b8860b;color:#fff;border:none}.btn-primary:hover:not(:disabled){background-color:#986d0a}.btn-secondary{background-color:#fff;color:#b8860b;border:1px solid #B8860B}.btn-secondary:hover:not(:disabled){background-color:#fdf5e6}@media (max-width: 768px){.booking-page{padding:1rem}.booking-progress{margin:0 auto 1.5rem;padding:0}.progress-step{padding:0 .25rem}.progress-step:before,.progress-step:after{top:16px;height:1px}.step-number{width:32px;height:32px;font-size:.875rem;margin-bottom:.25rem}.step-label{font-size:.45rem;max-width:80px;text-align:center;word-wrap:break-word}.booking-content{padding:1rem;margin:0 .5rem}.rooms-grid,.form-grid{grid-template-columns:1fr;gap:1rem;margin-top:1rem}.input-group{margin-bottom:1rem}.input-group label{font-size:.875rem}.input-group input[type=date]{padding:.5rem;font-size:.875rem}.number-input{padding:.25rem;gap:.5rem}.number-input button{width:28px;height:28px;font-size:1rem}.number-input span{min-width:32px;font-size:.875rem}.booking-navigation{margin:1rem auto 0;padding:0 .5rem;flex-direction:column;gap:1rem;width:100%}.booking-navigation-right{width:100%;display:flex;justify-content:space-between;gap:.75rem;order:1}.booking-navigation-right button{flex:1;min-width:0;padding:.75rem 1rem;font-size:.875rem}.booking-navigation .btn-secondary:not(.booking-navigation-right .btn-secondary){width:100%;order:2;margin-top:.5rem}.btn{padding:.75rem 1rem;font-size:.875rem;min-width:0}.add-ons-grid{gap:1rem;margin-top:1rem}.add-on-items{grid-template-columns:1fr;gap:.75rem;padding:.75rem}.add-on-card{padding:1rem}.add-on-content h4{font-size:.875rem}.add-on-content p{font-size:.75rem}.add-on-price{font-size:.875rem!important;margin-top:.75rem!important}.booking-summary{padding:1rem;margin:1rem auto}.receipt-columns{flex-direction:column;gap:1rem}.receipt-left{padding-right:0;border-right:none;border-bottom:1px dashed #eee;padding-bottom:1rem;margin-bottom:1rem}.receipt-footer{padding-top:.75rem}.booking-summary h3{font-size:1rem;margin:1rem 0 .5rem;padding-bottom:.375rem}.receipt-row{font-size:.875rem;padding:.375rem 0}.receipt-row.subtotal{margin-top:.375rem;padding-top:.5rem}.receipt-row.total{margin-top:0;padding-top:.75rem;font-size:1.125rem}.add-on-detail{font-size:.675rem;margin-top:.125rem}.validation-error{padding:.75rem;font-size:.75rem;margin-bottom:.75rem}}.add-ons-grid{display:flex;flex-direction:column;gap:2rem;margin-top:2rem}.add-on-category{background:#fff;border-radius:8px;overflow:hidden}.add-on-category h3{padding:1rem;margin:0;background:#f8f8f8;color:#333;border-bottom:1px solid #eee}.add-on-items{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;padding:1rem}.add-on-card{border:1px solid #ddd;border-radius:8px;padding:1.5rem;cursor:pointer;transition:all .3s ease;background:#fff}.add-on-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.add-on-card.selected{border-color:#646cff;box-shadow:0 0 0 2px #646cff}.add-on-content h4{margin:0 0 .5rem;color:#333}.add-on-content p{margin:0;color:#666;font-size:.875rem}.add-on-price{margin-top:1rem!important;color:#646cff!important;font-weight:700;font-size:1rem!important}.add-on-summary{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid #eee}.add-on-summary:last-child{border-bottom:none}.add-on-summary p{margin:0}.info-text{color:#666;font-size:.875rem;margin:1rem 0}.price-info{margin:1rem 0;padding:.5rem;background:#f8f8f8;border-radius:4px}.weekday-price,.weekend-price{margin:0;font-size:.875rem;color:#646cff}.weekend-price{font-weight:700}.bath-type{display:inline-block;margin:.5rem 0 0;padding:.25rem .75rem;background:#f0f0f0;border-radius:4px;font-size:.75rem;color:#666;align-self:flex-start}.booking-policies{margin-top:2rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.booking-policies h3{color:#333;margin:0 0 1rem;font-size:1rem}.booking-policies ul{list-style:none;padding:0;margin:0}.booking-policies li{margin:.5rem 0;padding-left:1.5rem;position:relative;font-size:.875rem;color:#666}.booking-policies li:before{content:"•";position:absolute;left:.5rem;color:#646cff}@media (max-width: 768px){.info-text{font-size:.75rem;margin:.75rem 0}.price-info{margin:.75rem 0;padding:.375rem}.weekday-price,.weekend-price{font-size:.75rem}.bath-type{font-size:.675rem;padding:.2rem .4rem}.booking-policies{margin-top:1.5rem;padding:.75rem}.booking-policies h3{font-size:.875rem}.booking-policies li{font-size:.75rem;margin:.375rem 0}}.payment{max-width:800px;margin:0 auto}.payment-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin:2rem 0}.payment-method-card{display:flex;align-items:center;gap:1rem;padding:1.5rem;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;position:relative;background:#fff}.payment-method-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.payment-method-card.selected{border-color:#646cff;box-shadow:0 0 0 2px #646cff;transform:none}.payment-method-card.selected:hover{transform:none;box-shadow:0 0 0 2px #646cff}.payment-method-icon{font-size:2rem}.payment-method-details h3{margin:0 0 .5rem;font-size:1rem}.payment-method-details p{margin:0;font-size:.875rem;color:#666}.credit-card-form{max-width:500px;margin:2rem auto;padding:2rem;border:1px solid #ddd;border-radius:8px;background:#f8f8f8}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#646cff}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.alternative-payment{max-width:500px;margin:2rem auto;text-align:center}.qr-section{margin-bottom:2rem}.qr-code{max-width:200px;margin:1rem auto;display:block}.bank-details{margin-bottom:2rem;padding:1.5rem;background:#f8f8f8;border-radius:8px}.bank-info{text-align:left}.bank-info p{margin:.5rem 0}.upload-section{margin:2rem 0}.upload-label{display:inline-block;padding:.75rem 1.5rem;background:#646cff;color:#fff;border-radius:4px;cursor:pointer;transition:background-color .3s ease}.upload-label:hover{background:#5753e0}.upload-label input{display:none}.file-name{margin-top:1rem;font-size:.875rem;color:#666}.payment-total{margin:2rem 0;padding:1.5rem;background:#f8f8f8;border-radius:8px;text-align:center}.payment-total h3{margin:0 0 1rem;color:#333}.total-amount{font-size:2rem;font-weight:700;color:#646cff;margin:0}.confirmation{max-width:1000px;margin:0 auto;text-align:center}.confirmation-content{background:#fff;padding:3rem;border-radius:12px;box-shadow:0 4px 24px #0000001a}.confirmation-icon{width:80px;height:80px;background:#4caf50;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 2rem;box-shadow:0 4px 12px #4caf504d}.confirmation h2{color:#333;margin:0 0 1.5rem;font-size:2rem}.reference-container{display:flex;justify-content:center;margin:2rem 0;padding:2rem;background:#f8f8f8;border-radius:12px;text-align:center}.reference-number h3{margin:0 0 .75rem;font-size:1rem;color:#666;text-transform:uppercase;letter-spacing:1px}.reference-number strong{font-size:2rem;color:#333;letter-spacing:2px;display:block}.receipt{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 12px #00000014;margin:2rem 0;text-align:left}.receipt-header{text-align:center;margin-bottom:3rem;padding-bottom:1.5rem;border-bottom:2px solid #eee}.receipt-header h3{margin:0;font-size:1.5rem;color:#333;letter-spacing:1px}.receipt-main{display:flex;gap:3rem;margin-bottom:2rem}.receipt-column{flex:1;min-width:0}.receipt-section{margin-bottom:2.5rem;padding:1.5rem;background:#fafafa;border-radius:8px}.receipt-section h4{margin:0 0 1.25rem;color:#333;font-size:1.125rem;padding-bottom:.75rem;border-bottom:1px solid #eee;letter-spacing:.5px}.receipt-row{display:flex;justify-content:space-between;padding:.75rem 0;font-size:1rem;color:#666}.receipt-row>span:first-child{color:#333;font-weight:500}.receipt-row.subtotal{margin-top:.75rem;padding-top:1rem;border-top:1px dashed #ddd;font-weight:500;color:#333}.receipt-row.grand-total{margin-top:1rem;padding:1.25rem 0;border-top:2px solid #eee;font-size:1.25rem;font-weight:700;color:#646cff}.info-list{list-style:none;padding:0;margin:0}.info-list li{margin:.75rem 0;padding-left:1.5rem;position:relative;font-size:.875rem;color:#666;line-height:1.5}.info-list li:before{content:"•";position:absolute;left:.5rem;color:#646cff}.receipt-footer{margin-top:3rem;padding-top:2rem;border-top:2px solid #eee;text-align:center}.contact-info{font-size:.875rem;color:#666}.contact-info p{margin:.5rem 0}.confirmation-actions{display:flex;gap:1rem;justify-content:center;margin-top:3rem}.confirmation-actions button{padding:1rem 2rem;font-size:1rem}@media print{.confirmation{max-width:none}.confirmation-content{padding:0;box-shadow:none}.receipt{box-shadow:none;padding:0}.receipt-section{background:none;padding:0}.receipt-main{page-break-inside:avoid}}@media (max-width: 768px){.confirmation{max-width:100%}.confirmation-content{padding:1.5rem}.confirmation h2{font-size:1.5rem}.reference-container{padding:1.5rem}.reference-number strong{font-size:1.5rem}.receipt{padding:1.5rem;margin:1.5rem 0}.receipt-header{margin-bottom:2rem}.receipt-main{flex-direction:column;gap:1.5rem}.receipt-section{margin-bottom:1.5rem;padding:1rem}.receipt-row{font-size:.875rem}.receipt-row.grand-total{font-size:1.125rem}.confirmation-actions{flex-direction:column;margin-top:2rem}.confirmation-actions button{width:100%}}.credit-card-container{max-width:500px;margin:2rem auto}.credit-card-preview{perspective:1000px;margin-bottom:2rem}.card-face{background:linear-gradient(45deg,#1a1a1a,#333);border-radius:16px;padding:1.5rem;color:#fff;min-height:280px;position:relative;transition:all .3s ease;box-shadow:0 8px 16px #0003}.card-face.visa{background:linear-gradient(45deg,#1a1a1a,#2196f3)}.card-face.mastercard{background:linear-gradient(45deg,#1a1a1a,#f44336)}.card-face.amex{background:linear-gradient(45deg,#1a1a1a,#4caf50)}.card-face.discover{background:linear-gradient(45deg,#1a1a1a,#ff9800)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.card-type{font-size:2rem}.card-brand{font-size:1rem;text-transform:uppercase;letter-spacing:2px}.card-number{font-size:1.5rem;letter-spacing:2px;margin-bottom:2rem;font-family:monospace}.card-details{display:flex;justify-content:space-between;font-size:.875rem}.card-holder label,.card-expires label{display:block;text-transform:uppercase;font-size:.75rem;margin-bottom:.25rem;opacity:.8}.credit-card-form{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}.print-header{text-align:center;margin-bottom:2rem;display:none}.print-header h1{margin:0;font-size:1.5rem;color:#333}.print-header p{margin:.5rem 0 0;color:#666}.reference-container{display:flex;justify-content:center;margin:2rem 0;padding:1.5rem;background:#f8f8f8;border-radius:8px;text-align:center}.reference-number h3{margin:0 0 .5rem;font-size:.875rem;color:#666;text-transform:uppercase}.reference-number strong{font-size:1.5rem;color:#333;letter-spacing:1px}.receipt{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:2rem 0}.receipt-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #eee}.receipt-header h3{margin:0;font-size:1.25rem;color:#333}.receipt-date{margin:.5rem 0 0;font-size:.875rem;color:#666}.receipt-section{margin-bottom:2rem}.receipt-section:last-child{margin-bottom:0}.receipt-section h4{margin:0 0 1rem;color:#333;font-size:1rem;padding-bottom:.5rem;border-bottom:1px solid #eee}.receipt-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.875rem;color:#666}.receipt-total{margin-top:2rem;padding-top:1rem;border-top:1px solid #eee}.receipt-row.subtotal{color:#333;font-weight:500}.receipt-row.grand-total{margin-top:1rem;padding-top:1rem;border-top:2px solid #eee;font-size:1.125rem;font-weight:700;color:#646cff}.receipt-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid #eee}.terms-conditions h4{margin:0 0 1rem;font-size:.875rem;color:#333}.terms-conditions ul{list-style:none;padding:0;margin:0}.terms-conditions li{margin:.5rem 0;font-size:.75rem;color:#666}.contact-info{margin-top:1.5rem;text-align:center;font-size:.75rem;color:#666}.contact-info p{margin:.25rem 0}.confirmation-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}@media print{@page{size:A4;margin:1cm}body *{visibility:hidden}.confirmation,.confirmation *{visibility:visible}.confirmation{position:absolute;left:0;top:0;width:100%;padding:0}.print-header{display:block}.confirmation-icon,.confirmation-actions{display:none}.receipt{box-shadow:none;padding:0}.reference-container{background:none;padding:0}.receipt-columns{page-break-inside:avoid}.receipt-left{border-right-color:#ddd}}@media (max-width: 768px){.credit-card-preview{margin:1rem auto;padding:0 1rem;max-width:400px}.card-face{border-radius:12px;padding:1.25rem;min-height:200px}.card-header{margin-bottom:1.5rem}.card-number{font-size:1.25rem;margin-bottom:1.5rem;word-spacing:.25rem}.card-details{font-size:.875rem;margin-top:auto}.credit-card-form{padding:1.5rem;margin:1.5rem 1rem;border-radius:12px}.reference-container{flex-direction:column;text-align:center;gap:1rem}.receipt{padding:1rem;margin:1rem 0}.receipt-header{margin-bottom:1.5rem}.confirmation-actions{flex-direction:column}.confirmation-actions button{width:100%}}.payment-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;opacity:0;animation:modalFadeIn .3s ease forwards}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;max-height:90vh;overflow:hidden;position:relative;opacity:0;transform:translateY(20px);animation:modalContentSlideIn .3s ease forwards}.modal-header{padding:1.5rem;border-bottom:1px solid #eee;display:flex;justify-content:space-between;align-items:center;background:#fff;position:sticky;top:0;z-index:2}.modal-header h3{margin:0;color:#333}.close-button{background:none;border:none;font-size:1.5rem;color:#666;cursor:pointer;padding:.5rem;line-height:1}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{padding:1.5rem;border-top:1px solid #eee;display:flex;justify-content:space-between;gap:1rem;background:#fff;position:sticky;bottom:0;z-index:2}.modal-header:after{content:"";position:absolute;left:0;right:0;bottom:-8px;height:8px;background:linear-gradient(to bottom,rgba(0,0,0,.05),transparent);opacity:0;transition:opacity .2s ease;pointer-events:none}.modal-body:not(:scrollbar)~.modal-header:after{opacity:1}.modal-footer:before{content:"";position:absolute;left:0;right:0;top:-8px;height:8px;background:linear-gradient(to top,rgba(0,0,0,.05),transparent);opacity:0;transition:opacity .2s ease;pointer-events:none}.modal-body:not(:scrollbar)~.modal-footer:before{opacity:1}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh}.modal-header,.modal-footer,.modal-body{padding:1rem}.modal-footer{flex-direction:column;gap:.75rem}.modal-footer button{width:100%;margin:0}.modal-footer .btn-primary{order:-1}.modal-footer .btn-secondary{order:1}}.payment-method-card{position:relative}.modal-validation-error{background-color:#ffebee;color:#d32f2f;padding:1rem;border-radius:4px;margin-bottom:1rem;font-size:.875rem;border:1px solid #ffcdd2}.payment-form{margin-top:2rem}.payment-form .form-group{margin-bottom:1.5rem}.payment-form label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.payment-form input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .3s ease}.payment-form input:focus{outline:none;border-color:#646cff}.qr-note{color:#666;font-size:.875rem;margin-top:.5rem;font-style:italic}.upload-instruction{color:#666;font-size:.875rem;margin-bottom:1rem;font-style:italic}.upload-section{margin-top:2rem;padding:1.5rem;background:#f8f8f8;border-radius:8px;text-align:center}@media (max-width: 768px){.payment-form{margin-top:1.5rem}.payment-form .form-group{margin-bottom:1rem}.payment-form label{font-size:.875rem}.payment-form input{padding:.5rem;font-size:.875rem}.upload-section{margin-top:1.5rem;padding:1rem}.qr-note,.upload-instruction{font-size:.75rem}}.payment-processing,.payment-success{text-align:center;padding:2rem}.processing-animation{margin:2rem auto}.spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #B8860B;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.processing-details,.success-details{margin-top:1.5rem;padding:1rem;background:#0000000d;border-radius:8px}.processing-details p,.success-details p{margin:.5rem 0;font-size:.9rem;color:#666}.success-icon{width:60px;height:60px;background:#4caf50;border-radius:50%;color:#fff;font-size:2rem;line-height:60px;margin:1rem auto;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.payment-success h3{color:#4caf50;margin:1rem 0}.guest-info{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.guest-info .input-group{width:100%}.guest-info input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.guest-info input:focus{outline:none;border-color:#b8860b;box-shadow:0 0 0 2px #b8860b1a}.guest-info label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.guest-info input::placeholder{color:#999}.guest-info input[type=tel]{letter-spacing:.5px}@media (max-width: 768px){.guest-info{margin-bottom:1.5rem}.guest-info input{padding:.625rem;font-size:.875rem}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:modalFadeIn .3s ease forwards}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 10px 25px #0003;animation:modalContentSlideIn .3s ease forwards;padding:2rem}.payment-modal .modal-content{max-width:500px;padding:0;display:flex;flex-direction:column}.payment-modal .modal-header{padding:1.5rem;border-bottom:1px solid #eee;background:#fff;position:sticky;top:0;z-index:2;display:flex;justify-content:space-between;align-items:center}.payment-modal .modal-body{padding:1.5rem;overflow-y:auto;flex:1}.payment-modal .modal-footer{padding:1.5rem;border-top:1px solid #eee;background:#fff;position:sticky;bottom:0;z-index:2;display:flex;justify-content:flex-end;gap:1rem}.confirmation .modal-content{max-width:1000px;padding:3rem}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalContentSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header h2,.modal-header h3{margin:0;color:#333}.close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;line-height:1;transition:color .3s ease}.close-button:hover{color:#333}.modal-footer{margin-top:30px;display:flex;justify-content:flex-end;gap:12px}@media (max-width: 768px){.modal-content{width:95%;max-height:95vh;padding:1.5rem;margin:1rem}.payment-modal .modal-content{margin:.5rem;padding:0}.payment-modal .modal-header,.payment-modal .modal-footer,.payment-modal .modal-body{padding:1rem}.payment-modal .modal-footer{flex-direction:column;gap:.75rem}.payment-modal .modal-footer button{width:100%}.confirmation .modal-content{padding:1.5rem}.modal-footer{flex-direction:column;gap:.75rem}.modal-footer button{width:100%}}.error-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:2rem}.error-content{text-align:center;background:#fff;padding:3rem;border-radius:16px;box-shadow:0 8px 32px #0000001a;max-width:480px;width:100%;animation:errorSlideIn .5s ease}.error-icon{font-size:4rem;margin-bottom:1rem;animation:iconBounce 1s ease infinite}.error-content h1{font-size:5rem;margin:0;background:linear-gradient(135deg,#646cff,#5753e0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}.error-content h2{font-size:1.5rem;color:#333;margin:1rem 0}.error-content p{color:#666;margin-bottom:2rem;font-size:1rem;line-height:1.5}.return-button{background:#646cff;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.return-button:hover{background:#5753e0;transform:translateY(-2px)}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes iconBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media (max-width: 768px){.error-content{padding:2rem}.error-icon{font-size:3rem}.error-content h1{font-size:4rem}.error-content h2{font-size:1.25rem}}.admin-login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(#0009,#0009),url(/images/hero-bg.jpg) center/cover no-repeat;padding:20px}.admin-login-card{background:#fffffff2;padding:40px;border-radius:12px;box-shadow:0 8px 32px #0000001a;width:100%;max-width:420px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.admin-login-header{text-align:center;margin-bottom:30px}.admin-login-header h1{color:#b8860b;font-size:2.5rem;margin-bottom:10px}.admin-login-header p{color:#666;font-size:1.1rem}.admin-login-form{display:flex;flex-direction:column;gap:20px}.admin-login-input-group{display:flex;flex-direction:column;gap:8px}.admin-login-input-group label{color:#333;font-weight:500}.admin-login-input-group input{padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:all .3s ease}.admin-login-input-group input:focus{border-color:#b8860b;outline:none;box-shadow:0 0 0 2px #b8860b1a}.admin-login-button{background-color:#b8860b;color:#fff;padding:14px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.admin-login-button:hover{background-color:#986c09;transform:translateY(-1px)}.admin-login-error{background-color:#fff2f2;color:#dc3545;padding:12px;border-radius:8px;text-align:center;font-size:.9rem;border:1px solid #ffcdd2}@media (max-width: 480px){.admin-login-card{padding:30px 20px}.admin-login-header h1{font-size:2rem}}.admin-dashboard{display:flex;min-height:100vh;background-color:#f8f9fa;position:relative}.dashboard-sidebar{width:280px;background-color:#fff;box-shadow:2px 0 5px #0000000d;display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100;transition:transform .3s ease,width .3s ease}.sidebar-toggle{position:fixed;left:20px;top:20px;padding:10px;border-radius:8px;background:#b8860b;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:101;transition:all .3s ease;opacity:0;pointer-events:none;outline:none}.sidebar-toggle:focus{outline:none}.sidebar-toggle svg{width:24px;height:24px;display:block}.sidebar-toggle:hover{background:#986c09}.sidebar-closed .dashboard-sidebar{transform:translate(-100%)}.sidebar-closed .dashboard-main{margin-left:0}.sidebar-closed .sidebar-toggle{left:20px}.dashboard-main{flex-grow:1;margin-left:280px;padding:30px;transition:margin-left .3s ease}.sidebar-header{padding:24px;border-bottom:1px solid #eee}.sidebar-header h2{color:#b8860b;margin:0;font-size:1.5rem}.sidebar-nav{padding:20px 0;flex-grow:1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 24px;width:100%;border:none;background:none;color:#666;font-size:1rem;text-align:left;cursor:pointer;transition:all .3s ease;outline:none}.nav-item:focus{outline:none}.nav-item:hover{background-color:#f8f9fa;color:#b8860b}.nav-item.active{background-color:#b8860b1a;color:#b8860b;font-weight:500}.nav-item svg{font-size:1.2rem}.logout-button{margin:20px;padding:12px;border:none;background-color:#f8f9fa;color:#666;border-radius:8px;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:all .3s ease;outline:none}.logout-button:focus{outline:none}.logout-button:hover{background-color:#fee;color:#dc3545}.dashboard-overview h2{color:#333;margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:linear-gradient(145deg,#fff,#f8f9fa);padding:24px;border-radius:16px;box-shadow:0 4px 20px #0000000d;transition:all .3s ease;border:1px solid rgba(184,134,11,.1)}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000001a;border-color:#b8860b33}.stat-card h3{color:#666;font-size:1rem;margin:0 0 12px;display:flex;align-items:center;gap:8px}.stat-card h3 svg{color:#b8860b}.stat-card p{color:#333;font-size:2rem;font-weight:600;margin:0;background:linear-gradient(45deg,#b8860b,#daa520);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.stats-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:24px;margin-bottom:40px}.chart-card{background:#fff;padding:24px;border-radius:16px;box-shadow:0 4px 20px #0000000d;border:1px solid rgba(184,134,11,.1);transition:all .3s ease}.chart-card:hover{box-shadow:0 8px 25px #0000001a;border-color:#b8860b33}.chart-card h3{color:#333;font-size:1.1rem;margin:0 0 20px;padding-bottom:12px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:8px}.chart-card h3 svg{color:#b8860b}.chart-container{height:300px;margin:0 -10px}.room-type-stats{display:flex;flex-direction:column;gap:16px}.stat-bar{display:grid;grid-template-columns:120px 1fr 60px;align-items:center;gap:12px}.stat-label{color:#666;font-size:.9rem}.stat-bar-container{height:8px;background-color:#f0f0f0;border-radius:4px;overflow:hidden}.stat-bar-fill{height:100%;background-color:#b8860b;border-radius:4px;transition:width .3s ease}.stat-value{color:#333;font-weight:500;text-align:right}.monthly-revenue{height:300px;display:flex;align-items:flex-end;gap:12px;padding-top:24px}.revenue-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.revenue-label{color:#666;font-size:.8rem;transform:rotate(-45deg);white-space:nowrap}.revenue-bar-container{width:100%;height:200px;display:flex;align-items:flex-end}.revenue-bar-fill{width:100%;background-color:#b8860b;border-radius:4px 4px 0 0;transition:height .3s ease}.revenue-value{color:#333;font-size:.8rem;font-weight:500;transform:rotate(-45deg);white-space:nowrap}.dashboard-section{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 4px #0000000d}.dashboard-section h2{color:#333;margin-bottom:20px}.recent-bookings{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 4px #0000000d}.recent-bookings h3{color:#333;margin:0 0 20px}table{width:100%;border-collapse:collapse}th{text-align:left;padding:12px;border-bottom:2px solid #eee;color:#666;font-weight:500}td{padding:12px;border-bottom:1px solid #eee;color:#333}.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.85rem;font-weight:500}@media (max-width: 768px){.sidebar-toggle{opacity:1;pointer-events:auto}.dashboard-sidebar{transform:translate(-100%)}.sidebar-open .dashboard-sidebar{transform:translate(0)}.sidebar-open .sidebar-toggle{left:230px}.dashboard-main{margin-left:0;padding:80px 20px 20px}.stats-charts{grid-template-columns:1fr}.chart-card{padding:16px}.chart-container{height:250px}.sidebar-header h2{display:block}.nav-item span{display:inline}.nav-item{padding:12px 24px;justify-content:flex-start}.logout-button span{display:inline}.stats-grid{grid-template-columns:1fr}.monthly-revenue{height:200px}}@media (min-width: 769px){.dashboard-sidebar{transform:none}.dashboard-main{margin-left:280px}}.ai-knowledgebase{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:24px}.kb-section{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 4px #0000000d;transition:transform .3s ease}.kb-section:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.kb-section h3{color:#333;margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid #eee;font-size:1.2rem}.kb-content{color:#666}.kb-content p{margin:0 0 12px;font-size:.95rem}.kb-content ul{list-style:none;padding:0;margin:0}.kb-content li{padding:8px 0 8px 24px;position:relative;font-size:.9rem}.kb-content li:before{content:"•";position:absolute;left:8px;color:#b8860b}@media (max-width: 768px){.ai-knowledgebase{grid-template-columns:1fr;gap:16px;margin-top:16px}.kb-section{padding:16px}.kb-section h3{font-size:1.1rem;margin-bottom:12px;padding-bottom:8px}.kb-content p{font-size:.9rem}.kb-content li{font-size:.85rem;padding:6px 0 6px 20px}}.bookings-management{padding:20px}.bookings-header{margin-bottom:30px}.bookings-header h2{color:#333;margin-bottom:20px}.search-filters{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.search-bar{flex:1;min-width:300px;position:relative}.search-bar svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#666}.search-bar input{width:100%;padding:12px 12px 12px 40px;border:2px solid #ddd;border-radius:8px;font-size:1rem;transition:all .3s ease}.search-bar input:focus{border-color:#b8860b;outline:none;box-shadow:0 0 0 2px #b8860b1a}.filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.filters select,.filters input{padding:6px 12px;height:35px;border:1px solid #ddd;border-radius:6px;font-size:.9rem;transition:all .3s ease;min-width:120px}.filters input[type=date]{min-width:130px}.filters select:focus,.filters input:focus{border-color:#b8860b;outline:none;box-shadow:0 0 0 2px #b8860b1a}.bookings-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;overflow:auto}.bookings-table{width:100%;border-collapse:collapse;min-width:1000px}.bookings-table th{background-color:#f8f9fa;padding:16px;text-align:left;font-weight:500;color:#666;border-bottom:2px solid #eee}.bookings-table td{padding:16px;border-bottom:1px solid #eee;color:#333}.status-select{padding:8px 32px 8px 12px;border-radius:10px;border:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-repeat:no-repeat;background-position:right 10px center;background-size:14px}.status-select.pending{background-color:#fff3cd;color:#856404;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='%23856404' 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")}.status-select.completed{background-color:#d4edda;color:#155724;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='%23155724' 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")}.status-select.cancelled{background-color:#f8d7da;color:#721c24;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='%23721c24' 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")}.status-select:hover{opacity:.9}.status-select:focus{outline:none;box-shadow:0 0 0 2px #b8860b1a}.modal-content{background:#fff;padding:40px;border-radius:16px;width:90%;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.print-header{text-align:center;margin-bottom:30px;border-bottom:2px solid #B8860B;padding-bottom:20px}.print-header h1{color:#b8860b;margin:0 0 10px;font-size:32px}.print-header p{color:#666;margin:0;font-size:16px}.booking-status{text-align:center;margin:30px 0;display:flex;align-items:center;justify-content:center;gap:12px}.booking-status .status-icon{font-size:32px;color:#b8860b}.booking-status h2{color:#333;margin:0;font-size:24px}.reference-container{text-align:center;background:#f8f9fa;padding:20px;border-radius:12px;margin:20px 0;box-shadow:0 2px 8px #0000000d}.reference-container h3{color:#666;margin:0 0 10px}.reference-container strong{color:#b8860b;font-size:24px;display:block}.receipt{background:#fff;border-radius:12px;margin-top:30px;box-shadow:0 2px 8px #0000001a}.receipt-header{background:#f8f9fa;padding:20px;border-radius:12px 12px 0 0;border-bottom:1px solid #eee}.receipt-header h3{margin:0;color:#333;font-size:18px}.receipt-date{color:#666;margin:5px 0 0;font-size:14px}.receipt-main{padding:30px;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:30px}.receipt-section{margin-bottom:20px}.receipt-section h4{color:#b8860b;margin:0 0 15px;padding-bottom:10px;border-bottom:1px solid #eee;font-size:16px}.receipt-row{display:flex;justify-content:space-between;margin-bottom:10px;font-size:14px;line-height:1.5}.receipt-row span:first-child{color:#666}.receipt-row span:last-child{font-weight:500;color:#333;text-align:right}.receipt-row.grand-total{font-size:18px;font-weight:700;margin-top:20px;padding-top:20px;border-top:2px solid #eee;color:#333}.status-badge{padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500}.payment-proof-section{grid-column:1 / -1}.payment-proof-image{max-width:100%;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-top:10px}.receipt-footer{background:#f8f9fa;padding:20px;border-radius:0 0 12px 12px;text-align:center;border-top:1px solid #eee}.contact-info{color:#666;font-size:14px}.contact-info p{margin:5px 0}.modal-actions{margin-top:30px;display:flex;gap:12px;justify-content:flex-end}.btn-primary{background-color:#b8860b;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-primary:hover{background-color:#986c09;transform:translateY(-1px)}.clear-filters{padding:6px 12px;background-color:#f8f9fa;border:1px solid #ddd;border-radius:6px;color:#666;font-size:.85rem;cursor:pointer;transition:all .2s ease;min-width:60px;height:35px;display:inline-flex;align-items:center;justify-content:center}.clear-filters:hover:not(.disabled){background-color:#e9ecef;color:#333;border-color:#ccc}.clear-filters.disabled{opacity:.5;cursor:not-allowed;background-color:#f8f9fa;color:#999}@media (max-width: 768px){.search-filters{flex-direction:column;align-items:stretch}.search-bar{min-width:auto}.filters{flex-direction:column;align-items:stretch;gap:8px}.filters select,.filters input,.clear-filters{width:100%}.modal-content{padding:20px;margin:20px;width:auto}.receipt-main{grid-template-columns:1fr;gap:20px;padding:20px}.print-header h1{font-size:24px}.booking-status{flex-direction:column;gap:8px}.booking-status h2,.reference-container strong{font-size:20px}.receipt-section{margin-bottom:15px}.receipt-row{font-size:13px}.receipt-row.grand-total{font-size:16px}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.customer-management{padding:20px}.customer-header{margin-bottom:30px}.customer-header h2{color:#333;margin-bottom:20px}.statistics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:40px}.stat-card{background-color:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 4px #0000000d;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-card h3{color:#666;font-size:1rem;margin:0 0 8px}.stat-card p{color:#333;font-size:1.8rem;font-weight:600;margin:0}.customers-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;overflow:auto}.customers-table{width:100%;border-collapse:collapse;min-width:1000px}.customers-table th{background-color:#f8f9fa;padding:16px;text-align:left;font-weight:500;color:#666;border-bottom:2px solid #eee}.customers-table td{padding:16px;border-bottom:1px solid #eee;color:#333}.action-buttons{display:flex;gap:8px}.action-buttons button{background:none;border:none;padding:8px;cursor:pointer;color:#666;transition:all .3s ease}.action-buttons button:hover{color:#b8860b}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;padding:40px;border-radius:16px;width:90%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 25px #0003}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.modal-header h2{margin:0;color:#333}.close-button{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:0;line-height:1}.customer-details{margin-bottom:30px}.customer-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:40px;background:#f8f9fa;padding:24px;border-radius:12px}.info-group{display:flex;align-items:flex-start;gap:16px}.info-icon{color:#b8860b;font-size:24px;margin-top:4px}.info-group h3{color:#666;font-size:.9rem;margin:0 0 4px}.info-group p{color:#333;font-size:1.1rem;margin:0;font-weight:500}.booking-history{margin-top:30px}.booking-history h3{color:#333;margin-bottom:20px}.booking-history table{width:100%;border-collapse:collapse}.booking-history th{background-color:#f8f9fa;padding:12px;text-align:left;font-weight:500;color:#666;border-bottom:2px solid #eee}.booking-history td{padding:12px;border-bottom:1px solid #eee;color:#333}.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500}.status-badge.pending{background-color:#fff3cd;color:#856404}.status-badge.completed{background-color:#d4edda;color:#155724}.status-badge.cancelled{background-color:#f8d7da;color:#721c24}.modal-footer{margin-top:30px;display:flex;justify-content:flex-end}.btn-secondary{background-color:#f8f9fa;color:#666;border:none;padding:12px 24px;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background-color:#e9ecef;transform:translateY(-1px)}.error-message{background-color:#f8d7da;color:#721c24;padding:12px;border-radius:8px;margin-bottom:20px;border:1px solid #f5c6cb}.no-results{text-align:center;padding:40px;background:#fff;border-radius:12px;color:#666;font-size:1.1rem}.loading{text-align:center;padding:40px;color:#666;font-size:1.1rem}@media (max-width: 768px){.customer-management{padding:16px}.statistics-grid,.customer-info{grid-template-columns:1fr;gap:16px}.modal-content{padding:20px;margin:16px;width:auto}.info-group{flex-direction:column;gap:8px}.info-icon{font-size:20px}}.analytics-container{padding:24px}.analytics-container h2{color:#333;margin-bottom:24px;font-size:1.5rem}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 4px #0000000d;transition:transform .3s ease,box-shadow .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.stat-card h3{color:#666;font-size:.875rem;margin:0 0 12px;font-weight:500}.stat-value{color:#333;font-size:1.75rem;font-weight:600;margin:0 0 8px}.stat-change{font-size:.875rem;margin:0}.stat-change.positive{color:#4caf50}.stat-change.negative{color:#f44336}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.chart-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 4px #0000000d}.chart-card.wide{grid-column:1 / -1}.chart-card h3{color:#333;font-size:1rem;margin:0 0 20px;font-weight:500}.chart-container{position:relative;width:100%;height:300px}.recharts-tooltip-wrapper{outline:none}.recharts-default-tooltip{background-color:#fff!important;border:1px solid #ddd!important;border-radius:8px!important;padding:12px!important;box-shadow:0 2px 8px #0000001a!important}.recharts-legend-wrapper{padding:0 16px}.recharts-legend-item{padding:4px 8px!important}@media (max-width: 1024px){.charts-grid{grid-template-columns:1fr}.chart-card.wide{grid-column:auto}}@media (max-width: 768px){.analytics-container{padding:16px}.stats-cards{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{padding:16px}.stat-value{font-size:1.5rem}.chart-card{padding:16px}.chart-container{height:250px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chart-card{animation:fadeIn .5s ease-out}.analytics-container{scrollbar-width:thin;scrollbar-color:#B8860B #f5f5f5}.analytics-container::-webkit-scrollbar{width:8px}.analytics-container::-webkit-scrollbar-track{background:#f5f5f5}.analytics-container::-webkit-scrollbar-thumb{background-color:#b8860b;border-radius:4px;border:2px solid #f5f5f5}.loading-state{display:flex;align-items:center;justify-content:center;min-height:400px;color:#666;font-size:1.1rem;background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000000d;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.error-state{display:flex;align-items:center;justify-content:center;min-height:400px;color:#dc3545;font-size:1.1rem;background:#fff2f2;border-radius:12px;box-shadow:0 2px 4px #dc35451a;border:1px solid #ffcdd2}.chatbot-container{position:fixed;bottom:20px;right:20px;transition:transform .3s ease-in-out;z-index:1000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif}.chatbot-container:not(.open){transform:translateY(calc(100% - 60px))}.chatbot-container.open{transform:translateY(0)}.chatbot-toggle{width:60px;height:60px;padding:10px;border-radius:50%;background-color:#b8860b;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.5rem;box-shadow:0 4px 12px #b8860b4d;transition:all .3s ease;outline:none}.chatbot-toggle:hover{transform:translateY(-2px);box-shadow:0 6px 16px #b8860b66}.chatbot-toggle.open{transform:scale(.9);background-color:#986c09}.chatbot-toggle:focus{outline:none}.chatbot-window{position:absolute;bottom:80px;right:0;width:400px;height:600px;background:#fff;border-radius:16px;box-shadow:0 8px 24px #0000001a;display:flex;flex-direction:column;overflow:hidden;animation:slideIn .3s ease}.chatbot-header{display:flex;justify-content:space-between;align-items:center;padding:15px;background-color:#b8860b;color:#fff;border-radius:10px 10px 0 0}.chatbot-title{display:flex;align-items:center;gap:10px}.header-actions{display:flex;gap:10px}.clear-button,.close-button{background:none;border:none;color:#fff;cursor:pointer;padding:5px;display:flex;align-items:center;justify-content:center;transition:opacity .2s;outline:none}.clear-button:focus,.close-button:focus{outline:none}.clear-button:hover,.close-button:hover{opacity:.8}.chatbot-avatar{font-size:1.25rem}.chatbot-messages{flex:1;padding:1rem;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.message{max-width:80%;margin:4px 10px;padding:8px 12px;border-radius:15px;position:relative}.message.user{margin-left:auto;background-color:#b8860b;color:#fff}.message.bot{margin-right:auto;background-color:#f0f0f0;color:#333}.message-content{margin-bottom:2px;word-wrap:break-word}.markdown-content{margin:0;line-height:1.3}.markdown-content p{margin:0 0 4px}.markdown-content p:last-child{margin-bottom:0}.markdown-content ul,.markdown-content ol{margin:4px 0;padding-left:20px}.markdown-content li{margin:2px 0}.markdown-content code{background:#0000001a;padding:2px 4px;border-radius:4px;font-size:.9em}.markdown-content pre{background:#0000000d;padding:8px;border-radius:8px;overflow-x:auto;margin:4px 0}.markdown-content pre code{background:none;padding:0}.message-time{font-size:.7rem;opacity:.7;text-align:right;margin-top:2px}.message.user .message-time{color:#fffc}.message.bot .message-time{color:#0009}.message.error{background:#fff2f2;color:#dc3545;align-self:center;font-size:.85rem;max-width:90%;text-align:center}.chatbot-input{padding:1rem;border-top:1px solid #eee;display:flex}.chatbot-input input{flex:1;padding:.75rem 1rem;border:2px solid #eee;border-radius:24px;font-size:.9rem;transition:all .3s ease}.chatbot-input input:focus{outline:none;border-color:#b8860b}.chatbot-input input:disabled{background-color:#f8f9fa;cursor:not-allowed}.chatbot-input button{background:none;color:#b8860b;border:none;width:auto;height:auto;padding:10px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1.2rem;outline:none}.chatbot-input button:focus{outline:none}.chatbot-input button:disabled{color:#ccc;cursor:not-allowed;transform:none}.chatbot-input button:disabled:hover{color:#ccc;transform:none}.chatbot-messages::-webkit-scrollbar{width:6px}.chatbot-messages::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.chatbot-messages::-webkit-scrollbar-thumb{background:#b8860b;border-radius:10px}.chatbot-messages::-webkit-scrollbar-thumb:hover{background:#986c09}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (max-width: 768px){.chatbot-window{height:60vh;bottom:80px}.chatbot-container{bottom:1rem;right:1rem}.chatbot-toggle{width:50px;height:50px;font-size:1.25rem}}.typing-indicator{padding:.75rem!important;display:flex;align-items:center;gap:.3rem;min-width:60px;max-width:60px!important}.typing-indicator span{display:block;width:8px;height:8px;background-color:#999;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.typing-indicator span:nth-child(1){animation-delay:0s}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}:root{--primary-color: #B8860B;--primary-light: #D4AF37;--primary-dark: #996515;--secondary-color: #1C1C1C;--secondary-light: #2C2C2C;--secondary-dark: #0F0F0F;--accent-color: #E8DCC4;--accent-dark: #D4C5A9;--text-light: #FFFFFF;--text-dark: #1A1A1A;--text-muted: #666666;--bg-light: #FFFFFF;--bg-cream: #FAF9F6;--bg-dark: #1C1C1C;--overlay-light: rgba(255, 255, 255, .9);--overlay-dark: rgba(28, 28, 28, .85);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .1);--shadow-md: 0 4px 8px rgba(0, 0, 0, .12);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .15);--transition: all .3s ease;--transition-slow: all .5s ease}*{margin:0;padding:0;box-sizing:border-box}*:focus{outline:none!important}html{scroll-behavior:smooth;scroll-padding-top:80px}html,body{width:100%;overflow-x:hidden;margin:0;padding:0;font-family:Poppins,sans-serif;line-height:1.6;background-color:var(--bg-light);color:var(--text-dark)}#root{width:100%;min-height:100vh}.app{width:100%;min-height:100vh;overflow-x:hidden}.full-page{min-height:100vh;width:100vw;display:flex;align-items:center;justify-content:center;font-size:2rem;padding-top:80px;background-color:var(--bg-cream);margin:0}main{width:100vw;margin:0;padding:0;overflow-x:hidden;scroll-snap-type:y proximity}section{scroll-snap-align:start;scroll-snap-stop:always}.btn{padding:1rem 2.5rem;font-size:1.1rem;font-weight:500;border:none;border-radius:3px;cursor:pointer;transition:var(--transition);text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden}.btn-primary{background-color:var(--primary-color);color:var(--text-light);box-shadow:var(--shadow-md)}.btn-primary:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background-color:transparent;color:var(--primary-color);border:2px solid var(--primary-color)}.btn-secondary:hover{background-color:var(--primary-color);color:var(--text-light);transform:translateY(-2px)}.section{padding:6rem 0;background-color:var(--bg-light);min-height:100vh;width:100vw;display:flex;flex-direction:column;justify-content:center}.section-dark{background-color:var(--bg-dark);color:var(--text-light)}.section-cream{background-color:var(--bg-cream)}.section-title{font-family:Playfair Display,serif;font-size:2.5rem;margin-bottom:2rem;text-align:center;position:relative;color:inherit}.section-title:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);width:80px;height:3px;background-color:var(--primary-color)}.fade-in{opacity:0;animation:fadeIn .8s ease forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.container{max-width:1200px;margin:0 auto;padding:0 2rem;width:100%}
