/* =============================================================
   GRAND ROTANA — "The Red Sea, Rendered"
   Master design system. Cinematic Red-Sea luxury, editorial.
   Author: built for Mahmoud's redesign pitch.
   ============================================================= */

/* ---------- 1. FONTS (self-hosted) ---------- */
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:400;font-display:swap;src:url('../assets/fonts/cormorant-garamond-400.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:400;font-display:swap;src:url('../assets/fonts/cormorant-garamond-400-italic.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:500;font-display:swap;src:url('../assets/fonts/cormorant-garamond-500.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('../assets/fonts/cormorant-garamond-600.woff2') format('woff2');}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:700;font-display:swap;src:url('../assets/fonts/cormorant-garamond-700.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:300;font-display:swap;src:url('../assets/fonts/jost-300.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:400;font-display:swap;src:url('../assets/fonts/jost-400.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:500;font-display:swap;src:url('../assets/fonts/jost-500.woff2') format('woff2');}
@font-face{font-family:'Jost';font-style:normal;font-weight:600;font-display:swap;src:url('../assets/fonts/jost-600.woff2') format('woff2');}

/* ---------- 2. DESIGN TOKENS ---------- */
:root{
  /* Red Sea palette */
  --abyss:#06222A;        /* deepest sea — primary dark canvas */
  --deep:#0B323C;         /* deep teal */
  --sea:#16515E;          /* mid teal */
  --sea-glow:#2C7A86;     /* lit water */
  --gold:#C9A24B;         /* primary gold */
  --gold-soft:#E4CB8E;    /* light gold highlight */
  --gold-deep:#9A7A33;    /* engraved gold */
  --sand:#E8DCC6;         /* sand */
  --cream:#F7F2E8;        /* cream — light sections */
  --ivory:#FCFAF4;        /* lightest */
  --ink:#10201F;          /* near-black text on light */
  --ink-soft:#4B5853;     /* muted text */
  --ink-faint:#8A938E;
  --line-gold:rgba(201,162,75,.30);
  --line-dark:rgba(255,255,255,.12);
  --line-light:rgba(16,32,31,.12);
  --coral:#CF6A47;        /* rare living-coral accent */

  /* typography */
  --font-display:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --font-body:'Jost', system-ui, -apple-system, sans-serif;

  /* fluid type scale */
  --fs-hero:clamp(3.4rem, 9vw, 9.5rem);
  --fs-h1:clamp(2.6rem, 6vw, 5.5rem);
  --fs-h2:clamp(2rem, 4.2vw, 3.6rem);
  --fs-h3:clamp(1.5rem, 2.6vw, 2.2rem);
  --fs-lead:clamp(1.1rem, 1.5vw, 1.4rem);
  --fs-body:clamp(1rem, 1.1vw, 1.075rem);
  --fs-eyebrow:.78rem;

  /* spacing & rhythm */
  --pad-x:clamp(1.4rem, 6vw, 8rem);
  --section-y:clamp(5rem, 11vw, 11rem);
  --maxw:1480px;

  /* motion */
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);
  --dur:.8s;

  --radius:2px;
  --shadow-soft:0 24px 60px -28px rgba(6,34,42,.55);
  --shadow-deep:0 40px 90px -40px rgba(6,34,42,.7);
}

/* ---------- 3. RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}*{animation-duration:.001ms!important;transition-duration:.001ms!important}}
body{
  font-family:var(--font-body);
  font-weight:400;
  font-size:var(--fs-body);
  line-height:1.7;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--gold);color:var(--abyss)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* ---------- 4. TYPOGRAPHY ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.04;letter-spacing:-.01em}
.display{font-size:var(--fs-hero);font-weight:500;line-height:.95}
h1,.h1{font-size:var(--fs-h1)}
h2,.h2{font-size:var(--fs-h2)}
h3,.h3{font-size:var(--fs-h3);font-weight:600}
.serif-italic{font-family:var(--font-display);font-style:italic;font-weight:400}
.lead{font-size:var(--fs-lead);line-height:1.6;color:var(--ink-soft);font-weight:300;max-width:60ch}

/* eyebrow / label */
.eyebrow{
  font-family:var(--font-body);
  font-size:var(--fs-eyebrow);
  font-weight:500;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:.9rem;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold);display:inline-block}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold);display:inline-block}

/* big engraved section index */
.section-index{
  font-family:var(--font-display);
  font-size:clamp(4rem,11vw,9rem);
  line-height:1;
  font-weight:500;
  color:transparent;
  -webkit-text-stroke:1px var(--line-gold);
  opacity:.7;
}

/* gold animated underline link */
.ulink{position:relative;display:inline-block;font-weight:500;letter-spacing:.04em}
.ulink::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.ulink:hover::after{transform:scaleX(1);transform-origin:left}

