
:root{
  --bg:#fdfcf9;--bg2:#faf7f2;--text:#171613;--muted:#6b6a67;--gold:#cdb47a;--gold-deep:#b89d5a;--border:#e7e3d9;--shadow:0 30px 80px rgba(0,0,0,.25);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}
h1,h2,h3{font-family:"Playfair Display",Georgia,serif;letter-spacing:.2px}
a{color:inherit;text-decoration:none}
.nav{position:fixed;top:0;left:0;right:0;height:74px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);z-index:100;transition:box-shadow .3s ease}
.nav.scrolled{box-shadow:0 8px 25px rgba(0,0,0,.08)}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;font-size:20px}
.brand .dot{width:12px;height:12px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 8px rgba(205,180,122,.2)}
.menu{display:flex;gap:22px;align-items:center}
.menu a{font-weight:600;color:#222;position:relative}
.menu a::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:2px;background:var(--gold);transition:.3s}
.menu a:hover::after{width:100%}
.nav .btn{background:linear-gradient(90deg,var(--gold),var(--gold-deep));color:#111;border-radius:16px;padding:.7rem 1rem;font-weight:700;margin-left:20px;box-shadow:0 10px 25px rgba(184,157,90,.3)}
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(1.05) contrast(1.1) saturate(1.35);transform:translateY(var(--parallax,0)) scale(1.08);transition:transform 600ms ease}
.overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.45))}
.hero-content{position:relative;z-index:2;text-align:center;color:#fff;padding-bottom:12vh}
.hero-content h1{font-size:clamp(56px,8vw,112px);line-height:1.06;margin-bottom:14px;background:linear-gradient(90deg,#fff,#f7e3a8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 6px 22px rgba(0,0,0,.4)}
.hero-content p{font-size:22px;max-width:760px;margin:0 auto 22px;line-height:1.55;color:#f5f5f5}
.btn{display:inline-flex;align-items:center;justify-content:center;border-radius:16px;padding:14px 26px;font-weight:700;border:1px solid rgba(0,0,0,.06)}
.btn--gold{background:linear-gradient(90deg,var(--gold),var(--gold-deep));color:#111;box-shadow:0 15px 30px rgba(184,157,90,.35)}
.btn--glass{background:rgba(255,255,255,.65);backdrop-filter:blur(8px);color:#111}
section{padding:90px 0;text-align:center}
.section-title{font-size:42px;margin-bottom:26px}
.section-sub{color:#6b6a67;max-width:800px;margin:0 auto 26px}
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px;padding:0 24px}
.gallery-grid img, .card-photo{width:100%;height:360px;object-fit:cover;border-radius:18px;box-shadow:0 10px 30px rgba(0,0,0,.12);transition:transform .6s ease, box-shadow .6s ease}
.gallery-grid img:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 50px rgba(0,0,0,.18)}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:22px;padding:0 24px}
.card{position:relative;border-radius:22px;overflow:hidden;background:#fff;border:1px solid #e7e3d9;box-shadow:0 15px 40px rgba(0,0,0,.08)}
.card-body{position:absolute;left:0;right:0;bottom:0;padding:18px;background:linear-gradient(0deg,rgba(0,0,0,.55),rgba(0,0,0,.05));color:#fff;text-align:left}
.badge{display:inline-block;background:rgba(255,255,255,.85);color:#111;border-radius:999px;padding:6px 12px;font-weight:700;font-size:12px;border:1px solid rgba(0,0,0,.06)}
.stripe{background:linear-gradient(90deg,#fff, #fff6e0, #fff);border-top:1px solid #e7e3d9;border-bottom:1px solid #e7e3d9;padding:26px 24px}
.stripe .inner{max-width:1200px;margin:0 auto;display:flex;gap:16px;flex-wrap:wrap;align-items:center;justify-content:center}
.stripe b{font-size:18px}
.features{max-width:1000px;margin:0 auto;text-align:left;padding:0 24px}
.features ul{list-style:none;padding:0;display:grid;gap:10px;font-size:17px;color:#444}
.features li{display:flex;gap:10px;align-items:center}
footer{border-top:1px solid #e7e3d9;background:#faf7f2;color:#333;padding:44px 20px;text-align:center}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px;max-width:1100px;margin:0 auto;text-align:left}
footer a{color:#555;text-decoration:none}
footer a:hover{color:#b89d5a}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.85);display:none;align-items:center;justify-content:center;z-index:200}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:16px;box-shadow:0 20px 80px rgba(0,0,0,.5)}
.lightbox .close{position:fixed;top:18px;right:18px;background:#fff;border:none;border-radius:12px;padding:10px 14px;font-weight:800}
@media(max-width:860px){.hero-content{padding-bottom:16vh}.gallery-grid img,.card-photo{height:300px}}
.map-section{padding:0;background:#faf7f2;border-top:1px solid #e7e3d9;border-bottom:1px solid #e7e3d9}
.map-wrap{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch;padding:60px 24px}
.map-card{background:#fff;border:1px solid #e7e3d9;border-radius:22px;box-shadow:0 20px 60px rgba(0,0,0,.08);padding:26px;text-align:left;display:flex;flex-direction:column;justify-content:center}
.map-card h3{font-size:36px;margin:0 0 8px}
.map-card p{color:#6b6a67;margin:0 0 14px}
.map-card .contact-list{display:grid;gap:10px;margin-top:8px}
.map-embed{border-radius:22px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.08);border:1px solid #e7e3d9}
.map-embed iframe{width:100%;height:100%;min-height:420px;border:0;display:block}
.sep{height:2px;width:80px;background:linear-gradient(90deg,#cdb47a,#b89d5a);border-radius:2px;margin:10px 0 18px}
@media(max-width:980px){.map-wrap{grid-template-columns:1fr}.map-embed iframe{min-height:360px}}
