/* =====================================================
   CB Systems · Design system brique & mortier
   ===================================================== */
:root{
  --bg:#ece4d8;
  --bg-2:#dccdb6;
  --ink:#2a1816;
  --brick:#7a2e23;
  --brick-deep:#4a1812;
  --brick-light:#cc6f5c;
  --rust:#d97a3f;
  --moss:#5a6a3c;
  --rule:#3a2520;
  --soft:rgba(42,24,22,.8);
  --ink-soft:#574039;
  --ink-mute:#6e5b4c;
  --grot:'Bricolage Grotesque','Inter',system-ui,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--ink);font-family:var(--grot);font-weight:400}
body{font-size:16px;line-height:1.45;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:none;color:inherit;cursor:pointer}
::selection{background:var(--brick);color:var(--bg)}

body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;mix-blend-mode:multiply;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(74,24,18,.08) 0, transparent 1px),
    radial-gradient(circle at 80% 70%, rgba(74,24,18,.06) 0, transparent 1px),
    radial-gradient(circle at 50% 50%, rgba(74,24,18,.04) 0, transparent 1px);
  background-size:3px 3px,5px 5px,2px 2px;
}

.container{max-width:1240px;margin:0 auto;padding:0 20px;position:relative;z-index:2}
.container-sm{max-width:920px;margin:0 auto;padding:0 20px;position:relative;z-index:2}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .8s cubic-bezier(.2,.8,.2,1),transform .8s cubic-bezier(.2,.8,.2,1)}
.reveal.is-shown{opacity:1;transform:none}

/* ===== Nav (sticky bar with marquee) ===== */
.nav{
  position:fixed;left:0;right:0;top:0;z-index:50;
  display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;
  padding:12px 20px;
  background:var(--ink);color:var(--bg);
  font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  border-bottom:2px solid var(--brick);
}
.nav-logo{display:inline-flex;align-items:center;gap:10px;font-family:var(--grot);font-weight:700;font-size:18px;letter-spacing:-.02em;text-transform:none}
.nav-logo .stamp{display:inline-block;width:30px;height:30px;background:var(--brick-light);-webkit-mask:url(../assets/logo-cb.png) center/contain no-repeat;mask:url(../assets/logo-cb.png) center/contain no-repeat}
.nav-links{display:flex;gap:18px;justify-self:center;color:var(--bg-2)}
.nav-links a{transition:.2s;border-bottom:1px solid transparent;padding:4px 0;white-space:nowrap}
.nav-links a:hover{color:var(--bg);border-color:var(--brick-light)}
.nav-links a.is-current{color:var(--bg);border-color:var(--brick-light)}
.nav-cta{
  background:var(--brick);color:var(--bg);padding:10px 16px;letter-spacing:.16em;
  border:1px solid var(--brick);transition:.2s;white-space:nowrap;
  display:inline-flex;align-items:center;gap:10px;
}
.nav-cta:hover{background:var(--bg);color:var(--ink);border-color:var(--bg)}
.nav-cta .arr{transition:.25s}.nav-cta:hover .arr{transform:translateX(3px)}
.body-pad{padding-top:54px}
/* anchor jumps land below the fixed nav (services packs + sur-mesure, FAQ ids, etc.) */
:target{scroll-margin-top:74px}
#pack-presence,#pack-fidelisation,#sur-mesure{scroll-margin-top:74px}
html{scroll-behavior:smooth}

/* ===== Page banner ===== */
.page-banner{
  padding:120px 20px 60px;background:var(--bg);position:relative;border-bottom:2px solid var(--ink);
  overflow:hidden;
}
.page-banner::before{
  content:"";position:absolute;left:0;right:0;bottom:0;height:14px;
  background:repeating-linear-gradient(90deg,var(--ink) 0 12px,transparent 12px 24px);
  opacity:.25;
}
.page-banner .container{display:flex;flex-direction:column;gap:0}
.kicker{
  font-family:var(--grot);font-size:13px;font-weight:500;letter-spacing:-.01em;text-transform:none;color:var(--brick);
  display:inline-flex;align-items:center;gap:8px;margin-bottom:20px;
}
.kicker::before{content:"";width:6px;height:6px;background:var(--brick-light);border-radius:50%;flex-shrink:0}
.kicker-light{color:var(--brick-light)}
.kicker-light::before{color:var(--bg-2)}
.h1{font-family:var(--grot);font-weight:300;font-size:clamp(56px,8vw,140px);line-height:.9;letter-spacing:-.045em}
.h1 em{font-style:normal;font-weight:800;color:var(--brick)}
.h2{font-family:var(--grot);font-weight:300;font-size:clamp(40px,6vw,96px);line-height:.95;letter-spacing:-.04em}
.h2 em{font-style:normal;font-weight:800;color:var(--brick)}
.h2-light em{color:var(--brick-light)}
.h3{font-family:var(--grot);font-weight:500;font-size:clamp(24px,2.6vw,32px);line-height:1.1;letter-spacing:-.02em}
.h3 em{font-style:normal;font-weight:800;color:var(--brick)}
.lede{font-family:var(--grot);font-size:clamp(17px,1.6vw,21px);line-height:1.45;color:var(--ink);max-width:560px}
.lede em{font-style:normal;color:var(--brick);font-weight:500}
.page-banner-title{margin-bottom:8px}
.page-banner-lede{margin-top:24px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 22px;font-family:var(--grot);font-weight:500;font-size:15px;letter-spacing:-.005em;
  border:2px solid var(--ink);transition:.25s;cursor:pointer;text-decoration:none;
}
.btn .arr{transition:.3s;font-size:18px}
.arr-hover:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--brick);color:var(--bg);border-color:var(--brick)}
.btn-primary:hover{background:var(--brick-deep);border-color:var(--brick-deep)}
.btn-ink{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-ink:hover{background:var(--brick);border-color:var(--brick)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bg)}
.btn-link{padding:10px 0;border:none;color:var(--brick);font-weight:500}
.btn-link:hover{color:var(--brick-deep)}
.btn-sm{padding:10px 16px;font-size:13px}
.cup-ico{display:inline-flex;align-items:center}

/* ===== Sections ===== */
.section{padding:100px 20px;border-bottom:2px solid var(--ink)}
.section-warm{background:var(--bg-2)}
.section-dark{background:var(--ink);color:var(--bg-2)}
.section-dark .h2{color:var(--bg)}
.section-dark .h2 em{color:var(--brick-light)}
.section-dark .lede{color:var(--bg-2)}
/* Cadre atelier des intros sombres */
.svc-sep-box{max-width:780px;padding:46px 30px;border:1px solid rgba(196,100,81,.32);border-radius:5px}
.svc-sep-box::before,.svc-sep-box::after{content:'\2726';position:absolute;font-size:11px;line-height:1;color:var(--rust);background:var(--ink);padding:5px 8px}
.svc-sep-box::before{top:-10px;left:22px}
.svc-sep-box::after{bottom:-10px;right:22px}
.section-head{margin-bottom:48px;display:grid;grid-template-columns:1fr;gap:6px;max-width:1100px}

/* ===== Hero (home) ===== */
.hero{
  padding:48px 20px 32px;height:100vh;min-height:620px;
  display:flex;align-items:center;border-bottom:2px solid var(--ink);
  overflow:hidden;
}
.hero-inner{display:grid;grid-template-columns:7fr 5fr;gap:32px;width:100%;align-items:center}
.hero-text{padding-top:0}
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--brick);display:inline-flex;align-items:center;gap:10px;margin-bottom:18px}
.eyebrow-dot{width:8px;height:8px;background:var(--brick-light);display:inline-block;animation:blink 1.4s infinite}
@keyframes blink{50%{opacity:.2}}
.hero-h1{font-size:clamp(40px,5.2vw,84px);line-height:.95;font-weight:300;letter-spacing:-.04em}
.hero-h1 em{font-style:normal;font-weight:800;color:var(--brick)}
.hero-lede{margin-top:16px;font-size:clamp(15px,1.1vw,17px);max-width:560px;color:var(--ink);line-height:1.4;min-height:calc(1.4em * 3)}
.hero-tw{display:inline}
.tw-caret{display:inline-block;animation:blink 1s infinite;color:var(--brick);font-weight:300;margin-left:1px}
.hero-ctas{margin-top:18px;display:flex;flex-wrap:wrap;gap:12px}
.hero-meta{margin-top:14px;display:flex;flex-wrap:wrap;gap:14px;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft)}
.hero-meta b{color:var(--ink);font-weight:500}
.dot-sep{width:4px;height:4px;background:var(--brick);border-radius:50%;align-self:center}

/* ===== Ledger demo (copier-coller killer) ===== */
.ledger{
  background:var(--ink);color:var(--bg);padding:0;
  font-family:var(--mono);font-size:12px;line-height:1.6;letter-spacing:.04em;
  border:2px solid var(--ink);position:relative;overflow:hidden;
}
.ledger-head{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--brick-light);border-bottom:1px solid rgba(236,228,216,.15);gap:14px}
.ledger-dot{width:8px;height:8px;background:var(--brick-light);border-radius:50%;animation:blink 1.4s infinite;flex-shrink:0}
.ledger-title{display:inline-flex;gap:.4em}
.ledger-title-wf{display:inline-block;animation:wf-swap .5s var(--ease-out)}
@keyframes wf-swap{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}
.ledger-status{margin-left:auto;color:rgba(236,228,216,.72)}
.ledger{transition:opacity .55s ease}
.ledger.ledger-fading{opacity:0}
.ledger-stage{position:relative;min-height:260px}
.ledger-rows{list-style:none;padding:0;margin:0;transition:opacity .45s ease .55s}
.ledger-rows.is-hidden{opacity:0;pointer-events:none;transition:opacity .35s ease}
.ledger-summary{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;
  padding:28px 24px;opacity:0;transform:translateY(6px);pointer-events:none;
  transition:opacity .55s ease .12s, transform .55s ease .12s;
}
.ledger-summary.is-on{opacity:1;transform:translateY(0)}
.lsum-k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(236,228,216,.72)}
.lsum-big{display:flex;align-items:baseline;gap:2px;margin:8px 0 6px;color:var(--brick-light);font-family:var(--grot);font-weight:300;letter-spacing:-.04em;line-height:.9;font-variant-numeric:tabular-nums}
.lsum-h{font-size:96px}
.lsum-u{font-size:42px;margin:0 4px 0 2px;opacity:.7}
.lsum-m{font-size:60px;opacity:.85}
.lsum-v{font-family:var(--grot);font-weight:300;font-size:18px;color:rgba(236,228,216,.85);max-width:34ch;line-height:1.25}
.lsum-meta{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;font-family:var(--mono);font-size:10px;letter-spacing:.06em;color:rgba(236,228,216,.72)}
.lsum-meta b{font-family:var(--grot);font-weight:500;color:var(--cream);font-size:12px;letter-spacing:-.01em}
.lsum-dot{opacity:.4}
.lrow{
  display:grid;grid-template-columns:74px 1fr auto;gap:12px;align-items:center;
  padding:12px 20px;border-bottom:1px solid rgba(236,228,216,.08);
  transition:opacity .5s var(--ease-soft), color .5s var(--ease-soft);
  position:relative;min-width:0;
}
.lrow > .lrow-label{min-width:0;overflow:hidden}
.lrow:last-child{border-bottom:none}
.lrow-time{font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:rgba(236,228,216,.72)}
.lrow-label{font-family:var(--grot);font-weight:400;font-size:13.5px;line-height:1.35;letter-spacing:-.005em;color:var(--bg);text-transform:none;display:block;position:relative}
.lrow-label-inner{
  display:inline;
  text-decoration:line-through 1.5px transparent;
  text-decoration-skip-ink:none;
  transition:text-decoration-color .6s cubic-bezier(.2,.8,.2,1);
}
.lrow-cost{font-size:10px;letter-spacing:.1em;color:rgba(236,228,216,.72);font-variant-numeric:tabular-nums}
.lrow-stamp{
  position:absolute;right:20px;top:50%;transform:translateY(-50%) rotate(-6deg);
  font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--brick-light);border:1.5px solid var(--brick-light);padding:3px 8px;
  background:transparent;opacity:0;animation:stamp-in .35s var(--ease-out) forwards;
  pointer-events:none;
}
@keyframes stamp-in{from{opacity:0;transform:translateY(-50%) rotate(-12deg) scale(1.4)}to{opacity:1;transform:translateY(-50%) rotate(-6deg) scale(1)}}
.lrow.killed .lrow-label{color:rgba(236,228,216,.72)}
.lrow.killed .lrow-label-inner{text-decoration-color:var(--brick-light)}
.lrow.killed .lrow-cost{visibility:hidden}
.lrow.killed .lrow-time{color:rgba(236,228,216,.72)}
.lrow.active{background:rgba(196,100,81,.08)}
.lrow.active .lrow-time{color:var(--brick-light)}
.lrow.active::before{content:"";position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--brick-light);animation:blink 0.7s infinite}
.ledger-foot{
  padding:14px 20px;border-top:1px solid rgba(236,228,216,.15);
  display:flex;justify-content:space-between;align-items:baseline;gap:14px;
}
.ledger-foot-k{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(236,228,216,.72)}
.ledger-foot-v{font-family:var(--grot);font-weight:300;font-size:24px;letter-spacing:-.02em;color:var(--brick-light);font-variant-numeric:tabular-nums}
.ledger-foot-total{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:rgba(236,228,216,.72)}

