/* ═══ BEST OUTLOOK HOTEL — Global Styles ═══ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0c1d3a;--navy-lt:#1a3565;--charcoal:#2a2a2a;--mid:#666;--gray:#999;
  --cream:#f7f4ee;--warm:#ede8dd;--sand:#d9d2c4;--white:#fff;
  --gold:#b8944e;--gold-lt:#d4b87a;--gold-dk:#8a6e34;
  --serif:'Cormorant',Georgia,serif;
  --sans:'Outfit',system-ui,sans-serif;
  --nav-h:70px;
  --red:#c0392b;--green:#27ae60;
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);color:var(--charcoal);background:var(--cream);-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--gold);color:#fff}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
button{font-family:var(--sans);cursor:pointer;border:none;background:none}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.sec{padding:100px 0}

/* ═══ NAV ═══ */
body:not(.admin-body) nav{position:fixed;top:0;left:0;right:0;z-index:500;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 40px;transition:background .4s,box-shadow .4s,border-color .4s;border-bottom:1px solid transparent}
body:not(.admin-body) nav.scrolled{background:rgba(247,244,238,.96);backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 1px 20px rgba(0,0,0,.04)}
nav.at-hero .nav-logo,nav.at-hero .nav-links a,nav.at-hero .nav-book{color:#fff}
nav.at-hero .nav-book{border-color:rgba(255,255,255,.5)}
nav.at-hero .nav-book:hover{background:#fff;color:var(--navy);border-color:#fff}
.nav-logo{font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--navy);letter-spacing:.06em;transition:color .4s}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:var(--charcoal);transition:color .3s;position:relative}
.nav-links a:hover{color:var(--gold)}
.nav-links a.active{color:var(--gold)}
.nav-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:1.5px;background:var(--gold)}
.nav-book{font-size:.63rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--navy);border:1.5px solid var(--navy);padding:10px 22px;transition:.3s}
.nav-book:hover{background:var(--navy);color:#fff}
.nav-burger{display:none;flex-direction:column;gap:5px;width:24px;cursor:pointer}
.nav-burger span{display:block;height:1.5px;background:var(--navy);transition:.3s}
nav.at-hero .nav-burger span{background:#fff}

/* Mobile menu */
.mob-menu{position:fixed;inset:0;background:var(--cream);z-index:499;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;opacity:0;visibility:hidden;transition:.4s}
.mob-menu.open{opacity:1;visibility:visible}
.mob-menu a{font-family:var(--serif);font-size:1.5rem;color:var(--navy);letter-spacing:.05em}
.mob-close{position:absolute;top:24px;right:28px;font-size:1.8rem;color:var(--navy);cursor:pointer}

/* ═══ HERO ═══ */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden}
.hero-img{position:absolute;inset:0}
.hero-img img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,29,58,.25) 0%,rgba(12,29,58,.55) 100%)}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:#fff;padding:0 28px}
.hero-tag{font-size:.6rem;letter-spacing:.55em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:20px;opacity:0;animation:heroUp .8s ease .3s forwards}
.hero-h1{font-family:var(--serif);font-size:clamp(2.6rem,6vw,4.5rem);font-weight:300;letter-spacing:.06em;line-height:1.15;margin-bottom:14px;opacity:0;animation:heroUp .8s ease .5s forwards}
.hero-sub{font-size:.85rem;font-weight:300;letter-spacing:.04em;color:rgba(255,255,255,.85);max-width:500px;opacity:0;animation:heroUp .8s ease .7s forwards}
.hero-cta{margin-top:36px;display:flex;gap:16px;opacity:0;animation:heroUp .8s ease .9s forwards}
.hero-cta a{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:14px 32px;transition:.3s}
.hero-cta .cta-pri{background:#fff;color:var(--navy)}
.hero-cta .cta-pri:hover{background:var(--gold);color:#fff}
.hero-cta .cta-sec{border:1.5px solid rgba(255,255,255,.6);color:#fff}
.hero-cta .cta-sec:hover{border-color:#fff;background:rgba(255,255,255,.12)}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:heroUp .8s ease 1.1s forwards}
.hero-scroll span{font-size:.55rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.hero-scroll-line{width:1px;height:40px;background:rgba(255,255,255,.25);position:relative;overflow:hidden}
.hero-scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:var(--gold-lt);animation:scrollLine 2s ease infinite}
@keyframes heroUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes scrollLine{0%{top:-100%}50%{top:0}100%{top:100%}}

/* ═══ PAGE BANNER (inner pages) ═══ */
.page-banner{position:relative;height:50vh;min-height:340px;overflow:hidden;display:flex;align-items:flex-end}
.page-banner img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-banner .pb-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(12,29,58,.2) 0%,rgba(12,29,58,.65) 100%)}
.page-banner .pb-content{position:relative;z-index:2;padding:0 40px 48px;width:100%}
.page-banner .pb-tag{font-size:.6rem;letter-spacing:.45em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:10px}
.page-banner .pb-title{font-family:var(--serif);font-size:clamp(2rem,5vw,3.2rem);font-weight:300;color:#fff;letter-spacing:.04em}
.page-banner .pb-sub{font-size:.85rem;color:rgba(255,255,255,.7);font-weight:300;margin-top:8px;max-width:500px}

/* ═══ SECTION HEADERS ═══ */
.sec-header{text-align:center;margin-bottom:56px}
.sec-tag{font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.sec-title{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:400;color:var(--navy);line-height:1.2}
.sec-rule{width:50px;height:1px;background:var(--gold);margin:20px auto 0}
.sec-desc{max-width:600px;margin:20px auto 0;font-size:.9rem;color:var(--mid);line-height:1.7;font-weight:300}

/* ═══ ABOUT ═══ */
.about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.about-text h2{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;color:var(--navy);line-height:1.3;margin-bottom:24px}
.about-text p{font-size:.88rem;color:var(--mid);line-height:1.8;font-weight:300;margin-bottom:16px}
.about-img{position:relative;overflow:hidden}
.about-img img{width:100%;height:480px;object-fit:cover}
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:40px;border-top:1px solid var(--sand);padding-top:32px}
.about-stat{text-align:center}
.about-stat strong{font-family:var(--serif);font-size:2rem;font-weight:400;color:var(--navy);display:block}
.about-stat span{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray)}

/* ═══ ROOM CARDS ═══ */
.rooms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:28px}
.room-card{background:var(--white);overflow:hidden;transition:transform .4s,box-shadow .4s}
.room-card:hover{transform:translateY(-4px);box-shadow:0 20px 60px rgba(0,0,0,.08)}
.room-img{height:280px;overflow:hidden}
.room-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.room-card:hover .room-img img{transform:scale(1.04)}
.room-body{padding:28px}
.room-type{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.room-name{font-family:var(--serif);font-size:1.35rem;font-weight:400;color:var(--navy);margin-bottom:12px}
.room-desc{font-size:.82rem;color:var(--mid);line-height:1.7;font-weight:300;margin-bottom:16px}
.room-amenities{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.room-amenities span{font-size:.65rem;letter-spacing:.06em;color:var(--mid);background:var(--cream);padding:5px 12px}
.room-cta{font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--gold-dk);display:inline-flex;align-items:center;gap:8px;transition:color .3s}
.room-cta:hover{color:var(--navy)}
.room-cta svg{width:14px;height:14px;transition:transform .3s}
.room-cta:hover svg{transform:translateX(4px)}
/* Room detail */
.room-detail{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.room-detail-amenities{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}
.room-detail-amenities .rd-am{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--mid)}
.room-detail-amenities .rd-am svg{width:18px;height:18px;stroke:var(--gold);flex-shrink:0}

/* ═══ DINING / MENU ═══ */
.dining{background:var(--navy);color:#fff}
.dining .sec-tag{color:var(--gold-lt)}.dining .sec-title{color:#fff}.dining .sec-desc{color:rgba(255,255,255,.6)}.dining .sec-rule{background:var(--gold-lt)}
.menu-tabs{display:flex;justify-content:center;gap:8px;margin-bottom:40px;flex-wrap:wrap}
.menu-tab{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;color:rgba(255,255,255,.5);padding:10px 22px;border:1px solid rgba(255,255,255,.15);transition:.3s;cursor:pointer}
.menu-tab.active,.menu-tab:hover{color:#fff;border-color:var(--gold);background:rgba(184,148,78,.12)}
.menu-section{display:none}.menu-section.active{display:block}
.menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px 60px}
.menu-item{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.06)}
.menu-item-name{font-size:.88rem;font-weight:400;color:rgba(255,255,255,.9)}
.menu-item-sub{font-size:.75rem;font-weight:300;color:rgba(255,255,255,.4);margin-top:2px}
.menu-item-price{font-size:.82rem;color:var(--gold-lt);white-space:nowrap;margin-left:16px}
.menu-note{text-align:center;margin-top:32px;font-size:.78rem;color:rgba(255,255,255,.4);font-style:italic}
/* Light variant for inner pages */
.dining-light{background:var(--white);color:var(--charcoal)}
.dining-light .menu-tab{color:var(--mid);border-color:var(--sand)}
.dining-light .menu-tab.active,.dining-light .menu-tab:hover{color:var(--navy);border-color:var(--gold);background:rgba(184,148,78,.06)}
.dining-light .menu-item{border-color:var(--sand)}
.dining-light .menu-item-name{color:var(--charcoal)}
.dining-light .menu-item-sub{color:var(--gray)}
.dining-light .menu-item-price{color:var(--gold-dk)}
.dining-light .menu-note{color:var(--gray)}

/* ═══ FACILITIES ═══ */
.fac-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.fac-card{display:grid;grid-template-columns:200px 1fr;background:var(--white);overflow:hidden;transition:box-shadow .3s}
.fac-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.06)}
.fac-card-img{height:100%;min-height:200px;overflow:hidden}
.fac-card-img img{width:100%;height:100%;object-fit:cover}
.fac-card-body{padding:28px;display:flex;flex-direction:column;justify-content:center}
.fac-card-body h3{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:var(--navy);margin-bottom:10px}
.fac-card-body p{font-size:.82rem;color:var(--mid);line-height:1.7;font-weight:300}
.fac-price{margin-top:10px;font-size:.75rem;color:var(--gold-dk);font-weight:500}

/* ═══ DISCOVER ═══ */
.disc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.disc-item{text-align:center;padding:36px 24px;background:var(--white);transition:box-shadow .3s}
.disc-item:hover{box-shadow:0 8px 30px rgba(0,0,0,.05)}
.disc-icon{width:48px;height:48px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;border:1px solid var(--sand);border-radius:50%}
.disc-icon svg{width:22px;height:22px;stroke:var(--gold)}
.disc-item h3{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:var(--navy);margin-bottom:8px}
.disc-item p{font-size:.8rem;color:var(--mid);line-height:1.6;font-weight:300}

/* ═══ GALLERY ═══ */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-grid .gal-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:4/3}
.gallery-grid .gal-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery-grid .gal-item:hover img{transform:scale(1.05)}
.gallery-grid .gal-item.big{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
.gal-lightbox{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.3s}
.gal-lightbox.open{opacity:1;visibility:visible}
.gal-lightbox img{max-width:90vw;max-height:85vh;object-fit:contain}
.gal-lightbox .gal-close{position:absolute;top:24px;right:32px;font-size:2rem;color:#fff;cursor:pointer}

/* ═══ BOOKING WIZARD ═══ */
.wizard{max-width:680px;margin:0 auto;background:var(--white);padding:48px;box-shadow:0 8px 40px rgba(0,0,0,.05)}
.wizard-steps{display:flex;justify-content:center;gap:0;margin-bottom:40px}
.wizard-step{display:flex;align-items:center;gap:8px}
.wizard-step .ws-num{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;border:1.5px solid var(--sand);color:var(--gray);transition:.3s}
.wizard-step.active .ws-num{background:var(--gold);color:#fff;border-color:var(--gold)}
.wizard-step.done .ws-num{background:var(--green);color:#fff;border-color:var(--green)}
.wizard-step .ws-label{font-size:.65rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gray);transition:color .3s}
.wizard-step.active .ws-label{color:var(--navy);font-weight:600}
.wizard-step.done .ws-label{color:var(--green)}
.ws-line{width:40px;height:1px;background:var(--sand);margin:0 12px}
.wizard-panel{display:none}.wizard-panel.active{display:block}
.wiz-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.wiz-field{display:flex;flex-direction:column}
.wiz-field.full{grid-column:1/-1}
.wiz-label{font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);margin-bottom:8px}
.wiz-input,.wiz-select,.wiz-textarea{background:var(--cream);border:1px solid var(--sand);color:var(--charcoal);font-family:var(--sans);font-size:.85rem;padding:14px 16px;transition:border-color .3s;outline:none;width:100%}
.wiz-input:focus,.wiz-select:focus,.wiz-textarea:focus{border-color:var(--gold)}
.wiz-textarea{resize:vertical;min-height:80px}
.wiz-btns{display:flex;justify-content:space-between;margin-top:32px}
.wiz-btn{padding:14px 32px;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;transition:.3s}
.wiz-btn-next{background:var(--gold);color:#fff}.wiz-btn-next:hover{background:var(--gold-dk)}
.wiz-btn-back{color:var(--mid);border:1px solid var(--sand)}.wiz-btn-back:hover{border-color:var(--gold);color:var(--navy)}
.wiz-btn-submit{background:var(--navy);color:#fff;width:100%;text-align:center}.wiz-btn-submit:hover{background:var(--navy-lt)}
/* Room selection cards in wizard */
.wiz-rooms{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.wiz-room{border:2px solid var(--sand);padding:20px;text-align:center;cursor:pointer;transition:.3s}
.wiz-room:hover{border-color:var(--gold)}
.wiz-room.selected{border-color:var(--gold);background:rgba(184,148,78,.06)}
.wiz-room h4{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:var(--navy);margin-bottom:4px}
.wiz-room p{font-size:.75rem;color:var(--mid)}
/* Confirmation summary */
.wiz-summary{border:1px solid var(--sand);padding:28px;margin-bottom:24px}
.wiz-summary h3{font-family:var(--serif);font-size:1.3rem;color:var(--navy);margin-bottom:16px}
.wiz-summary-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--cream);font-size:.85rem}
.wiz-summary-row .wsr-label{color:var(--gray)}.wiz-summary-row .wsr-value{color:var(--navy);font-weight:500}
.wiz-success{text-align:center;padding:40px 20px}
.wiz-success svg{width:64px;height:64px;stroke:var(--green);margin-bottom:20px}
.wiz-success h2{font-family:var(--serif);font-size:1.6rem;color:var(--navy);margin-bottom:12px}
.wiz-success p{color:var(--mid);font-size:.9rem;line-height:1.6}

/* ═══ EVENTS ═══ */
.event-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.event-card{background:var(--white);padding:36px;transition:box-shadow .3s}
.event-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.06)}
.event-card h3{font-family:var(--serif);font-size:1.3rem;font-weight:400;color:var(--navy);margin-bottom:12px}
.event-card p{font-size:.85rem;color:var(--mid);line-height:1.7;font-weight:300;margin-bottom:12px}
.event-card .event-specs{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px}
.event-card .event-spec{font-size:.7rem;letter-spacing:.06em;color:var(--gold-dk);background:rgba(184,148,78,.08);padding:6px 14px}

/* ═══ FAQ ═══ */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--sand);overflow:hidden}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:20px 0;cursor:pointer;font-size:.95rem;font-weight:500;color:var(--navy);transition:color .3s}
.faq-q:hover{color:var(--gold)}
.faq-q svg{width:20px;height:20px;stroke:var(--gold);transition:transform .3s;flex-shrink:0}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{font-size:.85rem;color:var(--mid);line-height:1.7;padding-bottom:20px}