/* ---------- 5. LAYOUT ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
.section{padding-block:var(--section-y);position:relative}
.grid{display:grid;gap:clamp(1.5rem,3vw,3rem)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}.cols-3.keep-2,.cols-4.keep-2{grid-template-columns:1fr 1fr}}

/* theme sections */
.bg-dark{background:var(--abyss);color:var(--sand)}
.bg-dark h1,.bg-dark h2,.bg-dark h3{color:var(--ivory)}
.bg-dark .lead{color:rgba(232,220,198,.78)}
.bg-deep{background:linear-gradient(165deg,var(--abyss),var(--deep) 70%);color:var(--sand)}
.bg-deep h1,.bg-deep h2,.bg-deep h3{color:var(--ivory)}
.bg-cream{background:var(--cream);color:var(--ink)}
.bg-sand{background:var(--sand);color:var(--ink)}

/* ---------- 6. BUTTONS ---------- */
.btn{
  --bg:var(--gold);--fg:var(--abyss);
  display:inline-flex;align-items:center;gap:.7rem;
  font-family:var(--font-body);font-weight:500;font-size:.82rem;
  letter-spacing:.16em;text-transform:uppercase;
  padding:1.05rem 2.2rem;background:var(--bg);color:var(--fg);
  border-radius:var(--radius);position:relative;overflow:hidden;
  transition:color .5s var(--ease),transform .4s var(--ease);
  border:1px solid var(--bg);
}
.btn span{position:relative;z-index:2}
.btn::before{content:"";position:absolute;inset:0;background:var(--abyss);transform:translateY(101%);transition:transform .5s var(--ease);z-index:1}
.btn:hover{color:var(--gold-soft)}
.btn:hover::before{transform:translateY(0)}
.btn-ghost{--bg:transparent;--fg:currentColor;border:1px solid var(--line-gold);color:inherit}
.btn-ghost::before{background:var(--gold)}
.btn-ghost:hover{color:var(--abyss)}
.btn-arrow::after{content:"→";font-size:1.05em;transition:transform .4s var(--ease)}
.btn-arrow:hover::after{transform:translateX(5px)}

/* ---------- 7. HEADER / NAV ---------- */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem var(--pad-x);
  transition:background .5s var(--ease),padding .5s var(--ease),box-shadow .5s var(--ease);
  color:var(--ivory);
}
.nav.solid{background:rgba(6,34,42,.92);backdrop-filter:blur(14px);padding-block:1rem;box-shadow:0 1px 0 var(--line-dark)}
.nav__logo{display:flex;align-items:center;gap:.7rem;font-family:var(--font-display);font-size:1.5rem;font-weight:600;letter-spacing:.02em;line-height:1}
.nav__logo b{color:var(--gold);font-weight:600}
.nav__logo small{display:block;font-family:var(--font-body);font-size:.56rem;letter-spacing:.36em;text-transform:uppercase;color:var(--gold-soft);font-weight:500;margin-top:.25rem}
.nav__links{display:flex;align-items:center;gap:clamp(1rem,2vw,2.1rem)}
.nav__links a{font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;font-weight:400;color:rgba(252,250,244,.82);transition:color .35s}
.nav__links a:hover,.nav__links a.active{color:var(--gold)}
.nav__right{display:flex;align-items:center;gap:1.4rem}
.nav__lang{font-size:.78rem;letter-spacing:.12em;color:rgba(252,250,244,.7);border:1px solid var(--line-dark);padding:.4rem .7rem;border-radius:2px;transition:.35s}
.nav__lang:hover{color:var(--gold);border-color:var(--line-gold)}
.nav__book{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;font-weight:500;color:var(--abyss);background:var(--gold);padding:.75rem 1.5rem;border-radius:2px;transition:.4s}
.nav__book:hover{background:var(--gold-soft)}
.nav__burger{display:none;flex-direction:column;gap:5px;width:30px;padding:6px 0;z-index:120}
.nav__burger span{height:1.5px;width:100%;background:currentColor;transition:.4s var(--ease)}
.nav.open .nav__burger span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media(max-width:980px){
  .nav__right .nav__lang{display:none}
  .nav__burger{display:flex}
  .nav__links{
    display:flex;position:fixed;inset:0;background:rgba(6,34,42,.98);backdrop-filter:blur(8px);
    flex-direction:column;justify-content:center;align-items:center;gap:1.6rem;
    transform:translateX(100%);transition:transform .6s var(--ease);
  }
  .nav.open .nav__links{transform:translateX(0)}
  .nav__links a{font-size:1.5rem;font-family:var(--font-display);letter-spacing:.02em;text-transform:none}
}

