*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-gold:#c8973f;--color-gold-light:#e2b96a;--color-gold-dark:#a07830;--color-sand:#f5edd8;--color-sand-light:#faf5ec;--color-terracotta:#c4714a;--color-terracotta-dk:#9e5a3a;--color-deep:#1a1208;--color-dark:#231a0c;--color-dark-mid:#2e2010;--color-dark-card:#322415;--color-text:#1c1309;--color-text-muted:#7a6245;--color-text-light:#bfa87a;--color-white:#fff;--color-off-white:#fdf8f0;--color-border:#c8973f40;--color-border-light:#c8973f1f;--font-serif:"Cormorant", Georgia, serif;--font-sans:"Montserrat", system-ui, sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--space-2xl:64px;--space-3xl:96px;--space-4xl:128px;--radius-sm:4px;--radius-md:8px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--shadow-sm:0 2px 8px #1a120814;--shadow-md:0 4px 24px #1a120824;--shadow-lg:0 12px 48px #1a120838;--shadow-xl:0 24px 80px #1a12084d;--shadow-gold:0 4px 24px #c8973f40;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--transition-slower:.6s cubic-bezier(.16, 1, .3, 1);--z-navbar:100;--z-modal:200;--z-toast:300}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background-color:var(--color-off-white);color:var(--color-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-sand)}::-webkit-scrollbar-thumb{background:var(--color-gold);border-radius:var(--radius-full)}::selection{background:var(--color-gold);color:var(--color-white)}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);letter-spacing:-.01em;color:var(--color-text);line-height:1.15}p{line-height:1.75}a{color:inherit;cursor:pointer;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font-family:var(--font-sans);background:0 0;border:none}input,select,textarea{font-family:var(--font-sans);font-size:14px}.container{max-width:1280px;padding:0 var(--space-xl);margin:0 auto}@media (width<=768px){.container{padding:0 var(--space-md)}}.section{padding:var(--space-4xl) 0}@media (width<=768px){.section{padding:var(--space-2xl) 0}}@media screen and (width<=768px){input,select,textarea,.form-input{font-size:16px!important}}.gold-divider{background:linear-gradient(90deg, transparent, var(--color-gold), transparent);width:60px;height:2px;margin:var(--space-md) auto}.gold-divider.left{margin-left:0}.section-header{margin-bottom:var(--space-2xl)}.section-header.centered{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;display:flex}.section-header.centered .section-eyebrow,.section-header.centered .section-title{text-align:center;width:100%}.section-eyebrow{font-family:var(--font-sans);letter-spacing:.2em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-sm);font-size:11px;font-weight:600;display:block}.section-title{color:var(--color-text);font-size:clamp(36px,5vw,58px);font-weight:500}.section-title.light{color:var(--color-sand)}.section-subtitle{color:var(--color-text-muted);max-width:520px;margin-top:var(--space-md);font-size:16px;font-weight:300}.section-subtitle.light{color:var(--color-text-light)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);letter-spacing:.1em;text-transform:uppercase;transition:all var(--transition-slow);padding:14px 32px;font-size:13px;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";transition:transform var(--transition-slow);background:#ffffff1a;position:absolute;inset:0;transform:translate(-100%)}.btn:hover:before{transform:translate(0)}.btn-primary{background:var(--color-gold);color:var(--color-white);box-shadow:var(--shadow-gold)}.btn-primary:hover{background:var(--color-gold-dark);transform:translateY(-2px);box-shadow:0 8px 32px #c8973f66}.btn-outline{color:var(--color-gold);border:1.5px solid var(--color-gold);background:0 0}.btn-outline:hover{background:var(--color-gold);color:var(--color-white);transform:translateY(-2px)}.btn-ghost-white{color:var(--color-white);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:1.5px solid #ffffff4d}.btn-ghost-white:hover{background:#ffffff38;transform:translateY(-2px)}.card{background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);transition:transform var(--transition-slow), box-shadow var(--transition-slow);overflow:hidden}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-6px)}.moroccan-divider{opacity:.6;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='48' viewBox='0 0 40 48'%3E%3Cpath fill='%23C8973F' fill-opacity='0.18' d='M20 0 L40 24 L20 48 L0 24 Z'/%3E%3C/svg%3E");background-repeat:repeat-x;background-size:40px 48px;height:48px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes spinSlow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in-up{animation:fadeInUp .7s var(--transition-slower) both}.animate-fade-in{animation:.6s both fadeIn}.animate-scale-in{animation:scaleIn .5s var(--transition-slower) both}.glass-card{-webkit-backdrop-filter:blur(20px);border-radius:var(--radius-xl);background:#ffffff14;border:1px solid #c8973f33}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);font-size:11px;font-weight:600}.form-input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-white);color:var(--color-text);font-size:16px;font-family:var(--font-sans);transition:border-color var(--transition-base), box-shadow var(--transition-base);width:100%;padding:12px 16px}.form-input:focus{border-color:var(--color-gold);outline:none;box-shadow:0 0 0 3px #c8973f1f}.form-input::placeholder{color:var(--color-text-light)}.stars{color:var(--color-gold);gap:2px;font-size:14px;display:flex}.badge{border-radius:var(--radius-full);letter-spacing:.08em;text-transform:uppercase;align-items:center;gap:4px;padding:4px 12px;font-size:11px;font-weight:600;display:inline-flex}.badge-gold{color:var(--color-gold-dark);background:#c8973f1f;border:1px solid #c8973f4d}.badge-success{color:#16a34a;background:#22c55e1a}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.navbar{z-index:var(--z-navbar);background:var(--color-off-white);border-bottom:1px solid var(--color-border-light);position:fixed;top:0;left:0;right:0}.navbar-scrolled{background:var(--color-off-white);box-shadow:var(--shadow-md);border-bottom-color:var(--color-border)}.navbar-transparent{background:0 0;border-bottom-color:#0000}.navbar.menu-open,.navbar.menu-open.navbar-transparent,.navbar.menu-open.navbar-scrolled{background:var(--color-off-white);border-bottom-color:var(--color-border-light)}.navbar-inner{justify-content:space-between;align-items:center;gap:var(--space-xl);height:72px;display:flex}.navbar-logo{cursor:pointer;transition:opacity var(--transition-base);flex-direction:column;line-height:1.1;display:flex}.navbar-logo:hover{opacity:.8}.logo-text{font-family:var(--font-serif);color:var(--color-gold);letter-spacing:.02em;transition:color var(--transition-slow);font-size:24px;font-weight:600}.navbar-transparent .logo-text{color:var(--color-white)}.navbar.menu-open .logo-text{color:var(--color-gold)}.logo-sub{font-family:var(--font-sans);letter-spacing:.25em;text-transform:uppercase;color:var(--color-text-muted);transition:color var(--transition-slow);margin-top:1px;font-size:9px;font-weight:600}.navbar-transparent .logo-sub{color:#fff9}.navbar.menu-open .logo-sub{color:var(--color-text-muted)}.navbar-links{align-items:center;gap:var(--space-xl);margin:0;padding:0;list-style:none;display:flex}.nav-link{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);transition:color var(--transition-base);padding:4px 0;font-size:12px;font-weight:500;position:relative}.navbar-transparent .nav-link{color:#ffffffbf}.nav-link:after{content:"";background:var(--color-gold);width:0;height:1.5px;transition:width var(--transition-slow);position:absolute;bottom:-2px;left:0}.nav-link:hover,.nav-link.active{color:var(--color-gold)}.navbar-transparent .nav-link:hover,.navbar-transparent .nav-link.active{color:var(--color-white)}.nav-link:hover:after,.nav-link.active:after{width:100%}.navbar-book-btn{white-space:nowrap;padding:10px 22px;font-size:11px}.navbar-hamburger{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;appearance:none;touch-action:manipulation;background:0 0;justify-content:center;align-items:center;display:none;outline:none!important}@media (hover:hover) and (pointer:fine){.navbar-hamburger:hover{background:var(--color-sand);border-color:var(--color-gold)}}.navbar-hamburger:focus,.navbar-hamburger:active,.navbar-hamburger:focus-visible,.navbar-hamburger:focus-within{border-color:var(--color-border);box-shadow:none;background:0 0;outline:none!important}.navbar-transparent .navbar-hamburger{color:var(--color-white);border-color:#ffffff4d}.navbar.menu-open .navbar-hamburger{color:var(--color-text);border-color:var(--color-border)}.navbar-transparent .navbar-hamburger:focus,.navbar-transparent .navbar-hamburger:active,.navbar-transparent .navbar-hamburger:focus-visible{background:0 0;border-color:#ffffff4d}.mobile-menu{background:var(--color-off-white);padding:var(--space-xl) var(--space-lg);visibility:hidden;pointer-events:none;flex-direction:column;justify-content:space-between;transition:transform .3s ease-out,visibility .3s;display:flex;position:fixed;inset:72px 0 0;transform:translate(100%)}.mobile-menu.open{visibility:visible;pointer-events:all;transform:translate(0)}.mobile-menu ul{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.mobile-menu li{opacity:0;animation:none;transform:translate(20px)}.mobile-menu.open li{animation:slideIn .4s var(--transition-slower) both}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.mobile-nav-link{font-family:var(--font-serif);color:var(--color-text);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-light);transition:color var(--transition-base), padding-left var(--transition-base);font-size:32px;font-weight:500;display:block}.mobile-nav-link:hover{color:var(--color-gold);padding-left:var(--space-md)}.mobile-book-btn{margin-top:var(--space-lg);justify-content:center;width:100%;padding:16px 32px;font-size:13px}.mobile-menu-footer{color:var(--color-text-muted);border-top:1px solid var(--color-border-light);padding-top:var(--space-lg);flex-direction:column;gap:4px;font-size:13px;display:flex}@media (width<=900px){.navbar-links,.navbar-cta{display:none}.navbar-hamburger{display:flex}}.footer{background:var(--color-deep);color:var(--color-text-light);position:relative;overflow:hidden}.footer:before{content:"";background:linear-gradient(90deg, transparent, var(--color-gold), transparent);height:1px;position:absolute;top:0;left:0;right:0}.footer-pattern{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='40' viewBox='0 0 30 40'%3E%3Cpath fill='%23C8973F' fill-opacity='0.15' d='M15 0 L30 20 L15 40 L0 20 Z'/%3E%3C/svg%3E");background-repeat:repeat-x;background-size:30px 40px;border-bottom:1px solid #c8973f1a;height:40px}.footer-inner{padding-top:var(--space-3xl);padding-bottom:var(--space-2xl)}.footer-grid{gap:var(--space-3xl);margin-bottom:var(--space-3xl);grid-template-columns:1.5fr 1fr 1.2fr;display:grid}.footer-logo{margin-bottom:var(--space-lg);flex-direction:column;display:flex}.footer-logo-text{font-family:var(--font-serif);color:var(--color-gold);letter-spacing:.02em;font-size:28px;font-weight:600}.footer-logo-sub{letter-spacing:.2em;text-transform:uppercase;color:var(--color-text-light);margin-top:2px;font-size:10px;font-weight:500}.footer-tagline{color:var(--color-text-light);margin-bottom:var(--space-lg);max-width:300px;font-size:14px;line-height:1.8}.footer-socials{gap:var(--space-sm);display:flex}.social-link{border-radius:var(--radius-md);width:38px;height:38px;color:var(--color-text-light);transition:all var(--transition-base);border:1px solid #c8973f40;justify-content:center;align-items:center;display:flex}.social-link:hover{background:var(--color-gold);border-color:var(--color-gold);color:var(--color-white);transform:translateY(-2px)}.footer-col-title{font-family:var(--font-sans);letter-spacing:.18em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-md);font-size:11px;font-weight:600}.footer-links{flex-direction:column;gap:10px;list-style:none;display:flex}.footer-links a{color:var(--color-text-light);transition:color var(--transition-base), padding-left var(--transition-base);font-size:14px;display:inline-block}.footer-links a:hover{color:var(--color-gold-light);padding-left:6px}.footer-contact{gap:var(--space-md);flex-direction:column;list-style:none;display:flex}.footer-contact li{align-items:flex-start;gap:var(--space-sm);font-size:14px;line-height:1.6;display:flex}.footer-contact svg{color:var(--color-gold);flex-shrink:0;margin-top:2px}.footer-map-link{margin-top:var(--space-md);letter-spacing:.08em;text-transform:uppercase;color:var(--color-gold);transition:opacity var(--transition-base);align-items:center;gap:6px;font-size:12px;font-weight:600;display:inline-flex}.footer-map-link:hover{opacity:.75}.footer-bottom{padding-top:var(--space-xl);color:#bfa87a80;border-top:1px solid #c8973f1a;justify-content:space-between;align-items:center;font-size:13px;display:flex}.footer-bottom-links{gap:var(--space-xl);display:flex}.footer-bottom-links a{color:#bfa87a80;transition:color var(--transition-base)}.footer-bottom-links a:hover{color:var(--color-gold-light)}@media (width<=1024px){.footer-grid{gap:var(--space-2xl);grid-template-columns:1fr 1fr}}@media (width<=640px){.footer-grid{gap:var(--space-xl);grid-template-columns:1fr}.footer-bottom{gap:var(--space-md);text-align:center;flex-direction:column}}.hero{align-items:center;height:100vh;min-height:680px;display:flex;position:relative;overflow:hidden}.hero-slides-container{z-index:1;position:absolute;inset:0}.hero-slide{opacity:0;transition:opacity 1.8s cubic-bezier(.4,0,.2,1);position:absolute;inset:0;overflow:hidden}.hero-slide.active{opacity:1;z-index:2}.hero-bg{object-fit:cover;width:100%;height:100%;transition:transform 10s ease-out;transform:scale(1.1)}.hero-slide.active .hero-bg{transform:scale(1)}.hero-overlay{z-index:1;background:radial-gradient(circle at 40%,#0000 20%,#0a060266 60%,#0a0602d9 100%),linear-gradient(90deg,#0a060299 0%,#0000 100%);position:absolute;inset:0}.hero-content{z-index:3;padding-top:72px;position:relative}.hero-text-stack{grid-template-columns:1fr;align-items:center;display:grid}.hero-text-item{opacity:0;visibility:hidden;filter:blur(10px);pointer-events:none;text-align:center;flex-direction:column;grid-area:1/1;align-items:center;max-width:820px;margin:0 auto;transition:opacity 1s,transform 1s cubic-bezier(.16,1,.3,1),visibility 1s,filter 1s;display:flex;transform:translateY(30px)}.hero-text-item.active{opacity:1;visibility:visible;filter:blur();pointer-events:auto;transition-delay:.6s;transform:translateY(0)}.hero-title{color:var(--color-white);margin:var(--space-sm) 0 var(--space-lg);letter-spacing:-.01em;flex-direction:column;align-items:center;font-size:clamp(42px,6vw,82px);font-weight:500;line-height:.95;display:flex}.hero-line{display:block}.hero-line-italic{font-style:italic;font-family:var(--font-serif);color:var(--color-gold-light);opacity:.9;margin-top:-.05em}.hero-sub{color:#ffffffd1;max-width:820px;margin-bottom:var(--space-xl);letter-spacing:.02em;font-size:clamp(15px,1vw,17px);font-weight:300;line-height:1.5}.hero-actions{gap:var(--space-md);flex-wrap:wrap;justify-content:center;display:flex}.hero-dots{bottom:var(--space-2xl);gap:var(--space-sm);z-index:10;display:flex;position:absolute;left:50%;transform:translate(-50%)}.hero-dot{border-radius:var(--radius-full);cursor:pointer;background:#fff3;border:none;width:32px;height:3px;padding:0;transition:all .6s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden}.hero-dot:after{content:"";background:var(--color-gold);transition:transform 8s linear;position:absolute;inset:0;transform:translate(-100%)}.hero-dot.active{background:#ffffff4d;width:64px}.hero-dot.active:after{transform:translate(0)}.hero-scroll-cue{bottom:var(--space-xl);right:var(--space-xl);border-radius:var(--radius-full);color:#fff9;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid #fff3;justify-content:center;align-items:center;width:48px;height:48px;transition:all .4s;animation:3s ease-in-out infinite float;display:flex;position:absolute}.hero-scroll-cue:hover{border-color:var(--color-gold);color:var(--color-gold);transform:translateY(0)}.booking-bar{z-index:5;padding:var(--space-xl) 0;background:var(--color-dark);position:relative}.booking-bar-inner{background:var(--color-dark-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-lg);border:1px solid #c8973f4d;align-items:center;display:flex;overflow:hidden;box-shadow:0 24px 64px #0006}.booking-bar-item{padding:var(--space-lg) var(--space-xl);text-align:center;flex-direction:column;flex:1;align-items:center;gap:6px;transition:background .3s;display:flex}.booking-bar-item:hover{background:#ffffff08}.booking-bar-item .form-label{color:var(--color-gold);text-align:center;font-size:10px}.booking-bar-input{color:var(--color-sand);cursor:pointer;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;text-align:center;text-align-last:center;background:0 0;border:none;border-radius:0;width:100%;padding:4px 0;font-size:16px;font-weight:500}.booking-bar-input:focus{outline:none}.booking-bar-input option{background:var(--color-dark-card);color:var(--color-sand);text-align:center;padding:12px}select.booking-bar-input{text-align:center;text-align-last:center;appearance:none;padding-right:0}.booking-bar-input[type=date]{padding-left:24px}.booking-bar-input::-webkit-calendar-picker-indicator{filter:invert(.8)sepia(.5)saturate(10)hue-rotate(330deg);cursor:pointer}.date-input-wrapper{width:100%;position:relative}.date-placeholder{display:none}.booking-bar-divider{background:#c8973f26;flex-shrink:0;width:1px;height:60px}.booking-bar-btn{margin:var(--space-md);white-space:nowrap;letter-spacing:.12em;flex-shrink:0;padding:18px 36px;font-size:13px}.about-grid{gap:var(--space-4xl);grid-template-columns:1fr 1fr;align-items:center;display:grid}.about-images{position:relative}.about-img-main{border-radius:var(--radius-xl);aspect-ratio:4/5;box-shadow:var(--shadow-xl);overflow:hidden}.about-img-main img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slower)}.about-img-main:hover img{transform:scale(1.04)}.about-img-secondary{border-radius:var(--radius-lg);width:240px;box-shadow:var(--shadow-xl);border:4px solid var(--color-off-white);aspect-ratio:1;position:absolute;bottom:-40px;right:-40px;overflow:hidden}.about-img-secondary img{object-fit:cover;width:100%;height:100%}.about-stats-badge{background:var(--color-gold);color:var(--color-white);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg);text-align:center;box-shadow:var(--shadow-gold);position:absolute;top:40px;right:-20px}.stat-number{font-family:var(--font-serif);font-size:36px;font-weight:600;line-height:1;display:block}.stat-label{letter-spacing:.08em;text-transform:uppercase;opacity:.85;margin-top:4px;font-size:11px;font-weight:600;display:block}.about-content{padding-bottom:var(--space-xl);text-align:center}.about-content .section-eyebrow{text-align:center;display:block}.about-content .section-title{text-align:center}.about-content .gold-divider,.about-content .gold-divider.left{margin-left:auto;margin-right:auto}.about-content .about-text,.about-content .about-certifications{text-align:left}.about-content .btn{margin-left:auto;margin-right:auto}.about-text{color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:16px;line-height:1.85}.about-certifications{gap:var(--space-sm);margin:var(--space-xl) 0;padding:var(--space-lg);background:var(--color-sand);border-radius:var(--radius-lg);border-left:3px solid var(--color-gold);flex-direction:column;display:flex}.cert-item{align-items:center;gap:var(--space-sm);color:var(--color-text-muted);font-size:14px;font-weight:500;display:flex}.cert-item svg{color:var(--color-gold);flex-shrink:0}.features-section{background:var(--color-dark);padding:var(--space-4xl) 0;border-top:1px solid #c8973f1f;border-bottom:1px solid #c8973f1f;position:relative}.features-grid{gap:var(--space-2xl);grid-template-columns:repeat(4,1fr);display:grid}.feature-card{text-align:center;padding:var(--space-xl) var(--space-md);border-radius:var(--radius-xl);background:#ffffff05;border:1px solid #c8973f14;transition:all .5s cubic-bezier(.16,1,.3,1)}.feature-card:hover{background:#c8973f0d;border-color:#c8973f59;transform:translateY(-8px);box-shadow:0 12px 32px #0003}.feature-icon-wrap{width:64px;height:64px;color:var(--color-gold);margin:0 auto var(--space-lg);background:#c8973f1a;border:1px solid #c8973f33;border-radius:20px;justify-content:center;align-items:center;transition:all .5s cubic-bezier(.16,1,.3,1);display:flex}.feature-card:hover .feature-icon-wrap{background:var(--color-gold);color:var(--color-white);transform:rotate(10deg)}.feature-title{font-family:var(--font-sans);text-transform:uppercase;letter-spacing:.1em;color:var(--color-sand);margin-bottom:var(--space-sm);font-size:14px;font-weight:600}.feature-desc{color:var(--color-text-light);opacity:.8;font-size:13px;line-height:1.6}.rooms-section{background:var(--color-off-white);position:relative}.rooms-section .section-header{text-align:center;flex-direction:column;align-items:center;display:flex}.rooms-section .section-eyebrow,.rooms-section .section-title{text-align:center;width:100%}.rooms-grid{gap:var(--space-2xl);grid-template-columns:repeat(3,1fr);display:grid}.room-card{background:var(--color-white);box-shadow:var(--shadow-md);flex-direction:column;display:flex}.room-card-img{aspect-ratio:4/5;position:relative;overflow:hidden}.room-card-img img{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.16,1,.3,1)}.room-card:hover .room-card-img img{transform:scale(1.07)}.room-card-badge{top:var(--space-md);right:var(--space-md);text-transform:capitalize;position:absolute}.room-card-body{padding:var(--space-xl);gap:var(--space-sm);flex-direction:column;flex:1;display:flex}.room-card-name{color:var(--color-text);font-size:22px;font-weight:500}.room-card-desc{color:var(--color-text-muted);flex:1;font-size:14px;line-height:1.7}.room-card-meta{gap:var(--space-xl);padding:var(--space-md) 0;border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light);margin:var(--space-md) 0;display:flex}.room-meta-item{flex-direction:column;gap:2px;display:flex}.room-meta-label{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);font-size:10px;font-weight:600}.room-meta-price{font-family:var(--font-serif);color:var(--color-gold-dark);font-size:22px;font-weight:600}.room-meta-price span{font-size:13px;font-family:var(--font-sans);color:var(--color-text-muted);margin-left:2px;font-weight:400}.room-meta-val{color:var(--color-text);font-size:15px;font-weight:500}.room-card-footer{margin-top:auto}.room-view-link{letter-spacing:.1em;text-transform:uppercase;color:var(--color-gold);transition:gap var(--transition-base);align-items:center;gap:6px;font-size:12px;font-weight:600;display:inline-flex}.room-card:hover .room-view-link{gap:10px}.section-cta{text-align:center;margin-top:var(--space-3xl)}.moroccan-banner{background:var(--color-dark);padding:var(--space-3xl) 0;position:relative;overflow:hidden}.moroccan-banner:before,.moroccan-banner:after{content:"";background:linear-gradient(to bottom, transparent, var(--color-gold), transparent);width:3px;position:absolute;top:0;bottom:0}.moroccan-banner:before{left:60px}.moroccan-banner:after{right:60px}.moroccan-quote{font-family:var(--font-serif);color:var(--color-sand);text-align:center;max-width:960px;margin:0 auto;font-size:clamp(22px,3.5vw,36px);font-style:italic;font-weight:400;line-height:1.6}.moroccan-quote span{color:var(--color-gold);vertical-align:middle;margin:0 4px;font-size:1.4em;line-height:.5}.reviews-section{background:var(--color-dark)}.reviews-grid{gap:var(--space-xl);margin-top:var(--space-3xl);grid-template-columns:repeat(3,1fr);display:grid}.review-card{padding:var(--space-xl);gap:var(--space-md);transition:transform var(--transition-slow), box-shadow var(--transition-slow);flex-direction:column;display:flex}.review-card:hover{box-shadow:var(--shadow-gold);transform:translateY(-4px)}.review-text{font-family:var(--font-serif);color:var(--color-text-light);flex:1;font-size:17px;font-style:italic;line-height:1.75}.review-author{align-items:center;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid #c8973f1a;display:flex}.review-avatar{border-radius:var(--radius-full);background:var(--color-gold);width:44px;height:44px;color:var(--color-white);flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.review-name{color:var(--color-sand);font-size:15px;font-weight:600}.review-country{color:var(--color-text-light);margin-top:2px;font-size:12px}.cta-banner{padding:var(--space-4xl) 0;position:relative;overflow:hidden}.cta-banner-bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.cta-banner-overlay{background:linear-gradient(135deg,#0a0602e0 0%,#1a1208b3 100%);position:absolute;inset:0}.cta-banner-content{z-index:1;text-align:center;align-items:center;gap:var(--space-lg);flex-direction:column;display:flex;position:relative}.cta-banner-actions{gap:var(--space-md);margin-top:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}@media (width<=1024px){.about-grid{gap:var(--space-3xl);grid-template-columns:1fr}.about-img-secondary{width:180px;bottom:-30px;right:0}.about-stats-badge{right:0}.features-grid,.rooms-grid,.reviews-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.hero-title{font-size:clamp(40px,10vw,64px)}.booking-bar-inner{border-radius:var(--radius-lg);flex-direction:column}.booking-bar-divider{display:none}.booking-bar-item{border-bottom:1px solid #c8973f1f;width:100%}.date-input-wrapper{justify-content:center;align-items:center;display:flex;position:relative}.date-placeholder{color:var(--color-sand);pointer-events:none;text-align:center;font-size:16px;font-weight:500;display:block}.date-input-wrapper .booking-bar-input{opacity:0;width:100%;height:100%;position:absolute}.date-input-wrapper .booking-bar-input:valid+.date-placeholder,.date-input-wrapper .booking-bar-input:focus+.date-placeholder,:is(.date-input-wrapper:has(.booking-bar-input:valid) .date-placeholder,.date-input-wrapper:has(.booking-bar-input:focus) .date-placeholder){display:none}:is(.date-input-wrapper:has(.booking-bar-input:valid) .booking-bar-input,.date-input-wrapper:has(.booking-bar-input:focus) .booking-bar-input){opacity:1;padding-left:0;position:relative}.booking-bar-input{text-align:center;min-height:24px;font-size:16px}.booking-bar-input[type=date]{padding-left:0}.booking-bar-btn{width:calc(100% - var(--space-lg));margin:var(--space-sm) var(--space-md)}.features-grid,.rooms-grid{grid-template-columns:1fr}.room-card-body{text-align:center;align-items:center}.room-card-meta{justify-content:center}.room-card-footer{justify-content:center;display:flex}.reviews-grid{grid-template-columns:1fr}.moroccan-banner:before,.moroccan-banner:after{display:none}}.page-hero{height:55vh;min-height:400px;padding-bottom:var(--space-3xl);align-items:flex-end;display:flex;position:relative;overflow:hidden}.page-hero-bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.page-hero-overlay{background:linear-gradient(#0a06024d 0%,#0a0602d9 100%);position:absolute;inset:0}.page-hero-content{z-index:1;text-align:center;flex-direction:column;align-items:center;width:100%;display:flex;position:relative}.page-hero-title{color:var(--color-white);margin:var(--space-xs) 0 var(--space-sm);text-align:center;font-size:clamp(40px,6vw,72px);font-weight:500}.page-hero-sub{color:#ffffffb8;text-align:center;max-width:500px;font-size:18px;font-weight:300}.rooms-filters-bar{background:var(--color-white);border-bottom:1px solid var(--color-border-light);z-index:50;padding:var(--space-md) 0;position:sticky;top:72px}.filters-inner{align-items:center;gap:var(--space-lg);flex-wrap:wrap;display:flex}.filters-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);flex-shrink:0;font-size:12px;font-weight:600}.filter-tabs{gap:var(--space-xs);flex-wrap:wrap;display:flex}.filter-tab{border-radius:var(--radius-full);color:var(--color-text-muted);border:1.5px solid var(--color-border);cursor:pointer;transition:all var(--transition-base);letter-spacing:.05em;background:0 0;padding:8px 18px;font-size:13px;font-weight:500}.filter-tab:hover{border-color:var(--color-gold);color:var(--color-gold)}.filter-tab.active{background:var(--color-gold);border-color:var(--color-gold);color:var(--color-white);box-shadow:var(--shadow-gold)}.filters-count{color:var(--color-text-muted);margin-left:auto;font-size:13px}.rooms-list-section{background:var(--color-off-white)}.rooms-list{gap:var(--space-3xl);flex-direction:column;display:flex}.room-list-card{gap:var(--space-3xl);background:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);transition:box-shadow var(--transition-slow);grid-template-columns:1fr 1fr;align-items:center;display:grid;overflow:hidden}.room-list-card:hover{box-shadow:var(--shadow-lg)}.room-list-card.reverse{direction:rtl}.room-list-card.reverse>*{direction:ltr}.room-list-card.unavailable{opacity:.75}.rlc-images{padding:var(--space-md);flex-direction:column;gap:8px;display:flex}.rlc-main-img{border-radius:var(--radius-lg);aspect-ratio:4/3;position:relative;overflow:hidden}.rlc-main-img img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slower)}.room-list-card:hover .rlc-main-img img{transform:scale(1.04)}.rlc-unavailable-overlay{color:var(--color-white);letter-spacing:.1em;text-transform:uppercase;background:#0a060299;justify-content:center;align-items:center;font-size:18px;font-weight:600;display:flex;position:absolute;inset:0}.rlc-category-badge{top:var(--space-md);left:var(--space-md);text-transform:capitalize;position:absolute}.rlc-thumbs{gap:8px;display:flex}.rlc-thumb{border-radius:var(--radius-md);aspect-ratio:4/3;transition:border-color var(--transition-base);cursor:pointer;background:0 0;border:2px solid #0000;flex:1;padding:0;overflow:hidden}.rlc-thumb.active{border-color:var(--color-gold)}.rlc-thumb img{object-fit:cover;width:100%;height:100%}.rlc-content{padding:var(--space-2xl);gap:var(--space-xl);flex-direction:column;justify-content:space-between;height:100%;display:flex}.rlc-name{color:var(--color-text);margin-bottom:var(--space-sm);font-size:32px;font-weight:500}.rlc-meta{gap:var(--space-lg);margin-bottom:var(--space-md);display:flex}.rlc-meta-item{color:var(--color-text-muted);align-items:center;gap:6px;font-size:14px;display:flex}.rlc-meta-item svg{color:var(--color-gold)}.rlc-desc{color:var(--color-text-muted);font-size:15px;line-height:1.8}.rlc-amenities-title{letter-spacing:.15em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-sm);font-size:11px;font-weight:600}.rlc-amenities-list{gap:var(--space-xs) var(--space-md);flex-wrap:wrap;list-style:none;display:flex}.rlc-amenity{color:var(--color-text-muted);align-items:center;gap:5px;font-size:13px;display:flex}.rlc-amenity svg{color:var(--color-gold);flex-shrink:0}.rlc-footer{padding-top:var(--space-lg);border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;gap:var(--space-md);flex-wrap:wrap;display:flex}.rlc-price{align-items:baseline;gap:4px;display:flex}.rlc-from{color:var(--color-text-muted);font-size:12px}.rlc-amount{font-family:var(--font-serif);color:var(--color-gold-dark);font-size:36px;font-weight:600}.rlc-per{color:var(--color-text-muted);font-size:14px}.rlc-actions{gap:var(--space-sm);flex-wrap:wrap;display:flex}.rlc-fully-booked{color:#dc2626;border-radius:var(--radius-full);background:#dc262614;align-items:center;gap:6px;padding:10px 16px;font-size:13px;font-weight:600;display:flex}@media (width<=900px){.room-list-card{grid-template-columns:1fr}.room-list-card.reverse{direction:ltr}.rlc-content{padding:var(--space-xl)}}@media (width<=768px){.filters-inner{align-items:flex-start;gap:var(--space-sm);flex-direction:column}.filter-tabs{gap:var(--space-xs);width:100%;padding-bottom:var(--space-xs);-webkit-overflow-scrolling:touch;flex-wrap:nowrap;display:flex;overflow-x:auto}.filter-tab{white-space:nowrap;flex-shrink:0;padding:6px 12px;font-size:11px}.filters-count{margin-left:0}.rlc-footer{text-align:center;flex-direction:column;align-items:center}.rlc-price{justify-content:center}.rlc-actions{justify-content:center;width:100%}.rlc-actions .btn{text-align:center;flex:1;justify-content:center}}.room-detail-page{background:var(--color-off-white);padding-top:72px}.room-detail-page.not-found{text-align:center;justify-content:center;align-items:center;min-height:100vh;display:flex}.room-detail-page.not-found h1{margin-bottom:var(--space-md);font-size:48px}.room-detail-page.not-found p{color:var(--color-text-muted);margin-bottom:var(--space-xl)}.rd-hero{background:var(--color-deep);padding:var(--space-lg)}.rd-gallery{max-width:1000px;margin:0 auto}.rd-main-image{border-radius:var(--radius-lg);aspect-ratio:16/9;margin-bottom:var(--space-md);position:relative;overflow:hidden}.rd-main-image img{object-fit:cover;width:100%;height:100%}.rd-nav-btn{cursor:pointer;width:48px;height:48px;transition:all var(--transition-base);color:var(--color-text);background:#ffffffe6;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.rd-nav-btn:hover{background:var(--color-white);transform:translateY(-50%)scale(1.05)}.rd-nav-btn.prev{left:var(--space-md)}.rd-nav-btn.next{right:var(--space-md)}.rd-image-counter{bottom:var(--space-md);right:var(--space-md);color:var(--color-white);border-radius:var(--radius-full);background:#0009;padding:6px 12px;font-size:13px;font-weight:500;position:absolute}.rd-thumbs{gap:var(--space-sm);justify-content:center;display:flex}.rd-thumb{border-radius:var(--radius-md);cursor:pointer;width:80px;height:60px;transition:border-color var(--transition-base), opacity var(--transition-base);opacity:.6;background:0 0;border:2px solid #0000;padding:0;overflow:hidden}.rd-thumb:hover{opacity:.9}.rd-thumb.active{border-color:var(--color-gold);opacity:1}.rd-thumb img{object-fit:cover;width:100%;height:100%}.rd-content{padding-top:var(--space-3xl);padding-bottom:var(--space-3xl)}.rd-grid{gap:var(--space-3xl);grid-template-columns:1fr 380px;align-items:start;display:grid}.rd-details{gap:var(--space-lg);flex-direction:column;display:flex}.rd-back-link{color:var(--color-text-muted);transition:color var(--transition-base);margin-bottom:var(--space-sm);align-items:center;gap:6px;font-size:13px;display:inline-flex}.rd-back-link:hover{color:var(--color-gold)}.rd-title{color:var(--color-text);margin-top:var(--space-xs);font-size:clamp(32px,5vw,48px);font-weight:500}.rd-meta{gap:var(--space-xl);padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light);display:flex}.rd-meta-item{color:var(--color-text-muted);align-items:center;gap:8px;font-size:16px;display:flex}.rd-meta-item svg{color:var(--color-gold)}.rd-description{color:var(--color-text-muted);font-size:17px;line-height:1.9}.rd-section-title{letter-spacing:.15em;text-transform:uppercase;color:var(--color-gold);margin-bottom:var(--space-md);font-size:13px;font-weight:600}.rd-amenities{padding:var(--space-xl) 0;border-top:1px solid var(--color-border-light)}.rd-amenities-list{gap:var(--space-sm) var(--space-xl);grid-template-columns:repeat(2,1fr);list-style:none;display:grid}.rd-amenities-list li{color:var(--color-text);align-items:center;gap:10px;font-size:15px;display:flex}.rd-amenities-list svg{color:var(--color-gold);flex-shrink:0}.rd-policies{padding:var(--space-xl) 0;border-top:1px solid var(--color-border-light)}.rd-policies-list{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.rd-policies-list li{color:var(--color-text-muted);font-size:15px}.rd-policies-list strong{color:var(--color-text)}.rd-booking-card{position:sticky;top:100px}.rd-booking-inner{background:var(--color-white);border-radius:var(--radius-xl);padding:var(--space-xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-lg)}.rd-price{margin-bottom:var(--space-md);align-items:baseline;gap:6px;display:flex}.rd-price-from{color:var(--color-text-muted);font-size:14px}.rd-price-amount{font-family:var(--font-serif);color:var(--color-gold-dark);font-size:42px;font-weight:600}.rd-price-per{color:var(--color-text-muted);font-size:16px}.rd-booking-note{color:var(--color-text-muted);margin-bottom:var(--space-lg);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light);font-size:14px;line-height:1.6}.rd-book-btn{justify-content:center;width:100%;padding:16px 24px;font-size:15px}.rd-unavailable{text-align:center;padding:var(--space-lg) 0}.rd-unavailable p{color:var(--color-text-muted);margin-bottom:var(--space-md)}.rd-contact{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid var(--color-border-light);text-align:center}.rd-contact p{color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:13px}.rd-contact a{color:var(--color-gold);margin-top:4px;font-size:14px;display:block}.rd-contact a:hover{text-decoration:underline}.rd-other-rooms{background:var(--color-white);padding:var(--space-3xl) 0}.rd-other-grid{gap:var(--space-xl);margin-top:var(--space-2xl);grid-template-columns:repeat(3,1fr);display:grid}.rd-other-card{border-radius:var(--radius-lg);background:var(--color-off-white);transition:transform var(--transition-base), box-shadow var(--transition-base);overflow:hidden}.rd-other-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.rd-other-img{aspect-ratio:4/3;position:relative;overflow:hidden}.rd-other-img img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-slow)}.rd-other-card:hover .rd-other-img img{transform:scale(1.05)}.rd-other-img .badge{top:var(--space-sm);left:var(--space-sm);text-transform:capitalize;position:absolute}.rd-other-info{padding:var(--space-lg)}.rd-other-info h3{color:var(--color-text);margin-bottom:var(--space-xs);font-size:18px;font-weight:500}.rd-other-info p{color:var(--color-gold);font-size:14px}@media (width<=1024px){.rd-grid{gap:var(--space-2xl);grid-template-columns:1fr}.rd-booking-card{position:static}.rd-other-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.rd-hero{padding:var(--space-sm)}.rd-thumbs{gap:var(--space-xs)}.rd-thumb{width:60px;height:45px}.rd-amenities-list,.rd-other-grid{grid-template-columns:1fr}.rd-nav-btn{width:40px;height:40px}}.riad-page{background:var(--color-off-white)}.riad-hero{height:60vh;min-height:450px;padding-bottom:var(--space-3xl);align-items:flex-end;display:flex;position:relative}.riad-hero-bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.riad-hero-overlay{background:linear-gradient(#0a06024d 0%,#0a0602d9 100%);position:absolute;inset:0}.riad-hero-content{z-index:1;text-align:center;flex-direction:column;align-items:center;width:100%;display:flex;position:relative}.riad-hero-title{color:var(--color-white);margin:var(--space-xs) 0 var(--space-sm);font-size:clamp(48px,8vw,80px);font-weight:500}.riad-hero-sub{color:#ffffffbf;max-width:500px;font-size:18px;font-weight:300}.riad-story{background:var(--color-white)}.riad-story-grid{gap:var(--space-3xl);grid-template-columns:1fr 1fr;align-items:center;display:grid}.riad-story-content{gap:var(--space-md);flex-direction:column;display:flex}.riad-story-content p{color:var(--color-text-muted);font-size:16px;line-height:1.9}.riad-story-image{position:relative}.riad-story-image img{border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-lg)}.riad-story-badge{bottom:-20px;left:var(--space-xl);background:var(--color-gold);color:var(--color-white);padding:var(--space-md) var(--space-xl);border-radius:var(--radius-lg);align-items:center;gap:var(--space-sm);box-shadow:var(--shadow-gold);font-size:14px;font-weight:600;display:flex;position:absolute}.riad-highlights{background:var(--color-off-white)}.highlights-grid{gap:var(--space-xl);margin-top:var(--space-2xl);grid-template-columns:repeat(4,1fr);display:grid}.highlight-card{background:var(--color-white);padding:var(--space-xl);border-radius:var(--radius-lg);text-align:center;border:1px solid var(--color-border-light);transition:transform var(--transition-base), box-shadow var(--transition-base)}.highlight-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.highlight-icon{background:linear-gradient(135deg, var(--color-gold-light), var(--color-gold));width:64px;height:64px;margin:0 auto var(--space-lg);color:var(--color-white);border-radius:50%;justify-content:center;align-items:center;display:flex}.highlight-card h3{color:var(--color-text);margin-bottom:var(--space-sm);font-size:18px;font-weight:600}.highlight-card p{color:var(--color-text-muted);font-size:14px;line-height:1.7}.riad-amenities{background:var(--color-white)}.riad-amenities-grid{gap:var(--space-3xl);grid-template-columns:1fr 1fr;align-items:center;display:grid}.riad-amenities-image img{border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-lg)}.riad-amenities-content{gap:var(--space-md);flex-direction:column;display:flex}.riad-amenities-intro{color:var(--color-text-muted);margin-bottom:var(--space-md);font-size:16px;line-height:1.8}.amenities-list{gap:var(--space-sm);grid-template-columns:1fr 1fr;list-style:none;display:grid}.amenities-list li{color:var(--color-text);padding-left:24px;font-size:15px;position:relative}.amenities-list li:before{content:"";background:var(--color-gold);border-radius:50%;width:8px;height:8px;position:absolute;top:8px;left:0}.riad-location{background:var(--color-off-white)}.location-content{gap:var(--space-2xl);margin-top:var(--space-2xl);grid-template-columns:1fr 1.5fr;display:grid}.location-info{gap:var(--space-xl);flex-direction:column;display:flex}.location-address{gap:var(--space-md);padding:var(--space-lg);background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);display:flex}.location-address svg{color:var(--color-gold);flex-shrink:0}.location-address div{flex-direction:column;gap:4px;display:flex}.location-address strong{color:var(--color-text);font-size:18px}.location-address span{color:var(--color-text-muted);font-size:14px}.location-nearby{padding:var(--space-lg);background:var(--color-white);border-radius:var(--radius-lg);border:1px solid var(--color-border-light)}.location-nearby h4{text-transform:uppercase;letter-spacing:.1em;color:var(--color-gold);margin-bottom:var(--space-md);font-size:14px;font-weight:600}.location-nearby ul{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.location-nearby li{color:var(--color-text-muted);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-light);font-size:14px}.location-nearby li:last-child{border-bottom:none;padding-bottom:0}.location-map{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.riad-cta{background:var(--color-deep);padding:var(--space-3xl) 0;text-align:center}.riad-cta h2{color:var(--color-white);margin-bottom:var(--space-sm);font-size:clamp(28px,4vw,40px);font-weight:500}.riad-cta p{color:#ffffffb3;margin-bottom:var(--space-xl);font-size:17px}@media (width<=1024px){.highlights-grid{grid-template-columns:repeat(2,1fr)}.location-content{grid-template-columns:1fr}}@media (width<=768px){.riad-story-grid,.riad-amenities-grid{gap:var(--space-2xl);grid-template-columns:1fr}.riad-story-image{order:-1}.riad-story-badge{bottom:-15px;left:var(--space-md);padding:var(--space-sm) var(--space-md);font-size:12px}.highlights-grid,.amenities-list{grid-template-columns:1fr}}.booking-page{background:var(--color-off-white);min-height:100vh;padding-top:72px}.booking-header{background:var(--color-white);border-bottom:1px solid var(--color-border-light);padding:var(--space-md) 0}.booking-header-inner{justify-content:space-between;align-items:center;gap:var(--space-xl);flex-wrap:wrap;display:flex}.booking-back{align-items:center;gap:var(--space-sm);color:var(--color-text-muted);transition:color var(--transition-base);font-size:13px;font-weight:500;display:flex}.booking-back:hover{color:var(--color-gold)}.booking-steps{align-items:center;gap:0;display:flex}.booking-step{align-items:center;gap:var(--space-sm);display:flex}.booking-step-circle{border-radius:var(--radius-full);border:2px solid var(--color-border);width:32px;height:32px;color:var(--color-text-muted);background:var(--color-white);transition:all var(--transition-base);flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:600;display:flex}.booking-step.active .booking-step-circle{background:var(--color-gold);border-color:var(--color-gold);color:var(--color-white);box-shadow:var(--shadow-gold)}.booking-step.done .booking-step-circle{background:var(--color-text);border-color:var(--color-text);color:var(--color-white)}.booking-step-label{color:var(--color-text-muted);white-space:nowrap;font-size:13px;font-weight:500}.booking-step.active .booking-step-label{color:var(--color-gold);font-weight:600}.booking-step.done .booking-step-label{color:var(--color-text)}.booking-step-line{background:var(--color-border);width:40px;height:2px;margin:0 var(--space-sm)}.booking-layout{gap:var(--space-3xl);padding:var(--space-3xl) 0;grid-template-columns:1fr 360px;align-items:start;display:grid}.booking-step-content{background:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);padding:var(--space-3xl)}.booking-step-title{color:var(--color-text);margin-bottom:var(--space-xs);font-size:32px;font-weight:500}.booking-step-sub{color:var(--color-text-muted);margin-bottom:var(--space-2xl);font-size:15px}.room-picker{gap:var(--space-md);margin-bottom:var(--space-xl);flex-direction:column;display:flex}.room-pick-card{gap:var(--space-md);padding:var(--space-md);border-radius:var(--radius-lg);border:2px solid var(--color-border-light);cursor:pointer;transition:all var(--transition-base);align-items:center;display:flex;position:relative}.room-pick-card input[type=radio]{opacity:0;pointer-events:none;position:absolute}.room-pick-card:hover{border-color:var(--color-gold);background:#c8973f08}.room-pick-card.selected{border-color:var(--color-gold);background:#c8973f0f;box-shadow:0 0 0 3px #c8973f1f}.rpc-img{border-radius:var(--radius-md);flex-shrink:0;width:100px;height:80px;overflow:hidden}.rpc-img img{object-fit:cover;width:100%;height:100%}.rpc-info{gap:var(--space-xs);flex-direction:column;flex:1;display:flex}.rpc-top{justify-content:space-between;align-items:baseline;gap:var(--space-md);display:flex}.rpc-name{font-family:var(--font-serif);color:var(--color-text);font-size:20px;font-weight:500}.rpc-price{font-family:var(--font-serif);color:var(--color-gold-dark);white-space:nowrap;font-size:22px;font-weight:600}.rpc-price span{font-size:13px;font-family:var(--font-sans);color:var(--color-text-muted);font-weight:400}.rpc-desc{color:var(--color-text-muted);font-size:13px;line-height:1.6}.rpc-tags{gap:var(--space-xs);flex-wrap:wrap;margin-top:4px;display:flex}.rpc-tag{color:var(--color-text-muted);background:var(--color-sand);border-radius:var(--radius-full);padding:3px 10px;font-size:11px;font-weight:500}.rpc-check{border-radius:var(--radius-full);background:var(--color-gold);width:28px;height:28px;color:var(--color-white);flex-shrink:0;justify-content:center;align-items:center;display:flex}.booking-dates-row{gap:var(--space-md);margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr 1fr;display:grid}.booking-next-btn{justify-content:center;width:100%;padding:16px;font-size:14px}.booking-form-grid{gap:var(--space-lg);margin-bottom:var(--space-xl);grid-template-columns:1fr 1fr;display:grid}.form-group.full-width{grid-column:1/-1}textarea.form-input{resize:vertical;min-height:100px}.booking-error{color:#dc2626;margin-bottom:var(--space-md);padding:var(--space-md);border-radius:var(--radius-md);background:#dc26260f;border:1px solid #dc262633;font-size:14px}.booking-form-actions{gap:var(--space-md);justify-content:space-between;align-items:center;display:flex}.spin{animation:.8s linear infinite spinSlow}.booking-confirmed{background:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);padding:var(--space-4xl) var(--space-3xl);text-align:center;align-items:center;gap:var(--space-lg);flex-direction:column;grid-column:1/-1;display:flex}.confirmed-icon{border-radius:var(--radius-full);width:80px;height:80px;color:var(--color-gold);margin-bottom:var(--space-sm);background:#c8973f1a;border:2px solid #c8973f4d;justify-content:center;align-items:center;display:flex}.confirmed-title{color:var(--color-text);font-size:40px;font-weight:500}.confirmed-sub{color:var(--color-text-muted);max-width:480px;font-size:16px}.confirmed-ref{background:var(--color-sand);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg) var(--space-xl);gap:var(--space-xs);flex-direction:column;align-items:center;display:flex}.ref-label{letter-spacing:.15em;text-transform:uppercase;color:var(--color-text-muted);font-size:11px;font-weight:600}.ref-number{font-family:var(--font-serif);color:var(--color-gold-dark);letter-spacing:.05em;font-size:32px;font-weight:600}.confirmed-desc{max-width:520px;color:var(--color-text-muted);line-height:1.8}.confirmed-actions{gap:var(--space-md);margin-top:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}.booking-summary{top:calc(72px + var(--space-xl));position:sticky}.summary-card{background:var(--color-white);border-radius:var(--radius-xl);border:1px solid var(--color-border-light);box-shadow:var(--shadow-md);overflow:hidden}.summary-title{color:var(--color-text);padding:var(--space-xl);border-bottom:1px solid var(--color-border-light);font-size:16px;font-weight:600}.summary-room-img{aspect-ratio:16/9;overflow:hidden}.summary-room-img img{object-fit:cover;width:100%;height:100%}.summary-room-name{font-family:var(--font-serif);color:var(--color-text);padding:var(--space-lg);padding-bottom:0;font-size:22px;font-weight:500}.summary-details{padding:0 var(--space-lg);gap:var(--space-sm);margin:var(--space-md) 0;flex-direction:column;display:flex}.summary-row{padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;font-size:14px;display:flex}.summary-row span{color:var(--color-text-muted)}.summary-row strong{color:var(--color-text);font-weight:500}.summary-pricing{background:var(--color-sand);margin:0 var(--space-lg) var(--space-lg);border-radius:var(--radius-lg);padding:var(--space-md)}.summary-price-row{color:var(--color-text-muted);margin-bottom:var(--space-sm);justify-content:space-between;font-size:14px;display:flex}.summary-total{font-family:var(--font-serif);color:var(--color-gold-dark);border-top:1px solid var(--color-border);padding-top:var(--space-sm);justify-content:space-between;font-size:24px;font-weight:600;display:flex}.summary-placeholder{padding:var(--space-xl);color:var(--color-text-muted);text-align:center;font-size:14px}.summary-note{align-items:center;gap:var(--space-xs);color:#16a34a;padding:var(--space-md) var(--space-lg);background:#22c55e0f;border-top:1px solid #22c55e1a;font-size:13px;display:flex}@media (width<=1024px){.booking-layout{grid-template-columns:1fr}.booking-summary{position:static}}@media (width<=768px){.booking-step-content{padding:var(--space-xl)}.booking-dates-row,.booking-form-grid{grid-template-columns:1fr}.booking-steps{display:none}.booking-form-actions{flex-direction:column}.form-input,input,select,textarea{font-size:16px!important}}
