:root{
  --violet-red:#861452;
  --pearl-tint:#FAE7C8;
  --pearl-soft:#F3E2C5;
  --orchid:#A877B2;
  --crimson:#BF2657;
  --mulberry:#311A41;
  --mulberry-deep:#241432;
  --mulberry-line:#4A2B5E;
  --ink:#2A1736;
  --bg-card:#1A0E22;
  --font-display:"Cinzel",serif;
  --font-body:"Montserrat",sans-serif;
  --max-w:430px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{font-family:var(--font-body);color:var(--ink);background:var(--mulberry)}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{display:flex;justify-content:center;min-height:100vh;overflow-x:hidden}
.app{width:100%;max-width:var(--max-w);background:var(--pearl-tint);position:relative;overflow-x:clip}
button,a{font-family:inherit;font:inherit;color:inherit;cursor:pointer;text-decoration:none;border:none;background:none}
svg{width:100%;height:100%;display:block;fill:none}
img{display:block;max-width:100%}
hr{border:none;height:1px;background:rgba(49,26,65,.15);margin:8px 0}

/* === LOADING SCREEN === */
.loading-screen{
  position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;
  background:url('assets/pattern-violet.jpg') center/cover var(--bg-card);
  transition:opacity .8s ease, visibility .8s;
}
.loading-screen.hide{opacity:0;visibility:hidden;pointer-events:none}
.loading-overlay{position:absolute;inset:0;background:rgba(26,14,34,.95)}
.loading-glow{position:absolute;width:280px;height:280px;border-radius:50%;background:rgba(134,20,82,.4);filter:blur(70px);top:30%;left:50%;transform:translate(-50%,-50%)}
.loading-content{position:relative;display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px;text-align:center;color:var(--pearl-tint)}
.sigil-row{display:flex;align-items:center;gap:12px;color:var(--crimson)}
.sigil-line{display:block;width:32px;height:1px;background:currentColor}
.sigil-mark{width:18px;height:18px}
.loading-crest{width:240px;animation:breath 3s ease-in-out infinite}
.loading-logo{width:260px}
.loading-tagline{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--orchid)}
.loading-track{width:220px;height:3px;background:rgba(250,231,200,.12);border-radius:999px;overflow:hidden;position:relative}
.loading-progress{height:100%;background:var(--crimson);border-radius:999px;width:0;animation:fill 1.8s ease-out forwards}
.loading-text{font-size:10px;font-weight:700;letter-spacing:.3em;color:var(--orchid)}
.loading-signature{margin-top:24px;font-size:9px;font-weight:600;letter-spacing:.3em;color:rgba(168,119,178,.6)}
@keyframes breath{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}
@keyframes fill{from{width:0}to{width:82%}}

/* === NAV === */
.nav{
  background:var(--mulberry);color:var(--pearl-tint);
  position:sticky;top:0;z-index:50;display:flex;flex-direction:column;
}
.nav-top-strip{
  background:var(--mulberry-deep);text-align:center;
  padding:5px 16px;font-size:9px;font-weight:600;letter-spacing:.3em;color:var(--orchid);
}
.nav-main{
  display:flex;align-items:center;padding:8px 18px;gap:10px;
}
.nav-side{flex:1 1 0;display:flex;align-items:center}
.nav-side.left{justify-content:flex-start}
.nav-side.right{justify-content:flex-end}
.nav-logo{flex:0 0 168px;width:168px;height:34px;object-fit:contain;opacity:0;transition:opacity .3s ease}
.nav.show-logo .nav-logo{opacity:1}
.nav-ornament .sigil-line{display:block;width:28px;height:1px;background:currentColor}
.sigil-mark.sm{width:12px;height:12px}
.icon-btn{
  width:38px;height:38px;border:1px solid var(--orchid);border-radius:999px;
  display:flex;align-items:center;justify-content:center;color:var(--pearl-tint);
  flex:0 0 38px;background:transparent;transition:border-color .2s, background .2s;
}
.icon-btn svg{width:16px;height:16px}
.icon-btn:hover{border-color:var(--pearl-tint);background:rgba(250,231,200,.06)}
.cart-pill{
  display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;
  border:1px solid var(--orchid);color:var(--pearl-tint);font-size:12px;font-weight:600;
  flex:0 0 auto;background:transparent;transition:border-color .2s, background .2s;
}
.cart-pill svg{width:14px;height:14px}
.cart-pill:hover{border-color:var(--pearl-tint);background:rgba(250,231,200,.06)}
.cart-count{transition:color .2s}
.cart-pill.has-items{border-color:var(--crimson)}
.cart-pill.has-items .cart-count{color:var(--crimson)}

