/* SKIP */
.skip-link{position:absolute;top:-100%;left:var(--space-4);padding:var(--space-3) var(--space-6);background:var(--color-accent);color:var(--color-text-on-accent);border-radius:var(--radius-md);font-weight:700;z-index:9999}
.skip-link:focus{top:var(--space-4)}

/* HEADER */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:var(--nav-height);background:rgba(20,18,16,.85);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-divider);transition:background var(--transition)}
.site-header.scrolled{background:rgba(20,18,16,.97)}
.site-header__inner{display:flex;align-items:center;gap:var(--space-6);height:100%}
.site-header__logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.site-header__logo img{height:48px;width:auto}
.site-header__logo-text{display:flex;flex-direction:column;line-height:1.1;font-family:var(--font-display);font-size:1.05rem;color:var(--color-text)}
.logo-line1{color:var(--color-accent)}.logo-line2{color:var(--color-text)}
.site-nav{margin-left:auto}
.site-nav__list{display:flex;gap:var(--space-6);list-style:none}
.site-nav__list a{font-size:var(--text-sm);font-weight:500;color:var(--color-text-muted);letter-spacing:.04em;transition:color var(--transition)}
.site-nav__list a:hover,
.site-nav__list .current-menu-item>a{color:var(--color-accent)}
.site-header__actions{display:flex;align-items:center;gap:var(--space-4);flex-shrink:0}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:var(--space-2);cursor:pointer}
.nav-toggle__bar{width:22px;height:1.5px;background:var(--color-text);border-radius:2px;transition:transform var(--transition),opacity var(--transition)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ── Language Switcher ── */
.lang-switcher {
  position: relative;
}
.lang-switcher__trigger {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text);
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  transition: color var(--transition);
}
.lang-switcher__trigger:hover { color: var(--color-accent); }
.lang-switcher__trigger svg {
  transition: transform var(--transition);
}
.lang-switcher.open .lang-switcher__trigger svg {
  transform: rotate(180deg);
}
.lang-switcher__list {
  position: absolute;
  top: calc(100% + var(--space-2));
  right: 0;
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: var(--space-1);
  list-style: none;
  margin: 0;
  min-width: 80px;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition), transform var(--transition);
  transform: translateY(-4px);
}
.lang-switcher.open .lang-switcher__list {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.lang-switcher__list a {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: color var(--transition), background var(--transition);
}
.lang-switcher__list a:hover {
  color: var(--color-text);
  background: var(--color-surface-offset);
}
.lang-switcher__trigger img,
.lang-switcher__list img {
  width: 16px;
  height: 12px;
  object-fit: cover;
  border-radius: 2px;
  flex-shrink: 0;
}


@media(max-width:768px){
  .site-nav{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100vw!important;height:100vh!important;height:100dvh!important;margin-left:0!important;background:var(--color-bg)!important;padding:calc(var(--nav-height) + var(--space-8)) var(--space-6) var(--space-8)!important;overflow-y:auto!important;transform:translateX(110%)!important;transition:transform .35s cubic-bezier(0.16,1,0.3,1)!important;z-index:999!important;display:flex!important;flex-direction:column!important;justify-content:flex-start!important}
  .site-nav.open{transform:translateX(0)!important}
  .nav-close{display:flex;align-items:center;justify-content:flex-end;color:var(--color-text-muted);margin-bottom:var(--space-8);align-self:flex-start;margin-left:-4px;transition:color var(--transition)}
  .nav-close:hover{color:var(--color-accent)}
  .site-nav__list{flex-direction:column;gap:var(--space-6)}
  .site-nav__list a{font-size:var(--text-lg)}
  .nav-toggle{display:flex}
}

@media(min-width:769px){
  .nav-close{display:none}
}

/* HERO */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1564501049412-61c2a3083791?w=1800&q=80') center/cover no-repeat}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,8,6,.88) 40%,rgba(30,20,12,.55))}
.hero__content{position:relative;z-index:1;padding-block:clamp(var(--space-20),12vw,var(--space-24))}
.hero__eyebrow{font-family:var(--font-body);font-size:var(--text-xs);font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-4)}
.hero__title{font-family:var(--font-display);font-size:var(--text-hero);font-weight:300;line-height:1.0;color:var(--color-text);margin-bottom:var(--space-6);max-width:12ch}
.hero__tagline{font-size:var(--text-lg);color:var(--color-text-muted);max-width:48ch;margin-bottom:var(--space-8);font-weight:300}
.hero__actions{display:flex;gap:var(--space-4);flex-wrap:wrap}
.hero__scroll-hint{position:absolute;bottom:var(--space-8);left:50%;transform:translateX(-50%);color:var(--color-text-faint);animation:bounce 2s ease-in-out infinite;transition:color var(--transition)}
.hero__scroll-hint:hover{color:var(--color-accent)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}