/* ---------- 8. HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;background:var(--abyss);color:var(--ivory)}
.hero__canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{width:100%;height:100%;object-fit:cover}
.hero__veil{position:absolute;inset:0;z-index:1;background:
  linear-gradient(180deg,rgba(6,34,42,.55) 0%,rgba(6,34,42,.12) 30%,rgba(6,34,42,.2) 55%,rgba(6,34,42,.86) 100%)}
.hero__content{position:relative;z-index:3;width:100%;padding:0 var(--pad-x) clamp(3.5rem,7vw,6rem)}
.hero__content .eyebrow{color:var(--gold-soft)}
.hero__title{font-size:var(--fs-hero);font-weight:500;line-height:.92;margin:1.3rem 0 1.5rem;max-width:16ch}
.hero__title em{font-style:italic;color:var(--gold-soft)}
.hero__row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:2rem}
.hero__sub{max-width:42ch;color:rgba(232,220,198,.85);font-weight:300}
.hero__cue{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:.6rem;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(252,250,244,.6)}
.hero__cue::after{content:"";width:1px;height:46px;background:linear-gradient(var(--gold),transparent);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* monogram 3D mount (small canvas) */
.monogram{width:clamp(120px,14vw,190px);aspect-ratio:1;position:relative}

/* ---------- 9. COMPONENTS ---------- */
/* section header */
.sec-head{display:flex;flex-direction:column;gap:1.1rem;max-width:64ch}
.sec-head.center{align-items:center;text-align:center;margin-inline:auto}
.sec-head h2{margin-top:.2rem}

/* split feature (image + text) */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(2rem,5vw,5.5rem)}
.split.reverse .split__media{order:2}
.split__media{position:relative;overflow:hidden;border-radius:var(--radius)}
.split__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.split__media:hover img{transform:scale(1.05)}
.split__media .tag{position:absolute;left:1.2rem;bottom:1.2rem;background:rgba(6,34,42,.7);backdrop-filter:blur(6px);color:var(--gold-soft);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;padding:.5rem .9rem;border:1px solid var(--line-gold)}
@media(max-width:860px){.split{grid-template-columns:1fr}.split.reverse .split__media{order:0}}

/* feature cards */
.card{position:relative;overflow:hidden;border-radius:var(--radius);background:var(--abyss);min-height:clamp(360px,42vw,520px);display:flex;align-items:flex-end;isolation:isolate}
.card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform 1.1s var(--ease)}
.card::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(180deg,rgba(6,34,42,0) 30%,rgba(6,34,42,.9) 100%)}
.card:hover img{transform:scale(1.07)}
.card__body{padding:clamp(1.4rem,2.5vw,2.2rem);color:var(--ivory)}
.card__body .eyebrow{color:var(--gold-soft)}
.card__body h3{margin:.6rem 0 .4rem;color:var(--ivory)}
.card__body p{color:rgba(232,220,198,.8);font-size:.95rem;font-weight:300}
.card__link{margin-top:1rem;display:inline-flex;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);gap:.5rem;align-items:center}
.card__link::after{content:"→";transition:transform .4s var(--ease)}
.card:hover .card__link::after{transform:translateX(5px)}

/* stat row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-gold);border-block:1px solid var(--line-gold)}
.stat{padding:clamp(1.6rem,3vw,2.6rem);text-align:center;background:var(--abyss)}
.bg-cream .stats{background:var(--line-light);border-color:var(--line-light)}
.bg-cream .stat{background:var(--cream)}
.stat__num{font-family:var(--font-display);font-size:clamp(2.4rem,4.5vw,3.6rem);font-weight:500;color:var(--gold);line-height:1}
.stat__label{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-faint);margin-top:.6rem}
.bg-dark .stat__label{color:rgba(232,220,198,.6)}
@media(max-width:760px){.stats{grid-template-columns:1fr 1fr}}

/* quote band */
.quote{text-align:center;max-width:30ch;margin-inline:auto}
.quote q{font-family:var(--font-display);font-style:italic;font-size:clamp(1.8rem,4vw,3rem);line-height:1.25;font-weight:400}
.quote q::before{content:"“"}.quote q::after{content:"”"}
.quote cite{display:block;margin-top:1.6rem;font-style:normal;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}

/* gallery grid (editorial mosaic) */
.mosaic{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:minmax(120px,18vh);gap:clamp(.6rem,1vw,1rem)}
.mosaic figure{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer}
.mosaic img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .6s}
.mosaic figure:hover img{transform:scale(1.06)}
.mosaic figure::after{content:"";position:absolute;inset:0;background:rgba(6,34,42,.16);opacity:0;transition:.4s}
.mosaic figure:hover::after{opacity:1}
.m-tall{grid-row:span 2}.m-wide{grid-column:span 6}.m-mid{grid-column:span 4}.m-sm{grid-column:span 3}.m-half{grid-column:span 6}
@media(max-width:760px){.mosaic{grid-template-columns:repeat(6,1fr)}.m-wide,.m-mid,.m-half{grid-column:span 6}.m-sm{grid-column:span 3}}

