:root{
  --bleu-deep:#0f2d5a;
  --bleu-bm:#1e4d8c;
  --bleu-azur:#7bb8e0;
  --or:#c9a14a;
  --or-clair:#e3c97a;
  --porcelaine:#f4ecd8;
  --creme:#faf6ec;
  --rouge:#c0392b;
  --noir:#0e0e0e;
  --gris:#6b6b6b;
  --gris-clair:#b8b8b8;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--creme);
  color:var(--noir);
  font-family:'Inter',sans-serif;
  font-weight:300;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:opacity .2s}
a:hover{opacity:.75}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;font-weight:500;letter-spacing:-.01em;color:var(--noir)}
h1{font-size:clamp(56px,9vw,118px);line-height:.92;font-weight:600}
h2{font-size:clamp(32px,5.5vw,58px);line-height:1.02;margin-bottom:16px}
h3{font-size:clamp(22px,3.5vw,32px);line-height:1.15;margin-bottom:8px}
h4{font-size:clamp(17px,2.6vw,22px);line-height:1.2}
p{font-size:clamp(15px,2.3vw,17px);color:#2a2a2a;margin-bottom:14px;max-width:64ch}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:860px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--or);font-weight:600;margin-bottom:10px}
.rule{width:60px;height:2px;background:var(--or);margin:18px 0 22px}
.center .rule{margin-left:auto;margin-right:auto}
.center{text-align:center}
.gold{color:var(--or-clair);font-style:italic;font-weight:400}
.sig{font-family:'Pinyon Script',cursive;color:var(--or-clair)}

/* ====== NAV ====== */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(250,246,236,.92);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(201,161,74,.18);
}
.nav-inner{
  max-width:1380px;margin:0 auto;padding:14px 28px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav-logo{display:flex;align-items:center;gap:10px;font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--bleu-deep);font-weight:500}
.nav-logo img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.nav-menu{display:flex;gap:30px;list-style:none;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--bleu-deep);font-weight:500}
.nav-actions{display:flex;align-items:center;gap:16px;font-size:13px;letter-spacing:.06em}
.nav-cart{
  background:var(--bleu-deep);color:var(--porcelaine);
  padding:8px 14px;border-radius:30px;font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:6px;
}
@media(max-width:880px){
  .nav-menu{display:none}
  .nav-inner{padding:12px 18px}
}

/* ====== BUTTONS ====== */
.btn{
  display:inline-block;padding:14px 28px;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  border:none;cursor:pointer;border-radius:30px;
  transition:all .25s;
  font-family:'Inter',sans-serif;
}
.btn-primary{background:var(--bleu-deep);color:var(--porcelaine)}
.btn-primary:hover{background:var(--bleu-bm);opacity:1;transform:translateY(-1px)}
.btn-gold{background:linear-gradient(135deg,var(--or-clair),var(--or));color:var(--bleu-deep)}
.btn-gold:hover{transform:translateY(-1px);box-shadow:0 12px 30px rgba(201,161,74,.3);opacity:1}
.btn-ghost{background:transparent;color:var(--porcelaine);border:1px solid var(--or-clair)}
.btn-ghost:hover{background:var(--or-clair);color:var(--bleu-deep);opacity:1}

