
:root{
  --c-ink:#0e1f24; --c-ink-2:#1a3036; --c-body:#1a2328; --c-muted:#5b6b6f;
  --c-line:#e5dfd3; --c-sand:#f7f1e3; --c-paper:#fdfaf2; --c-white:#fff;
  --c-coral:#c6573d; --c-coral-2:#a63f26; --c-honey:#c89a3b; --c-sea:#1d6b75;
  --sh-sm:0 1px 2px rgba(14,31,36,.06);
  --sh-md:0 10px 30px -12px rgba(14,31,36,.25);
  --sh-lg:0 30px 80px -30px rgba(14,31,36,.45);
  --r-sm:4px; --r-md:10px; --r-lg:22px;
  --container:1200px; --container-narrow:760px;
  --font-display:'Fraunces',Georgia,'Times New Roman',serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font-family:var(--font-body);font-size:17px;line-height:1.65;color:var(--c-body);background:var(--c-sand);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img,video,iframe{max-width:100%;display:block}
a{color:var(--c-coral);text-decoration:none;transition:color .18s ease}
a:hover{color:var(--c-coral-2)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;color:var(--c-ink);line-height:1.15;letter-spacing:-.012em;margin:0 0 .6em;font-variation-settings:"opsz" 36}
h1{font-size:clamp(2.4rem,5.6vw,4.4rem);font-weight:700;letter-spacing:-.02em;font-variation-settings:"opsz" 96}
h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-top:1.4em}
h3{font-size:1.28rem;margin-top:1.4em}
h4{font-size:1.05rem}
p{margin:0 0 1.1em}

/* ---------- nav ---------- */
.site-nav{position:sticky;top:0;z-index:50;background:rgba(253,250,242,.94);backdrop-filter:saturate(140%) blur(10px);-webkit-backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--c-line)}
.nav-inner{max-width:var(--container);margin:0 auto;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.logo{display:flex;align-items:center;gap:12px;color:var(--c-ink)}
.logo:hover{color:var(--c-ink)}
.logo img{height:56px;width:auto}
.logo-text{font-family:var(--font-display);font-size:1.4rem;font-weight:700;letter-spacing:-.02em;line-height:1}
.logo-text small{display:block;font-family:var(--font-body);font-size:.65rem;text-transform:uppercase;letter-spacing:.18em;color:var(--c-muted);margin-top:3px;font-weight:500}
.nav-links{display:flex;gap:22px;list-style:none;margin:0;padding:0;align-items:center}
.nav-links a{color:var(--c-ink);font-size:.9rem;font-weight:500;padding:6px 0;border-bottom:2px solid transparent;transition:border-color .18s ease,color .18s ease}
.nav-links a:hover{color:var(--c-coral)}
.nav-links a.active{border-bottom-color:var(--c-coral)}
.nav-cta{background:var(--c-coral);color:var(--c-white)!important;padding:9px 18px!important;border-radius:999px;font-weight:600;border-bottom:none!important}
.nav-cta:hover{background:var(--c-coral-2);border-bottom:none!important}
.nav-toggle{display:none;background:none;border:1px solid var(--c-line);border-radius:var(--r-sm);padding:6px 12px;font-size:1.15rem;cursor:pointer;color:var(--c-ink)}
@media (max-width:1000px){
  .nav-toggle{display:inline-block}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--c-paper);border-bottom:1px solid var(--c-line);padding:16px 24px 22px;gap:6px;box-shadow:var(--sh-md)}
  .nav-links.open{display:flex}
  .nav-links li{border-bottom:1px solid var(--c-line)}
  .nav-links li:last-child{border-bottom:none}
  .nav-links a{padding:12px 0;display:block}
  .nav-cta{margin-top:8px;text-align:center}
  .nav-inner{position:relative}
  .logo img{height:48px}
}

/* ---------- hero (rotating + static) ---------- */
.hero{position:relative;min-height:82vh;padding:80px 24px 60px;color:var(--c-white);display:flex;align-items:center;justify-content:center;text-align:center;isolation:isolate;overflow:hidden;background:var(--c-ink)}
.hero-static{background-size:cover;background-position:center}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,31,36,.18) 0%,rgba(14,31,36,.55) 55%,rgba(14,31,36,.82) 100%);z-index:1}
.hero-content{position:relative;z-index:2;max-width:860px;width:100%}
.hero-logo{max-height:240px;width:auto;margin:0 auto 32px;filter:drop-shadow(0 4px 24px rgba(0,0,0,.4))}
.hero h1{color:var(--c-white);text-shadow:0 2px 24px rgba(0,0,0,.3)}
.hero-subtitle{font-size:clamp(1.05rem,1.6vw,1.35rem);color:rgba(255,255,255,.94);margin:0 auto 32px;max-width:50ch;line-height:1.55}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* rotating slides on home hero */
.hero-slides{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;animation:heroFade 28s infinite}
.hero-slide:nth-child(1){animation-delay:0s}
.hero-slide:nth-child(2){animation-delay:7s}
.hero-slide:nth-child(3){animation-delay:14s}
.hero-slide:nth-child(4){animation-delay:21s}
@keyframes heroFade{
  0%,22%{opacity:1}
  28%,97%{opacity:0}
  100%{opacity:1}
}
@media (prefers-reduced-motion:reduce){
  .hero-slide{animation:none;opacity:0}
  .hero-slide:nth-child(1){opacity:1}
}