/* BOOKING BAR */
.booking-bar{background:var(--color-surface);border-bottom:1px solid var(--color-divider)}
.booking-bar__inner{padding-block:var(--space-5)}
.booking-bar__form{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:var(--space-4);align-items:end}
@media(max-width:640px){.booking-bar__form{grid-template-columns:1fr 1fr}.booking-bar__form button{grid-column:span 2}}

/* ROOMS GRID homepage */
.rooms-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}
@media(max-width:900px){.rooms-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.rooms-grid{grid-template-columns:1fr}}

/* POOL TEASER */
.pool-teaser{display:grid;grid-template-columns:1fr 1fr;min-height:560px}
.pool-teaser__media{overflow:hidden}
.pool-teaser__media img{width:100%;height:100%;object-fit:cover;transition:transform 6s ease}
.pool-teaser:hover .pool-teaser__media img{transform:scale(1.04)}
.pool-teaser__content{background:var(--color-surface);display:flex;flex-direction:column;justify-content:center;padding:clamp(var(--space-10),6vw,var(--space-20))}
.pool-teaser__content h2{font-size:var(--text-2xl);margin-bottom:var(--space-4)}
.pool-teaser__content p{color:var(--color-text-muted);max-width:42ch}
@media(max-width:768px){.pool-teaser{grid-template-columns:1fr}.pool-teaser__media{aspect-ratio:16/9}}

/* PAGE HERO */
.page-hero{background:var(--color-surface);border-bottom:1px solid var(--color-divider);padding-block:clamp(var(--space-16),8vw,var(--space-24));margin-top:var(--nav-height)}
.page-hero h1{font-size:var(--text-3xl);margin-bottom:var(--space-4)}
.page-hero p{color:var(--color-text-muted);max-width:55ch}

/* ROOMS PAGE */
.room-type-tabs{display:flex;gap:var(--space-3);margin-bottom:var(--space-10);flex-wrap:wrap}
.room-tab{font-family:var(--font-body);font-size:var(--text-sm);font-weight:600;letter-spacing:.06em;padding:var(--space-2) var(--space-5);border-radius:var(--radius-full);border:1.5px solid var(--color-border);color:var(--color-text-muted);background:transparent;cursor:pointer;transition:all var(--transition)}
.room-tab:hover{border-color:var(--color-accent);color:var(--color-accent)}
.room-tab.active{background:var(--color-accent);color:var(--color-text-on-accent);border-color:var(--color-accent)}
.rooms-list{display:flex;flex-direction:column;gap:var(--space-8)}
.room-card{display:grid;grid-template-columns:420px 1fr;border-radius:var(--radius-xl);overflow:hidden;background:var(--color-surface);border:1px solid var(--color-border);transition:box-shadow var(--transition)}
.room-card:hover{box-shadow:var(--shadow-md)}
.room-card__img{width:100%;height:100%;object-fit:cover;min-height:260px}
.room-card__content{padding:clamp(var(--space-8),4vw,var(--space-12));display:flex;flex-direction:column;justify-content:center;gap:var(--space-4)}
.room-card__title{font-size:var(--text-xl)}
.room-card__desc{color:var(--color-text-muted);font-size:var(--text-sm)}
.room-card.hidden{display:none}
@media(max-width:768px){.room-card{grid-template-columns:1fr}.room-card__img{min-height:220px;aspect-ratio:16/9}}

/* POOL PAGE */
.pool-hero{position:relative;overflow:hidden;height:70svh;min-height:400px;margin-top:var(--nav-height)}
.pool-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pool-hero__overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(10,8,6,.25),rgba(10,8,6,.78))}
.pool-hero__content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(var(--space-10),6vw,var(--space-16))}
.pool-hero__content h1{font-size:var(--text-3xl)}
.pool-gallery{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:var(--space-3);height:520px}
.pool-gallery__main{grid-row:span 2;object-fit:cover;width:100%;height:100%;border-radius:var(--radius-lg)}
.pool-gallery__sm{object-fit:cover;width:100%;height:100%;border-radius:var(--radius-lg)}
.amenities-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}
.amenity-card{text-align:center;padding:var(--space-6);background:var(--color-surface-2);border-radius:var(--radius-lg);border:1px solid var(--color-border)}
.amenity-card__icon{font-size:2rem;margin-bottom:var(--space-3)}
.amenity-card__title{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--space-2)}
@media(max-width:640px){.pool-gallery{grid-template-columns:1fr;height:auto}.pool-gallery__main,.pool-gallery__sm{aspect-ratio:16/9}.pool-gallery__sm:last-child{display:none}.amenities-grid{grid-template-columns:repeat(2,1fr)}}