/* ====== HERO ====== */
.hero{
  position:relative;
  min-height:92vh;
  display:flex;align-items:center;justify-content:center;
  color:var(--porcelaine);text-align:center;
  overflow:hidden;
  background:var(--bleu-deep);
}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:brightness(.75) saturate(1.1);
}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at center,transparent 30%,rgba(8,16,40,.7) 100%),
             linear-gradient(180deg,rgba(8,16,40,.2) 0%,rgba(8,16,40,.5) 100%);
}
/* Hero slider */
.hero-slider .slide{
  position:absolute;
  top:0;left:0;right:0;bottom:0;
  width:100%;height:100%;
  background-size:cover;background-position:center;
  background-repeat:no-repeat;
  background-color:#0f2d5a;
  opacity:0;transition:opacity 1.4s cubic-bezier(.6,.1,.4,1);
  filter:brightness(.78) saturate(1.12);
  z-index:1;
}
.hero-slider .slide.active{opacity:1;z-index:2;animation:slideZoom 8s ease-out forwards}
.hero-slider::after{
  content:"";position:absolute;inset:0;z-index:3;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 28%,rgba(8,16,40,.7) 100%),
             linear-gradient(180deg,rgba(8,16,40,.18) 0%,rgba(8,16,40,.55) 100%);
}
@keyframes slideZoom{
  from{transform:scale(1.0)}
  to{transform:scale(1.08)}
}
.hero-dots{
  position:absolute;bottom:60px;left:50%;transform:translateX(-50%);
  display:flex;gap:10px;z-index:6;
}
.hero-dots .dot{
  width:34px;height:2px;background:rgba(244,236,216,.3);cursor:pointer;border:none;padding:0;
  transition:background .3s;
}
.hero-dots .dot.active{background:var(--or-clair);height:3px}
.hero-content{position:relative;z-index:5;padding:40px 28px;max-width:1080px}
.hero .sub{font-size:clamp(28px,4vw,42px);margin-bottom:6px}
.hero h1{color:var(--porcelaine);text-shadow:0 4px 40px rgba(0,0,0,.4)}
.hero .tagline{margin-top:20px;font-family:'Cormorant Garamond',serif;font-style:italic;font-size:clamp(17px,2.3vw,22px);color:rgba(244,236,216,.88)}
.hero .meta{margin-top:32px;display:flex;justify-content:center;gap:22px;flex-wrap:wrap;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--or-clair)}
.hero .meta span+span::before{content:"·";position:relative;left:-11px;color:var(--or)}
.hero-ctas{margin-top:36px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.hero .scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);font-size:11px;letter-spacing:.18em;color:var(--or-clair);opacity:.7;text-transform:uppercase;z-index:6}
.hero .scroll-hint::after{content:"↓";display:block;font-size:14px;margin-top:6px}

/* ====== SECTIONS ====== */
section{padding:90px 0;position:relative}
section.dark{background:var(--bleu-deep);color:var(--porcelaine)}
section.dark h2,section.dark h3{color:var(--porcelaine)}
section.dark p{color:rgba(244,236,216,.85)}
section.dark .eyebrow{color:var(--or-clair)}
section.porcelaine{background:var(--porcelaine)}
section.cream{background:var(--creme)}

/* ====== PRODUITS GRID ====== */
.products-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:30px;margin-top:50px;
}
.product-card{
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 14px 40px rgba(15,45,90,.08);
  transition:transform .35s cubic-bezier(.2,.7,.3,1),box-shadow .35s;
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-6px);box-shadow:0 24px 56px rgba(15,45,90,.16)}
.product-card .img{
  aspect-ratio:1/1;position:relative;overflow:hidden;background:var(--creme);
}
.product-card .img img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.2,.7,.3,1)}
.product-card:hover .img img{transform:scale(1.04)}
.product-card .badge{
  position:absolute;top:14px;left:14px;
  background:var(--or);color:var(--bleu-deep);
  font-size:10px;letter-spacing:.12em;font-weight:700;padding:4px 10px;border-radius:20px;text-transform:uppercase;
}
.product-card .info{padding:22px 24px 26px;flex:1;display:flex;flex-direction:column}
.product-card .cat{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--or);margin-bottom:6px;font-weight:600}
.product-card .name{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--bleu-deep);font-weight:500;margin-bottom:6px;line-height:1.15}
.product-card .desc{font-size:13px;color:var(--gris);margin-bottom:14px;flex:1}
.product-card .price{font-family:'Cormorant Garamond',serif;font-size:24px;color:var(--noir);font-weight:500}
.product-card .price .small{font-size:13px;color:var(--gris);font-weight:300;margin-left:4px}
.product-card .cta-row{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:1px solid rgba(201,161,74,.18)}
.product-card .cta-row a{font-size:12px;letter-spacing:.12em;color:var(--bleu-deep);font-weight:500;text-transform:uppercase}
.product-card .cta-row a::after{content:" →";color:var(--or)}