/* interior page hero */
.hero-inner-page{min-height:44vh;padding:80px 24px 60px;text-align:left}
.hero-inner-page .hero-content{max-width:var(--container)}
.hero-inner-page .hero-logo{max-height:120px;margin:0 0 24px}
.breadcrumbs{font-size:.8rem;text-transform:uppercase;letter-spacing:.14em;margin-bottom:18px;color:rgba(255,255,255,.78)}
.breadcrumbs a{color:rgba(255,255,255,.78)}
.breadcrumbs a:hover{color:var(--c-white)}
.crumb-sep{margin:0 8px;opacity:.6}

/* ---------- buttons ---------- */
.btn{display:inline-block;padding:13px 28px;border-radius:999px;font-weight:600;font-size:.95rem;letter-spacing:.01em;box-shadow:var(--sh-sm);transition:transform .15s ease,background .18s ease,box-shadow .18s ease;border:none;cursor:pointer;text-align:center}
.btn-primary{background:var(--c-coral);color:var(--c-white)}
.btn-primary:hover{background:var(--c-coral-2);color:var(--c-white);transform:translateY(-1px);box-shadow:var(--sh-md)}
.btn-ghost{background:transparent;color:var(--c-white);border:1.5px solid rgba(255,255,255,.65)}
.btn-ghost:hover{background:rgba(255,255,255,.12);color:var(--c-white);border-color:var(--c-white)}
.btn-outline{background:transparent;color:var(--c-ink);border:1.5px solid var(--c-ink)}
.btn-outline:hover{background:var(--c-ink);color:var(--c-white)}

/* ---------- sections ---------- */
.site-main{min-height:50vh}
.section{max-width:var(--container);margin:0 auto;padding:80px 24px}
.section-narrow{max-width:var(--container-narrow)}
.section-dark{background:var(--c-ink);color:var(--c-sand)}
.section-dark h1,.section-dark h2,.section-dark h3{color:var(--c-white)}
.section-sand{background:var(--c-paper)}
.section-heading{text-align:center;margin-bottom:48px}
.section-heading .eyebrow{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.22em;color:var(--c-coral);font-weight:600;margin-bottom:14px}
.section-heading h2{margin-top:0}
.lead{font-size:1.15rem;color:var(--c-ink-2);line-height:1.6;max-width:56ch}
.lead-center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- three-up feature grid (home) ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
@media (max-width:900px){.features{grid-template-columns:1fr}}
.feature{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--c-ink);aspect-ratio:4/5;display:flex;align-items:flex-end;color:var(--c-white);text-decoration:none;background-size:cover;background-position:center;transition:transform .25s ease,box-shadow .25s ease}
.feature:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.feature::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(14,31,36,0) 30%,rgba(14,31,36,.85) 100%);transition:opacity .3s ease}
.feature:hover::after{opacity:.75}
.feature-inner{position:relative;z-index:1;padding:30px;width:100%;color:var(--c-white)}
.feature-inner h3{color:var(--c-white);margin:0 0 6px;font-size:1.7rem}
.feature-inner p{margin:0 0 14px;font-size:.95rem;color:rgba(255,255,255,.92)}
.feature-inner .arrow{font-size:.85rem;text-transform:uppercase;letter-spacing:.14em;font-weight:600;color:var(--c-sand)}

