/* ============================================================
   THE BLUE ORCHID VILLA — Cabrera, Dominican Republic
   ============================================================ */

/* ---------- Fonts ---------- */
@font-face{font-family:"Seasons";src:url("../fonts/TheSeasons-Light.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Seasons";src:url("../fonts/TheSeasons-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Seasons";src:url("../fonts/TheSeasons-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Seasons";src:url("../fonts/TheSeasons-Italic.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Raleway";src:url("../fonts/Raleway-Variable.ttf") format("truetype");font-weight:100 900;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --ink:#0e1012;
  --ink-soft:#15181b;
  --cream:#f3efe6;
  --cream-2:#e9e3d6;
  --sand:#cdbfa6;
  --ocean:#5d7d8a;
  --ocean-deep:#2c4450;
  --line:rgba(243,239,230,.16);
  --line-dark:rgba(14,16,18,.14);
  --serif:"Seasons",Georgia,serif;
  --sans:"Raleway",system-ui,sans-serif;
  --ease:cubic-bezier(.22,.61,.36,1);
  --pad:clamp(22px,6vw,120px);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);background:var(--ink);color:var(--cream);
  font-weight:300;line-height:1.7;letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
body.no-scroll{overflow:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ---------- Type ---------- */
.serif{font-family:var(--serif)}
h1,h2,h3{font-family:var(--serif);font-weight:300;line-height:1.08;letter-spacing:.01em}
.eyebrow{
  font-family:var(--sans);font-weight:500;font-size:.72rem;letter-spacing:.42em;
  text-transform:uppercase;color:var(--sand);display:inline-block;
}
.h-xl{font-size:clamp(2.6rem,7vw,6.4rem)}
.h-lg{font-size:clamp(2.1rem,5vw,4rem)}
.h-md{font-size:clamp(1.6rem,3.4vw,2.6rem)}
.lead{font-size:clamp(1.05rem,1.5vw,1.32rem);font-weight:300;line-height:1.85;color:var(--cream-2)}
.muted{color:rgba(243,239,230,.6)}
em,.it{font-style:italic}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;font-family:var(--sans);
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;font-weight:500;
  padding:1.15em 2.3em;border:1px solid var(--line);color:var(--cream);
  background:transparent;cursor:pointer;transition:.5s var(--ease);position:relative;overflow:hidden;
}
.btn span{position:relative;z-index:2;transition:color .5s var(--ease)}
.btn::after{content:"";position:absolute;inset:0;background:var(--cream);transform:translateY(101%);transition:transform .5s var(--ease);z-index:1}
.btn:hover::after{transform:translateY(0)}
.btn:hover span{color:var(--ink)}
.btn--solid{background:var(--cream);color:var(--ink);border-color:var(--cream)}
.btn--solid::after{background:var(--ocean-deep)}
.btn--solid:hover span{color:var(--cream)}
.btn--dark{border-color:var(--line-dark);color:var(--ink)}
.btn--dark::after{background:var(--ink)}
.btn--dark:hover span{color:var(--cream)}

/* ---------- Header ---------- */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(16px,2.4vw,30px) var(--pad);
  background:transparent;
  transition:padding .5s var(--ease);
}
.header.scrolled{background:transparent;padding-top:14px;padding-bottom:14px;box-shadow:none}
.header__logo{display:flex;align-items:center;gap:12px}
.header__logo{flex-shrink:0;background:rgba(14,16,18,.75);border-radius:8px;padding:8px 16px;min-width:0}
.header__logo img{height:clamp(60px,9vw,90px);width:auto;filter:brightness(0) invert(1);opacity:1;flex-shrink:0;display:block}
.nav{display:flex;align-items:center;gap:clamp(20px,2.4vw,40px)}
.nav__links{display:flex;gap:clamp(18px,2vw,34px)}
.nav__links a{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;font-weight:500;position:relative;padding:.45em .85em;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);overflow:hidden;transition:color .5s var(--ease),border-color .5s var(--ease),text-shadow .3s var(--ease),background .5s var(--ease);z-index:1;white-space:nowrap}
.nav__links a::after{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:-1}
.nav__links a:hover{color:#fff;border-color:var(--ink);text-shadow:none}
.nav__links a:hover::after{transform:translateY(0)}
.nav__right{display:flex;align-items:center;gap:18px}
.lang{display:flex;align-items:center;gap:7px;font-size:.72rem;letter-spacing:.12em;font-weight:500}
.lang button{background:none;border:none;color:var(--cream);cursor:pointer;opacity:.5;font:inherit;letter-spacing:.12em;transition:opacity .3s;padding:2px}
.lang button.active{opacity:1;text-decoration:underline;text-underline-offset:4px;text-decoration-color:var(--sand)}
.lang .sep{opacity:.4}
.header .btn{padding:.85em 1.7em}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:1.5px;background:var(--cream);transition:.4s var(--ease)}

/* mobile nav drawer */
.drawer{position:fixed;inset:0;z-index:55;background:var(--ink);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:26px;transform:translateY(-100%);transition:transform .6s var(--ease);visibility:hidden}
.drawer.open{transform:translateY(0);visibility:visible}
.drawer a{font-family:var(--serif);font-size:1.9rem;opacity:.9}
.drawer .lang{margin-top:18px}

/* ---------- Hero ---------- */
.hero{position:relative;height:100svh;min-height:600px;display:flex;align-items:flex-end;overflow:hidden}
.hero__media,.hero__media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,16,18,.65) 0%,rgba(14,16,18,.35) 35%,rgba(14,16,18,.42) 62%,rgba(14,16,18,.92) 100%)}
#orchid-canvas{display:none}
.hero__inner{position:relative;z-index:3;padding:0 var(--pad) clamp(60px,9vh,120px);width:100%}
.hero__eyebrow{margin-bottom:26px;opacity:0;transform:translateY(20px);animation:rise 1.1s var(--ease) .3s forwards;color:#fff;font-size:.82rem;font-weight:600;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.hero__eyebrow--bottom{margin-bottom:0;margin-top:24px;animation-delay:1.3s}
.hero h1{font-size:clamp(3rem,9vw,8.4rem);font-weight:300;line-height:.96;max-width:14ch}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln span{display:block;transform:translateY(110%);animation:rise 1.2s var(--ease) forwards}
.hero h1 .ln:nth-child(1) span{animation-delay:.45s}
.hero h1 .ln:nth-child(2) span{animation-delay:.6s}
.hero h1 .ln:nth-child(2) span{font-style:italic;color:var(--cream)}
.hero__sub{margin-top:30px;max-width:46ch;font-size:clamp(1.05rem,1.5vw,1.3rem);color:#fff;font-weight:400;text-shadow:0 2px 8px rgba(0,0,0,.5);opacity:0;transform:translateY(20px);animation:rise 1.1s var(--ease) .95s forwards}
.hero__meta{margin-top:40px;display:flex;gap:34px;flex-wrap:wrap;align-items:center;opacity:0;transform:translateY(20px);animation:rise 1.1s var(--ease) 1.15s forwards}
.hero__meta .item{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase}
.hero__meta .item b{font-family:var(--serif);font-size:1.5rem;font-weight:300;display:block;letter-spacing:.02em;margin-bottom:4px;text-transform:none}
.hero__meta .div{width:1px;height:38px;background:var(--line)}
.scrollcue{position:absolute;bottom:34px;right:var(--pad);z-index:3;writing-mode:vertical-rl;font-size:.66rem;letter-spacing:.3em;text-transform:uppercase;opacity:.7;display:flex;align-items:center;gap:14px}
.scrollcue::after{content:"";width:1px;height:54px;background:var(--cream);transform-origin:top;animation:cue 2.2s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0)}40%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}
@keyframes rise{to{transform:translateY(0);opacity:1}}