/* === HERO === */
.hero{
  background:url('assets/pattern-violet.jpg') center/cover var(--mulberry);
  color:var(--pearl-tint);position:relative;padding:64px 0 0;display:flex;flex-direction:column;align-items:center;gap:22px;overflow:hidden;
}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(125% 95% at 50% 12%,rgba(26,14,34,.5),rgba(26,14,34,.97) 72%);pointer-events:none}
.hero-logo,.hero-tagline,.hero-subline,.btn-ghost,.divider,.eyebrow,.hero-carousel{position:relative;z-index:1}
.hero-logo{width:280px}
.hero-tagline{font-family:var(--font-display);font-style:italic;font-size:18px;color:var(--pearl-tint);text-align:center}
.hero-subline{font-size:12px;line-height:1.55;text-align:center;max-width:300px;color:rgba(250,231,200,.7)}
.divider{display:block;width:40px;height:1px;background:var(--crimson)}
.eyebrow{font-size:10px;font-weight:700;letter-spacing:.3em;color:var(--pearl-tint)}
.hero-carousel{display:block;width:100%;overflow:hidden;position:relative;mask-image:linear-gradient(to right,transparent 0,#000 24px,#000 calc(100% - 60px),transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 24px,#000 calc(100% - 60px),transparent 100%)}
.hero-carousel-track{display:flex;align-items:flex-end;gap:10px;width:max-content;animation:bc-marquee 55s linear infinite;will-change:transform}
.hero-carousel-track img{height:262px;width:auto;flex:0 0 auto;object-fit:contain;display:block;filter:drop-shadow(0 20px 22px rgba(0,0,0,.62)) drop-shadow(0 2px 6px rgba(0,0,0,.5)) brightness(1.07) contrast(1.05);transition:filter .3s,transform .3s}
.hero-carousel-track img:hover{transform:translateY(-6px) scale(1.03);filter:drop-shadow(0 28px 30px rgba(0,0,0,.62)) brightness(1.12) contrast(1.06)}
.hero-carousel:hover .hero-carousel-track,.hero-carousel:focus-within .hero-carousel-track{animation-play-state:paused}
@keyframes bc-marquee{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@media (prefers-reduced-motion:reduce){.hero-carousel-track{animation:none}.hero-carousel{overflow-x:auto;scrollbar-width:none}.hero-carousel::-webkit-scrollbar{display:none}}

/* === BUTTONS === */
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;
  border:1px solid var(--pearl-tint);background:rgba(250,231,200,.08);
  color:var(--pearl-tint);font-size:11px;font-weight:700;letter-spacing:.25em;
}
.btn-ghost.light{border-color:var(--pearl-tint);background:transparent;margin:0 auto;display:flex;justify-content:center;align-items:center;width:fit-content;color:var(--pearl-tint)}
.btn-ghost svg{width:12px;height:12px}
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:999px;
  background:var(--crimson);color:var(--pearl-tint);font-size:12px;font-weight:700;letter-spacing:.2em;transition:transform .2s, background .2s;
}
.btn-primary:hover{background:var(--violet-red);transform:translateY(-1px)}
.btn-primary svg{width:14px;height:14px}
.btn-primary.block{width:100%}

/* === SEPARATORS === */
.seam-separator{
  height:60px;width:100%;background-repeat:repeat-x;background-position:center;background-size:auto 60px;
  margin:-30px 0;position:relative;z-index:5;pointer-events:none;
}

/* === SECTIONS === */
.manifeste,.boutique,.atelier{padding:56px 22px;display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}
.manifeste{background:var(--pearl-tint);color:var(--ink)}
.boutique{background:var(--mulberry);color:var(--pearl-tint)}
.atelier{background:var(--pearl-soft);color:var(--ink)}
.eyebrow-row{display:flex;align-items:center;gap:10px;color:var(--crimson)}
.eyebrow-row .bar{display:block;width:24px;height:1px;background:currentColor}
.eyebrow-row .label{font-size:11px;font-weight:700;letter-spacing:.25em}
.eyebrow-row.dark{color:var(--crimson)}
.display-xl{font-family:var(--font-display);font-size:38px;font-weight:500;line-height:1.05}
.display-lg{font-family:var(--font-display);font-size:32px;font-weight:500;line-height:1.05}
.display-md{font-family:var(--font-display);font-size:24px;font-weight:500}
.display-sm{font-family:var(--font-display);font-size:22px;font-weight:500}
.light{color:var(--pearl-tint)}
.lead,.body{font-size:14px;line-height:1.75;text-align:center}
.body{text-align:left;width:100%}

/* MANIFESTE */
.manifeste-crest{width:180px;margin:8px auto}
.stats{display:flex;gap:8px;width:100%;padding:12px 0 4px;align-items:flex-start}
.stats>div{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}
.stat-num{font-family:var(--font-display);font-size:28px;color:var(--violet-red)}
.stat-lbl{font-size:10px;font-weight:700;letter-spacing:.2em;text-align:center}
.pull-quote{display:flex;flex-direction:column;align-items:center;gap:14px;padding:20px 12px}
.pull-quote .qline{display:block;width:40px;height:1px;background:var(--crimson)}
.pull-quote p{font-family:var(--font-display);font-size:22px;line-height:1.3;color:var(--violet-red);text-align:center}
.pull-quote .attribution{font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.3em;color:var(--crimson)}
.creators{display:flex;flex-direction:column;align-items:center;gap:18px;width:100%}
.creators-eyebrow{display:flex;align-items:center;gap:10px;color:var(--crimson)}
.creators-eyebrow .bar{width:24px;height:1px;background:currentColor;display:block}
.creators-eyebrow .label{font-size:11px;font-weight:700;letter-spacing:.25em}
.creators-subtitle{font-family:var(--font-display);font-size:22px;line-height:1.1;text-align:center;color:var(--mulberry);font-weight:500}
.creators-row{display:flex;align-items:flex-start;justify-content:center;gap:14px;width:100%}
.creator-card{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1.6}
.creator-card.small{flex:1;gap:6px}
.creator-card img{width:100%;max-width:206px;object-fit:contain}
.creator-card.small img{max-width:132px}
.creator-card .role{font-size:10px;font-weight:700;letter-spacing:.2em;color:var(--violet-red)}
.creator-card.small .role{color:var(--orchid);font-size:9px}
.creator-card .name{font-family:var(--font-display);font-size:26px;color:var(--mulberry)}
.creator-card.small .name{font-size:20px}
.creator-card .bio{font-size:11px;line-height:1.55;color:var(--ink);text-align:center}
.creator-card.small .bio{font-size:10px}
.creators-foot{font-size:11px;font-style:italic;color:var(--orchid);text-align:center;margin-top:4px}
.signature{font-size:11px;font-weight:600;letter-spacing:.3em;color:var(--crimson);text-align:center}

/* BOUTIQUE */
.cards-grid{display:flex;flex-direction:column;gap:16px;width:100%}
.corne-card{
  display:flex;background:var(--bg-card);border:1px solid var(--mulberry-line);
  border-radius:18px;overflow:hidden;height:204px;box-shadow:0 14px 26px rgba(10,4,16,.8);
  cursor:pointer;transition:transform .2s;text-align:left;width:100%;
}
.corne-card:hover{transform:translateY(-2px)}
.corne-photo{width:184px;background:#251536;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:16px 12px;position:relative;flex:0 0 184px}
.corne-photo img{width:160px;height:152px;object-fit:contain;display:block}
.corne-shadow{width:128px;height:16px;border-radius:50%;background:rgba(0,0,0,.7);filter:blur(12px)}
.corne-info{flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:18px 18px 18px 16px;min-width:0}
.corne-info .corne-top{display:flex;flex-direction:column;gap:8px}
.corne-info .name{font-family:var(--font-display);font-size:24px;color:var(--pearl-tint);line-height:1.05}
.corne-info .dots{display:flex;align-items:center;gap:6px}
.corne-info .dot{display:block;width:10px;height:10px;border-radius:50%;border:0.5px solid rgba(74,43,94,.5)}
.corne-info .scarcity{display:inline-flex;align-items:center;gap:5px;padding-top:2px;font-size:9px;font-weight:600;letter-spacing:.22em;color:var(--orchid)}
.corne-info .scarcity .pulse{width:4px;height:4px;border-radius:50%;background:var(--crimson);animation:pulse 1.6s ease-in-out infinite}
.corne-info .bottom-row{display:flex;justify-content:space-between;align-items:center}
.corne-info .price{font-family:var(--font-display);font-size:22px;color:var(--crimson)}
.corne-arrow{width:34px;height:34px;border-radius:999px;background:var(--crimson);display:flex;align-items:center;justify-content:center;color:var(--pearl-tint);flex-shrink:0}
.corne-arrow svg{width:16px;height:16px}

/* ATELIER */
.feature-card{
  background:var(--pearl-soft);border:1px solid var(--mulberry);border-radius:14px;
  padding:24px;width:100%;display:flex;flex-direction:column;gap:12px;text-align:left;
}
.feature-icon{width:52px;height:52px;border-radius:999px;background:var(--mulberry);color:var(--pearl-tint);display:flex;align-items:center;justify-content:center}
.feature-icon svg{width:24px;height:24px}
.feature-card h3{font-family:var(--font-display);font-size:20px;color:var(--mulberry)}
.feature-card p{font-size:13px;line-height:1.55;color:var(--ink)}

/* FOOTER */
.footer{position:relative;background:var(--mulberry-deep);color:var(--pearl-tint);padding:54px 28px 28px;display:flex;flex-direction:column;align-items:center;gap:18px;text-align:center;overflow:hidden}
.footer::before{content:"";position:absolute;top:0;left:50%;width:300px;height:300px;border-radius:50%;background:radial-gradient(closest-side,rgba(134,20,82,.4),transparent);transform:translate(-50%,-58%);pointer-events:none}
.footer-brand{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px}
.footer-crest{width:54px;height:auto}
.footer-logo{width:208px;height:auto;object-fit:contain}
.footer-tagline{font-family:var(--font-display);font-style:italic;font-size:16px;color:var(--orchid)}
.footer-links{position:relative;display:flex;flex-wrap:wrap;justify-content:center;gap:10px 22px}
.footer-links a{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--pearl-tint);padding-bottom:3px;position:relative;transition:color .2s}
.footer-links a::after{content:"";position:absolute;left:50%;bottom:0;width:0;height:1px;background:var(--crimson);transition:width .25s ease, left .25s ease}
.footer-links a:hover{color:var(--crimson)}
.footer-links a:hover::after{width:100%;left:0}
.footer-sigil{margin:2px 0}
.footer-sub{font-size:12px;line-height:1.6;max-width:300px;color:rgba(250,231,200,.72)}
.footer-sub strong{color:var(--orchid);font-weight:600}
.socials{display:flex;gap:14px}
.socials a{width:42px;height:42px;border-radius:999px;border:1px solid var(--mulberry-line);display:flex;align-items:center;justify-content:center;color:var(--pearl-tint);transition:border-color .2s, background .2s, transform .2s}
.socials a svg{width:18px;height:18px}
.socials a:hover{border-color:var(--crimson);background:rgba(191,38,87,.12);transform:translateY(-2px)}
.mail{font-size:13px;color:var(--orchid);border-bottom:1px solid transparent;transition:border-color .2s}
.mail:hover{border-color:var(--orchid)}
.footer-bottom{width:100%;margin-top:8px;padding-top:18px;border-top:1px solid var(--mulberry-line);display:flex;flex-direction:column;gap:7px}
.footer-madein{font-size:10px;font-weight:700;letter-spacing:.26em;color:var(--orchid)}
.copy{font-size:11px;letter-spacing:.08em;color:rgba(168,119,178,.7)}

/* PRODUCT DETAIL */
.product-screen{
  position:fixed;inset:0;z-index:100;background:var(--mulberry);color:var(--pearl-tint);
  transform:translateX(100%);transition:transform .35s ease;overflow-y:auto;
  display:flex;flex-direction:column;
}
.product-screen.open{transform:translateX(0)}
.product-header{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;gap:12px;background:var(--mulberry)}
.product-eyebrow{font-size:11px;font-weight:700;letter-spacing:.3em;color:var(--orchid)}
.product-hero{background:#251536;min-height:360px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:28px 24px 24px}
.product-hero img{width:260px;height:260px;object-fit:contain}
.product-floor{width:200px;height:24px;border-radius:50%;background:rgba(0,0,0,.6);filter:blur(16px)}
.product-body{background:var(--pearl-tint);color:var(--ink);padding:28px 24px 32px;display:flex;flex-direction:column;gap:20px;flex:1}
.product-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.material{font-size:11px;font-weight:700;letter-spacing:.3em;color:var(--crimson);margin-bottom:4px}
.product-name{font-family:var(--font-display);font-size:32px;font-weight:500;line-height:1.05;color:var(--mulberry)}
.product-price{font-family:var(--font-display);font-size:26px;color:var(--violet-red);white-space:nowrap}
.product-desc{font-size:14px;line-height:1.6;color:var(--ink)}
.product-hr{border:none;height:1px;background:rgba(49,26,65,.15);margin:0}
.variants-label{font-size:11px;font-weight:700;letter-spacing:.3em;color:var(--ink)}
.variants{display:flex;gap:10px}
.variant{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px;border-radius:12px;border:1px solid rgba(49,26,65,.2);background:transparent;cursor:pointer;transition:border .2s}
.variant.selected{border:2px solid var(--crimson);padding:9px}
.variant .swatch{width:100%;height:50px;border-radius:8px}
.variant .lbl{font-size:11px;font-weight:600;color:var(--ink)}
.qty-add{display:flex;gap:12px;align-items:center}
.qty-stepper{display:flex;align-items:center;gap:14px;padding:8px 14px;border:1px solid var(--mulberry);border-radius:999px;flex:0 0 auto}
.qty-stepper button{width:20px;height:20px;color:var(--mulberry);font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center}
.qty-stepper span{font-weight:700;color:var(--mulberry);font-size:15px;min-width:14px;text-align:center}
.trust-row{display:flex;gap:14px;justify-content:center;padding-top:6px;flex-wrap:wrap}
.trust-row span{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--ink)}
.trust-row svg{width:14px;height:14px;color:var(--violet-red);stroke-width:2;flex-shrink:0}
.product-signature{background:var(--mulberry-deep);color:var(--crimson);text-align:center;padding:20px 24px;font-size:11px;font-weight:600;letter-spacing:.3em}

/* CART DRAWER */
.cart-backdrop{position:fixed;inset:0;background:rgba(26,14,34,.6);z-index:90;opacity:0;visibility:hidden;transition:opacity .3s, visibility .3s}
.cart-backdrop.open{opacity:1;visibility:visible}
.cart-drawer{
  position:fixed;top:0;right:0;height:100%;width:min(100%,var(--max-w));
  background:var(--mulberry);color:var(--pearl-tint);transform:translateX(100%);
  transition:transform .35s ease;z-index:100;display:flex;flex-direction:column;
}
.cart-drawer.open{transform:translateX(0)}
.cart-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;gap:12px;background:var(--mulberry)}
.cart-eyebrow{font-size:11px;font-weight:700;letter-spacing:.3em;color:var(--crimson);margin-bottom:6px}
.cart-title{font-family:var(--font-display);font-size:30px;font-weight:500;color:var(--pearl-tint);line-height:1.05}
.cart-empty{padding:48px 24px;text-align:center;color:var(--orchid);display:none;flex-direction:column;gap:12px;justify-content:center;min-height:240px}
.cart-empty p:not(.cart-title){font-size:13px;line-height:1.6}
.cart-empty.show{display:flex}
.cart-lines{padding:8px 20px;display:flex;flex-direction:column;gap:14px}
.cart-line{display:flex;gap:14px;padding:14px;border-radius:14px;background:var(--mulberry-deep);border:1px solid var(--mulberry-line);align-items:center}
.cart-line .thumb{width:88px;height:88px;border-radius:10px;background:#251536;display:flex;align-items:center;justify-content:center;flex:0 0 88px;overflow:hidden}
.cart-line .thumb img{width:100%;height:100%;object-fit:contain}
.cart-line .info{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0}
.cart-line .name{font-family:var(--font-display);font-size:18px;color:var(--pearl-tint);line-height:1.05}
.cart-line .var{font-size:11px;font-weight:600;letter-spacing:.15em;color:var(--orchid)}
.cart-line .row{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:2px}
.cart-line .price{font-size:14px;font-weight:600;color:var(--pearl-tint)}
.cart-line .stepper{display:flex;align-items:center;gap:10px;padding:4px 10px;border-radius:999px;border:1px solid var(--orchid)}
.cart-line .stepper button{color:var(--pearl-tint);font-size:13px;width:16px;height:16px;display:flex;align-items:center;justify-content:center}
.cart-line .stepper span{font-size:13px;font-weight:700;color:var(--pearl-tint);min-width:10px;text-align:center}
.cart-footer{padding:24px 24px 32px;background:var(--mulberry-deep);display:flex;flex-direction:column;gap:18px}
.cart-total{display:flex;justify-content:space-between;align-items:center}
.cart-total span:first-child{font-weight:600;color:var(--pearl-tint);font-size:14px}
.cart-total span:last-child{font-family:var(--font-display);font-size:28px;color:var(--pearl-tint)}
.cart-ship{font-size:12px;color:var(--orchid)}
.cart-trust{display:flex;gap:16px;justify-content:center;padding-top:4px}
.cart-trust span{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.15em;color:var(--orchid)}
.cart-trust svg{width:12px;height:12px;flex-shrink:0;stroke-width:2}

/* utility */
.crimson{color:var(--crimson)}

/* === PRODUCT HEADER RICH === */
.product-header-center{display:flex;flex-direction:column;align-items:center;gap:4px}
.stock-pulse{display:inline-flex;align-items:center;gap:6px;font-size:9px;font-weight:700;letter-spacing:.25em;color:rgba(168,119,178,.8)}
.stock-pulse .dot{width:5px;height:5px;border-radius:50%;background:var(--crimson);animation:pulse 1.6s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.45}}

