:root{--primary-brown:#3E2723;--secondary-brown:#5D4037;--accent-burgundy:#8D4037;--warm-beige:#EFEBE9;--dark-wood:#2E1A16;--light-beige:#F5F5F5;--cream-white:#FAFAFA;--deep-green:#2E4D32;--pure-white:#FFFFFF;--text-dark:#212121;--text-medium:#424242;--text-light:#757575;--border-light:#E0E0E0;--shadow-color:#1B1B1B;--font-heading:'Cinzel',serif;--font-body:'Crimson Text',serif;--shadow-light:0 2px 10px rgba(27,27,27,0.1);--shadow-medium:0 4px 20px rgba(27,27,27,0.15);--shadow-strong:0 8px 30px rgba(27,27,27,0.25);--transition-smooth:all 0.3s ease;--price-font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);line-height:1.7;color:var(--text-dark);background-color:var(--cream-white);font-size:16px}
body.modal-open{overflow:hidden;padding-right:0!important}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.transparent-header{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(224,159,119,0.7);backdrop-filter:blur(10px);box-shadow:0 2px 20px rgba(0,0,0,0.1);transition:var(--transition-smooth);padding:15px 0}
.transparent-header .logo h1{color:var(--primary-brown)}
.transparent-header .username{color:var(--primary-brown)}
.header-container{max-width:1200px;margin:0 auto;padding:0 20px;position:relative}
.header-layout{display:flex;align-items:center;justify-content:center;width:100%;position:relative;min-height:60px}
.header-layout h1{font-family:var(--font-heading);font-size:2rem;color:var(--primary-brown);font-weight:600;margin:0;letter-spacing:1px;opacity:1;user-select:none;transition:color 0.3s ease}
.logo-link{text-decoration:none;cursor:pointer}
.logo-link:hover h1{color:var(--accent-burgundy)}
.logo h1{font-family:var(--font-heading);font-size:2rem;color:var(--primary-brown);font-weight:600;margin:0;letter-spacing:1px}
.logo-image{width:50px;height:50px;opacity:1;user-select:none;position:fixed;top:20px;z-index:1001;transition:transform 0.3s ease}
.logo-left{left:80px}
.logo-right{right:80px}
.logo-image:hover{transform:scale(1.05) rotate(5deg)}
.header-right{display:flex;align-items:center;gap:20px}
.btn-reserver{position:fixed;top:20px;right:80px;background:var(--accent-burgundy);color:var(--pure-white);padding:12px 24px;border-radius:25px;text-decoration:none;font-weight:600;font-family:var(--font-heading);transition:var(--transition-smooth);border:none;cursor:pointer;box-shadow:0 4px 15px rgba(141,64,55,0.3);font-size:0.9rem;letter-spacing:0px;z-index:1001}
.btn-connexion{background:var(--accent-burgundy);color:var(--pure-white);padding:12px 24px;border-radius:25px;text-decoration:none;font-weight:600;font-family:var(--font-heading);transition:var(--transition-smooth);border:none;cursor:pointer;box-shadow:0 4px 15px rgba(141,64,55,0.3);font-size:0.9rem;letter-spacing:0px}
.btn-reserver:hover,.btn-connexion:hover{background:var(--primary-brown);transform:translateY(-2px);box-shadow:var(--shadow-medium)}
.username{color:var(--primary-brown);font-weight:500;font-family:var(--font-heading)}
.hero{height:100vh;background:linear-gradient(rgba(33,33,33,0.0),rgba(46,26,22,0.4)),url('uploads/maison.jpg') center/cover no-repeat;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:var(--pure-white);position:relative;overflow:hidden}
.hero-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(45deg,rgba(46,26,22,0.4),rgba(33,33,33,0.1))}
.hero-vignette{position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at center,transparent 30%,rgba(33,33,33,0.2) 100%);opacity:0;transition:opacity 1.5s ease-in-out;z-index:1}
.hero-content{position:relative;z-index:2;max-width:800px;padding:0 20px;opacity:0;transform:translateY(30px);transition:all 1s ease-in-out}
.hero-content.loaded{opacity:1;transform:translateY(0)}
.hero-content h1{font-family:var(--font-heading);font-size:4rem;font-weight:400;margin-bottom:0.5rem;text-shadow:3px 3px 6px rgba(0,0,0,0.7);letter-spacing:2px}
.hero-content h2{font-family:var(--font-heading);font-size:2.2rem;font-weight:300;margin-bottom:1rem;color:var(--warm-beige);text-shadow:2px 2px 4px rgba(0,0,0,0.7);letter-spacing:1px}
.hero-content p{font-size:1.4rem;margin-bottom:2.5rem;text-shadow:1px 1px 3px rgba(0,0,0,0.7);font-style:italic;letter-spacing:0.5px}
.btn-hero{background:var(--accent-burgundy);color:var(--pure-white);padding:15px 35px;border-radius:30px;text-decoration:none;font-size:1.1rem;font-weight:600;font-family:var(--font-heading);transition:var(--transition-smooth);display:inline-block;text-transform:uppercase;letter-spacing:1px;box-shadow:0 6px 20px rgba(141,64,55,0.4)}
.btn-hero:hover{background:var(--primary-brown);transform:translateY(-3px);box-shadow:0 10px 30px rgba(62,39,35,0.4)}
.hero-scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);text-align:center;color:var(--pure-white);cursor:pointer;transition:var(--transition-smooth);display:flex;flex-direction:column;align-items:center;justify-content:center;width:fit-content;z-index:3}
.hero-scroll:hover{transform:translateX(-50%) translateY(-5px)}
.hero-scroll span{display:block;margin-bottom:10px;font-size:0.9rem;text-transform:uppercase;letter-spacing:2px;text-align:center;white-space:nowrap;font-family:var(--font-heading)}
.arrow-down{width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:12px solid var(--warm-beige);animation:bounce 2s infinite;margin:0 auto}
@keyframes bounce{0%,20%,50%,80%,100%{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}
.main-content{margin-top:0}
.presentation-section{padding:100px 0;background:var(--light-beige)}
.presentation-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.carousel-container{position:relative;transform:translateY(-60px)}
.carousel-wrapper{position:relative;border-radius:15px;overflow:hidden;box-shadow:0 0 0 1px rgba(62,39,35,0.2),0 8px 30px rgba(27,27,27,0.25),0 0 20px rgba(62,39,35,0.15)}
.carousel-slides{position:relative;width:100%;height:500px}
.slide{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 0.5s ease}
.slide.active{opacity:1}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);background:var(--primary-brown);color:var(--pure-white);border:2px solid var(--accent-burgundy);width:50px;height:50px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:var(--transition-smooth);z-index:10}
.carousel-btn:hover{background:var(--accent-burgundy);transform:translateY(-50%) scale(1.1)}
.carousel-prev{left:-25px}
.carousel-next{right:-25px}
.carousel-dots{display:flex;justify-content:center;gap:10px;margin-top:20px}
.dot{width:12px;height:12px;border-radius:50%;background:var(--border-light);cursor:pointer;transition:var(--transition-smooth);border:2px solid var(--primary-brown)}
.dot.active{background:var(--accent-burgundy);transform:scale(1.2)}
.presentation-text h2{font-family:var(--font-heading);font-size:2.5rem;color:var(--primary-brown);margin-bottom:1.5rem;letter-spacing:1px}
.rating-badge{display:flex;align-items:center;gap:15px;background:var(--pure-white);padding:15px 20px;border-radius:10px;box-shadow:var(--shadow-light);margin-bottom:2rem;width:fit-content;border:2px solid var(--accent-burgundy)}
.rating-score{font-size:2rem;font-weight:700;color:var(--accent-burgundy);font-family:var(--font-heading)}
.rating-text strong{display:block;color:var(--text-dark);font-weight:700;font-family:var(--font-heading)}
.rating-text span{font-size:0.9rem;color:var(--text-medium)}
.intro-text{font-size:1.1rem;margin-bottom:1.5rem;color:var(--text-dark);font-style:italic;line-height:1.8}
.presentation-text p{margin-bottom:1.2rem;line-height:1.7;text-align:justify}
.highlights{background:var(--pure-white);padding:20px;border-radius:10px;margin-top:2rem;box-shadow:var(--shadow-light);border:2px solid var(--warm-beige)}
.highlights h3{color:var(--primary-brown);margin-bottom:15px;font-family:var(--font-heading)}
.highlights ul{list-style:none}
.highlights li{margin-bottom:8px;color:var(--text-medium)}
.btn-center-container{display:flex;justify-content:center;margin-top:3rem;width:100%}
.btn-presentation{background:var(--primary-brown);color:var(--pure-white);padding:15px 30px;border-radius:25px;text-decoration:none;font-weight:600;font-family:var(--font-heading);transition:var(--transition-smooth);display:inline-block;font-size:1.1rem;letter-spacing:1px;box-shadow:0 4px 15px rgba(62,39,35,0.3)}
.btn-presentation:hover{background:var(--secondary-brown);transform:translateY(-2px);box-shadow:var(--shadow-medium)}
.hosts-section{padding:100px 0;background:var(--pure-white)}
.hosts-content{display:grid;grid-template-columns:300px 1fr;gap:50px;align-items:start}
.host-image img{width:250px;height:250px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 1px rgba(141,64,55,0.2),0 8px 30px rgba(27,27,27,0.25),0 0 25px rgba(141,64,55,0.15)}
.host-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}
.host-header h2{font-family:var(--font-heading);font-size:2.2rem;color:var(--primary-brown);margin:0;letter-spacing:1px}
.host-rating{display:flex;align-items:center;gap:15px;background:var(--light-beige);padding:15px 20px;border-radius:10px;border:2px solid var(--accent-burgundy)}
.host-description p{margin-bottom:1.5rem;line-height:1.7;text-align:justify}
.languages{margin-top:2rem;padding:20px;background:var(--light-beige);border-radius:10px;border:2px solid var(--warm-beige)}
.languages h3{color:var(--primary-brown);margin-bottom:15px;font-family:var(--font-heading)}
.language-tag{display:inline-block;background:var(--pure-white);padding:8px 15px;border-radius:20px;margin:5px 10px 5px 0;font-weight:500;box-shadow:var(--shadow-light);border:2px solid var(--accent-burgundy);font-family:var(--font-heading)}
.footer{background:var(--text-dark);color:var(--warm-beige);padding:60px 0 30px}
.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px;margin-bottom:40px}
.footer-section h3{font-family:var(--font-heading);color:var(--accent-burgundy);margin-bottom:20px;font-size:1.3rem;letter-spacing:0.5px}
.footer-subtitle{font-style:italic;margin-bottom:15px;color:var(--warm-beige)}
.footer-section address{font-style:normal;line-height:1.6}
.footer-section ul{list-style:none}
.footer-section ul li{margin-bottom:8px}
.footer-section a{color:var(--warm-beige);text-decoration:none;transition:var(--transition-smooth)}
.footer-section a:hover{color:var(--accent-burgundy)}
.certifications{margin-top:20px;padding:15px;background:rgba(141,64,55,0.1);border-radius:8px;border:1px solid var(--accent-burgundy)}
.social-links{display:flex;flex-direction:column;gap:10px;margin-bottom:25px}
.social-link{display:flex;align-items:center;gap:10px;padding:8px 0;transition:var(--transition-smooth)}
.social-link:hover{transform:translateX(5px);color:var(--accent-burgundy)}
.newsletter{margin-top:25px}
.newsletter h4{color:var(--accent-burgundy);margin-bottom:10px;font-family:var(--font-heading)}
.newsletter-form{display:flex;gap:10px;margin-top:15px}
.newsletter-form input{flex:1;padding:10px;border:1px solid var(--border-light);border-radius:5px;background:var(--pure-white)}
.newsletter-form button{background:var(--accent-burgundy);color:var(--pure-white);border:none;padding:10px 15px;border-radius:5px;cursor:pointer;transition:var(--transition-smooth);font-family:var(--font-heading);font-weight:600}
.newsletter-form button:hover{background:var(--primary-brown)}
.footer-bottom{border-top:1px solid rgba(239,235,233,0.2);padding-top:30px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px}
.footer-legal{display:flex;gap:20px;flex-wrap:wrap}
.footer-legal a{color:var(--warm-beige);text-decoration:none;font-size:0.9rem;transition:var(--transition-smooth)}
.footer-legal a:hover{color:var(--accent-burgundy)}
.copyright{text-align:center;font-size:0.9rem;color:var(--warm-beige)}
.animate-in{animation:fadeInUp 0.8s ease forwards}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.reservation-hero{padding:120px 0 60px;background:var(--light-beige);min-height:100vh}
.establishment-header{margin-bottom:2rem;margin-top:1.5rem}
.establishment-info h1{font-family:var(--font-heading);font-size:2.5rem;color:var(--primary-brown);margin:0;letter-spacing:1px}
.establishment-info .address{font-size:0.9rem;color:var(--text-medium);margin:5px 0 0}
.rating-location{margin-bottom:2rem}
.location-badge{background:var(--pure-white);padding:20px;border-radius:10px;box-shadow:var(--shadow-light);margin-bottom:2rem;width:fit-content;border:2px solid var(--accent-burgundy);line-height:1.6}
.location-badge strong{color:var(--accent-burgundy);font-family:var(--font-heading)}
.location-badge span{display:block;margin-top:5px;font-size:0.95rem}
.location-badge small{display:block;margin-top:8px;font-size:0.9rem;color:var(--text-light);font-style:italic}
.photos-map-links{display:flex;gap:20px;margin-bottom:2rem}
.photo-link,.map-link{background:var(--primary-brown);color:var(--pure-white);padding:12px 20px;border-radius:25px;text-decoration:none;font-weight:600;font-family:var(--font-heading);transition:var(--transition-smooth);border:none;cursor:pointer;font-size:0.95rem;display:flex;align-items:center;gap:8px}
.photo-link:hover,.map-link:hover{background:var(--accent-burgundy);transform:translateY(-2px);box-shadow:var(--shadow-medium)}
.description-summary{background:var(--pure-white);padding:25px;border-radius:10px;margin:1.5rem 0 2rem;box-shadow:var(--shadow-light);border:2px solid var(--warm-beige)}
.description-summary p{line-height:1.7;text-align:justify;margin:0}
.highlight-features{background:var(--pure-white);padding:25px;border-radius:10px;margin:2rem 0;box-shadow:var(--shadow-light);border:2px solid var(--warm-beige)}
.highlight-features h3{font-family:var(--font-heading);color:var(--primary-brown);margin-bottom:1rem;font-size:1.3rem}
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:0.5rem}
.feature{color:var(--text-dark);font-weight:500;padding:8px 0;border-bottom:1px solid var(--border-light)}
.main-gallery{margin-top:3rem}
.gallery-preview{position:relative;border-radius:15px;overflow:hidden;box-shadow:var(--shadow-strong);cursor:pointer;transition:var(--transition-smooth)}
.gallery-preview:hover{transform:translateY(-5px);box-shadow:0 15px 40px rgba(27,27,27,0.3)}
.gallery-preview img{width:100%;height:400px;object-fit:cover;transition:var(--transition-smooth)}
.gallery-preview:hover img{transform:scale(1.05)}
.gallery-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(33,33,33,0.3);display:flex;align-items:center;justify-content:center;opacity:0;transition:var(--transition-smooth)}
.gallery-preview:hover .gallery-overlay{opacity:1}
.gallery-overlay span{background:var(--pure-white);color:var(--primary-brown);padding:12px 24px;border-radius:25px;font-weight:600;font-family:var(--font-heading);box-shadow:var(--shadow-medium)}
.gallery-overview{display:grid;grid-template-columns:2fr 1fr;gap:8px;margin-top:1rem}
.gallery-overview img{width:100%;height:100%;object-fit:cover;border-radius:4px;cursor:pointer}
.gallery-left {height: 520px;border-radius: 12px;overflow: hidden;}
.gallery-left img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease;will-change:transform}
.gallery-right{position:relative;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:8px;height:520px}
.gallery-right img{width:100%;height:100%;object-fit:cover;border-radius:8px;display:block;aspect-ratio:1/1;transition:transform .35s ease;will-change:transform}
.btn-all-photos{position:absolute;bottom:8px;right:8px;background:#fff;border:none;padding:.6rem 1rem;border-radius:6px;font-weight:700;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.gallery-overview img,
.gallery-strip img {transition: transform 0.4s ease; }
.gallery-overview img:hover,
.gallery-strip img:hover {transform: scale(1.08); }
.gallery-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:10px}
.gallery-strip img,.gallery-strip .thumb-more{height:110px;width:100%;object-fit:cover;border-radius:10px;display:block;position:relative;overflow:hidden;transition:transform .35s ease;will-change:transform}
.gallery-strip img{cursor:pointer}
.thumb-more{background:#0a0a0a;border:0;cursor:pointer}
.thumb-more span{position:absolute;right:10px;bottom:10px;background:rgba(0,0,0,.6);color:#fff;padding:.45rem .6rem;border-radius:8px;font-weight:700}
.gallery-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.2);z-index:10000;padding:20px;animation:fadeIn 0.3s ease;align-items:center;justify-content:center}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.gallery-modal-content{display:flex;flex-direction:column;height:90vh;background:var(--pure-white);border-radius:15px;box-shadow:0 20px 60px rgba(0,0,0,0.5);overflow:hidden;width:min(1680px,95vw);max-height:calc(100vh - 48px);overflow:auto;border-radius:12px;scrollbar-width:none}
.gallery-modal-content::-webkit-scrollbar{width:0;height:0}
.gallery-header{display:flex;justify-content:space-between;align-items:center;padding:20px 30px;background:var(--light-beige);border-bottom:1px solid var(--border-light)}
.gallery-counter{font-family:var(--font-heading);font-size:1.2rem;font-weight:600;color:var(--text-dark)}
.gallery-close{background:none;border:none;color:var(--text-dark);font-size:2.5rem;cursor:pointer;transition:var(--transition-smooth);padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.gallery-close:hover{background:var(--border-light);color:var(--accent-burgundy)}
.gallery-main{flex:1;display:flex;align-items:center;position:relative;padding:20px 24px;background:var(--pure-white)}
.gallery-image-container{flex:1;text-align:center;height:60vh;display:flex;align-items:center;justify-content:center;width:100%;aspect-ratio:16/9}
.gallery-image-container img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s ease;border-radius:10px;box-shadow:var(--shadow-medium)}
.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:var(--pure-white);color:var(--primary-brown);border:2px solid var(--border-light);width:50px;height:50px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:var(--transition-smooth);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-light)}
.gallery-nav:hover{background:var(--accent-burgundy);color:var(--pure-white);border-color:var(--accent-burgundy);transform:translateY(-50%) scale(1.1);box-shadow:var(--shadow-medium)}
.gallery-prev{left:20px}
.gallery-next{right:20px}
.gallery-thumbnails{padding:20px 30px;background:var(--light-beige);border-top:1px solid var(--border-light)}
.thumbnails-container{display:flex;gap:10px;overflow-x:auto;padding:10px 0;justify-content:center;flex-wrap:wrap;max-height:120px;overflow-y:auto}
.thumbnail{width:80px;height:60px;object-fit:cover;border-radius:8px;cursor:pointer;transition:var(--transition-smooth);border:2px solid transparent;opacity:0.7;box-shadow:var(--shadow-light)}
.thumbnail:hover{opacity:1;transform:scale(1.05);border-color:var(--accent-burgundy);box-shadow:var(--shadow-medium)}
.thumbnail.active{opacity:1;border-color:var(--accent-burgundy);box-shadow:0 0 15px rgba(141,64,55,0.3)}
.thumbnails-container::-webkit-scrollbar{height:8px}
.thumbnails-container::-webkit-scrollbar-track{background:var(--border-light);border-radius:4px}
.thumbnails-container::-webkit-scrollbar-thumb{background:var(--accent-burgundy);border-radius:4px}
.thumbnails-container::-webkit-scrollbar-thumb:hover{background:var(--primary-brown)}
.booking-calendar-section{padding:60px 0;background:var(--pure-white)}
.booking-two-col{display:grid;grid-template-columns:minmax(260px,320px) 1fr;gap:24px;align-items:start;margin-top:24px}
.booking-sidebar{position:static;grid-column:1;align-self:start}
.booking-main{min-width:0;grid-column:2}
.booking-results{width:100%;margin-top:24px}
.booking-form{background:var(--light-beige);padding:20px;border-radius:12px;box-shadow:var(--shadow-medium);border:2px solid var(--warm-beige)}
.guest-selector{margin-bottom:20px}
.guest-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-light)}
.guest-item:last-child{border-bottom:none}
.guest-label{font-weight:600;color:var(--text-dark);font-family:var(--font-heading);font-size:0.9rem}
.guest-item small{display:block;color:var(--text-light);font-size:0.75rem;margin-top:2px}
.guest-controls{display:flex;align-items:center;gap:12px}
.guest-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--accent-burgundy);background:var(--pure-white);color:var(--accent-burgundy);cursor:pointer;font-size:1rem;font-weight:600;transition:var(--transition-smooth)}
.guest-btn:hover{background:var(--accent-burgundy);color:var(--pure-white)}
.guest-count{min-width:18px;text-align:center;font-weight:600;color:var(--text-dark);font-size:0.9rem}
.room-selector{margin-bottom:20px}
.room-selector label{display:block;margin-bottom:6px;font-weight:600;color:var(--text-dark);font-family:var(--font-heading);font-size:0.9rem}
.room-selector select{width:100%;padding:10px;border:1px solid var(--border-light);border-radius:6px;background:var(--pure-white);font-family:var(--font-body);font-size:0.9rem}
.selected-dates{margin-bottom:20px}
.date-input{margin-bottom:12px}
.date-input label{display:block;margin-bottom:4px;font-weight:600;color:var(--text-dark);font-family:var(--font-heading);font-size:0.9rem}
.date-input input{width:100%;padding:10px;border:1px solid var(--border-light);border-radius:6px;background:var(--pure-white);cursor:pointer;font-family:var(--font-body);font-size:0.9rem}
.btn-search{width:100%;background:var(--accent-burgundy);color:var(--pure-white);border:none;padding:12px;border-radius:6px;font-weight:600;font-family:var(--font-heading);cursor:pointer;transition:var(--transition-smooth);font-size:1rem;letter-spacing:1px}
.btn-search:hover{background:var(--primary-brown);transform:translateY(-2px);box-shadow:var(--shadow-medium)}
.booking-calendar{background:var(--pure-white);border-radius:12px;padding:25px;box-shadow:var(--shadow-medium);border:2px solid var(--warm-beige);min-height:600px;width:100%}
.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}
.calendar-header h3{font-family:var(--font-heading);font-size:1.8rem;color:var(--primary-brown);margin:0;letter-spacing:1px}
.nav-btn{width:45px;height:45px;border-radius:50%;border:2px solid var(--accent-burgundy);background:var(--pure-white);color:var(--accent-burgundy);font-size:1.3rem;cursor:pointer;transition:var(--transition-smooth);font-weight:bold}
.nav-btn:hover{background:var(--accent-burgundy);color:var(--pure-white);transform:scale(1.1)}
.calendar-grid{margin-bottom:20px}
.weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:10px}
.weekday{padding:12px 8px;text-align:center;font-weight:700;color:var(--text-dark);background:var(--light-beige);font-family:var(--font-heading);font-size:0.9rem;border-radius:8px;text-transform:uppercase;letter-spacing:0.5px}
.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.day{min-height:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-smooth);font-weight:600;font-size:1rem;position:relative;border-radius:8px;padding:8px 4px;gap:4px}
.day-number{font-size:1.1rem;font-weight:700;margin-bottom:2px}
.day-price{font-size:0.95rem;font-weight:600;line-height:1.1;text-align:center;min-height:16px;display:flex;align-items:center;justify-content:center;font-family:var(--price-font);letter-spacing:0;font-variant-numeric:tabular-nums}
.day.empty{cursor:default;background:transparent}
.day.available{background:var(--light-beige);color:var(--text-dark);border:1px solid transparent}
.day.available:hover{background:var(--warm-beige);transform:scale(1.05);border-color:var(--accent-burgundy);box-shadow:0 4px 12px rgba(141,64,55,0.2)}
.day.busy{background:#ffebee;color:var(--text-light);cursor:not-allowed}
.day.busy .day-price{text-decoration:line-through;opacity:0.5}
.day.past{background:#f5f5f5;color:var(--text-light);cursor:not-allowed;opacity:0.6}
.calendar-days .day.today{background:transparent!important;color:var(--text-dark)!important;border:1px solid #000!important;box-shadow:none!important}
.calendar-days .day.selected{background:var(--accent-burgundy)!important;color:var(--pure-white)!important;box-shadow:0 4px 15px rgba(141,64,55,.4);transform:scale(1.05)}
.calendar-days .day.in-range{background:rgba(141,64,55,.18)!important;color:var(--text-dark)!important;border:1px solid rgba(141,64,55,.25)}
.calendar-days .day.preview-range{background:rgba(141,64,55,.15)!important;color:var(--text-dark);border:1px dashed var(--accent-burgundy)}
.calendar-days .day.preview-start{background:var(--primary-brown)!important;color:var(--pure-white);font-weight:700;border-radius:16px}
.calendar-days .day.preview-end{background:rgba(141,64,55,.4)!important;color:var(--text-dark);font-weight:700;border:2px solid var(--accent-burgundy);border-radius:16px}
.day.selected .day-price,.day.in-range .day-price,.day.preview-range .day-price,.day.preview-start .day-price,.day.preview-end .day-price{display:none}
.day.selected.start{border-radius:16px}
.day.selected.end{border-radius:16px}
.day.selected.start::after,.day.preview-start::after{content:"Arrivée";position:absolute;bottom:6px;left:6px;padding:2px 6px;font-size:.7rem;border-radius:10px;background:rgba(255,255,255,.9);color:var(--primary-brown);font-family:var(--font-heading)}
.day.selected.end::after,.day.preview-end::after{content:"Départ";position:absolute;bottom:6px;right:6px;padding:2px 6px;font-size:.7rem;border-radius:10px;background:rgba(255,255,255,.9);color:var(--primary-brown);font-family:var(--font-heading)}
.price-loading{width:30px;height:12px;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0 50%,#e0e0e0 75%);border-radius:6px;animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{background-position:-50px 0}100%{background-position:50px 0}}
.calendar-days .day .day-price.price-available,.calendar-days .day .day-price.price-cheapest{color:#1b5e20}
.price-unavailable{color:var(--text-light);text-decoration:line-through;opacity:0.6}
.price-cheapest{color:#2e7d32;font-weight:700;position:relative}
.price-cheapest::after{position:absolute;top:-2px;right:-8px;font-size:0.6rem;color:#ffa000}
.calendar-legend{display:flex;justify-content:center;gap:25px;flex-wrap:wrap;margin-top:20px;padding:15px;background:var(--light-beige);border-radius:8px}
.legend-item{display:flex;align-items:center;gap:8px;font-size:0.9rem;color:var(--text-medium);font-weight:500}
.legend-dot{width:16px;height:16px;border-radius:50%;border:1px solid rgba(0,0,0,0.1)}
.legend-dot.available{background:var(--light-beige)}
.legend-dot.busy{background:#ffebee}
.legend-dot.selected{background:var(--primary-brown)}
.legend-dot.cheapest{background:#2e7d32;position:relative}
.legend-dot.cheapest::after{position:absolute;top:-2px;right:-6px;font-size:0.6rem;color:#ffa000}
.all-available-rooms{display:grid;gap:20px;margin-bottom:30px}
.room-result{background:var(--pure-white);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-medium);border:2px solid var(--warm-beige);display:flex;cursor:pointer;transition:var(--transition-smooth);animation:slideInUp 0.5s ease forwards;opacity:0}
.room-result:nth-child(2){animation-delay:0.1s}
.room-result:nth-child(3){animation-delay:0.2s}
.room-result:nth-child(4){animation-delay:0.3s}
.room-result:hover{transform:translateY(-3px);box-shadow:var(--shadow-strong);border-color:var(--accent-burgundy)}
.room-main-image{width:350px;height:220px;position:relative;overflow:hidden}
.room-main-image img{width:100%;height:100%;object-fit:cover;transition:transform 0.3s}
.room-result:hover .room-main-image img{transform:scale(1.05)}
.room-details{flex:1;padding:20px;display:flex;justify-content:space-between;align-items:flex-start}
.room-info{flex:1;padding-right:30px}
.room-info h3{margin:0 0 10px 0;color:var(--primary-brown);font-family:var(--font-heading);font-size:1.3rem;letter-spacing:0.5px}
.room-info p{margin-bottom:8px;color:var(--text-medium);line-height:1.5;font-size:0.95rem}
.room-price{text-align:right;min-width:160px}
.room-price .price{font-size:2.4rem;line-height:1.1;letter-spacing:.3px;font-weight:600;color:var(--accent-burgundy);font-family:var(--font-heading)}
.room-price .nights{font-size:0.9rem;color:var(--text-light);margin-top:5px}
.single-reserve-button{text-align:center;padding:25px;border-top:3px solid var(--accent-burgundy);background:var(--pure-white);border-radius:0 0 12px 12px;margin-top:20px}
.btn-reserve-all{background:linear-gradient(45deg,var(--accent-burgundy),var(--primary-brown));color:var(--pure-white);padding:18px 45px;border:none;border-radius:30px;cursor:pointer;font-weight:700;font-family:var(--font-heading);transition:var(--transition-smooth);font-size:1.2rem;letter-spacing:1px;box-shadow:0 8px 25px rgba(141,64,55,0.4);text-transform:uppercase;position:relative;overflow:hidden}
.btn-reserve-all::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left 0.5s}
.btn-reserve-all:hover::before{left:100%}
.btn-reserve-all:hover{transform:translateY(-3px);box-shadow:0 12px 35px rgba(62,39,35,0.5)}
@keyframes slideInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.room-details-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.4);z-index:99999;align-items:center;justify-content:center;padding:20px}
.room-details-content{background:white;border-radius:12px;width:95vw;max-width:1100px;height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 25px 80px rgba(0,0,0,0.5);max-height:90vh;overflow:auto}
.room-details-content::-webkit-scrollbar{width:10px;height:10px}
.room-details-content::-webkit-scrollbar-thumb{background:#bbb;border-radius:8px}
.room-details-content::-webkit-scrollbar-track{background:transparent}
.room-details-header{padding:15px 20px;border-bottom:1px solid #e0e0e0;background:#f8f8f8;flex-shrink:0;display:flex;justify-content:space-between;align-items:center}
.room-details-header h2{font-family:var(--font-heading);color:var(--primary-brown);margin:0;font-size:1.3rem}
.room-details-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background 0.3s}
.room-details-close:hover{background:#f0f0f0;color:#333}
.room-details-body{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;padding:16px;flex:1;overflow:visible;align-items:start}
.room-details-left{display:flex;flex-direction:column;gap:12px;min-width:0}
.room-details-right{display:flex;flex-direction:column;gap:12px;overflow:visible;max-height:none;min-width:0}
.room-details-gallery{position:relative;width:100%;height:430px;overflow:hidden;background:#f8f8f8;border-radius:8px}
.room-carousel-container{width:100%;height:100%;overflow:hidden;position:relative}
.room-carousel-track{display:flex;width:100%;height:100%;transition:transform 0.4s cubic-bezier(0.25,0.46,0.45,0.94)}
.room-carousel-slide{flex:0 0 100%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f5f5f5}
.room-carousel-slide img{max-width:100%;max-height:100%;object-fit:cover;width:100%;height:100%}
.room-gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,0.9);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all 0.3s;color:#333;font-weight:bold;font-size:0.9rem}
.room-gallery-nav:hover{background:var(--accent-burgundy);color:white;transform:translateY(-50%) scale(1.05)}
.room-gallery-prev{left:8px}
.room-gallery-next{right:8px}
.room-surface{background:var(--light-beige);border:1px solid var(--border-light);border-radius:6px;padding:10px;display:flex;align-items:center;gap:10px;margin-bottom:14px}
.surface-badge{background:var(--accent-burgundy);color:white;padding:6px 12px;border-radius:15px;font-weight:600;font-family:var(--font-heading);font-size:0.8rem}
.room-description{line-height:1.5;color:var(--text-dark);font-size:0.9rem;text-align:justify;background:var(--light-beige);padding:15px;border-radius:8px;border:1px solid var(--border-light);margin-bottom:14px}
.room-description p{margin:0;max-height:none;overflow:visible}
.amenities-section{margin:0;padding:10px;background:var(--pure-white);border:1px solid var(--border-light);border-radius:6px;margin-bottom:14px}
.amenities-section h4{margin:0 0 8px 0;color:var(--primary-brown);font-family:var(--font-heading);font-size:1.05rem;font-weight:600}
.amenities-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px 14px}
.amenity-item{display:flex;align-items:center;gap:6px;padding:6px 0;font-size:.9rem;color:var(--text-dark);line-height:1.2}
.amenity-item::before{content:"✓";color:var(--accent-burgundy);font-weight:bold;font-size:0.7rem;flex-shrink:0}
.amenities-list,.rules-full{background:#fff;border-radius:16px;box-shadow:var(--shadow-light);padding:24px;margin:28px 0}
.amenities-list h2,.amenities-list h3,.amenities h2,.amenities h3,.rules-full h2,.rules-full h3,.rules h2,.rules h3,.house-rules h3{font-family:var(--font-heading);font-weight:700;color:var(--primary-brown);letter-spacing:0.5px;font-size:1.3rem;margin:0 0 15px 0;border-bottom:2px solid var(--warm-beige);padding-bottom:6px}
.amenities-list h4,.rules-full h4{font-family:var(--font-heading);font-weight:600;margin:14px 0 6px;font-size:1rem;color:var(--text-dark)}
.amenities-cols{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.amenities-list ul{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr;gap:6px}
.amenities-list li{position:relative;padding-left:20px}
.amenities-list li:before{content:"✓";position:absolute;left:0;top:0;line-height:1;color:var(--deep-green)}
.rules-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.rules-grid > div{background:var(--cream-white);border:1px solid var(--border-light);border-radius:12px;padding:14px}
.booking-results p[style*="color:red"]{background:#ffebee;color:#c62828!important;padding:15px;border-radius:8px;text-align:center;font-weight:500;border:1px solid #ef9a9a}
.booking-table{width:100%;border-collapse:collapse;margin-top:2rem;background:white;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-medium)}
.booking-table th{background:var(--primary-brown);color:white;padding:15px;text-align:left;font-family:var(--font-heading);font-weight:600}
.booking-table td{padding:20px 15px;border-bottom:1px solid var(--border-light);vertical-align:top}
.booking-table tr:hover{background:var(--light-beige)}
.room-type-cell{display:flex;align-items:center;gap:20px}
.room-type-image{width:200px;height:140px;border-radius:8px;object-fit:cover;cursor:zoom-in}
.room-type-info h4{margin:0;color:var(--primary-brown);font-family:var(--font-heading)}
.room-type-info p{margin:5px 0 0;font-size:0.9rem;color:var(--text-medium)}
.room-price .per-night{font-size:0.9rem;color:var(--text-medium)}
.room-selector{text-align:center}
.room-quantity-controls{display:flex;align-items:center;justify-content:center;gap:10px}
.quantity-btn{width:35px;height:35px;border:1px solid var(--accent-burgundy);background:white;color:var(--accent-burgundy);border-radius:50%;cursor:pointer;font-weight:bold;transition:var(--transition-smooth)}
.quantity-btn:hover{background:var(--accent-burgundy);color:white}
.quantity-btn:disabled{opacity:0.5;cursor:not-allowed}
.quantity-display{min-width:30px;text-align:center;font-weight:600;font-family:var(--font-heading)}
.reservation-summary{background:var(--light-beige);padding:20px;border-radius:8px;margin-top:20px;border:2px solid var(--accent-burgundy)}
.reservation-summary h3{margin:0 0 15px;color:var(--primary-brown);font-family:var(--font-heading)}
.summary-line{display:flex;justify-content:space-between;margin-bottom:8px}
.summary-total{border-top:2px solid var(--accent-burgundy);padding-top:10px;font-weight:700;font-size:1.2rem;color:var(--primary-brown)}
.reservation-details-section{padding:80px 0 60px;background:var(--light-beige);min-height:100vh}
.reservation-progress{display:flex;justify-content:center;align-items:center;margin-bottom:40px;gap:40px}
.progress-step{display:flex;align-items:center;gap:10px;color:var(--text-light)}
.progress-step.active{color:var(--primary-brown)}
.step-number{width:35px;height:35px;border-radius:50%;background:var(--border-light);color:var(--text-light);display:flex;align-items:center;justify-content:center;font-weight:600;font-family:var(--font-heading)}
.progress-step.active .step-number{background:var(--accent-burgundy);color:var(--pure-white)}
.reservation-content-grid{display:grid;grid-template-columns:400px 1fr;gap:40px;align-items:start}
.reservation-sidebar{display:flex;flex-direction:column;gap:20px;position:sticky;top:20px}
.establishment-card{background:var(--pure-white);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-medium);border:2px solid var(--warm-beige);position:relative}
.establishment-image{width:100%;height:150px;object-fit:cover}
.establishment-info-card{padding:20px}
.establishment-info-card h3{margin:0 0 5px 0;font-family:var(--font-heading);color:var(--primary-brown);font-size:1.3rem}
.establishment-info-card p{margin:5px 0;color:var(--text-medium);font-size:0.9rem}
.address-small{font-size:0.85rem!important;color:var(--text-light)!important}
.rating-badge-small{position:absolute;top:10px;right:10px;background:var(--accent-burgundy);color:var(--pure-white);padding:5px 10px;border-radius:15px;font-weight:600;font-size:0.9rem}
.rating-text{margin-top:10px;font-size:0.85rem}
.rating-text strong{color:var(--primary-brown)}
.amenities-small{margin-top:15px;display:flex;flex-direction:column;gap:5px}
.amenities-small span{font-size:0.8rem;color:var(--text-medium)}
.booking-details-card,.price-summary-card{background:var(--pure-white);border-radius:12px;padding:20px;box-shadow:var(--shadow-medium);border:2px solid var(--warm-beige)}
.booking-details-card h3,.price-summary-card h3{margin:0 0 15px 0;font-family:var(--font-heading);color:var(--primary-brown);font-size:1.2rem}
.dates-info{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:15px}
.date-section strong{display:block;color:var(--text-dark);font-family:var(--font-heading);margin-bottom:5px}
.date-section div{font-weight:600;color:var(--primary-brown);margin-bottom:3px}
.date-section small{color:var(--text-light);font-size:0.8rem}
.duration-info{padding:10px 0;border-top:1px solid var(--border-light);margin-top:15px}
.duration-info strong{color:var(--text-dark);font-family:var(--font-heading)}
.selection-info{padding:10px 0;border-top:1px solid var(--border-light);margin-top:15px}
.selection-info strong{display:block;color:var(--text-dark);font-family:var(--font-heading);margin-bottom:8px}
.selection-info a{color:var(--accent-burgundy);text-decoration:none;font-size:0.9rem}
.selection-info a:hover{text-decoration:underline}
.total-price{text-align:center;padding:15px 0;border-bottom:1px solid var(--border-light);margin-bottom:15px}
.total-price strong{display:block;font-family:var(--font-heading);color:var(--text-dark);margin-bottom:5px}
.price-amount{font-size:2rem;font-weight:700;color:var(--accent-burgundy);font-family:var(--font-heading);margin:5px 0}
.total-price small{color:var(--text-light);font-size:0.85rem}
.price-breakdown h4{font-family:var(--font-heading);color:var(--primary-brown);margin:0 0 10px 0;font-size:1rem}
.tax-details{margin-left:15px;font-size:0.85rem}
.tax-details div{display:flex;justify-content:space-between;margin:5px 0}
.cancellation-info,.availability-warning{margin-top:15px;padding-top:15px;border-top:1px solid var(--border-light)}
.cancellation-info h4{font-family:var(--font-heading);color:var(--primary-brown);margin:0 0 8px 0;font-size:0.95rem}
.cancellation-info p{margin:0;font-size:0.9rem}
.availability-warning strong{display:block;color:var(--accent-burgundy);font-family:var(--font-heading);margin-bottom:5px;font-size:0.9rem}
.availability-warning p{margin:0;font-size:0.85rem;color:var(--text-medium)}
.reservation-main{background:var(--pure-white);border-radius:12px;padding:30px;box-shadow:var(--shadow-medium);border:2px solid var(--warm-beige)}
.login-suggestion{background:var(--light-beige);padding:20px;border-radius:8px;margin-bottom:30px;border:2px solid var(--accent-burgundy)}
.login-suggestion p{margin:0 0 15px 0;font-size:0.9rem;line-height:1.5}
.login-buttons{display:flex;gap:10px}
.btn-login,.btn-create-account{padding:8px 16px;border-radius:4px;text-decoration:none;font-weight:600;font-size:0.9rem;cursor:pointer;border:none;transition:var(--transition-smooth)}
.btn-login{background:var(--accent-burgundy);color:var(--pure-white)}
.btn-create-account{background:transparent;color:var(--accent-burgundy);border:1px solid var(--accent-burgundy)}
.btn-login:hover{background:var(--primary-brown)}
.btn-create-account:hover{background:var(--accent-burgundy);color:var(--pure-white)}
.guest-details-form h2{font-family:var(--font-heading);color:var(--primary-brown);margin:0 0 10px 0;font-size:1.8rem}
.form-subtitle{color:var(--text-medium);margin-bottom:25px;font-size:0.95rem}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.form-group{margin-bottom:20px}
.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-dark);font-family:var(--font-heading);font-size:0.95rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid var(--border-light);border-radius:6px;font-family:var(--font-body);font-size:0.95rem;transition:border-color 0.3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--accent-burgundy);outline:none}
.form-group small{display:block;margin-top:5px;color:var(--text-light);font-size:0.8rem}
.phone-group{margin-bottom:20px}
.phone-input{display:flex;gap:5px}
.country-code{width:100px;padding:12px;border:1px solid var(--border-light);border-radius:6px;font-size:0.9rem}
.phone-input input{flex:1}
.checkbox-group{display:flex;align-items:flex-start;gap:10px;margin-bottom:20px}
.checkbox-group input[type="checkbox"]{width:18px;height:18px;margin-top:2px}
.checkbox-group label{margin:0;font-weight:normal;line-height:1.4;font-size:0.9rem}
.checkbox-group small{display:block;margin-top:5px;color:var(--text-light);font-size:0.8rem;margin-left:28px}
.room-notice{margin:30px 0;padding:20px;background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px}
.room-notice h3{margin:0 0 10px 0;color:#856404;font-family:var(--font-heading)}
.notice-content p{margin:0;color:#856404;font-size:0.9rem}
.selected-room-card{border:1px solid var(--border-light);border-radius:8px;padding:20px;margin-bottom:20px;background:var(--light-beige)}
.room-card-header h4{margin:0 0 15px 0;font-family:var(--font-heading);color:var(--primary-brown);font-size:1.3rem}
.room-features{display:flex;flex-direction:column;gap:10px}
.feature-tag{background:var(--deep-green);color:var(--pure-white);padding:5px 10px;border-radius:15px;font-size:0.8rem;font-weight:600;width:fit-content}
.room-rating{display:flex;align-items:center;gap:10px}
.room-rating .rating-score{background:var(--accent-burgundy);color:var(--pure-white);padding:3px 8px;border-radius:10px;font-weight:600;font-size:0.85rem}
.room-capacity{font-size:0.9rem}
.room-actions{margin-top:15px;display:flex;justify-content:space-between;align-items:center}
.add-guest-info-btn{background:transparent;color:var(--accent-burgundy);border:1px solid var(--accent-burgundy);padding:8px 15px;border-radius:4px;font-size:0.85rem;cursor:pointer;transition:var(--transition-smooth)}
.add-guest-info-btn:hover{background:var(--accent-burgundy);color:var(--pure-white)}
.room-smoking-status{font-size:0.85rem;color:var(--text-medium);font-weight:500}
.special-requests,.arrival-time,.baby-bed-section,.house-rules{margin:30px 0;padding:25px 0;border-bottom:1px solid var(--border-light)}
.special-requests h3,.arrival-time h3,.baby-bed-section h3,.house-rules h3{margin:0 0 15px 0;font-family:var(--font-heading);color:var(--primary-brown);font-size:1.3rem}
.special-requests p,.arrival-time p,.baby-bed-section p,.house-rules p{margin-bottom:15px;line-height:1.6;font-size:0.95rem}
.special-requests textarea {
  width: 100%;
  min-height: 120px;
  padding: 14px 16px;
  border: 1px solid var(--border-light);
  border-radius: 8px;
  background: var(--pure-white);
  font-family: var(--font-body);
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--text-dark);
  box-shadow: var(--shadow-light);
  transition: border-color 0.3s, box-shadow 0.3s;
}

.special-requests textarea:focus {
  border-color: var(--accent-burgundy);
  box-shadow: 0 0 0 3px rgba(141,64,55,0.2);
  outline: none;
}
.arrival-info{color:var(--deep-green);font-weight:600;margin-bottom:15px}
.bed-info{margin-bottom:20px;padding-left:20px}
.bed-info li{margin-bottom:8px;color:var(--text-medium);font-size:0.9rem}
.bed-options h4{margin:0 0 15px 0;font-family:var(--font-heading);color:var(--primary-brown)}
.free-tag{background:var(--deep-green);color:var(--pure-white);padding:2px 6px;border-radius:8px;font-size:0.7rem;margin-left:5px}
.rules-list{margin:15px 0;padding-left:20px}
.rules-list li{margin-bottom:8px;color:var(--text-medium);font-size:0.9rem}
.rules-agreement{font-weight:600;color:var(--text-dark);font-size:0.9rem;margin-top:15px}

.form-actions{margin-top:40px;text-align:center;padding-top:30px;border-top:2px solid var(--border-light)}
.price-adjustment-notice{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:20px;color:var(--text-medium);font-size:0.9rem}
.adjustment-icon{font-size:1.2rem}
.btn-next-step{background:var(--accent-burgundy);color:var(--pure-white);border:none;padding:15px 40px;border-radius:30px;font-size:1.1rem;font-weight:600;font-family:var(--font-heading);cursor:pointer;transition:var(--transition-smooth);letter-spacing:0.5px;box-shadow:0 4px 15px rgba(141,64,55,0.3)}
.btn-next-step:hover{background:var(--primary-brown);transform:translateY(-2px);box-shadow:var(--shadow-medium)}
.conditions-link{margin-top:15px;color:var(--accent-burgundy);text-decoration:none;font-size:0.9rem;cursor:pointer}
.conditions-link:hover{text-decoration:underline}

.confirmation-banner{background:linear-gradient(135deg,#4caf50,#45a049);color:white;padding:20px 0;margin:90px 0 30px;animation:slideDown 0.5s ease-out;position:relative;z-index:999}
.confirmation-content{display:flex;align-items:center;gap:20px}
.confirmation-icon{width:60px;height:60px;background:rgba(255,255,255,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:bold}
.confirmation-text h2{margin:0 0 5px 0;font-family:var(--font-heading);font-size:1.8rem}
.confirmation-text p{margin:0;font-size:1.1rem;opacity:0.95}

.cancel-banner{background:linear-gradient(135deg,#f44336,#d32f2f);color:white;padding:20px 0;margin:90px 0 30px;animation:slideDown 0.5s ease-out;position:relative;z-index:999}
.cancel-content{display:flex;align-items:center;gap:20px}
.cancel-icon{width:60px;height:60px;background:rgba(255,255,255,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:bold}
.cancel-text h2{margin:0 0 5px 0;font-family:var(--font-heading);font-size:1.8rem}
.cancel-text p{margin:0;font-size:1.1rem;opacity:0.95}

.payment-section{padding:100px 0;background:var(--light-beige);min-height:100vh;display:flex;align-items:center}
.payment-container{max-width:600px;margin:0 auto;background:white;border-radius:15px;padding:40px;box-shadow:var(--shadow-strong);text-align:center}
.payment-header h2{font-family:var(--font-heading);color:var(--primary-brown);font-size:2rem;margin:0 0 10px 0}
.payment-header p{color:var(--text-medium);font-size:1.1rem;margin-bottom:30px}
.payment-loading{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 0}
.spinner{width:60px;height:60px;border:4px solid var(--border-light);border-top:4px solid var(--accent-burgundy);border-radius:50%;animation:spin 1s linear infinite}
.payment-loading p{color:var(--text-medium);font-size:1.1rem}

@keyframes spin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}

.stripe-button{background:linear-gradient(135deg,var(--accent-burgundy),var(--primary-brown));color:white;padding:15px 40px;border:none;border-radius:30px;font-size:1.1rem;font-weight:600;font-family:var(--font-heading);cursor:pointer;transition:var(--transition-smooth);box-shadow:0 4px 15px rgba(141,64,55,0.3);letter-spacing:0.5px}
.stripe-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(141,64,55,0.4)}
.stripe-button:disabled{opacity:0.6;cursor:not-allowed}
.payment-error{background:#ffebee;color:#c62828;padding:15px;border-radius:8px;margin-top:20px;border:1px solid #ef9a9a}
.payment-success{background:#e8f5e8;color:#2e7d32;padding:15px;border-radius:8px;margin-top:20px;border:1px solid #81c784}

.login-body{background:linear-gradient(135deg,var(--light-beige),var(--warm-beige));min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-container{display:grid;grid-template-columns:1fr 1fr;max-width:1100px;width:100%;background:var(--pure-white);border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,0.2);overflow:hidden}
.login-box{padding:60px;display:flex;flex-direction:column;justify-content:center}
.login-logo{text-align:center;margin-bottom:40px}
.login-logo h1{font-family:var(--font-heading);font-size:2.5rem;color:var(--primary-brown);margin:0 0 10px 0;letter-spacing:1px}
.login-logo p{color:var(--text-medium);font-size:1.1rem}

.login-form,.register-form{margin-top:20px}
.form-field{margin-bottom:20px}
.form-field label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-dark);font-family:var(--font-heading);font-size:0.95rem}
.form-field input{width:100%;padding:12px 15px;border:2px solid var(--border-light);border-radius:8px;font-size:1rem;transition:border-color 0.3s}
.form-field input:focus{border-color:var(--accent-burgundy);outline:none}
.form-field small{display:block;margin-top:5px;color:var(--text-light);font-size:0.85rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:15px}

.form-remember{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}
.form-remember label{display:flex;align-items:center;gap:8px;font-size:0.95rem;color:var(--text-medium)}
.forgot-link{color:var(--accent-burgundy);text-decoration:none;font-size:0.9rem}
.forgot-link:hover{text-decoration:underline}

.btn-login-submit,.btn-register-submit{width:100%;background:var(--accent-burgundy);color:var(--pure-white);border:none;padding:14px;border-radius:8px;font-size:1.1rem;font-weight:600;font-family:var(--font-heading);cursor:pointer;transition:var(--transition-smooth);letter-spacing:0.5px}
.btn-login-submit:hover,.btn-register-submit:hover{background:var(--primary-brown);transform:translateY(-2px);box-shadow:0 5px 15px rgba(141,64,55,0.3)}

.login-footer{text-align:center;margin-top:30px;padding-top:30px;border-top:1px solid var(--border-light)}
.login-footer p{margin-bottom:10px;color:var(--text-medium)}
.login-footer a{color:var(--accent-burgundy);text-decoration:none;font-weight:500}
.login-footer a:hover{text-decoration:underline}
.back-link{display:inline-block;margin-top:15px;color:var(--text-medium)!important;font-size:0.95rem}

.login-image{position:relative;background:var(--primary-brown);display:flex;align-items:center;justify-content:center}
.login-image img{position:absolute;width:100%;height:100%;object-fit:cover;opacity:0.7}
.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(62,39,35,0.7),rgba(141,64,55,0.5))}
.image-content{position:relative;z-index:2;text-align:center;padding:40px;color:var(--pure-white)}
.image-content h2{font-family:var(--font-heading);font-size:2.5rem;margin-bottom:15px;letter-spacing:1px}
.image-content p{font-size:1.2rem;line-height:1.6;opacity:0.95}

.alert{padding:15px 20px;border-radius:8px;margin-bottom:20px;font-size:0.95rem}
.alert-error{background:#ffebee;color:#c62828;border:1px solid #ef9a9a}
.alert-success{background:#e8f5e8;color:#2e7d32;border:1px solid #81c784}
.alert p{margin:5px 0}

.register-container{max-width:600px;width:100%;background:var(--pure-white);border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,0.2);overflow:hidden}
.register-box{padding:50px}
.form-terms{margin:20px 0}
.form-terms label{display:flex;align-items:flex-start;gap:8px;font-size:0.9rem;color:var(--text-medium)}
.form-terms a{color:var(--accent-burgundy);text-decoration:none}
.form-terms a:hover{text-decoration:underline}

.admin-container{display:flex;min-height:100vh;background:var(--light-beige)}
.admin-sidebar{width:280px;background:var(--primary-brown);color:var(--pure-white);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;box-shadow:2px 0 10px rgba(0,0,0,0.1)}
.admin-logo{padding:30px 25px;border-bottom:1px solid rgba(255,255,255,0.1);text-align:center}
.admin-logo h2{font-family:var(--font-heading);font-size:1.5rem;margin:0 0 5px 0;letter-spacing:0.5px}
.admin-logo span{font-size:0.85rem;opacity:0.8}

.admin-nav{flex:1;padding:20px 0}
.nav-item{display:flex;align-items:center;gap:12px;padding:15px 25px;color:var(--pure-white);text-decoration:none;transition:var(--transition-smooth);font-size:0.95rem;position:relative}
.nav-item:hover{background:rgba(255,255,255,0.1)}
.nav-item.active{background:var(--accent-burgundy)}
.nav-item.active::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--warm-beige)}
.nav-item .icon{font-size:1.2rem;width:24px;text-align:center}

.admin-user{padding:20px;border-top:1px solid rgba(255,255,255,0.1)}
.user-info{margin-bottom:15px}
.user-info strong{display:block;font-size:0.95rem;margin-bottom:3px}
.user-info span{font-size:0.85rem;opacity:0.8}
.logout-btn{display:block;width:100%;background:rgba(255,255,255,0.1);color:var(--pure-white);border:1px solid rgba(255,255,255,0.2);padding:10px;border-radius:6px;text-align:center;text-decoration:none;font-size:0.9rem;transition:var(--transition-smooth)}
.logout-btn:hover{background:rgba(255,255,255,0.2)}

.admin-main{flex:1;margin-left:280px;padding:30px}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}
.admin-header h1{font-family:var(--font-heading);font-size:2rem;color:var(--primary-brown);margin:0}
.header-actions{display:flex;gap:10px}
.btn-export,.btn-print{background:var(--pure-white);border:1px solid var(--border-light);padding:10px 20px;border-radius:6px;font-size:0.9rem;cursor:pointer;transition:var(--transition-smooth)}
.btn-export:hover,.btn-print:hover{background:var(--accent-burgundy);color:var(--pure-white);border-color:var(--accent-burgundy)}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:30px}
.stat-card{background:var(--pure-white);border-radius:12px;padding:25px;box-shadow:var(--shadow-light);display:flex;align-items:center;gap:20px;transition:var(--transition-smooth)}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-medium)}
.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:bold}
.stat-icon.confirmed{background:#e8f5e8;color:#2e7d32}
.stat-icon.pending{background:#fff3cd;color:#856404}
.stat-icon.revenue{background:#e3f2fd;color:#1976d2}
.stat-icon.upcoming{background:#f3e5f5;color:#7b1fa2}
.stat-content{flex:1}
.stat-value{display:block;font-size:2rem;font-weight:700;color:var(--text-dark);font-family:var(--font-heading)}
.stat-label{display:block;font-size:0.9rem;color:var(--text-medium);margin-top:5px}

.admin-content{background:var(--pure-white);border-radius:12px;padding:25px;box-shadow:var(--shadow-light)}
.content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;padding-bottom:15px;border-bottom:2px solid var(--border-light)}
.content-header h2{font-family:var(--font-heading);font-size:1.5rem;color:var(--primary-brown);margin:0}
.filters{display:flex;gap:10px}
.filters select,.filters input{padding:8px 12px;border:1px solid var(--border-light);border-radius:6px;font-size:0.9rem}
.filters input{width:200px}

.table-container{overflow-x:auto}
.admin-table{width:100%;border-collapse:collapse}
.admin-table thead{background:var(--light-beige)}
.admin-table th{padding:12px;text-align:left;font-weight:600;color:var(--text-dark);font-family:var(--font-heading);font-size:0.9rem;border-bottom:2px solid var(--border-light)}
.admin-table td{padding:12px;border-bottom:1px solid var(--border-light);vertical-align:middle}
.admin-table tbody tr:hover{background:var(--light-beige)}

.client-info{display:flex;flex-direction:column;gap:2px}
.client-info strong{color:var(--text-dark);font-size:0.95rem}
.client-info span{font-size:0.85rem;color:var(--text-medium)}
.price{font-weight:600;color:var(--accent-burgundy);font-family:var(--font-heading)}

.status-badge{display:inline-block;padding:5px 12px;border-radius:15px;font-size:0.85rem;font-weight:600}
.status-confirmée{background:#e8f5e8;color:#2e7d32}
.status-en_attente{background:#fff3cd;color:#856404}
.status-annulée{background:#ffebee;color:#c62828}

.table-actions{display:flex;gap:5px}
.btn-action{width:32px;height:32px;border-radius:6px;border:none;cursor:pointer;font-size:1rem;transition:var(--transition-smooth)}
.btn-confirm{background:#e8f5e8;color:#2e7d32}
.btn-confirm:hover{background:#2e7d32;color:var(--pure-white)}
.btn-cancel{background:#ffebee;color:#c62828}
.btn-cancel:hover{background:#c62828;color:var(--pure-white)}
.btn-view{background:#e3f2fd;color:#1976d2}
.btn-view:hover{background:#1976d2;color:var(--pure-white)}

.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:1000;align-items:center;justify-content:center}
.modal-content{background:var(--pure-white);border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow-y:auto}
.modal-header{padding:20px;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}
.modal-header h3{margin:0;font-family:var(--font-heading);color:var(--primary-brown)}
.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-medium)}
.modal-close:hover{color:var(--text-dark)}
.modal-body{padding:20px}

.email-verification{background:var(--light-beige);border:2px solid var(--accent-burgundy);border-radius:10px;padding:20px;margin-bottom:20px}
.email-verification h3{font-family:var(--font-heading);color:var(--primary-brown);margin:0 0 15px 0}
.email-step{margin-bottom:15px}
.email-step input{width:100%;padding:12px;border:1px solid var(--border-light);border-radius:6px;font-size:1rem;margin-bottom:10px}
.email-step button{background:var(--accent-burgundy);color:white;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-weight:600;transition:var(--transition-smooth)}
.email-step button:hover{background:var(--primary-brown)}
.email-step button:disabled{opacity:0.6;cursor:not-allowed}
.code-step{display:none}
.code-input{text-align:center;font-size:1.2rem;letter-spacing:0.5em;font-weight:600}
.verification-success{background:#e8f5e8;color:#2e7d32;padding:15px;border-radius:6px;display:none}

#rooms-info{display:block;color:var(--text-light);font-size:0.75rem;margin-top:2px}


/* Éléments invisibles par défaut */
.animate-in {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s ease;
}

/* Quand ils deviennent visibles */
.animate-in.visible {
    opacity: 1;
    transform: translateY(0);
}

.room-result {
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.5s ease;
}

.room-result.visible {
    opacity: 1;
    transform: translateY(0);
}

/* Délais pour les éléments multiples */
.room-result.visible:nth-child(2) { transition-delay: 0.1s; }
.room-result.visible:nth-child(3) { transition-delay: 0.2s; }
.room-result.visible:nth-child(4) { transition-delay: 0.3s; }


/* Ajouter cette règle pour rendre les sections invisibles par défaut */
section {
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s ease;
}

/* Et cette règle pour les faire apparaître avec l'animation */
section.animate-in {
    opacity: 1;
    transform: translateY(0);
}

/* Garder le hero toujours visible */
section.hero {
    opacity: 1;
    transform: none;
}

.gallery-image-container {
    flex: 1;
    text-align: center;
    height: 70vh;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 20px; /* Espacement autour */
}

.gallery-image-container img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    transition: transform 0.3s ease;
    border-radius: 10px;
    box-shadow: var(--shadow-medium);
}

.gallery-main {
    flex: 1;
    display: flex;
    align-items: center;
    position: relative;
    padding: 0;
    background: var(--light-beige);
}

.gallery-image-container img {
    max-width: 100%;
    max-height: 100%;
    width: auto;
    height: auto;
    object-fit: contain;
    transition: transform 0.3s ease;
    border-radius: 12px;
    box-shadow: var(--shadow-medium);
}

.gallery-thumbnails {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 12px 30px;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(10px);
    z-index: 15;
    border-top: 1px solid var(--border-light);
}

.thumbnail {
    width: 60px;
    height: 45px;
    object-fit: cover;
    border-radius: 6px;
    cursor: pointer;
    transition: var(--transition-smooth);
    border: 2px solid transparent;
    opacity: 0.7;
    flex-shrink: 0;
}

.thumbnail:hover {
    opacity: 1;
    transform: scale(1.1);
    border-color: var(--accent-burgundy);
}

.thumbnail.active {
    opacity: 1;
    border-color: var(--accent-burgundy);
    box-shadow: 0 0 10px rgba(141,64,55,0.3);
}
.thumbnails-container {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 5px 0;
    justify-content: flex-start;
    flex-wrap: nowrap;
    scrollbar-width: none;
    scroll-behavior: smooth;
}

.thumbnails-container::-webkit-scrollbar {
    display: none;
}
.reservation-details-section {
    padding-top: 120px !important;
}

.confirmation-banner,
.cancel-banner {
    margin-top: 120px;
    margin-bottom: 0;
}

.reservation-hero {
    padding-top: 120px;
}

:root{--primary-brown:#3E2723;--secondary-brown:#5D4037;--accent-burgundy:#8D4037;--warm-beige:#EFEBE9;--dark-wood:#2E1A16;--light-beige:#F5F5F5;--cream-white:#FAFAFA;--deep-green:#2E4D32;--pure-white:#FFFFFF;--text-dark:#212121;--text-medium:#424242;--text-light:#757575;--border-light:#E0E0E0;--shadow-color:#1B1B1B;--font-heading:'Cinzel',serif;--font-body:'Crimson Text',serif;--shadow-light:0 2px 10px rgba(27,27,27,0.1);--shadow-medium:0 4px 20px rgba(27,27,27,0.15);--shadow-strong:0 8px 30px rgba(27,27,27,0.25);--transition-smooth:all 0.3s ease;--price-font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif}

@media (max-width:768px){
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);line-height:1.6;background:var(--cream-white);color:var(--text-dark);font-size:15px;padding-top:64px;padding-bottom:96px}
.container{max-width:100%;padding:0 16px;margin:0}
.logo-image{display:none}
.logo-link,.logo h1,.transparent-header .logo h1{font-size:18px;letter-spacing:.5px}
.transparent-header{position:fixed;top:0;left:0;right:0;background:linear-gradient(180deg,rgba(224,159,119,.92),rgba(224,159,119,.86));backdrop-filter:blur(8px);padding:10px 0;box-shadow:0 2px 12px rgba(0,0,0,.08);z-index:1000}
.header-container{padding:0 12px}
.header-layout{min-height:44px;justify-content:center}
.header-right{display:none}
.btn-reserver{position:fixed;left:16px;right:16px;bottom:16px;top:auto;background:var(--accent-burgundy);border-radius:14px;padding:16px;font-size:16px;z-index:1001;text-align:center}
.username{display:none}

.hero{height:64vh;min-height:420px;align-items:flex-end;padding:0 16px 28px;background-position:center;background-size:cover}
.hero-content{max-width:none;padding:0;transform:none;opacity:1}
.hero-content h1{font-size:36px;line-height:1.1;margin-bottom:6px}
.hero-content h2{font-size:20px;margin-bottom:10px}
.hero-content p{font-size:15px;margin-bottom:16px}
.hero-scroll{display:none}
.btn-hero{padding:12px 18px;font-size:14px;border-radius:12px}

.main-content{margin-top:0}
.presentation-section{padding:28px 0;background:var(--light-beige)}
.presentation-grid{display:block}
.carousel-container{transform:none;margin-bottom:16px}
.carousel-wrapper{border-radius:12px;box-shadow:var(--shadow-medium)}
.carousel-slides{height:240px}
.carousel-btn{width:36px;height:36px;font-size:18px}
.carousel-prev{left:6px}
.carousel-next{right:6px}
.carousel-dots{gap:6px;margin-top:12px}
.dot{width:8px;height:8px}

.presentation-text h2{font-size:24px;margin-bottom:10px}
.intro-text{font-size:15px;margin-bottom:10px}
.presentation-text p{font-size:15px;margin-bottom:10px;text-align:left}
.btn-center-container{margin-top:16px}
.btn-presentation{width:100%;text-align:center;padding:14px 16px;border-radius:12px}

.rating-badge,.host-rating,.rating-location,.rating-badge-small,.gallery-overlay,.calendar-legend,.booking-table,.newsletter,.footer-subtitle,.social-links,.confirmation-content,.cancel-content{display:none}

.hosts-section{padding:28px 0}
.hosts-content{display:block}
.host-image img{width:160px;height:160px;margin:0 auto 12px auto;display:block}
.host-header h2{font-size:22px}
.host-description p{font-size:15px}

.main-gallery{margin-top:16px}
.gallery-preview img{height:220px}
.gallery-overview{display:block}
.gallery-left{height:auto;aspect-ratio:16/10;border-radius:10px}
.gallery-right{display:none}
.gallery-strip{grid-template-columns:repeat(4,1fr);gap:6px}
.gallery-strip img,.gallery-strip .thumb-more{height:72px;border-radius:8px}

.gallery-modal{padding:0;background:rgba(0,0,0,.8)}
.gallery-modal-content{width:100vw;max-width:none;height:100vh;border-radius:0}
.gallery-header{padding:14px 16px}
.gallery-main{padding:0;background:#000}
.gallery-image-container{height:calc(100vh - 160px);padding:0}
.gallery-image-container img{border-radius:0;box-shadow:none}
.gallery-thumbnails{position:static;padding:10px 14px}

.booking-calendar-section{padding:18px 0;background:var(--pure-white)}
.booking-two-col{display:block}
.booking-sidebar{position:static;margin-bottom:12px}
.booking-main{grid-column:auto}
.booking-form{padding:14px;border-radius:10px}
.guest-item{padding:8px 0}
.room-selector label,.guest-label,.date-input label{font-size:13px}
.date-input input,.room-selector select{padding:10px;font-size:14px}
.btn-search{padding:12px;border-radius:12px}

.booking-calendar{padding:14px;border-radius:12px;min-height:auto}
.calendar-header{margin-bottom:10px}
.calendar-header h3{font-size:20px}
.nav-btn{width:36px;height:36px;font-size:16px}
.weekdays{gap:4px;margin-bottom:6px}
.weekday{padding:8px 0;font-size:11px;border-radius:8px}
.calendar-days{grid-template-columns:repeat(7,minmax(0,1fr));gap:4px}
.day{min-height:52px;border-radius:8px;padding:6px 2px}
.day-number{font-size:13px}
.day-price{font-size:11px}
.calendar-days .day.selected,.calendar-days .day.in-range,.calendar-days .day.preview-range,.calendar-days .day.preview-start,.calendar-days .day.preview-end{transform:none}

.all-available-rooms{gap:12px}
.room-result{flex-direction:column;border-radius:12px}
.room-main-image{width:100%;height:180px}
.room-details{flex-direction:column;gap:10px;padding:14px}
.room-info{padding-right:0}
.room-info h3{font-size:18px}
.room-info p{font-size:14px}
.room-price{text-align:left;min-width:0}
.room-price .price{font-size:22px}
.single-reserve-button{padding:16px;margin-top:10px}
.btn-reserve-all{width:100%;border-radius:14px;padding:14px 16px;font-size:15px}

.room-details-modal{padding:0}
.room-details-content{width:100vw;height:100vh;border-radius:0}
.room-details-header{padding:14px 16px}
.room-details-body{display:block;padding:12px}
.room-details-gallery{height:260px;border-radius:10px}
.room-surface{margin:10px 0}
.amenities-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.amenity-item{font-size:14px}

.reservation-hero{padding-top:24px;padding-bottom:10px;min-height:auto;background:var(--light-beige)}
.establishment-header{margin:10px 0}
.establishment-info h1{font-size:24px}
.description-summary,.highlight-features{padding:16px;border-radius:12px;margin:12px 0}
.features-grid{grid-template-columns:1fr;gap:8px}

.reservation-details-section{padding:24px 0 16px}
.reservation-progress{display:none}
.reservation-content-grid{display:block}
.reservation-sidebar{position:static}
.reservation-main{padding:16px;border-radius:12px}
.form-grid{grid-template-columns:1fr;gap:12px}
.form-group input,.form-group select,.form-group textarea{padding:12px;border-radius:10px}
.btn-next-step{width:100%;border-radius:14px;padding:14px 16px}

.payment-section{padding:24px 0;align-items:flex-start}
.payment-container{max-width:none;margin:0 16px;border-radius:14px;padding:24px}

.footer{background:#121212;color:var(--warm-beige);padding:28px 0 120px}
.footer-content{display:block}
.footer-section{padding:0 16px;margin-bottom:18px}
.footer-section h3{font-size:16px;margin-bottom:10px}
.footer-section a{font-size:15px}
.certifications{margin:12px 16px;padding:12px;border-radius:10px}
.footer-bottom{padding:12px 16px;gap:10px;justify-content:center}
.footer-legal{justify-content:center;gap:14px}
.copyright{width:100%;text-align:center;font-size:13px}

.admin-container,.admin-sidebar,.admin-main{display:none}
}

@media (max-width:768px){
  .transparent-header{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    background:linear-gradient(180deg,rgba(224,159,119,.97),rgba(224,159,119,.9));
    -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
    padding:calc(14px + env(safe-area-inset-top)) 16px 18px;
    box-shadow:0 6px 20px rgba(0,0,0,.12)
  }
  .transparent-header::after{
    content:"";position:absolute;left:0;right:0;bottom:-12px;height:12px;
    background:linear-gradient(180deg,rgba(0,0,0,.12),transparent);pointer-events:none
  }
  .header-container{max-width:none;padding:0}
  .header-layout{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:8px;min-height:auto}
  .logo-image{display:none!important}
  .logo-link{display:block;width:100%}
  .logo h1{font-family:var(--font-heading);color:var(--primary-brown);font-weight:700;font-size:28px;line-height:1.08;letter-spacing:.6px;margin:0}
  .logo h1::after{content:"Guest House Saint Yves";display:block;font-size:14px;letter-spacing:.5px;color:rgba(62,39,35,.9);margin-top:2px}
  .header-right{display:none}
  .transparent-header .btn-reserver{
    position:static!important;left:auto;right:auto;top:auto;
    display:block;width:100%;margin-top:6px;
    background:var(--accent-burgundy);color:#fff;
    padding:14px 16px;border-radius:16px;font-size:15px;font-weight:700;
    box-shadow:0 6px 18px rgba(141,64,55,.35);text-align:center
  }
  body{padding-top:152px!important}
  .hero{margin-top:0}
  .reservation-hero,.reservation-details-section{padding-top:152px!important}
  .confirmation-banner,.cancel-banner{margin-top:152px}
}
@media (max-width: 768px) {
  .transparent-header .logo-link .logo h1,
  .transparent-header .logo h1,
  .logo-link h1,
  .logo h1 {
    font-size: 22px !important;
    letter-spacing: 0.3px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  .logo h1::after {
    display: none !important;
  }
}
@media (max-width: 768px) {
  .reservation-hero,
  .reservation-details-section {
    padding-top: 90px !important;
  }
  
  .transparent-header {
    padding: 16px 16px 20px !important;
  }
  
  body {
    padding-top: 110px !important;
  }
}

@media (max-width: 768px) {
  .rules-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  
  .rules-grid > div {
    min-height: 120px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 12px;
  }
  
  .rules-grid h3 {
    font-size: 14px;
    margin-bottom: 6px;
  }
  
  .rules-grid p {
    font-size: 13px;
    line-height: 1.3;
    flex-grow: 1;
  }
}
@media (max-width: 768px) {
  .rules-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  
  .rules-grid > div {
    min-height: 120px;
    padding: 12px;
    text-align: center;
    align-items: center;
    justify-content: center;
    display: flex;
    flex-direction: column;
  }
  
  .rules-grid h3,
  .rules-grid p {
    text-align: center;
    margin: 0;
    width: 100%;
  }
  
  .transparent-header {
    background: rgba(224,159,119,0.7) !important;
    backdrop-filter: blur(10px);
  }
}

@media (max-width: 768px) {
  .rules-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  
  .rules-grid > div {
    min-height: 120px;
    padding: 12px;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
  }
  
  .rules-grid h3 {
    text-align: center !important;
    margin: 0 0 8px 0 !important;
    width: 100% !important;
    font-size: 14px !important;
  }
  
  .rules-grid p {
    text-align: center !important;
    margin: 0 !important;
    width: 100% !important;
    font-size: 13px !important;
    line-height: 1.3 !important;
  }
}
html::-webkit-scrollbar {
  width: 18px; 
}

html::-webkit-scrollbar-track {
  background: var(--light-beige); 
  border-radius: 12px;
}

html::-webkit-scrollbar-thumb {background: linear-gradient(180deg, var(--accent-burgundy), var(--primary-brown));border-radius: 12px;border: 4px solid var(--light-beige);}
html::-webkit-scrollbar-thumb:hover {background: linear-gradient(180deg, var(--primary-brown), var(--accent-burgundy));}
html {scrollbar-width: auto;scrollbar-color: var(--accent-burgundy) var(--light-beige);}

@media (max-width:768px){
  .gallery-image-container{aspect-ratio:auto !important;}
  .gallery-image-container img{object-fit:contain;}
  .gallery-main{background:var(--pure-white);}
}
.transparent-header .logo h1 {
  font-size: clamp(14px, 4vw, 22px);
  white-space: nowrap;
  overflow: visible;
  text-overflow: clip;
}

.logo h1 {
  font-family: 'Cinzel', serif;
  font-display: block;
	
}

.header-layout h1 {
  margin: 0 auto;
  text-align: center;
}

@media (max-width: 768px) {
  .header-layout h1 {
    font-size: clamp(14px, 5vw, 22px) !important;
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: unset !important;
  }
}


@media (max-width:768px){
  .booking-two-col{grid-template-columns:1fr;display:block}
  .booking-sidebar{margin-bottom:12px}
  .booking-main{margin-top:12px}

  .booking-table{display:block!important;background:transparent;border-radius:14px;overflow:visible;box-shadow:none}
  .booking-table thead{display:none}
  .booking-table tbody,.booking-table tr,.booking-table td{display:block;width:100%}
  .booking-table tr{background:#fff;border:1px solid var(--warm-beige);border-radius:14px;margin:12px 0;box-shadow:var(--shadow-light)}
  .booking-table td{border-bottom:0;padding:14px 14px 0}
  .booking-table td:last-child{padding-bottom:14px}

  .room-type-cell{display:grid;grid-template-columns:1fr;grid-template-areas:"img" "desc" "meta";gap:10px;align-items:start}
  .room-type-image{grid-area:img;width:100%;height:auto;aspect-ratio:16/10;border-radius:12px;object-fit:cover}
  .room-full-desc{grid-area:desc;font-size:14px;line-height:1.5;color:var(--text-medium);background:var(--light-beige);border:1px solid var(--border-light);border-radius:10px;padding:10px}
  .room-type-info{grid-area:meta;padding:0}
  .room-type-info h4{font-size:18px;margin:6px 0}
  .room-type-info p{font-size:14px;margin:6px 0}

  .room-price,.room-selector,.room-options{margin-top:10px;text-align:left}
  .room-price{min-width:0}
  .room-price .price{font-size:22px;line-height:1.1}
  .room-quantity-controls .quantity-btn{width:32px;height:32px}
}


.day.busy {
    background: #ffebee;
    color: var(--text-light);
    cursor: not-allowed;
    pointer-events: none;
    opacity: 0.6;
}

.day.busy:hover {
    background: #ffebee;
    transform: none;
    border-color: transparent;
    box-shadow: none;
}

.day.busy .day-price {
    text-decoration: line-through;
    opacity: 0.5;
}

.presentation-text h2{letter-spacing:0;line-height:1.25;}



