/* =========================================================
   NOCKD — V4  ·  BRUTALISTE ÉDITORIAL
   Noir · Blanc · Rouge · Gris(texte)  |  radius 0  |  grille visible
   ========================================================= */

@font-face{font-family:"Clash Display";src:url("../fonts/ClashDisplay-Semibold.otf") format("opentype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Satoshi";src:url("../fonts/Satoshi-Medium.otf") format("opentype");font-weight:400 500;font-style:normal;font-display:swap}
@font-face{font-family:"Satoshi";src:url("../fonts/Satoshi-Black.otf") format("opentype");font-weight:700 900;font-style:normal;font-display:swap}
@font-face{font-family:"Aleo";src:url("../fonts/Aleo.ttf") format("truetype");font-weight:100 900;font-style:normal;font-display:swap}

:root{
  --font-display:"Clash Display",sans-serif;
  --font-sans:"Satoshi",sans-serif;
  --font-slab:"Aleo",serif;

  --black:#0A0A0A;
  --white:#FFFFFF;
  --red:#E63228;
  --red-deep:#C9271E;
  --gray:#666666;

  --gl-dark:rgba(255,255,255,.05);   /* grid lines on black */
  --gl-light:rgba(10,10,10,.07);     /* grid lines on white */
  --hair-dark:rgba(255,255,255,.16);
  --hair-light:rgba(10,10,10,.14);

  --container:1320px;
  --pad:clamp(18px,4.5vw,64px);
  --ease:cubic-bezier(.3,.86,.36,1);
  --snap:cubic-bezier(.6,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--font-sans);font-weight:400;color:var(--black);background:var(--black);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--red);color:#fff}
:focus-visible{outline:2px solid var(--red);outline-offset:2px}

h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;margin:0;line-height:.9;letter-spacing:-.02em}
p{margin:0}

.container{width:100%;max-width:var(--container);margin:0 auto;padding-inline:var(--pad);position:relative}
.section{position:relative}

/* ---------- Grid overlay (retiré — V8 : aucune ligne verticale visible) ---------- */
.gridlines{display:none !important}