/* ===== Stats strip ===== */
.stats-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.stat{padding:24px 14px;border-top:2px solid var(--ink);display:flex;flex-direction:column;gap:8px}
.stat-num{font-family:var(--grot);font-weight:700;font-size:clamp(40px,5vw,64px);line-height:.9;letter-spacing:-.04em;color:var(--ink);
  filter:blur(12px);opacity:0;transform:scale(1.15);
  transition:filter .7s cubic-bezier(.22,1,.36,1),opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.stat-num.stat-num-in{filter:blur(0);opacity:1;transform:scale(1)}
.stat-tail{font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;font-weight:400;color:var(--brick);margin-left:6px}
.stat-lbl{font-family:var(--mono);font-size:11px;letter-spacing:.06em;line-height:1.5;color:var(--soft);text-transform:uppercase}

/* ===== Pains (data table) ===== */
.pains{display:grid;grid-template-columns:1fr;border-top:2px solid var(--ink)}
.pain{
  display:grid;grid-template-columns:60px 1fr auto;gap:0 24px;
  padding:24px 0;border-bottom:1px solid var(--ink);align-items:center;
  transition:background .4s,padding-left .4s;cursor:pointer;
}
.pain.is-flipped{padding-left:9px;background:rgba(46,122,72,.04)}
.pain:not(.is-flipped):hover{background:rgba(122,46,35,.04)}
.pain.is-flipped:hover{background:rgba(46,122,72,.08)}
.pain-num{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);font-weight:500;align-self:start;padding-top:4px}
.pain.is-flipped .pain-num{color:var(--ink)}

/* Pain content · layered, SEQUENTIAL slide (no overlap) */
.pain-content{display:grid;overflow:hidden}
.pain-front,.pain-back{grid-area:1/1}
/* default (problem shown): front in place; back waits faded out, slightly right.
   Un-flip: back fades+slides out first (no delay), front fades+slides in after (delay). */
.pain-front{opacity:1;transform:translateX(0);transition:opacity .5s var(--ease-soft) .08s,transform .5s var(--ease-soft) .08s}
.pain-back{opacity:0;transform:translateX(8px);pointer-events:none;transition:opacity .42s var(--ease-soft),transform .42s var(--ease-soft)}
/* flipped (solution shown): front fades+slides out first (no delay), back fades+slides in after (delay). */
.pain.is-flipped .pain-front{opacity:0;transform:translateX(-8px);pointer-events:none;transition:opacity .42s var(--ease-soft),transform .42s var(--ease-soft)}
.pain.is-flipped .pain-back{opacity:1;transform:translateX(0);pointer-events:auto;transition:opacity .5s var(--ease-soft) .08s,transform .5s var(--ease-soft) .08s}

/* Labels */
.pain-label{font-family:var(--mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;display:inline-block;padding:2px 8px;border-radius:2px;margin-bottom:8px}
.pain-label-problem{color:var(--brick);background:rgba(122,46,35,.08)}
.pain-label-solution{color:rgb(36,100,60);background:rgba(36,100,60,.08)}

.pain-title{font-family:var(--grot);font-weight:500;font-size:clamp(20px,2.2vw,28px);line-height:1.15;letter-spacing:-.02em;margin:0}
.pain-title-sol{color:var(--ink)}
.pain-sub{font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--soft);line-height:1.5;margin-top:4px}
.pain-sub-sol{color:rgb(36,100,60)}

/* Hover hint arrow */
.pain-hint{font-family:var(--mono);font-size:14px;color:var(--soft);transition:color .3s,transform .3s;align-self:center}
.pain-hint-txt{display:block;transition:transform .3s}
.pain:hover .pain-hint{color:var(--brick)}
.pain.is-flipped .pain-hint{color:rgb(36,100,60)}

/* ===== Marquee scrollant ===== */
.mq{
  border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);
  background:var(--ink);color:var(--bg);overflow:hidden;
  padding:18px 0;
}
.mq-track{display:flex;width:max-content;animation:mq-scroll 38s linear infinite;will-change:transform}
.mq-track:hover{animation-play-state:paused}
.mq-row{display:flex;align-items:center;gap:28px;padding-right:28px;flex-shrink:0}
.mq-item{font-family:var(--grot);font-weight:500;font-size:clamp(20px,2.6vw,32px);letter-spacing:-.015em;white-space:nowrap}
.mq-sep{color:var(--brick);font-size:18px}
@keyframes mq-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===== Cards (services) ===== */
.cards{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.card{
  padding:32px;background:var(--bg);color:var(--ink);
  border:2px solid var(--ink);
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;gap:16px;justify-content:space-between;
  transition:.3s;min-height:420px;
  grid-column:span 5;
}
.card:nth-child(2){grid-column:span 4;background:var(--brick);color:var(--bg)}
.card:nth-child(3){grid-column:span 3;background:var(--bg-2);color:var(--ink)}
.card::after{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--brick);transition:width .55s cubic-bezier(.2,.8,.2,1)}
.card:nth-child(2)::after{background:var(--bg)}
.card:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 0 var(--ink)}
.card:hover::after{width:100%}
.card-tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}
.card-title{font-family:var(--grot);font-weight:500;font-size:clamp(24px,2.6vw,32px);line-height:1.05;letter-spacing:-.02em}
.card-price{display:flex;align-items:baseline;gap:8px;border-top:1px solid currentColor;border-bottom:1px solid currentColor;padding:14px 0}
.card-price .price{font-family:var(--grot);font-weight:300;font-size:48px;line-height:.9;letter-spacing:-.04em}
.card-price .price-unit{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.card-offer{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick)}
.card:nth-child(2) .card-offer{color:var(--bg-2)}
.card-list{list-style:none;font-family:var(--mono);font-size:12px;line-height:1.8;letter-spacing:.04em}
.card-list li{padding-left:18px;position:relative}
.card-list li::before{content:"+";position:absolute;left:0;top:0;font-weight:700;color:currentColor}
.card-cta{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;border-top:1px solid currentColor;padding-top:14px;display:flex;justify-content:space-between;align-items:center}
.card-soon{opacity:.95}
.card-soon-text{font-family:var(--grot);font-size:14px;line-height:1.5;color:var(--soft)}
.card-muted{opacity:.5}

/* ===== Packs grid (services on home) ===== */
.packs{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:60px}
.packs-2{grid-template-columns:repeat(2,1fr);gap:20px;max-width:980px;margin-left:auto;margin-right:auto}
.packs > .reveal{display:flex;flex-direction:column}
.packs > .reveal > .pack{flex:1}
.pack{
  padding:28px;border:2px solid var(--ink);
  display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;
  transition:transform var(--t-base) var(--ease-soft),box-shadow var(--t-base) var(--ease-soft);
}
.pack::after{content:"";position:absolute;left:0;top:0;height:4px;width:0;background:var(--brick);transition:width .55s cubic-bezier(.2,.8,.2,1)}
.pack:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 0 var(--ink)}
.pack:hover::after{width:100%}
.pack-light{background:var(--bg);color:var(--ink)}
.pack-brick{background:var(--brick);color:var(--bg)}
.pack-brick::after{background:var(--bg)}
.pack-ink{background:var(--ink);color:var(--bg)}
.pack-ink::after{background:var(--brick-light)}
.pack-warm{background:var(--bg-2);color:var(--ink)}
.pack-head{display:flex;justify-content:space-between;align-items:baseline}
.pack-tag{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}
.pack-num{font-family:var(--mono);font-size:10px;letter-spacing:.18em;opacity:.5}
.pack-title{font-family:var(--grot);font-weight:500;font-size:clamp(20px,1.7vw,24px);line-height:1.1;letter-spacing:-.02em}
.pack-price{display:flex;align-items:baseline;gap:6px;border-top:1px solid currentColor;border-bottom:1px solid currentColor;padding:12px 0}
.pack-price .price{font-family:var(--grot);font-weight:300;font-size:38px;line-height:.9;letter-spacing:-.04em}
.pack-price .price-unit{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase}
.pack-offer{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick-light)}
.pack-brick .pack-offer{color:var(--bg-2)}
.pack-ink .pack-offer{color:var(--brick-light)}
.pack-badges{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 6px}
.pack-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border:1px solid currentColor;background:transparent}
.pack-badge-dot{width:6px;height:6px;background:currentColor;border-radius:50%;opacity:.8}
.pack-badge-dot-alt{background:var(--brick);opacity:1}
.pack-brick .pack-badge-dot-alt{background:var(--bg)}
.pack-list{list-style:none;font-family:var(--mono);font-size:11px;line-height:1.7;letter-spacing:.03em;flex:1;padding:0;margin:0}
.pack-list li{padding-left:14px;position:relative;margin-bottom:4px}
.pack-list li::before{content:"+";position:absolute;left:0;top:0;font-weight:700}
.pack-cta{
  margin-top:8px;font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:11px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;
  text-decoration:none;border:1.5px solid var(--brick);
  background:transparent;color:var(--brick);
  transition:background .2s,color .2s,border-color .2s;
}
.pack-cta:hover{background:var(--brick);color:var(--bg);border-color:var(--brick)}
.pack-cta .arr{transition:transform .25s}
.pack-cta:hover .arr{transform:translateX(4px)}
/* per-theme so the outline reads on every card background */
.pack-brick .pack-cta{border-color:var(--bg);color:var(--bg)}
.pack-brick .pack-cta:hover{background:var(--bg);color:var(--brick);border-color:var(--bg)}
.pack-ink .pack-cta{border-color:var(--brick-light);color:var(--brick-light)}
.pack-ink .pack-cta:hover{background:var(--brick-light);color:var(--ink);border-color:var(--brick-light)}
/* whole-card clickable: stretch the CTA's hit area over the entire card
   (single real link = keeps accessibility/SEO; text stays the visible affordance) */
.pack{cursor:pointer}
.pack-cta::after{content:"";position:absolute;inset:0;z-index:2}

/* ===== Packs → Sur-mesure divider ===== */
.svc-divider{display:flex;flex-direction:column;align-items:center;text-align:center;padding:90px 0 0;position:relative}
.svc-divider::before{content:"";width:100%;max-width:1100px;height:2px;background:var(--ink);opacity:.12;margin-bottom:44px}
.svc-divider-tag{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--brick);display:inline-flex;align-items:center;gap:14px;margin-bottom:24px}
.svc-divider-tag::before,.svc-divider-tag::after{content:"";width:30px;height:1px;background:var(--brick);opacity:.55}
.svc-divider-phrase{font-family:var(--grot);font-weight:300;font-size:clamp(30px,4.4vw,58px);line-height:1.02;letter-spacing:-.035em;color:var(--ink);max-width:20ch;text-wrap:balance}
.svc-divider-phrase em{font-style:normal;font-weight:800;color:var(--brick)}
.svc-divider-connector{width:2px;height:60px;margin-top:32px;background:linear-gradient(var(--brick-light),var(--ink))}

