:root{
  --background:#fdfcfa;
  --foreground:#2a2320;
  --cream:#faf6f0;
  --beige:#ece2d3;
  --rose:#c98a96;
  --rose-soft:#f1d9dd;
  --sage:#b3c7b1;
  --gold:#d3b074;
  --primary:#b56b78;
  --primary-foreground:#fdfcfa;
  --muted:#f4efe8;
  --muted-foreground:#7a6e66;
  --border:#ebe3d8;
  --card:#ffffff;
  --radius:1rem;
  --font-display:"Cormorant Garamond","Playfair Display",Georgia,serif;
  --font-sans:"Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;border:0 solid var(--border)}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);background:var(--background);color:var(--foreground);font-weight:400;line-height:1.5;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:transparent}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;letter-spacing:-0.01em;line-height:1.1}
.italic{font-style:italic}
.container{max-width:1280px;margin:0 auto;padding:0 24px}
@media(min-width:1024px){.container{padding:0 40px}}

.text-gradient{background:linear-gradient(135deg,var(--rose),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.text-balance{text-wrap:balance}
.shadow-card{box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12)}
.shadow-soft{box-shadow:0 10px 40px -20px rgba(181,107,120,.5)}
.shadow-hover{box-shadow:0 20px 60px -20px rgba(181,107,120,.45)}
.section-label{font-size:11px;text-transform:uppercase;letter-spacing:.4em;color:rgba(181,107,120,.85);margin-bottom:16px}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;transition:all .5s ease;border-bottom:1px solid transparent}
.nav.scrolled{backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);background:rgba(253,252,250,.7);border-bottom-color:rgba(235,227,216,.6)}
.nav-inner{height:80px;display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:0 24px}
@media(min-width:1024px){.nav-inner{padding:0 40px}}
.brand{font-family:var(--font-display);font-size:24px;letter-spacing:.02em;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.25)}
.nav.scrolled .brand{color:var(--foreground);text-shadow:none}
.nav-links{display:none;gap:32px;align-items:center}
@media(min-width:1024px){.nav-links{display:flex}}
.nav-links a{font-size:14px;font-weight:500;color:rgba(255,255,255,.92);transition:color .3s}
.nav-links a:hover{color:#fff}
.nav.scrolled .nav-links a{color:rgba(42,35,32,.8)}
.nav.scrolled .nav-links a:hover{color:var(--primary)}
.nav-actions{display:flex;align-items:center;gap:12px}
.btn-primary{display:inline-flex;align-items:center;border-radius:999px;background:var(--primary);color:var(--primary-foreground);padding:10px 22px;font-size:14px;font-weight:500;box-shadow:0 10px 40px -20px rgba(181,107,120,.5);transition:opacity .3s}
.btn-primary:hover{opacity:.9}
.btn-soft{display:inline-flex;align-items:center;border-radius:999px;background:var(--rose-soft);color:var(--foreground);padding:14px 28px;font-weight:500;box-shadow:0 10px 40px -20px rgba(181,107,120,.5);transition:all .3s}
.btn-soft:hover{background:var(--rose);color:var(--primary-foreground)}
.btn-ghost-light{display:inline-flex;align-items:center;border-radius:999px;background:rgba(255,255,255,.1);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.4);color:#fff;padding:14px 28px;font-weight:500;transition:all .3s}
.btn-ghost-light:hover{background:#fff;color:var(--foreground)}
.menu-btn{display:inline-flex;height:40px;width:40px;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(255,255,255,.4);color:#fff}
.nav.scrolled .menu-btn{border-color:var(--border);color:var(--foreground)}
@media(min-width:1024px){.menu-btn{display:none}}
.menu-btn span{display:block;width:18px;height:1px;background:currentColor;margin:3px 0}
.btn-primary.hide-sm{display:none}
@media(min-width:768px){.btn-primary.hide-sm{display:inline-flex}}
.mobile-menu{display:none;border-top:1px solid var(--border);background:rgba(253,252,250,.95);backdrop-filter:blur(14px)}
.mobile-menu.open{display:block}
.mobile-menu-inner{padding:16px 24px;display:flex;flex-direction:column;gap:12px}
.mobile-menu a{padding:6px 0;color:rgba(42,35,32,.8)}

/* HERO */
.hero{position:relative;min-height:100vh;width:100%;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,.32),rgba(0,0,0,.1) 40%,var(--background))}
.hero-content{position:relative;z-index:10;max-width:1280px;margin:0 auto;padding:160px 24px 96px;min-height:100vh;display:flex;flex-direction:column;justify-content:center}
@media(min-width:1024px){.hero-content{padding:160px 40px 96px}}
.hero-eyebrow{color:rgba(255,255,255,.85);letter-spacing:.4em;font-size:12px;text-transform:uppercase;margin-bottom:24px}
.hero-title{color:#fff;font-size:clamp(56px,9vw,128px);line-height:.95;max-width:880px}
.hero-sub{margin-top:32px;max-width:560px;font-size:18px;color:rgba(255,255,255,.92);line-height:1.6}
.hero-cta{margin-top:40px;display:flex;flex-wrap:wrap;gap:16px}
.scroll-cue{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.7);font-size:11px;letter-spacing:.3em;text-transform:uppercase}

/* SECTIONS */
section{padding:128px 0}
.bg-cream{background:var(--cream)}
.section-head{text-align:center;margin-bottom:64px}
.section-h{font-size:clamp(40px,6vw,72px)}
.section-sub{margin-top:16px;color:var(--muted-foreground);max-width:560px;margin-left:auto;margin-right:auto}

/* ABOUT */
.about-text{margin-top:32px;font-size:18px;color:var(--muted-foreground);line-height:1.7;max-width:720px;margin-left:auto;margin-right:auto}
.stats{margin-top:64px;display:grid;grid-template-columns:1fr;gap:32px;text-align:left}
@media(min-width:640px){.stats{grid-template-columns:repeat(3,1fr)}}
.stat{border-radius:16px;background:var(--background);padding:32px;box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12)}
.stat-num{font-family:var(--font-display);font-size:48px;background:linear-gradient(135deg,var(--rose),var(--gold));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat-l{margin-top:8px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-foreground)}