/* ---------- Sections ---------- */
section{position:relative}
.pad{padding:clamp(80px,12vh,170px) var(--pad)}
.bg-cream{background:var(--cream);color:var(--ink)}
.bg-cream .eyebrow{color:var(--ocean-deep)}
.bg-cream .muted{color:rgba(14,16,18,.55)}
.bg-cream .lead{color:rgba(14,16,18,.78)}
.bg-ink{background:var(--ink)}
.bg-soft{background:var(--ink-soft)}
.center{text-align:center}
.maxw{max-width:760px}
.mx-auto{margin-left:auto;margin-right:auto}

/* Intro split */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,100px);align-items:center}
.split--rev .split__media{order:2}
.split__media{position:relative;overflow:hidden}
.split__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.split__body .eyebrow{margin-bottom:22px}
.split__body h2{margin-bottom:26px}
.split__body p+p{margin-top:18px}
.sig{font-family:var(--serif);font-style:italic;font-size:1.5rem;margin-top:30px;opacity:.85}

/* Feature list */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:2px 50px;margin-top:34px}
.features li{list-style:none;display:flex;gap:14px;padding:15px 0;border-bottom:1px solid var(--line-dark);font-size:.95rem;align-items:baseline}
.bg-ink .features li,.bg-soft .features li{border-color:var(--line)}
.features li .n{font-family:var(--serif);font-size:.95rem;color:var(--ocean);min-width:26px}