/* ===== Bespoke band (sur-mesure) ===== */
.bespoke{
  background:var(--ink);color:var(--bg);
  border:2px solid var(--ink);
  padding:48px 44px;position:relative;overflow:hidden;
}
.bespoke::before{
  content:"";position:absolute;right:-80px;top:-80px;
  width:280px;height:280px;border:2px solid var(--brick-light);
  border-radius:50%;opacity:.15;
}
.bespoke-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:start;position:relative}
.bespoke-tag{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--brick-light);margin-bottom:18px}
.bespoke-title{font-family:var(--grot);font-weight:300;font-size:clamp(28px,3vw,40px);line-height:1.05;letter-spacing:-.02em;margin-bottom:20px}
.bespoke-title em{color:var(--brick-light);font-style:italic;font-weight:400}
.bespoke-text{font-family:var(--grot);font-weight:400;font-size:16px;line-height:1.55;color:var(--bg-2);margin-bottom:24px;max-width:48ch}
.bespoke-cta{
  display:inline-flex;align-self:flex-start;justify-content:space-between;align-items:center;gap:18px;
  font-family:var(--mono);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  color:var(--brick-light);text-decoration:none;
  padding:12px 18px;border:1.5px solid var(--brick-light);
  transition:background .2s,color .2s,border-color .2s;
}
.bespoke-cta:hover{background:var(--brick-light);color:var(--ink);border-color:var(--brick-light)}
.bespoke-cta .arr{transition:transform .25s}
.bespoke-cta:hover .arr{transform:translateX(4px)}

/* closing redirect at end of section */
.bespoke-end{margin-top:32px;padding-top:28px;border-top:1px solid rgba(236,228,216,.2);display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.bespoke-end-text{font-family:var(--grot);font-size:clamp(16px,1.6vw,20px);line-height:1.35;color:var(--bg);max-width:46ch;letter-spacing:-.01em;margin:0}
.bespoke-cta-end{flex-shrink:0}
.bespoke-meta{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(236,228,216,.2)}
.bm-row{display:flex;justify-content:space-between;align-items:baseline;padding:14px 0;border-bottom:1px solid rgba(236,228,216,.2);font-family:var(--mono);font-size:11px}
.bm-k{letter-spacing:.18em;text-transform:uppercase;color:rgba(236,228,216,.72)}
.bm-v{letter-spacing:.04em;color:var(--bg)}

/* ===== Bespoke cases (concrete examples) ===== */
.bespoke-cases{margin-top:48px;position:relative}
.bespoke-cases-head{display:flex;align-items:center;gap:18px;margin-bottom:24px}
.bespoke-cases-kicker{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--brick-light)}
.bespoke-cases-line{flex:1;height:1px;background:rgba(236,228,216,.18)}
.bespoke-cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.bcase{
  padding:24px 22px;
  background:rgba(236,228,216,.085);border:1px solid rgba(236,228,216,.3);
  display:flex;flex-direction:column;gap:10px;position:relative;
  transition:background var(--t-base) var(--ease-soft),border-color var(--t-base) var(--ease-soft),transform var(--t-base) var(--ease-out),box-shadow var(--t-base) var(--ease-soft);
}
.bcase:hover{background:rgba(236,228,216,.13);border-color:var(--brick-light);transform:translateY(-3px);box-shadow:5px 5px 0 0 rgba(0,0,0,.25)}
.bcase-num{font-family:var(--mono);font-size:10px;letter-spacing:.18em;color:rgba(236,228,216,.72)}
.bcase-client{font-family:var(--grot);font-weight:500;font-size:14px;letter-spacing:-.01em;color:var(--bg);text-transform:none}
.bcase-problem{font-family:var(--grot);font-size:13px;line-height:1.5;color:rgba(236,228,216,.72);font-style:italic}
.bcase-sep{font-family:var(--mono);font-size:14px;color:var(--brick-light);margin:2px 0}
.bcase-solution{font-family:var(--grot);font-size:13px;line-height:1.5;color:var(--bg-2)}
.bcase-detail{font-family:var(--grot);font-size:12px;line-height:1.45;color:rgba(236,228,216,.72)}
.bcase-foot{margin-top:auto;padding-top:12px;border-top:1px dashed rgba(196,100,81,.4);display:flex;flex-direction:column;gap:6px}
.bcase-meta{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:rgba(236,228,216,.72)}
.bcase-result{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--brick-light);
}

@media (max-width:1024px){
  .packs{grid-template-columns:repeat(2,1fr)}
  .packs-2{grid-template-columns:repeat(2,1fr)}
  .bespoke-grid{grid-template-columns:1fr;gap:32px}
  .bespoke-cases-grid{grid-template-columns:1fr}
  .bcase{border-right:none}
}
@media (max-width:560px){
  .stats-inner{grid-template-columns:1fr}
  .mj-bilan-grid{grid-template-columns:1fr}
  .packs,.packs-2{grid-template-columns:1fr}
  .bespoke{padding:32px 24px}
}

/* ===== Frise verticale (method on home) ===== */
.frise{position:relative;padding-left:52px}
.frise-line{position:absolute;left:17px;top:4px;bottom:4px;width:2px;background:var(--bg-2)}
.frise-fill{position:absolute;left:17px;top:4px;width:2px;height:0;background:var(--brick-light);will-change:height}
.frise-item{position:relative;margin-bottom:40px;opacity:.2;transform:translateX(-10px);will-change:opacity,transform}
.frise-item:last-child{margin-bottom:0}
.frise-dot{position:absolute;left:-34px;top:4px;width:12px;height:12px;border-radius:50%;border:2px solid var(--bg-2);background:var(--bg);transition:width .4s ease,height .4s ease,border-color .4s ease,background .4s ease;transform:translateX(-50%)}
.frise-dot.is-active{width:16px;height:16px;border-color:var(--brick-light);background:var(--brick-light)}
.frise-num{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick-light);margin-bottom:4px}
.frise-title{font-family:var(--grot);font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--ink);margin-bottom:6px}
.frise-desc{font-size:14px;line-height:1.55;color:var(--soft);max-width:480px;letter-spacing:-.005em}
.frise-when{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--brick);margin-top:8px;display:inline-block;padding:3px 8px;border:1px solid var(--bg-2);background:var(--cream)}

/* ===== Steps legacy (method detail page) ===== */
.steps{
  display:flex;flex-direction:column;
  border:2px solid var(--ink);background:var(--bg);
}
.step{
  display:grid;grid-template-columns:96px 1fr 200px;align-items:stretch;
  border-bottom:1px solid var(--ink);
  position:relative;overflow:hidden;
  transition:background .35s ease;
}
.step:last-child{border-bottom:none}
.step::before{
  content:"";position:absolute;left:0;top:0;height:100%;width:0;
  background:var(--brick);opacity:.08;transition:width .55s cubic-bezier(.2,.8,.2,1);
  pointer-events:none;
}
.step:hover::before{width:100%}
.step:hover .step-num{background:var(--brick)}
.step-num{
  background:var(--ink);color:var(--bg);font-family:var(--mono);
  font-weight:700;font-size:14px;letter-spacing:.18em;
  display:flex;align-items:center;justify-content:center;padding:28px 16px;
  transition:background .3s ease;
}
.step-body{padding:28px 28px 28px 32px;position:relative}
.step-title{font-family:var(--grot);font-weight:500;font-size:clamp(22px,2.4vw,30px);line-height:1.1;letter-spacing:-.02em;margin-bottom:8px;color:var(--ink)}
.step-desc{font-size:14px;line-height:1.55;color:var(--soft);max-width:680px;font-family:var(--sans)}
.step-when{
  padding:28px 24px;display:flex;align-items:center;justify-content:flex-end;
  color:var(--brick);font-family:var(--mono);font-weight:500;
  letter-spacing:.16em;text-transform:uppercase;font-size:11px;
  border-left:1px solid var(--ink);
}

/* ===== Video block ===== */
.demo-head{margin-bottom:40px;max-width:900px}
.video{
  position:relative;aspect-ratio:16/9;background:var(--brick-deep);overflow:hidden;
  border:2px solid var(--bg);
}
.video-stripes{position:absolute;inset:0;background:repeating-linear-gradient(45deg,rgba(0,0,0,.08) 0 14px,transparent 14px 28px)}
.video-play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:88px;height:88px;border-radius:50%;background:var(--brick-light);color:var(--ink);
  display:grid;place-items:center;cursor:pointer;transition:.3s;
}
.video-play:hover{transform:translate(-50%,-50%) scale(1.08)}
.video-play svg{width:28px;height:28px;margin-left:4px}
.video-meta{
  position:absolute;left:0;right:0;bottom:0;padding:14px 18px;
  background:linear-gradient(transparent,rgba(0,0,0,.7));color:var(--bg);
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
}

/* ===== FAQ ===== */
.faq{display:flex;flex-direction:column;border-top:2px solid var(--ink)}
.faq-row{border-bottom:1px solid var(--ink);transition:.2s}
.faq-q{
  width:100%;text-align:left;padding:22px 0;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--grot);font-weight:500;font-size:clamp(17px,1.8vw,22px);line-height:1.3;letter-spacing:-.01em;
  cursor:pointer;
}
.faq-toggle{font-family:var(--grot);font-weight:300;font-size:32px;color:var(--brick);transition:.3s;line-height:1}
.faq-row.is-open .faq-toggle{transform:rotate(180deg)}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s ease}
.faq-row.is-open .faq-a{grid-template-rows:1fr}
.faq-a > div{overflow:hidden;font-size:15px;line-height:1.6;color:var(--soft);max-width:880px}
.faq-row.is-open .faq-a > div{padding-bottom:22px}
.faq-more{margin-top:32px}

/* ===== CTA block ===== */
.cta-block{padding:120px 20px;background:var(--brick);color:var(--bg);text-align:center;position:relative;overflow:hidden;border-bottom:2px solid var(--ink)}
.cta-block::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:80vw;height:80vw;max-width:900px;max-height:900px;border:1px solid var(--brick-light);border-radius:50%;opacity:.4}
.cta-block::after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:60vw;height:60vw;max-width:700px;max-height:700px;border:1px solid var(--brick-light);border-radius:50%;opacity:.25}
.cta-inner{position:relative;z-index:2}
.cta-ring{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:40vw;height:40vw;max-width:500px;max-height:500px;border:1px solid var(--brick-light);border-radius:50%;opacity:.4;z-index:1;pointer-events:none}
.cta-inner .kicker{color:var(--bg-2)}
.cta-inner .kicker::before{color:var(--brick-light)}
.cta-title{font-size:clamp(48px,7vw,110px);color:var(--bg);margin-bottom:24px}
.cta-title em{font-style:normal;font-weight:800;color:var(--bg-2)}
.cta-text{margin:0 auto;color:var(--bg);opacity:.9;max-width:680px}
.cta-ctas{margin-top:36px;display:flex;justify-content:center;gap:14px;flex-wrap:wrap}
.cta-block .btn-primary{background:var(--bg);color:var(--ink);border-color:var(--bg)}
.cta-block .btn-primary:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.cta-block .btn-link{color:var(--bg);border-bottom:1px solid var(--bg-2);padding-right:8px;transition:border-color .25s,color .25s}
.cta-block .btn-link:hover{color:var(--bg-2);border-bottom-color:transparent}
.cta-block .btn-ghost{color:var(--bg);border-color:rgba(236,228,216,.72)}
.cta-block .btn-ghost:hover{background:var(--bg);color:var(--brick);border-color:var(--bg)}

