/* ========== RESET & BASE ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',sans-serif;color:#1a1a1a;background:#fafaf7;line-height:1.6;font-weight:400;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .25s ease}
button{font-family:inherit;cursor:pointer;border:none;background:none}
sup{font-size:.7em;vertical-align:super}

:root{
  --bg:#fafaf7;
  --bg-dark:#0f0e0c;
  --text:#1a1a1a;
  --text-muted:#6e6a62;
  --gold:#b08d57;
  --gold-light:#c9a978;
  --gold-dark:#8c6c3f;
  --line:#e8e3d8;
  --card:#fff;
  --header-h:80px;
}

.container{width:100%;max-width:1280px;margin:0 auto;padding:0 32px}
.section{padding:120px 0;position:relative}
.section.dark{background:var(--bg-dark);color:#f0ece2}
.section.dark .eyebrow,.section.dark h2,.section.dark h3{color:#f0ece2}
.center{text-align:center}

/* ========== TYPO ========== */
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:400;letter-spacing:-.01em;line-height:1.15;color:#0f0e0c}
h1{font-size:clamp(2.5rem,6vw,5rem);font-weight:300}
h2{font-size:clamp(2rem,4vw,3.4rem);font-weight:400}
h3{font-size:1.5rem;font-weight:500}
h4{font-size:1.05rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase}

