/* ======================================================================
   Casa Cova — Coastal Provence design system
   ====================================================================== */
:root{
  --cream:#F7F3EC;
  --cream-2:#EFE8DC;
  --cream-3:#EAE2D4;
  --ink:#22231F;
  --ink-soft:#3c3d38;
  --muted:#8C8475;
  --line:#D9D1C2;
  --gold:#B49A66;
  --white:#ffffff;
  --black:#1B1B19;
  --display:'Cinzel', 'Trajan Pro', Georgia, serif; /* Trajan-style engraved caps */
  --serif:'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:'Mulish', system-ui, sans-serif;
  --container:1200px;
  --pad:clamp(20px,5vw,64px);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--serif);
  color:var(--ink);
  background:var(--cream);
  font-size:18px;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ---------- Type ---------- */
h1,h2,h3{font-weight:500;line-height:1.12;letter-spacing:.01em}
.eyebrow{
  font-family:var(--display);
  font-weight:400;
  font-size:.72rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1.1rem;
}
.display{
  font-family:var(--display);
  font-size:clamp(1.8rem,4vw,3.1rem);
  text-transform:uppercase;
  letter-spacing:.06em;
  font-weight:500;
  line-height:1.2;
}
.h-script{font-style:italic;font-weight:500;letter-spacing:.01em}
.lead{font-size:1.22rem;color:var(--ink-soft);line-height:1.85}
p{color:var(--ink-soft)}
p+p{margin-top:1.1rem}
.center{text-align:center}

/* ---------- Layout ---------- */
.container{max-width:var(--container);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.section{padding:clamp(64px,9vw,128px) 0}
.section--tight{padding:clamp(48px,6vw,84px) 0}
.bg-cream2{background:var(--cream-2)}
.bg-cream3{background:var(--cream-3)}

/* ---------- Arrow link ---------- */
.arrow-link{
  font-family:var(--display);
  font-size:.8rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  padding-bottom:4px;
  border-bottom:1px solid var(--line);
  transition:.35s;
}
.arrow-link .ar{font-family:var(--serif);font-size:1.1rem;transition:transform .35s}
.arrow-link:hover{color:var(--gold);border-color:var(--gold)}
.arrow-link:hover .ar{transform:translateX(5px)}

/* italic serif version of the arrow link (mockup "See the residence ›") */
.link-script{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.18rem;
  letter-spacing:.02em;
  display:inline-flex;align-items:center;gap:.45em;
  border-bottom:1px solid var(--line);padding-bottom:3px;transition:.35s;
}
.link-script:hover{color:var(--gold);border-color:var(--gold)}
.link-script .ar{transition:transform .35s}
.link-script:hover .ar{transform:translateX(5px)}

/* ---------- Button ---------- */
.btn{
  display:inline-block;
  font-family:var(--display);
  font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;
  background:var(--black);color:#fff;
  padding:18px 38px;border:1px solid var(--black);
  transition:.35s;
}
.btn:hover{background:transparent;color:var(--black)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--black);color:#fff;border-color:var(--black)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(247,243,236,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  gap:1rem;padding:16px var(--pad);max-width:1340px;margin:0 auto;
}
.nav__group{display:flex;gap:clamp(14px,2.4vw,40px);align-items:center}
.nav__group--right{justify-content:flex-end}
.nav a.nav__link{
  font-family:var(--display);font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink);padding:6px 0;position:relative;white-space:nowrap;
}
.nav a.nav__link::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .35s}
.nav a.nav__link.nav__cta{background:var(--cream-3);padding:8px 18px;transition:background .3s}
.nav a.nav__link.nav__cta::after{display:none}
.nav a.nav__link.nav__cta:hover{background:#E1D6C0}
.nav a.nav__link:hover::after,.nav a.nav__link.is-active::after{width:100%}
.nav__logo{justify-self:center;display:flex;flex-direction:column;align-items:center;gap:2px}
.nav__logo img{height:46px;width:auto;filter:brightness(0) saturate(100%) opacity(.78)}
.nav__logo .wm{font-size:.78rem;letter-spacing:.4em;text-transform:uppercase;color:var(--ink);font-family:var(--display)}
.nav__toggle{display:none;background:none;border:0;cursor:pointer;font-family:var(--display);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:clamp(360px,60vw,640px);overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background-size:cover;background-position:center;
  text-align:center;color:#fff;
}
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(20,22,20,.22),rgba(20,22,20,.40))}
.hero__inner{position:relative;z-index:2;padding:40px}
@media(prefers-reduced-motion:reduce){.hero__video{display:none}}
.hero__mark{height:clamp(58px,7vw,92px);margin:0 auto 14px;filter:brightness(0) invert(1) drop-shadow(0 2px 14px rgba(0,0,0,.35))}
.hero__wm{font-family:var(--display);font-size:clamp(2.1rem,5.2vw,4rem);letter-spacing:.16em;text-transform:uppercase;font-weight:500;text-shadow:0 2px 22px rgba(0,0,0,.32)}
.hero__sub{font-style:italic;font-size:clamp(1.05rem,1.8vw,1.5rem);letter-spacing:.04em;margin-top:.2rem;text-shadow:0 2px 18px rgba(0,0,0,.4)}