/* ===== Footer ===== */
.foot{background:var(--ink);color:var(--bg-2);padding:60px 20px 24px;font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.foot-top{display:grid;grid-template-columns:2fr 3fr;gap:48px;align-items:start;max-width:1240px;margin:0 auto}
.foot-brand .nav-logo{color:var(--bg)}
.foot-brand .nav-logo .stamp{background:var(--bg)}
.foot-tag{font-family:var(--grot);font-size:14px;letter-spacing:0;text-transform:none;line-height:1.55;color:var(--bg-2);margin:18px 0 24px;max-width:380px}
.foot-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.foot h5,.foot .foot-h{font-family:var(--grot);font-weight:700;font-size:16px;letter-spacing:-.02em;text-transform:none;margin-bottom:14px;color:var(--bg)}
.foot ul{list-style:none;line-height:2}
.foot a:hover{color:var(--brick-light)}
.foot-bot{max-width:1240px;margin:36px auto 0;padding-top:20px;border-top:1px solid var(--bg-2);display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px}

/* ===== Timeline (méthode) ===== */
.timeline{display:flex;flex-direction:column;border-top:2px solid var(--ink)}
.tl-step{display:grid;grid-template-columns:200px 1fr;gap:32px;padding:32px 0;border-bottom:1px solid var(--ink);transition:.3s}
.tl-step:hover{padding-left:14px;background:rgba(122,46,35,.06)}
.tl-step.is-cur{background:var(--bg-2)}
.tl-num{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);font-weight:500}
.tl-title{font-family:var(--grot);font-weight:500;font-size:clamp(28px,3vw,40px);line-height:1.05;letter-spacing:-.02em;margin-bottom:14px}
.tl-desc{font-size:16px;line-height:1.55;color:var(--ink);max-width:700px;margin-bottom:18px}
.tl-deliv{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.tl-deliv span:not(:first-child){padding:3px 8px;background:var(--bg-2);border:none;font-size:10px;color:var(--ink)}
.section-warm .tl-deliv span:not(:first-child){background:var(--bg)}

/* ===== Method Journey (new interactive) ===== */
.mj-counter{position:fixed;top:80px;right:24px;z-index:90;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);background:var(--bg);border:2px solid var(--ink);padding:8px 14px;transition:opacity .4s}
.mj-counter-n{font-family:var(--grot);font-weight:700;font-size:18px;letter-spacing:-.02em}
.mj-counter-sep{opacity:.4;margin:0 2px}
.mj-counter-t{opacity:.5}
/* ===== Méthode · timeline verticale compacte ===== */
.mj-flow-section{padding:60px 20px 76px}
.mj-flow-intro{max-width:780px;margin:0 auto 38px;padding-bottom:26px;border-bottom:2px solid var(--ink);display:flex;align-items:baseline;gap:18px;flex-wrap:wrap}
.mj-flow-intro-k{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);font-weight:500;white-space:nowrap}
.mj-flow-intro-t{font-family:var(--grot);font-size:16px;line-height:1.5;color:var(--ink-soft);flex:1;min-width:240px}
.mj-flow{list-style:none;max-width:780px;margin:0 auto;display:flex;flex-direction:column}
.mj-step{display:grid;grid-template-columns:72px 1fr;column-gap:28px}
.mj-rail{display:flex;flex-direction:column;align-items:center}
.mj-node{width:72px;height:72px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--grot);font-weight:700;font-size:30px;letter-spacing:-.03em;color:var(--bg);background:var(--brick);border:2px solid var(--ink)}
.mj-line{flex:1;width:2px;background:var(--ink);margin:6px 0;min-height:18px}
.mj-card{border:2px solid var(--ink);background:var(--bg);padding:24px 26px 26px;margin-bottom:26px;box-shadow:6px 6px 0 rgba(122,46,35,.13);transition:box-shadow .25s ease,transform .25s ease}
.mj-card:hover{box-shadow:9px 9px 0 var(--brick);transform:translate(-2px,-2px)}
.mj-card-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:12px}
.mj-card-title{font-family:var(--grot);font-weight:700;font-size:clamp(22px,2.4vw,29px);line-height:1.04;letter-spacing:-.025em}
.mj-card-dur{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--brick);background:var(--bg-2);border:1px solid rgba(122,46,35,.28);padding:5px 10px;white-space:nowrap}
.mj-card-desc{font-size:15px;line-height:1.6;color:var(--ink-soft);margin-bottom:20px;max-width:600px}
.mj-card-delivs{display:flex;flex-direction:column;gap:11px;padding-top:18px;border-top:1px solid rgba(58,37,32,.16)}
.mj-card-delivs-k{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick)}
.mj-chips{display:flex;flex-wrap:wrap;gap:8px}
.mj-chip{font-family:var(--grot);font-weight:500;font-size:13px;color:var(--ink);background:var(--bg-2);border:1px solid rgba(58,37,32,.2);padding:6px 12px;display:flex;align-items:center;gap:8px}
.mj-chip::before{content:"";width:5px;height:5px;background:var(--brick);border-radius:50%;flex-shrink:0}
@media(max-width:560px){
  .mj-step{grid-template-columns:52px 1fr;column-gap:16px}
  .mj-node{width:52px;height:52px;font-size:22px}
  .mj-card{padding:20px}
}
.mj-picker-section{padding:48px 20px 40px}
.mj-picker{display:inline-flex;gap:0;border:2px solid rgba(236,228,216,.2);overflow:hidden}
.mj-picker-btn{display:flex;flex-direction:column;gap:4px;padding:20px 36px;background:transparent;border:none;cursor:pointer;transition:background .3s,color .3s;color:rgba(236,228,216,.72);text-align:left;border-right:2px solid rgba(236,228,216,.2)}
.mj-picker-btn:last-child{border-right:none}
.mj-picker-btn:hover{background:rgba(236,228,216,.06)}
.mj-picker-on{background:rgba(236,228,216,.1);color:var(--bg)}
.mj-picker-label{font-family:var(--grot);font-size:18px;font-weight:700;letter-spacing:-.02em}
.mj-picker-sub{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;opacity:.6}
.mj-picker-on .mj-picker-sub{opacity:.8}
@media(max-width:600px){
  .mj-picker{flex-direction:column;width:100%}
  .mj-picker-btn{border-right:none;border-bottom:2px solid rgba(236,228,216,.2)}
  .mj-picker-btn:last-child{border-bottom:none}
}
.mj-bilan-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:40px}
.mj-bilan-card{padding:28px 20px;border:2px solid var(--ink);background:var(--bg);text-align:center;transition:transform .25s,box-shadow .25s}
.mj-bilan-card:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--brick)}
.mj-bilan-n{font-family:var(--grot);font-weight:700;font-size:clamp(28px,3.5vw,44px);letter-spacing:-.03em;color:var(--brick);line-height:1;margin-bottom:8px}
.mj-bilan-l{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);line-height:1.4}
.mj-bilan-delivs{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.mj-bilan-tag{padding:6px 12px;background:var(--bg);border:1px solid var(--ink);font-family:var(--grot);font-size:13px;font-weight:500}

/* ===== Services packs side-by-side ===== */
.svc-packs-row{display:grid;grid-template-columns:1fr 1fr}
.svc-pack-col{padding:48px 40px;display:flex;flex-direction:column;background:var(--bg);min-height:0}
.svc-pack-col-warm{background:var(--bg-2)}
.svc-pack-col + .svc-pack-col{border-left:2px solid var(--ink)}
.svc-col-title{font-family:var(--grot);font-weight:700;font-size:clamp(28px,4vw,40px);letter-spacing:-.02em;line-height:1.1;margin-bottom:18px}
.svc-col-pricerow{display:flex;align-items:baseline;flex-wrap:wrap;gap:8px 16px;margin-bottom:30px}
.svc-col-price{font-family:var(--grot);font-weight:400;font-size:clamp(48px,6vw,66px);letter-spacing:-.045em;line-height:.85;color:var(--brick)}
.svc-col-cur{font-size:.46em;font-weight:500;margin-left:3px;letter-spacing:0}
.svc-col-per{font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft)}
.svc-col-pricerow .svc-pack-deal{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--brick);background:rgba(122,46,35,.07);border:1px solid rgba(122,46,35,.22);border-radius:999px;padding:5px 11px;align-self:center;margin:0;line-height:1}
.svc-col-pricerow .svc-pack-deal sup{font-size:.75em;vertical-align:.35em}
/* Bandeau "1er mois offert" (hero, legacy) */
.svc-col-offer{display:inline-flex;align-items:center;gap:11px;align-self:flex-start;background:var(--brick);color:var(--bg);border-radius:7px;padding:10px 16px;margin:-16px 0 18px;box-shadow:0 10px 24px -14px rgba(122,46,35,.7)}
.svc-col-offer-tag{font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;opacity:.72}
.svc-col-offer-txt{font-family:var(--grot);font-size:16px;letter-spacing:-.01em}
.svc-col-offer-txt strong{font-weight:700}
.svc-col-offer sup{font-size:.66em;vertical-align:.42em}
/* Paliers d'engagement */
.svc-col-engage{margin:0 0 26px;max-width:380px}
.svc-col-engage-k{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);margin-bottom:9px}
.svc-col-engage-tiers{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.svc-col-engage-tier{position:relative;display:flex;flex-direction:column;gap:4px;padding:11px 13px;border:1px solid rgba(122,46,35,.22);border-radius:6px;background:rgba(122,46,35,.05)}
.svc-col-engage-dur{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--brick)}
.svc-col-engage-price{font-family:var(--grot);font-weight:500;font-size:21px;letter-spacing:-.02em;color:var(--ink);line-height:1}
.svc-col-engage-price span{font-family:var(--mono);font-size:9px;letter-spacing:.06em;color:var(--soft);font-weight:400;margin-left:2px}
.svc-col-engage-off{position:absolute;top:10px;right:11px;font-family:var(--mono);font-size:10px;font-weight:500;color:var(--bg);background:var(--brick);border-radius:3px;padding:2px 6px;letter-spacing:.02em}
.svc-col-engage-tier-best{border-color:rgba(122,46,35,.4);background:rgba(122,46,35,.09)}
.svc-col-engage-note{display:block;margin-top:9px;font-size:12px;line-height:1.4;color:var(--ink-soft)}
/* Deux parcours cote a cote */
.svc-col-plans{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:-4px 0 28px;align-items:stretch}
.svc-col-plan{display:flex;flex-direction:column;gap:7px;padding:18px 18px 20px;border:1px solid var(--rule);border-radius:9px;background:var(--bg);position:relative;transition:transform .4s cubic-bezier(.22,1,.36,1),box-shadow .4s ease,border-color .3s ease,background .3s ease;will-change:transform}
.svc-col-plan-best{border-color:rgba(122,46,35,.45);background:rgba(122,46,35,.06);box-shadow:0 14px 30px -20px rgba(122,46,35,.55)}
.svc-col-plan-flag{position:absolute;top:-9px;left:16px;font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--bg);background:var(--brick);border-radius:4px;padding:3px 8px;line-height:1}
.svc-col-plan-tag{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--brick);font-weight:500}
.svc-col-plan-price{font-family:var(--grot);font-weight:400;font-size:40px;letter-spacing:-.03em;line-height:.9;color:var(--brick);display:flex;align-items:baseline}
.svc-col-plan-cur{font-size:.45em;font-weight:500;margin-left:2px}
.svc-col-plan-per{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--soft);margin-left:7px;align-self:flex-end;padding-bottom:5px}
.svc-col-plan-perk{font-family:var(--grot);font-weight:600;font-size:14px;line-height:1.25;color:var(--ink);display:flex;gap:7px;align-items:baseline;margin-top:2px}
.svc-col-plan-perk-i{color:var(--brick);font-size:11px;flex-shrink:0}
.svc-col-plan-perk sup{font-size:.66em;vertical-align:.42em}
.svc-col-plan-sub{font-size:12.5px;line-height:1.4;color:var(--ink-soft);margin-top:auto}
/* Hover des cartes de prix */
.svc-col-plan-price{transition:transform .45s cubic-bezier(.22,1,.36,1),color .3s ease;transform-origin:left center}
.svc-col-plan-flag{transition:transform .45s cubic-bezier(.34,1.56,.64,1)}
.svc-col-plan-perk-i{display:inline-block;transition:transform .55s cubic-bezier(.34,1.56,.64,1)}
.svc-col-plan:hover{transform:translateY(-4px);border-color:rgba(122,46,35,.4);box-shadow:0 16px 34px -22px rgba(42,24,22,.45)}
.svc-col-plan:hover .svc-col-plan-perk-i{transform:scale(1.18)}
.svc-col-plan-best:hover{transform:translateY(-8px);border-color:var(--brick);box-shadow:0 26px 52px -20px rgba(122,46,35,.5)}
.svc-col-plan-best:hover .svc-col-plan-price{transform:scale(1.07);color:var(--brick-deep)}
.svc-col-plan-best:hover .svc-col-plan-flag{transform:translateY(-3px) rotate(-2deg) scale(1.06)}
.svc-col-plan-best:hover .svc-col-plan-perk-i{transform:rotate(45deg) scale(1.25)}
@media (prefers-reduced-motion:reduce){.svc-col-plan,.svc-col-plan-price,.svc-col-plan-flag,.svc-col-plan-perk-i{transition:none}.svc-col-plan:hover,.svc-col-plan-best:hover{transform:none}}
/* Appels de note + conditions legales */
.svc-legal-ref{font-family:var(--mono);font-weight:500;color:var(--brick)}
.svc-packs-legal{padding:26px 40px 30px;border-top:2px solid var(--ink);background:var(--bg);display:flex;flex-direction:column;gap:9px}
.svc-legal-note{font-size:12.5px;line-height:1.55;color:var(--soft);max-width:920px;margin:0}
.svc-legal-note .svc-legal-ref{margin-right:3px}
.svc-legal-note-fine{font-family:var(--mono);font-size:11px;line-height:1.5;letter-spacing:.01em;color:var(--ink-mute,rgba(42,24,22,.5))}
.svc-legal-note a{color:var(--brick);text-decoration:underline;text-underline-offset:2px}