/* CTA band */
.cta{position:relative;overflow:hidden;text-align:center;color:var(--ivory)}
.cta img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.cta::after{content:"";position:absolute;inset:0;background:rgba(6,34,42,.66);z-index:-1}
.cta .wrap{padding-block:clamp(5rem,10vw,9rem)}

/* ---------- 10. BOOKING BAR ---------- */
.booking{
  position:relative;z-index:4;max-width:var(--maxw);margin:-3.2rem auto 0;
  background:var(--ivory);box-shadow:var(--shadow-deep);
  display:grid;grid-template-columns:repeat(4,1fr) auto;align-items:end;
  gap:1.5rem;padding:1.6rem clamp(1.4rem,3vw,2.4rem);border-top:2px solid var(--gold);
}
.booking__field{display:flex;flex-direction:column;gap:.45rem}
.booking__field label{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:500}
.booking__field input,.booking__field select{
  font-family:var(--font-body);font-size:.95rem;color:var(--ink);
  border:none;border-bottom:1px solid var(--line-light);padding:.4rem 0;background:none;width:100%;
}
.booking__field input:focus,.booking__field select:focus{outline:none;border-color:var(--gold)}
.booking .btn{height:fit-content;justify-content:center}
@media(max-width:980px){.booking{grid-template-columns:1fr 1fr;margin-top:-2rem}.booking .btn{grid-column:1/-1}}

/* ---------- 11. FOOTER ---------- */
.footer{background:var(--abyss);color:rgba(232,220,198,.72);padding-top:clamp(4rem,8vw,7rem)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2.5rem;padding-bottom:3.5rem;border-bottom:1px solid var(--line-dark)}
.footer__brand .nav__logo{color:var(--ivory);margin-bottom:1.2rem}
.footer h4{font-family:var(--font-body);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.3rem;font-weight:500}
.footer ul li{margin-bottom:.7rem}
.footer ul a{font-size:.92rem;font-weight:300;transition:color .3s}
.footer ul a:hover{color:var(--gold-soft)}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;padding-block:2rem;font-size:.78rem;color:var(--ink-faint)}
.footer__social{display:flex;gap:1.2rem}
.footer__social a{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}
@media(max-width:860px){.footer__top{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer__top{grid-template-columns:1fr}}

/* ---------- 12. PAGE HERO (interior pages) ---------- */
.phero{position:relative;min-height:74svh;display:flex;align-items:flex-end;overflow:hidden;color:var(--ivory);background:var(--abyss)}
.phero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.phero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(6,34,42,.5),rgba(6,34,42,.15) 40%,rgba(6,34,42,.85))}
.phero__in{position:relative;z-index:2;padding:0 var(--pad-x) clamp(3rem,6vw,5rem);width:100%}
.phero__in .eyebrow{color:var(--gold-soft)}
.phero__in h1{font-size:var(--fs-h1);margin-top:1rem;max-width:18ch}
.breadcrumb{margin-top:1.2rem;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(252,250,244,.62)}
.breadcrumb a:hover{color:var(--gold)}

/* ---------- 13. ATMOSPHERE (grain + hairlines) ---------- */
.grain::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.rule{height:1px;background:var(--line-gold);border:0}
.vlabel{writing-mode:vertical-rl;text-orientation:mixed;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-faint)}

/* ---------- 14. REVEAL ANIMATIONS ---------- */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal="fade"]{transform:none}
[data-reveal-delay="1"]{transition-delay:.12s}
[data-reveal-delay="2"]{transition-delay:.24s}
[data-reveal-delay="3"]{transition-delay:.36s}
[data-reveal-delay="4"]{transition-delay:.48s}
.clip-reveal{clip-path:inset(0 100% 0 0);animation:none}
[data-reveal].in .clip-reveal{animation:clip 1.2s var(--ease) forwards}
@keyframes clip{to{clip-path:inset(0 0 0 0)}}

/* hero load stagger */
.hero [data-stagger]{opacity:0;transform:translateY(40px);animation:rise 1.1s var(--ease) forwards}
.hero [data-stagger="1"]{animation-delay:.25s}
.hero [data-stagger="2"]{animation-delay:.45s}
.hero [data-stagger="3"]{animation-delay:.65s}
.hero [data-stagger="4"]{animation-delay:.85s}
@keyframes rise{to{opacity:1;transform:none}}