/* ---------- gallery strip ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media (max-width:760px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
.gallery-grid img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--r-md);background:var(--c-ink);transition:transform .3s ease}
.gallery-grid img:hover{transform:scale(1.02)}
.gallery-grid img:nth-child(1),.gallery-grid img:nth-child(6){aspect-ratio:1/1.2}

/* ---------- menu ---------- */
.menu-nav{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:0 0 48px}
.menu-nav a{padding:8px 18px;border-radius:999px;background:var(--c-paper);color:var(--c-ink);font-size:.88rem;font-weight:500;border:1px solid var(--c-line)}
.menu-nav a:hover{background:var(--c-ink);color:var(--c-white);border-color:var(--c-ink)}
.menu-category{margin-bottom:64px;scroll-margin-top:80px}
.menu-category-head{text-align:center;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid var(--c-line)}
.menu-category-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem);margin:0 0 6px}
.menu-category-head .note{font-style:italic;color:var(--c-muted);font-size:.95rem}
.menu-items{display:grid;grid-template-columns:1fr 1fr;gap:28px 44px}
@media (max-width:720px){.menu-items{grid-template-columns:1fr}}
.menu-item-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:4px}
.menu-item-name{font-family:var(--font-display);font-weight:600;color:var(--c-ink);font-size:1.12rem}
.menu-item-leader{flex:1;border-bottom:1.5px dotted var(--c-line);margin:0 6px 6px}
.menu-item-price{font-weight:600;color:var(--c-ink);white-space:nowrap}
.menu-item-desc{color:var(--c-muted);font-size:.92rem;margin:0}
.menu-tag{display:inline-block;font-size:.65rem;letter-spacing:.12em;font-weight:700;text-transform:uppercase;padding:2px 7px;border-radius:3px;margin-left:8px;vertical-align:middle}
.menu-tag-vg{background:#1e6b4e;color:#fff}
.menu-tag-v{background:#2a7a5c;color:#fff;opacity:.85}
.menu-photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:48px 0}
@media (max-width:720px){.menu-photo-strip{grid-template-columns:1fr}}
.menu-photo-strip img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-md)}

/* ---------- events ---------- */
.event-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
@media (max-width:760px){.event-grid{grid-template-columns:1fr}}
.event-card{background:var(--c-paper);border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--c-line);display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease}
.event-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.event-card img{width:100%;aspect-ratio:16/10;object-fit:cover;background:var(--c-ink)}
.event-card-body{padding:26px 26px 28px;flex:1;display:flex;flex-direction:column}
.event-when{font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--c-coral);font-weight:600;margin-bottom:8px}
.event-card h3{margin:0 0 12px;font-size:1.5rem}
.event-card p{margin:0 0 18px;font-size:.95rem;flex:1}
.event-card .btn{align-self:flex-start}

/* ---------- guesthouse ---------- */
.guesthouse{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
@media (max-width:800px){.guesthouse{grid-template-columns:1fr}}
.guesthouse img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r-lg);background:var(--c-ink)}
.guesthouse-body .eyebrow{font-size:.78rem;text-transform:uppercase;letter-spacing:.22em;color:var(--c-coral);font-weight:600;display:block;margin-bottom:14px}

/* ---------- about page ---------- */
.about-logo-wrap{display:flex;justify-content:center;margin:0 0 36px}
.about-logo{height:200px;width:auto;filter:drop-shadow(0 4px 14px rgba(14,31,36,.12))}
@media (max-width:640px){.about-logo{height:140px}}
.about-photo{width:100%;border-radius:var(--r-lg);margin:32px 0;aspect-ratio:16/10;object-fit:cover}
.about-grid-photos{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:32px 0}
@media (max-width:600px){.about-grid-photos{grid-template-columns:1fr}}
.about-grid-photos img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--r-md)}

/* ---------- instagram strip ---------- */
.insta-strip{background:var(--c-ink);color:var(--c-sand);padding:72px 24px;text-align:center}
.insta-strip h2{color:var(--c-white);margin-top:0}
.insta-strip .eyebrow{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.22em;color:var(--c-coral);font-weight:600;margin-bottom:14px}
.insta-handle{font-family:var(--font-display);font-size:1.15rem;color:var(--c-sand)}
.insta-handle a{color:var(--c-sand);border-bottom:1px solid rgba(245,239,225,.4)}
.insta-handle a:hover{color:var(--c-white);border-bottom-color:var(--c-white)}
.behold-holder{margin:36px auto 0;max-width:var(--container)}
.behold-placeholder{margin:36px auto 0;max-width:720px;padding:32px;border-radius:var(--r-lg);background:rgba(255,255,255,.05);border:1px dashed rgba(255,255,255,.2);font-size:.92rem;color:rgba(245,239,225,.75)}