/* Bandeau renvoi vers les tarifs (page Services) */
.svc-packs-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px 40px;padding:30px 40px;border-top:2px solid var(--ink);background:var(--bg-2)}
.svc-packs-cta-txt{display:flex;flex-direction:column;gap:8px;max-width:560px}
.svc-packs-cta-txt .kicker{margin-bottom:0}
.svc-packs-cta-txt p{font-size:15px;line-height:1.55;color:var(--ink-soft);margin:0}
.svc-packs-cta .btn{white-space:nowrap}
@media(max-width:560px){.svc-packs-cta{padding:24px}}

/* ===== Bundle Facilité (bandeau pleine largeur) ===== */
.svc-bundle-band{background:var(--bg);border-top:2px solid var(--ink);padding:40px}
.svc-bundle{display:grid;grid-template-columns:1.05fr 1.5fr auto;align-items:center;gap:34px;background:var(--ink);color:var(--bg-2);border-radius:12px;padding:30px 36px}
.svc-bundle-left{display:flex;flex-direction:column;gap:8px}
.svc-bundle-tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick-light);font-weight:500}
.svc-bundle-name{font-family:var(--grot);font-weight:700;font-size:clamp(22px,2.4vw,30px);letter-spacing:-.02em;line-height:1.05;color:var(--bg)}
.svc-bundle-desc{font-size:13.5px;line-height:1.5;color:rgba(236,228,216,.72);max-width:340px}
.svc-bundle-desc strong{color:var(--rust);font-weight:600}
.svc-bundle-prices{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.svc-bundle-price{position:relative;display:flex;flex-direction:column;gap:5px;padding:16px 18px 18px;border:1px solid rgba(236,228,216,.18);border-radius:10px}
.svc-bundle-price-best{border-color:var(--brick-light);background:rgba(196,100,81,.14)}
.svc-bundle-flag{position:absolute;top:-9px;left:16px;white-space:nowrap;font-family:var(--mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);background:var(--brick-light);border-radius:4px;padding:3px 8px;line-height:1}
.svc-bundle-k{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--brick-light)}
.svc-bundle-p{font-family:var(--grot);font-weight:400;font-size:clamp(30px,3vw,38px);letter-spacing:-.03em;color:var(--bg);line-height:.95;display:flex;align-items:baseline}
.svc-bundle-cur{font-size:.45em;font-weight:500;margin-left:2px}
.svc-bundle-p .svc-bundle-per{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:rgba(236,228,216,.72);margin-left:5px;align-self:flex-end;padding-bottom:4px}
.svc-bundle-was{font-family:var(--mono);font-size:11px;color:rgba(236,228,216,.72);text-decoration:line-through}
.svc-bundle-note{font-family:var(--grot);font-size:12px;line-height:1.3;color:var(--bg-2);font-weight:500}
.svc-bundle-note sup{font-size:.66em;vertical-align:.42em}
.svc-bundle .btn{align-self:center;white-space:nowrap}
.svc-bundle .btn-primary{background:var(--brick-light);color:var(--ink);border-color:var(--brick-light)}
.svc-bundle .btn-primary:hover{background:var(--bg);border-color:var(--bg)}
@media(max-width:1080px){
  .svc-bundle{grid-template-columns:1fr;gap:24px}
  .svc-bundle .btn{align-self:start}
}
@media(max-width:560px){
  .svc-bundle-band{padding:24px}
  .svc-bundle{padding:24px 22px}
  .svc-bundle-prices{grid-template-columns:1fr}
}

/* ===== Page Tarifs ===== */
.tarif-head{max-width:720px;margin:0 0 48px}
.tarif-head .h2{margin:14px 0 0}
.tarif-head-lede{font-size:16px;line-height:1.6;color:var(--ink-soft);margin-top:18px;max-width:560px}
.tarif-packs{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.tarif-card{display:flex;flex-direction:column;padding:34px 32px 30px;border:1px solid var(--rule);border-radius:14px;background:var(--bg)}
.tarif-card-num{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);font-weight:500}
.tarif-card-name{font-family:var(--grot);font-weight:700;font-size:clamp(24px,2.6vw,32px);letter-spacing:-.02em;line-height:1.05;margin:8px 0 10px}
.tarif-card-desc{font-size:14px;line-height:1.55;color:var(--ink-soft);max-width:380px;margin-bottom:26px;min-height:65px}
.tarif-card .svc-col-plans{margin:0 0 24px}
.tarif-incl{list-style:none;display:flex;flex-direction:column;gap:9px;margin:0 0 28px;padding-top:22px;border-top:1px solid rgba(58,37,32,.16)}
.tarif-incl li{font-family:var(--grot);font-size:13.5px;line-height:1.4;color:var(--ink);display:flex;gap:9px;align-items:baseline}
.tarif-incl li .svc-col-check{color:var(--brick)}
.tarif-card-foot{margin-top:auto;display:flex;flex-wrap:wrap;align-items:center;gap:16px 20px}
.tarif-card-foot .btn-link{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase}

/* Sur-mesure pricing */
.tarif-sm{display:grid;grid-template-columns:1fr 1.25fr;gap:40px;align-items:center;background:var(--bg-2);border:1px solid var(--rule);border-radius:14px;padding:40px}
.tarif-sm-left{display:flex;flex-direction:column;gap:12px}
.tarif-sm-tag{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);font-weight:500}
.tarif-sm-name{font-family:var(--grot);font-weight:700;font-size:clamp(26px,3vw,36px);letter-spacing:-.025em;line-height:1.02}
.tarif-sm-price{font-family:var(--grot);font-weight:300;font-size:clamp(34px,4vw,46px);letter-spacing:-.03em;color:var(--brick);line-height:1}
.tarif-sm-sub{font-size:14px;line-height:1.55;color:var(--ink-soft);max-width:340px}
.tarif-sm-rows{display:flex;flex-direction:column;gap:0;border-top:1px solid rgba(58,37,32,.18)}
.tarif-sm-row{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:baseline;padding:15px 0;border-bottom:1px solid rgba(58,37,32,.18)}
.tarif-sm-row-k{font-family:var(--grot);font-weight:600;font-size:18px;letter-spacing:-.02em;color:var(--brick);white-space:nowrap;min-width:96px}
.tarif-sm-row-v{font-size:13.5px;line-height:1.45;color:var(--ink-soft)}
.tarif-sm-row-v strong{color:var(--ink);font-weight:600}

/* Bandeau d'assurances */
.tarif-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(236,228,216,.18);border-radius:12px;overflow:hidden}
.tarif-strip-item{padding:26px 22px;display:flex;flex-direction:column;gap:6px;border-right:1px solid rgba(236,228,216,.14)}
.tarif-strip-item:last-child{border-right:none}
.tarif-strip-k{font-family:var(--grot);font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--bg)}
.tarif-strip-v{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(236,228,216,.72);line-height:1.4}
.tarif-legal{margin-top:40px;display:flex;flex-direction:column;gap:9px;max-width:920px}
.tarif-legal-band{padding:44px 20px 8px;border-top:1px solid rgba(58,37,32,.14)}
.tarif-legal-band .tarif-legal{margin-top:0}
.tarif-legal-band .svc-legal-ref{color:var(--brick)}

@media(max-width:900px){
  .tarif-packs{grid-template-columns:1fr}
  .tarif-sm{grid-template-columns:1fr;gap:28px;padding:30px 26px}
  .tarif-strip{grid-template-columns:1fr 1fr}
  .tarif-strip-item:nth-child(2){border-right:none}
  .tarif-strip-item:nth-child(1),.tarif-strip-item:nth-child(2){border-bottom:1px solid rgba(236,228,216,.14)}
}
@media(max-width:560px){
  .tarif-strip{grid-template-columns:1fr}
  .tarif-strip-item{border-right:none;border-bottom:1px solid rgba(236,228,216,.14)}
}

@media(max-width:900px){.svc-packs-legal{padding:24px 24px 28px}}

/* ===== Page Sur-mesure ===== */
.sm-facts{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--rule);border-radius:12px;overflow:hidden;background:var(--bg)}
.sm-fact{display:flex;flex-direction:column;gap:6px;padding:22px 22px;border-right:1px solid rgba(58,37,32,.14)}
.sm-fact:last-child{border-right:none}
.sm-fact-k{font-family:var(--grot);font-weight:700;font-size:19px;letter-spacing:-.02em;color:var(--brick)}
.sm-fact-v{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;line-height:1.45;color:var(--ink-soft)}

.sm-steps{max-width:760px}
.sm-step-dur{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-left:8px;white-space:nowrap}

/* Packs vs sur-mesure */
.sm-compare{display:grid;grid-template-columns:1fr 1.15fr;gap:20px;align-items:stretch}
.sm-compare-col{position:relative;display:flex;flex-direction:column;padding:30px 30px 28px;border:1px solid var(--rule);border-radius:14px;background:var(--bg)}
.sm-compare-col-feat{background:var(--ink);border-color:var(--ink)}
.sm-compare-flag{position:absolute;top:-10px;left:30px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--brick-light);border-radius:5px;padding:4px 10px;line-height:1;font-weight:500}
.sm-compare-k{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);font-weight:500}
.sm-compare-col-feat .sm-compare-k{color:var(--brick-light)}
.sm-compare-price{font-family:var(--grot);font-weight:300;font-size:clamp(28px,3vw,36px);letter-spacing:-.03em;line-height:1;color:var(--ink);margin:10px 0 4px;display:flex;align-items:baseline;flex-wrap:wrap;gap:8px}
.sm-compare-col-feat .sm-compare-price{color:var(--bg)}
.sm-compare-per{font-family:var(--mono);font-size:11px;font-weight:400;letter-spacing:.04em;text-transform:uppercase;color:var(--soft)}
.sm-compare-col-feat .sm-compare-per{color:rgba(236,228,216,.72)}
.sm-compare-tag{font-family:var(--grot);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink-soft);margin-bottom:20px}
.sm-compare-col-feat .sm-compare-tag{color:var(--bg-2)}
.sm-compare-list{list-style:none;display:flex;flex-direction:column;gap:11px;margin:0 0 24px;padding-top:20px;border-top:1px solid rgba(58,37,32,.16)}
.sm-compare-col-feat .sm-compare-list{border-top-color:rgba(236,228,216,.72)}
.sm-compare-list li{font-family:var(--grot);font-size:14px;line-height:1.45;color:var(--ink-soft);position:relative;padding-left:18px}
.sm-compare-list li::before{content:"·";position:absolute;left:0;color:var(--soft)}
.sm-compare-list-feat li{color:var(--bg-2);padding-left:24px}
.sm-compare-list-feat li::before{content:none}
.sm-compare-col .btn-link,.sm-compare-col .btn{margin-top:auto;align-self:flex-start}
.sm-compare-col-feat .btn-primary{background:var(--brick-light);color:var(--ink);border-color:var(--brick-light)}
.sm-compare-col-feat .btn-primary:hover{background:var(--bg);border-color:var(--bg)}
.sm-compare-note{margin-top:22px;max-width:620px;font-size:14px;line-height:1.55;color:var(--ink-soft)}
@media(max-width:760px){
  .sm-compare{grid-template-columns:1fr}
}

.sm-cases{display:flex;flex-direction:column;gap:22px}
.sm-case{background:var(--bg);border:1px solid var(--rule);border-radius:14px;padding:30px 32px;display:flex;flex-direction:column;gap:22px}
.sm-case-head{display:flex;align-items:flex-start;gap:20px}
.sm-case-num{font-family:var(--grot);font-weight:300;font-size:46px;line-height:.8;letter-spacing:-.04em;color:var(--brick);opacity:.85;flex-shrink:0}
.sm-case-tag{display:block;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);font-weight:500;margin-bottom:6px}
.sm-case-title{font-family:var(--grot);font-weight:700;font-size:clamp(20px,2.2vw,26px);letter-spacing:-.02em;line-height:1.1;color:var(--ink)}
.sm-case-body{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border-top:1px solid rgba(58,37,32,.14)}
.sm-case-col{padding:22px 24px 22px 0}
.sm-case-col-sys{padding-left:28px;border-left:1px solid rgba(58,37,32,.14)}
.sm-case-col-k{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);margin-bottom:14px}
.sm-case-col-sys .sm-case-col-k{color:var(--brick)}
.sm-case-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin:0;padding:0}
.sm-case-list li{font-family:var(--grot);font-size:14px;line-height:1.45;color:var(--ink-soft);position:relative;padding-left:18px}
.sm-case-list li::before{content:"·";position:absolute;left:0;color:var(--soft)}
.sm-case-list-sys li{color:var(--ink);padding-left:24px}
.sm-case-list-sys li::before{content:none}
.sm-case-check{position:absolute;left:0;top:1px;color:var(--brick);font-weight:700;font-size:13px}
.sm-case-result{display:flex;align-items:baseline;gap:14px;padding-top:20px;border-top:2px solid var(--ink)}
.sm-case-result-k{flex-shrink:0;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick)}
.sm-case-result-v{font-family:var(--grot);font-weight:500;font-size:16px;line-height:1.4;letter-spacing:-.01em;color:var(--ink)}
.sm-cases-foot{margin-top:26px;text-align:center;font-size:15px;color:var(--ink-soft)}
.sm-cases-foot a{color:var(--brick);text-decoration:underline;text-underline-offset:2px}