.eyebrow{display:inline-block;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:24px;font-family:'Inter',sans-serif}
.eyebrow.light{color:var(--gold-light)}
.lead{font-size:1.18rem;color:var(--text-muted);margin-bottom:24px;font-weight:300}
p{color:var(--text-muted);margin-bottom:16px}
.section.dark p{color:#bcb6a8}

.section-head{margin-bottom:80px;max-width:680px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.section-head h2{margin-bottom:20px}
.section-sub{font-size:1.05rem;color:var(--text-muted);max-width:560px}
.section-head.center .section-sub{margin:0 auto}

/* ========== HEADER ========== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 0;transition:all .35s ease;background:rgba(250,250,247,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header.transparent{background:transparent;backdrop-filter:none;border-bottom:1px solid transparent}
.site-header.transparent .logo,.site-header.transparent .main-nav a,.site-header.transparent .burger span{color:#fff}
.site-header.transparent .burger span{background:#fff}
.site-header.scrolled{background:rgba(250,250,247,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:14px 0}
.site-header.scrolled .logo,.site-header.scrolled .main-nav a{color:#0f0e0c}
.site-header.scrolled .burger span{background:#0f0e0c}

.header-inner{max-width:1280px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between}

.logo{display:flex;align-items:center;gap:14px;color:#0f0e0c;font-family:'Cormorant Garamond',serif}
.logo-mark{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--gold);color:var(--gold);font-size:.95rem;font-weight:500;letter-spacing:.05em;font-family:'Cormorant Garamond',serif}
.logo-amp{margin:0 1px;font-size:.8em;opacity:.8}
.logo-text{font-size:1.35rem;font-weight:500;letter-spacing:.02em}

.main-nav{display:flex;gap:42px;align-items:center}
.main-nav a{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:#0f0e0c;position:relative;padding:6px 0}
.main-nav a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--gold);transition:width .3s ease}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.main-nav a.active{color:var(--gold)}

.burger{display:none;flex-direction:column;gap:5px;padding:8px;z-index:101}
.burger span{display:block;width:24px;height:1.5px;background:#0f0e0c;transition:all .3s ease}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);background:#0f0e0c!important}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);background:#0f0e0c!important}

/* ========== HERO ========== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;color:#fff}
.hero-image{position:absolute;inset:0;background-image:url('https://images.unsplash.com/photo-1577083552431-6e5fd01988ec?w=1920&q=80');background-size:cover;background-position:center;background-attachment:fixed;transform:scale(1.05);animation:slowZoom 20s ease-in-out infinite alternate}
@keyframes slowZoom{from{transform:scale(1.05)}to{transform:scale(1.12)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,14,12,.55) 0%,rgba(15,14,12,.4) 40%,rgba(15,14,12,.75) 100%)}
.hero-content{position:relative;z-index:2;max-width:880px;padding:0 32px}
.hero-tag{display:inline-block;font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-light);margin-bottom:32px;font-weight:500;padding:8px 20px;border:1px solid rgba(201,169,120,.4)}
.hero-title{font-family:'Cormorant Garamond',serif;font-size:clamp(3.5rem,9vw,7rem);font-weight:300;color:#fff;margin-bottom:24px;letter-spacing:-.02em;line-height:1}
.hero-subtitle{font-size:clamp(1.05rem,1.6vw,1.3rem);color:rgba(255,255,255,.85);font-weight:300;margin-bottom:48px;max-width:600px;margin-left:auto;margin-right:auto}
.hero-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2}
.hero-scroll span{display:block;width:1px;height:48px;background:linear-gradient(180deg,transparent,#fff,transparent);animation:scrollHint 2.2s ease-in-out infinite}
@keyframes scrollHint{0%,100%{opacity:.3;transform:translateY(0)}50%{opacity:1;transform:translateY(10px)}}

/* ========== BUTTONS ========== */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:16px 36px;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:500;border:1px solid transparent;transition:all .3s ease;cursor:pointer;font-family:'Inter',sans-serif}
.btn-primary{background:var(--gold);color:#fff;border-color:var(--gold)}
.btn-primary:hover{background:var(--gold-dark);border-color:var(--gold-dark);transform:translateY(-2px);box-shadow:0 10px 30px rgba(176,141,87,.3)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}
.btn-light{background:#fff;color:#0f0e0c;border-color:#fff}
.btn-light:hover{background:var(--gold);color:#fff;border-color:var(--gold)}

.link-arrow{display:inline-flex;align-items:center;gap:14px;color:var(--gold);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;margin-top:24px}
.link-arrow svg{transition:transform .3s ease}
.link-arrow:hover svg{transform:translateX(6px)}

/* ========== INTRO ========== */
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.intro-image{position:relative}
.intro-image img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover}
.intro-image-caption{position:absolute;bottom:24px;left:24px;background:rgba(255,255,255,.95);padding:10px 20px;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:500}

/* ========== FEATURES ========== */
.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px}
.feature{padding:32px 24px;position:relative;border-left:1px solid rgba(201,169,120,.25)}
.section:not(.dark) .feature{border-left-color:var(--line)}
.feature-icon{color:var(--gold);margin-bottom:24px}
.feature-num{font-family:'Cormorant Garamond',serif;font-size:2.5rem;color:var(--gold);font-weight:300;margin-bottom:16px;line-height:1}
.feature h3{margin-bottom:14px;color:inherit}
.feature p{font-size:.95rem;margin:0}

/* ========== GALLERY ========== */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;grid-auto-rows:340px}
.gallery-grid.full{grid-auto-rows:380px}
.gallery-large{grid-column:span 2;grid-row:span 2}
.gallery-tall{grid-row:span 2}
.gallery-item{position:relative;overflow:hidden;background:#222;cursor:pointer;display:block}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.6,.2,1);filter:brightness(.92)}
.gallery-item:hover img{transform:scale(1.06);filter:brightness(1)}
.gallery-info{position:absolute;left:0;right:0;bottom:0;padding:24px;background:linear-gradient(180deg,transparent,rgba(15,14,12,.85));color:#fff;transform:translateY(8px);transition:transform .4s ease}
.gallery-item:hover .gallery-info{transform:translateY(0)}
.gallery-cat{display:block;font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-light);margin-bottom:6px}
.gallery-info h3{color:#fff;font-size:1.3rem;margin:0}

.filter-bar{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:60px}
.filter-btn{padding:10px 22px;background:transparent;border:1px solid var(--line);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .3s ease}
.filter-btn:hover{border-color:var(--gold);color:var(--gold)}
.filter-btn.active{background:var(--gold);color:#fff;border-color:var(--gold)}

/* ========== PAGE HERO ========== */
.page-hero{padding:calc(var(--header-h) + 100px) 0 80px;background:#f3efe6;text-align:center;border-bottom:1px solid var(--line)}
.page-hero h1{margin-bottom:24px}
.page-hero p{max-width:600px;margin:0 auto;font-size:1.1rem;color:var(--text-muted);font-weight:300}

/* ========== ABOUT ========== */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center}
.about-grid.reverse .about-image{order:2}
.about-image img{width:100%;aspect-ratio:4/5;object-fit:cover}
.about-text h2{margin-bottom:24px}

/* ========== CTA BAND ========== */
.cta-band{background:linear-gradient(135deg,#1a1815 0%,#0f0e0c 100%);color:#fff;padding:120px 0}
.cta-inner{max-width:680px;margin:0 auto;text-align:center}
.cta-inner .eyebrow{color:var(--gold-light)}
.cta-inner h2{color:#fff;margin-bottom:24px}
.cta-inner p{color:rgba(255,255,255,.7);margin-bottom:40px;font-size:1.05rem}

/* ========== CONTACT ========== */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:stretch}
.contact-info{display:flex;flex-direction:column;gap:24px}
.contact-card{padding:36px;background:#fff;border:1px solid var(--line);transition:all .3s ease}
.contact-card:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 20px 50px rgba(0,0,0,.06)}
.contact-icon{color:var(--gold);margin-bottom:18px}
.contact-card h3{margin-bottom:10px;font-size:1.25rem}
.contact-card p{margin:0;font-size:.98rem}
.contact-map{min-height:460px;overflow:hidden;border:1px solid var(--line)}
.contact-map iframe{display:block;width:100%;height:100%}

.visit-section{background:#f3efe6}
.visit-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;align-items:center}
.visit-image img{width:100%;aspect-ratio:4/3;object-fit:cover}

/* ========== FOOTER ========== */
.site-footer{background:#0f0e0c;color:#bcb6a8;padding:80px 0 32px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:60px;margin-bottom:60px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand .logo{margin-bottom:20px;color:#fff}
.footer-brand .logo-mark{border-color:var(--gold-light);color:var(--gold-light)}
.footer-brand p{color:rgba(255,255,255,.55);font-size:.95rem}
.footer-col h4{color:#fff;margin-bottom:20px;font-size:.78rem;letter-spacing:.2em;font-family:'Inter',sans-serif;font-weight:600}
.footer-col a,.footer-col p{display:block;color:rgba(255,255,255,.55);font-size:.95rem;margin-bottom:10px}
.footer-col a:hover{color:var(--gold-light)}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(255,255,255,.4)}
.footer-bottom p{margin:0}

/* ========== LIGHTBOX ========== */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.95);display:none;align-items:center;justify-content:center;z-index:9999;opacity:0;transition:opacity .3s}
.lightbox.active{display:flex;opacity:1}
.lightbox img{max-width:90%;max-height:90%;object-fit:contain}
.lightbox-close{position:absolute;top:24px;right:32px;color:#fff;font-size:48px;cursor:pointer;line-height:1;font-weight:200}

/* ========== ANIMATIONS REVEAL ========== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s cubic-bezier(.2,.6,.2,1),transform 1s cubic-bezier(.2,.6,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}
.reveal{animation:revealFallback 1.2s ease .5s forwards}

/* ========== RESPONSIVE ========== */
@media(max-width:1024px){
  .section{padding:90px 0}
  .intro-grid,.about-grid,.contact-grid,.visit-grid{grid-template-columns:1fr;gap:60px}
  .about-grid.reverse .about-image{order:0}
  .features-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:300px}
  .gallery-large{grid-column:span 2}
  .gallery-tall{grid-row:span 1}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px}
}

@media(max-width:768px){
  .container{padding:0 22px}
  .section{padding:70px 0}
  .header-inner{padding:0 22px}
  .main-nav{position:fixed;top:0;right:-100%;width:80%;max-width:340px;height:100vh;background:#fff;flex-direction:column;align-items:flex-start;padding:100px 36px 40px;gap:24px;transition:right .4s ease;box-shadow:-10px 0 40px rgba(0,0,0,.15)}
  .main-nav.open{right:0}
  .main-nav a{color:#0f0e0c;font-size:1rem}
  .burger{display:flex}
  .site-header.transparent.has-mobile-open .burger span{background:#0f0e0c}
  .hero{min-height:90vh}
  .hero-image{background-attachment:scroll}
  .hero-cta{flex-direction:column;width:100%;max-width:280px;margin:0 auto}
  .hero-cta .btn{width:100%}
  .features-grid{grid-template-columns:1fr;gap:24px}
  .feature{border-left:none;border-top:1px solid var(--line);padding:24px 0}
  .section.dark .feature{border-top-color:rgba(201,169,120,.15)}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:280px}
  .gallery-large,.gallery-tall{grid-column:span 1;grid-row:span 1}
  .footer-grid{grid-template-columns:1fr;gap:36px}
  .footer-bottom{flex-direction:column;text-align:center}
  .section-head{margin-bottom:50px}
  .page-hero{padding:calc(var(--header-h) + 60px) 0 60px}
  .cta-band{padding:80px 0}
}
