/* ================= Lumières Vive — Design System ================= */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --color-bg: #FAF7F0;
  --color-bg-alt: #F3ECDC;
  --color-ink: #211a10;
  --color-ink-soft: #4a3f2c;
  --color-cream: #F8F3E6;
  --color-gold: #C9A14D;
  --color-gold-dark: #8C6A2E;
  --color-gold-light: #E7DCC2;
  --color-black: #15110a;
  --color-line: rgba(33,26,16,0.12);
  --shadow-soft: 0 10px 40px rgba(33,26,16,0.08);
  --shadow-lift: 0 18px 50px rgba(33,26,16,0.16);
  --radius: 2px;
  --container: 1240px;
  --serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Jost', 'Helvetica Neue', Arial, sans-serif;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  font-family: var(--sans);
  color: var(--color-ink);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; margin:0; padding:0; }
button{ font-family: var(--sans); cursor:pointer; }

h1,h2,h3,h4{
  font-family: var(--serif);
  font-weight: 500;
  margin: 0 0 .5em;
  letter-spacing: .01em;
  color: var(--color-black);
}
h1{ font-size: clamp(2.6rem, 5vw, 4.4rem); font-weight: 400; line-height: 1.05; }
h2{ font-size: clamp(2rem, 3.4vw, 2.8rem); font-weight: 400; }
h3{ font-size: 1.5rem; }
p{ margin: 0 0 1em; }

.eyebrow{
  font-family: var(--sans);
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--color-gold-dark);
  font-weight: 500;
}

.container{ max-width: var(--container); margin: 0 auto; padding: 0 32px; }
.section{ padding: 96px 0; }
.section-tight{ padding: 56px 0; }
.center{ text-align:center; }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  padding: 16px 34px;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 500;
  border: 1px solid var(--color-black);
  background: var(--color-black);
  color: #fff;
  transition: all .25s ease;
  white-space: nowrap;
}
.btn:hover{ background: transparent; color: var(--color-black); }
.btn-outline{
  background: transparent; color: var(--color-black); border: 1px solid var(--color-black);
}
.btn-outline:hover{ background: var(--color-black); color: #fff; }
.btn-gold{
  background: var(--color-gold); border-color: var(--color-gold); color: var(--color-black);
}
.btn-gold:hover{ background: transparent; color: var(--color-gold-dark); }
.btn-block{ width:100%; }
.btn-sm{ padding: 11px 22px; font-size: .68rem; }
.btn:disabled{ opacity:.45; cursor:not-allowed; }

/* ---------- Header ---------- */
.site-header{
  position: sticky; top:0; z-index: 500;
  background: rgba(250,247,240,0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--color-line);
}
.announce-bar{
  background: var(--color-black); color: var(--color-gold-light);
  text-align:center; font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  padding: 9px 12px;
}
.announce-bar a{ color: var(--color-gold); text-decoration:underline; }
.nav-wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding: 16px 32px;
  max-width: var(--container); margin: 0 auto;
}
.nav-logo{ display:flex; align-items:center; gap:10px; }
.nav-logo img{ height:40px; width:auto; }
.nav-logo-text{ font-family: var(--serif); font-size:1.3rem; letter-spacing:.04em; }
.nav-links{ display:flex; gap:34px; align-items:center; }
.nav-links a{
  font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; font-weight:500;
  position:relative; padding: 4px 0;
}
.nav-links a.active, .nav-links a:hover{ color: var(--color-gold-dark); }
.nav-links a.active::after{
  content:''; position:absolute; left:0; bottom:-4px; width:100%; height:1px; background:var(--color-gold-dark);
}
.nav-actions{ display:flex; align-items:center; gap:20px; }
.icon-btn{ position:relative; display:flex; align-items:center; justify-content:center; width:24px; height:24px; background:none; border:none; padding:0; }
.icon-btn svg{ width:21px; height:21px; stroke: var(--color-black); fill:none; }
.cart-count{
  position:absolute; top:-9px; right:-11px;
  background: var(--color-gold-dark); color:#fff;
  font-size:.62rem; width:17px; height:17px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-weight:600;
}
.mobile-toggle{ display:none; background:none; border:none; flex-direction:column; gap:5px; }
.mobile-toggle span{ width:24px; height:1.5px; background: var(--color-black); display:block; }