/* ---------- 15. LIGHTBOX ---------- */
.lightbox{position:fixed;inset:0;z-index:1000;background:rgba(6,34,42,.96);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:.4s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:88vw;max-height:84vh;object-fit:contain;box-shadow:var(--shadow-deep)}
.lightbox__close{position:absolute;top:2rem;right:2rem;color:var(--ivory);font-size:1.6rem;width:48px;height:48px;border:1px solid var(--line-dark);border-radius:50%;display:grid;place-items:center;transition:.35s}
.lightbox__close:hover{border-color:var(--gold);color:var(--gold);transform:rotate(90deg)}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);color:var(--ivory);font-size:2rem;padding:1rem;opacity:.6;transition:.3s}
.lightbox__nav:hover{opacity:1;color:var(--gold)}
.lightbox__prev{left:1.5rem}.lightbox__next{right:1.5rem}

/* =============================================================
   THE DESCENT — immersive underwater experience (homepage)
   ============================================================= */
:root{
  --abyss-2:#04101c;
  --ocean-cyan:#5fd0d6;
  --sun-warm:#ffd98a;
}
/* fixed ocean world behind everything */
#ocean{position:fixed;inset:0;width:100%;height:100%;z-index:-2;display:block}
body.dive{background:var(--abyss-2);color:var(--sand)}
body.dive .grain::before{opacity:.05;mix-blend-mode:soft-light}

/* custom cursor (desktop, fine pointer) */
.cursor{position:fixed;top:0;left:0;width:30px;height:30px;border:1px solid rgba(95,208,214,.6);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,border-color .3s;mix-blend-mode:screen}
.cursor.hot{width:58px;height:58px;background:rgba(95,208,214,.08);border-color:var(--ocean-cyan)}
.cursor__dot{position:fixed;top:0;left:0;width:5px;height:5px;background:var(--sun-warm);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);box-shadow:0 0 12px var(--sun-warm)}
@media(hover:none),(pointer:coarse){.cursor,.cursor__dot{display:none}}

/* intro — break the surface */
#dive-intro{position:fixed;inset:0;z-index:9000;display:grid;place-items:center;background:
  radial-gradient(120% 90% at 50% -10%, #0a3a4e 0%, #062236 45%, #04101c 100%);
  transition:opacity 1.1s var(--ease),transform 1.4s var(--ease),clip-path 1.4s var(--ease);
  clip-path:inset(0 0 0 0);
  /* fail-safe: if main.js never runs/throws, the overlay still clears on its own
     well after the normal JS dismissal (~2.3s + 1.6s remove). Holds fully visible
     until ~6s, then fades out. The .gone class below cancels this so the JS path wins. */
  animation:diSafety 7s linear forwards}
#dive-intro .di-mark{text-align:center;transform:translateY(0);transition:transform 1.2s var(--ease),opacity .9s var(--ease)}
#dive-intro .di-mark span{display:block;font-family:var(--font-display);color:var(--ivory);font-size:clamp(2.4rem,7vw,5rem);font-weight:500;letter-spacing:.02em;line-height:1}
#dive-intro .di-mark b{color:var(--gold);font-weight:500}
#dive-intro .di-mark small{display:block;margin-top:1rem;font-family:var(--font-body);font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;color:var(--ocean-cyan);opacity:0;animation:diIn 1s var(--ease) .5s forwards}
#dive-intro .di-line{width:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:1.4rem auto;animation:diLine 1.4s var(--ease) .3s forwards}
#dive-intro .di-cue{position:absolute;bottom:2.4rem;left:50%;transform:translateX(-50%);font-size:.64rem;letter-spacing:.34em;text-transform:uppercase;color:rgba(95,208,214,.7);opacity:0;animation:diIn 1s 1.3s forwards}
@keyframes diIn{to{opacity:1}}
@keyframes diLine{to{width:min(260px,60vw)}}
/* fail-safe auto-fade: visible through the whole normal JS window, then clears */
@keyframes diSafety{0%,85%{opacity:1}100%{opacity:0;visibility:hidden;pointer-events:none}}
/* reduced-motion globally collapses animation-duration to ~0, which would make the
   safety fade fire instantly; disable it there. JS still dismisses (~250ms) and the
   <noscript> guard covers the no-JS case, so the overlay can't get stuck either way. */