/* ===== Survol : transformation avant → après ===== */
.sm-case{transition:border-color .45s ease, box-shadow .45s ease, transform .45s ease}
.sm-case-col-avant,.sm-case-col-sys{transition:opacity .45s ease, transform .45s ease, background .45s ease}
.sm-case-col-avant .sm-case-list li{transition:color .45s ease}
.sm-case-col-sys .sm-case-list-sys li{transition:transform .5s cubic-bezier(.4,0,.2,1)}
.sm-case-col-sys .sm-case-check{transition:transform .5s cubic-bezier(.34,1.56,.64,1), color .45s ease}
.sm-case-body::after{
  content:"→";position:absolute;left:calc(100%/2.1);top:50%;
  font-family:var(--grot);font-weight:700;font-size:23px;line-height:1;
  color:var(--brick);
  transform:translate(-50%,-50%) scale(.4);opacity:0;
  transition:opacity .4s ease, transform .55s cubic-bezier(.34,1.56,.64,1);
  pointer-events:none;z-index:3}
.sm-case-body{position:relative}

@media (hover:hover){
  .sm-case:hover{cursor:default}
}
.sm-case:hover{border-color:var(--brick);box-shadow:0 22px 46px -28px rgba(122,46,35,.45);transform:translateY(-3px)}
.sm-case:hover .sm-case-col-avant{opacity:.4;transform:translateX(-5px)}
.sm-case:hover .sm-case-col-avant .sm-case-list li{color:var(--soft)}
.sm-case:hover .sm-case-col-sys{background:linear-gradient(90deg, rgba(122,46,35,.07), transparent 78%)}
.sm-case:hover .sm-case-col-sys .sm-case-list-sys li{transform:translateX(3px)}
.sm-case:hover .sm-case-col-sys .sm-case-check{transform:scale(1.4)}
.sm-case-col-sys .sm-case-list-sys li:nth-child(1) .sm-case-check{transition-delay:.05s}
.sm-case-col-sys .sm-case-list-sys li:nth-child(2) .sm-case-check{transition-delay:.13s}
.sm-case-col-sys .sm-case-list-sys li:nth-child(3) .sm-case-check{transition-delay:.21s}
.sm-case-col-sys .sm-case-list-sys li:nth-child(4) .sm-case-check{transition-delay:.29s}
.sm-case:hover .sm-case-body::after{opacity:1;transform:translate(-50%,-50%) scale(1);transition-delay:.1s}
@media (max-width:680px){
  .sm-case-body::after{display:none}
}
@media (prefers-reduced-motion:reduce){
  .sm-case,.sm-case *{transition:none !important}
  .sm-case-body::after{display:none}
}

/* ===== Slogan band ===== */
.slogan-band{background:var(--ink);padding:clamp(48px,8vw,96px) 20px;text-align:center}
.slogan-text{font-family:var(--grot);font-weight:300;font-size:clamp(26px,3.6vw,48px);line-height:1.1;letter-spacing:-.03em;color:var(--bg);max-width:720px;margin:0 auto;cursor:default}
.slogan-text:hover em{background-position:-100% 0}
.slogan-text em{font-style:normal;font-weight:700;color:var(--brick-light);
  background:linear-gradient(90deg, var(--brick-light) 0%, var(--brick-light) 40%, #fff 50%, var(--brick-light) 60%, var(--brick-light) 100%);
  background-size:250% 100%;background-position:100% 0;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  transition:background-position 1.6s cubic-bezier(.22,1,.36,1)}

/* ===== ROI (valeur / gain de temps) ===== */
/* Billboard sombre (accueil + sur-mesure) */
.roi-wrap{display:grid;grid-template-columns:1fr 1px 1.25fr;gap:50px;align-items:center}
.roi-figure{display:flex;flex-direction:column;gap:10px}
.roi-figure-num{font-family:var(--grot);font-weight:300;font-size:clamp(92px,13vw,176px);letter-spacing:-.05em;line-height:.78;color:var(--brick-light);display:flex;align-items:baseline;gap:8px;font-variant-numeric:tabular-nums}
.roi-figure-unit{font-size:.27em;font-weight:600;letter-spacing:-.01em;color:var(--bg)}
.roi-figure-cap{font-family:var(--grot);font-weight:600;font-size:19px;letter-spacing:-.01em;line-height:1.25;color:var(--bg);max-width:30ch}
.roi-figure-sub{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:rgba(236,228,216,.72)}
.roi-rule{align-self:stretch;background:rgba(236,228,216,.18)}
.roi-pitch{display:flex;flex-direction:column;gap:20px}
.roi-eyebrow{display:inline-flex;align-items:center;gap:9px;align-self:flex-start;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--brick-light);padding:8px 14px;border-radius:6px;font-weight:600}
.roi-eyebrow::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--ink);animation:blink 1.4s infinite}
.roi-pitch-lead{font-family:var(--grot);font-weight:300;font-size:clamp(26px,3.2vw,40px);letter-spacing:-.03em;line-height:1.06;color:var(--bg)}
.roi-pitch-lead em{font-style:normal;font-weight:800;color:var(--brick-light)}
.roi-promise{list-style:none;display:flex;flex-direction:column;gap:12px;margin:0;padding:0}
.roi-promise li{display:flex;gap:13px;align-items:flex-start;font-size:15.5px;line-height:1.45;color:var(--bg-2)}
.roi-promise li::before{content:"";flex-shrink:0;width:7px;height:7px;margin-top:7px;background:var(--brick-light);border-radius:50%}
.roi-promise li strong{color:var(--bg);font-weight:600;display:block;margin-bottom:2px}
.roi-cta-row{margin-top:6px}
.roi-band .btn-primary{background:var(--brick-light);color:var(--ink);border-color:var(--brick-light)}
.roi-band .btn-primary:hover{background:var(--bg);border-color:var(--bg)}

/* Tuiles ROI (sur-mesure, fond clair) */
.roi-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--rule);border-radius:12px;overflow:hidden;background:var(--bg)}
.roi-tile{padding:28px 24px;display:flex;flex-direction:column;gap:8px;border-right:1px solid rgba(58,37,32,.14)}
.roi-tile:last-child{border-right:none}
.roi-tile-k{font-family:var(--grot);font-weight:300;font-size:clamp(36px,4.4vw,52px);letter-spacing:-.04em;color:var(--brick);line-height:.85;font-variant-numeric:tabular-nums}
.roi-tile-k small{font-size:.42em;font-weight:600;letter-spacing:-.01em}
.roi-tile-v{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;line-height:1.5;color:var(--ink-soft)}
.roi-quote{margin-top:30px;max-width:780px;font-family:var(--grot);font-weight:400;font-size:clamp(19px,2.3vw,26px);line-height:1.32;letter-spacing:-.018em;color:var(--ink);text-wrap:pretty}
.roi-quote em{font-style:normal;font-weight:700;color:var(--brick)}
.roi-quote-attr{display:block;margin-top:14px;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft)}

/* Reframe coût (services / packs) */
.roi-vs{display:grid;grid-template-columns:1fr auto 1fr;gap:0;align-items:stretch;border:1px solid var(--rule);border-radius:14px;overflow:hidden;background:var(--bg)}
.roi-vs-col{padding:30px 30px 28px;display:flex;flex-direction:column;gap:10px}
.roi-vs-col-bad{background:var(--bg-2)}
.roi-vs-col-good{background:var(--ink);color:var(--bg-2)}
.roi-vs-k{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft)}
.roi-vs-col-good .roi-vs-k{color:var(--brick-light)}
.roi-vs-line{font-family:var(--grot);font-weight:600;font-size:clamp(19px,2vw,24px);letter-spacing:-.02em;line-height:1.15;color:var(--ink)}
.roi-vs-col-good .roi-vs-line{color:var(--bg)}
.roi-vs-sub{font-size:13.5px;line-height:1.5;color:var(--ink-soft)}
.roi-vs-col-good .roi-vs-sub{color:rgba(236,228,216,.72)}
.roi-vs-arrow{display:grid;place-items:center;padding:0 6px;font-family:var(--grot);font-weight:700;font-size:22px;color:var(--brick);background:var(--bg)}

@media(max-width:860px){
  .roi-wrap{grid-template-columns:1fr;gap:32px}
  .roi-rule{display:none}
  .roi-tiles{grid-template-columns:1fr 1fr}
  .roi-tile:nth-child(2){border-right:none}
  .roi-tile:nth-child(1),.roi-tile:nth-child(2){border-bottom:1px solid rgba(58,37,32,.14)}
  .roi-vs{grid-template-columns:1fr}
  .roi-vs-arrow{padding:10px;font-size:18px;background:var(--bg-2)}
}
@media(max-width:520px){
  .roi-tiles{grid-template-columns:1fr}
  .roi-tile{border-right:none;border-bottom:1px solid rgba(58,37,32,.14)}
}

.sm-limits{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:rgba(236,228,216,.14);border:1px solid rgba(236,228,216,.14);border-radius:12px;overflow:hidden}
.sm-limit{grid-column:span 2;background:var(--ink);padding:26px 24px;display:flex;flex-direction:column;gap:9px}
.sm-limit:nth-child(4),.sm-limit:nth-child(5){grid-column:span 3}
.sm-limit-mark{font-family:var(--grot);font-weight:700;font-size:15px;color:var(--brick-light);line-height:1}
.sm-limit-title{font-family:var(--grot);font-weight:700;font-size:16.5px;letter-spacing:-.01em;color:var(--bg)}
.sm-limit-desc{font-size:13px;line-height:1.55;color:rgba(236,228,216,.72)}

@media(max-width:900px){
  .sm-facts{grid-template-columns:1fr 1fr}
  .sm-fact:nth-child(2){border-right:none}
  .sm-fact:nth-child(1),.sm-fact:nth-child(2){border-bottom:1px solid rgba(58,37,32,.14)}
  .sm-limits{grid-template-columns:1fr 1fr}
  .sm-limit,.sm-limit:nth-child(4),.sm-limit:nth-child(5){grid-column:auto}
}
@media(max-width:680px){
  .sm-case-body{grid-template-columns:1fr}
  .sm-case-col{padding:22px 0}
  .sm-case-col-sys{padding-left:0;border-left:none;border-top:1px solid rgba(58,37,32,.14)}
  .sm-case-result{flex-direction:column;gap:6px}
}
@media(max-width:560px){
  .sm-facts{grid-template-columns:1fr}
  .sm-fact{border-right:none;border-bottom:1px solid rgba(58,37,32,.14)}
  .sm-limits{grid-template-columns:1fr}
  .sm-limit,.sm-limit:nth-child(4),.sm-limit:nth-child(5){grid-column:auto}
}
@media(max-width:560px){.svc-col-plans{grid-template-columns:1fr}}
/* Alignement des deux colonnes de packs (repères 01/02/03 alignés) */
@media(min-width:901px){
  .svc-col-desc{min-height:124px}
  .svc-col-for{min-height:33px}
  .svc-col-list-rich{min-height:338px}
}
.svc-col-desc{font-size:16px;line-height:1.55;color:var(--ink-soft);margin-bottom:24px;max-width:400px}
.svc-col-list{list-style:none;display:flex;flex-direction:column;gap:12px;margin-bottom:32px;flex:1}
.svc-col-list li{font-family:var(--grot);font-size:15px;line-height:1.4;display:flex;gap:10px;align-items:baseline}
.svc-col-check{color:var(--brick);font-weight:700;font-size:14px;flex-shrink:0}
.svc-col-for{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--brick);line-height:1.5;margin-bottom:24px;max-width:420px}
.svc-col-sec-k{display:block;font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--brick);margin:8px 0 16px;padding-top:22px;border-top:1px solid rgba(42,24,22,.18)}
.svc-col-list-rich li{align-items:flex-start}
.svc-col-list-rich .svc-col-check{margin-top:3px}
.svc-col-feat > div{display:flex;flex-direction:column;gap:3px}
.svc-col-feat strong{font-weight:600;font-size:15px;line-height:1.3;color:var(--ink)}
.svc-col-feat > div span{font-size:13px;line-height:1.45;color:var(--ink-soft)}
.svc-col-deliv{margin-bottom:24px}
.svc-col-deliv-k{display:block;font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--brick);margin:8px 0 16px;padding-top:22px;border-top:1px solid rgba(42,24,22,.18)}
.svc-col-deliv-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:13px}
.svc-col-deliv-list li{display:flex;flex-direction:column;gap:2px;padding-left:18px;position:relative}
.svc-col-deliv-list li::before{content:"";position:absolute;left:0;top:7px;width:7px;height:7px;border-radius:50%;background:var(--brick)}
.svc-col-deliv-list strong{font-weight:600;font-size:14px;line-height:1.3;color:var(--ink)}
.svc-col-deliv-list li > span{font-size:13px;line-height:1.45;color:var(--ink-soft)}

