/* ============================================================
   CARMELINA — Luxury Hotel
   Inspired by demo.7iquid.com/carmelina
   Fonts: Forum (display) · Poppins (body)
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=Forum&family=Poppins:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&family=Jost:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,400;0,500;1,400&display=swap');

/* ---- Design Tokens ---- */
:root{
  /* Typography — matches demo */
  --font-display: 'Forum', Georgia, 'Times New Roman', serif;
  --font-sans:    'Poppins', system-ui, -apple-system, sans-serif;

  /* Palette — matches demo.7iquid.com/carmelina exactly */
  --bg:        #F8F6F2;
  --bg-alt:    #F0EBE3;
  --paper:     #FFFFFF;
  --ink:       #1A191D;          /* --default-color */
  --ink-soft:  #646464;          /* --body-color */
  --ink-faint: #9A968E;
  --line:      rgba(26,25,29,.12);
  --line-soft: rgba(26,25,29,.08);
  --accent:    #AA998A;          /* --second-color */
  --accent-deep:#8C7D6E;
  --dark:      #1C2C34;          /* --primary-color */
  --dark-2:    #142028;
  --on-dark:   #F0ECE6;
  --on-dark-soft: rgba(240,236,230,.62);

  --maxw:   1280px;
  --gutter: clamp(20px, 5vw, 64px);
  --sect:   clamp(72px, 11vh, 132px);

  /* Sharp corners — demo uses 0 or minimal */
  --radius:      2px;
  --radius-sm:   2px;
  --radius-lg:   4px;
  --radius-pill: 2px;

  --shadow:      0 24px 72px -20px rgba(28,44,52,.28), 0 6px 20px -8px rgba(28,44,52,.12);
  --shadow-soft: 0 12px 40px -14px rgba(28,44,52,.20);
  --shadow-card: 0 2px 18px -6px rgba(28,44,52,.10);
  --trans:       .42s cubic-bezier(.25,.8,.25,1);
}

/* ---- Reset ---- */
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-sans); font-weight:400;
  font-size:15px; line-height:1.625; letter-spacing:0px;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
h1,h2,h3,h4,h5{ margin:0; font-weight:400; }
p{ margin:0; }
ul{ margin:0; padding:0; list-style:none; }

/* ---- Display headings — Forum serif ---- */
.display{
  font-family:var(--font-display); font-weight:400;
  line-height:1.1; letter-spacing:0.01em;
}
h1.display{
  font-size:clamp(2.8rem, 6.5vw, 5.2rem);
  line-height:1.0; letter-spacing:0.02em;
}
h2.display{ font-size:clamp(2rem, 4.2vw, 3.6rem); line-height:1.08; }
h3.display{ font-size:clamp(1.45rem, 2.4vw, 2rem);  line-height:1.12; }
.italic{ font-style:italic; }
.fw-light{ font-weight:300; }

/* ---- Eyebrow / kicker ---- */
.eyebrow{
  font-family:var(--font-sans); font-weight:500;
  font-size:.68rem; text-transform:uppercase; letter-spacing:.32em;
  color:var(--accent-deep); display:inline-flex; align-items:center; gap:.9em;
}
.eyebrow::before{ content:""; width:30px; height:1px; background:currentColor; opacity:.55; }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:30px; height:1px; background:currentColor; opacity:.55; }
.eyebrow.no-rule::before{ display:none; }
.eyebrow.light{ color:var(--accent); }