@media (prefers-reduced-motion:reduce){#dive-intro{animation:none}}
/* normal JS dismissal must win: cancel the safety animation so .gone applies at once */
#dive-intro.gone{animation:none;opacity:0;clip-path:inset(0 0 100% 0);pointer-events:none}
#dive-intro.gone .di-mark{transform:translateY(-40px);opacity:0}
body.dive-ready{overflow:hidden}

/* depth rail */
.depth-rail{position:fixed;right:clamp(.8rem,2vw,2rem);top:50%;transform:translateY(-50%);z-index:50;display:flex;flex-direction:column;align-items:flex-end;gap:.7rem;pointer-events:none;mix-blend-mode:difference}
.depth-rail .dr-val{font-family:var(--font-display);font-size:1.5rem;color:var(--ivory);line-height:1;font-weight:500}
.depth-rail .dr-label{font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.depth-rail .dr-track{width:1px;height:34vh;background:rgba(255,255,255,.25);position:relative;margin-top:.4rem}
.depth-rail .dr-fill{position:absolute;top:0;left:0;width:100%;background:var(--ocean-cyan);height:0%}
.depth-rail .dr-fill::after{content:"";position:absolute;bottom:-3px;left:-3px;width:7px;height:7px;border-radius:50%;background:var(--sun-warm);box-shadow:0 0 10px var(--sun-warm)}
@media(max-width:820px){.depth-rail{display:none}}

/* DESCENT hero */
.dhero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;overflow:hidden;padding:0 var(--pad-x)}
.dhero__eyebrow{color:var(--ocean-cyan);margin-bottom:1.6rem}
.dhero__title{font-family:var(--font-display);font-weight:500;color:var(--ivory);font-size:clamp(3rem,11vw,11rem);line-height:.9;letter-spacing:-.02em;text-shadow:0 2px 60px rgba(4,16,28,.6)}
.dhero__title em{font-style:italic;background:linear-gradient(120deg,var(--sun-warm),var(--ocean-cyan));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.dhero__sub{max-width:46ch;margin:2rem auto 0;color:rgba(234,243,243,.82);font-weight:300;font-size:var(--fs-lead)}
.dhero__cue{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.7rem;font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;color:rgba(95,208,214,.8)}
.dhero__cue .dl{width:1px;height:50px;background:linear-gradient(var(--ocean-cyan),transparent);animation:cue 2.4s var(--ease) infinite}
.dhero .monogram{position:absolute;top:7%;left:50%;transform:translateX(-50%);opacity:.92;width:clamp(96px,10vw,150px)}
.float-soft{animation:floaty 7s ease-in-out infinite}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* immersive content panels over the ocean */
.deep-panel{position:relative;background:linear-gradient(180deg,rgba(4,16,28,.74),rgba(4,18,30,.9));border-block:1px solid rgba(95,208,214,.14);color:var(--sand)}
.deep-panel h2,.deep-panel h3{color:var(--ivory)}
.deep-panel .lead{color:rgba(234,243,243,.78)}
.air-panel{position:relative;background:rgba(247,242,232,.94);backdrop-filter:blur(2px);color:var(--ink)}
/* full-bleed ocean break (pure water, a line of text) */
.ocean-break{position:relative;min-height:62svh;display:grid;place-items:center;text-align:center;padding:0 var(--pad-x)}
.ocean-break q{font-family:var(--font-display);font-style:italic;font-size:clamp(1.8rem,4.4vw,3.4rem);line-height:1.25;color:var(--ivory);max-width:24ch;text-shadow:0 2px 40px rgba(4,16,28,.7)}
.ocean-break .depth-tag{display:block;margin-bottom:1.4rem;font-family:var(--font-body);font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ocean-cyan)}

/* WebGL/CSS water-distortion image reveal */
.distort{position:relative;overflow:hidden}
.distort canvas{display:block;width:100%;height:100%}
.distort img.distort-src{display:block;width:100%;height:100%;object-fit:cover}
.distort.gl img{position:absolute;inset:0;opacity:0;pointer-events:none}

/* === DIVE MODE — turn every interior page immersive over the ocean === */
body.dive .section.bg-cream,
body.dive .section.bg-sand{
  background:linear-gradient(180deg,rgba(4,16,28,.70),rgba(4,18,30,.9));
  color:var(--sand);border-block:1px solid rgba(95,208,214,.12);
}
body.dive .bg-dark,
body.dive .bg-deep{background:linear-gradient(180deg,rgba(4,15,26,.80),rgba(5,20,32,.93))}
body.dive .bg-cream h1,body.dive .bg-cream h2,body.dive .bg-cream h3,body.dive .bg-cream h4,
body.dive .bg-sand h2,body.dive .bg-sand h3,body.dive .bg-sand h4{color:var(--ivory)}
body.dive .bg-cream .lead,body.dive .bg-sand .lead{color:rgba(234,243,243,.8)}
body.dive .bg-cream p,body.dive .bg-sand p{color:rgba(234,243,243,.72)}
body.dive .bg-cream .stats,body.dive .bg-sand .stats{background:rgba(95,208,214,.18);border-color:rgba(95,208,214,.2)}
body.dive .bg-cream .stat,body.dive .bg-sand .stat{background:rgba(4,16,28,.55)}
body.dive .bg-cream .stat__label,body.dive .bg-sand .stat__label{color:rgba(234,243,243,.6)}
body.dive .bg-cream .quote q,body.dive .bg-sand .quote q{color:var(--ivory)}
body.dive .section-index{-webkit-text-stroke-color:rgba(95,208,214,.32)}
body.dive .muted{color:rgba(234,243,243,.52)}
body.dive [style*="--ink-soft"],body.dive [style*="--ink-faint"]{color:rgba(234,243,243,.72)!important}
/* phero blends into the ocean below */
body.dive .phero::after{background:linear-gradient(180deg,rgba(4,16,28,.5),rgba(4,16,28,.2) 38%,rgba(4,16,28,.96))}

/* utility */
.text-center{text-align:center}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:clamp(2rem,4vw,3.5rem)}
.gold{color:var(--gold)}
.muted{color:var(--ink-faint)}
.maxw-prose{max-width:62ch}
.flex-between{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}