/* ===== Pack · points réglables ===== */
.svc-col-adapt{margin-bottom:26px}
.svc-col-adapt-k{display:block;font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--brick);font-weight:500;margin:8px 0 12px;padding-top:22px;border-top:1px solid rgba(42,24,22,.18)}
.svc-col-adapt-k::before{display:none}
.svc-col-adapt-txt{font-size:13px;line-height:1.5;color:var(--ink-soft);margin-bottom:12px}
.svc-col-adapt-tags{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:7px}
.svc-col-adapt-tags li{font-size:12px;line-height:1.3;color:var(--ink);background:var(--bg);border:1px solid var(--rule);border-radius:999px;padding:5px 12px}
@media (max-width:900px){
  .svc-packs-row{grid-template-columns:1fr}
  .svc-pack-col + .svc-pack-col{border-left:none;border-top:2px solid var(--ink)}
}

/* ===== Services pack (legacy single col) ===== */
.svc-pack{display:grid;grid-template-columns:5fr 7fr;gap:48px;align-items:start}
.svc-pack-meta h3{font-family:var(--grot);font-weight:500;font-size:clamp(32px,4vw,52px);line-height:1.05;letter-spacing:-.025em;margin-bottom:18px}
.svc-pack-price{font-family:var(--grot);font-weight:300;font-size:64px;letter-spacing:-.04em;line-height:.9;color:var(--brick);margin-bottom:6px}
.svc-pack-price span{font-family:var(--mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);font-weight:400}
.svc-pack-deal{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);margin-bottom:14px}
.svc-feats{list-style:none;display:flex;flex-direction:column;border-top:2px solid var(--ink)}
.svc-feats li{display:grid;grid-template-columns:60px 1fr;gap:20px;padding:20px 0;border-bottom:1px solid var(--ink);align-items:baseline}
.svc-feat-num{font-family:var(--mono);font-size:12px;letter-spacing:.16em;color:var(--brick);font-weight:500}
.svc-feat-title{font-family:var(--grot);font-weight:500;font-size:clamp(18px,2vw,24px);line-height:1.2;letter-spacing:-.015em;margin-bottom:6px}
.svc-feat-desc{font-size:14px;line-height:1.5;color:var(--soft)}

/* ===== Sur-mesure · cas déjà construits ===== */
.svc-sm-cases-head{max-width:640px;margin:76px 0 36px}
.svc-sm-cases-title{font-family:var(--grot);font-weight:500;font-size:clamp(26px,3.2vw,40px);line-height:1.08;letter-spacing:-.025em;margin:12px 0 14px}
.svc-sm-cases-title em{font-style:normal;color:var(--brick)}
.svc-sm-cases-lede{font-size:15px;line-height:1.6;color:var(--ink-soft);max-width:580px}
.svc-sm-cases{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:4px;overflow:hidden}
.svc-sm-case{background:var(--bg);padding:30px;display:flex;flex-direction:column;gap:16px;transition:background .3s}
.svc-sm-cases > .reveal{display:flex}
.svc-sm-cases > .reveal > .svc-sm-case{width:100%}
.svc-sm-case:hover{background:var(--bg-2)}
.svc-sm-case-sec{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);font-weight:500}
.svc-sm-case-line{display:flex;gap:12px;margin:0;font-size:14px;line-height:1.5}
.svc-sm-case-line > span:last-child{color:var(--soft)}
.svc-sm-case-line .svc-sm-case-sol-txt{color:var(--ink)}
.svc-sm-case-lbl{flex-shrink:0;width:50px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);padding-top:2px}
.svc-sm-case-lbl-sol{color:rgb(36,100,60)}
@media(max-width:760px){.svc-sm-cases{grid-template-columns:1fr}}

/* ===== About ===== */
.about-grid{display:grid;grid-template-columns:5fr 7fr;gap:48px;align-items:start}
.about-portrait{aspect-ratio:3/4;background:var(--brick-deep);position:relative;overflow:hidden;border:2px solid var(--ink)}
.about-portrait-stripes{position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0 14px,transparent 14px 28px)}
.about-portrait-label{position:absolute;left:0;right:0;bottom:0;padding:14px 18px;display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--bg-2);background:linear-gradient(transparent,rgba(0,0,0,.5))}
.about-text{font-size:17px;line-height:1.6;display:flex;flex-direction:column;gap:20px;color:var(--ink)}
.about-text strong{color:var(--brick);font-weight:600}

/* ===== Posts (blog) ===== */
.posts{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.post{
  display:flex;flex-direction:column;gap:14px;
  padding:32px;background:var(--bg);border:2px solid var(--ink);min-height:280px;
  transition:.3s;
}
.post:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 0 var(--brick);background:var(--bg-2)}
.post-meta{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);display:flex;gap:8px}
.post-title{font-family:var(--grot);font-weight:500;font-size:clamp(22px,2.4vw,30px);line-height:1.15;letter-spacing:-.02em}
.post-excerpt{font-size:14px;line-height:1.55;color:var(--soft);flex:1}
.post-cta{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--brick);margin-top:auto;display:inline-flex;gap:8px}

/* ===== Connect grid (services) ===== */
.connect-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;gap:12px}
.connect-card{padding:24px 20px;border:1px solid rgba(236,228,216,.15);background:rgba(236,228,216,.05);transition:all .3s cubic-bezier(.22,1,.36,1);display:flex;flex-direction:column;min-height:100px}
.connect-card:hover{background:rgba(236,228,216,.1);border-color:var(--brick-light);transform:translateY(-2px)}
.connect-card-title{font-family:var(--grot);font-weight:700;font-size:17px;letter-spacing:-.01em;color:var(--bg);margin-bottom:6px}
.connect-card-desc{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:rgba(236,228,216,.72);line-height:1.5}
@media (max-width:560px){.connect-grid{grid-template-columns:1fr}}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.cal-frame{border:2px solid var(--ink);background:var(--bg);padding:24px}
.cal-mock-head{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);border-bottom:1px solid var(--ink);padding-bottom:12px;margin-bottom:18px}
.cal-mock-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:18px}
.cal-mock-day{
  aspect-ratio:1;display:grid;place-items:center;font-family:var(--mono);font-size:13px;
  border:1px solid var(--ink);cursor:pointer;transition:.2s;
}
.cal-mock-day:hover{background:var(--bg-2)}
.cal-mock-day.is-sel{background:var(--brick);color:var(--bg);border-color:var(--brick)}
.cal-mock-day.is-off{opacity:.3;cursor:not-allowed}
.cal-mock-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.cal-mock-slot{padding:10px;text-align:center;font-family:var(--mono);font-size:12px;border:1px solid var(--ink);cursor:pointer;transition:.2s}
.cal-mock-slot:hover{background:var(--brick);color:var(--bg);border-color:var(--brick)}
.cal-mock-slot.is-sel{background:var(--brick);color:var(--bg);border-color:var(--brick)}
.cal-slots-label{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);margin:18px 0 8px}
.cal-confirm{padding:14px 18px;font-family:var(--grot);font-size:14px;color:var(--brick);border-top:1px solid var(--ink);margin-top:12px}
.cal-confirm strong{font-weight:600;color:var(--ink)}
.cal-soon{margin-top:18px;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--soft);text-align:center}

/* Step-based contact flow */
.ct-progress{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:32px}
.ct-pip{width:36px;height:36px;border-radius:50%;border:2px solid var(--bg-2);background:var(--bg);display:flex;align-items:center;justify-content:center;font-family:var(--grot);font-weight:700;font-size:14px;color:var(--bg-2);transition:all .4s cubic-bezier(.22,1,.36,1);position:relative}
.ct-pip-done{border-color:var(--brick);background:var(--brick);color:var(--bg)}
.ct-pip-label{position:absolute;top:calc(100% + 6px);font-family:var(--mono);font-size:9px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;white-space:nowrap;color:var(--soft);transition:color .4s}
.ct-pip-done .ct-pip-label{color:var(--brick)}
.ct-pipe{width:60px;height:2px;background:var(--bg-2);transition:background .4s cubic-bezier(.22,1,.36,1)}
.ct-pipe-done{background:var(--brick)}

.ct-stage{position:relative;overflow:hidden}
.ct-panel{position:absolute;inset:0;opacity:0;transform:translateX(40px);transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1);pointer-events:none}
.ct-panel-on{position:relative;opacity:1;transform:translateX(0);pointer-events:auto}
.ct-panel-left{transform:translateX(-40px)}
.ct-panel-right{transform:translateX(40px)}

.ct-slots-title{font-family:var(--grot);font-weight:600;font-size:20px;letter-spacing:-.02em;padding:24px 24px 16px;color:var(--ink)}
.ct-slots-grid{display:flex;flex-direction:column;gap:8px;padding:0 24px 24px}
.ct-slot{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border:2px solid var(--ink);background:var(--bg);cursor:pointer;transition:all .25s cubic-bezier(.22,1,.36,1);animation:ct-slot-in .4s cubic-bezier(.22,1,.36,1) both}
@keyframes ct-slot-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.ct-slot:hover{background:var(--bg-2);transform:translateX(4px)}
.ct-slot-sel{background:var(--brick);border-color:var(--brick);color:var(--bg);transform:scale(1.02)}
.ct-slot-sel:hover{background:var(--brick-deep);transform:scale(1.02)}
.ct-slot-time{font-family:var(--grot);font-weight:700;font-size:18px;letter-spacing:-.02em}
.ct-slot-dur{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;opacity:.7}

.contact-info h3{font-family:var(--grot);font-weight:500;font-size:clamp(28px,3vw,42px);line-height:1.05;letter-spacing:-.02em;margin-bottom:16px}
.contact-info p{font-size:16px;line-height:1.55;color:var(--soft);margin-bottom:24px;max-width:480px}
.contact-intro{font-size:15px;line-height:1.6;color:var(--ink-soft);max-width:560px;margin-top:14px}
.contact-rows{display:flex;flex-direction:column;border-top:2px solid var(--ink)}
.contact-row{display:grid;grid-template-columns:140px 1fr;gap:14px;padding:16px 0;border-bottom:1px solid var(--ink);align-items:baseline}
.contact-row-lbl{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);font-weight:500}
.contact-row-val{font-family:var(--grot);font-size:15px}
.contact-row-val a{border-bottom:1px solid var(--brick)}
.contact-row-val a:hover{color:var(--brick)}

/* ===== Contact form ===== */
.contact-form-frame{border:2px solid var(--ink);background:var(--bg);overflow:hidden}
.contact-form-head{padding:14px 24px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);border-bottom:1px solid var(--ink)}
.contact-form{padding:28px 24px;display:flex;flex-direction:column;gap:20px}
.cf-row{display:flex;flex-direction:column;gap:6px}
.cf-label{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);font-weight:500}
.cf-input,.cf-textarea{font-family:var(--grot);font-size:15px;padding:12px 14px;border:2px solid var(--ink);background:var(--bg);color:var(--ink);transition:border-color .25s}
.cf-input:focus,.cf-textarea:focus{outline:none;border-color:var(--brick)}
.cf-textarea{resize:vertical;min-height:100px}
.cf-radios{display:flex;gap:20px;flex-wrap:wrap}
.cf-radio{font-family:var(--grot);font-size:14px;display:flex;align-items:center;gap:8px;cursor:pointer}
.cf-radio input{accent-color:var(--brick);width:16px;height:16px}
.cf-note{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin-top:4px}
.cf-change-btn{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);background:none;border:1px solid var(--brick);padding:4px 10px;cursor:pointer;transition:background .25s,color .25s}
.cf-change-btn:hover{background:var(--brick);color:var(--bg)}

