/** Shopify CDN: Minification failed

Line 561:0 Unexpected "}"

**/

:root{
  --ink:#000;
  --bone:#f3efe6;
  --paper:#0a0a0a;
  --line:rgba(243,239,230,.18);
  --line-strong:rgba(243,239,230,.6);
  --accent:#b91c2c;
  --accent-soft:rgba(185,28,44,.18);
  --type-display:'UnifrakturMaguntia','Old London Text MT',serif;
  --type-body:'Cormorant Garamond','Times New Roman',serif;
  --type-mono:'Space Mono',ui-monospace,monospace;
  --max:1440px;
  --easing:cubic-bezier(.2,.8,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{background:var(--paper);color:var(--bone);font-family:var(--type-body);font-size:clamp(15px,1.05vw,18px);line-height:1.55;overflow-x:hidden}
@media (pointer:coarse){body{cursor:auto}}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--accent);color:var(--bone)}

.grain{position:fixed;inset:-50%;pointer-events:none;z-index:9000;opacity:.08;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .7 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");animation:grain 1.6s steps(6) infinite}
@keyframes grain{0%{transform:translate(0,0)}20%{transform:translate(-3%,2%)}40%{transform:translate(2%,-3%)}60%{transform:translate(-1%,1%)}80%{transform:translate(3%,-2%)}100%{transform:translate(-2%,3%)}}
@media (prefers-reduced-motion:reduce){.grain{animation:none}*,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important}}
.vignette{position:fixed;inset:0;pointer-events:none;z-index:8500;background:radial-gradient(120% 80% at 50% 50%,transparent 60%,rgba(0,0,0,.35) 100%)}

.cursor,.cursor-dot{display:none!important}
.cursor{width:46px;height:46px;border:1px solid var(--bone);border-radius:50%;transition:width .25s var(--easing),height .25s var(--easing),background .25s var(--easing)}
.cursor-dot{width:6px;height:6px;background:var(--bone);border-radius:50%}
.cursor.is-hover{width:90px;height:90px;background:var(--bone)}
.cursor .label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--type-mono);font-size:11px;color:var(--ink);text-transform:uppercase;opacity:0;transition:opacity .2s var(--easing)}
.cursor.is-hover .label{opacity:1}
@media (pointer:coarse){.cursor,.cursor-dot{display:none}}



.nav{position:fixed;top:0;left:0;right:0;z-index:5000;padding:18px clamp(16px,3vw,40px);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;font-family:var(--type-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;background:linear-gradient(180deg,rgba(0,0,0,.7),transparent);transition:transform .5s var(--easing),background .5s var(--easing)}
.nav.hidden{transform:translateY(-110%)}
.nav.scrolled{background:rgba(0,0,0,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav .left,.nav .right{display:flex;gap:22px;align-items:center}
.nav .right{justify-content:flex-end}
.nav a{position:relative;padding:6px 0;display:inline-block}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--bone);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--easing)}
.nav a:hover::after{transform:scaleX(1);transform-origin:left}
.nav .brand{font-family:var(--type-display);font-size:24px;letter-spacing:0;text-transform:none;line-height:1}
.cart-btn{display:flex;gap:10px;align-items:center}
.cart-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border:1px solid var(--accent);background:var(--accent);color:var(--bone);border-radius:50%;font-size:10px}

.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;padding:120px clamp(16px,3vw,40px) 80px;overflow:hidden;text-align:center}
.hero .bg{position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 100%,rgba(243,239,230,.06),transparent 70%),radial-gradient(40% 50% at 80% 20%,rgba(243,239,230,.05),transparent 70%),#050505}