/* =============================================================
   CONCEPT-DEMO MARKER — Talbawy Studios
   A small, fixed, design-token-aligned badge present on every
   page. Sits above the dive-intro overlay (z 9000) so it stays
   visible through the surface-break intro, yet below the custom
   cursor (z 9998/9999). Bottom-left so it never covers the
   right-edge depth rail or the nav's Reserve CTA.
   ============================================================= */
.ts-demo-badge{
  position:fixed;left:clamp(.9rem,2vw,1.6rem);bottom:clamp(.9rem,2vw,1.6rem);
  z-index:9100;display:inline-flex;align-items:center;gap:.55rem;
  padding:.5rem .85rem;
  font-family:var(--font-body);font-size:.62rem;font-weight:500;
  letter-spacing:.2em;text-transform:uppercase;line-height:1;
  color:var(--gold-soft);
  background:rgba(6,34,42,.78);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border:1px solid var(--line-gold);border-radius:2px;
  box-shadow:0 10px 30px -16px rgba(4,16,28,.8);
  transition:color .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease),transform .35s var(--ease);
}
.ts-demo-badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold);flex:0 0 auto}
.ts-demo-badge b{font-weight:600;color:var(--ivory)}
.ts-demo-badge:hover{color:var(--ivory);border-color:var(--gold);background:rgba(6,34,42,.92);transform:translateY(-2px)}
@media(max-width:560px){
  .ts-demo-badge{font-size:.56rem;letter-spacing:.16em;padding:.45rem .7rem;gap:.45rem}
}

/* discreet concept-demo line inside the shared footer */
.footer__demo{font-size:.74rem;letter-spacing:.04em;color:var(--ink-faint)}
.footer__demo a{color:var(--gold);font-weight:500}
.footer__demo a:hover{color:var(--gold-soft)}

/* =============================================================
   16. CUSTOM FORM UI — booking bar selects & date pickers
   Progressive enhancement: native <select>/<input type=date>
   are visually hidden (kept for sync, a11y, no-JS). Custom
   triggers mirror the .booking__field input/select look so the
   bar stays cohesive. Panels render in a body-level portal so
   nothing clips them. All colours come from the existing tokens.
   ============================================================= */

/* hide the native control but keep it focusable in the DOM for
   form submission / no-JS. (Not display:none — we want it to keep
   participating in the form.) */
.gr-fui-native{
  position:absolute!important;width:1px!important;height:1px!important;
  padding:0!important;margin:-1px!important;overflow:hidden!important;
  clip:rect(0 0 0 0)!important;clip-path:inset(50%)!important;
  white-space:nowrap!important;border:0!important;
}

/* shared trigger — matches .booking__field input/select exactly,
   plus room for the icon/chevron */
