@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,600;1,500;1,600&family=Inter:wght@400;600;800&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&display=swap');
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.65;color:#1A1A1A;background:#ffffff}
:root{--gold:#D4AF37;--gold-deep:#C49A22;--ink:#1A1A1A;--muted:#6B7280;--line:#EFE7CF}
.container{width:min(1200px,92%);margin:0 auto}

/* Headings use Playfair Display for a luxe feel */
h1,h2,h3{font-family:'Marcellus', serif;color:#1A1A1A;letter-spacing:.2px}

/* Header (white) */
header{position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid var(--line);backdrop-filter:saturate(160%) blur(6px)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 0}
.brand{font-family:'Cormorant Garamond', serif;font-style:italic;font-weight:600;letter-spacing:.2px;color:var(--gold);text-decoration:none;font-size:1.3rem}
header nav a{color:#2a2a2a;text-decoration:none;font-weight:600;margin-left:1.1rem;position:relative;padding:.2rem .1rem}
header nav a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transition:transform .2s ease}
header nav a:hover::after, header nav a.active::after{transform:scaleX(1)}

/* Hero: full video banner with overlayed text */
.hero{position:relative;min-height:72vh;display:grid;place-items:center;text-align:center;color:#111;overflow:hidden}
.hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(1.05) brightness(0.9)}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.35) 0%, rgba(255,255,255,.92) 75%)}
.hero .glitter{pointer-events:none;position:absolute;inset:0;background:
  radial-gradient(2px 2px at 20% 30%, rgba(212,175,55,.8), transparent 60%),
  radial-gradient(2px 2px at 70% 20%, rgba(212,175,55,.6), transparent 60%),
  radial-gradient(2px 2px at 40% 80%, rgba(212,175,55,.7), transparent 60%),
  radial-gradient(2px 2px at 80% 60%, rgba(212,175,55,.6), transparent 60%);
animation: drift 14s linear infinite;
opacity:.45}
@keyframes drift{
  0%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
  100%{transform:translateY(0)}
}

.hero-inner{position:relative;z-index:1;padding:4rem 1rem}
.hero h1{font-family:'Cormorant Garamond', serif;font-style:italic;font-weight:600;font-size:clamp(2.5rem,1.9rem + 2.8vw,3.6rem);letter-spacing:.2px;line-height:1.18;color:#fff}
.hero p{max-width:64ch;margin:.9rem auto 1.2rem;color:#fff;letter-spacing:.1px;text-shadow:0 1px 8px rgba(0,0,0,.25)}
.cta{display:flex;justify-content:center;gap:.8rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.15rem;border-radius:999px;border:1px solid var(--gold);background:var(--gold);color:#111;text-decoration:none;font-weight:800;box-shadow:0 6px 14px rgba(212,175,55,.18)}
.btn:hover{background:var(--gold-deep);border-color:var(--gold-deep)}
.btn.ghost{background:#fff;color:#111;border-color:var(--line)}
.btn.ghost:hover{border-color:var(--gold);color:#000}

/* Sections */
.section{padding:3.6rem 0}
.section h2{font-size:clamp(1.7rem,1.3rem + 1.3vw,2.3rem);margin-bottom:.6rem}
.section p.lead{color:#4B5563;max-width:70ch}
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:1.6rem 0}

/* Luxe cards & grids */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.2rem}
.card{background:#fff;border:1px solid #F2EAD0;border-radius:18px;padding:1.15rem;box-shadow:0 2px 18px rgba(0,0,0,.05)}
.card h3{margin-bottom:.35rem}
.card .price{font-weight:900;color:var(--gold);margin-top:.5rem}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.2rem}
.gallery img{width:100%;border-radius:14px;border:1px solid var(--line);box-shadow:0 6px 20px rgba(0,0,0,.06)}

/* Video grid section */
.videogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.2rem}
.videogrid .vwrap{position:relative;overflow:hidden;border-radius:16px;border:1px solid var(--line);box-shadow:0 8px 28px rgba(0,0,0,.08)}
.videogrid video{width:100%;height:100%;display:block;object-fit:cover}

/* Testimonials carousel */
.carousel{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:16px;background:#fff}
.slide{display:none;padding:1.2rem}
.slide.active{display:block}
.carousel-nav{display:flex;justify-content:center;gap:.6rem;margin-top:.6rem}
.dot{width:10px;height:10px;border-radius:999px;background:#e7dcb3;border:1px solid var(--line);cursor:pointer}
.dot.active{background:var(--gold)}

/* Footer (white) */
footer{margin-top:3rem;padding:2rem 0;border-top:1px solid var(--line);color:#6B7280;background:#fff}
.ribbon{background:linear-gradient(90deg,#fff, #fffbe8, #fff);border:1px solid var(--line);padding:1rem;border-radius:14px;box-shadow:0 8px 30px rgba(0,0,0,.05);display:flex;align-items:center;justify-content:space-between;gap:1rem}

@media (max-width:900px){
  .grid-3,.gallery,.videogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1.2rem}
}


/* --- Added: shimmer CTA + outline gold + over-hero header --- */
.btn.shimmer{position:relative;overflow:hidden}
.btn.shimmer::after{content:"";position:absolute;top:0;left:-150%;width:50%;height:100%;
  background:linear-gradient(120deg,rgba(255,255,255,0) 0%, rgba(255,255,255,.55) 50%, rgba(255,255,255,0) 100%);
  transform:skewX(-20deg);animation:shimmer 2.8s infinite}
@keyframes shimmer{0%{left:-150%}100%{left:200%}}

.no-outline{color:#fff;text-shadow:0 0 1px #D4AF37, 0 0 2px #D4AF37}
.no-outline{color:#fff;-webkit-text-stroke:.6px #D4AF37;text-shadow:0 0 1px #D4AF37}

body.over-hero header{background:#fff;border-bottom:1px solid var(--line)}
body.over-hero header{background:#fff;border-bottom:1px solid var(--line)}

.stacked .grid-3{grid-template-columns:1fr}

form label{display:flex;flex-direction:column;margin:.65rem 0}
form input, form select, form textarea{padding:.7rem .8rem;border-radius:12px;border:1px solid #EDE4C8;outline:none}

.stacked .container{max-width:860px}


@media (max-width: 768px){
  .container{width:94%}
  .nav{padding:.75rem 0}
  .brand{font-size:1.15rem}
  header nav a{margin-left:.8rem;font-size:.95rem}
  .hero{min-height:58vh}
  .hero-inner{padding:3rem 1rem 2.2rem}
  .hero h1{font-size:clamp(1.9rem, 4.8vw, 2.4rem)}
  .hero p{font-size:1rem}
  .cta{gap:.6rem}
  .btn, .btn.ghost{width:100%;justify-content:center;padding:.9rem 1rem}
  .grid-3{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr}
  .videogrid{grid-template-columns:1fr}
  form label{margin:.6rem 0}
  form input, form select, form textarea{font-size:16px} /* prevent iOS zoom */
}