@media (max-width: 900px){
  .nav-links{
    position:fixed; top:0; right:-100%; height:100vh; width:78%; max-width:330px;
    background: var(--color-cream); flex-direction:column; justify-content:flex-start;
    padding: 100px 36px; gap:26px; transition: right .35s ease; box-shadow: var(--shadow-lift);
    z-index: 600;
  }
  .nav-links.open{ right:0; }
  .mobile-toggle{ display:flex; }
  .nav-logo-text{ font-size:1.1rem; }
}
.nav-overlay{
  position:fixed; inset:0; background:rgba(21,17,10,.4); z-index:550; opacity:0; pointer-events:none; transition:opacity .3s;
}
.nav-overlay.open{ opacity:1; pointer-events:auto; }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height: 86vh; display:flex; align-items:center;
  background: radial-gradient(ellipse at 70% 20%, #fffaf0 0%, var(--color-bg) 55%, var(--color-bg-alt) 100%);
  overflow:hidden;
}
.hero::before{
  content:''; position:absolute; width:680px; height:680px; border-radius:50%;
  background: radial-gradient(circle, rgba(201,161,77,.28), transparent 70%);
  top:-220px; right:-180px;
}
.hero-grid{
  position:relative; z-index:2; display:grid; grid-template-columns: 1.1fr .9fr; gap:60px; align-items:center;
  max-width: var(--container); margin:0 auto; padding: 60px 32px;
}
.hero h1{ margin-bottom: 22px; }
.hero p.lead{ font-size:1.15rem; color: var(--color-ink-soft); max-width:460px; }
.hero-ctas{ display:flex; gap:16px; margin-top: 34px; flex-wrap:wrap; }
.hero-stats{ display:flex; gap:40px; margin-top:54px; }
.hero-stats div b{ display:block; font-family:var(--serif); font-size:1.7rem; color: var(--color-gold-dark); }
.hero-stats div span{ font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--color-ink-soft); }
.hero-visual{
  position:relative; aspect-ratio: 4/5; border-radius: 6px; overflow:hidden;
  background: linear-gradient(155deg, #2a2014 0%, #4a3a20 45%, #C9A14D 100%);
  display:flex; align-items:center; justify-content:center;
  box-shadow: var(--shadow-lift);
}
.hero-visual img{ width:46%; opacity:.95; filter: drop-shadow(0 20px 40px rgba(0,0,0,.35)); }
.hero-visual .ring{
  position:absolute; border:1px solid rgba(255,255,255,.25); border-radius:50%;
}
.hero-visual .ring.r1{ width:340px; height:340px; }
.hero-visual .ring.r2{ width:440px; height:440px; }

@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr; padding-top:40px; }
  .hero-visual{ order:-1; aspect-ratio: 5/4; }
}

/* ---------- Marquee ---------- */
.marquee{ background: var(--color-black); color: var(--color-gold-light); overflow:hidden; padding:16px 0; }
.marquee-track{ display:flex; gap:60px; white-space:nowrap; animation: scrollLeft 28s linear infinite; }
.marquee span{ font-family: var(--serif); font-size:1.05rem; letter-spacing:.04em; }
@keyframes scrollLeft{ from{ transform: translateX(0); } to{ transform: translateX(-50%); } }

/* ---------- Section headers ---------- */
.section-head{ max-width:640px; margin: 0 auto 56px; text-align:center; }
.section-head.left{ margin: 0 0 48px; text-align:left; }

/* ---------- Pillars / Features ---------- */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:36px; }
.pillar{ padding: 38px 30px; background: var(--color-cream); border:1px solid var(--color-line); text-align:center; transition: transform .25s, box-shadow .25s; }
.pillar:hover{ transform: translateY(-6px); box-shadow: var(--shadow-soft); }
.pillar .num{ font-family:var(--serif); font-size:2.2rem; color: var(--color-gold); margin-bottom:10px; }
@media (max-width:760px){ .pillars{ grid-template-columns:1fr; } }

/* ---------- Product grid ---------- */
.product-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
@media (max-width:1100px){ .product-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:760px){ .product-grid{ grid-template-columns:repeat(2,1fr); gap:18px; } }
@media (max-width:480px){ .product-grid{ grid-template-columns:1fr; } }