/* RESERVATIONS */
.reservations-layout{display:grid;grid-template-columns:1fr 360px;gap:var(--space-10);padding-block:clamp(var(--space-12),6vw,var(--space-24))}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}
.form-grid .field--full{grid-column:span 2}
.booking-summary{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);position:sticky;top:calc(var(--nav-height) + var(--space-6));height:fit-content}
.booking-summary h3{font-family:var(--font-display);font-size:var(--text-lg);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--color-divider)}
.summary-row{display:flex;justify-content:space-between;font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-3)}
.summary-row.total{font-weight:700;color:var(--color-text);font-size:var(--text-base);border-top:1px solid var(--color-divider);padding-top:var(--space-4);margin-top:var(--space-2)}
.plugin-notice{background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);margin-bottom:var(--space-6);font-size:var(--text-sm);color:var(--color-text-muted)}
.plugin-notice strong{color:var(--color-accent)}
@media(max-width:900px){.reservations-layout{grid-template-columns:1fr}}
@media(max-width:640px){.form-grid{grid-template-columns:1fr}.form-grid .field--full{grid-column:span 1}}

/* CONTACT */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-12);padding-block:clamp(var(--space-12),6vw,var(--space-24))}
.contact-detail{display:flex;gap:var(--space-4);align-items:flex-start;margin-bottom:var(--space-6)}
.contact-detail__icon{font-size:1.3rem;flex-shrink:0;margin-top:.1em}
.contact-detail__label{font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-1)}
.contact-detail__value{font-size:var(--text-sm);color:var(--color-text-muted)}
.contact-detail__value a{color:var(--color-text-muted)}.contact-detail__value a:hover{color:var(--color-accent)}
.map-section{padding-block:clamp(var(--space-8),4vw,var(--space-16));background:var(--color-surface)}
.map-embed{border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--color-border)}
.map-embed iframe{width:100%;height:440px;border:0;display:block}
.contact-form-fields{display:flex;flex-direction:column;gap:var(--space-5)}
@media(max-width:768px){.contact-layout{grid-template-columns:1fr}}

/* FOOTER */
.site-footer{background:var(--color-surface);border-top:1px solid var(--color-divider)}
.site-footer__inner{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:var(--space-10);padding-block:clamp(var(--space-10),5vw,var(--space-16))}
.site-footer__logo-link{display:block;text-decoration:none;margin-bottom:var(--space-3)}
.site-footer__logo-link .logo-line1,.site-footer__logo-link .logo-line2{font-family:var(--font-display);font-size:1.4rem;display:block;line-height:1.1}
.site-footer__tagline{font-size:var(--text-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-faint);margin-bottom:var(--space-4)}
.site-footer__nav-list{list-style:none;display:flex;flex-direction:column;gap:var(--space-3)}
.site-footer__nav-list a{font-size:var(--text-sm);color:var(--color-text-muted);transition:color var(--transition)}
.site-footer__nav-list a:hover{color:var(--color-accent)}
.site-footer__section-title{font-size:var(--text-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-accent);margin-bottom:var(--space-4)}
.site-footer__address p{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:var(--space-2)}
.site-footer__address a{color:var(--color-text-muted)}.site-footer__address a:hover{color:var(--color-accent)}
.site-footer__bottom{border-top:1px solid var(--color-divider);padding-block:var(--space-5)}
.site-footer__bottom .container--wide{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-4)}
.site-footer__bottom ul{display:flex;gap:var(--space-4);list-style:none}
.site-footer__bottom a{color:var(--color-text-faint);font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;transition:color var(--transition)}
.site-footer__bottom a:hover{color:var(--color-accent)}
@media(max-width:768px){.site-footer__inner{grid-template-columns:1fr}.site-footer__bottom .container--wide{flex-direction:column;align-items:flex-start}}

/* WP HOTEL BOOKING OVERRIDES */
.mphb-checkout-form label,.mphb-search-form label{color:var(--color-text-muted)!important;font-size:var(--text-sm)!important}
.mphb-checkout-form input,.mphb-search-form input,.mphb-checkout-form select,.mphb-search-form select{background:var(--color-surface-2)!important;border:1px solid var(--color-border)!important;color:var(--color-text)!important;border-radius:var(--radius-md)!important;padding:var(--space-3) var(--space-4)!important}
.mphb-book-button,.mphb-check-form-submit,.mphb-submit-button{background:var(--color-accent)!important;color:var(--color-text-on-accent)!important;border-radius:var(--radius-sm)!important;border:none!important;font-weight:600!important;padding:var(--space-3) var(--space-6)!important;cursor:pointer!important}