/* ====== MOOD GALLERY ====== */
.mood-scroller{
  display:flex;gap:18px;overflow-x:auto;
  padding:20px 28px 30px;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
}
.mood-scroller::-webkit-scrollbar{display:none}
.mood-scroller{scrollbar-width:none}
.mood-item{
  flex:0 0 280px;
  aspect-ratio:9/16;
  border-radius:12px;overflow:hidden;
  scroll-snap-align:start;
  box-shadow:0 16px 40px rgba(15,45,90,.18);
  position:relative;
}
.mood-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.mood-item:hover img{transform:scale(1.05)}
.mood-item .cap{position:absolute;left:14px;bottom:14px;right:14px;color:#fff;font-family:'Cormorant Garamond',serif;font-size:17px;text-shadow:0 2px 12px rgba(0,0,0,.6)}

/* ====== SPLIT ====== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
@media(max-width:880px){.split{grid-template-columns:1fr;gap:30px}}
.split img{width:100%;border-radius:12px;box-shadow:0 24px 60px rgba(15,45,90,.18)}

/* ====== VIDEO SECTION ====== */
.video-stage{display:flex;justify-content:center;margin-top:40px}
.video-stage video{
  width:min(420px,90vw);aspect-ratio:9/16;border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(201,161,74,.25);
  background:#000;
}

/* ====== NEWSLETTER ====== */
.newsletter{text-align:center;background:linear-gradient(135deg,var(--bleu-deep),var(--bleu-bm));color:var(--porcelaine);padding:80px 28px}
.newsletter h2{color:var(--porcelaine)}
.newsletter form{margin-top:30px;display:flex;justify-content:center;gap:10px;flex-wrap:wrap;max-width:520px;margin-left:auto;margin-right:auto}
.newsletter input{flex:1;min-width:240px;padding:14px 18px;border:1px solid rgba(244,236,216,.3);background:rgba(244,236,216,.05);color:var(--porcelaine);border-radius:30px;font-family:'Inter',sans-serif;font-size:14px}
.newsletter input::placeholder{color:rgba(244,236,216,.5)}
.newsletter input:focus{outline:none;border-color:var(--or-clair)}

/* ====== FOOTER ====== */
footer{background:var(--bleu-deep);color:var(--porcelaine);padding:70px 28px 30px}
.footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
@media(max-width:880px){.footer-inner{grid-template-columns:1fr 1fr;gap:30px}}
.footer-col h4{color:var(--or-clair);font-family:'Cormorant Garamond',serif;font-size:20px;margin-bottom:14px}
.footer-col ul{list-style:none}
.footer-col li{padding:5px 0;font-size:13px;color:rgba(244,236,216,.7)}
.footer-col li a:hover{color:var(--or-clair)}
.footer-brand p{color:rgba(244,236,216,.65);font-size:13px;max-width:30ch;margin-top:10px}
.footer-brand .sig{font-size:30px;display:block;margin-bottom:4px}
.footer-bottom{max-width:1280px;margin:50px auto 0;padding-top:24px;border-top:1px solid rgba(244,236,216,.12);font-size:11px;letter-spacing:.1em;color:rgba(244,236,216,.5);text-transform:uppercase;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* ====== PRODUCT PAGE ====== */
.pdp{padding:60px 0;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;max-width:1280px;margin:0 auto;padding:60px 28px}
@media(max-width:880px){.pdp{grid-template-columns:1fr;gap:30px;padding:30px 22px}}
.pdp-gallery img{width:100%;border-radius:12px;box-shadow:0 18px 48px rgba(15,45,90,.14);margin-bottom:14px}
.pdp-info .breadcrumb{font-size:11px;letter-spacing:.12em;color:var(--gris);text-transform:uppercase;margin-bottom:18px}
.pdp-info .breadcrumb a{color:var(--bleu-deep)}
.pdp-info h1{font-size:clamp(36px,5.5vw,52px);margin-bottom:8px;font-weight:500;line-height:1.05}
.pdp-info .price{font-family:'Cormorant Garamond',serif;font-size:34px;color:var(--noir);margin:18px 0;font-weight:500}
.pdp-info .price .strike{color:var(--gris);text-decoration:line-through;font-size:22px;margin-right:10px}
.pdp-info .lede{font-style:italic;font-size:18px;color:var(--bleu-deep);margin-bottom:24px;font-family:'Cormorant Garamond',serif;line-height:1.4}
.pdp-info .desc{margin-bottom:30px}
.pdp-info .meta-list{margin:30px 0;border-top:1px solid rgba(201,161,74,.25);border-bottom:1px solid rgba(201,161,74,.25);padding:20px 0}
.pdp-info .meta-list li{list-style:none;padding:7px 0;font-size:14px;color:var(--noir);display:flex;justify-content:space-between;border-bottom:1px dashed rgba(201,161,74,.18)}
.pdp-info .meta-list li:last-child{border-bottom:none}
.pdp-info .meta-list b{color:var(--bleu-deep);font-weight:500}
.pdp-info .qty-row{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.pdp-info .qty{display:inline-flex;align-items:center;border:1px solid var(--bleu-deep);border-radius:30px;padding:4px}
.pdp-info .qty button{background:transparent;border:none;width:36px;height:36px;cursor:pointer;font-size:16px;color:var(--bleu-deep)}
.pdp-info .qty span{padding:0 14px;font-weight:500}
.pdp-info .reassurance{background:var(--porcelaine);border-left:3px solid var(--or);padding:20px 24px;border-radius:6px;margin-top:30px;font-size:14px;color:var(--bleu-deep);line-height:1.6}
.pdp-info .reassurance b{display:block;font-family:'Cormorant Garamond',serif;font-size:18px;margin-bottom:6px}
.pdp-story{background:var(--bleu-deep);color:var(--porcelaine);padding:80px 28px}
.pdp-story .wrap-narrow h2{color:var(--porcelaine);font-style:italic}
.pdp-story .wrap-narrow p{color:rgba(244,236,216,.85)}

/* ====== UTIL ====== */
.tag-list{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.tag{display:inline-block;padding:4px 12px;background:rgba(201,161,74,.12);color:var(--bleu-deep);font-size:11px;letter-spacing:.1em;border-radius:30px;font-weight:500;text-transform:uppercase}
.divider-or{height:1px;background:linear-gradient(90deg,transparent,var(--or),transparent);margin:50px auto;max-width:200px}

/* ====== LIGHTBOX ====== */
#lb{position:fixed;inset:0;background:rgba(8,12,28,.95);z-index:9999;display:none;align-items:center;justify-content:center;padding:24px;cursor:zoom-out;backdrop-filter:blur(8px)}
#lb.on{display:flex}
#lb img{max-width:96vw;max-height:96vh;object-fit:contain;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.7);cursor:zoom-out}
#lb .close{position:absolute;top:18px;right:22px;color:var(--or-clair);font-family:'Cormorant Garamond',serif;font-size:38px;line-height:1;cursor:pointer}

/* ====== CART DRAWER ====== */
#cart{position:fixed;top:0;right:0;height:100%;width:380px;max-width:90vw;background:#fff;z-index:200;transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.7,.3,1);box-shadow:-20px 0 50px rgba(0,0,0,.18);display:flex;flex-direction:column}
#cart.on{transform:translateX(0)}
#cart .head{padding:22px;border-bottom:1px solid rgba(201,161,74,.2);display:flex;justify-content:space-between;align-items:center}
#cart .head h3{font-size:22px;color:var(--bleu-deep);margin:0}
#cart .head .x{cursor:pointer;font-size:24px;color:var(--gris)}
#cart .items{flex:1;padding:20px;overflow-y:auto}
#cart .empty{text-align:center;padding:40px 20px;color:var(--gris);font-style:italic}
#cart .foot{padding:22px;border-top:1px solid rgba(201,161,74,.2);background:var(--porcelaine)}
#cart .total{display:flex;justify-content:space-between;font-family:'Cormorant Garamond',serif;font-size:22px;margin-bottom:16px;color:var(--bleu-deep)}
.cart-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150;display:none}
.cart-backdrop.on{display:block}