.product-card{ background:#fff; border:1px solid var(--color-line); position:relative; display:flex; flex-direction:column; transition: box-shadow .3s, transform .3s; }
.product-card:hover{ box-shadow: var(--shadow-soft); transform: translateY(-4px); }
.product-media{
  aspect-ratio: 1/1.1; display:flex; align-items:center; justify-content:center; position:relative; overflow:hidden;
}
.product-bottle{
  width:36%; height:62%; border-radius: 40% 40% 18% 18% / 22% 22% 10% 10%;
  position:relative; box-shadow: 0 18px 30px rgba(0,0,0,.18);
}
.product-bottle::before{
  content:''; position:absolute; top:-10%; left:50%; transform:translateX(-50%); width:34%; height:14%;
  background: inherit; filter: brightness(1.15); border-radius: 4px 4px 0 0;
}
.product-bottle .label{
  position:absolute; inset:30% 12% 30% 12%; background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.4);
  display:flex; align-items:center; justify-content:center; font-family:var(--serif); font-size:.62rem; letter-spacing:.1em; text-align:center; color:#fff; padding:4px;
}
.product-badge{
  position:absolute; top:14px; left:14px; background: var(--color-black); color: var(--color-gold-light);
  font-size:.62rem; letter-spacing:.1em; text-transform:uppercase; padding:6px 10px; z-index:3;
}
.product-quickadd{
  position:absolute; bottom:14px; left:14px; right:14px; opacity:0; transform: translateY(8px);
  transition: all .25s; z-index:3;
}
.product-card:hover .product-quickadd{ opacity:1; transform:none; }
.product-info{ padding: 18px 18px 22px; display:flex; flex-direction:column; gap:6px; flex:1; }
.product-cat{ font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color: var(--color-gold-dark); }
.product-name{ font-family:var(--serif); font-size:1.18rem; }
.product-tagline{ font-size:.83rem; color: var(--color-ink-soft); flex:1; }
.product-price-row{ display:flex; align-items:center; gap:10px; margin-top:6px; }
.product-price{ font-weight:500; }
.compare-price{ text-decoration: line-through; color:#9a8e76; font-size:.85rem; }
.stars{ color: var(--color-gold); font-size:.8rem; letter-spacing:1px; }

/* Filters */
.filter-bar{ display:flex; flex-wrap:wrap; gap:12px; margin-bottom: 40px; align-items:center; justify-content:space-between; }
.filter-pills{ display:flex; gap:10px; flex-wrap:wrap; }
.filter-pill{
  padding: 9px 20px; border:1px solid var(--color-line); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase;
  background:#fff; transition: all .2s;
}
.filter-pill.active, .filter-pill:hover{ background: var(--color-black); color:#fff; border-color: var(--color-black); }
.sort-select{ padding:9px 16px; border:1px solid var(--color-line); background:#fff; font-size:.78rem; font-family:var(--sans); }

/* ---------- Testimonials ---------- */
.testimonials{ background: var(--color-cream); }
.t-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
@media (max-width:900px){ .t-grid{ grid-template-columns:1fr; } }
.t-card{ background:#fff; padding:34px 28px; border:1px solid var(--color-line); }
.t-card .stars{ display:block; margin-bottom:14px; }
.t-card .who{ margin-top:18px; font-size:.8rem; letter-spacing:.05em; text-transform:uppercase; color: var(--color-ink-soft); }

/* ---------- Newsletter ---------- */
.newsletter{
  background: linear-gradient(120deg, #1c1610, #3a2e1a);
  color: #F8F3E6; text-align:center; padding: 90px 32px; position:relative; overflow:hidden;
}
.newsletter::before{ content:''; position:absolute; inset:0; background: radial-gradient(circle at 80% 20%, rgba(201,161,77,.25), transparent 60%); }
.newsletter-inner{ position:relative; z-index:2; max-width:560px; margin:0 auto; }
.newsletter h2{ color:#F8F3E6; }
.nform{ display:flex; gap:0; margin-top:30px; border-bottom:1px solid rgba(248,243,230,.5); }
.nform input{
  flex:1; background:transparent; border:none; color:#F8F3E6; padding:14px 8px; font-size:1rem; font-family:var(--sans);
}
.nform input::placeholder{ color: rgba(248,243,230,.5); }
.nform button{ background:transparent; border:none; color:var(--color-gold); letter-spacing:.1em; text-transform:uppercase; font-size:.78rem; padding:14px 6px; }
.nform input:focus{ outline:none; }
.form-msg{ margin-top:14px; font-size:.85rem; color: var(--color-gold); min-height:1.2em; }

/* ---------- Footer ---------- */
.site-footer{ background: var(--color-black); color: rgba(248,243,230,.75); padding-top:72px; }
.footer-grid{ display:grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:50px; border-bottom:1px solid rgba(248,243,230,.12); }
.footer-brand img{ height:46px; margin-bottom:14px; }
.footer-brand p{ font-size:.85rem; max-width:280px; color: rgba(248,243,230,.55); }
.footer-col h4{ color:#F8F3E6; font-size:.95rem; margin-bottom:18px; letter-spacing:.04em; }
.footer-col ul li{ margin-bottom:11px; }
.footer-col a{ font-size:.85rem; color: rgba(248,243,230,.65); transition:color .2s; }
.footer-col a:hover{ color: var(--color-gold); }
.footer-social{ display:flex; gap:14px; margin-top:18px; }
.footer-social a{ width:34px; height:34px; border:1px solid rgba(248,243,230,.25); border-radius:50%; display:flex; align-items:center; justify-content:center; }
.footer-social a:hover{ border-color: var(--color-gold); color: var(--color-gold); }
.footer-bottom{ display:flex; justify-content:space-between; align-items:center; padding: 24px 0; font-size:.76rem; color: rgba(248,243,230,.45); flex-wrap:wrap; gap:10px;}
@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }

/* ---------- Page banner (sub pages) ---------- */
.page-banner{
  padding: 70px 32px 50px; text-align:center; background: var(--color-bg-alt);
  border-bottom: 1px solid var(--color-line);
}
.breadcrumb{ font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; color: var(--color-ink-soft); margin-bottom:14px; }
.breadcrumb a:hover{ color: var(--color-gold-dark); }

/* ---------- Forms (contact, account, checkout) ---------- */
.form-card{ background:#fff; border:1px solid var(--color-line); padding: 44px; max-width:620px; margin: 0 auto; }
.field{ margin-bottom: 22px; }
.field label{ display:block; font-size:.74rem; letter-spacing:.08em; text-transform:uppercase; margin-bottom:8px; color: var(--color-ink-soft); }
.field input, .field select, .field textarea{
  width:100%; padding: 13px 14px; border:1px solid var(--color-line); background: var(--color-bg); font-family: var(--sans); font-size:.95rem;
}
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color: var(--color-gold); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:560px){ .field-row{ grid-template-columns:1fr; } }
.form-success{
  display:none; text-align:center; padding: 50px 20px;
}
.form-success.show{ display:block; }
.form-success svg{ width:54px; height:54px; stroke:var(--color-gold-dark); margin-bottom:16px; }

/* ---------- Product detail ---------- */
.pd-grid{ display:grid; grid-template-columns: 1fr 1fr; gap:64px; align-items:flex-start; }
@media (max-width:900px){ .pd-grid{ grid-template-columns:1fr; gap:32px; } }
.pd-media{ aspect-ratio:1/1.05; border-radius:6px; display:flex; align-items:center; justify-content:center; position:sticky; top:110px; }
.pd-bottle{ width:32%; height:65%; border-radius: 40% 40% 18% 18% / 22% 22% 10% 10%; box-shadow: 0 30px 50px rgba(0,0,0,.2); position:relative; }
.pd-bottle::before{ content:''; position:absolute; top:-10%; left:50%; transform:translateX(-50%); width:34%; height:14%; background: inherit; filter:brightness(1.15); border-radius:4px 4px 0 0; }
.pd-bottle .label{ position:absolute; inset:28% 10% 28% 10%; background:rgba(255,255,255,.18); border:1px solid rgba(255,255,255,.4); display:flex; align-items:center; justify-content:center; text-align:center; font-family:var(--serif); font-size:.74rem; letter-spacing:.08em; color:#fff; padding:6px; }
.pd-qty{ display:flex; align-items:center; border:1px solid var(--color-line); width:fit-content; }
.pd-qty button{ width:42px; height:46px; background:none; border:none; font-size:1.1rem; }
.pd-qty input{ width:46px; height:46px; text-align:center; border:none; border-left:1px solid var(--color-line); border-right:1px solid var(--color-line); font-size:1rem; }
.pd-tabs{ display:flex; gap:28px; border-bottom:1px solid var(--color-line); margin-top:46px; }
.pd-tab{ padding-bottom:14px; font-size:.82rem; letter-spacing:.06em; text-transform:uppercase; border-bottom:2px solid transparent; cursor:pointer; color: var(--color-ink-soft); }
.pd-tab.active{ color: var(--color-black); border-color: var(--color-gold); }
.pd-tabpanel{ display:none; padding-top:24px; }
.pd-tabpanel.active{ display:block; }
.stock-note{ font-size:.82rem; color: var(--color-gold-dark); margin-top:6px; }

/* ---------- Cart ---------- */
.cart-table{ width:100%; border-collapse:collapse; }
.cart-table th{ text-align:left; font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color: var(--color-ink-soft); padding-bottom:16px; border-bottom:1px solid var(--color-line); }
.cart-table td{ padding: 22px 0; border-bottom:1px solid var(--color-line); vertical-align:middle; }
.cart-item-info{ display:flex; gap:16px; align-items:center; }
.cart-thumb{ width:64px; height:64px; border-radius:4px; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.cart-thumb .mini-bottle{ width:40%; height:60%; border-radius: 40% 40% 18% 18% / 22% 22% 10% 10%; }
.cart-remove{ background:none; border:none; font-size:.74rem; letter-spacing:.05em; text-transform:uppercase; color:#9a8e76; text-decoration:underline; }
.cart-remove:hover{ color:#b3261e; }
.cart-summary{ background: var(--color-cream); padding: 34px; border:1px solid var(--color-line); }
.summary-row{ display:flex; justify-content:space-between; margin-bottom:14px; font-size:.92rem; }
.summary-row.total{ font-size:1.15rem; border-top:1px solid var(--color-line); padding-top:16px; margin-top:6px; }
.empty-state{ text-align:center; padding: 90px 20px; }
.promo-row{ display:flex; gap:8px; margin: 18px 0; }
.promo-row input{ flex:1; padding:11px 12px; border:1px solid var(--color-line); }

/* ---------- Misc ---------- */
.divider-gold{ width:60px; height:1px; background: var(--color-gold); margin: 18px auto; }
.tag-line{ display:flex; align-items:center; gap:14px; justify-content:center; color: var(--color-gold-dark); font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; }
.tag-line .line{ width:40px; height:1px; background: var(--color-gold); }
.toast{
  position:fixed; bottom:28px; right:28px; background: var(--color-black); color:#fff;
  padding: 16px 22px; font-size:.85rem; border-radius:3px; box-shadow: var(--shadow-lift);
  transform: translateY(20px); opacity:0; pointer-events:none; transition: all .3s; z-index:1000; display:flex; gap:12px; align-items:center;
}
.toast.show{ transform:none; opacity:1; }
.toast b{ color: var(--color-gold); }
.faq-item{ border-bottom:1px solid var(--color-line); }
.faq-q{ padding: 22px 0; display:flex; justify-content:space-between; align-items:center; cursor:pointer; font-family:var(--serif); font-size:1.1rem; }
.faq-q .plus{ font-size:1.4rem; color:var(--color-gold-dark); transition: transform .25s; }
.faq-item.open .plus{ transform: rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition: max-height .3s ease; }
.faq-a p{ color: var(--color-ink-soft); padding-bottom:22px; }
.acc-tabs{ display:flex; gap:0; border:1px solid var(--color-line); width:fit-content; margin:0 auto 40px; }
.acc-tab{ padding:13px 30px; font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; background:#fff; }
.acc-tab.active{ background: var(--color-black); color:#fff; }
.acc-panel{ display:none; }
.acc-panel.active{ display:block; }
.map-block{
  height:340px; background: linear-gradient(135deg, var(--color-gold-light), var(--color-bg-alt));
  display:flex; align-items:center; justify-content:center; border:1px solid var(--color-line);
  font-family: var(--serif); color: var(--color-gold-dark); text-align:center;
}
.value-list{ display:flex; flex-direction:column; gap:18px; }
.value-list li{ display:flex; gap:14px; align-items:flex-start; }
.value-list .dot{ width:8px; height:8px; border-radius:50%; background:var(--color-gold); margin-top:8px; flex-shrink:0; }
.timeline{ position:relative; padding-left: 36px; border-left:1px solid var(--color-line); }
.timeline-item{ position:relative; padding-bottom:42px; }
.timeline-item::before{ content:''; position:absolute; left:-41px; top:2px; width:10px; height:10px; border-radius:50%; background: var(--color-gold); }
.timeline-year{ font-family:var(--serif); font-size:1.3rem; color: var(--color-gold-dark); }
.skel-img{ background: linear-gradient(135deg,#e9e0c8,#cdb87f); }
table.compare{ width:100%; border-collapse:collapse; }
table.compare th, table.compare td{ border:1px solid var(--color-line); padding:14px; text-align:center; font-size:.88rem; }
table.compare th{ background: var(--color-cream); }