/* Amenity chips */
.amen{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.amen span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;padding:.7em 1.2em;border:1px solid var(--line);border-radius:40px}
.bg-cream .amen span{border-color:var(--line-dark)}

/* Section heading block */
.shead{max-width:680px}
.shead .eyebrow{margin-bottom:20px}
.shead h2{margin-bottom:20px}

/* Experiences grid */
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,28px);margin-top:60px}
.exp{position:relative;overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end}
.exp img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.exp::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(14,16,18,.85) 100%)}
.exp:hover img{transform:scale(1.06)}
.exp__t{position:relative;z-index:2;padding:30px;width:100%}
.exp__t h3{font-size:1.5rem;margin-bottom:8px}
.exp__t p{font-size:.86rem;color:var(--cream-2);opacity:0;max-height:0;transition:.6s var(--ease)}
.exp:hover .exp__t p{opacity:1;max-height:80px}

/* Dining */
.dishes{display:grid;grid-template-columns:repeat(2,1fr);gap:0 60px;margin-top:30px}
.dish{display:flex;justify-content:space-between;gap:20px;padding:18px 0;border-bottom:1px solid var(--line-dark);align-items:baseline}
.dish .name{font-family:var(--serif);font-size:1.25rem}
.dish .desc{font-size:.82rem;text-align:right;color:rgba(14,16,18,.55);max-width:18ch}

/* Full-bleed quote / events */
.bleed{position:relative;min-height:78vh;display:flex;align-items:center;overflow:hidden}
.bleed video,.bleed img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.bleed::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(14,16,18,.85) 0%,rgba(14,16,18,.45) 60%,rgba(14,16,18,.3) 100%)}
.bleed__in{position:relative;z-index:2;padding:0 var(--pad);max-width:680px}
.bleed__in h2{margin:22px 0}

/* Gallery */
.gallery{columns:3;column-gap:14px;margin-top:54px}
.gallery figure{break-inside:avoid;margin-bottom:14px;overflow:hidden;cursor:pointer;position:relative}
.gallery img{width:100%;transition:transform 1s var(--ease),filter .6s;filter:saturate(.96)}
.gallery figure::after{content:"";position:absolute;inset:0;background:rgba(14,16,18,.0);transition:.5s}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figure:hover::after{background:rgba(14,16,18,.12)}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(8,9,10,.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:90vw;max-height:86vh;object-fit:contain;box-shadow:0 30px 90px rgba(0,0,0,.6)}
.lb-close,.lb-nav{position:absolute;background:none;border:none;color:var(--cream);cursor:pointer;font-family:var(--serif);transition:.3s}
.lb-close{top:24px;right:30px;font-size:2rem;line-height:1}
.lb-nav{top:50%;transform:translateY(-50%);font-size:2.4rem;padding:20px;opacity:.7}
.lb-nav:hover{opacity:1}
.lb-prev{left:14px}.lb-next{right:14px}
.lb-count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);font-size:.74rem;letter-spacing:.2em;opacity:.7}