/* ---- Layout helpers ---- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.wrap-wide{ max-width:1480px; margin:0 auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--sect); }
.lede{ font-size:1rem; color:var(--ink-soft); line-height:1.8; max-width:62ch; }
.measure{ max-width:60ch; }
.center{ text-align:center; }
.muted{ color:var(--ink-soft); }
.dark-section{ background:var(--dark); color:var(--on-dark); }
.dark-section .muted{ color:var(--on-dark-soft); }
.dark-section .eyebrow{ color:var(--accent); }

/* ---- Buttons — sharp, uppercase, Poppins ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.7em;
  font-family:var(--font-sans); font-weight:500;
  font-size:.72rem; text-transform:uppercase; letter-spacing:.22em;
  padding:1.1em 2.4em; border-radius:var(--radius); white-space:nowrap;
  border:1px solid transparent; background:var(--dark); color:#fff;
  transition:var(--trans); position:relative; overflow:hidden;
}
.btn:hover{ background:var(--accent); border-color:var(--accent); transform:translateY(-1px); box-shadow:0 8px 28px -8px rgba(170,153,138,.5); }
.btn--accent{ background:var(--accent); color:#fff; border-color:var(--accent); }
.btn--accent:hover{ background:var(--accent-deep); border-color:var(--accent-deep); box-shadow:0 8px 28px -8px rgba(140,125,110,.5); }
.btn--outline{ background:transparent; border-color:var(--ink); color:var(--ink); }
.btn--outline:hover{ background:var(--dark); color:#fff; border-color:var(--dark); }
.btn--ghost-light{ background:transparent; border-color:rgba(240,236,230,.45); color:var(--on-dark); }
.btn--ghost-light:hover{ background:rgba(240,236,230,.12); border-color:rgba(240,236,230,.7); }
.btn--block{ width:100%; }

/* text link with arrow */
.link-arrow{
  font-family:var(--font-sans); font-weight:500; font-size:.72rem;
  text-transform:uppercase; letter-spacing:.22em; color:var(--ink);
  display:inline-flex; align-items:center; gap:.8em; padding-bottom:.4em;
  border-bottom:1px solid var(--line); transition:var(--trans);
}
.link-arrow .ar{ transition:transform .4s; }
.link-arrow:hover{ color:var(--accent-deep); border-color:var(--accent); }
.link-arrow:hover .ar{ transform:translateX(6px); }
.dark-section .link-arrow{ color:var(--on-dark); border-color:rgba(240,236,230,.28); }
.dark-section .link-arrow:hover{ color:var(--accent); }

/* ============================================================
   HEADER
   ============================================================ */
.topbar{
  background:var(--dark); color:var(--on-dark-soft);
  font-size:.68rem; letter-spacing:.12em;
  border-bottom:1px solid rgba(240,236,230,.07);
}
.topbar .wrap-wide{ display:flex; align-items:center; justify-content:space-between; height:42px; }
.topbar a{ color:var(--on-dark-soft); transition:.3s; }
.topbar a:hover{ color:var(--accent); }
.topbar .tb-group{ display:flex; align-items:center; gap:1.6em; }
.topbar .tb-sep{ opacity:.3; }
.topbar .tb-lang{ display:flex; gap:.7em; align-items:center; text-transform:uppercase; }
.topbar .tb-lang .cur{ color:var(--accent); }

.site-header{
  position:sticky; top:0; z-index:60;
  background:var(--paper); border-bottom:1px solid var(--line-soft);
  /* Only transition shadow/border — NOT background, to keep full-or-none behaviour */
  transition:box-shadow .3s, border-color .3s;
}

/* Transparent mode: header is fixed, NO background at all */
.site-header.is-transparent{
  position:fixed; left:0; right:0;
  background:transparent;
  border-color:transparent;
}
.site-header.is-transparent .nav-link,
.site-header.is-transparent .nav-icon{ color:var(--on-dark); }
.site-header.is-transparent .brand-mark{ color:var(--on-dark); }
.site-header.is-transparent .brand-sub{ color:var(--accent); }
.site-header.is-transparent .nav-burger span{ background:var(--on-dark); }

/* Scrolled: instantly switch to FULL solid background — no partial states */
.site-header.is-transparent.scrolled{
  background:var(--paper);          /* full, 100% opaque */
  box-shadow:0 2px 24px -8px rgba(28,44,52,.18);
  border-color:var(--line-soft);
}
.site-header.is-transparent.scrolled .nav-link,
.site-header.is-transparent.scrolled .nav-icon{ color:var(--ink); }
.site-header.is-transparent.scrolled .brand-mark{ color:var(--ink); }
.site-header.is-transparent.scrolled .brand-sub{ color:var(--accent-deep); }
.site-header.is-transparent.scrolled .nav-burger span{ background:var(--ink); }