.gr-fui{
  font-family:var(--font-body);font-size:.95rem;color:var(--ink);
  border:none;border-bottom:1px solid var(--line-light);
  padding:.4rem 0;background:none;width:100%;
  display:flex;align-items:center;gap:.55rem;
  text-align:left;line-height:1.4;min-height:calc(.95rem * 1.4 + .8rem);
  cursor:pointer;border-radius:0;
  transition:border-color .35s var(--ease),color .35s var(--ease);
}
.gr-fui:hover{border-color:var(--line-gold)}
.gr-fui:focus-visible{outline:none;border-color:var(--gold)}
.gr-fui[aria-expanded="true"]{border-color:var(--gold)}
.gr-fui .gr-fui__val{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.gr-fui.is-empty .gr-fui__val{color:var(--ink-faint)}

/* chevron (select) */
.gr-fui__chev{flex:0 0 auto;width:14px;height:14px;color:var(--gold-deep);transition:transform .3s var(--ease),color .3s var(--ease)}
.gr-fui[aria-expanded="true"] .gr-fui__chev{transform:rotate(180deg);color:var(--gold)}
.gr-sel__trigger:hover .gr-fui__chev{color:var(--gold)}

/* gem/calendar icon (date) */
.gr-fui__gem{flex:0 0 auto;width:15px;height:15px;color:var(--gold-deep);transition:color .3s var(--ease)}
.gr-date__trigger:hover .gr-fui__gem,
.gr-date__trigger[aria-expanded="true"] .gr-fui__gem{color:var(--gold)}

/* ---- portal + shared panel chrome ---- */
.gr-fui-portal{position:absolute;top:0;left:0;width:0;height:0;z-index:1500}
.gr-fui-panel{
  position:absolute;z-index:1500;
  background:var(--ivory);color:var(--ink);
  border:1px solid var(--line-gold);border-top:2px solid var(--gold);
  border-radius:var(--radius);
  box-shadow:var(--shadow-deep);
  font-family:var(--font-body);
  opacity:0;transform:translateY(6px) scale(.985);
  transform-origin:top left;
  transition:opacity .2s var(--ease),transform .2s var(--ease);
  will-change:opacity,transform;
}
.gr-fui-panel.is-open{opacity:1;transform:translateY(0) scale(1)}

/* ---- COMPONENT A : select listbox ---- */
.gr-sel__panel{padding:.4rem;min-width:200px}
.gr-sel__list{max-height:min(46vh,320px);overflow-y:auto;-webkit-overflow-scrolling:touch}
.gr-sel__opt{
  display:flex;align-items:center;gap:.6rem;
  padding:.62rem .7rem;border-radius:var(--radius);
  font-size:.92rem;color:var(--ink);line-height:1.3;
  cursor:pointer;position:relative;
  transition:background .2s var(--ease),color .2s var(--ease);
}
.gr-sel__optlabel{flex:1 1 auto;min-width:0}
.gr-sel__opt .gr-fui__check{flex:0 0 auto;width:14px;height:14px;color:var(--gold);opacity:0;transform:scale(.6);transition:opacity .2s var(--ease),transform .2s var(--ease)}
.gr-sel__opt.is-active{background:rgba(201,162,75,.12)}
.gr-sel__opt:hover{background:rgba(201,162,75,.12)}
.gr-sel__opt.is-selected{color:var(--gold-deep);font-weight:500}
.gr-sel__opt.is-selected .gr-fui__check{opacity:1;transform:scale(1)}

/* ---- COMPONENT B : date calendar ---- */
.gr-date__panel{padding:.85rem;width:288px;max-width:calc(100vw - 16px)}
.gr-date__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.7rem}
.gr-date__title{
  font-family:var(--font-display);font-size:1.2rem;font-weight:600;
  color:var(--ink);letter-spacing:.01em;text-align:center;flex:1 1 auto;
}
.gr-date__nav{
  flex:0 0 auto;width:32px;height:32px;display:grid;place-items:center;
  color:var(--gold-deep);border:1px solid var(--line-gold);border-radius:var(--radius);
  background:none;transition:color .3s var(--ease),border-color .3s var(--ease),background .3s var(--ease),transform .3s var(--ease);
}
.gr-date__nav svg{width:15px;height:15px}
.gr-date__nav:hover{color:var(--abyss);background:var(--gold);border-color:var(--gold)}
.gr-date__nav:disabled{opacity:.3;cursor:not-allowed;color:var(--ink-faint);background:none;border-color:var(--line-light)}
.gr-date__week{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.35rem}
.gr-date__week span{
  text-align:center;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:500;padding:.2rem 0;
}
.gr-date__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;transition:opacity .18s var(--ease),transform .18s var(--ease)}
.gr-date__panel.is-shift .gr-date__grid{opacity:0;transform:translateY(4px)}
.gr-date__day{
  aspect-ratio:1;display:grid;place-items:center;
  font-family:var(--font-body);font-size:.84rem;color:var(--ink);
  border-radius:var(--radius);background:none;border:1px solid transparent;
  cursor:pointer;line-height:1;
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
}
.gr-date__day:hover:not(:disabled){background:rgba(201,162,75,.14);color:var(--gold-deep)}
.gr-date__day.is-out{color:var(--ink-faint);opacity:.5}
.gr-date__day.is-today{border-color:var(--line-gold)}
.gr-date__day:focus-visible{outline:2px solid var(--gold);outline-offset:1px}
.gr-date__day:disabled{color:var(--ink-faint);opacity:.32;cursor:not-allowed}
.gr-date__day.is-selected,
.gr-date__day.is-selected:hover{background:var(--gold);color:var(--abyss);font-weight:500;border-color:var(--gold)}

/* small screens: panels go (near) full-width under the field */
@media(max-width:480px){
  .gr-date__panel{width:min(340px,calc(100vw - 16px))}
  .gr-sel__panel{width:min(340px,calc(100vw - 16px))}
}

/* reduced motion: drop entrance/icon motion, keep states */
@media (prefers-reduced-motion:reduce){
  .gr-fui-panel{transition:none;opacity:1;transform:none}
  .gr-fui__chev,.gr-date__grid,.gr-sel__opt .gr-fui__check{transition:none}
  .gr-date__panel.is-shift .gr-date__grid{opacity:1;transform:none}
}