/* ═══ BLOG ═══ */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.blog-card{background:var(--white);overflow:hidden;transition:box-shadow .3s}
.blog-card:hover{box-shadow:0 12px 40px rgba(0,0,0,.06)}
.blog-card-img{height:200px;overflow:hidden}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-card:hover .blog-card-img img{transform:scale(1.04)}
.blog-card-body{padding:24px}
.blog-card-date{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.blog-card-body h3{font-family:var(--serif);font-size:1.15rem;font-weight:400;color:var(--navy);margin-bottom:10px;line-height:1.35}
.blog-card-body p{font-size:.82rem;color:var(--mid);line-height:1.6;font-weight:300}

/* ═══ CONTACT ═══ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.contact-info h3{font-family:var(--serif);font-size:1.4rem;font-weight:400;color:var(--navy);margin-bottom:20px}
.contact-line{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.contact-line svg{width:18px;height:18px;stroke:var(--gold);flex-shrink:0;margin-top:2px}
.contact-line p{font-size:.85rem;color:var(--mid);line-height:1.6}
.contact-map{width:100%;height:350px;background:var(--warm);overflow:hidden}
.contact-map iframe{width:100%;height:100%;border:0;filter:grayscale(.3)}
.contact-form{margin-top:32px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.cf-input,.cf-textarea{background:var(--cream);border:1px solid var(--sand);color:var(--charcoal);font-family:var(--sans);font-size:.85rem;padding:14px 16px;outline:none;width:100%;transition:border-color .3s}
.cf-input:focus,.cf-textarea:focus{border-color:var(--gold)}
.cf-textarea{resize:vertical;min-height:100px}
.cf-submit{display:block;width:100%;padding:14px;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;background:var(--navy);color:#fff;border:none;cursor:pointer;transition:.3s;margin-top:8px}
.cf-submit:hover{background:var(--navy-lt)}

/* ═══ INFO BAR ═══ */
.info-bar{background:var(--white);border-top:1px solid var(--sand);border-bottom:1px solid var(--sand)}
.info-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.info-item{text-align:center;padding:36px 20px;border-right:1px solid var(--sand)}
.info-item:last-child{border-right:none}
.info-item h4{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.info-item p{font-size:.88rem;color:var(--navy);font-weight:400}

/* ═══ ADMIN PANEL ═══ */
.admin-wrap{max-width:1100px;margin:0 auto;padding:100px 28px 60px}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}
.admin-header h1{font-family:var(--serif);font-size:1.8rem;font-weight:400;color:var(--navy)}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px}
.admin-stat{background:var(--white);padding:24px;text-align:center;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.admin-stat .as-num{font-family:var(--serif);font-size:2rem;color:var(--navy);font-weight:400}
.admin-stat .as-label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-top:4px}
.admin-table{width:100%;background:var(--white);box-shadow:0 2px 12px rgba(0,0,0,.04);overflow-x:auto}
.admin-table table{width:100%;border-collapse:collapse}
.admin-table th{text-align:left;padding:14px 18px;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);background:var(--cream);border-bottom:1px solid var(--sand);font-weight:500}
.admin-table td{padding:14px 18px;font-size:.85rem;color:var(--charcoal);border-bottom:1px solid var(--cream)}
.admin-table tr:hover td{background:rgba(247,244,238,.5)}
.status{display:inline-block;font-size:.65rem;letter-spacing:.06em;padding:4px 12px;font-weight:600;text-transform:uppercase}
.status-pending{background:rgba(243,156,18,.1);color:#f39c12}
.status-confirmed{background:rgba(39,174,96,.1);color:var(--green)}
.status-cancelled{background:rgba(192,57,43,.1);color:var(--red)}
.admin-empty{text-align:center;padding:60px;color:var(--gray);font-size:.9rem}

/* ═══ FOOTER ═══ */
footer{background:var(--navy);color:rgba(255,255,255,.5);padding:60px 0 28px}
.foot-top{display:flex;justify-content:space-between;align-items:center;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-logo{font-family:var(--serif);font-size:1.15rem;font-weight:500;color:#fff;letter-spacing:.06em}
.foot-links{display:flex;gap:20px;flex-wrap:wrap}
.foot-links a{font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;transition:color .3s}
.foot-links a:hover{color:var(--gold-lt)}
.foot-mid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;padding:36px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-col h4{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-lt);margin-bottom:14px}
.foot-col p,.foot-col a{display:block;font-size:.8rem;color:rgba(255,255,255,.45);line-height:1.7}
.foot-col a:hover{color:var(--gold-lt)}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:24px}
.foot-copy{font-size:.72rem}
.foot-credit{font-size:.68rem}
.foot-credit a{color:var(--gold-lt);transition:color .3s}
.foot-credit a:hover{color:#fff}

/* ═══ LANG SWITCH ═══ */
.lang-switch{position:fixed;bottom:24px;right:24px;z-index:400;display:flex;border:1px solid var(--sand);background:var(--white);box-shadow:0 4px 20px rgba(0,0,0,.08)}
.lang-btn{padding:8px 14px;font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;font-weight:500;color:var(--mid);cursor:pointer;transition:.3s}
.lang-btn.active{background:var(--navy);color:#fff}

/* ═══ REVEAL ═══ */
.rv{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}
.rv.vis{opacity:1;transform:none}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .about-grid,.contact-grid,.room-detail{grid-template-columns:1fr}
  .about-img img{height:320px}
  .rooms-grid,.blog-grid{grid-template-columns:1fr}
  .menu-grid{grid-template-columns:1fr}
  .fac-grid,.event-cards{grid-template-columns:1fr}
  .fac-card{grid-template-columns:1fr}
  .fac-card-img{min-height:180px}
  .disc-grid,.gallery-grid{grid-template-columns:1fr 1fr}
  .gallery-grid .gal-item.big{grid-column:span 1;grid-row:span 1}
  .wiz-rooms{grid-template-columns:1fr}
  .wiz-row{grid-template-columns:1fr}
  .info-grid{grid-template-columns:1fr 1fr}
  .info-item{border-right:none;border-bottom:1px solid var(--sand)}
  .admin-stats{grid-template-columns:1fr 1fr}
  .foot-top,.foot-bot{flex-direction:column;gap:16px;text-align:center}
  .foot-mid{grid-template-columns:1fr}
  nav{padding:0 20px}.wrap{padding:0 20px}.sec{padding:64px 0}
  .cf-row{grid-template-columns:1fr}
  .page-banner .pb-content{padding:0 20px 36px}
}
@media(max-width:600px){
  .about-stats{grid-template-columns:1fr;gap:20px}
  .info-grid{grid-template-columns:1fr}
  .hero-cta{flex-direction:column;align-items:center}
  .disc-grid{grid-template-columns:1fr}
  .admin-stats{grid-template-columns:1fr}
  .wizard{padding:28px 20px}
}

/* ═══ BOOKING — NEW LAYOUT ═══ */
.bk-layout{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start;max-width:1140px;margin:0 auto}
.bk-layout .wizard{max-width:none;margin:0;padding:36px}
.wiz-h{font-family:var(--serif);font-size:1.3rem;color:var(--navy);text-align:center;margin-bottom:8px}
.wiz-sub{text-align:center;font-size:.82rem;color:var(--gray);margin-bottom:24px}
.bk-rooms{display:flex;flex-direction:column;gap:16px;margin-bottom:8px}
.bk-room{display:grid;grid-template-columns:200px 1fr;border:2px solid var(--sand);overflow:hidden;cursor:pointer;transition:.3s;background:var(--white)}
.bk-room:hover{border-color:var(--gold-lt);box-shadow:0 8px 30px rgba(0,0,0,.06)}
.bk-room.selected{border-color:var(--gold);box-shadow:0 8px 30px rgba(184,148,78,.15)}
.bk-room-img{height:100%;min-height:160px;overflow:hidden;position:relative}
.bk-room-img img{width:100%;height:100%;object-fit:cover}
.bk-room-badge{position:absolute;top:12px;left:12px;font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;font-weight:600;color:#fff;background:var(--gold);padding:5px 12px;z-index:2}
.bk-room-body{padding:20px;display:flex;flex-direction:column}
.bk-room-body h3{font-family:var(--serif);font-size:1.2rem;font-weight:400;color:var(--navy);margin-bottom:4px}
.bk-room-size{font-size:.74rem;color:var(--gold-dk);font-weight:500;margin-bottom:8px}
.bk-room-body p{font-size:.8rem;color:var(--mid);line-height:1.55;font-weight:300;margin-bottom:12px;flex:1}
.bk-bedchoice{margin:0 0 14px}
.bk-bedchoice-lbl{display:block;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dk);font-weight:600;margin-bottom:8px}
.bk-bedopts{display:flex;gap:8px;flex-wrap:wrap}
.bk-bedopt{font-size:.74rem;color:var(--mid);background:var(--white);border:1.5px solid var(--sand);padding:8px 14px;cursor:pointer;transition:.25s;font-family:var(--sans)}
.bk-bedopt:hover{border-color:var(--gold-lt)}
.bk-bedopt.active{border-color:var(--gold);background:var(--gold);color:#fff;font-weight:500}
.bk-room-footer{display:flex;align-items:center;gap:12px}
.bk-room-price{font-size:.95rem;color:var(--navy)}
.bk-room-price strong{font-family:var(--serif);font-size:1.2rem;color:var(--navy)}
.bk-room-price span{font-size:.75rem;color:var(--gray)}
.bk-room-avail{margin-left:auto}
.bk-room-check{width:22px;height:22px;border:2px solid var(--sand);border-radius:50%;flex-shrink:0;transition:.3s}
.bk-room.selected .bk-room-check{background:var(--gold);border-color:var(--gold);position:relative}
.bk-room.selected .bk-room-check::after{content:'\2713';position:absolute;inset:0;color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.bk-pill{font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:2px}
.bk-pill-ok{background:rgba(39,174,96,.12);color:var(--green)}
.bk-pill-bad{background:rgba(192,57,43,.12);color:var(--red)}
.bk-srs{display:flex;align-items:center;gap:14px;background:var(--cream);padding:14px;margin-bottom:20px}
.bk-srs img{width:80px;height:60px;object-fit:cover;flex-shrink:0}
.bk-avail{margin:8px 0 16px;text-align:center;font-size:.85rem;min-height:1.2em}
.bk-ok{color:var(--green);font-weight:500}
.bk-bad{color:var(--red);font-weight:500}
.bk-loading{color:var(--gray);font-style:italic}
.bk-addons{display:flex;flex-direction:column;gap:12px;margin-bottom:8px}
.bk-addon{display:flex;align-items:center;gap:14px;padding:16px;border:2px solid var(--sand);background:var(--white);cursor:pointer;transition:.3s}
.bk-addon:hover{border-color:var(--gold-lt)}
.bk-addon.selected{border-color:var(--gold);background:rgba(184,148,78,.04)}
.bk-addon input{display:none}
.bk-addon-body{flex:1}
.bk-addon-name{font-size:.95rem;color:var(--navy);font-weight:500}
.bk-addon-meta{font-size:.78rem;color:var(--gray);margin-top:2px}
.bk-addon-check{width:20px;height:20px;border:2px solid var(--sand);border-radius:50%;flex-shrink:0;transition:.3s}
.bk-addon.selected .bk-addon-check{background:var(--gold);border-color:var(--gold);position:relative}
.bk-addon.selected .bk-addon-check::after{content:'\2713';position:absolute;inset:0;color:#fff;font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.bk-pay-options{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.bk-pay-opt{display:flex;align-items:center;gap:18px;padding:20px;border:2px solid var(--sand);background:var(--white);cursor:pointer;transition:.3s}
.bk-pay-opt:hover{border-color:var(--gold-lt)}
.bk-pay-opt.selected{border-color:var(--gold);background:rgba(184,148,78,.04)}
.bk-pay-icon{font-size:1.6rem}
.bk-pay-body{flex:1}
.bk-pay-title{font-size:1rem;color:var(--navy);font-weight:600;margin-bottom:4px}
.bk-pay-desc{font-size:.8rem;color:var(--mid);font-weight:300}
.bk-pay-check{width:22px;height:22px;border:2px solid var(--sand);border-radius:50%;flex-shrink:0;transition:.3s}
.bk-pay-opt.selected .bk-pay-check{background:var(--gold);border-color:var(--gold);position:relative}
.bk-pay-opt.selected .bk-pay-check::after{content:'\2713';position:absolute;inset:0;color:#fff;font-size:.7rem;font-weight:700;display:flex;align-items:center;justify-content:center}
.bk-paypal{margin-bottom:14px;min-height:80px}
.bk-pp-msg{margin-top:10px;font-size:.85rem;text-align:center}
.bk-ref{font-size:.85rem;color:var(--gold-dk);margin-top:14px;padding:10px;background:var(--cream);font-family:'Courier New',monospace}
.bk-back-home{display:inline-block;margin-top:24px;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--gold-dk)}
.bk-summary{background:var(--white);padding:24px;position:sticky;top:90px;box-shadow:0 4px 24px rgba(0,0,0,.05)}
.bk-summary h4{font-family:var(--serif);font-size:1.1rem;color:var(--navy);font-weight:500;margin-bottom:14px}
.bks-room{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.bks-room img{width:64px;height:48px;object-fit:cover}
.bks-room-name{font-family:var(--serif);font-size:.95rem;color:var(--navy)}
.bks-room-meta{font-size:.72rem;color:var(--gold-dk)}
.bks-empty{font-size:.82rem;color:var(--gray);font-style:italic;padding:8px 0}
.bks-divider{height:1px;background:var(--sand);margin:12px 0}
.bks-line{display:flex;justify-content:space-between;padding:6px 0;font-size:.82rem;color:var(--mid)}
.bks-line span:last-child{color:var(--navy);font-weight:500}
.bks-total{display:flex;justify-content:space-between;padding-top:8px;font-family:var(--serif);font-size:1.3rem;color:var(--navy)}
.bks-note{margin-top:14px;font-size:.7rem;color:var(--gray);text-align:center;font-style:italic}
@media(max-width:900px){
  .bk-layout{grid-template-columns:1fr}
  .bk-summary{position:static;order:-1}
  .bk-room{grid-template-columns:1fr}
  .bk-room-img{min-height:180px}
  .bk-layout .wizard{padding:24px 18px}
}

/* ═══ ADMIN — NEW LAYOUT ═══ */
.admin-body{background:#f3f1ec}
.adm-login{position:fixed;inset:0;background:var(--navy);display:flex;align-items:center;justify-content:center;padding:20px;z-index:100}
.adm-login-card{background:var(--white);padding:40px;width:100%;max-width:380px;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.adm-login-logo{font-family:var(--serif);font-size:1.1rem;color:var(--gold-dk);letter-spacing:.1em;margin-bottom:20px}
.adm-login-card h1{font-family:var(--serif);font-size:1.6rem;color:var(--navy);font-weight:400;margin-bottom:8px}
.adm-login-card p{font-size:.82rem;color:var(--gray);margin-bottom:20px}
.adm-login-card input{width:100%;padding:12px 14px;border:1px solid var(--sand);background:var(--cream);font-family:var(--sans);font-size:.9rem;outline:none;margin-bottom:14px}
.adm-login-card input:focus{border-color:var(--gold)}
.adm-login-card button{width:100%}
.adm-login-msg{margin-top:10px;font-size:.8rem;color:var(--red);min-height:1.2em}
.adm-login-hint{margin-top:18px;font-size:.72rem;color:var(--gray)}
.adm-login-hint code{background:var(--cream);padding:2px 6px;font-family:'Courier New',monospace}
/* ═══ ADMIN LAYOUT ═══ */
.admin-body{margin:0;padding:0;background:#f3f1ec}
.adm{display:flex;height:100vh;overflow:hidden}

/* Sidebar — always fixed on left */
.adm-side{
  width:240px;flex-shrink:0;
  background:#0f1f3d;
  display:flex;flex-direction:column;
  height:100vh;overflow-x:hidden;overflow-y:auto;
  box-shadow:2px 0 12px rgba(0,0,0,.18);
  z-index:30;position:relative;
}
.adm-brand{
  font-family:var(--serif);font-size:1.05rem;color:#fff;
  padding:22px 20px 16px;
  border-bottom:1px solid rgba(255,255,255,.1);
  flex-shrink:0;letter-spacing:.05em;line-height:1.3;
}
.adm-brand span{
  display:block;font-size:.58rem;letter-spacing:.3em;
  color:#c8a96e;text-transform:uppercase;
  font-family:var(--sans);margin-top:4px;
}
/* Nav — fills remaining space, pushing footer to bottom */
.adm-nav{position:static;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;flex:1;padding:10px 0;gap:1px;height:auto}
/* Each nav item is a pill — scoped within sidebar, not full-bleed */
.adm-nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  margin:0 8px;
  width:calc(100% - 16px);
  font-size:.82rem;color:rgba(255,255,255,.7);
  border:none;background:transparent;cursor:pointer;
  text-align:left;border-radius:8px;
  font-family:var(--sans);transition:background .15s,color .15s;
  letter-spacing:.01em;
  flex-shrink:0;
}
.adm-nav-item:hover{
  background:rgba(255,255,255,.09);
  color:#fff;
}
.adm-nav-item.active{
  background:rgba(200,169,110,.22);
  color:#fff;font-weight:600;
  box-shadow:inset 3px 0 0 #c8a96e;
}
.adm-i{
  font-size:1rem;width:18px;text-align:center;
  color:#c8a96e;flex-shrink:0;
}
.adm-nav-item.active .adm-i{color:#e2c47e}
/* Footer always at bottom, never overlapping nav */
.adm-side-foot{
  flex-shrink:0;
  padding:14px 20px;
  border-top:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;gap:6px;
}
.adm-side-foot a,.adm-side-foot button{
  display:block;width:fit-content;
  font-size:.74rem;color:rgba(255,255,255,.45);
  background:none;border:none;text-align:left;
  cursor:pointer;font-family:var(--sans);padding:3px 0;
  transition:.15s;
}
.adm-side-foot a:hover,.adm-side-foot button:hover{color:rgba(255,255,255,.85)}

/* Main area — scrollable */
.adm-main{flex:1;min-width:0;padding:0 36px 60px;overflow-y:auto;height:100vh}
.adm-top{
  display:flex;justify-content:space-between;align-items:center;
  padding:24px 0;border-bottom:1px solid rgba(0,0,0,.07);
  margin-bottom:24px;position:sticky;top:0;
  background:#f3f1ec;z-index:15;
}

/* Mobile: narrow sidebar, no toggle needed */
.adm-sidebar-toggle{display:none}
.adm-side-overlay{display:none}

@media(max-width:700px){
  .adm-side{width:200px}
  .adm-nav-item{padding:11px 14px;font-size:.78rem}
  .adm-main{padding:0 14px 40px}
  .adm-top{padding:14px 0}
}
@media(max-width:520px){
  .adm-side{width:52px}
  .adm-brand{padding:16px 14px;font-size:0}
  .adm-brand span{display:none}
  .adm-nav-item{padding:12px 0;justify-content:center;gap:0;font-size:0;margin:0 4px;width:calc(100% - 8px);border-radius:6px;box-shadow:none}
  .adm-nav-item.active{background:rgba(200,169,110,.22);box-shadow:none}
  .adm-i{width:18px;font-size:1rem;margin:0;flex-shrink:0}
  .adm-side-foot a span,.adm-side-foot button span{display:none}
  .adm-side-foot{padding:12px 0;align-items:center}
}
.adm-top-title{font-family:var(--serif);font-size:1.6rem;color:var(--navy);font-weight:400}
.adm-top-actions{display:flex;gap:10px}
.adm-btn-primary{padding:10px 22px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;background:var(--navy);color:#fff;border:none;cursor:pointer;font-family:var(--sans);transition:.2s}
.adm-btn-primary:hover{background:var(--navy-lt)}
.adm-btn-ghost{padding:10px 18px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;background:var(--white);color:var(--navy);border:1px solid var(--sand);cursor:pointer;font-family:var(--sans);transition:.2s}
.adm-btn-ghost:hover{border-color:var(--gold);color:var(--gold-dk)}
.adm-btn-danger{padding:10px 18px;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;background:none;color:var(--red);border:1px solid var(--red);cursor:pointer;font-family:var(--sans)}
.adm-view{display:none}
.adm-view.active{display:block}
.adm-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:24px}
.adm-stat{background:var(--white);padding:18px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.adm-stat .as-num{font-family:var(--serif);font-size:1.6rem;color:var(--navy);font-weight:400}
.adm-stat .as-label{font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);margin-top:4px}
.adm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.adm-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.adm-card{background:var(--white);padding:22px;box-shadow:0 2px 8px rgba(0,0,0,.04);overflow:hidden}
.adm-card h3{font-family:var(--serif);font-size:1.1rem;color:var(--navy);font-weight:500;margin-bottom:14px}
.adm-help{font-size:.78rem;color:var(--gray);margin-bottom:14px}
.adm-chart{display:flex;align-items:flex-end;gap:8px;height:160px;padding-top:10px}
.adm-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%}
.adm-bar-fill{width:100%;background:linear-gradient(180deg,var(--gold-lt),var(--gold));min-height:2px;transition:height .4s;align-self:flex-end}
.adm-bar-lbl{font-size:.6rem;color:var(--gray);letter-spacing:.05em}
.adm-split{display:grid;grid-template-columns:80px 1fr 30px;align-items:center;gap:12px;padding:8px 0}
.adm-split-lbl{font-size:.85rem;color:var(--navy)}
.adm-split-bar{height:8px;background:var(--cream);position:relative}
.adm-split-bar div{height:100%;background:var(--gold)}
.adm-split-n{font-size:.85rem;color:var(--mid);text-align:right}
.adm-row{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;margin:0 -12px;border-bottom:1px solid var(--cream);cursor:pointer;font-size:.85rem;gap:12px;border-radius:6px;transition:background .15s}
.adm-row:hover{background:rgba(184,148,78,.06)}
.adm-row:last-child{border-bottom:none}
.adm-rowform{margin-bottom:10px;cursor:default}
.adm-mut{color:var(--gray);font-size:.78rem}
.adm-toolbar{display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:14px}
.adm-tabs{display:flex;flex-direction:column;gap:4px;min-width:160px}
.adm-tab{padding:10px 16px;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;color:var(--mid);border:1px solid var(--sand);background:var(--white);cursor:pointer;font-family:var(--sans);transition:.2s;text-align:left;border-left:3px solid transparent}
.adm-tab.active{background:rgba(184,148,78,.08);color:var(--navy);border-color:var(--sand);border-left-color:var(--gold);font-weight:600}
.adm-tab:hover:not(.active){background:rgba(0,0,0,.02);color:var(--navy)}
.adm-bk-layout{display:flex;gap:18px;align-items:flex-start}
.adm-bk-side{flex:0 0 160px}
.adm-bk-side .adm-tabs{width:100%}
.adm-bk-content{flex:1;min-width:0}
.adm-toolbar-r{display:flex;gap:8px}
.adm-toolbar-r input{padding:8px 12px;font-size:.8rem;border:1px solid var(--sand);background:var(--white);outline:none;font-family:var(--sans);min-width:240px}
.adm-toolbar-r input:focus{border-color:var(--gold)}
.adm-table-wrap{background:var(--white);box-shadow:0 2px 8px rgba(0,0,0,.04);overflow-x:auto}
.adm-table{width:100%;border-collapse:collapse}
.adm-table th{text-align:left;padding:14px 16px;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);background:var(--cream);font-weight:500;border-bottom:1px solid var(--sand)}
.adm-table td{padding:14px 16px;font-size:.82rem;color:var(--charcoal);border-bottom:1px solid var(--cream)}
.adm-table tr{cursor:pointer;transition:.15s}
.adm-table tr:hover td{background:rgba(247,244,238,.6)}
.adm-table code{background:var(--cream);padding:2px 6px;font-size:.7rem;color:var(--gold-dk)}
.adm-status{display:inline-block;font-size:.6rem;letter-spacing:.06em;padding:3px 10px;font-weight:600;text-transform:uppercase}
.adm-status.status-pending{background:rgba(243,156,18,.12);color:#f39c12}
.adm-status.status-pending_payment{background:rgba(155,89,182,.12);color:#9b59b6}
.adm-status.status-confirmed{background:rgba(39,174,96,.12);color:var(--green)}
.adm-status.status-cancelled{background:rgba(192,57,43,.12);color:var(--red)}
.adm-paid{display:inline-block;font-size:.55rem;letter-spacing:.1em;padding:2px 6px;background:var(--green);color:#fff;font-weight:700;margin-left:4px}
.adm-link{font-size:.7rem;font-weight:500;background:none;border:none;cursor:pointer;font-family:var(--sans);padding:0 6px}
.adm-link-ok{color:var(--green)}
.adm-link-bad{color:var(--red)}
.adm-empty{padding:40px;text-align:center;color:var(--gray);font-size:.85rem}

.adm-cal-header{display:flex;justify-content:center;align-items:center;gap:24px;margin-bottom:14px;padding:12px 0}
.adm-cal-header h3{font-family:var(--serif);font-size:1.3rem;color:var(--navy);min-width:180px;text-align:center}
.adm-cal-nav{min-width:90px}
.adm-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;background:var(--white);padding:14px;box-shadow:0 2px 8px rgba(0,0,0,.04)}
.adm-cal-h{text-align:center;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);padding:8px 0}
.adm-cal-d{aspect-ratio:1;padding:8px;display:flex;flex-direction:column;justify-content:space-between;border-radius:4px;font-size:.75rem;transition:.2s}
.adm-cal-day{font-weight:600;color:var(--navy)}
.adm-cal-info{font-size:.65rem;opacity:.7}
.adm-cal-d.leg-free{background:rgba(39,174,96,.08)}
.adm-cal-d.leg-some{background:rgba(243,156,18,.12)}
.adm-cal-d.leg-full{background:rgba(192,57,43,.12);color:var(--red)}
.adm-cal-d.leg-block{background:repeating-linear-gradient(45deg,var(--cream),var(--cream) 6px,#e6dfcf 6px,#e6dfcf 12px);color:var(--mid)}
.adm-cal-legend{display:flex;gap:18px;margin-top:14px;font-size:.78rem;color:var(--mid);flex-wrap:wrap}
.adm-cal-legend .leg{display:inline-block;width:14px;height:14px;margin-right:6px;vertical-align:middle;border-radius:2px}
.leg.leg-free{background:rgba(39,174,96,.4)}
.leg.leg-some{background:rgba(243,156,18,.5)}
.leg.leg-full{background:rgba(192,57,43,.5)}
.leg.leg-block{background:repeating-linear-gradient(45deg,var(--cream),var(--cream) 4px,#bbb 4px,#bbb 8px)}

.adm-form{display:grid;grid-template-columns:1fr 1fr 1fr 1fr auto;gap:12px;align-items:end}

.adm-toggle{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--charcoal);margin-bottom:10px;cursor:pointer}
.adm-toggle input{width:18px;height:18px;cursor:pointer}

.adm-modal{position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.5);display:flex;align-items:flex-start;justify-content:center;padding:40px 20px;opacity:0;visibility:hidden;transition:.3s;overflow-y:auto}
.adm-modal.open{opacity:1;visibility:visible}
.adm-modal-card{background:var(--white);max-width:640px;width:100%;padding:36px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.adm-modal-x{position:absolute;top:14px;right:18px;background:none;border:none;font-size:1.6rem;color:var(--gray);cursor:pointer;line-height:1}
.adm-modal-card h2{font-family:var(--serif);font-size:1.4rem;color:var(--navy);font-weight:500;margin-bottom:18px}
.dt-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.dt-grid > div{background:var(--cream);padding:10px 12px}
.dt-grid label{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);display:block;margin-bottom:3px}
.dt-grid > div > div{font-size:.85rem;color:var(--navy)}
.dt-box{background:rgba(184,148,78,.05);border-left:3px solid var(--gold);padding:12px 14px;margin-bottom:12px}
.dt-box label{font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-dk);display:block;margin-bottom:6px}
.dt-line{display:flex;justify-content:space-between;font-size:.82rem;padding:3px 0}
.dt-line.dt-total{font-family:var(--serif);font-size:1.1rem;color:var(--navy);border-top:1px solid var(--sand);margin-top:6px;padding-top:8px}
.dt-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;align-items:center}
.dt-actions a{display:inline-flex;align-items:center}

.adm-toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:12px 22px;font-size:.85rem;box-shadow:0 8px 24px rgba(0,0,0,.2);opacity:0;transform:translateY(20px);transition:.3s;z-index:10000}
.adm-toast.show{opacity:1;transform:none}

/* Sidebar toggle (mobile only, shown via media query) */
.adm-sidebar-toggle{display:none;position:fixed;top:12px;left:12px;z-index:300;background:var(--navy);color:#fff;border:none;cursor:pointer;padding:9px 13px;font-size:1.1rem;line-height:1;border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.adm-side-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:250}

@media(max-width:700px){
  .adm-stats{grid-template-columns:1fr 1fr}
  .adm-grid-2{grid-template-columns:1fr}
  .adm-grid-3,.adm-form{grid-template-columns:1fr}
  .dt-grid{grid-template-columns:1fr}
  .adm-bk-layout{flex-direction:column}
  .adm-bk-side{flex:none;width:100%}
  .adm-bk-side .adm-tabs{flex-direction:row;flex-wrap:wrap;gap:4px}
}

/* ═══ ADMIN — readability improvements for forms ═══ */
.adm .adm-card{margin-bottom:18px;padding:26px}
.adm .adm-card h3{font-size:1.2rem;color:var(--navy);font-weight:600;margin-bottom:6px;letter-spacing:.01em}
.adm .adm-card > h3 + .adm-help{margin-top:0;margin-bottom:18px;font-size:.82rem;color:var(--mid)}
.adm .wiz-label{color:var(--charcoal);font-size:.7rem;font-weight:600;letter-spacing:.08em;margin-bottom:6px;opacity:1}
.adm .wiz-input,.adm .wiz-select,.adm .wiz-textarea{
  background:#fff;
  border:1.5px solid #cfc8b8;
  border-radius:6px;
  color:var(--charcoal);
  font-size:.92rem;
  font-weight:500;
  padding:11px 14px;
  transition:border-color .2s,box-shadow .2s;
}
.adm .wiz-input:hover,.adm .wiz-select:hover{border-color:#a89a72}
.adm .wiz-input:focus,.adm .wiz-select:focus,.adm .wiz-textarea:focus{
  border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(184,148,78,.15);
  outline:none;
  border-radius:6px;
}
.adm .wiz-input::placeholder{color:#a8a496}
.adm-toggle{
  display:flex;
  align-items:center;
  gap:14px;
  padding:14px 16px;
  background:var(--cream);
  border:1.5px solid transparent;
  margin-bottom:10px;
  cursor:pointer;
  font-size:.92rem;
  color:var(--charcoal);
  font-weight:500;
  transition:.2s;
}
.adm-toggle:hover{border-color:var(--sand)}
.adm-toggle:has(input:checked){background:rgba(184,148,78,.08);border-color:var(--gold)}
.adm-toggle input{
  width:20px;
  height:20px;
  accent-color:var(--gold);
  cursor:pointer;
  flex-shrink:0;
}
.adm-help{font-size:.85rem;color:var(--mid);line-height:1.55;margin-bottom:14px}
.adm .adm-grid-3{gap:18px}
.adm .adm-grid-2{gap:18px}
.adm-card .adm-btn-primary{margin-top:18px}

/* Section heading on top of settings groups */
.adm-section-h{
  font-size:.65rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--gold-dk);
  font-weight:700;
  margin:8px 0 14px;
}

/* ═══ ROOMS PICKER ═══ */
.rooms-picker{display:flex;gap:32px;align-items:flex-start;padding:20px 0}
.rooms-picker-nav{flex:0 0 220px;display:flex;flex-direction:column;gap:0;position:sticky;top:90px}
.rpn-label{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gray);padding:0 0 12px;font-family:var(--sans);font-weight:600}
.rpn-item{display:flex;align-items:center;gap:12px;padding:12px;border:none;background:none;cursor:pointer;text-align:left;border-left:3px solid transparent;transition:.2s;width:100%}
.rpn-item:hover{background:rgba(184,148,78,.06)}
.rpn-item.active{border-left-color:var(--gold);background:rgba(184,148,78,.08)}
.rpn-thumb{width:60px;height:50px;flex-shrink:0;overflow:hidden}
.rpn-thumb img{width:100%;height:100%;object-fit:cover;transition:.3s}
.rpn-item:hover .rpn-thumb img{transform:scale(1.05)}
.rpn-type{font-size:.58rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-dk);font-family:var(--sans);font-weight:600}
.rpn-name{font-size:.9rem;color:var(--navy);font-family:var(--serif);font-weight:500;margin-top:2px}
.rooms-picker-detail{flex:1;min-width:0}
.rpd-pager{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px;border-bottom:1px solid var(--warm);padding-bottom:16px}
.rpd-pager-btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--navy);background:none;border:1px solid var(--sand);padding:10px 18px;cursor:pointer;transition:.25s}
.rpd-pager-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.rpd-pager-btn svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2}
.rpd-pager-dots{display:flex;gap:9px}
.rpd-pager-dot{width:9px;height:9px;border-radius:50%;background:var(--sand);border:none;padding:0;cursor:pointer;transition:.25s}
.rpd-pager-dot:hover{background:var(--gold-lt)}
.rpd-pager-dot.active{background:var(--gold);transform:scale(1.2)}
.rpd-room{display:none}
.rpd-room.active{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
.rpd-gallery{display:flex;flex-direction:column;gap:10px}
.rpd-main{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--warm)}
.rpd-main img{width:100%;height:100%;object-fit:cover;transition:.4s;cursor:zoom-in}
.rpd-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:rgba(12,29,58,.5);color:#fff;border:none;cursor:pointer;z-index:3;opacity:0;transition:.25s}
.rpd-main:hover .rpd-arrow{opacity:1}
.rpd-arrow:hover{background:var(--navy)}
.rpd-arrow.prev{left:10px}
.rpd-arrow.next{right:10px}
.rpd-arrow svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2}
.rpd-count{position:absolute;bottom:10px;right:10px;z-index:3;background:rgba(12,29,58,.6);color:#fff;font-family:var(--sans);font-size:.62rem;letter-spacing:.05em;padding:4px 10px;pointer-events:none}
.rpd-thumbs{display:flex;gap:8px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;scrollbar-width:thin}
.rpd-thumbs img{flex:0 0 78px;width:78px;height:58px;object-fit:cover;cursor:pointer;opacity:.55;transition:.2s;border:2px solid transparent}
.rpd-thumbs img:hover{opacity:.85}
.rpd-thumbs img.active{opacity:1;border-color:var(--gold)}
/* Room photo lightbox */
.rpd-lb{position:fixed;inset:0;z-index:11000;background:rgba(8,12,20,.93);display:none;align-items:center;justify-content:center}
.rpd-lb.open{display:flex}
.rpd-lb img{max-width:92vw;max-height:86vh;object-fit:contain;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.rpd-lb-close{position:absolute;top:18px;right:26px;background:none;border:none;color:#fff;font-size:2.2rem;line-height:1;cursor:pointer;opacity:.8;transition:.2s}
.rpd-lb-close:hover{opacity:1}
.rpd-lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;transition:.25s}
.rpd-lb-nav:hover{background:rgba(255,255,255,.2)}
.rpd-lb-nav.prev{left:18px}
.rpd-lb-nav.next{right:18px}
.rpd-lb-nav svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2}
@media(hover:none){.rpd-arrow{opacity:1}}
.rpd-info{padding-top:8px}
.rpd-title{font-family:var(--serif);font-size:2rem;color:var(--navy);font-weight:400;margin:6px 0 14px;line-height:1.15}
.rpd-desc{font-size:.88rem;color:var(--mid);line-height:1.7;margin-bottom:22px}
.rpd-features{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:28px}
.rpd-feat{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--charcoal)}
.rpd-feat-icon{font-size:1rem;width:20px;text-align:center}
.rpd-cta{display:inline-flex;align-items:center;gap:10px;background:var(--navy);color:#fff;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;padding:14px 28px;transition:.2s;font-family:var(--sans)}
.rpd-cta:hover{background:var(--gold-dk)}
.rpd-cta svg{width:18px;height:18px;transition:.2s}
.rpd-cta:hover svg{transform:translateX(4px)}
@media(max-width:960px){
  .rooms-picker{flex-direction:column}
  .rooms-picker-nav{flex:none;width:100%;flex-direction:row;flex-wrap:wrap;position:static;gap:8px}
  .rpn-label{display:none}
  .rpn-item{flex:1 1 140px;border-left:none;border-bottom:2px solid transparent;flex-direction:column;text-align:center;padding:8px}
  .rpn-item.active{border-bottom-color:var(--gold);border-left:none}
  .rpn-thumb{width:100%;height:60px}
  .rpd-room.active{grid-template-columns:1fr}
}

/* ═══ MOBILE REFINEMENTS ═══ */
@media(max-width:600px){
  /* Booking stepper: keep all 5 steps on one row on small phones */
  .wizard-steps{margin-bottom:28px}
  .wizard-step{gap:0}
  .wizard-step .ws-label{display:none}
  .wizard-step .ws-num{width:28px;height:28px;font-size:.66rem}
  .ws-line{width:auto;flex:1;min-width:10px;margin:0 6px}
  /* Room pager sits comfortably */
  .rpd-pager{flex-wrap:wrap;gap:12px}
  .rpd-pager-btn{padding:9px 14px;font-size:.56rem}
  /* Keep the language switch clear of thumbs/edges */
  .lang-switch{bottom:16px;right:16px}
  /* Dining menu tabs scroll horizontally instead of stacking tall */
  .menu-tabs{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:8px;gap:6px}
  .menu-tab{flex:0 0 auto;white-space:nowrap}
  /* Contact map a touch shorter on phones */
  .contact-map{height:260px}
}
@media(max-width:380px){
  .rpd-pager-btn span{display:none}
  .wizard-steps{gap:0}
}