.nav{ display:flex; align-items:center; justify-content:space-between; height:84px; gap:2rem; }
.brand{ display:flex; align-items:center; gap:.7em; flex-shrink:0; }
.brand-mark{
  font-family:var(--font-display); font-size:1.75rem;
  letter-spacing:.08em; color:var(--ink);
}
.brand-sub{ font-size:.55rem; letter-spacing:.45em; text-transform:uppercase; color:var(--accent-deep); display:block; margin-top:-.2em; }

.nav-links{ display:flex; align-items:center; gap:2.2rem; }
.nav-link{
  font-family:var(--font-sans); font-size:.72rem; font-weight:500;
  text-transform:uppercase; letter-spacing:.18em;
  color:var(--ink); position:relative; padding:.4em 0; transition:color .3s; white-space:nowrap;
}
.nav-link::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0;
  background:var(--accent); transition:width .4s;
}
.nav-link:hover::after,.nav-link.active::after{ width:100%; }
.nav-link:hover{ color:var(--accent-deep); }
.site-header.is-transparent:not(.scrolled) .nav-link:hover{ color:var(--accent); }

.nav-right{ display:flex; align-items:center; gap:1.4rem; flex-shrink:0; }
.nav-icon{ color:var(--ink); display:inline-flex; transition:color .3s, transform .3s; }
.nav-icon:hover{ color:var(--accent); transform:translateY(-1px); }
.nav-burger{ display:none; flex-direction:column; gap:5px; width:26px; background:none; border:none; padding:0; }
.nav-burger span{ height:1.5px; background:currentColor; color:var(--ink); transition:.3s; }
.site-header.is-transparent:not(.scrolled) .nav-burger span{ background:var(--on-dark); }

/* mobile drawer */
.drawer{ position:fixed; inset:0; z-index:120; pointer-events:none; visibility:hidden; }
.drawer.open{ pointer-events:auto; visibility:visible; }
.drawer-scrim{ position:absolute; inset:0; background:rgba(15,13,9,.6); opacity:0; transition:.4s; }
.drawer.open .drawer-scrim{ opacity:1; }
.drawer-panel{
  position:absolute; top:0; right:0; height:100%; width:min(86vw,380px);
  background:var(--dark); color:var(--on-dark); padding:2.2rem 2rem;
  transform:translateX(100%); transition:transform .5s cubic-bezier(.25,.8,.25,1);
  display:flex; flex-direction:column; gap:.4rem; overflow-y:auto;
}
.drawer.open .drawer-panel{ transform:translateX(0); }
.drawer-panel a{
  font-family:var(--font-display); font-size:1.6rem;
  padding:.5rem 0; border-bottom:1px solid rgba(240,236,230,.1);
  color:var(--on-dark); transition:color .3s, padding-left .3s;
}
.drawer-panel a:hover{ color:var(--accent); padding-left:.5rem; }
.drawer-close{ align-self:flex-end; background:none; border:none; color:var(--on-dark); font-size:1.6rem; margin-bottom:1rem; transition:color .3s; }
.drawer-close:hover{ color:var(--accent); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:var(--dark); color:var(--on-dark-soft); padding-top:var(--sect); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:3rem; padding-bottom:3.5rem; }
.footer-brand .brand-mark{ color:var(--on-dark); font-size:2rem; }
.footer-col h4{ font-family:var(--font-sans); font-size:.68rem; text-transform:uppercase; letter-spacing:.28em; color:var(--on-dark); margin-bottom:1.4rem; }
.footer-col a,.footer-col li{ color:var(--on-dark-soft); font-size:.92rem; line-height:1.5; }
.footer-col ul{ display:flex; flex-direction:column; gap:.7rem; }
.footer-col a:hover{ color:var(--accent); }
.footer-pay{ display:flex; gap:.9rem; align-items:center; margin-top:1.2rem; flex-wrap:wrap; }
.footer-pay img{ height:24px; opacity:.6; filter:brightness(0) invert(1); transition:opacity .3s; }
.footer-pay img:hover{ opacity:1; }
.footer-social{ display:flex; gap:.8rem; margin-top:1.5rem; }
.footer-social a{ width:38px; height:38px; border:1px solid rgba(240,236,230,.18); border-radius:50%; display:grid; place-items:center; transition:var(--trans); }
.footer-social a:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }
.footer-bottom{ border-top:1px solid rgba(240,236,230,.1); padding-block:1.6rem; display:flex; align-items:center; justify-content:space-between; gap:1rem; font-size:.76rem; letter-spacing:.05em; flex-wrap:wrap; }
.footer-bottom a:hover{ color:var(--accent); }