.hero-overlay{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse at center, rgba(0,0,0,0) 0%, rgba(0,0,0,.32) 90%)}
.hero .smoke{position:absolute;inset:0;z-index:2;opacity:.35;mix-blend-mode:screen;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='800' height='800'><filter id='s'><feTurbulence baseFrequency='.012' numOctaves='3' seed='4'/><feDisplacementMap in='SourceGraphic' scale='80'/></filter><radialGradient id='g'><stop offset='0%25' stop-color='%23ffffff' stop-opacity='.18'/><stop offset='100%25' stop-color='%23000' stop-opacity='0'/></radialGradient><rect width='100%25' height='100%25' fill='url(%23g)' filter='url(%23s)'/></svg>");background-size:cover;background-position:center;animation:drift 24s linear infinite alternate}
@keyframes drift{from{transform:translate3d(-2%,-1%,0) scale(1.05)}to{transform:translate3d(2%,1%,0) scale(1.1)}}
.hero-inner{position:relative;z-index:3;max-width:1200px;width:100%}
.hero-brand{font-family:var(--type-display);font-size:clamp(80px,14vw,240px);line-height:.9;letter-spacing:-.01em;font-weight:400;color:var(--bone);text-shadow:0 4px 40px rgba(0,0,0,.6);animation:rise2 1.2s var(--easing) both}
@keyframes rise2{from{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}
.hero .ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:36px;opacity:0;animation:fade .9s var(--easing) .6s forwards}
@keyframes fade{to{opacity:.85}}
.btn{position:relative;display:inline-flex;align-items:center;gap:14px;padding:16px 28px;border:1px solid var(--bone);font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;overflow:hidden;isolation:isolate}
.btn::before{content:"";position:absolute;inset:0;background:var(--bone);transform:translateY(101%);transition:transform .5s var(--easing);z-index:-1}
.btn:hover{color:var(--ink)}
.btn:hover::before{transform:translateY(0)}
.btn .arrow{display:inline-block;transition:transform .5s var(--easing)}
.btn:hover .arrow{transform:translateX(6px)}
.btn-solid{background:var(--accent);color:var(--bone);border-color:var(--accent)}
.btn-solid::before{background:#000}
.btn-solid:hover{color:var(--bone);border-color:#000}
.scroll-cue{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-family:var(--type-mono);font-size:10px;letter-spacing:.4em;text-transform:uppercase;opacity:.5;display:flex;flex-direction:column;align-items:center;gap:10px;z-index:3}
.scroll-cue .line{width:1px;height:40px;background:var(--bone);transform-origin:top;animation:cue 2s var(--easing) infinite}
@keyframes cue{0%{transform:scaleY(0)}50%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}

.marquee{position:relative;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:#000;padding:18px 0}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:scroll 38s linear infinite;font-family:var(--type-display);font-size:clamp(32px,4vw,56px);color:var(--bone)}
.marquee-track span{display:inline-flex;align-items:center;gap:60px}
.marquee-track .star{font-family:var(--type-mono);font-size:.5em;opacity:.6}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee:hover .marquee-track{animation-play-state:paused}

.drop{padding:clamp(60px,9vw,140px) clamp(16px,3vw,40px);display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;max-width:var(--max);margin:auto}
@media(max-width:900px){.drop{grid-template-columns:1fr}}
.drop .visual{position:relative;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:#111}
.drop .visual img{width:100%;height:100%;object-fit:cover;transform:scale(1.1);transition:transform 8s var(--easing)}
.drop:hover .visual img{transform:scale(1)}
.drop .visual::before{content:"";position:absolute;inset:0;z-index:2;background:linear-gradient(180deg,rgba(0,0,0,0),rgba(0,0,0,.35))}
.drop .visual .tag{position:absolute;top:24px;left:24px;z-index:3;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;border:1px solid var(--bone);padding:8px 14px}
.drop .visual .label{position:absolute;bottom:24px;left:24px;right:24px;z-index:3;font-family:var(--type-display);font-size:clamp(36px,5vw,68px);line-height:.9}
.drop .meta{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.7;margin-bottom:18px}
.drop h2{font-family:var(--type-display);font-size:clamp(48px,7vw,108px);line-height:.9;margin-bottom:22px}
.drop p{font-size:clamp(16px,1.2vw,19px);max-width:54ch;opacity:.85;margin-bottom:28px}
.countdown{display:flex;gap:18px;margin-bottom:32px;flex-wrap:wrap}
.countdown .cell{border:1px solid var(--line-strong);padding:18px 20px;min-width:90px;text-align:center}
.countdown .num{font-family:var(--type-display);font-size:clamp(36px,4vw,56px);line-height:1}
.countdown .lbl{font-family:var(--type-mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;margin-top:4px}

.section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;padding:0 clamp(16px,3vw,40px);max-width:var(--max);margin:0 auto 40px;flex-wrap:wrap}
.section-head .num{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.6}
.section-head h2{font-family:var(--type-display);font-size:clamp(48px,7vw,120px);line-height:.9}
.section-head .meta{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;text-align:right}

.shop{padding:clamp(60px,9vw,140px) 0}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
@media(max-width:1100px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.grid{grid-template-columns:1fr}}
.card{position:relative;background:var(--paper);overflow:hidden;display:flex;flex-direction:column}
.card .img{position:relative;aspect-ratio:3/4;overflow:hidden;background:#111}
.card .img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--easing),filter .6s var(--easing)}
.card .img .alt{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s var(--easing)}
.card:hover .img img{transform:scale(1.06)}
.card:hover .img .alt{opacity:1}
.card .badge{position:absolute;top:16px;left:16px;z-index:3;font-family:var(--type-mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;background:var(--accent);color:var(--bone);padding:6px 10px}
.card .quickadd{position:absolute;left:16px;right:16px;bottom:16px;z-index:3;display:flex;justify-content:center;gap:6px;transform:translateY(140%);transition:transform .55s var(--easing)}
.card:hover .quickadd{transform:translateY(0)}
.card .quickadd .size{flex:1;text-align:center;padding:12px 0;border:1px solid var(--bone);background:rgba(0,0,0,.6);font-family:var(--type-mono);font-size:11px;letter-spacing:.18em;transition:background .25s var(--easing),color .25s var(--easing)}
.card .quickadd .size:hover{background:var(--bone);color:var(--ink)}
.card .quickadd .size[disabled]{opacity:.3;text-decoration:line-through;pointer-events:none}
.card .info{display:grid;grid-template-columns:1fr auto;gap:6px 16px;padding:18px 18px 22px}
.card .info h3{font-family:var(--type-display);font-size:clamp(22px,1.8vw,28px);line-height:1;font-weight:400}
.card .info h3 a{display:block}
.card .info .price{font-family:var(--type-mono);font-size:13px;letter-spacing:.1em;color:var(--accent)}
.card .info .desc{grid-column:1/-1;font-size:14px;opacity:.7;font-style:italic}
.card .info .stock{grid-column:1/-1;font-family:var(--type-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;opacity:.6;margin-top:6px}

.manifesto{padding:clamp(80px,12vw,180px) clamp(16px,3vw,40px);max-width:1100px;margin:auto;text-align:center}
.manifesto .num{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;margin-bottom:30px}
.manifesto p{font-family:var(--type-body);font-style:italic;font-size:clamp(28px,4vw,56px);line-height:1.18;letter-spacing:-.005em}
.manifesto p .word{display:inline-block;opacity:.18;transition:opacity .5s var(--easing)}
.manifesto p .word.lit{opacity:1}
.manifesto .sig{font-family:var(--type-display);font-size:clamp(28px,3vw,42px);margin-top:40px}



.trust{padding:30px clamp(16px,3vw,40px);border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase}
.trust div{display:flex;align-items:center;gap:10px;opacity:.85}
.trust svg{width:18px;height:18px;flex:0 0 18px}

.nl{position:relative;padding:clamp(80px,12vw,160px) clamp(16px,3vw,40px);display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;max-width:var(--max);margin:auto}
@media(max-width:900px){.nl{grid-template-columns:1fr}}
.nl .copy h2{font-family:var(--type-display);font-size:clamp(56px,7vw,140px);line-height:.85;margin-bottom:24px}
.nl .copy p{font-size:clamp(16px,1.2vw,19px);opacity:.85;max-width:46ch;margin-bottom:18px}
.nl .copy .promo{display:inline-block;border:1px solid var(--accent);background:var(--accent-soft);padding:8px 14px;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--bone)}
.nl form{display:flex;flex-direction:column;gap:14px}
.nl .field{position:relative;border-bottom:1px solid var(--line-strong);padding-bottom:8px}
.nl .field input{width:100%;background:none;border:none;outline:none;color:var(--bone);font-family:var(--type-body);font-size:22px;padding:14px 0}
.nl .field label{position:absolute;left:0;top:14px;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.5;transition:transform .35s var(--easing),opacity .35s var(--easing);pointer-events:none}
.nl .field input:focus + label,.nl .field input:not(:placeholder-shown) + label{transform:translateY(-22px);opacity:.9;font-size:10px}
.nl .check{display:flex;gap:10px;font-size:13px;opacity:.7}
.nl button{align-self:flex-start;margin-top:8px}
.nl .ok{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--bone);opacity:0;height:0;transition:opacity .4s var(--easing)}
.nl .ok.show{opacity:1;height:auto}

footer{padding:80px clamp(16px,3vw,40px) 24px;border-top:1px solid var(--line);position:relative}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;max-width:var(--max);margin:auto}
@media(max-width:768px){.foot-grid{grid-template-columns:1fr 1fr}}
.foot-grid h4{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;margin-bottom:18px}
.foot-grid ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:15px;opacity:.85}
.foot-grid ul a:hover{text-decoration:underline}
.foot-grid .brand-block .logo{font-family:var(--type-display);font-size:64px;line-height:1}
.foot-grid .brand-block p{font-size:14px;opacity:.7;max-width:38ch;font-style:italic;margin-top:8px}
.bottom{margin-top:60px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:var(--type-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;opacity:.6}


.sticky-cta{position:fixed;left:16px;right:16px;bottom:16px;z-index:4000;background:var(--accent);color:var(--bone);display:none;padding:16px;justify-content:space-between;align-items:center;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase}
@media(max-width:768px){.sticky-cta{display:flex}}

.cookies{position:fixed;left:24px;right:24px;bottom:24px;z-index:6000;background:#000;border:1px solid var(--bone);padding:18px 22px;display:none;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap;font-size:13px}
.cookies.show{display:flex;animation:fadeUp .6s var(--easing)}
@keyframes fadeUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.cookies .actions{display:flex;gap:10px}
.cookies button{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;border:1px solid var(--bone);padding:10px 14px}
.cookies button.refuse{opacity:.7}

.reveal{opacity:1;animation:revealFade 1s cubic-bezier(.2,.8,.2,1) both}
.reveal.in{opacity:1}
.reveal-mask{display:inline-block;overflow:hidden}
.reveal-mask .inner{display:inline-block;animation:revealRise 1.1s cubic-bezier(.2,.8,.2,1) both}
.reveal-mask.in .inner{transform:translateY(0)}
@keyframes revealFade{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes revealRise{from{transform:translateY(110%)}to{transform:translateY(0)}}

.drawer{position:fixed;top:0;right:0;bottom:0;width:min(440px,92vw);z-index:7000;background:#000;border-left:1px solid var(--line);transform:translateX(100%);transition:transform .55s var(--easing);display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-head{padding:24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer-head h3{font-family:var(--type-display);font-size:32px}
.drawer-head .x{font-family:var(--type-mono);font-size:18px;cursor:pointer}
.drawer-body{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;gap:16px}
.drawer-body .empty{font-style:italic;opacity:.6;text-align:center;padding:40px 0}
.drawer-item{display:grid;grid-template-columns:80px 1fr auto;gap:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.drawer-item img{width:80px;height:100px;object-fit:cover}
.drawer-item .name{font-family:var(--type-display);font-size:20px}
.drawer-item .opt{font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin-top:4px}
.drawer-item .price{font-family:var(--type-mono);font-size:13px}
.drawer-item .rm{font-family:var(--type-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;opacity:.6;margin-top:6px;cursor:pointer}
.drawer-foot{padding:24px;border-top:1px solid var(--line)}
.drawer-foot .total{display:flex;justify-content:space-between;font-family:var(--type-mono);font-size:13px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px}
.drawer-foot .ship{font-family:var(--type-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;opacity:.6;margin-bottom:14px}
.drawer-foot .checkout{width:100%;justify-content:center}
.scrim{position:fixed;inset:0;z-index:6500;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .4s var(--easing)}
.scrim.show{opacity:1;pointer-events:auto}

.ticker{border-top:1px solid var(--line);padding:14px 0;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;display:flex;justify-content:space-between;padding-left:clamp(16px,3vw,40px);padding-right:clamp(16px,3vw,40px);opacity:.7}

/* Pages internes */
.page-wrap{padding:140px clamp(16px,3vw,40px) 80px;max-width:1200px;margin:auto}
.page-wrap h1{font-family:var(--type-display);font-size:clamp(48px,7vw,120px);line-height:.9;margin-bottom:30px}
.page-wrap h2{font-family:var(--type-display);font-size:clamp(32px,4vw,56px);margin:30px 0 16px}
.page-wrap p{font-size:clamp(16px,1.1vw,19px);opacity:.85;margin-bottom:14px}
.page-wrap a{text-decoration:underline}
.rte img{margin:20px 0}

/* Product page */
.product{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;padding:140px clamp(16px,3vw,40px) 80px;max-width:var(--max);margin:auto}
@media(max-width:900px){.product{grid-template-columns:1fr}}

.product .info h1{font-family:var(--type-display);font-size:clamp(48px,5vw,84px);line-height:.95;margin-bottom:12px}
.product .info .price{font-family:var(--type-mono);font-size:18px;letter-spacing:.1em;margin-bottom:24px}
.product .info .desc{font-size:17px;opacity:.85;margin-bottom:30px}
.product .info .options{margin-bottom:24px}
.product .info .options label{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;display:block;margin-bottom:10px}
.product .info .size-row{display:flex;gap:8px;flex-wrap:wrap}
.product .info .size-row button{padding:14px 20px;border:1px solid var(--bone);font-family:var(--type-mono);font-size:12px;letter-spacing:.18em}
.product .info .size-row button.active{background:var(--bone);color:var(--ink)}
.product .info .size-row button[disabled]{opacity:.3;text-decoration:line-through;pointer-events:none}
.product .info .add{width:100%;justify-content:center;margin-top:18px}

/* Collection */
.coll-head{padding:140px clamp(16px,3vw,40px) 30px;max-width:var(--max);margin:auto;text-align:center}
.coll-head h1{font-family:var(--type-display);font-size:clamp(56px,8vw,140px);line-height:.9}
.coll-head .desc{font-size:17px;opacity:.85;max-width:60ch;margin:18px auto 0;font-style:italic}

/* Customer forms */


@media(max-width:600px){.nav{grid-template-columns:auto 1fr auto;font-size:11px}.nav .left{display:none}.hero-brand{font-size:clamp(58px,18vw,120px)}}


/* SEARCH OVERLAY */
.search-overlay{position:fixed;inset:0;z-index:7500;background:rgba(0,0,0,.94);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:flex;flex-direction:column;padding:90px clamp(16px,3vw,40px) 40px;opacity:0;pointer-events:none;transition:opacity .35s var(--easing)}
.search-overlay.open{opacity:1;pointer-events:auto}
.search-wrap{max-width:900px;width:100%;margin:0 auto}
.search-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.7}
.search-close{cursor:pointer}
.search-form{position:relative;border-bottom:1px solid var(--line-strong)}
.search-input{width:100%;background:none;border:none;outline:none;color:var(--bone);font-family:var(--type-display);font-size:clamp(36px,7vw,84px);line-height:1;padding:16px 60px 16px 0;letter-spacing:-.01em}
.search-input::placeholder{color:var(--bone);opacity:.25}
.search-go{position:absolute;right:0;top:50%;transform:translateY(-50%);font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;cursor:pointer;opacity:.7;transition:opacity .3s}
.search-go:hover{opacity:1;color:var(--accent)}
.search-results{margin-top:30px;overflow-y:auto;max-height:60vh}
.search-results .empty{font-style:italic;opacity:.5;text-align:center;padding:30px 0}
.search-results .group{margin-bottom:24px}
.search-results .group h4{font-family:var(--type-mono);font-size:10px;letter-spacing:.35em;text-transform:uppercase;opacity:.55;margin-bottom:12px;border-bottom:1px solid var(--line);padding-bottom:8px}
.search-results .row{display:flex;align-items:center;gap:14px;padding:10px 12px;border-bottom:1px solid var(--line);transition:background .25s var(--easing),padding-left .25s var(--easing)}
.search-results .row:hover{background:var(--accent-soft);padding-left:18px}
.search-results .row img{width:54px;height:70px;object-fit:cover;flex:0 0 54px}
.search-results .row .meta{flex:1;min-width:0}
.search-results .row .ttl{font-family:var(--type-display);font-size:22px;line-height:1.05;color:var(--bone)}
.search-results .row .sub{font-family:var(--type-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;opacity:.6;margin-top:4px}
.search-results .row .px{font-family:var(--type-mono);font-size:13px;letter-spacing:.1em;color:var(--accent)}
.search-results .row .arr{opacity:.4;transition:transform .25s var(--easing),opacity .25s}
.search-results .row:hover .arr{opacity:1;transform:translateX(4px);color:var(--accent)}
@media(max-width:600px){.search-input{font-size:32px;padding-right:50px}.search-go{font-size:10px}}


/* BUNDLES */
.bundle-info{margin:20px 0 30px;padding:18px;border:1px solid var(--line);background:rgba(0,0,0,.3)}
.bundle-item{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid var(--line);transition:padding-left .25s var(--easing),background .25s var(--easing)}
.bundle-item:last-child{border-bottom:0}
.bundle-item:hover{padding-left:8px;background:var(--accent-soft)}
.bundle-item img{width:60px;height:80px;object-fit:cover;flex:0 0 60px}
.bundle-item .bi-body{flex:1;min-width:0}
.bundle-item .bi-title{font-family:var(--type-display);font-size:22px;line-height:1.1}
.bundle-item .bi-stat{font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.75;margin-top:4px}
.bundle-item .bi-stat.out{color:var(--accent);opacity:1}
.bundle-item .bi-arr{opacity:.5;transition:transform .25s,opacity .25s}
.bundle-item:hover .bi-arr{opacity:1;transform:translateX(4px);color:var(--accent)}
.bundle-warn{margin-top:14px;padding:12px 14px;border:1px solid var(--accent);background:var(--accent-soft);font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase}


/* === LOADER FLUIDE SANS TEXTE === */
#loader{position:fixed;top:0;left:0;right:0;z-index:10000;height:2px;background:transparent;pointer-events:none}
#loader .loader-bar{display:block;height:100%;width:0;background:var(--accent);transition:width .5s cubic-bezier(.25,.8,.25,1)}
body:not(.loaded) #loader .loader-bar{width:30%;animation:loadGrow 1.2s cubic-bezier(.25,.8,.25,1) forwards}
@keyframes loadGrow{0%{width:0}40%{width:60%}80%{width:90%}100%{width:100%}}
body.loaded #loader{opacity:0;transition:opacity .25s .1s}
body.loaded #loader .loader-bar{width:100%}

/* === SOCIAL ICONS === */
.socials{display:flex;gap:12px;margin-top:18px}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--line-strong);border-radius:50%;transition:background .25s,border-color .25s,color .25s}
.socials a:hover{background:var(--accent);border-color:var(--accent);color:var(--bone)}
.socials svg{width:18px;height:18px}

/* === ACCORDÉONS === */
.accordions{margin-top:36px;border-top:1px solid var(--line)}
.acc{border-bottom:1px solid var(--line)}
.acc summary{list-style:none;padding:18px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-family:var(--type-mono);font-size:12px;letter-spacing:.25em;text-transform:uppercase}
.acc summary::-webkit-details-marker{display:none}
.acc summary:hover{color:var(--accent)}
.acc-icon{transition:transform .35s var(--easing);display:inline-block;font-size:18px;line-height:1}
.acc[open] .acc-icon{transform:rotate(45deg);color:var(--accent)}
.acc-body{padding:0 0 22px;font-size:15px;line-height:1.7;opacity:.85;font-family:var(--type-body)}
.acc-body p{margin-bottom:8px}
.acc-body table{width:100%;border-collapse:collapse;margin:10px 0;font-family:var(--type-mono);font-size:12px}
.acc-body table th,.acc-body table td{border-bottom:1px solid var(--line);padding:8px;text-align:left}

/* === BUNDLE PAGE (config tee + short) === */
.bundle-page{display:flex;flex-direction:column;align-items:center;text-align:center;padding:120px clamp(16px,3vw,40px) 60px;max-width:var(--max);margin:auto}
.bundle-page-head{max-width:760px;margin-bottom:50px}
.bundle-badge{display:inline-block;background:var(--accent);color:var(--bone);padding:6px 14px;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;margin-bottom:18px}
.bundle-page h1{font-family:var(--type-display);font-size:clamp(48px,7vw,108px);line-height:.95;margin-bottom:16px}
.bundle-page .price.big{font-family:var(--type-mono);font-size:20px;letter-spacing:.1em;margin-bottom:18px;color:var(--accent)}
.bundle-page .price.big s{opacity:.5;margin-left:8px;color:var(--bone);font-size:16px}
.bundle-page .desc{font-size:17px;opacity:.85;margin-bottom:0}
.bundle-warn{margin-top:18px;padding:12px 14px;border:1px solid var(--accent);background:var(--accent-soft);font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase}

.bundle-config{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;width:100%;max-width:960px;margin-bottom:40px}
.bundle-comp{display:flex;flex-direction:column;gap:16px;padding:20px;border:1px solid var(--line);background:rgba(0,0,0,.3);transition:border-color .3s}
.bundle-comp.ready{border-color:var(--accent)}
.bundle-comp-img{display:block;aspect-ratio:3/4;overflow:hidden;background:#111}
.bundle-comp-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--easing)}
.bundle-comp-img:hover img{transform:scale(1.04)}
.bundle-comp-meta{text-align:left}
.bundle-comp-meta h3{font-family:var(--type-display);font-size:28px;line-height:1;margin-bottom:4px}
.bundle-comp-px{font-family:var(--type-mono);font-size:13px;letter-spacing:.1em;opacity:.7}
.bundle-comp-size{width:100%;background:#000;color:var(--bone);border:1px solid var(--bone);padding:14px 16px;font-family:var(--type-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23f3efe6' stroke-width='1.5' fill='none'/></svg>");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px;transition:border-color .25s}
.bundle-comp-size:hover{border-color:var(--accent)}
.bundle-comp-size:focus{border-color:var(--accent)}

.bundle-add-wrap{display:flex;flex-direction:column;align-items:center;gap:10px}
.bundle-add{padding:20px 40px;font-size:13px}
.bundle-add[disabled]{opacity:.4;pointer-events:none}
.bundle-add-hint{font-family:var(--type-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;opacity:.55}

/* === BUNDLE INFO TITLE === */
.bundle-info-title{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.7;margin-bottom:14px}

/* === HERO ADDS === */
.hero-eyebrow{font-family:var(--type-mono);font-size:11px;letter-spacing:.45em;text-transform:uppercase;opacity:.7;margin-bottom:24px}
.hero-sub{font-family:var(--type-body);font-style:italic;font-size:clamp(16px,1.4vw,22px);margin-top:20px;max-width:620px;margin-left:auto;margin-right:auto;opacity:0;animation:fade .9s var(--easing) .9s forwards}

/* === MANIFESTO BG === */


/* === SEARCH HIGHLIGHT === */
.search-results mark{background:var(--accent);color:var(--bone);padding:0 2px}
.search-results .row.kb-active{background:var(--accent-soft);padding-left:18px}


/* ====== HERO MÉDIA (z-index strict, texte intouchable) ====== */
.hero{position:relative}
.hero .bg{z-index:0}
.hero-media{position:absolute;inset:0;z-index:1;overflow:hidden}
.hero-media video,
.hero-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.85) contrast(1.02) saturate(1)}
.hero-overlay{z-index:2}
.hero .smoke{z-index:3;opacity:.32}
.hero-inner{position:relative;z-index:5}
.scroll-cue{z-index:5}

/* ====== DROP MÉDIA ====== */
.drop .visual{position:relative;aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:#111}
.visual-media{position:absolute;inset:0;z-index:1}
.visual-media video,
.visual-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.05);transition:transform 6s var(--easing)}
.drop:hover .visual-media video,
.drop:hover .visual-media img{transform:scale(1)}
.drop .visual::before{z-index:2}
.drop .visual .tag,
.drop .visual .label{z-index:3}

/* ====== MANIFESTO BG ====== */
.manifesto-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.manifesto-overlay{position:absolute;inset:0;background:rgba(10,10,10,.82);z-index:1}
.manifesto-inner{position:relative;z-index:2}
.manifesto{position:relative;overflow:hidden}


/* === IFRAMES VIDÉO (YouTube/Vimeo) — cover total === */
.hero-media iframe,
.hero-iframe{position:absolute;top:50%;left:50%;width:177.78vh;height:56.25vw;min-width:100%;min-height:100%;transform:translate(-50%,-50%);pointer-events:none;border:0;filter:brightness(.85) contrast(1.02) saturate(1)}

.visual-media iframe,
.drop-iframe{position:absolute;top:50%;left:50%;width:177.78%;height:177.78%;min-width:100%;min-height:100%;transform:translate(-50%,-50%);pointer-events:none;border:0}

/* Si l'iframe est dans un container plus petit que le viewport (ex: drop), couvre via aspect-ratio */
.visual-media{overflow:hidden}


/* ====== ACCOUNT & CONTACT PAGES ====== */
.account-page,.contact-page{max-width:1100px;margin:auto;padding:140px clamp(16px,3vw,40px) 80px}
.account-head,.contact-head{margin-bottom:50px}
.account-head .num,.contact-head .num{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;margin-bottom:14px}
.account-head h1,.contact-head h1{font-family:var(--type-display);font-size:clamp(56px,8vw,140px);line-height:.85;margin-bottom:12px}
.account-head .lead,.contact-head .lead{font-family:var(--type-body);font-style:italic;font-size:clamp(17px,1.3vw,21px);opacity:.85;max-width:60ch}

.account-nav{display:flex;gap:24px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:18px 0;margin-bottom:40px;font-family:var(--type-mono);font-size:11px;letter-spacing:.25em;text-transform:uppercase;overflow-x:auto}
.account-nav a{position:relative;padding:4px 0;opacity:.6;transition:opacity .25s,color .25s;white-space:nowrap}
.account-nav a:hover,.account-nav a.active{opacity:1;color:var(--accent)}
.account-nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-19px;height:1px;background:var(--accent)}

.account-section{margin-bottom:60px}
.acc-section-title{font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.6;margin-bottom:18px}

.account-grid{max-width:560px;margin:0 auto}
.form-card{padding:0}
.form-card .form-field,.form-card .form-row{margin-bottom:16px}
.form-subhead{font-family:var(--type-display);font-size:28px;margin-bottom:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}

.form-field{position:relative;border-bottom:1px solid var(--line-strong);padding-bottom:6px}
.form-field input,.form-field textarea{width:100%;background:none;border:none;outline:none;color:var(--bone);font-family:var(--type-body);font-size:18px;padding:14px 0;resize:vertical}
.form-field textarea{min-height:130px;line-height:1.5}
.form-field label{position:absolute;left:0;top:14px;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.5;transition:transform .35s var(--easing),opacity .35s var(--easing),font-size .35s var(--easing);pointer-events:none}
.form-field input:focus + label,.form-field input:not(:placeholder-shown) + label,.form-field textarea:focus + label,.form-field textarea:not(:placeholder-shown) + label{transform:translateY(-22px);opacity:.9;font-size:10px}

.form-consent{display:flex;gap:10px;font-size:13px;opacity:.75;margin:18px 0;align-items:flex-start;line-height:1.5}
.form-consent input{accent-color:var(--accent);margin-top:4px}
.form-consent a{text-decoration:underline}

.form-alt{margin-top:20px;font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.7;display:flex;gap:20px;flex-wrap:wrap}
.form-alt a{position:relative}
.form-alt a:hover{color:var(--accent)}

.form-success{padding:14px;border:1px solid var(--accent);background:var(--accent-soft);font-family:var(--type-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px}
.form-card .errors,.form-errors,form .errors{border:1px solid var(--accent);background:var(--accent-soft);padding:14px;margin-bottom:18px;font-size:14px;font-style:italic}
.form-card .errors ul,form .errors ul{padding-left:20px;margin:6px 0 0}

/* CONTACT GRID */
.contact-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:60px;align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:40px}}
.contact-info{display:flex;flex-direction:column;gap:30px}
.info-block h3{font-family:var(--type-mono);font-size:10px;letter-spacing:.35em;text-transform:uppercase;opacity:.5;margin-bottom:8px}
.info-block a,.info-block p{font-family:var(--type-display);font-size:24px;line-height:1.2;display:block;color:var(--bone)}
.info-block a:hover{color:var(--accent)}
.info-block p{font-family:var(--type-body);font-size:16px;font-style:italic;opacity:.85}

.contact-success{text-align:center;padding:60px 30px;border:1px solid var(--accent)}
.contact-success h2{font-family:var(--type-display);font-size:48px;color:var(--accent);margin-bottom:14px}
.contact-errors{border:1px solid var(--accent);background:var(--accent-soft);padding:16px;margin-bottom:20px;font-size:14px}

/* ORDERS TABLE */
.orders-table{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.orders-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr 1.2fr;gap:14px;padding:18px 0;border-bottom:1px solid var(--line);font-family:var(--type-mono);font-size:13px;letter-spacing:.05em;transition:background .25s,padding-left .25s}
.orders-row:not(.orders-head):hover{background:var(--accent-soft);padding-left:14px}
.orders-head{font-size:10px;letter-spacing:.3em;text-transform:uppercase;opacity:.5}
.orders-num{font-family:var(--type-display);font-size:22px;color:var(--bone)}
.orders-row:not(.orders-head):hover .orders-num{color:var(--accent)}
.orders-total{font-weight:700}
.orders-status{font-size:11px;letter-spacing:.18em;text-transform:uppercase}
.status-paid,.status-fulfilled{color:#7aa05a}
.status-pending,.status-partial,.status-partially_fulfilled{color:#e0a93b}
.status-refunded,.status-voided,.status-unfulfilled{color:var(--accent)}
@media(max-width:768px){.orders-row{grid-template-columns:1fr 1fr;gap:8px;padding:14px 0}.orders-head{display:none}.orders-num{font-size:18px}}

/* ADDRESSES */
.address-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-bottom:30px}
.address-card{padding:24px;border:1px solid var(--line);background:rgba(0,0,0,.3);position:relative;font-size:14px;line-height:1.7}
.address-card.is-default{border-color:var(--accent)}
.default-tag{position:absolute;top:-10px;left:16px;background:var(--accent);color:var(--bone);padding:4px 10px;font-family:var(--type-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase}
.address-actions{display:flex;gap:14px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-family:var(--type-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase}
.address-actions a{opacity:.7}
.address-actions a:hover{color:var(--accent);opacity:1}
.address-del{font-family:var(--type-mono);font-size:10px;letter-spacing:.25em;text-transform:uppercase;opacity:.5;cursor:pointer;background:none;border:none;color:inherit}
.address-del:hover{color:var(--accent);opacity:1}
.address-edit{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.address-add summary{cursor:pointer;list-style:none;display:inline-flex}
.address-add summary::-webkit-details-marker{display:none}

/* ORDER DETAIL */
.order-status-row{display:flex;gap:30px;flex-wrap:wrap;padding:24px;border:1px solid var(--line);margin-bottom:40px;background:rgba(0,0,0,.3)}
.order-status-item{display:flex;flex-direction:column;gap:6px}
.order-status-item .lbl{font-family:var(--type-mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;opacity:.5}
.order-status-item .val{font-family:var(--type-display);font-size:24px}
.order-items{display:flex;flex-direction:column;border-top:1px solid var(--line)}
.order-item{display:grid;grid-template-columns:80px 1fr auto;gap:18px;padding:18px 0;border-bottom:1px solid var(--line);align-items:center}
.order-item img{width:80px;height:100px;object-fit:cover}
.oi-title{font-family:var(--type-display);font-size:22px}
.oi-meta{font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin-top:4px}
.oi-price{font-family:var(--type-mono);font-size:14px}
.order-totals{margin-top:24px;padding:20px;border:1px solid var(--line);background:rgba(0,0,0,.3)}
.order-totals > div{display:flex;justify-content:space-between;padding:8px 0;font-family:var(--type-mono);font-size:13px;letter-spacing:.1em}
.order-totals > div.grand{padding-top:16px;margin-top:8px;border-top:1px solid var(--line);font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.2em}

/* EMPTY STATE */
.empty-state{text-align:center;padding:60px 30px;border:1px solid var(--line);background:rgba(0,0,0,.3)}
.empty-state p{font-family:var(--type-body);font-style:italic;font-size:20px;opacity:.7;margin-bottom:24px}


/* ====== BUNDLE INLINE (sur fiche tee/short) ====== */
.bundle-inline{margin-top:40px;padding:30px;border:1px solid var(--accent);background:var(--accent-soft);position:relative}
.bundle-inline-head{margin-bottom:24px;text-align:center}
.bundle-inline-tag{display:inline-block;font-family:var(--type-mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.bundle-inline-head h3{font-family:var(--type-display);font-size:clamp(28px,3vw,40px);line-height:1;margin-bottom:8px}
.bundle-inline-price{display:flex;justify-content:center;align-items:baseline;gap:10px;flex-wrap:wrap;font-family:var(--type-mono);font-size:13px;letter-spacing:.05em}
.bundle-inline-price .px-now{color:var(--accent);font-size:18px;font-weight:700}
.bundle-inline-price .px-was{opacity:.5}
.bundle-inline-price .px-save{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);padding:3px 8px}

.bundle-inline-comps{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:start;margin-bottom:24px}
.bic{display:flex;flex-direction:column;gap:10px;padding:14px;border:1px solid var(--line);background:rgba(0,0,0,.4);transition:border-color .3s}
.bic.ready{border-color:var(--accent)}
.bic img{width:100%;aspect-ratio:3/4;object-fit:cover;background:#111}
.bic-title{font-family:var(--type-display);font-size:18px;line-height:1.1;margin-bottom:8px}
.bic-plus{align-self:center;font-family:var(--type-display);font-size:32px;color:var(--accent);padding:0 6px}
.bic-size{width:100%;background:#000;color:var(--bone);border:1px solid var(--bone);padding:12px 14px;font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23f3efe6' stroke-width='1.5' fill='none'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px;transition:border-color .25s}
.bic-size:hover,.bic-size:focus{border-color:var(--accent)}
.bundle-inline-add{width:100%;justify-content:center;padding:18px}
.bundle-inline-add[disabled]{opacity:.5;pointer-events:none}

@media(max-width:600px){
  .bundle-inline-comps{grid-template-columns:1fr;gap:14px}
  .bic-plus{display:none}
}


/* ====== CART DRAWER : groupage bundle ====== */
.drawer-bundle{border:1px solid var(--accent);background:var(--accent-soft);padding:14px;margin-bottom:14px}
.drawer-bundle-head{display:flex;justify-content:space-between;align-items:center;padding-bottom:10px;border-bottom:1px solid var(--line);margin-bottom:10px}
.drawer-bundle .db-tag{font-family:var(--type-mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent)}
.drawer-bundle .db-title{font-family:var(--type-display);font-size:18px}
.drawer-item-bundled{padding-bottom:10px !important;border-bottom:1px dashed var(--line) !important}
.drawer-item-bundled:last-of-type{border-bottom:0 !important;padding-bottom:0 !important}
.drawer-bundle-foot{font-family:var(--type-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.85;text-align:right;padding-top:10px;margin-top:10px;border-top:1px solid var(--line)}
.drawer-bundle-foot strong{color:var(--accent);font-weight:700;font-size:13px}


.bundle-inline-price{flex-wrap:wrap;justify-content:center;align-items:center}
.px-bundle-hint{flex:1 0 100%;font-family:var(--type-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;opacity:.6;text-align:center;margin-top:6px}

.px-bundle-savings{font-family:var(--type-mono);font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);padding:4px 10px;display:inline-block;margin-top:8px}





/* ====== LOOKBOOK MARQUEE (drag + auto-scroll JS) ====== */
.look-marquee-section{padding:clamp(60px,9vw,140px) 0;overflow:hidden}
.look-marquee{position:relative;width:100%}
.look-marquee::before,
.look-marquee::after{content:"";position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.look-marquee::before{left:0;background:linear-gradient(to right,var(--paper),transparent)}
.look-marquee::after{right:0;background:linear-gradient(to left,var(--paper),transparent)}
.look-marquee-track{display:flex;gap:24px;padding:0 16px;overflow-x:auto;scrollbar-width:none;cursor:grab;-webkit-overflow-scrolling:touch;scroll-behavior:auto;user-select:none}
.look-marquee-track::-webkit-scrollbar{display:none}
.look-marquee-track.is-grabbing{cursor:grabbing}
.look-marquee-frame{flex:0 0 auto;width:clamp(240px,26vw,400px);aspect-ratio:3/4;overflow:hidden;border:1px solid var(--line);background:#111;pointer-events:none}
.look-marquee-frame img{width:100%;height:100%;object-fit:cover;pointer-events:none}
.look-marquee-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;opacity:.4}


}




/* ====== PRODUIT : gallery empilée à gauche, info sticky à droite ====== */
.product{align-items:start}
.product .gallery{display:flex;flex-direction:column;gap:14px}
.product .gallery img{width:100%;height:auto;border:1px solid var(--line);display:block}
.product .info{position:sticky;top:100px;align-self:start;max-height:calc(100vh - 120px);overflow-y:auto;scrollbar-width:thin;padding-right:6px}
.product .info::-webkit-scrollbar{width:4px}
.product .info::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:2px}
@media(max-width:900px){
  .product .info{position:static;top:auto;max-height:none;overflow:visible}
}


/* ====== CARD CAROUSEL (catalogue, swipeable avant clic) ====== */
.card .img{position:relative}
.card-carousel{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-webkit-overflow-scrolling:touch;height:100%;aspect-ratio:3/4;cursor:grab;user-select:none;background:#111}
.card-carousel.is-grabbing{cursor:grabbing}
.card-carousel::-webkit-scrollbar{display:none}
.card-slide{flex:0 0 100%;scroll-snap-align:center;display:block;height:100%}
.card-slide img{width:100%;height:100%;object-fit:cover;pointer-events:none;display:block}
.card-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.55);color:var(--bone);border:1px solid var(--bone);width:32px;height:32px;font-size:18px;font-family:var(--type-mono);cursor:pointer;z-index:3;display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .25s,background .25s,border-color .25s;padding:0}
.card:hover .card-arrow{opacity:1}
.card-arrow.prev{left:8px}
.card-arrow.next{right:8px}
.card-arrow:hover{background:var(--accent);border-color:var(--accent)}
@media(min-width:1024px){.card-arrow{display:inline-flex}}
.card-dots{position:absolute;bottom:8px;left:0;right:0;display:flex;justify-content:center;gap:4px;z-index:3;pointer-events:none}
.card-dots .dot{width:5px;height:5px;border-radius:50%;background:rgba(243,239,230,.4);transition:background .25s,transform .25s}
.card-dots .dot.active{background:var(--accent);transform:scale(1.4)}
.card .badge{z-index:3}
.card .quickadd{z-index:3}


/* ====== FOOTER : dropdown légal (JS-controlled) ====== */
.legal-dropdown{position:relative;display:inline-block}
.legal-trigger{
  cursor:pointer;
  font-family:var(--type-mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--bone);opacity:.75;
  background:rgba(0,0,0,.4);
  border:1px solid var(--accent);
  padding:7px 14px;
  transition:color .25s,opacity .25s,background .25s
}
.legal-trigger:hover{opacity:1;color:var(--accent);background:rgba(185,28,44,.12)}
.legal-dropdown.is-open .legal-trigger{color:var(--accent);opacity:1;background:rgba(185,28,44,.18)}

.legal-menu{
  position:absolute;
  left:50%;
  bottom:calc(100% + 10px);
  transform:translateX(-50%);
  background:#000;
  border:1px solid var(--accent);
  box-shadow:0 12px 40px rgba(185,28,44,.18), 0 0 0 1px rgba(185,28,44,.25);
  padding:14px 22px;
  list-style:none;margin:0;
  white-space:nowrap;
  z-index:5000;
  min-width:220px;
  display:none;
  flex-direction:column;
  gap:10px;
}
.legal-dropdown.is-open .legal-menu{
  display:flex;
  animation:legalFade .3s var(--easing)
}
@keyframes legalFade{from{opacity:0;transform:translateX(-50%) translateY(6px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

.legal-menu::after{
  content:"";position:absolute;
  left:50%;bottom:-6px;
  transform:translateX(-50%) rotate(45deg);
  width:10px;height:10px;background:#000;
  border-right:1px solid var(--accent);
  border-bottom:1px solid var(--accent);
}
.legal-menu li{padding:0}
.legal-menu a{
  font-family:var(--type-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone);opacity:.85;
  display:block;text-align:center;padding:2px 0;
  transition:color .25s,opacity .25s
}
.legal-menu a:hover{opacity:1;color:var(--accent)}