/* ---------- Labels / meta ---------- */
.label{font-family:var(--font-slab);font-weight:600;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray)}
.kicker{display:inline-flex;align-items:center;gap:.85em;flex-wrap:wrap;font-family:var(--font-slab);font-weight:600;font-size:.76rem;letter-spacing:.26em;text-transform:uppercase;color:#fff}
.kicker::before{content:"";width:40px;height:2px;background:var(--red);flex:none}
.kicker .sep{color:var(--red)}

/* section index : 01 — NOS SUPPORTS */
.sec-index{display:flex;align-items:center;gap:14px;font-family:var(--font-slab);font-weight:600;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase}
.sec-index .n{color:var(--red)}
.sec-index .dash{width:26px;height:1px;background:currentColor;opacity:.4}

/* thick section rule */
.rule-top{border-top:2px solid currentColor}

/* ---------- Symbol / wordmark ---------- */
.nk-symbol{display:block;width:1em;height:1em;flex:none}
.nk-symbol path{fill:currentColor}
.nk-symbol .nk-accent{fill:var(--red)}
.nk-word{display:block;width:118px;height:30px;background:currentColor;-webkit-mask:url("../logo/wordmark.svg") left center/contain no-repeat;mask:url("../logo/wordmark.svg") left center/contain no-repeat}

/* ---------- Buttons (angular) ---------- */
.btn{--bg:var(--red);--fg:#fff;position:relative;display:inline-flex;align-items:center;gap:.8em;font-family:var(--font-sans);font-weight:900;font-size:.92rem;letter-spacing:.08em;padding:17px 30px;border:none;border-radius:0;background:var(--bg);color:var(--fg);text-transform:uppercase;transition:background .15s var(--snap)}
.btn .arr{width:1em;height:1em;transition:transform .2s var(--snap)}
.btn:hover{background:var(--red-deep)}
.btn:hover .arr{transform:translateX(6px)}
.btn--lg{padding:20px 38px;font-size:1rem}
.btn--block{width:100%;justify-content:center}
.btn--invert{--bg:#fff;--fg:var(--black)}
.btn--invert:hover{--bg:var(--red);--fg:#fff}

.textlink{display:inline-flex;align-items:center;gap:.55em;font-weight:900;letter-spacing:.06em;text-transform:uppercase;font-size:.84rem;border-bottom:2px solid var(--red);padding-bottom:3px;transition:gap .2s var(--snap)}
.textlink:hover{gap:.95em}
.textlink svg{width:15px;height:12px;transition:transform .2s var(--snap)}
.textlink:hover svg{transform:translateX(5px)}

/* =========================================================
   HEADER
   ========================================================= */
.header{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .3s var(--snap),border-color .3s}
.header__inner{display:flex;align-items:center;gap:24px;height:70px;border-bottom:1px solid transparent}
.header__brand{display:flex;align-items:center;gap:11px;color:#fff}
.header__brand .nk-symbol{width:22px;height:22px}
.header__brand .nk-word{width:96px;height:22px}
.header__nav{display:flex;align-items:center;gap:34px;margin-left:auto}
.header__nav a{font-weight:500;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:#fff;opacity:.78;position:relative;padding:4px 0;transition:opacity .2s}
.header__nav a::after{content:"";position:absolute;left:0;bottom:-1px;height:2px;width:0;background:var(--red);transition:width .26s var(--snap)}
.header__nav a:hover{opacity:1}
.header__nav a:hover::after{width:100%}
.header__burger{display:none}
.header.is-solid{background:rgba(10,10,10,.82);backdrop-filter:saturate(1.1) blur(14px);-webkit-backdrop-filter:saturate(1.1) blur(14px)}
.header.is-solid .header__inner{border-color:var(--hair-dark)}

.mnav{position:fixed;inset:0;z-index:80;background:var(--black);color:#fff;display:flex;flex-direction:column;padding:18px var(--pad) 40px;transform:translateY(-100%);transition:transform .4s var(--snap);visibility:hidden}
.mnav.is-open{transform:none;visibility:visible}
.mnav__top{display:flex;align-items:center;height:70px}
.mnav__top .nk-word{width:96px;height:22px;color:#fff}
.mnav__close{margin-left:auto;background:none;border:1px solid var(--hair-dark);color:#fff;width:44px;height:44px;display:grid;place-items:center}
.mnav__links{display:flex;flex-direction:column;margin-top:24px;border-top:1px solid var(--hair-dark)}
.mnav__links a{font-family:var(--font-display);font-size:2rem;text-transform:uppercase;padding:18px 0;border-bottom:1px solid var(--hair-dark);display:flex;align-items:center;justify-content:space-between}
.mnav__links a .nk-symbol{width:18px;height:18px;color:var(--red)}
.mnav .btn{margin-top:30px}

/* =========================================================
   HERO — typographique
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;background:var(--black);color:#fff;padding-top:108px;padding-bottom:0;overflow:hidden}
.hero__inner{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:center;flex:1;padding-bottom:34px}
.hero__mark{position:absolute;z-index:0;width:min(66vw,720px);height:auto;right:-7%;top:50%;transform:translateY(-50%);opacity:.045;color:#fff;pointer-events:none}
.hero__mark .nk-accent{fill:#fff}
.hero .kicker{margin-bottom:clamp(20px,3vw,40px)}
.hero__title{font-family:var(--font-display);font-weight:600;font-size:clamp(60px,13.5vw,210px);line-height:.84;letter-spacing:-.025em;text-transform:uppercase;margin:0}
.hero__title .ln{display:block;overflow:hidden;padding-block:.01em}
.hero__title .ln i{display:block;font-style:normal;transform:translateY(110%);transition:transform .6s var(--ease)}
.js .hero__title.reveal-in .ln:nth-child(1) i{transition-delay:.05s}
.js .hero__title.reveal-in .ln:nth-child(2) i{transition-delay:.16s}
.js .hero__title.reveal-in .ln:nth-child(3) i{transition-delay:.27s}
.hero__title.reveal-in .ln i{transform:none}
.hero__title .acc{display:inline-block;width:.2em;height:.2em;border-radius:50%;background:var(--red);margin-left:.16em;vertical-align:.06em}
.hero__foot-text{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-top:clamp(28px,4vw,56px)}
.hero__lead{font-size:1.05rem;color:#C4C4C4;max-width:42ch;line-height:1.6}
.hero__ours{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-block:16px;border-top:2px solid #fff;font-family:var(--font-slab);font-weight:600;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:#fff}
.hero__ours .mid{display:flex;align-items:center;gap:12px;color:var(--gray)}
.hero__ours .nk-symbol{width:14px;height:14px;color:#fff}
.hero__scroll{display:inline-flex;align-items:center;gap:10px}
.hero__scroll .arrw{display:inline-block;width:10px;height:24px;position:relative}
.hero__scroll .arrw::after{content:"";position:absolute;left:50%;top:0;width:1px;height:100%;background:var(--gray);transform:translateX(-50%)}
.hero__scroll .arrw::before{content:"";position:absolute;left:50%;width:6px;height:6px;border-right:1px solid var(--red);border-bottom:1px solid var(--red);transform:translateX(-50%) rotate(45deg);animation:scrolldown 1.8s var(--ease) infinite;top:0}
@keyframes scrolldown{0%{top:0;opacity:0}40%{opacity:1}100%{top:16px;opacity:0}}
@media (prefers-reduced-motion:reduce){.hero__scroll .arrw::before{animation:none;top:14px}}

/* =========================================================
   MARQUEE
   ========================================================= */
.kwmarquee{background:var(--black);overflow:hidden;padding-block:clamp(16px,2.2vw,30px);border-top:2px solid #fff;border-bottom:2px solid #fff;position:relative;user-select:none}
.kwmarquee__track{display:flex;width:max-content;align-items:center;will-change:transform}
.kwmarquee__item{display:flex;align-items:center;gap:clamp(20px,2.6vw,40px);padding-right:clamp(20px,2.6vw,40px)}
.kw{font-family:var(--font-display);font-weight:600;font-size:clamp(24px,3.2vw,46px);line-height:1;letter-spacing:-.01em;text-transform:uppercase;color:#fff}
.kw--out{color:transparent;-webkit-text-stroke:1.5px #fff;text-stroke:1.5px #fff}
.kw-dot{width:.13em;height:.13em;border-radius:50%;background:var(--red);flex:none}

/* =========================================================
   SECTION HEAD
   ========================================================= */
.sec-head{display:grid;gap:18px;max-width:18ch;position:relative;z-index:2}
.sec-head--wide{max-width:24ch}
.sec-head h2{font-family:var(--font-display);font-weight:600;font-size:clamp(40px,6.4vw,84px);line-height:.92;letter-spacing:-.025em}
.sec-head p{font-family:var(--font-sans);color:var(--gray);font-size:1.02rem;max-width:46ch;line-height:1.6}

/* =========================================================
   SUPPORTS — catalogue (fond blanc)
   ========================================================= */
.supports{background:var(--white);color:var(--black);padding-block:clamp(64px,8vw,120px) clamp(72px,9vw,140px)}
.sec-top{display:flex;align-items:flex-start;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-top:26px;border-top:2px solid var(--black);position:relative;z-index:2}
.sec-top .sec-index{color:var(--black)}
.supports__group{margin-top:clamp(48px,6vw,92px);position:relative;z-index:2}
.group-label{display:flex;align-items:baseline;gap:18px;padding-bottom:16px;margin-bottom:0;border-bottom:1px solid var(--hair-light)}
.group-label .gnum{font-family:var(--font-display);font-weight:600;font-size:clamp(2.4rem,5vw,4rem);line-height:.8;color:var(--black)}
.group-label h3{font-family:var(--font-sans);font-weight:900;font-size:.92rem;letter-spacing:.16em;text-transform:uppercase}
.group-label .count{margin-left:auto;font-family:var(--font-slab);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray)}

.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-left:1px solid var(--hair-light);border-top:1px solid var(--hair-light)}
.card{position:relative;background:var(--white);border-right:1px solid var(--hair-light);border-bottom:1px solid var(--hair-light);display:flex;flex-direction:column;overflow:hidden}
.card__media{position:relative;aspect-ratio:1/1;background:#EFEFEF;overflow:hidden;border-bottom:1px solid var(--hair-light)}
.card__media .slide{position:absolute;inset:0;opacity:0;transition:opacity .35s var(--snap)}
.card__media .slide.is-on{opacity:1}
.card__media .slide img{width:100%;height:100%;object-fit:contain;padding:13%;box-sizing:border-box;filter:drop-shadow(0 14px 20px rgba(10,10,10,.18))}
.card[data-cat="gobelet"] .card__media .slide img{filter:none}
/* échelle : patchs > pin's = clips de casquette ; paddings réglés par image (inline)
   pour égaliser la taille affichée d'après le cadrage réel de chaque détourage */

.slider-nav{position:absolute;inset:auto 0 0 0;z-index:3;display:flex;align-items:center;justify-content:space-between;padding:10px 12px;pointer-events:none}
.slider-dots{display:flex;gap:6px;pointer-events:auto}
.slider-dots b{width:8px;height:8px;background:rgba(10,10,10,.25);cursor:pointer;transition:background .15s}
.slider-dots b.is-on{background:var(--red)}
.slider-arrows{display:flex;gap:4px;pointer-events:auto;opacity:0;transition:opacity .2s}
.card:hover .slider-arrows{opacity:1}
.slider-arrows button{width:28px;height:28px;border:none;background:var(--black);color:#fff;display:grid;place-items:center;transition:background .15s}
.slider-arrows button:hover{background:var(--red)}
.slider-arrows svg{width:12px;height:12px}
.card__count{position:absolute;top:0;right:0;z-index:3;font-family:var(--font-slab);font-size:.7rem;font-weight:700;letter-spacing:.06em;color:#fff;background:var(--black);padding:5px 10px}

.card__body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:11px;flex:1;transition:background .15s var(--snap),color .15s var(--snap)}
.card__head{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.card__body h4{font-family:var(--font-sans);font-weight:900;font-size:1.18rem;letter-spacing:-.01em;line-height:1}
.card__ref{font-family:var(--font-slab);font-weight:600;font-size:.72rem;letter-spacing:.08em;color:var(--gray);transition:color .15s}
.card__tags{display:flex;flex-wrap:wrap;gap:6px 10px;margin-top:auto}
.tag{font-family:var(--font-slab);font-size:.66rem;font-weight:600;letter-spacing:.14em;color:var(--gray);text-transform:uppercase;transition:color .15s}
.tag::before{content:"";display:inline-block;width:4px;height:4px;background:var(--red);margin-right:6px;vertical-align:middle}

/* hover : inversion nette */
.card:hover{z-index:2}
.card:hover .card__body{background:var(--black);color:#fff}
.card:hover .card__body h4{color:#fff}
.card:hover .card__ref{color:var(--red)}
.card:hover .tag{color:#C4C4C4}

/* textile : carte "bientôt" typographique (fond noir) */
.card--bientot{background:var(--black);color:#fff}
.card--bientot .card__media{background:var(--black);display:grid;place-items:center;border-bottom:1px solid var(--hair-dark)}
.card--bientot .bnock{width:54%;height:auto;color:#fff;opacity:.12}
.card--bientot .bnock .nk-accent{fill:var(--red);opacity:.9}
.card--bientot .soon{position:absolute;top:0;left:0;z-index:3;font-family:var(--font-slab);font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;background:var(--red);padding:5px 10px}
.card--bientot .card__body{background:var(--black);color:#fff}
.card--bientot .card__body h4{color:#fff}
.card--bientot .tag{color:#8A8A8A}
.card--bientot:hover .card__body{background:#fff;color:var(--black)}
.card--bientot:hover .card__body h4{color:var(--black)}
.card--bientot:hover .tag{color:var(--gray)}

.textile-more{margin-top:24px;font-family:var(--font-sans);font-size:.95rem;color:var(--gray);position:relative;z-index:2}
.textile-more b{color:var(--black);font-weight:900}

/* custom block */
.card--custom{grid-column:1/-1;background:var(--black);color:#fff;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap;padding:clamp(28px,4vw,52px);border-right:1px solid var(--hair-light)}
.card--custom .nk-symbol{width:44px;height:44px;color:#fff;flex:none}
.card--custom .cc-txt{flex:1;min-width:260px}
.card--custom h4{font-family:var(--font-display);font-weight:600;color:#fff;font-size:clamp(1.6rem,3vw,2.4rem);letter-spacing:-.01em;text-transform:uppercase;line-height:.95}
.card--custom p{color:#B0B0B0;font-size:.98rem;margin-top:12px;max-width:48ch}
.card--custom:hover .card__body{background:transparent}

/* =========================================================
   METHODE — numéros géants
   ========================================================= */
.method{background:var(--black);color:#fff;position:relative;overflow:hidden;padding-block:clamp(64px,8vw,120px) clamp(72px,9vw,140px)}
.method .sec-top{border-top-color:#fff}
.method .sec-top .sec-index{color:#fff}
.method__grid{display:grid;grid-template-columns:34% 66%;gap:clamp(30px,5vw,80px);align-items:start;margin-top:clamp(40px,5vw,72px);position:relative;z-index:2}
.method__head{position:sticky;top:108px}
.method__head h2{color:#fff;font-family:var(--font-display);font-weight:600;font-size:clamp(40px,5.4vw,76px);line-height:.92;letter-spacing:-.025em;margin-top:18px}
.method__head p{color:#A6A6A6;font-size:1.02rem;margin-top:22px;max-width:32ch;line-height:1.6}

.steps{position:relative;padding-left:clamp(58px,7vw,96px)}
.steps__line{position:absolute;left:clamp(20px,2.4vw,34px);top:14px;bottom:24px;width:2px;background:var(--hair-dark)}
.steps__line::after{content:"";position:absolute;inset:0;background:var(--red);transform:scaleY(0);transform-origin:top;transition:transform 1.2s var(--ease)}
.steps.is-traced .steps__line::after{transform:scaleY(1)}
.step{position:relative;padding-bottom:clamp(40px,4.6vw,70px);display:grid;grid-template-columns:1fr;gap:0}
.step:last-child{padding-bottom:0}
.step__dot{position:absolute;left:calc(clamp(20px,2.4vw,34px) - clamp(58px,7vw,96px) - 6px);top:18px;width:14px;height:14px;background:var(--black);border:2px solid var(--hair-dark);transition:border-color .4s var(--snap),background .4s var(--snap),box-shadow .4s var(--snap);z-index:2}
.step.reveal-in .step__dot{border-color:var(--red);background:var(--red);box-shadow:0 0 0 5px rgba(230,50,40,.18)}
.step__num{display:block;font-family:var(--font-display);font-weight:600;font-size:clamp(64px,9vw,128px);line-height:.8;color:transparent;-webkit-text-stroke:2px rgba(255,255,255,.18);text-stroke:2px rgba(255,255,255,.18);margin-bottom:14px;transform:translateX(-6px);opacity:.55;transition:-webkit-text-stroke-color .55s var(--snap),color .55s var(--snap),transform .55s var(--ease),opacity .55s var(--snap)}
.step.reveal-in .step__num{-webkit-text-stroke-color:var(--red);text-stroke-color:var(--red);transform:none;opacity:1}
.step h3{font-family:var(--font-sans);font-weight:900;font-size:clamp(1.3rem,2.2vw,1.7rem);color:#fff;letter-spacing:-.01em}
.step p{color:#A6A6A6;font-size:1.02rem;margin-top:10px;max-width:48ch;line-height:1.55}

/* =========================================================
   DEVIS — bordereau (fond blanc)
   ========================================================= */
.devis{background:var(--white);color:var(--black);padding-block:clamp(64px,8vw,120px) clamp(72px,9vw,140px)}
.devis .sec-top{border-top-color:var(--black)}
.devis .sec-top .sec-index{color:var(--black)}
.devis__wrap{display:grid;grid-template-columns:36% 64%;gap:0;border:2px solid var(--black);margin-top:clamp(40px,5vw,68px);position:relative;z-index:2}
.devis__aside{background:var(--black);color:#fff;padding:clamp(30px,3.4vw,52px);display:flex;flex-direction:column;gap:26px}
.devis__aside h2{color:#fff;font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,3.4vw,3.2rem);letter-spacing:-.02em;line-height:.95;text-transform:uppercase;margin-bottom:20px}
.devis__aside .kicker{color:#fff}
.devis__points{display:flex;flex-direction:column;gap:9px;margin-top:4px}
.devis__point{display:flex;gap:11px;align-items:center;color:#fff;font-family:var(--font-sans);font-weight:900;font-size:1rem}
.devis__point .nk-symbol{width:15px;height:15px;color:var(--red)}
.devis__contact{margin-top:auto;font-size:.92rem;color:#A6A6A6;line-height:1.6}
.devis__contact a{color:#fff;font-weight:900;border-bottom:2px solid var(--red);padding-bottom:1px}

.form{padding:clamp(28px,3.2vw,50px);display:flex;flex-direction:column;gap:18px;background:var(--white)}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:var(--font-slab);font-weight:600;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--black)}
.field label .opt{color:var(--gray);font-weight:400;letter-spacing:.1em}
.field input,.field textarea{font-family:inherit;font-size:1rem;font-weight:500;color:var(--black);background:#fff;border:1px solid var(--black);border-radius:0;padding:13px 14px;transition:border-color .15s,box-shadow .15s}
.field input::placeholder,.field textarea::placeholder{color:#9A9A9A}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--red);box-shadow:inset 0 0 0 1px var(--red)}
.field textarea{resize:vertical;min-height:92px}
.field.is-error input,.field.is-error textarea{border-color:var(--red);box-shadow:inset 0 0 0 1px var(--red)}
.field__err{color:var(--red-deep);font-size:.76rem;font-weight:900;letter-spacing:.04em;text-transform:uppercase;display:none}
.field.is-error .field__err{display:block}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:540px){.grid2{grid-template-columns:1fr}}

.checks{display:flex;flex-wrap:wrap;gap:9px}
.check{position:relative}
.check input{position:absolute;opacity:0;width:0;height:0}
.check span{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-slab);font-weight:600;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--gray);border:1px solid var(--hair-light);padding:10px 14px;transition:all .14s var(--snap);user-select:none;cursor:pointer}
.check span::before{content:"";width:7px;height:7px;background:#CFCFCF;transition:background .14s;flex:none}
.check span:hover{border-color:var(--black);color:var(--black)}
.check input:checked+span{color:#fff;background:var(--red);border-color:var(--red)}
.check input:checked+span:hover{color:#fff}
.check input:checked+span::before{background:#fff}
.check input:focus-visible+span{outline:2px solid var(--red);outline-offset:2px}

.file{position:relative}
.file input{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}
.file__box{display:flex;align-items:center;gap:14px;border:1px dashed var(--black);padding:15px 16px;background:#fff;transition:border-color .15s,background .15s}
.file:hover .file__box{border-style:solid;border-color:var(--red)}
.file__ic{width:38px;height:38px;background:var(--black);color:#fff;display:grid;place-items:center;flex:none}
.file__ic svg{width:18px;height:18px}
.file__txt{display:flex;flex-direction:column;gap:1px}
.file__txt b{font-weight:900;font-size:.9rem}
.file__txt span{font-size:.8rem;color:var(--gray)}
.file.has-file .file__box{border-style:solid;border-color:var(--red)}
.file.has-file .file__ic{background:var(--red)}

.newsletter{display:flex;align-items:center;gap:13px;cursor:pointer;font-size:.86rem;color:var(--gray);line-height:1.45}
.newsletter input{position:absolute;opacity:0;width:0;height:0}
.newsletter .box{width:22px;height:22px;border:1px solid var(--black);display:grid;place-items:center;flex:none;transition:all .15s}
.newsletter .news-txt{display:block}
.newsletter .box svg{width:13px;height:13px;color:#fff;opacity:0;transition:opacity .12s}
.newsletter input:checked+.box{background:var(--red);border-color:var(--red)}
.newsletter input:checked+.box svg{opacity:1}
.newsletter input:focus-visible+.box{outline:2px solid var(--red);outline-offset:2px}

.form__foot{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:4px}
.form__note{font-size:.8rem;color:var(--gray);max-width:32ch}
.form__success{display:none;flex-direction:column;align-items:flex-start;gap:16px;padding:clamp(40px,5vw,72px) clamp(28px,3.2vw,50px);background:var(--white)}
.form__success.is-on{display:flex}
.form__success .ok{width:56px;height:56px;background:var(--red);color:#fff;display:grid;place-items:center}
.form__success h3{font-family:var(--font-display);font-weight:600;font-size:2.1rem;text-transform:uppercase;letter-spacing:-.01em}
.form__success p{color:var(--gray);max-width:42ch}
.form.is-sent{display:none}

/* =========================================================
   FOOTER — ours
   ========================================================= */
.footer{background:var(--black);color:#fff;padding-block:0 38px;border-top:2px solid #fff}
.footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding-top:clamp(48px,6vw,84px);position:relative;z-index:2}
.footer__brand .nk-word{width:150px;height:38px;color:#fff;margin-bottom:18px}
.footer__brand p{color:#A6A6A6;max-width:34ch;line-height:1.55;font-size:.95rem}
.footer__brand .steady{display:inline-block;margin-top:18px;font-family:var(--font-slab);font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;font-size:.84rem}
.footer__col h4{font-family:var(--font-slab);font-weight:600;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray)}
.footer__col ul{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}
.footer__col a{font-family:var(--font-sans);font-size:.92rem;color:#fff;opacity:.85;transition:opacity .2s,color .2s}
.footer__col a:hover{opacity:1;color:var(--red)}
.footer__bottom{margin-top:clamp(40px,5vw,64px);padding-top:22px;border-top:1px solid var(--hair-dark);display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center;font-family:var(--font-slab);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gray)}
.footer__bottom .nk-symbol{width:18px;height:18px;color:#fff}

/* =========================================================
   CURSOR (crosshair)
   ========================================================= */
.cursor-cross{position:fixed;top:0;left:0;z-index:200;pointer-events:none;width:26px;height:26px;margin:-13px 0 0 -13px;opacity:0;transition:opacity .25s}
.cursor-cross::before,.cursor-cross::after{content:"";position:absolute;background:var(--red)}
.cursor-cross::before{left:50%;top:0;width:1.5px;height:100%;transform:translateX(-50%)}
.cursor-cross::after{top:50%;left:0;height:1.5px;width:100%;transform:translateY(-50%)}
body.cursor-on{cursor:none}
body.cursor-on a,body.cursor-on button,body.cursor-on input,body.cursor-on textarea,body.cursor-on label{cursor:none}
.cursor-on .cursor-cross{opacity:1}
.cursor-cross.is-hot{transform:rotate(45deg) scale(1.25)}

/* =========================================================
   REVEAL — snap (sec, mécanique)
   ========================================================= */
.reveal{transition:opacity .5s var(--snap),transform .5s var(--snap)}
.js .reveal{opacity:0;transform:translateY(20px)}
.js .reveal.reveal-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.06s}
.reveal[data-d="2"]{transition-delay:.12s}
.reveal[data-d="3"]{transition-delay:.18s}
.reveal[data-d="4"]{transition-delay:.24s}
.reveal[data-d="5"]{transition-delay:.30s}
.reveal[data-d="6"]{transition-delay:.36s}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}}
.js.no-anim .reveal,.js.no-anim .step{opacity:1 !important;transform:none !important;transition:none !important}
.js.no-anim .hero__title .ln i{transform:none !important;transition:none !important}
.js.no-anim .step__num{opacity:1 !important;transform:none !important;-webkit-text-stroke-color:var(--red) !important;text-stroke-color:var(--red) !important}
.js.no-anim .step__dot{border-color:var(--red) !important;background:var(--red) !important}
.js.no-anim .steps__line::after{transform:scaleY(1) !important;transition:none !important}

/* =========================================================
   V7 — empennage / brand presence
   ========================================================= */
.hero>.container{position:relative;z-index:2}
.hero__emp{position:absolute;z-index:0;width:min(82vw,900px);height:auto;right:-13%;top:50%;transform:translateY(-50%);opacity:.1;pointer-events:none}
.hero__emp path{fill:none;stroke:#fff;stroke-width:1.2px;vector-effect:non-scaling-stroke}

/* bandeau « un support en tête » : gros empennage + CTA renforcé */
.card--custom{align-items:center}
.card--custom .nk-symbol{width:clamp(96px,12vw,134px);height:clamp(96px,12vw,134px)}
.card--custom h4 br{display:block}
.card--custom .btn{margin-top:22px}

/* brand band (moment empennage) */
.brandband{background:var(--black);border-top:2px solid #fff;padding-block:clamp(40px,6vw,82px);overflow:hidden}
.brandband__in{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;position:relative;z-index:1}
.brandband__emp{width:clamp(74px,9vw,124px);height:auto}
.brandband__emp path{fill:#fff}
.brandband__emp .nk-accent{fill:var(--red)}
.brandband .nk-word{width:148px;height:34px;color:#fff}
.brandband__tag{font-family:var(--font-slab);font-weight:600;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gray)}

.devis__aside{position:relative;overflow:hidden;gap:0}
.devis__aside>*{position:relative;z-index:1}
.devis__lockup{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.devis__lockup .nk-symbol{width:46px;height:46px;color:#fff}
.devis__lockup .nk-word{width:188px;height:44px;color:#fff}
/* badge : deux mentions empilées, filet rouge devant chacune, bloc compact */
.devis__badge{display:flex;flex-direction:column;align-items:flex-start;gap:7px;align-self:flex-start;margin:0 0 clamp(42px,6vw,68px);
  font-family:var(--font-slab);font-weight:600;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:#fff}
.devis__badge .bi{display:inline-flex;align-items:center;gap:11px}
.devis__badge .bi::before{content:"";width:20px;height:2px;background:var(--red);flex:none}
.devis__aside h2{margin-bottom:18px}
/* bloc contact, poussé en bas */
.devis__foot{margin-top:clamp(42px,6vw,68px)}
.devis__contact{position:relative;z-index:1;font-size:.92rem;color:#A6A6A6;line-height:1.6}

/* footer logo lockup (avec empennage) */
.footer__logo{display:flex;align-items:center;gap:11px;margin-bottom:18px}
.footer__logo .nk-symbol{width:28px;height:28px;color:#fff}
.footer__logo .nk-word{width:138px;height:34px;color:#fff;margin:0}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1040px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr 1fr}
  .method__grid{grid-template-columns:1fr;gap:40px}
  .method__head{position:static}
}
@media(max-width:880px){
  .header__nav{display:none}
  .header__burger{display:grid;place-items:center;margin-left:auto;width:46px;height:46px;border:1px solid var(--hair-dark);background:transparent;color:#fff}
  .devis__wrap{grid-template-columns:1fr}
  .devis__aside{order:-1}
  body.cursor-on{cursor:auto}
  .cursor-on .cursor-cross{opacity:0}
}
@media(max-width:620px){
  .cards{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr;gap:34px}
  .hero__foot-text{flex-direction:column;align-items:flex-start;gap:22px}
  .hero{padding-top:96px;min-height:100svh;padding-bottom:34px}
  .hero__inner{justify-content:center;flex:1;padding-top:0;padding-bottom:0}
  .hero .kicker{margin-bottom:clamp(28px,7vw,46px);font-size:.7rem;letter-spacing:.18em}
  .hero .kicker::before{width:28px}
  .hero__title{font-size:clamp(56px,17vw,90px)}
  .hero__lead{font-size:1.08rem}
  .hero__foot-text{margin-top:clamp(34px,8vw,52px);gap:26px}
}
@media (hover:none){
  body.cursor-on{cursor:auto}
  .cursor-cross{display:none}
}