/* Location */
.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:54px}
.loc-grid figure{overflow:hidden;position:relative;aspect-ratio:16/11}
.loc-grid img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.loc-grid figure:hover img{transform:scale(1.05)}
.loc-tags{display:flex;flex-wrap:wrap;gap:26px;margin-top:34px}
.loc-tags .t{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;opacity:.8}
.loc-tags .t b{display:block;font-family:var(--serif);font-size:1.3rem;text-transform:none;letter-spacing:0;margin-top:6px;opacity:1}

/* Inquiry / Contact */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px)}
.contact__info h2{margin:20px 0 26px}
.contact__info .row{padding:18px 0;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:4px}
.contact__info .row .k{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--sand)}
.contact__info .row .v{font-family:var(--serif);font-size:1.25rem}
.form{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.form .full{grid-column:1/-1}
.field{position:relative}
.field input,.field textarea,.field select{
  width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);
  color:var(--cream);font-family:var(--sans);font-size:.95rem;font-weight:300;
  padding:14px 2px;letter-spacing:.02em;
}
.field select{color:var(--cream-2)}
.field option{background:var(--ink);color:var(--cream)}
.field textarea{resize:vertical;min-height:90px}
.field label{position:absolute;left:2px;top:14px;font-size:.95rem;color:rgba(243,239,230,.45);pointer-events:none;transition:.3s var(--ease)}
.field input:focus~label,.field textarea:focus~label,
.field input:not(:placeholder-shown)~label,.field textarea:not(:placeholder-shown)~label,
.field.filled label{top:-12px;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--sand)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--sand)}
.form .btn{justify-content:center}
.form__note{font-size:.78rem;color:rgba(243,239,230,.5);margin-top:6px}
.form__ok{display:none;font-size:.95rem;color:var(--sand);padding:14px 0}
.form__ok.show{display:block}

/* Footer */
.footer{background:#0a0c0d;padding:clamp(60px,8vh,110px) var(--pad) 40px}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;align-items:start}
.footer__logo img{height:clamp(80px,12vw,120px);width:auto;filter:brightness(0) invert(1);opacity:1}
.footer__logo p{margin-top:20px;max-width:34ch;font-size:.95rem;color:rgba(243,239,230,.7)}
.footer h4{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--sand);margin-bottom:18px;font-family:var(--sans);font-weight:600}
.footer ul{list-style:none}
.footer ul li{margin-bottom:12px;font-size:.92rem;color:rgba(243,239,230,.72)}
.footer ul li a:hover{color:var(--cream)}
.footer__bottom{margin-top:60px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.74rem;color:rgba(243,239,230,.45);letter-spacing:.06em}
.footer__bottom a:hover{color:var(--cream)}

/* ---------- Reveal animations ---------- */
[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity 1.1s var(--ease),transform 1.1s var(--ease)}
[data-reveal].in{opacity:1;transform:none}
[data-reveal][data-delay="1"]{transition-delay:.12s}
[data-reveal][data-delay="2"]{transition-delay:.24s}
[data-reveal][data-delay="3"]{transition-delay:.36s}
.clip{overflow:hidden}
[data-img]{transform:scale(1.12);transition:transform 1.6s var(--ease)}
[data-img].in{transform:scale(1)}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .nav__links{display:none}
  .burger{display:flex}
  .header .btn{display:none}
  .gallery{columns:2}
  .footer__top{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .split,.contact{grid-template-columns:1fr;gap:40px}
  .split--rev .split__media{order:0}
  .split__media img{aspect-ratio:4/3}
  .features,.dishes{grid-template-columns:1fr}
  .exp-grid{grid-template-columns:1fr;gap:14px}
  .exp{aspect-ratio:16/11}
  .exp__t p{opacity:1;max-height:80px}
  .loc-grid{grid-template-columns:1fr}
  .form{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .hero__meta .div{display:none}
  .gallery{columns:1}
  .dish .desc{display:none}
  .lang{display:none}
  .drawer .lang{display:flex}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.1s!important}
  [data-reveal],[data-img]{opacity:1;transform:none}
}