/* YouTube background cover (interior hero) */
.yt-cover{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.yt-cover iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100vw;height:56.25vw;min-height:100%;min-width:177.78vh;border:0}
@media(max-width:760px){.yt-cover{display:none}}

/* page hero (interior) */
.page-hero{min-height:clamp(300px,40vw,460px)}
.page-hero .hero__title{font-family:var(--display);font-size:clamp(2rem,4.6vw,3.5rem);text-transform:uppercase;letter-spacing:.08em;text-shadow:0 2px 22px rgba(0,0,0,.35)}
.page-hero .hero__eyebrow{font-family:var(--display);font-size:.74rem;letter-spacing:.34em;text-transform:uppercase;margin-bottom:1rem;opacity:.92}

/* ---------- Editorial 2-col ---------- */
.editorial{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,96px);align-items:center}
.editorial__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3.4;box-shadow:0 24px 60px -34px rgba(40,35,25,.5)}
.editorial__copy{max-width:480px}
.editorial.reverse .editorial__media{order:2}
.editorial.reverse .editorial__copy{order:1;margin-left:auto}
.editorial__copy .display{margin:.2rem 0 1.3rem}
.editorial__copy .arrow-link,.editorial__copy .link-script{margin-top:1.8rem}
.editorial--center{text-align:center}
.editorial--center .editorial__copy{max-width:560px;margin:0 auto}

/* ---------- Full-bleed ---------- */
.fullbleed{position:relative;height:clamp(340px,52vw,720px);overflow:hidden}
.fullbleed img{width:100%;height:100%;object-fit:cover}