/* ============================================================
   PAGE HERO BANNER (interior pages)
   ============================================================ */
.page-hero{ position:relative; min-height:58vh; display:flex; align-items:flex-end; color:var(--on-dark); overflow:hidden; }
.page-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(175deg, rgba(3,7,9,.35) 0%, rgba(3,7,9,.15) 35%, rgba(3,7,9,.78) 100%); }
.page-hero img.bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.page-hero .wrap{ position:relative; z-index:2; padding-bottom:clamp(40px,7vh,90px); padding-top:130px; }
.page-hero h1{ color:#fff; }
.breadcrumb{ font-size:.7rem; text-transform:uppercase; letter-spacing:.2em; color:var(--on-dark-soft); display:flex; gap:.7em; margin-top:1.2rem; align-items:center; }
.breadcrumb a:hover{ color:var(--accent); }
.breadcrumb .sep{ opacity:.4; }

/* ============================================================
   AMENITY / CTA FEATURE BAND
   ============================================================ */
.amen-feature{ position:relative; overflow:hidden; min-height:520px; display:flex; align-items:center; color:var(--on-dark); }
.amen-feature img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.amen-feature::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg,rgba(3,7,9,.86) 0%,rgba(3,7,9,.22) 100%); }
.amen-feature .wrap{ position:relative; z-index:2; }

/* ============================================================
   BOOKING BAR
   ============================================================ */
.booking-bar{
  background:var(--paper); box-shadow:var(--shadow); border:1px solid var(--line-soft);
  display:grid; grid-template-columns:repeat(4,1fr) auto; align-items:stretch;
}
.booking-field{ padding:1.3rem 1.6rem; border-right:1px solid var(--line-soft); display:flex; flex-direction:column; gap:.35rem; transition:background .3s; }
.booking-field:hover{ background:rgba(170,153,138,.05); }
.booking-field label{ font-size:.62rem; text-transform:uppercase; letter-spacing:.22em; color:var(--ink-faint); font-weight:500; font-family:var(--font-sans); }
.booking-field input,.booking-field select{
  border:none; background:transparent; font-family:var(--font-display); font-size:1.25rem; color:var(--ink);
  padding:0; width:100%; outline:none; -webkit-appearance:none; appearance:none;
}
.booking-field select{ cursor:pointer; }
.booking-submit{
  border:none; background:var(--accent); color:#fff;
  font-family:var(--font-sans); font-weight:500;
  font-size:.7rem; text-transform:uppercase; letter-spacing:.2em;
  padding-inline:2.4rem; transition:var(--trans);
}
.booking-submit:hover{ background:var(--accent-deep); }

/* ============================================================
   ROOM CARD
   ============================================================ */