/* === PAY BADGES === */
.pay-eyebrow{display:flex;align-items:center;gap:10px;margin-top:8px}
.pay-eyebrow .bar{flex:1;height:1px;background:rgba(49,26,65,.2)}
.pay-eyebrow .label{font-size:10px;font-weight:700;letter-spacing:.3em;color:var(--ink)}
.pay-badges{display:flex;justify-content:center;gap:6px;flex-wrap:wrap}
.badge{
  width:44px;height:28px;border-radius:6px;background:#fff;border:.5px solid rgba(49,26,65,.12);
  display:inline-flex;align-items:center;justify-content:center;gap:2px;
  font-family:Arial,sans-serif;font-size:10px;font-weight:900;letter-spacing:.5px;font-style:italic;
}
.badge.visa{color:#1A1F71}
.badge.mc{position:relative}
.badge.mc .dot{position:absolute;top:7px;width:14px;height:14px;border-radius:50%;display:block}
.badge.mc .dot.red{left:8px;background:#EB001B}
.badge.mc .dot.yellow{left:18px;background:rgba(247,158,27,.85)}
.badge.cb{color:#0E4C92;font-family:"IBM Plex Mono",monospace;font-style:normal;font-size:11px}
.badge.paypal{font-style:italic;font-size:8px;letter-spacing:0;font-weight:800}
.badge.paypal b{color:#003087}
.badge.paypal i{color:#009CDE;font-style:italic}
.badge.apay{color:#000;font-style:normal;font-size:9px;font-weight:600}
.badge.apay::before{content:"";display:inline-block;width:8px;height:10px;margin-right:2px;
  background:#000;mask:radial-gradient(circle at 60% 30%,transparent 22%,#000 24%) center/cover;
  -webkit-mask:radial-gradient(circle at 60% 30%,transparent 22%,#000 24%) center/cover;
}
.badge.gpay{color:#3C4043;font-style:normal;font-size:9px;font-weight:600}
.pay-note{font-size:10px;font-weight:500;letter-spacing:.2em;color:rgba(49,26,65,.5);text-align:center;margin-top:2px}

/* === PRODUCT SECTIONS === */
.prod-section-head{display:flex;flex-direction:column;gap:6px}
.prod-section-head .eyebrow{font-size:11px;font-weight:700;letter-spacing:.3em}
.prod-section-head .eyebrow.crimson{color:var(--crimson)}
.prod-section-head .eyebrow.violet{color:var(--violet-red)}
.prod-section-head h3{line-height:1.15}
.prod-section-head .sub{font-size:12px;line-height:1.5;color:var(--orchid)}
.prod-section-head.dark .sub{color:rgba(49,26,65,.7)}
.prod-section-head.dark h3{color:var(--ink)}

/* === GALLERY === */
.prod-gallery{background:var(--mulberry);padding:40px 24px;display:flex;flex-direction:column;gap:18px}
.bento{display:flex;flex-direction:column;gap:10px}
.bento-hero{height:240px;border-radius:14px;background-color:#251536;background-size:cover;background-position:center;background-repeat:no-repeat}
.bento-row{display:flex;gap:10px}
.bento-tile{flex:1;height:170px;border-radius:14px;background-color:#251536;background-size:cover;background-position:center;background-repeat:no-repeat}
.bento-tile.tall{flex:0 0 140px;height:240px}
.bento-tile.big{flex:1;height:240px}
.gallery-foot{display:flex;justify-content:space-between;align-items:center;padding-top:8px}
.gallery-foot>span:first-child{font-size:11px;font-weight:600;letter-spacing:.2em;color:var(--orchid)}
.see-all{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;letter-spacing:.1em;color:var(--pearl-tint)}
.see-all svg{width:12px;height:12px}

/* === 3D VIEWER === */
.prod-3d{background:var(--pearl-tint);padding:40px 24px;display:flex;flex-direction:column;gap:18px}
.stage{
  position:relative;height:380px;background:var(--mulberry-deep);border-radius:18px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.stage-glow{position:absolute;width:282px;height:220px;border-radius:50%;background:rgba(134,20,82,.4);filter:blur(50px);top:80px;left:50%;transform:translateX(-50%)}
.orbit{position:absolute;border:1px solid rgba(168,119,178,.25);border-radius:50%;left:50%;transform:translateX(-50%)}
.orbit.outer{width:278px;height:160px;top:100px}
.orbit.inner{width:218px;height:120px;top:120px;border-color:rgba(168,119,178,.15)}
.stage-horn{position:absolute;top:30px;left:50%;transform:translateX(-50%);width:240px;height:300px;object-fit:contain;z-index:2}
.stage-shadow{position:absolute;top:300px;left:50%;transform:translateX(-50%);width:200px;height:18px;border-radius:50%;background:rgba(0,0,0,.5);filter:blur(14px);z-index:1}
.stage-badge{
  position:absolute;top:16px;left:16px;display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:999px;background:rgba(26,14,34,.5);border:.5px solid rgba(168,119,178,.25);
  font-size:9px;font-weight:700;letter-spacing:.2em;color:var(--pearl-soft);z-index:3;
}
.stage-badge svg{width:11px;height:11px}
.stage-drag{
  position:absolute;right:30px;top:170px;width:34px;height:34px;border-radius:50%;
  background:rgba(243,226,197,.25);border:1px solid var(--pearl-soft);
  display:flex;align-items:center;justify-content:center;z-index:3;
}
.stage-drag svg{width:16px;height:16px;color:var(--pearl-soft)}
.stage-hint{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;background:rgba(26,14,34,.4);border:.5px solid rgba(168,119,178,.2);
  font-size:9px;font-weight:600;letter-spacing:.1em;color:var(--orchid);z-index:3;
}
.stage-hint svg{width:11px;height:11px}

/* === RELATED === */
.prod-related{background:var(--mulberry);padding:40px 0 32px}
.related-head{display:flex;justify-content:space-between;align-items:center;padding:0 24px;margin-bottom:8px}
.related-head .eyebrow{font-size:11px;font-weight:700;letter-spacing:.3em;color:var(--crimson)}
.related-pager{display:flex;gap:6px}
.pager-btn{width:28px;height:28px;border-radius:50%;border:1px solid var(--mulberry-line);color:var(--pearl-tint);display:flex;align-items:center;justify-content:center}
.pager-btn.fill{background:var(--crimson);border-color:var(--crimson)}
.pager-btn svg{width:12px;height:12px}
.related-title{padding:0 24px;margin-bottom:14px}
.related-scroller{display:flex;gap:14px;padding:4px 24px;overflow-x:auto;scrollbar-width:none}
.related-scroller::-webkit-scrollbar{display:none}
.mini-card{
  flex:0 0 178px;background:var(--mulberry-deep);border:1px solid var(--mulberry-line);
  border-radius:14px;padding:12px;display:flex;flex-direction:column;gap:10px;text-align:left;cursor:pointer;
}
.mini-thumb{background:#251536;border-radius:10px;height:154px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.mini-thumb img{max-width:128px;max-height:140px;object-fit:contain}
.mini-sub{font-size:9px;font-weight:600;letter-spacing:.25em;color:var(--orchid)}
.mini-name{font-family:var(--font-display);font-size:15px;color:var(--pearl-tint);line-height:1.2}
.mini-row{display:flex;justify-content:space-between;align-items:center}
.mini-price{font-family:var(--font-display);font-size:16px;color:var(--pearl-soft)}
.mini-add{width:26px;height:26px;border-radius:50%;background:var(--crimson);color:var(--pearl-tint);display:flex;align-items:center;justify-content:center}
.mini-add svg{width:12px;height:12px}
.mini-more{
  flex:0 0 140px;background:transparent;border:1px solid var(--mulberry-line);border-radius:14px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
}
.more-circle{width:44px;height:44px;border-radius:50%;background:var(--crimson);color:var(--pearl-tint);display:flex;align-items:center;justify-content:center}
.more-circle svg{width:18px;height:18px}
.mini-more p{font-family:var(--font-display);font-size:14px;color:var(--pearl-tint)}

/* === CLOSING === */
.prod-closing{background:var(--mulberry-deep);padding:36px 24px 40px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.sigil-row.crimson{color:var(--crimson)}
.closer-italic{font-family:var(--font-display);font-style:italic;font-size:20px;line-height:1.3;color:var(--pearl-tint)}
.closer-sub{font-size:12px;line-height:1.6;color:var(--orchid)}

/* === STICKY BAR === */
.prod-sticky{
  position:fixed;left:50%;bottom:0;width:min(100%,var(--max-w));transform:translateX(-50%) translateY(100%);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 20px 18px;background:rgba(26,14,34,.96);border-top:1px solid var(--mulberry-line);
  z-index:110;opacity:0;pointer-events:none;
  transition:transform .35s ease, opacity .35s ease;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.prod-sticky.visible{transform:translateX(-50%) translateY(0);opacity:1;pointer-events:auto}
.prod-sticky-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.prod-sticky-info .name{font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--pearl-tint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.prod-sticky-info .stock{font-size:10px;font-weight:500;color:var(--orchid)}
.prod-sticky-cta{
  display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:999px;background:var(--crimson);color:var(--pearl-tint);
  font-size:13px;font-weight:700;letter-spacing:.1em;flex-shrink:0;
}
.prod-sticky-cta svg{width:13px;height:13px}

/* === CART ENRICHED === */
.cart-scroll{flex:1;overflow-y:auto;display:flex;flex-direction:column}
.cart-addon{padding:20px 24px 8px;display:flex;flex-direction:column;gap:14px}
.cart-addon-head{display:flex;justify-content:space-between;align-items:center}
.cart-addon-head h3{font-family:var(--font-display);font-size:16px;color:var(--pearl-tint);font-weight:500}
.cart-addon-head .hint{font-size:11px;font-weight:500;letter-spacing:.05em;color:var(--orchid)}
.cart-addon-row{display:flex;gap:12px;overflow-x:auto;scrollbar-width:none}
.cart-addon-row::-webkit-scrollbar{display:none}
.addon-card{
  flex:0 0 160px;background:var(--mulberry-deep);border:1px solid var(--mulberry-line);
  border-radius:14px;padding:10px;display:flex;flex-direction:column;gap:6px;text-align:left;cursor:pointer;
}
.addon-thumb{background:#251536;border-radius:10px;height:120px;background-size:contain;background-position:center;background-repeat:no-repeat}
.addon-eyebrow{font-size:9px;font-weight:700;letter-spacing:.2em;color:var(--crimson);margin-top:2px}
.addon-name{font-family:var(--font-display);font-size:14px;color:var(--pearl-tint);line-height:1.15}
.addon-row{display:flex;justify-content:space-between;align-items:center;padding:0 2px;margin-top:2px}
.addon-row>span:first-child{font-size:13px;font-weight:600;color:var(--pearl-tint)}
.addon-add{width:28px;height:28px;border-radius:50%;background:var(--crimson);color:var(--pearl-tint);display:flex;align-items:center;justify-content:center}
.addon-add svg{width:12px;height:12px}

.promo-row{
  display:flex;justify-content:space-between;align-items:center;gap:8px;
  background:var(--mulberry);border:1px solid var(--mulberry-line);border-radius:999px;padding:6px 6px 6px 16px;
}
.promo-field{display:flex;align-items:center;gap:10px;flex:1;color:var(--orchid)}
.promo-field svg{width:14px;height:14px;flex-shrink:0}
.promo-field input{flex:1;background:none;border:none;outline:none;font-family:inherit;font-size:13px;font-weight:500;color:var(--pearl-tint)}
.promo-field input::placeholder{color:var(--orchid)}
.promo-apply{padding:8px 14px;border-radius:999px;background:var(--mulberry-line);color:var(--pearl-tint);font-size:12px;font-weight:700;letter-spacing:.05em}

.reassurance{list-style:none;display:flex;flex-direction:column;gap:6px;padding:2px}
.reassurance li{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:500;letter-spacing:.04em;color:var(--orchid)}
.reassurance svg{width:12px;height:12px;color:var(--orchid);flex-shrink:0;stroke-width:2}

.cart-pay{padding-top:8px;display:flex;flex-direction:column;align-items:center;gap:10px}
.cart-pay-eyebrow{font-size:9px;font-weight:700;letter-spacing:.3em;color:var(--orchid)}
.cart-pay-badges{display:flex;justify-content:center;gap:6px;flex-wrap:wrap}
.cart-pay-badges .badge{width:40px;height:24px;font-size:9px}
.cart-pay-badges .badge.mc .dot{top:5px;width:14px;height:14px}
.cart-pay-badges .badge.mc .dot.red{left:7px}
.cart-pay-badges .badge.mc .dot.yellow{left:17px}

/* tighten responsive bits */
@media (max-width:380px){
  .display-xl{font-size:32px}
  .product-hero{height:300px}
  .product-hero img{width:220px;height:220px}
  .bento-hero{height:200px}
  .bento-tile{height:140px}
  .bento-tile.tall,.bento-tile.big{height:200px}
  .stage{height:340px}
  .stage-horn{width:200px;height:260px}
}

/* ============ HERO VEDETTE (maquette retenue) ============ */
.hero-grain{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.08;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.hero.vedette{min-height:88vh;justify-content:center;gap:18px;padding:72px 18px 30px;background:#1a0e22}
.hero.vedette .hero-bg{position:absolute;inset:0;z-index:0;background:radial-gradient(85% 60% at 50% 34%,#3a1f52,#1a0e22 72%)}
.hero.vedette .v-stage,.hero.vedette .v-dots,.hero.vedette .v-sub,.hero.vedette .v-cta{position:relative;z-index:2}
.v-stage{position:relative;width:100%;max-width:440px;height:min(56vh,440px);display:flex;align-items:center;justify-content:center}
.v-crest{position:absolute;top:25%;left:50%;transform:translate(-50%,-50%);z-index:0;height:min(52%,310px);width:auto;opacity:.32;pointer-events:none;filter:drop-shadow(0 8px 30px rgba(0,0,0,.45))}
.v-logo{position:absolute;top:19%;left:50%;transform:translate(-50%,-50%);z-index:1;width:min(84%,380px);height:auto;opacity:.96;pointer-events:none;transition:transform .3s ease-out;filter:drop-shadow(0 2px 16px rgba(0,0,0,.6))}
.v-photo{position:relative;z-index:1;height:100%;display:flex;align-items:flex-end;justify-content:center;transition:transform .3s ease-out}
.v-photo img{height:88%;width:auto;object-fit:contain;filter:drop-shadow(0 30px 30px rgba(0,0,0,.62)) brightness(1.06) contrast(1.05);transition:opacity .35s ease,transform .55s cubic-bezier(.2,.8,.2,1)}
.v-photo img.swap{opacity:0;transform:translateY(16px) scale(.98)}
.v-glow{position:absolute;left:50%;bottom:7%;width:74%;height:56%;transform:translateX(-50%);z-index:-1;background:radial-gradient(closest-side,rgba(134,20,82,.55),transparent);filter:blur(22px)}
.v-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border-radius:999px;border:1px solid var(--mulberry-line);background:rgba(26,14,34,.55);color:var(--pearl-tint);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:border-color .2s,background .2s,transform .2s}
.v-arrow svg{width:18px;height:18px}
.v-arrow.prev{left:0}
.v-arrow.next{right:0}
.v-arrow:hover{border-color:var(--crimson);background:rgba(191,38,87,.22)}
.v-arrow:active{transform:translateY(-50%) scale(.92)}
.v-dots{display:flex;gap:8px;justify-content:center;align-items:center}
.v-dot{width:7px;height:7px;border-radius:999px;background:var(--mulberry-line);transition:.25s;padding:0;cursor:pointer}
.v-dot.active{background:var(--crimson);width:22px}
.v-sub{font-size:12.5px;line-height:1.6;text-align:center;max-width:320px;color:rgba(250,231,200,.74)}
.v-cta{display:inline-flex;align-items:center;gap:10px;padding:13px 24px;border-radius:999px;background:var(--crimson);color:var(--pearl-tint);font-size:11px;font-weight:700;letter-spacing:.2em;transition:transform .2s,background .2s,box-shadow .2s;box-shadow:0 10px 26px rgba(191,38,87,.35)}
.v-cta svg{width:13px;height:13px}
.v-cta:hover{background:var(--violet-red);transform:translateY(-2px);box-shadow:0 14px 30px rgba(191,38,87,.48)}

/* === LIGHTBOX (galerie plein écran) === */
.bento-hero,.bento-tile,.creator-card img{cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(13,7,18,.93);opacity:0;visibility:hidden;transition:opacity .25s ease, visibility .25s;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:100%;max-height:100%;object-fit:contain;border-radius:10px;box-shadow:0 24px 70px rgba(0,0,0,.6);transform:scale(.96);transition:transform .25s ease}
.lightbox.open img{transform:scale(1)}
.lightbox-close{position:absolute;top:16px;right:16px;width:44px;height:44px;border-radius:999px;border:1px solid var(--mulberry-line);background:rgba(26,14,34,.6);color:var(--pearl-tint);display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);transition:border-color .2s,background .2s}
.lightbox-close svg{width:20px;height:20px}
.lightbox-close:hover{border-color:var(--crimson);background:rgba(191,38,87,.2)}