/* ===== Conversational form ===== */
.cv-frame{border:2px solid var(--ink);background:var(--bg);overflow:hidden}
.cv-head{padding:14px 24px;border-bottom:1px solid var(--ink);display:flex;justify-content:space-between;align-items:center;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick)}
.cv-head-right{display:flex;align-items:center;gap:12px}
.cv-head-slot{font-weight:400;opacity:.7;color:var(--ink)}
.cv-dots{display:flex;gap:6px;justify-content:center;padding:20px 24px 0}
.cv-dot{width:8px;height:8px;border-radius:50%;background:var(--bg-2);transition:all .35s cubic-bezier(.22,1,.36,1)}
.cv-dot-on{background:var(--brick)}
.cv-dot-cur{transform:scale(1.3)}
.cv-body{padding:32px 32px 24px;position:relative;min-height:220px}
.cv-question{transition:opacity .4s cubic-bezier(.22,1,.36,1),transform .4s cubic-bezier(.22,1,.36,1);will-change:opacity,transform}
.cv-q-active{opacity:1;transform:none;position:relative;z-index:2}
.cv-q-done{opacity:0;transform:translateX(-30px);position:absolute;inset:32px;pointer-events:none;z-index:1}
.cv-q-next{opacity:0;transform:translateX(30px);position:absolute;inset:32px;pointer-events:none;z-index:1}
.cv-q-label{font-family:var(--grot);font-weight:700;font-size:clamp(22px,3vw,28px);letter-spacing:-.02em;line-height:1.1;margin-bottom:8px}
.cv-q-sub{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);margin-bottom:20px}
.cv-input{width:100%;padding:14px 0;border:none;border-bottom:2px solid var(--ink);background:transparent;font-family:var(--grot);font-size:20px;font-weight:300;color:var(--ink);outline:none;letter-spacing:-.01em;transition:border-color .3s}
.cv-input:focus{border-bottom-color:var(--brick)}
.cv-textarea{min-height:100px;resize:vertical}
.cv-modes{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
@media(max-width:520px){.cv-modes{grid-template-columns:1fr}}
.cv-mode{padding:20px 16px;border:2px solid var(--ink);background:transparent;cursor:pointer;display:flex;flex-direction:column;gap:4px;text-align:left;transition:all .25s cubic-bezier(.22,1,.36,1)}
.cv-mode:hover{background:var(--bg-2)}
.cv-mode-on{border-color:var(--brick);background:rgba(122,46,35,.08)}
.cv-mode-icon{display:flex;align-items:center;justify-content:center;color:var(--brick);margin-bottom:4px}
.cv-mode-on .cv-mode-icon{color:var(--brick-deep)}
.cv-mode-title{font-family:var(--grot);font-weight:600;font-size:16px;color:var(--ink)}
.cv-mode-sub{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft)}
.cv-submit{width:100%;padding:18px;background:var(--brick);color:var(--bg);border:2px solid var(--brick);font-family:var(--grot);font-weight:600;font-size:16px;cursor:pointer;transition:all .25s;letter-spacing:-.01em;display:flex;align-items:center;justify-content:center}
.cv-submit:hover{background:var(--brick-deep);border-color:var(--brick-deep)}
.cv-note{font-family:var(--mono);font-size:10px;letter-spacing:'.1em';text-transform:uppercase;color:var(--soft);text-align:center;margin-top:12px}
.cv-consent{font-family:var(--grot);font-size:11.5px;line-height:1.5;color:var(--ink-mute);text-align:center;margin-top:10px;max-width:440px;margin-left:auto;margin-right:auto}
.cv-consent a{color:var(--brick);text-decoration:underline;text-underline-offset:2px}
.cv-footer{padding:16px 32px;border-top:1px solid var(--bg-2);display:flex;justify-content:space-between;align-items:center}
.cv-back{background:none;border:none;font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--soft);cursor:pointer;transition:color .25s}
.cv-back:hover{color:var(--ink)}
.cv-next{padding:14px 24px;background:var(--ink);color:var(--bg);border:2px solid var(--ink);font-family:var(--grot);font-weight:600;font-size:15px;cursor:pointer;transition:all .25s;margin-left:auto}
.cv-next:hover{background:var(--brick);border-color:var(--brick)}
.cv-next-dim{opacity:.35;pointer-events:none}
@keyframes cvFadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ===== Bandeau cookies (carte d'angle) ===== */
.ckb{position:fixed;left:26px;bottom:26px;z-index:1000;width:372px;max-width:calc(100vw - 36px);background:var(--bg);border:2px solid var(--ink);padding:24px 24px 22px;box-shadow:7px 7px 0 var(--brick);animation:ckbIn .4s cubic-bezier(.22,1,.36,1)}
@keyframes ckbIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.ckb-stamp{width:30px;height:30px;background:var(--brick);border-radius:3px;margin-bottom:14px;display:flex;align-items:center;justify-content:center}
.ckb-k{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--brick);font-weight:500;margin-bottom:8px}
.ckb-title{font-family:var(--grot);font-weight:700;font-size:19px;line-height:1.1;letter-spacing:-.02em;color:var(--ink);margin-bottom:9px}
.ckb-txt{font-size:13.5px;line-height:1.55;color:var(--ink-soft);margin:0}
.ckb-txt a{color:var(--brick);text-decoration:underline;text-underline-offset:2px}
.ckb-cats{margin-top:14px}
.ckb-cat{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:12px 0;border-top:1px solid rgba(58,37,32,.16)}
.ckb-cat-h{font-family:var(--grot);font-weight:600;font-size:14px;color:var(--ink)}
.ckb-cat-d{font-size:12px;line-height:1.45;color:var(--ink-mute);margin-top:2px}
.ckb-sw{position:relative;width:46px;height:26px;border-radius:14px;border:2px solid var(--ink);background:var(--bg-2);cursor:pointer;flex-shrink:0;transition:background .2s,border-color .2s;margin-top:2px}
.ckb-knob{position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--ink);transition:left .2s,background .2s}
.ckb-sw-on{background:var(--brick);border-color:var(--brick)}
.ckb-sw-on .ckb-knob{left:22px;background:var(--bg)}
.ckb-sw-locked{opacity:.5;cursor:not-allowed}
.ckb-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}
.ckb-btn{font-family:var(--grot);font-weight:600;font-size:14px;padding:12px 0;border:2px solid var(--ink);cursor:pointer;transition:transform .15s,background .2s,color .2s;background:transparent;color:var(--ink);text-align:center}
.ckb-btn:hover{transform:translateY(-1px)}
.ckb-btn-accept{background:var(--brick);border-color:var(--brick);color:var(--bg)}
.ckb-btn-accept:hover{background:var(--brick-deep);border-color:var(--brick-deep)}
.ckb-foot{text-align:center;margin-top:12px}
.ckb-link{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:3px;padding:6px 2px}
.ckb-link:hover{color:var(--brick)}
@media(max-width:560px){
  .ckb{left:14px;right:14px;bottom:14px;width:auto;box-shadow:5px 5px 0 var(--brick)}
}

/* Confirmation · Cinematic C style */
.cv-confirmed-c{position:relative;overflow:hidden;border:2px solid var(--ink);min-height:380px;background:var(--brick)}
.cv-c-wipe{position:absolute;inset:0;background:var(--brick);transform-origin:bottom;animation:cvCWipe .55s cubic-bezier(.7,0,.3,1) forwards;z-index:1}
@keyframes cvCWipe{from{transform:scaleY(0)}to{transform:scaleY(1)}}
.cv-c-content{position:relative;z-index:2;padding:48px 32px 40px;display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--bg)}
.cv-c-check{margin-bottom:24px;animation:cvCPop .6s cubic-bezier(.34,1.56,.64,1) .3s both}
@keyframes cvCPop{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
.cv-c-tick{animation:cvCTick .5s ease .6s forwards}
@keyframes cvCTick{to{stroke-dashoffset:0}}
.cv-c-hero{font-family:var(--grot);font-weight:800;font-size:clamp(26px,4vw,38px);letter-spacing:-.03em;line-height:1.05;margin-bottom:12px;white-space:nowrap}
.cv-c-meta{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(236,228,216,.72);display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px}
.cv-c-metadot{width:4px;height:4px;border-radius:50%;background:var(--brick-light)}
.cv-c-name{font-family:var(--grot);font-weight:300;font-size:22px;letter-spacing:-.01em;color:var(--bg);margin-bottom:24px}
.cv-c-infocard{width:100%;background:var(--bg);color:var(--ink);border:2px solid var(--ink);overflow:hidden;margin-bottom:20px}
.cv-c-irow{display:flex;justify-content:space-between;padding:13px 20px;border-bottom:1px solid rgba(42,24,22,.1);opacity:0;transform:translateX(-10px);animation:cvCSlide .35s cubic-bezier(.22,1,.36,1) forwards}
.cv-c-irow-1{animation-delay:.8s}
.cv-c-irow-2{animation-delay:.9s}
.cv-c-irow-3{animation-delay:1s}
.cv-c-irow-4{animation-delay:1.1s}
.cv-c-irow-5{animation-delay:1.2s}
@keyframes cvCSlide{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}
.cv-c-irow:last-child{border-bottom:none}
.cv-c-ik{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--brick);font-weight:500}
.cv-c-iv{font-family:var(--grot);font-size:14px;font-weight:500;color:var(--ink)}
.cv-c-foot{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:rgba(236,228,216,.72)}

/* Stagger classes */
.cv-c-stagger-1{opacity:0;animation:cvCUp .5s cubic-bezier(.22,1,.36,1) .45s forwards}
.cv-c-stagger-2{opacity:0;animation:cvCUp .5s cubic-bezier(.22,1,.36,1) .6s forwards}
.cv-c-stagger-3{opacity:0;animation:cvCUp .5s cubic-bezier(.22,1,.36,1) .75s forwards}
.cv-c-stagger-4{opacity:0;animation:cvCUp .4s ease .9s forwards}
@keyframes cvCUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ===== Legal ===== */
.legal-content{max-width:820px;margin:0 auto;padding:60px 20px 100px;font-size:15px;line-height:1.65}
.legal-content h2{font-family:var(--grot);font-weight:600;font-size:24px;letter-spacing:-.02em;margin:32px 0 12px;color:var(--brick)}
.legal-content p{margin-bottom:14px}
.legal-content ul{margin:0 0 14px 24px}
.legal-content a{color:var(--brick);border-bottom:1px solid var(--brick)}
.legal-toc{background:var(--bg-2);padding:24px;margin:24px 0;border:2px solid var(--ink)}
.legal-toc h4,.legal-toc .legal-toc-t{font-family:var(--grot);font-weight:600;margin-bottom:8px}
.legal-toc ol{margin-left:24px}

/* ===== Responsive ===== */
@media (max-width:900px){
  .mj-inner{grid-template-columns:1fr;gap:16px}
  .mj-big-num{font-size:80px}
  .mj-section{padding:60px 20px}
  .mj-bilan-grid{grid-template-columns:repeat(2,1fr)}
  .mj-counter{display:none}
  .nav{grid-template-columns:auto auto;padding:10px 16px}
  .nav-links{display:none}
  .hero{height:auto;min-height:0;padding:90px 20px 60px}
  .hero-inner{grid-template-columns:1fr;gap:24px}
  .page-banner .container{flex-direction:column;gap:0}
  .stats-inner{grid-template-columns:repeat(3,1fr)}
  .pain{grid-template-columns:40px 1fr;gap:0 16px;grid-row:auto;text-align:left;justify-items:start}
  .pain-num{align-self:start;padding-top:6px}
  .pain-hint{display:none}
  .cards{grid-template-columns:1fr}
  .card,.card:nth-child(2),.card:nth-child(3){grid-column:1 / -1}
  .steps{font-size:12px}
  .step{grid-template-columns:60px 1fr;gap:0}
  .step-when{display:none}
  .svc-pack,.about-grid,.contact-grid{grid-template-columns:1fr;gap:32px}
  .tl-step{grid-template-columns:1fr;gap:14px}
  .posts{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr;gap:32px}
  .foot-cols{grid-template-columns:repeat(2,1fr);gap:24px}
  .cal-mock-slots{grid-template-columns:repeat(2,1fr)}
}