.room-card{
  background:var(--paper); border:1px solid var(--line-soft);
  display:flex; flex-direction:column; transition:var(--trans);
  box-shadow:var(--shadow-card);
}
.room-card:hover{ box-shadow:var(--shadow-soft); transform:translateY(-4px); }
.room-card .media{ position:relative; overflow:hidden; aspect-ratio:906/628; }
.room-card .media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.2s cubic-bezier(.25,.8,.25,1); }
.room-card:hover .media img{ transform:scale(1.07); }
.room-card .price-tag{
  position:absolute; top:0; left:0;
  background:var(--accent); color:#fff;
  font-size:.68rem; letter-spacing:.1em; text-transform:uppercase;
  padding:.65em 1.1em;
}
.room-card .body{ padding:1.8rem; display:flex; flex-direction:column; gap:1rem; flex:1; }
.room-card .body h3{ font-size:1.7rem; }
.room-meta{ display:flex; flex-wrap:wrap; gap:.5rem 1.3rem; font-size:.78rem; letter-spacing:.04em; color:var(--ink-soft); }
.room-meta span{ display:inline-flex; align-items:center; gap:.45em; }
.room-meta .ic{ color:var(--accent-deep); }
.room-card .desc{ font-size:.92rem; color:var(--ink-soft); line-height:1.65; }
.room-card .foot{ margin-top:auto; padding-top:1rem; border-top:1px solid var(--line-soft); display:flex; align-items:center; justify-content:space-between; }

/* ============================================================
   EXPERIENCE / FEATURE CARDS
   ============================================================ */
.exp-card{
  position:relative; overflow:hidden; min-height:460px;
  display:flex; align-items:flex-end; color:var(--on-dark);
}
.exp-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 1.2s cubic-bezier(.25,.8,.25,1); }
.exp-card::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(3,7,9,0) 25%, rgba(3,7,9,.88) 100%);
  transition:opacity .5s;
}
.exp-card:hover img{ transform:scale(1.07); }
.exp-card .exp-body{ position:relative; z-index:2; padding:2.4rem; }
.exp-card .exp-body h3{ color:#fff; margin-bottom:.6rem; }
.exp-card .exp-body p{ color:var(--on-dark-soft); font-size:.92rem; max-height:0; opacity:0; overflow:hidden; transition:.5s cubic-bezier(.25,.8,.25,1); }
.exp-card:hover .exp-body p{ max-height:120px; opacity:1; margin-bottom:1rem; }

/* stat counters */
.stat{ text-align:center; }
.stat .num{ font-family:var(--font-display); font-size:clamp(3rem,5vw,4.4rem); line-height:1; color:var(--accent-deep); }
.stat .lbl{ font-size:.92rem; color:var(--ink-soft); margin-top:.6rem; max-width:24ch; margin-inline:auto; }

/* offer / event card */
.offer-card{
  background:var(--paper); border:1px solid var(--line-soft);
  overflow:hidden; transition:var(--trans); box-shadow:var(--shadow-card);
}
.offer-card:hover{ box-shadow:var(--shadow-soft); transform:translateY(-4px); }
.offer-card .media{ aspect-ratio:555/470; overflow:hidden; }
.offer-card .media img{ width:100%; height:100%; object-fit:cover; transition:transform 1.1s cubic-bezier(.25,.8,.25,1); }
.offer-card:hover .media img{ transform:scale(1.05); }
.offer-card .body{ padding:1.8rem; }
.offer-date{ font-size:.68rem; text-transform:uppercase; letter-spacing:.2em; color:var(--accent-deep); margin-bottom:.7rem; }
.offer-card h3{ font-size:1.5rem; line-height:1.2; margin-bottom:.7rem; }
.offer-card h3 a:hover{ color:var(--accent-deep); }

/* testimonial */
.quote-card{
  background:var(--paper); border:1px solid var(--line-soft);
  padding:2.4rem; display:flex; flex-direction:column; gap:1.2rem;
  box-shadow:var(--shadow-card); transition:var(--trans);
}
.quote-card:hover{ box-shadow:var(--shadow-soft); transform:translateY(-3px); }
.quote-card .stars{ color:var(--accent); letter-spacing:.2em; font-size:1rem; }
.quote-card h4{ font-family:var(--font-display); font-size:1.5rem; line-height:1.18; }
.quote-card p{ color:var(--ink-soft); font-size:.94rem; line-height:1.72; }
.quote-card .who{ font-size:.74rem; text-transform:uppercase; letter-spacing:.16em; color:var(--ink-faint); margin-top:auto; }

/* newsletter */
.news-field{
  display:flex; border-bottom:1px solid rgba(240,236,230,.35); max-width:480px;
}
.dark-section .news-field{ border-color:rgba(240,236,230,.3); }
.news-field input{
  flex:1; background:transparent; border:none; outline:none;
  padding:1em 0; font-family:var(--font-sans); font-size:.95rem; color:inherit;
}
.news-field button{
  background:none; border:none; color:var(--accent);
  font-size:.7rem; text-transform:uppercase; letter-spacing:.2em; font-weight:600;
  transition:.3s;
}
.news-field button:hover{ color:var(--accent-deep); }

/* generic grids */
.grid{ display:grid; gap:clamp(20px,2.6vw,38px); }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }

.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(32px,5vw,80px); align-items:center; }

/* ---- Auth modal ---- */
.auth-modal{ position:fixed; inset:0; z-index:140; display:grid; place-items:center; padding:24px; pointer-events:none; visibility:hidden; }
.auth-modal.open{ pointer-events:auto; visibility:visible; }
.auth-scrim{ position:absolute; inset:0; background:rgba(28,44,52,.55); opacity:0; transition:.35s; }
.auth-modal.open .auth-scrim{ opacity:1; }
.auth-card{
  position:relative; background:var(--paper); width:min(440px,100%);
  padding:2.6rem 2.4rem; box-shadow:var(--shadow);
  transform:translateY(16px) scale(.98); opacity:0;
  transition:.42s cubic-bezier(.25,.8,.25,1); max-height:90vh; overflow:auto;
}
.auth-modal.open .auth-card{ transform:none; opacity:1; }
.auth-x{ position:absolute; top:1rem; right:1.2rem; background:none; border:none; font-size:1.7rem; line-height:1; color:var(--ink-faint); }
.auth-x:hover{ color:var(--ink); }
.fld{ display:block; margin-bottom:1rem; }
.fld span{ display:block; font-size:.64rem; text-transform:uppercase; letter-spacing:.2em; color:var(--ink-faint); margin-bottom:.45rem; font-weight:500; }
.fld input{
  width:100%; border:1px solid var(--line); background:var(--bg);
  padding:.88em 1em; font-family:var(--font-sans); font-size:.95rem; color:var(--ink);
  outline:none; transition:.3s;
}
.fld input:focus{ border-color:var(--accent); background:var(--paper); }
.auth-row{ display:flex; align-items:center; justify-content:space-between; margin:.3rem 0 1.2rem; }
.chk{ font-size:.85rem; color:var(--ink-soft); display:flex; align-items:center; gap:.5em; }
.auth-switch{ text-align:center; font-size:.88rem; color:var(--ink-soft); margin-top:1.4rem; }
.auth-switch a{ color:var(--accent-deep); border-bottom:1px solid var(--accent); }

/* ---- Tweaks panel ---- */
.twkp{ position:fixed; right:16px; bottom:16px; z-index:2147483646; width:264px; max-height:calc(100vh - 32px);
  display:none; flex-direction:column; background:rgba(250,248,245,.88); color:#29261b;
  -webkit-backdrop-filter:blur(22px) saturate(160%); backdrop-filter:blur(22px) saturate(160%);
  border:.5px solid rgba(255,255,255,.6); border-radius:12px; box-shadow:0 1px 0 rgba(255,255,255,.5) inset,0 12px 40px rgba(28,44,52,.18);
  font-family:var(--font-sans),system-ui,sans-serif; overflow:hidden; }