/* ---------- CTA hero (full-width image banner with overlay) ---------- */
.cta-hero{position:relative;min-height:clamp(420px,46vw,600px);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;background-size:cover;background-position:center;overflow:hidden}
.cta-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,24,22,.28),rgba(22,24,22,.46))}
.cta-hero__inner{position:relative;z-index:2;padding:40px}
.cta-hero .pre{font-style:italic;font-size:1.5rem;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.4)}
.cta-hero__mark{height:clamp(48px,5.2vw,72px);margin:10px auto 6px;filter:brightness(0) invert(1) drop-shadow(0 2px 14px rgba(0,0,0,.38))}
.cta-hero .big{font-family:var(--display);font-size:clamp(2rem,4.6vw,3.2rem);text-transform:uppercase;letter-spacing:.09em;margin:.1rem 0 .35rem;text-shadow:0 2px 22px rgba(0,0,0,.4)}
.cta-hero .eyebrow{margin:1rem 0 1.9rem;color:rgba(255,255,255,.9);font-size:.9rem;letter-spacing:.32em}
.btn--light{background:#fff;color:var(--black);border-color:#fff}
.btn--light:hover{background:transparent;color:#fff;border-color:#fff}

/* ---------- CTA band ---------- */
.cta-band{text-align:center;padding:clamp(60px,8vw,110px) 0}
.cta-band .pre{font-style:italic;font-size:1.5rem;color:var(--ink-soft)}
.cta-band .big{font-family:var(--display);font-size:clamp(2rem,4.4vw,3rem);text-transform:uppercase;letter-spacing:.08em;margin:.2rem 0 .3rem}
.cta-band .eyebrow{margin:1rem 0 1.8rem}

/* ---------- Gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:.6s ease}
.gallery a{overflow:hidden;display:block}
.gallery a:hover img{transform:scale(1.05)}
.gallery--3{grid-template-columns:repeat(3,1fr)}
.gallery--2{grid-template-columns:repeat(2,1fr)}
.gallery--wide img{aspect-ratio:4/3}

.section-head{text-align:center;max-width:720px;margin:0 auto clamp(36px,5vw,64px)}
.section-head .display{margin-bottom:.5rem}

/* feature list (What's provided / amenities) */
.feature-cols{columns:2;column-gap:60px;max-width:760px;margin:0 auto}
.feature-cols li{list-style:none;padding:10px 0 10px 24px;position:relative;break-inside:avoid;color:var(--ink-soft)}
.feature-cols li::before{content:"";position:absolute;left:0;top:19px;width:8px;height:8px;border:1px solid var(--gold);transform:rotate(45deg)}

/* detail rows (Reserve page) */
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:center}
.detail-grid .num{font-size:2.6rem;line-height:1}
.detail-grid .lbl{font-family:var(--display);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-top:.6rem}

/* ---------- Footer ---------- */
.site-footer{background:var(--cream-2);border-top:1px solid var(--line);padding:clamp(54px,7vw,86px) 0 40px}
.footer-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:40px;align-items:center}
.footer-col a{display:block;font-family:var(--display);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-soft);padding:7px 0;transition:.3s}
.footer-col a:hover{color:var(--gold)}
.footer-col--right{text-align:right}
.footer-brand{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}
.footer-brand img{height:64px;filter:brightness(0) saturate(100%) opacity(.72)}
.footer-brand .wm{font-family:var(--display);font-size:1.2rem;letter-spacing:.26em;text-transform:uppercase}
.footer-brand .sub{font-style:italic;color:var(--muted)}
.footer-social{display:flex;gap:16px;justify-content:flex-end;margin-top:14px}
.footer-social a{font-size:0;width:34px;height:34px;border:1px solid var(--line);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:.3s}
.footer-social svg{width:15px;height:15px;fill:var(--ink-soft)}
.footer-social a:hover{border-color:var(--gold)}
.footer-social a:hover svg{fill:var(--gold)}
.footer-legal{text-align:center;margin-top:46px;font-family:var(--sans);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* ---------- Reviews ---------- */
.bg-reviews{background:#E6DBC6}
.reviews{text-align:center}
.rating-row{font-family:var(--display);letter-spacing:.03em;color:var(--ink);font-size:1.05rem;display:flex;gap:clamp(18px,4vw,40px);justify-content:center;flex-wrap:wrap;align-items:center;margin:1.1rem 0 .5rem}
.rating-row .star{color:var(--gold);letter-spacing:0}
.rating-row .sep{color:var(--muted)}
.rating-badges{font-family:var(--display);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);text-align:center;margin-bottom:clamp(34px,5vw,56px)}
.quote{background:var(--white);border:1px solid var(--line);padding:32px 30px;display:flex;flex-direction:column;text-align:left}
.quote__stars{color:var(--gold);font-size:.85rem;letter-spacing:.18em;margin-bottom:.7rem}
.quote__text{font-style:italic;font-size:1.1rem;line-height:1.7;margin-bottom:1.3rem;color:var(--ink-soft);flex:1}
.quote__who{font-family:var(--display);font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
/* carousel */
.review-carousel{position:relative}
.review-track{display:flex;gap:26px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;padding:6px 2px}
.review-track::-webkit-scrollbar{display:none}
.review-track .quote{flex:0 0 calc((100% - 52px)/3);scroll-snap-align:start}
.car-controls{display:flex;gap:16px;justify-content:center;margin-top:clamp(30px,4vw,44px)}
.car-btn{width:46px;height:46px;border:1px solid var(--line);background:transparent;border-radius:50%;cursor:pointer;font-family:var(--serif);font-size:1.3rem;color:var(--ink);transition:.3s;display:inline-flex;align-items:center;justify-content:center}
.car-btn:hover{border-color:var(--gold);color:var(--gold)}
@media(max-width:900px){.review-track .quote{flex:0 0 86%}}

/* ---------- Restaurant links ---------- */
.eat-link{color:inherit;transition:color .3s}
.eat-link:hover{color:var(--gold)}
.eat-link::after{content:" \2197";font-size:.62em;color:var(--muted);vertical-align:super;opacity:.55}

/* ---------- Book direct ---------- */
.bookdirect{border:1px solid var(--gold);background:var(--white);padding:clamp(28px,4vw,46px);text-align:center;max-width:740px;margin:2.4rem auto 0}
.bookdirect .eyebrow{color:var(--gold);margin-bottom:.7rem}
.bookdirect p{margin-bottom:0}

/* ---------- Reveal animation (progressive enhancement) ---------- */
.js .reveal{opacity:0;transform:translateY(26px);transition:opacity 1s ease,transform 1s ease}
.js .reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .editorial{grid-template-columns:1fr;gap:30px}
  .editorial.reverse .editorial__media{order:0}
  .editorial.reverse .editorial__copy{order:0}
  .editorial__copy{max-width:none}
  .editorial__media img{aspect-ratio:4/3}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr;text-align:center;gap:30px}
  .footer-col,.footer-col--right{text-align:center}
  .footer-social{justify-content:center}
  .detail-grid{grid-template-columns:1fr;gap:24px}
}
@media(max-width:760px){
  .nav{grid-template-columns:auto 1fr auto}
  .nav__group{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);
    flex-direction:column;gap:0;padding:8px var(--pad) 22px;border-bottom:1px solid var(--line)}
  .nav__group.open{display:flex}
  .nav__group--right{order:3}
  .nav__group a.nav__link{padding:12px 0;width:100%;border-bottom:1px solid var(--line)}
  .nav__logo{justify-self:start}
  .nav__toggle{display:block;justify-self:end;order:3}
  .feature-cols{columns:1}
}