/* COLLECTIONS */
.cards{display:grid;grid-template-columns:1fr;gap:32px}
@media(min-width:640px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.cards{grid-template-columns:repeat(4,1fr)}}
.card{position:relative;overflow:hidden;border-radius:24px;background:var(--card);box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12);transition:box-shadow .5s}
.card:hover{box-shadow:0 20px 60px -20px rgba(181,107,120,.45)}
.card-img{aspect-ratio:3/4;overflow:hidden}
.card-img img{height:100%;width:100%;object-fit:cover;transition:transform 1.2s}
.card:hover .card-img img{transform:scale(1.1)}
.card-body{padding:28px}
.card-tone{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--primary)}
.card-name{margin-top:8px;font-family:var(--font-display);font-size:24px}
.card-desc{margin-top:8px;font-size:14px;color:var(--muted-foreground);line-height:1.6}
.card-foot{margin-top:20px;display:flex;align-items:center;justify-content:space-between}
.card-foot a{color:var(--primary);font-weight:500;font-size:14px}
.card-foot a:hover{text-decoration:underline}

/* OCCASIONS */
.occ-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:640px){.occ-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.occ-grid{grid-template-columns:repeat(3,1fr)}}
.occ{padding:32px;border-radius:16px;background:var(--background);border:1px solid var(--border);transition:all .5s;height:100%;box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12)}
.occ:hover{border-color:var(--rose);transform:translateY(-4px)}
.occ-dot{height:48px;width:48px;border-radius:999px;background:linear-gradient(135deg,#e9b6c1,#e8d2a3);margin-bottom:24px;transition:transform .5s}
.occ:hover .occ-dot{transform:scale(1.1)}
.occ h3{font-size:24px}
.occ p{margin-top:8px;font-size:14px;color:var(--muted-foreground);line-height:1.6}

/* DELIVERY */
.delivery{display:grid;grid-template-columns:1fr;gap:64px;align-items:center}
@media(min-width:1024px){.delivery{grid-template-columns:repeat(2,1fr)}}
.delivery-img{border-radius:24px;overflow:hidden;box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12)}
.delivery h2{text-align:left}
.delivery-sub{margin-top:24px;font-size:18px;color:var(--muted-foreground);line-height:1.7}
.delivery-list{margin-top:32px;list-style:none}
.delivery-list li{display:flex;gap:16px;border-top:1px solid var(--border);padding:16px 0;align-items:flex-start}
.delivery-list strong{font-family:var(--font-display);font-weight:500;font-size:20px;color:var(--primary);min-width:130px}
.delivery-list span{color:var(--muted-foreground)}

/* GALLERY masonry */
.masonry{column-count:1;column-gap:24px}
@media(min-width:640px){.masonry{column-count:2}}
@media(min-width:1024px){.masonry{column-count:3}}
.masonry-item{margin-bottom:24px;break-inside:avoid;overflow:hidden;border-radius:16px;box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12)}
.masonry-item img{transition:transform 1.2s}
.masonry-item:hover img{transform:scale(1.05)}