.twkp.open{ display:flex; }
.twkp-hd{ display:flex; align-items:center; justify-content:space-between; padding:11px 10px 11px 15px; }
.twkp-hd b{ font-size:12px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; }
.twkp-x{ border:0; background:transparent; color:rgba(41,38,27,.5); width:24px; height:24px; border-radius:6px; font-size:15px; }
.twkp-x:hover{ background:rgba(0,0,0,.06); color:#29261b; }
.twkp-body{ padding:2px 15px 16px; display:flex; flex-direction:column; gap:8px; overflow-y:auto; }
.twkp-sect{ font-size:9.5px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(41,38,27,.42); padding-top:8px; }
.twkp-pal{ display:flex; flex-direction:column; gap:5px; }
.twkp-palbtn{ display:flex; align-items:center; gap:9px; padding:6px 8px; border:.5px solid rgba(0,0,0,.1); border-radius:8px; background:rgba(255,255,255,.5); color:inherit; font:inherit; font-size:11.5px; font-weight:500; text-align:left; transition:.2s; }
.twkp-palbtn:hover{ background:rgba(255,255,255,.85); }
.twkp-palbtn.on{ border-color:#29261b; box-shadow:0 0 0 1px #29261b; }
.tw-sw{ width:22px; height:22px; border-radius:50%; flex-shrink:0; }
.twkp-seg{ display:flex; padding:2px; border-radius:8px; background:rgba(0,0,0,.06); gap:2px; }
.twkp-seg button{ flex:1; border:0; background:transparent; color:rgba(41,38,27,.7); font:inherit; font-size:11px; font-weight:500; min-height:24px; border-radius:6px; padding:3px 4px; transition:.15s; }
.twkp-seg button.on{ background:rgba(255,255,255,.92); color:#29261b; box-shadow:0 1px 2px rgba(0,0,0,.12); }

/* reveal animation */
[data-reveal]{ opacity:0; transform:translateY(28px); transition:opacity .9s cubic-bezier(.25,.8,.25,1), transform .9s cubic-bezier(.25,.8,.25,1); }
[data-reveal].in{ opacity:1; transform:none; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .hide-sm-btn{ display:none; }
}
@media (max-width:1080px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:2.4rem 2rem; }
  .g-4{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:900px){
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .booking-bar{ grid-template-columns:1fr 1fr; }
  .booking-submit{ grid-column:1/-1; padding-block:1.2rem; }
  .booking-field:nth-child(2){ border-right:none; }
  .split{ grid-template-columns:1fr; }
  .g-3{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  body{ font-size:14px; }
  .topbar .tb-group.hide-sm{ display:none; }
  .g-2{ grid-template-columns:1fr; }
  .booking-bar{ grid-template-columns:1fr; }
  .booking-field{ border-right:none; border-bottom:1px solid var(--line-soft); }
  .booking-field:last-of-type{ border-bottom:none; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .page-hero .wrap{ padding-top:120px; }
}
@media (max-width:480px){
  .nav{ gap:1rem; height:72px; }
  .brand-mark{ font-size:1.45rem; }
  .nav-right{ gap:.85rem; }
  .btn{ padding:1em 1.8em; letter-spacing:.16em; }
  .page-hero{ min-height:52vh; }
  .breadcrumb{ flex-wrap:wrap; }
}

/* ---- Overflow safety: keep long words / emails / URLs from breaking layout ---- */
.lede, .muted, p, .info-cell .iv, .footer-col a, .footer-col li, .topbar a, .breadcrumb{
  overflow-wrap:break-word; word-break:break-word;
}
.display, h1, h2, h3, h4, h5{ overflow-wrap:break-word; }

/* ============================================================
   LANGUAGE SWITCH (EN / SW)
   ============================================================ */
.lang-switch{ display:inline-flex; align-items:center; gap:.25em; font-size:.72rem; letter-spacing:.12em; font-weight:600; }
.lang-switch button{ background:none; border:none; color:inherit; font:inherit; letter-spacing:inherit; cursor:pointer; opacity:.55; padding:.2em .15em; transition:opacity .25s,color .25s; }
.lang-switch button:hover{ opacity:.9; }
.lang-switch button.on{ opacity:1; color:var(--accent); }
.lang-switch .sep{ opacity:.35; }
.nav-right .lang-switch{ margin-right:.2rem; }
.drawer-lang{ margin-top:1.6rem; font-size:.95rem; letter-spacing:.16em; }
@media (max-width:560px){ .nav-right .lang-switch{ display:none; } }