/* ---------- articles ---------- */
.article-body{font-size:1.07rem;line-height:1.72}
.article-body h2{margin-top:2em;font-size:1.6rem}
.article-body h3{margin-top:1.6em;font-size:1.22rem}
.article-body p{margin:0 0 1.2em}
.article-body a{color:var(--c-coral);border-bottom:1px solid rgba(198,87,61,.3)}
.article-body a:hover{border-bottom-color:var(--c-coral)}
.article-body ul,.article-body ol{margin:0 0 1.4em}
.article-body li{margin-bottom:.55em}
.article-body blockquote{margin:1.5em 0;padding:6px 0 6px 22px;border-left:3px solid var(--c-coral);font-style:italic;color:var(--c-ink-2)}
.article-body img{width:100%;border-radius:var(--r-md);margin:24px 0}
.article-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px}
.article-card{display:block;background:var(--c-white);border-radius:var(--r-lg);overflow:hidden;text-decoration:none;color:var(--c-ink);box-shadow:var(--sh-sm);transition:transform .2s ease,box-shadow .2s ease}
.article-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md);color:var(--c-ink)}
.article-card img{width:100%;aspect-ratio:16/10;object-fit:cover}
.article-card-inner{padding:22px 24px 26px}
.article-date{display:inline-block;font-size:.75rem;text-transform:uppercase;letter-spacing:.14em;color:var(--c-coral);font-weight:600;margin-bottom:8px}
.article-card h3{margin:0 0 10px;font-size:1.25rem}
.article-card p{margin:0;color:var(--c-muted);font-size:.93rem}
.article-meta{font-size:.85rem;color:var(--c-muted);margin:0 0 28px;padding-bottom:24px;border-bottom:1px solid var(--c-line)}

/* ---------- FAQ ---------- */
.faq-list details{border-bottom:1px solid var(--c-line);padding:18px 0}
.faq-list details:first-child{border-top:1px solid var(--c-line)}
.faq-list summary{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--c-ink);cursor:pointer;list-style:none;position:relative;padding-right:32px;outline:none}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:1.6rem;color:var(--c-coral);font-weight:400;transition:transform .2s ease;line-height:1}
.faq-list details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.faq-answer{padding-top:12px}
.faq-answer p{margin:0}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:start}
@media (max-width:800px){.contact-grid{grid-template-columns:1fr}}
.contact-item{margin-bottom:28px}
.contact-item h4{font-family:var(--font-body);font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;color:var(--c-muted);margin-bottom:6px;font-weight:600}
.contact-item .big{font-family:var(--font-display);font-size:1.35rem;color:var(--c-ink);font-weight:600}
.contact-item .big a{color:var(--c-ink);border-bottom:2px solid var(--c-coral)}
.contact-item .big a:hover{color:var(--c-coral)}
.hours-table{width:100%;border-collapse:collapse;margin-bottom:20px}
.hours-table td{padding:8px 0;border-bottom:1px solid var(--c-line);font-size:.95rem}
.hours-table td:first-child{font-weight:600;color:var(--c-ink)}
.hours-table td:last-child{color:var(--c-muted);text-align:right}

/* ---------- footer ---------- */
.site-footer{background:var(--c-ink);color:rgba(255,255,255,.82);padding:64px 0 28px;margin-top:80px}
.footer-inner{max-width:var(--container);margin:0 auto;padding:0 24px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
@media (max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:32px}.footer-brand{grid-column:1/-1}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{height:64px;margin-bottom:14px;filter:brightness(0) invert(1)}
.footer-brand .logo-text{color:var(--c-white);font-size:1.4rem}
.footer-brand p{max-width:36ch;color:rgba(255,255,255,.7);font-size:.93rem}
.footer-logo-link{display:inline-flex;align-items:center;gap:14px;color:inherit;text-decoration:none;margin-bottom:14px}
.footer-logo-link:hover{color:var(--c-coral)}
.footer-col h4{color:var(--c-white);font-family:var(--font-body);font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.16em;margin:4px 0 16px}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:10px}
.footer-col a{color:rgba(255,255,255,.78);font-size:.92rem}
.footer-col a:hover{color:var(--c-white)}
.footer-socials{display:flex;gap:14px;margin-top:16px;flex-wrap:wrap}
.footer-socials a{color:rgba(255,255,255,.7);border-bottom:1px solid rgba(255,255,255,.2);padding-bottom:1px;font-size:.9rem}
.footer-socials a:hover{color:var(--c-white);border-bottom-color:var(--c-coral)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;font-size:.82rem;color:rgba(255,255,255,.55);text-align:center}

::selection{background:var(--c-coral);color:var(--c-white)}
:focus-visible{outline:2px solid var(--c-coral);outline-offset:3px;border-radius:2px}

@media (max-width:600px){
  body{font-size:16px}
  .section{padding:56px 22px}
  .hero{min-height:72vh;padding:60px 22px 50px}
  .hero-logo{max-height:160px}
  .site-footer{padding:48px 0 24px;margin-top:56px}
}