/* REVIEWS */
.rev-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.rev-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.rev-grid{grid-template-columns:repeat(3,1fr)}}
.review{padding:32px;border-radius:16px;background:var(--card);border:1px solid var(--border);box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12);height:100%}
.stars{color:var(--gold);font-size:18px;letter-spacing:.4em}
.review blockquote{margin-top:20px;font-family:var(--font-display);font-size:24px;line-height:1.3}
.review figcaption{margin-top:24px;font-size:14px;color:var(--muted-foreground)}
.review figcaption strong{color:var(--foreground);font-weight:500}
.review.wide{grid-column:auto}
@media(min-width:1024px){.review.wide{grid-column:span 2}}

/* FAQ */
.faq{max-width:768px;margin:0 auto;padding:0 24px}
@media(min-width:1024px){.faq{padding:0 40px}}
.faq-list{border-radius:16px;background:var(--background);box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12);overflow:hidden}
.faq-item{border-bottom:1px solid var(--border)}
.faq-item:last-child{border-bottom:0}
.faq-q{width:100%;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:24px;text-align:left}
.faq-q span:first-child{font-family:var(--font-display);font-size:20px}
.faq-icon{height:32px;width:32px;border-radius:999px;border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .4s}
.faq-item.open .faq-icon{transform:rotate(45deg);background:var(--rose);color:#fff;border-color:var(--rose)}
.faq-a{display:grid;grid-template-rows:0fr;transition:all .5s}
.faq-item.open .faq-a{grid-template-rows:1fr;padding:0 24px 24px}
.faq-a > div{overflow:hidden;color:var(--muted-foreground);line-height:1.7}

/* CONTACT */
.contact-grid{display:grid;grid-template-columns:1fr;gap:24px}
@media(min-width:768px){.contact-grid{grid-template-columns:repeat(3,1fr)}}
.contact-card{display:block;height:100%;border-radius:24px;padding:40px;background:var(--card);border:1px solid var(--border);box-shadow:0 1px 2px rgba(0,0,0,.04),0 12px 40px -16px rgba(42,35,32,.12);transition:all .5s}
.contact-card:hover{border-color:var(--rose);transform:translateY(-4px)}
.contact-card p:nth-child(1){font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--primary)}
.contact-card p:nth-child(2){margin-top:16px;font-family:var(--font-display);font-size:24px}
.contact-card p:nth-child(3){margin-top:4px;color:var(--muted-foreground);font-size:14px}

/* FOOTER */
footer{border-top:1px solid var(--border);background:var(--cream)}
.footer-inner{padding:56px 24px;max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:24px}
@media(min-width:768px){.footer-inner{flex-direction:row;align-items:center;justify-content:space-between;padding:56px 40px}}
.footer-brand{font-family:var(--font-display);font-size:24px}
.footer-meta{font-size:14px;color:var(--muted-foreground);margin-top:8px}
.footer-tag{font-size:14px;color:var(--muted-foreground);letter-spacing:.04em}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
