/* ─── Reset ─── */
*,*::before,*::after{box-sizing:border-box}
[hidden]{display:none !important}
html,body,h1,h2,h3,h4,p,ul,ol,figure,blockquote,fieldset{margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}
body{min-height:100vh;font-family:var(--sans);font-size:16px;line-height:1.6;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;font-family:inherit}
ul{list-style:none}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}

/* ─── Tokens — direction C : clean tech minimal ─── */
:root{
  --bg:#ffffff;
  --bg-soft:#fafafa;
  --bg-mute:#f4f4f5;
  --ink:#0a0a0a;
  --ink-2:#18181b;
  --ink-3:#52525b;
  --ink-4:#a1a1aa;
  --line:#e4e4e7;
  --line-2:#d4d4d8;
  --accent:#0d4f4d;
  --accent-2:#0a3a39;
  --accent-3:#5fb8b5;
  --accent-soft:#ecf3f3;
  --accent-fade:#f5f9f9;
  --warn:#d97757;
  --gold:#b88f5d;
  --sans:'Inter','Helvetica Neue',system-ui,sans-serif;
  --display:'Inter Tight','Inter',system-ui,sans-serif;
  --mono:'SF Mono','Menlo',ui-monospace,monospace;
  --max:1200px;
  --gutter:clamp(20px,4vw,56px);
  --pad:22px;
  --rad-sm:6px;
  --rad-md:10px;
  --rad-lg:16px;
  --rad-xl:22px;
}

/* ─── Typo ─── */
h1,h2,h3,h4{font-family:var(--display);font-weight:600;line-height:1.04;letter-spacing:-.025em;color:var(--ink)}
.eyebrow{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:8px}
.eyebrow::before{content:"";display:inline-block;width:18px;height:1px;background:currentColor}
strong,b{font-weight:600}
em,i{font-style:normal;color:var(--accent);font-weight:600}

/* ─── Layout ─── */
.ctn{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
section{padding:88px var(--gutter)}
.section__top{max-width:740px;margin:0 0 48px}
.section__title{font-size:clamp(34px,4.6vw,56px);line-height:1.04;letter-spacing:-.028em;font-weight:600;color:var(--ink);margin:18px 0 18px}
.section__sub{font-size:18px;line-height:1.55;color:var(--ink-3);max-width:640px}

/* ─── Buttons ─── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 22px;font-size:15px;font-weight:600;border-radius:var(--rad-md);transition:transform .2s,box-shadow .2s,background .2s,border-color .2s,color .2s;cursor:pointer;border:1.5px solid transparent;font-family:var(--sans);letter-spacing:-.005em}
.btn--primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn--primary:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-1px);box-shadow:0 12px 28px -8px rgba(13,79,77,.45)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink);background:var(--bg-mute)}
.btn--lg{padding:17px 28px;font-size:16px}

/* ─── Partner ribbon ─── */
.ribbon{background:var(--ink);color:#fff;padding:10px var(--gutter);font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;letter-spacing:-.005em}
.ribbon__sep{width:4px;height:4px;border-radius:50%;background:rgba(255,255,255,.4)}
.ribbon strong{color:#fff;font-weight:700}
.ribbon__partner{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.85)}
.ribbon__partner svg{height:15px;width:auto}

/* ─── Nav ─── */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(14px);-webkit-backdrop-filter:saturate(180%) blur(14px);border-bottom:1px solid var(--line);padding:14px var(--gutter);display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav__brand{display:inline-flex;align-items:baseline;font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:-.03em;color:var(--ink)}
.nav__brand-dot{color:var(--accent);font-weight:700}
.nav__menu{display:flex;gap:32px;font-size:14.5px;font-weight:500;color:var(--ink-3)}
.nav__menu a:hover{color:var(--ink)}
.nav__cta{padding:11px 18px;font-size:14px}
@media(max-width:780px){.nav__menu{display:none}}

/* ─── Hero ─── */
.hero{padding:80px var(--gutter) 72px;position:relative;overflow:hidden}
.hero__inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.hero__pill{display:inline-flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;background:var(--accent-soft);border:1px solid #d6e6e5;color:var(--accent-2);font-size:13px;font-weight:600;border-radius:999px;letter-spacing:-.005em;margin-bottom:24px}
.hero__pill-tag{background:var(--accent);color:#fff;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.hero__title{font-size:clamp(40px,5.4vw,68px);font-weight:600;line-height:1.02;letter-spacing:-.032em;color:var(--ink);margin:0 0 22px}
.hero__title em{color:var(--ink);font-weight:600;background:linear-gradient(transparent 70%,rgba(13,79,77,.18) 70%);padding:0 4px}
.hero__sub{font-size:18.5px;line-height:1.55;color:var(--ink-3);margin:0 0 32px;max-width:540px}
.hero__cta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.hero__cta-link{color:var(--ink);font-weight:500;font-size:14.5px;display:inline-flex;align-items:center;gap:8px;padding:8px 4px}
.hero__cta-link::after{content:"→";transition:transform .25s}
.hero__cta-link:hover::after{transform:translateX(4px)}
.hero__trust{display:flex;flex-wrap:wrap;gap:8px 20px;font-size:13.5px;color:var(--ink-3);font-weight:500}
.hero__trust-item{display:inline-flex;align-items:center;gap:7px}
.hero__trust-item::before{content:"";display:inline-block;width:16px;height:16px;border-radius:50%;background:var(--accent-soft);border:1.5px solid var(--accent);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2.5 6.5l2.3 2.3L9.5 4' fill='none' stroke='%230d4f4d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:center}

.hero__stage{position:relative}
.hero__browser{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:0 30px 60px -20px rgba(0,0,0,.14),0 12px 24px -10px rgba(0,0,0,.08);transform:rotate(-1.2deg)}
.hero__browser-bar{display:flex;align-items:center;gap:6px;padding:10px 14px;background:#fff;border-bottom:1px solid var(--line)}
.hero__browser-dot{width:11px;height:11px;border-radius:50%;background:#e4e4e7}
.hero__browser-dot:nth-child(1){background:#fda4af}
.hero__browser-dot:nth-child(2){background:#fde68a}
.hero__browser-dot:nth-child(3){background:#bef264}
.hero__browser-url{flex:1;margin-left:14px;background:var(--bg-mute);border-radius:6px;padding:5px 12px;font-size:11.5px;color:var(--ink-3);font-weight:500;font-family:var(--mono);letter-spacing:-.01em}
.hero__browser-img{display:block;width:100%;height:auto}
.hero__phone{position:absolute;right:-12px;bottom:-32px;width:34%;border-radius:24px;overflow:hidden;border:8px solid #18181b;background:#18181b;box-shadow:0 20px 40px -10px rgba(0,0,0,.32);transform:rotate(4deg)}
.hero__phone img{display:block;width:100%;height:auto}
.hero__badge{position:absolute;top:-14px;left:-12px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 16px;font-size:13px;font-weight:600;color:var(--ink);box-shadow:0 12px 24px -10px rgba(0,0,0,.14);display:flex;align-items:center;gap:10px;line-height:1.3;z-index:2}
.hero__badge svg{width:20px;height:20px;color:var(--accent);flex-shrink:0}
.hero__badge strong{display:block;font-size:14px;font-weight:700;color:var(--ink);margin-bottom:1px}
.hero__badge small{display:block;font-size:11.5px;color:var(--ink-3);font-weight:500}

@media(max-width:880px){
  .hero__inner{grid-template-columns:1fr;gap:48px}
  .hero__phone{width:42%;right:-4px;bottom:-24px}
}

/* ─── Showroom ─── */
.showroom{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.showroom__head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;flex-wrap:wrap;margin-bottom:48px}
.showroom__cta{font-size:14.5px;font-weight:500;color:var(--ink);display:inline-flex;align-items:center;gap:8px;padding:10px 0}
.showroom__cta::after{content:"→";transition:transform .25s}
.showroom__cta:hover::after{transform:translateX(4px)}

.showroom__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:36px}
.showroom__grid > .showroom__card:nth-child(5){grid-column:1 / -1}
.showroom__grid > .showroom__card:nth-child(5) .showroom__visuals{padding:42px 56px 0}
.showroom__grid > .showroom__card:nth-child(5) .showroom__laptop{max-width:760px;margin:0 auto}
.showroom__card{background:linear-gradient(180deg,#fff 0%,#fafaf7 100%);border:1px solid var(--line);border-radius:22px;overflow:hidden;transition:transform .35s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease,border-color .25s ease;text-decoration:none;color:inherit;display:flex;flex-direction:column;isolation:isolate}
.showroom__card::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 60% at 50% 0%,rgba(20,79,72,.04),transparent 60%);pointer-events:none;z-index:-1;border-radius:inherit}
.showroom__card{position:relative}
.showroom__card:hover{transform:translateY(-6px);box-shadow:0 40px 70px -30px rgba(0,0,0,.22),0 8px 16px -8px rgba(0,0,0,.08);border-color:#d5cfb8}
.showroom__visuals{position:relative;padding:36px 44px 0;aspect-ratio:16/9;overflow:hidden}
/* Laptop frame minimaliste — bezel sombre, screen blanc, base discrète */
.showroom__laptop{position:relative;width:88%;margin:0 0 0 0;border-radius:14px 14px 8px 8px;background:#1c1c20;padding:14px 14px 0;box-shadow:0 30px 50px -25px rgba(0,0,0,.35),0 6px 14px -6px rgba(0,0,0,.18)}
.showroom__laptop-bar{display:flex;gap:5px;padding:0 0 10px}
.showroom__laptop-bar span{width:7px;height:7px;border-radius:50%;background:#3d3d42;display:block}
.showroom__laptop-bar span:nth-child(1){background:#ff5f57}
.showroom__laptop-bar span:nth-child(2){background:#febc2e}
.showroom__laptop-bar span:nth-child(3){background:#28c840}
.showroom__laptop-screen{aspect-ratio:1440/900;background:#f5f5f0;border-radius:4px;overflow:hidden}
.showroom__laptop-screen img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.showroom__laptop-base{height:0;position:relative;margin-top:0}
.showroom__laptop-base::after{content:"";position:absolute;left:50%;top:0;transform:translateX(-50%);width:108%;height:9px;background:linear-gradient(180deg,#2a2a2e 0%,#1a1a1d 100%);border-radius:0 0 14px 14px;box-shadow:inset 0 1px 0 rgba(255,255,255,.05),0 8px 12px -6px rgba(0,0,0,.2)}
/* Phone — flotte à droite, chevauche le laptop, dépasse en bas */
.showroom__phone{position:absolute;right:32px;bottom:-14%;width:21%;background:#1c1c20;border-radius:24px;padding:7px;box-shadow:0 24px 40px -18px rgba(0,0,0,.4),0 6px 14px -6px rgba(0,0,0,.18)}
.showroom__phone-notch{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:34%;height:14px;background:#000;border-radius:0 0 8px 8px;z-index:2}
.showroom__phone-screen{aspect-ratio:390/844;background:#000;border-radius:18px;overflow:hidden}
.showroom__phone-screen img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.showroom__meta{padding:34px 32px 32px;border-top:1px solid var(--line);margin-top:auto;background:#fff;position:relative}
.showroom__meta-top{display:flex;align-items:baseline;justify-content:space-between;gap:16px}
.showroom__name{font-family:var(--display);font-size:22px;font-weight:600;letter-spacing:-.018em;margin:0;color:var(--ink)}
.showroom__visit{font-size:13px;font-weight:500;color:var(--ink-3);transition:color .2s,transform .2s;flex-shrink:0;white-space:nowrap}
.showroom__card:hover .showroom__visit{color:var(--accent);transform:translateX(2px)}
.showroom__job{font-size:13.5px;color:var(--ink-3);font-weight:500;margin:5px 0 0}
.showroom__tags{margin-top:14px;display:flex;gap:6px;flex-wrap:wrap}
.showroom__tag{font-size:11.5px;font-weight:600;color:var(--accent-2);background:var(--accent-soft);border:1px solid #dbeae9;padding:3px 10px;border-radius:999px;letter-spacing:.01em}
@media(max-width:1100px){
  .showroom__grid{grid-template-columns:1fr;gap:32px}
  .showroom__grid > .showroom__card:nth-child(5){grid-column:auto}
  .showroom__grid > .showroom__card:nth-child(5) .showroom__visuals{padding:36px 44px 0}
  .showroom__grid > .showroom__card:nth-child(5) .showroom__laptop{max-width:none}
}
@media(max-width:680px){
  .showroom__visuals{padding:28px 24px 0;aspect-ratio:auto}
  .showroom__laptop{width:100%}
  .showroom__phone{position:relative;right:auto;bottom:auto;width:42%;margin:18px auto -8% auto;display:block}
  .showroom__meta{padding:28px 24px 24px}
  .showroom__name{font-size:19px}
  .showroom__meta-top{flex-wrap:wrap}
}

/* ─── Steps ─── */
.steps__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;counter-reset:s}
.step{padding:36px 30px;background:#fff;border:1px solid var(--line);border-radius:var(--rad-lg);position:relative;counter-increment:s;transition:border-color .2s,transform .2s}
.step:hover{border-color:var(--line-2);transform:translateY(-2px)}
.step::before{content:"0" counter(s);position:absolute;top:24px;right:28px;font-family:var(--display);font-weight:700;font-size:14px;color:var(--ink-4);letter-spacing:.05em}
.step__icon{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:22px}
.step__icon svg{width:22px;height:22px}
.step__title{font-family:var(--display);font-size:20px;font-weight:600;letter-spacing:-.02em;color:var(--ink);margin:0 0 8px}
.step__body{font-size:15px;line-height:1.55;color:var(--ink-3);margin:0}
@media(max-width:780px){.steps__grid{grid-template-columns:1fr}}

/* ─── Benefits ─── */
.benefits{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.benefits__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--rad-lg);overflow:hidden}
.benefit{background:#fff;padding:32px 28px}
.benefit__icon{color:var(--accent);width:24px;height:24px;margin-bottom:18px}
.benefit__title{font-family:var(--display);font-size:17px;font-weight:600;letter-spacing:-.015em;margin:0 0 6px;color:var(--ink)}
.benefit__body{font-size:14.5px;line-height:1.55;color:var(--ink-3);margin:0}
@media(max-width:780px){.benefits__grid{grid-template-columns:1fr}}

/* ─── Compare (Resalib / Médoucine) ─── */
.compare__inner{background:var(--ink);color:#fff;border-radius:var(--rad-xl);padding:64px var(--gutter);position:relative;overflow:hidden}
.compare__inner::before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(13,79,77,.55) 0%,transparent 70%);pointer-events:none}
.compare__title{font-family:var(--display);font-size:clamp(30px,3.6vw,46px);font-weight:600;letter-spacing:-.025em;line-height:1.08;color:#fff;margin:0 0 18px;max-width:780px;position:relative;z-index:1}
.compare__title em{color:var(--accent-3);font-weight:600;background:none}
.compare__sub{font-size:17px;line-height:1.55;color:#a1a1aa;max-width:640px;margin:0 0 36px;position:relative;z-index:1}
.compare__rows{display:grid;grid-template-columns:1fr 1fr;gap:40px;position:relative;z-index:1}
.compare__col h4{font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;color:#a1a1aa;margin:0 0 18px}
.compare__col ul{display:flex;flex-direction:column;gap:14px}
.compare__col li{display:flex;gap:12px;font-size:15px;color:#e4e4e7;line-height:1.55}
.compare__col li::before{content:"";flex-shrink:0;width:18px;height:18px;border-radius:50%;margin-top:2px}
.compare__col--bad li::before{background:rgba(217,119,87,.18);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M3 3l6 6M9 3l-6 6' fill='none' stroke='%23d97757' stroke-width='2' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:center}
.compare__col--good li::before{background:rgba(95,184,181,.18);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2.5 6.5l2.3 2.3L9.5 4' fill='none' stroke='%235fb8b5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:center}
@media(max-width:780px){.compare__rows{grid-template-columns:1fr;gap:32px}.compare__inner{padding:48px var(--pad)}}

/* ─── Testimonials ─── */
.testimonials{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.testi{background:#fff;border:1px solid var(--line);border-radius:var(--rad-lg);padding:28px 26px;display:flex;flex-direction:column;gap:18px;transition:border-color .2s,transform .2s}
.testi:hover{border-color:var(--line-2);transform:translateY(-2px)}
.testi__stars{display:flex;gap:2px;color:#f59e0b}
.testi__stars svg{width:14px;height:14px;fill:currentColor}
.testi__quote{font-family:var(--display);font-size:18px;font-weight:500;line-height:1.45;color:var(--ink);letter-spacing:-.012em;flex:1}
.testi__author{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--line)}
.testi__avatar{width:42px;height:42px;border-radius:50%;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;letter-spacing:-.01em;flex-shrink:0}
.testi__name{font-size:14px;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:2px}
.testi__job{font-size:12.5px;color:var(--ink-3);font-weight:500}
@media(max-width:980px){.testimonials__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.testimonials__grid{grid-template-columns:1fr}}

/* ─── Offers ─── */
.offers__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.offer{background:#fff;border:1px solid var(--line);border-radius:var(--rad-lg);padding:36px 30px 30px;display:flex;flex-direction:column;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s}
.offer:hover{transform:translateY(-3px);box-shadow:0 30px 60px -25px rgba(0,0,0,.12)}
.offer--featured{background:var(--ink);color:#fff;border-color:var(--ink)}
.offer__tag{position:absolute;top:-12px;left:30px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 10px;border-radius:6px}
.offer__name{font-family:var(--display);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin:0 0 4px}
.offer--featured .offer__name{color:#a1a1aa}
.offer__pitch{font-family:var(--display);font-size:18px;font-weight:600;letter-spacing:-.01em;color:var(--ink);margin:0 0 22px}
.offer--featured .offer__pitch{color:#fff}
.offer__price{display:flex;align-items:baseline;gap:6px;margin-bottom:6px}
.offer__price-amount{font-family:var(--display);font-size:46px;font-weight:700;letter-spacing:-.034em;color:var(--ink);line-height:1}
.offer--featured .offer__price-amount{color:#fff}
.offer__price-unit{font-size:14px;color:var(--ink-3);font-weight:500}
.offer--featured .offer__price-unit{color:#a1a1aa}
.offer__price-strike{font-size:14px;color:var(--ink-4);text-decoration:line-through;font-weight:500;margin-bottom:18px}
.offer--featured .offer__price-strike{color:#71717a}
.offer__setup{font-size:13px;color:var(--accent-2);background:var(--accent-soft);border-radius:6px;padding:8px 12px;font-weight:600;margin-bottom:22px;display:inline-block}
.offer--featured .offer__setup{background:rgba(13,79,77,.4);color:#a7e6e3}
.offer__features{display:flex;flex-direction:column;gap:11px;margin-bottom:28px;flex:1}
.offer__feature{font-size:14px;line-height:1.5;color:var(--ink-2);display:flex;gap:10px;align-items:flex-start}
.offer__feature::before{content:"";flex-shrink:0;width:16px;height:16px;margin-top:3px;border-radius:50%;background:var(--accent-soft);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2.5 6.5l2.3 2.3L9.5 4' fill='none' stroke='%230d4f4d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:center}
.offer--featured .offer__feature{color:#e4e4e7}
.offer--featured .offer__feature::before{background:rgba(95,184,181,.2);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2.5 6.5l2.3 2.3L9.5 4' fill='none' stroke='%235fb8b5' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>")}
.offer__cta{margin-top:auto}
.offer .btn--primary{width:100%}
.offer--featured .btn--primary{background:#fff;color:var(--ink);border-color:#fff}
.offer--featured .btn--primary:hover{background:var(--accent-3);border-color:var(--accent-3);color:var(--ink);box-shadow:0 12px 28px -8px rgba(95,184,181,.4)}
@media(max-width:980px){.offers__grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}}

/* ─── Audience ─── */
.audience__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.audience-card{padding:32px 28px 28px;background:#fff;border:1px solid var(--line);border-radius:var(--rad-lg);text-align:left;transition:border-color .25s,transform .25s,box-shadow .25s}
.audience-card:hover{border-color:#d5cfb8;transform:translateY(-3px);box-shadow:0 24px 48px -28px rgba(0,0,0,.18)}
.audience-card__photo{width:88px;height:88px;border-radius:50%;overflow:hidden;margin-bottom:22px;background:var(--bg-mute);position:relative;box-shadow:0 8px 24px -10px rgba(20,79,72,.18),0 2px 6px -2px rgba(0,0,0,.06)}
.audience-card__photo::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid rgba(255,255,255,.6);box-shadow:inset 0 0 0 4px rgba(255,255,255,.4);pointer-events:none}
.audience-card__photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.audience-card:hover .audience-card__photo img{transform:scale(1.06)}
.audience-card__title{font-family:var(--display);font-size:18px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin:0 0 8px}
.audience-card__body{font-size:13.5px;line-height:1.55;color:var(--ink-3);margin:0}
@media(max-width:980px){.audience__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.audience__grid{grid-template-columns:1fr}}

/* ─── FAQ ─── */
.faq__list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item details{padding:22px 0}
.faq__item summary{font-family:var(--display);font-size:17.5px;font-weight:600;letter-spacing:-.015em;color:var(--ink);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary::after{content:"";width:18px;height:18px;flex-shrink:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18'><path d='M9 4v10M4 9h10' fill='none' stroke='%230a0a0a' stroke-width='2' stroke-linecap='round'/></svg>");transition:transform .2s}
.faq__item details[open] summary::after{transform:rotate(45deg)}
.faq__answer{font-size:15.5px;line-height:1.6;color:var(--ink-3);margin:14px 0 0;max-width:780px}
.faq__answer strong{color:var(--ink)}
.faq__answer a{color:var(--accent);font-weight:600;border-bottom:1px solid currentColor}

/* ─── CTA final ─── */
.cta-final{background:var(--ink);color:#fff;padding:96px var(--gutter);text-align:center;position:relative;overflow:hidden}
.cta-final::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(13,79,77,.45) 0%,transparent 60%);pointer-events:none}
.cta-final__inner{max-width:780px;margin:0 auto;position:relative}
.cta-final__eyebrow{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-3);font-weight:600;margin-bottom:18px;display:block}
.cta-final__title{font-family:var(--display);font-size:clamp(32px,4.4vw,52px);font-weight:600;letter-spacing:-.028em;line-height:1.08;color:#fff;margin:0 0 18px}
.cta-final__title em{color:var(--accent-3);font-weight:600;background:none}
.cta-final__sub{font-size:17px;line-height:1.55;color:#a1a1aa;margin:0 0 32px}
.cta-final__btn{background:#fff;color:var(--ink);border-color:#fff}
.cta-final__btn:hover{background:var(--accent-3);border-color:var(--accent-3);color:var(--ink);box-shadow:0 12px 28px -8px rgba(95,184,181,.4);transform:translateY(-1px)}
.cta-final__rea{font-size:13px;color:#71717a;margin-top:18px}

/* ─── Footer ─── */
.footer{background:#fff;padding:48px var(--gutter) 32px;border-top:1px solid var(--line)}
.footer__grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:36px;padding-bottom:36px;border-bottom:1px solid var(--line)}
.footer__brand{font-family:var(--display);font-size:22px;font-weight:700;letter-spacing:-.025em;color:var(--ink);margin-bottom:8px}
.footer__brand em{color:var(--accent);font-weight:700;background:none}
.footer__tagline{font-size:13.5px;color:var(--ink-3);max-width:280px;line-height:1.55;margin:0 0 18px}
.footer__partner-block{display:flex;flex-direction:column;gap:8px;font-size:12px;color:var(--ink-3);font-weight:500;letter-spacing:.005em}
.footer__partner-block .footer__partner-logo{height:30px;width:auto;display:block}
.footer__col h4{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin:0 0 14px}
.footer__col ul{display:flex;flex-direction:column;gap:10px}
.footer__col a{font-size:14px;color:var(--ink-2);font-weight:500}
.footer__col a:hover{color:var(--accent)}
.footer__bottom{max-width:var(--max);margin:0 auto;padding-top:22px;display:flex;justify-content:space-between;font-size:12px;color:var(--ink-4);flex-wrap:wrap;gap:12px}
@media(max-width:780px){.footer__grid{grid-template-columns:1fr 1fr;gap:28px}}
@media(max-width:480px){.footer__grid{grid-template-columns:1fr}}

/* ─── Modal ─── */
.modal{position:fixed;inset:0;background:rgba(10,10,10,.5);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:none;align-items:center;justify-content:center;z-index:100;padding:24px}
.modal.is-open{display:flex}
.modal__panel{background:#fff;border-radius:var(--rad-lg);max-width:540px;width:100%;padding:36px 34px;max-height:92vh;overflow-y:auto;box-shadow:0 30px 80px -20px rgba(10,10,10,.4);position:relative;border:1px solid var(--line)}
.modal__close{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--ink-3);transition:background .2s,color .2s}
.modal__close:hover{background:var(--bg-mute);color:var(--ink)}
.modal__close svg{width:18px;height:18px}
.modal__title{font-family:var(--display);font-weight:600;font-size:24px;line-height:1.15;color:var(--ink);margin:0 0 6px;letter-spacing:-.02em}
.modal__title em{color:var(--accent);font-weight:600;background:none}
.modal__sub{font-size:14px;line-height:1.5;color:var(--ink-3);margin:0 0 20px}

/* ─── Booking widget ─── */
.booking{font-family:var(--sans)}
.booking__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding-right:40px}
.booking__step{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--accent)}
.booking__back{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--ink-3);cursor:pointer;font-size:13px;padding:4px 10px;border-radius:6px;transition:background .2s,color .2s}
.booking__back:hover{background:var(--bg-mute);color:var(--ink)}
.booking__back svg{width:13px;height:13px}
.booking__progress{display:flex;gap:6px;margin:14px 0 22px}
.booking__progress-step{flex:1;height:3px;border-radius:2px;background:var(--line);transition:background .25s}
.booking__progress-step--active{background:var(--accent)}
.booking__progress-step--done{background:var(--accent-3)}
.booking__body{position:relative}
.booking__month-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.booking__month{font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink);letter-spacing:-.015em}
.booking__month-btn{width:32px;height:32px;border:1px solid var(--line);border-radius:8px;color:var(--ink-3);display:flex;align-items:center;justify-content:center;background:#fff;transition:all .2s}
.booking__month-btn:hover{border-color:var(--accent);color:var(--accent)}
.booking__month-btn svg{width:14px;height:14px}
.booking__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}
.booking__wd{font-size:10.5px;font-weight:600;color:var(--ink-3);text-align:center;text-transform:uppercase;letter-spacing:.1em;padding:4px 0}
.booking__days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.booking__day{background:none;border:1px solid transparent;color:var(--ink);font-family:var(--sans);font-size:14px;font-weight:500;padding:9px 4px;border-radius:8px;cursor:pointer;text-align:center;transition:all .2s;position:relative}
.booking__day:hover:not(.booking__day--disabled):not(.booking__day--empty){border-color:var(--accent);background:var(--accent-fade)}
.booking__day--selected{background:var(--accent) !important;color:#fff !important;border-color:var(--accent) !important;font-weight:700}
.booking__day--today::after{content:'';position:absolute;bottom:3px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent)}
.booking__day--disabled{color:var(--ink-4);cursor:default}
.booking__day--empty{cursor:default}
.booking__day--weekend{color:var(--ink-4);cursor:default}
.booking__date-label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--ink);margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--line)}
.booking__date-label svg{width:16px;height:16px;color:var(--accent);flex-shrink:0}
.booking__slots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:6px}
.booking__slot{background:var(--bg-soft);border:1px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:14px;font-weight:500;padding:11px 8px;border-radius:8px;cursor:pointer;text-align:center;transition:all .2s}
.booking__slot:hover{border-color:var(--accent);background:var(--accent-fade);color:var(--accent)}
.booking__slot--selected{background:var(--accent) !important;color:#fff !important;border-color:var(--accent) !important;font-weight:700}
.booking__empty{color:var(--ink-3);font-size:14px;grid-column:1/-1;text-align:center;padding:20px 0;margin:0}
.booking__type-label-line{font-size:13px;color:var(--ink-3);margin:0 0 10px;font-weight:500}
.booking__type-choice{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.booking__type-btn{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--bg-soft);border:1.5px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:13.5px;font-weight:600;padding:14px 10px;border-radius:10px;cursor:pointer;text-align:center;transition:all .2s}
.booking__type-btn svg{width:22px;height:22px;color:var(--ink-3);transition:color .2s}
.booking__type-btn:hover{border-color:var(--accent)}
.booking__type-btn--selected{background:var(--accent-fade);border-color:var(--accent);color:var(--accent)}
.booking__type-btn--selected svg{color:var(--accent)}
.booking__type-tag{font-size:11px;font-weight:500;color:var(--ink-3);letter-spacing:.02em}
.booking__type-btn--selected .booking__type-tag{color:var(--accent-2)}
.booking__phone-row{max-height:0;overflow:hidden;transition:max-height .35s ease,margin-bottom .35s ease;margin-bottom:0}
.booking__phone-row.visible{max-height:80px;margin-bottom:12px}
.booking__form-group{margin-bottom:12px}
.booking__input{width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:14.5px;padding:12px 14px;border-radius:8px;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}
.booking__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-fade)}
.booking__input::placeholder{color:var(--ink-4)}
textarea.booking__input{resize:vertical;min-height:80px;font-family:var(--sans)}
select.booking__input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' fill='none' stroke='%2352525b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.booking__submit{width:100%;background:var(--ink);color:#fff;font-family:var(--sans);font-size:15px;font-weight:600;padding:15px;border:none;border-radius:10px;cursor:pointer;transition:all .25s;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:10px}
.booking__submit:hover{background:var(--accent);transform:translateY(-1px);box-shadow:0 12px 28px -10px rgba(13,79,77,.5)}
.booking__submit:disabled{opacity:.55;cursor:default;transform:none;box-shadow:none}
.booking__submit .spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:bk-spin .7s linear infinite;display:none}
@keyframes bk-spin{to{transform:rotate(360deg)}}
.booking__confirm{text-align:center;padding:32px 16px 12px}
.booking__check{width:64px;height:64px;border-radius:50%;background:var(--accent-fade);border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.booking__check svg{width:28px;height:28px;color:var(--accent)}
.booking__confirm h3{font-family:var(--display);font-size:22px;font-weight:600;color:var(--ink);margin:0 0 8px;letter-spacing:-.018em}
.booking__confirm > p{font-size:14.5px;color:var(--ink-3);line-height:1.55;margin:0 0 22px}
.booking__confirm-details{display:flex;flex-direction:column;gap:8px;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:14px 18px;text-align:left}
.booking__confirm-row{display:flex;justify-content:space-between;font-size:14px}
.booking__confirm-row span:first-child{color:var(--ink-3)}
.booking__confirm-row span:last-child{color:var(--ink);font-weight:600}

@media(max-width:560px){
  .booking__slots{grid-template-columns:repeat(2,1fr)}
  .booking__type-choice{grid-template-columns:1fr}
  .booking__day{font-size:13px;padding:8px 2px}
  .booking__month{font-size:16px}
  .modal__panel{padding:28px 22px}
}

/* ─── Reveal animations ─── */
html.js [data-animate]{opacity:0;transform:translateY(10px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
html.js [data-animate].in{opacity:1;transform:none}
[data-animate-delay="1"]{transition-delay:.06s}
[data-animate-delay="2"]{transition-delay:.12s}
[data-animate-delay="3"]{transition-delay:.18s}
[data-animate-delay="4"]{transition-delay:.24s}
@media(prefers-reduced-motion:reduce){[data-animate]{opacity:1;transform:none}}

/* ─── Mobile global ─── */
@media(max-width:780px){
  :root{--gutter:var(--pad)}
  body{font-size:15.5px}
  section{padding:64px var(--gutter)}
  .hero{padding:56px var(--gutter) 56px}
  .ribbon{padding:9px var(--pad);font-size:12.5px;gap:10px}
  .ribbon__sep{display:none}
  .footer{padding:40px var(--pad) 24px}
  .cta-final{padding:72px var(--pad)}
}

/* ─── Ribbon premium (refonte) ─── */
.ribbon{background:#0a0a0a;color:#fff}
.ribbon__exclusive{background:linear-gradient(135deg,#1A4FE3,#2A6BFF);color:#fff;padding:3px 8px;border-radius:4px;font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;margin-right:8px}
.ribbon__partner{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.92);font-weight:600}
.ribbon__cross{width:11px;height:11px;color:rgba(255,255,255,.55);margin:0 2px}
.ribbon__logo-img{height:18px;width:auto;filter:brightness(0) invert(1);opacity:.95}

/* ─── Hero amélioré ─── */
.hero__pill{background:linear-gradient(135deg,#eef3ff,#e0ecff);border-color:#c7d8ff;color:#1A4FE3}
.hero__pill-tag{background:linear-gradient(135deg,#1A4FE3,#2A6BFF);color:#fff;padding:4px 9px;border-radius:6px;font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.hero__pill-logo{height:20px;width:auto;display:inline-block;vertical-align:middle;margin-left:4px}

.hero__value{display:flex;flex-direction:column;gap:8px;margin:0 0 28px;padding:18px 20px;background:linear-gradient(135deg,#fafafa,#f4f4f5);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--rad-md);max-width:540px}
.hero__value-row{display:flex;align-items:center;gap:10px;font-size:14.5px;flex-wrap:wrap;line-height:1.4}
.hero__value-strike{color:var(--ink-3);text-decoration:line-through;font-weight:500}
.hero__value-arrow{color:var(--ink-4);font-weight:600}
.hero__value-now{color:var(--ink);font-weight:600}
.hero__value-now strong{color:var(--accent)}

.hero__badge--bottom{top:auto;bottom:-14px;left:auto;right:14%;background:#0a0a0a;color:#fff;border-color:#0a0a0a;z-index:3}
.hero__badge--bottom strong{color:#fff}
.hero__badge--bottom small{color:#a1a1aa}
.hero__badge--bottom svg{color:#f59e0b}

/* ─── Partner section (Stripe-style co-branding) ─── */
.partner{background:linear-gradient(180deg,#0a0a0a 0%,#0d4f4d 100%);color:#fff;padding:80px var(--gutter);position:relative;overflow:hidden}
.partner::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(26,79,227,.25) 0%,transparent 60%);pointer-events:none}
.partner__inner{max-width:var(--max);margin:0 auto;position:relative;display:grid;grid-template-columns:auto 1fr;gap:64px;align-items:center}
.partner__brands{display:flex;flex-direction:column;align-items:center;gap:12px;padding:36px 44px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px);border-radius:var(--rad-lg);min-width:280px}
.partner__brand-kalme{font-family:var(--display);font-weight:700;font-size:36px;color:#fff;letter-spacing:-.03em;line-height:1}
.partner__brand-kalme em{color:#5fb8b5;font-style:normal;font-weight:700}
.partner__cross{width:24px;height:24px;color:rgba(255,255,255,.45)}
.partner__logo{height:42px;width:auto;filter:brightness(0) invert(1)}
.partner__copy{}
.partner__tag{display:inline-block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#5fb8b5;font-weight:700;margin-bottom:14px;padding:6px 12px;background:rgba(95,184,181,.12);border:1px solid rgba(95,184,181,.32);border-radius:999px}
.partner__title{font-family:var(--display);font-size:clamp(28px,3.4vw,42px);font-weight:600;letter-spacing:-.025em;line-height:1.1;color:#fff;margin:0 0 18px}
.partner__title em{color:#5fb8b5;font-style:normal;font-weight:600;background:none}
.partner__sub{font-size:16.5px;line-height:1.55;color:#a1a1aa;margin:0 0 32px;max-width:680px}
.partner__sub strong{color:#fff;font-weight:600}
.partner__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.partner__stat{padding:18px 20px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--rad-md)}
.partner__stat-num{display:block;font-family:var(--display);font-size:30px;font-weight:700;letter-spacing:-.025em;color:#fff;line-height:1;margin-bottom:6px}
.partner__stat-label{display:block;font-size:12.5px;color:#a1a1aa;font-weight:500;line-height:1.35}
@media(max-width:980px){
  .partner{padding:64px var(--pad)}
  .partner__inner{grid-template-columns:1fr;gap:36px}
  .partner__brands{min-width:auto;padding:28px}
  .partner__stats{grid-template-columns:1fr}
}

/* ─── Showroom note ─── */
.showroom__note{margin:36px auto 0;max-width:640px;text-align:center;font-size:14px;color:var(--ink-3);line-height:1.55}

/* ─── Value section (12 bénéfices) ─── */
.value{}
.value__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.value-card{padding:30px 26px;background:#fff;border:1px solid var(--line);border-radius:var(--rad-lg);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}
.value-card:hover{transform:translateY(-3px);box-shadow:0 24px 48px -20px rgba(0,0,0,.1);border-color:var(--accent)}
.value-card__icon{width:44px;height:44px;border-radius:11px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.value-card__icon svg{width:22px;height:22px}
.value-card h3{font-family:var(--display);font-size:17px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin:0 0 8px;line-height:1.2}
.value-card p{font-size:14.5px;line-height:1.55;color:var(--ink-3);margin:0}
.value-card p strong{color:var(--ink);font-weight:600}
@media(max-width:980px){.value__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.value__grid{grid-template-columns:1fr}}

/* ─── Compare amélioré ─── */
.compare__eyebrow{display:inline-block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#5fb8b5;font-weight:700;margin-bottom:14px;padding:6px 12px;background:rgba(95,184,181,.12);border:1px solid rgba(95,184,181,.32);border-radius:999px;position:relative;z-index:1}

/* ─── Testimonials avec photos réelles ─── */
.testi{padding:26px 24px}
.testi__head{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.testi__photo{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--line);flex-shrink:0;background:var(--bg-mute)}
.testi__head .testi__stars{margin-top:4px}
.testi__quote{font-family:var(--display);font-size:16.5px;font-weight:500;line-height:1.5;color:var(--ink);letter-spacing:-.01em;margin:0;flex:1;border-top:1px solid var(--line);padding-top:16px}
.testi__author{display:none}
.testimonials__source{margin:36px auto 0;max-width:560px;text-align:center;font-size:13px;color:var(--ink-3)}
.testimonials__source a{color:var(--accent);font-weight:600;border-bottom:1px solid currentColor}

/* ─── Offers + guarantee ─── */
.offers__guarantee{display:flex;align-items:center;gap:18px;max-width:780px;margin:48px auto 0;padding:22px 28px;background:var(--accent-soft);border:1px solid #c8e0df;border-radius:var(--rad-md);font-size:14.5px;line-height:1.55;color:var(--ink-2)}
.offers__guarantee-icon{width:36px;height:36px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.offers__guarantee-icon svg{width:18px;height:18px}
.offers__guarantee strong{color:var(--ink);font-weight:700;display:block;margin-bottom:2px}
.offer__price-strike strong{color:var(--accent);font-weight:700}
.offer--featured .offer__price-strike strong{color:var(--accent-3)}
.offer__setup{display:inline-flex;align-items:center;gap:6px}
.offer__setup::before{content:"+";font-size:14px;font-weight:700;color:var(--accent)}
.offer--featured .offer__setup::before{color:var(--accent-3)}

/* ─── Footer partenariat ─── */
.footer__partner-block{display:flex;flex-direction:column;gap:6px}
.footer__partner-label{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--ink-3)}
.footer__partner-logo{height:32px;width:auto}

/* ─── Mobile adjustments ─── */
@media(max-width:780px){
  .hero__value{padding:14px 16px}
  .hero__value-row{font-size:13.5px}
  .partner__title{font-size:24px}
  .partner__sub{font-size:15px}
  .partner__stat-num{font-size:24px}
  .hero__badge--bottom{display:none}
}

/* ════════════════════════════════════════════════════════════════
   ─── REFONTE V2 : lockup co-branding, hero asymétrique, features dédiées
   ════════════════════════════════════════════════════════════════ */

:root{
  --allo-blue:#1A4FE3;
  --allo-blue-2:#2A6BFF;
  --allo-blue-soft:#eef3ff;
}

/* ─── Ribbon refondu : lockup propre + urgence live ─── */
.ribbon{padding:11px var(--gutter);gap:18px}
.ribbon__lockup{display:inline-flex;align-items:center;gap:10px}
.ribbon__brand-kalme{font-family:var(--display);font-weight:700;font-size:15.5px;letter-spacing:-.025em;color:#fff;line-height:1}
.ribbon__brand-kalme em{color:var(--accent-3);font-style:normal;font-weight:700}
.ribbon__cross-mark{font-family:var(--display);font-weight:300;font-size:18px;color:rgba(255,255,255,.4);line-height:1;margin:0 1px}
.ribbon__logo-img{height:20px;width:auto;filter:brightness(0) invert(1);opacity:.95}
.ribbon__live{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.95)}
.ribbon__dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.7);animation:pulse-dot 2s ease-out infinite}
@keyframes pulse-dot{0%{box-shadow:0 0 0 0 rgba(34,197,94,.6)}70%{box-shadow:0 0 0 10px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
@media(max-width:780px){
  .ribbon__cross-mark,.ribbon__brand-kalme{display:inline-block}
  .ribbon__logo-img{height:16px}
}

/* ─── Hero refondu : lockup propre + urgence + asymétrie subtile ─── */
.hero__lockup{display:inline-flex;align-items:center;gap:14px;padding:8px 16px 8px 14px;background:linear-gradient(135deg,#fff,#fafafa);border:1px solid var(--line);border-radius:999px;margin-bottom:28px;box-shadow:0 1px 0 rgba(0,0,0,.02)}
.hero__lockup-kalme{font-family:var(--display);font-weight:700;font-size:18px;letter-spacing:-.028em;color:var(--ink);line-height:1}
.hero__lockup-kalme em{color:var(--accent);font-style:normal;font-weight:700}
.hero__lockup-x{font-family:var(--display);font-weight:300;font-size:18px;color:var(--ink-4);line-height:1}
.hero__lockup-logo{height:24px;width:auto}

.hero__title-cursive{font-family:'Caveat','Brush Script MT',cursive;font-weight:700;font-style:italic;color:var(--accent);font-size:1.04em;letter-spacing:0;display:inline-block;transform:rotate(-2deg) translateY(2px);padding:0 4px}

.hero__live-mini{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink);padding:5px 10px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.3);border-radius:999px}
.hero__live-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:pulse-dot 2s ease-out infinite}

/* Browser mockup : casser la rigidité, plus de rotation */
.hero__browser{transform:rotate(-2deg) translateY(8px)}
.hero__phone{transform:rotate(5deg);bottom:-40px}
.hero__badge{transform:rotate(-3deg)}
.hero__badge--bottom{transform:rotate(2deg)}

/* ─── Partner v2 : Kalmé devant, narratif équilibré ─── */
.partner{background:linear-gradient(180deg,#0a0a0a 0%,#0d2625 100%);color:#fff;padding:96px var(--gutter);position:relative;overflow:hidden}
.partner::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 50% 40% at 50% 0%,rgba(95,184,181,.18) 0%,transparent 60%);pointer-events:none}
.partner__inner{max-width:var(--max);margin:0 auto;position:relative;text-align:center}
.partner__tag{display:inline-block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-3);font-weight:700;margin-bottom:18px;padding:6px 14px;background:rgba(95,184,181,.12);border:1px solid rgba(95,184,181,.32);border-radius:999px}
.partner__title{font-family:var(--display);font-size:clamp(32px,4.4vw,52px);font-weight:600;letter-spacing:-.028em;line-height:1.06;color:#fff;margin:0 0 56px;max-width:840px;margin-left:auto;margin-right:auto}
.partner__title em{color:var(--accent-3);font-style:normal;font-weight:600;background:none}
.partner__pair{display:grid;grid-template-columns:1fr auto 1fr;gap:32px;align-items:stretch;max-width:1000px;margin:0 auto;text-align:left}
.partner__brand{padding:36px 32px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--rad-lg);backdrop-filter:blur(10px)}
.partner__brand--kalme{border-color:rgba(95,184,181,.3);background:linear-gradient(180deg,rgba(95,184,181,.08),rgba(95,184,181,.02))}
.partner__brand--allo{border-color:rgba(42,107,255,.32);background:linear-gradient(180deg,rgba(42,107,255,.08),rgba(42,107,255,.02))}
.partner__brand-logo{margin-bottom:22px;display:flex;align-items:center;height:42px}
.partner__brand-name{font-family:var(--display);font-weight:700;font-size:32px;color:#fff;letter-spacing:-.03em;line-height:1}
.partner__brand-name em{color:var(--accent-3);font-style:normal;font-weight:700}
.partner__brand-img{height:34px;width:auto;filter:brightness(0) invert(1)}
.partner__brand-role{font-family:var(--display);font-size:20px;font-weight:600;color:#fff;letter-spacing:-.02em;line-height:1.15;margin:0 0 12px}
.partner__brand-body{font-size:14.5px;line-height:1.6;color:#a1a1aa;margin:0}
.partner__brand-body strong{color:#fff;font-weight:600}
.partner__plus{font-family:var(--display);font-size:48px;font-weight:300;color:rgba(255,255,255,.32);align-self:center;line-height:1}
.partner__verdict{margin:48px auto 0;max-width:780px;font-size:18px;line-height:1.55;color:#e4e4e7;text-align:center;padding:24px 32px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--rad-md)}
.partner__verdict strong{color:var(--accent-3);font-weight:700}
@media(max-width:880px){
  .partner__pair{grid-template-columns:1fr;gap:20px}
  .partner__plus{transform:rotate(90deg);justify-self:center}
  .partner{padding:64px var(--pad)}
}

/* ─── Features dédiées (style Visa) ─── */
.features-intro{padding:88px var(--gutter) 0}
.section__top--center{text-align:center;margin-left:auto;margin-right:auto}
.section__subtitle{font-family:var(--display);font-size:clamp(28px,3.4vw,40px);font-weight:600;letter-spacing:-.025em;line-height:1.06;color:var(--ink);margin:14px 0 0}
.feature{padding:64px var(--gutter)}
.feature--alt{background:var(--bg-soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.feature__row{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.05fr;gap:80px;align-items:center}
.feature__row--reverse{grid-template-columns:1.05fr 1fr}
.feature__row--reverse .feature__copy{order:2}
.feature__row--reverse .feature__visual{order:1}
.feature__num{font-family:var(--display);font-size:14px;font-weight:700;letter-spacing:.1em;color:var(--ink-4);margin-bottom:12px}
.feature__tag{display:inline-block;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--accent);background:var(--accent-soft);border:1px solid #d6e6e5;padding:5px 12px;border-radius:999px;margin-bottom:18px}
.feature__title{font-family:var(--display);font-size:clamp(28px,3.2vw,40px);font-weight:600;letter-spacing:-.025em;line-height:1.08;color:var(--ink);margin:0 0 18px}
.feature__title em{color:var(--ink);font-style:normal;font-weight:600;background:linear-gradient(transparent 70%,rgba(13,79,77,.18) 70%);padding:0 4px}
.feature__body{font-size:17px;line-height:1.55;color:var(--ink-3);margin:0 0 22px;max-width:560px}
.feature__body strong{color:var(--ink);font-weight:600}
.feature__list{display:flex;flex-direction:column;gap:10px;margin:0;padding:0}
.feature__list li{font-size:14.5px;line-height:1.5;color:var(--ink-2);padding-left:26px;position:relative}
.feature__list li::before{content:"";position:absolute;left:0;top:5px;width:16px;height:16px;border-radius:50%;background:var(--accent-soft);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2.5 6.5l2.3 2.3L9.5 4' fill='none' stroke='%230d4f4d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:center}
.feature__visual{position:relative}
@media(max-width:980px){
  .feature__row,.feature__row--reverse{grid-template-columns:1fr;gap:48px}
  .feature__row--reverse .feature__copy{order:1}
  .feature__row--reverse .feature__visual{order:2}
}

/* ─── Mockup : Google SERP ─── */
.mockup-google{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 26px;box-shadow:0 30px 60px -25px rgba(0,0,0,.14)}
.mockup-google__bar{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.mockup-google__logo{font-family:'Times','serif';font-size:24px;font-weight:400;letter-spacing:-.02em;background:linear-gradient(90deg,#4285F4,#34A853 25%,#FBBC04 50%,#EA4335 75%);-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:500;flex-shrink:0}
.mockup-google__input{flex:1;padding:9px 16px;background:#f1f3f4;border-radius:999px;font-size:14px;color:var(--ink-2)}
.mockup-google__caret{display:inline-block;width:1.5px;height:14px;background:var(--ink);margin-left:2px;animation:caret-blink 1s steps(2,end) infinite;vertical-align:middle}
@keyframes caret-blink{from,to{opacity:1}50%{opacity:0}}
.mockup-google__results{display:flex;gap:18px;padding:14px 0;border-bottom:1px solid var(--line);font-size:13px;color:var(--ink-3)}
.mockup-google__pill:first-child{color:var(--allo-blue);font-weight:600;border-bottom:2px solid var(--allo-blue);padding-bottom:14px;margin-bottom:-15px}
.mockup-google__result{padding:18px 0;border-bottom:1px solid var(--bg-mute)}
.mockup-google__result:last-child{border:0}
.mockup-google__result--featured{background:linear-gradient(90deg,#fafafa,transparent);border-left:3px solid var(--accent);padding-left:14px;border-radius:6px 0 0 6px;margin:18px -14px;padding-right:14px;border-bottom:0}
.mockup-google__result-url{font-size:12.5px;color:var(--ink-3);margin-bottom:4px}
.mockup-google__result-title{font-family:var(--display);font-size:18px;font-weight:600;color:var(--allo-blue);letter-spacing:-.01em;margin-bottom:4px;line-height:1.25}
.mockup-google__result-snippet{font-size:13.5px;color:var(--ink-3);line-height:1.5;margin-bottom:6px}
.mockup-google__result-meta{font-size:12.5px;color:#0c8a4f;font-weight:500}
.mockup-google__result--ghost{opacity:.55}

/* ─── Mockup : Booking calendar ─── */
.mockup-booking{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 24px;box-shadow:0 30px 60px -25px rgba(0,0,0,.14);max-width:380px;margin:0 auto}
.mockup-booking__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mockup-booking__step{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.mockup-booking__month{font-family:var(--display);font-size:16px;font-weight:600;color:var(--ink);margin-bottom:14px}
.mockup-booking__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;font-size:10.5px;font-weight:600;color:var(--ink-3);text-align:center;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.mockup-booking__days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:18px}
.mockup-booking__days .d{padding:8px 0;text-align:center;font-size:13px;font-weight:500;color:var(--ink);border-radius:8px;border:1px solid transparent}
.mockup-booking__days .d--off,.mockup-booking__days .d--past{color:var(--ink-4)}
.mockup-booking__days .d--sel{background:var(--accent);color:#fff;font-weight:700;border-color:var(--accent)}
.mockup-booking__slots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:18px}
.mockup-booking__slot{padding:10px 0;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;font-size:13px;font-weight:500;text-align:center;color:var(--ink)}
.mockup-booking__slot--sel{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700}
.mockup-booking__cta{padding:13px;background:var(--ink);color:#fff;font-size:13.5px;font-weight:600;text-align:center;border-radius:10px}

/* ─── Mockup : Avis Google ─── */
.mockup-reviews{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 26px;box-shadow:0 30px 60px -25px rgba(0,0,0,.14)}
.mockup-reviews__head{display:flex;align-items:center;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:18px}
.mockup-reviews__head svg{width:28px;height:28px;flex-shrink:0}
.mockup-reviews__brand{font-family:var(--display);font-size:15px;font-weight:600;color:var(--ink)}
.mockup-reviews__count{font-size:13px;color:var(--ink-3);font-weight:500;margin-top:2px}
.mockup-reviews__live{margin-left:auto;display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:rgba(34,197,94,.1);border-radius:999px;font-size:11px;font-weight:600;color:#0c8a4f}
.mockup-reviews__dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:pulse-dot 2s ease-out infinite}
.mockup-reviews__list{display:flex;flex-direction:column;gap:18px}
.mockup-reviews__item{display:flex;gap:12px}
.mockup-reviews__avatar{width:40px;height:40px;border-radius:50%;background:var(--allo-blue-soft);color:var(--allo-blue);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.mockup-reviews__name{font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:2px}
.mockup-reviews__date{font-weight:400;color:var(--ink-3);margin-left:8px}
.mockup-reviews__stars{font-size:13px;color:#f59e0b;margin-bottom:6px}
.mockup-reviews__text{font-size:13.5px;line-height:1.5;color:var(--ink-2);margin:0}

/* ─── Mockup : Backoffice praticienne ─── */
.mockup-admin{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:grid;grid-template-columns:200px 1fr;min-height:380px;box-shadow:0 30px 60px -25px rgba(0,0,0,.14)}
.mockup-admin__sidebar{background:var(--bg-soft);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:4px}
.mockup-admin__brand{font-family:var(--display);font-size:13.5px;font-weight:700;color:var(--ink);padding:6px 12px;margin-bottom:10px}
.mockup-admin__nav-item{padding:9px 12px;font-size:13px;color:var(--ink-3);font-weight:500;border-radius:7px;display:flex;align-items:center;justify-content:space-between}
.mockup-admin__nav-item--active{background:var(--accent);color:#fff;font-weight:600}
.mockup-admin__badge{background:var(--bg-mute);color:var(--ink-3);padding:1px 7px;border-radius:999px;font-size:11px;font-weight:700}
.mockup-admin__badge--alert{background:#fee2e2;color:#dc2626}
.mockup-admin__main{padding:22px 26px}
.mockup-admin__title{font-family:var(--display);font-size:17px;font-weight:600;color:var(--ink);margin-bottom:14px}
.mockup-admin__row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;margin-bottom:8px;font-size:13.5px}
.mockup-admin__row strong{display:block;color:var(--ink);font-weight:600;font-size:14px}
.mockup-admin__sub{color:var(--ink-3);font-size:12px;margin-top:2px}
.mockup-admin__price-input{padding:6px 12px;background:#fff;border:1px solid var(--line);border-radius:6px;font-weight:600;color:var(--ink);min-width:62px;text-align:right}
.mockup-admin__row--editing{border-color:var(--accent);background:var(--accent-fade)}
.mockup-admin__price-input--edit{background:#fff;border-color:var(--accent);color:var(--accent);font-weight:700}
.mockup-admin__save{margin-top:14px;padding:11px 16px;background:var(--ink);color:#fff;font-size:12.5px;font-weight:600;text-align:center;border-radius:8px}

/* ─── Mockup : Phones (Sophie + Marie) ─── */
.mockup-phones{position:relative;display:flex;justify-content:center;align-items:center;height:560px;perspective:1400px}
.mockup-phone{position:absolute;background:#1a1a1d;padding:8px;border-radius:38px;box-shadow:0 30px 60px -20px rgba(0,0,0,.4),0 12px 24px -8px rgba(0,0,0,.2);transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.mockup-phone__notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:32%;height:18px;background:#000;border-radius:0 0 12px 12px;z-index:3}
.mockup-phone__screen{aspect-ratio:390/844;background:#000;border-radius:30px;overflow:hidden;width:100%;position:relative}
.mockup-phone__screen img{display:block;width:100%;height:100%;object-fit:cover;object-position:top center}
/* 3 phones : front centré + back légèrement reculé en haut + side discret */
.mockup-phone--front{width:240px;z-index:3;transform:translateY(0)}
.mockup-phone--back{width:225px;z-index:1;left:calc(50% - 200px);top:8%;transform:rotate(-7deg)}
.mockup-phone--side{width:225px;z-index:2;right:calc(50% - 200px);top:6%;transform:rotate(7deg)}
.feature__visual--phones:hover .mockup-phone--back{transform:rotate(-9deg) translateY(-4px)}
.feature__visual--phones:hover .mockup-phone--side{transform:rotate(9deg) translateY(-4px)}
.feature__visual--phones:hover .mockup-phone--front{transform:translateY(-6px)}
@media(max-width:980px){
  .mockup-phones{height:480px}
  .mockup-phone--front{width:200px}
  .mockup-phone--back{width:185px;left:calc(50% - 170px)}
  .mockup-phone--side{width:185px;right:calc(50% - 170px)}
}
@media(max-width:680px){
  .mockup-phones{height:420px}
  .mockup-phone--front{width:170px}
  .mockup-phone--back{width:150px;left:calc(50% - 135px)}
  .mockup-phone--side{width:150px;right:calc(50% - 135px)}
}

/* ─── Bonus features grid (compact) ─── */
.bonus{padding:64px var(--gutter);background:var(--bg);border-top:1px solid var(--line)}
.bonus__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:var(--max);margin:0 auto}
.bonus__item{padding:22px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--rad-md);transition:border-color .2s,transform .2s}
.bonus__item:hover{border-color:var(--accent);transform:translateY(-2px)}
.bonus__icon{color:var(--accent);width:22px;height:22px;margin-bottom:14px}
.bonus__icon svg{width:22px;height:22px}
.bonus__item strong{display:block;font-family:var(--display);font-size:15.5px;font-weight:600;letter-spacing:-.01em;color:var(--ink);margin-bottom:4px}
.bonus__item p{font-size:13.5px;line-height:1.5;color:var(--ink-3);margin:0}
@media(max-width:780px){.bonus__grid{grid-template-columns:1fr}}

/* Mobile: ribbon condensed */
@media(max-width:560px){
  .ribbon{padding:9px 14px;font-size:12px;gap:10px}
  .ribbon__sep{display:none}
  .ribbon__brand-kalme{font-size:14px}
  .ribbon__live{font-size:12px}
}

.showroom__note strong{color:var(--ink);font-weight:700}

/* ════════════════════════════════════════════════════════════════
   ─── REFONTE V3 : hero deal premium, partner refondu, mockups améliorés
   ════════════════════════════════════════════════════════════════ */

/* ─── Hero refonte v3 : marge réduite, layout serré, mockup plus grand ─── */
.hero{padding:48px var(--gutter) 80px}
.hero__inner{grid-template-columns:1.02fr 1fr;gap:56px}
.hero__title{font-size:clamp(40px,5.6vw,72px);line-height:1.0;margin-bottom:18px}
.hero__sub{font-size:18px;margin-bottom:24px}

/* Bloc deal premium (style Stripe billing summary) */
.hero__deal{background:#fff;border:1.5px solid var(--ink);border-radius:14px;padding:0;margin:0 0 28px;max-width:560px;overflow:hidden;box-shadow:0 14px 32px -16px rgba(0,0,0,.18)}
.hero__deal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:linear-gradient(135deg,#0a0a0a,#0d4f4d);color:#fff}
.hero__deal-tag{font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:#fff}
.hero__deal-by{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:rgba(255,255,255,.7);font-weight:500}
.hero__deal-logo{height:18px;width:auto;filter:brightness(0) invert(1);opacity:.92}
.hero__deal-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;font-size:14.5px;border-bottom:1px solid var(--line)}
.hero__deal-label{color:var(--ink-2);font-weight:500;flex:1}
.hero__deal-price{display:inline-flex;align-items:center;gap:10px;font-weight:600}
.hero__deal-strike{color:var(--ink-4);text-decoration:line-through;font-size:13.5px;font-weight:500}
.hero__deal-free{color:#fff;background:var(--accent);padding:3px 10px;border-radius:5px;font-weight:700;font-size:13px;letter-spacing:-.005em}
.hero__deal-now{color:var(--ink);font-weight:700;font-size:14.5px}
.hero__deal-now em{color:var(--accent);font-style:normal;font-weight:700;background:var(--accent-soft);padding:1px 6px;border-radius:4px;margin-left:6px;font-size:11.5px;letter-spacing:.04em}
.hero__deal-total{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:var(--accent-soft)}
.hero__deal-total-label{font-size:13px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-2)}
.hero__deal-total-num{font-family:var(--display);font-size:18px;font-weight:700;letter-spacing:-.018em;color:var(--accent)}

/* Mockup browser plus grand, plus posé (moins penché) */
.hero__browser{transform:rotate(-1deg) translateY(0)}
.hero__phone{transform:rotate(3deg);bottom:-30px;width:36%}
.hero__badge{transform:rotate(-2deg)}
.hero__badge--bottom{transform:rotate(1deg)}

@media(max-width:880px){
  .hero{padding:32px var(--pad) 56px}
  .hero__inner{gap:36px}
  .hero__deal{max-width:none}
}

/* ─── Compteur live : nombre précis ─── */
.ribbon__remaining{font-weight:700;color:#fff;background:rgba(34,197,94,.22);padding:1px 8px;border-radius:5px;letter-spacing:-.005em}
.hero__live-mini strong{color:var(--ink);font-weight:700;font-size:14px}

/* ─── Section partner v3 : refonte propre ─── */
.partner{background:var(--bg-soft);color:var(--ink);padding:88px var(--gutter);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.partner::before{display:none}
.partner__inner{max-width:var(--max);margin:0 auto;text-align:center}
.partner__tag{display:inline-block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:20px;padding:6px 14px;background:#fff;border:1px solid var(--line-2);border-radius:999px}
.partner__title{font-family:var(--display);font-size:clamp(32px,4.4vw,52px);font-weight:600;letter-spacing:-.028em;line-height:1.06;color:var(--ink);margin:0 0 56px;max-width:840px;margin-left:auto;margin-right:auto}
.partner__title em{color:var(--accent);font-style:normal;font-weight:600;background:none}
.partner__pair{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:stretch;max-width:1040px;margin:0 auto;text-align:left}
.partner__brand{padding:36px 32px;background:#fff;border:1px solid var(--line);border-radius:var(--rad-lg);transition:transform .25s,box-shadow .25s}
.partner__brand:hover{transform:translateY(-2px);box-shadow:0 24px 48px -25px rgba(0,0,0,.14)}
.partner__brand--kalme{border-top:3px solid var(--accent)}
.partner__brand--allo{border-top:3px solid var(--allo-blue)}
.partner__brand-logo{margin-bottom:22px;display:flex;align-items:center;height:38px}
.partner__brand-name{font-family:var(--display);font-weight:700;font-size:30px;color:var(--ink);letter-spacing:-.03em;line-height:1}
.partner__brand-name em{color:var(--accent);font-style:normal;font-weight:700}
.partner__brand-img{height:30px;width:auto}
.partner__brand-role{font-family:var(--display);font-size:18px;font-weight:600;color:var(--ink);letter-spacing:-.018em;line-height:1.2;margin:0 0 12px}
.partner__brand-body{font-size:14.5px;line-height:1.6;color:var(--ink-3);margin:0}
.partner__brand-body strong{color:var(--ink);font-weight:600}
.partner__plus{font-family:var(--display);font-size:36px;font-weight:300;color:var(--ink-4);align-self:center;line-height:1;padding:0 6px}
.partner__verdict{margin:40px auto 0;max-width:780px;font-size:17px;line-height:1.55;color:var(--ink-2);text-align:center;padding:22px 28px;background:#fff;border:1px solid var(--line);border-radius:var(--rad-md)}
.partner__verdict strong{color:var(--accent);font-weight:700}
@media(max-width:880px){
  .partner__pair{grid-template-columns:1fr}
  .partner__plus{transform:rotate(0);text-align:center}
  .partner{padding:64px var(--pad)}
}

/* ─── Section feature 01 Google avec vrai branding ─── */
.mockup-google__logo{font-family:'Product Sans','Arial',sans-serif;font-size:22px;font-weight:500;letter-spacing:-.02em;color:#5f6368;display:inline-flex;background:none;-webkit-background-clip:initial;background-clip:initial}
.mockup-google__logo svg{width:78px;height:26px}

/* ─── Footer logo proportions ─── */
.footer__partner-logo{height:34px !important;width:auto;display:block}

/* ─── Bonus footer alignement ─── */
.bonus__icon svg{width:22px;height:22px;display:block}


/* ─── Mockup admin v3 (vue photos + bouton site) ─── */
.mockup-admin{grid-template-columns:210px 1fr;min-height:420px}
.mockup-admin__brand{padding:8px 12px 14px;margin-bottom:4px;border-bottom:1px solid var(--line)}
.mockup-admin__brand-name{font-family:var(--display);font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.mockup-admin__brand-sub{font-size:11.5px;color:var(--ink-3);font-weight:500}
.mockup-admin__nav-spacer{flex:1}
.mockup-admin__view-btn{padding:9px 12px;background:var(--ink);color:#fff;font-size:12.5px;font-weight:600;border-radius:7px;text-align:center;margin-top:10px}
.mockup-admin__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mockup-admin__hint{font-size:11.5px;color:var(--ink-3);font-style:italic}
.mockup-admin__photos{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px}
.mockup-admin__photo{position:relative;border:1px solid var(--line);border-radius:8px;overflow:hidden;cursor:pointer;transition:border-color .2s}
.mockup-admin__photo:hover{border-color:var(--accent)}
.mockup-admin__photo-img{aspect-ratio:4/3;width:100%}
.mockup-admin__photo-edit{position:absolute;bottom:6px;right:6px;background:rgba(10,10,10,.85);color:#fff;font-size:10.5px;font-weight:600;padding:3px 7px;border-radius:4px;letter-spacing:.02em}
.mockup-admin__photo--add{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-mute);border:2px dashed var(--line-2);min-height:80px}
.mockup-admin__photo-add{font-size:32px;color:var(--ink-4);font-weight:300;line-height:1;margin-bottom:4px}
.mockup-admin__photo--add .mockup-admin__photo-edit{position:static;background:none;color:var(--ink-3);font-size:11.5px;padding:0}
.mockup-admin__publish{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--accent-fade);border:1px solid #d6e6e5;border-radius:7px;font-size:12.5px;color:var(--accent-2);font-weight:600}
.mockup-admin__publish-status{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:#0c8a4f}
.mockup-admin__publish-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:pulse-dot 2s ease-out infinite}

/* ─── Override force partner v3 (kill old grid layout) ─── */
.partner__inner{display:block !important;grid-template-columns:none !important;gap:0 !important;text-align:center !important}

/* ─── Partner v3 force image color (kill v1 invert filter) ─── */
.partner__brand-img{filter:none !important;height:32px}
.partner__brand-name{color:var(--ink) !important}
.partner__brand-role{color:var(--ink) !important}
.partner__brand-body{color:var(--ink-3) !important}
.partner__brand-body strong{color:var(--ink) !important}

/* ════════════════════════════════════════════════════════════════
   ─── REFONTE V4 : footer logo, bandeau formules, anim mockups, section craft, hero hiérarchie
   ════════════════════════════════════════════════════════════════ */

/* ─── Footer logo AlloClients : taille raisonnable, alignée ─── */
.footer__partner-block{display:flex;align-items:center;gap:14px;padding:10px 14px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--rad-md);width:fit-content;margin-top:18px}
.footer__partner-label{font-size:10px !important;letter-spacing:.2em !important;text-transform:uppercase;font-weight:700;color:var(--ink-3);line-height:1.2}
.footer__partner-logo{height:22px !important;width:auto !important;display:block}

/* ─── Hero v4 : bloc deal moins criard, hiérarchie titre prioritaire ─── */
.hero__deal{border:1px solid var(--line) !important;border-radius:12px;box-shadow:0 4px 12px -6px rgba(0,0,0,.06);max-width:520px;margin-bottom:24px}
.hero__deal-head{padding:10px 18px;background:var(--bg-soft);color:var(--ink);border-bottom:1px solid var(--line)}
.hero__deal-tag{color:var(--accent);font-weight:700}
.hero__deal-by{color:var(--ink-3)}
.hero__deal-logo{filter:none;height:14px;opacity:1}
.hero__deal-row{padding:11px 18px;font-size:13.5px}
.hero__deal-total{padding:12px 18px;background:var(--accent-fade);border-top:1px solid var(--accent-soft)}
.hero__deal-total-num{font-size:16px}

/* ─── Lockup partner top de section Formules (juste le co-branding, pas un encart redondant) ─── */
.offers__partner-lockup-only{display:inline-flex;align-items:center;gap:14px;margin:0 auto 36px;padding:0;background:transparent;justify-content:center;width:100%}
.offers__partner-kalme{font-family:var(--display);font-weight:700;font-size:22px;letter-spacing:-.025em;color:var(--ink);line-height:1}
.offers__partner-kalme em{color:var(--accent);font-style:normal;font-weight:700}
.offers__partner-x{font-family:var(--display);font-weight:300;font-size:22px;color:var(--ink-4);line-height:1}
.offers__partner-lockup-only img{height:28px;width:auto;opacity:.92}
@media(max-width:520px){.offers__partner-lockup-only{gap:10px;margin-bottom:28px}.offers__partner-kalme,.offers__partner-x{font-size:18px}.offers__partner-lockup-only img{height:22px}}

/* ─── Section Craft (L'obsession du détail) ─── */
.craft{padding:104px var(--gutter);background:var(--ink);color:#fff;position:relative;overflow:hidden}
.craft::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 40% at 50% 0%,rgba(95,184,181,.18) 0%,transparent 60%);pointer-events:none}
.craft .ctn{position:relative}
.craft .eyebrow{color:var(--accent-3)}
.craft .section__title{color:#fff}
.craft .section__title em{color:var(--accent-3);background:none}
.craft .section__sub{color:#a1a1aa}
.craft__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px}
.craft__metric{padding:32px 28px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--rad-lg);transition:transform .25s,border-color .25s,background .25s}
.craft__metric:hover{transform:translateY(-3px);border-color:rgba(95,184,181,.45);background:rgba(95,184,181,.05)}
.craft__num{font-family:var(--display);font-size:64px;font-weight:700;letter-spacing:-.03em;line-height:1;color:#fff;margin-bottom:14px;display:flex;align-items:baseline}
.craft__num-unit{font-size:24px;font-weight:600;color:var(--accent-3);margin-left:4px}
.craft__label{font-family:var(--display);font-size:16px;font-weight:600;letter-spacing:-.015em;color:#fff;margin-bottom:8px}
.craft__sub{font-size:13.5px;line-height:1.55;color:#a1a1aa;margin:0}
.craft__verdict{margin:0 auto;max-width:760px;text-align:center;padding:32px 36px;background:rgba(95,184,181,.08);border:1px solid rgba(95,184,181,.32);border-radius:var(--rad-md)}
.craft__quote{font-family:var(--display);font-size:20px;font-weight:500;line-height:1.45;color:#fff;letter-spacing:-.01em;font-style:italic}
@media(max-width:980px){.craft__grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px){.craft__grid{grid-template-columns:1fr}.craft{padding:64px var(--pad)}}

/* ─── Animations mockups (vraies micro-démos lisibles, pas des artifices) ─── */

/* ════ Feature 02 — Booking : curseur clique day → slot → CTA, puis toast confirmation ════
   Cycle 10s :
   0-5 %    reset (curseur invisible, day/slot/CTA en état initial visible)
   5-12 %   curseur fade-in en haut à droite
   12-22 %  curseur descend vers le 13 (mb-day-target)
   22-25 %  click day : curseur scale + ring autour du day
   25-40 %  curseur descend vers slot 14:30
   40-43 %  click slot : curseur scale + ring autour du slot
   43-58 %  curseur descend vers CTA "Confirmer le RDV"
   58-62 %  click CTA : curseur scale + CTA scale + flash
   62-78 %  toast "Demande envoyée" slide-in & visible
   78-90 %  toast reste visible
   90-95 %  toast fade-out
   95-100 % reset */
.mockup-booking{position:relative;overflow:hidden}
.mockup-booking__cursor{
  position:absolute;top:14px;right:24px;width:18px;height:18px;
  pointer-events:none;z-index:5;will-change:transform,opacity;opacity:0;
  animation:mk-book-cursor 10s cubic-bezier(.35,.5,.45,.95) infinite;
}
.mockup-booking__cursor svg{width:18px;height:18px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}
@keyframes mk-book-cursor{
  0%,4%{opacity:0;transform:translate(0,-12px) scale(1)}
  8%{opacity:1;transform:translate(0,0) scale(1)}
  /* day 13 : col 2 row 3 dans la grid (left ~50px depuis right 24, down ~95px depuis top 14) */
  18%,22%{opacity:1;transform:translate(-200px,90px) scale(1)}
  24%{opacity:1;transform:translate(-200px,90px) scale(.78)}
  26%,28%{opacity:1;transform:translate(-200px,90px) scale(1)}
  /* slot 14:30 : centre du calendrier, plus bas */
  37%,40%{opacity:1;transform:translate(-118px,210px) scale(1)}
  42%{opacity:1;transform:translate(-118px,210px) scale(.78)}
  44%,46%{opacity:1;transform:translate(-118px,210px) scale(1)}
  /* CTA "Confirmer le RDV" : centre full-width, bottom */
  56%,60%{opacity:1;transform:translate(-118px,275px) scale(1)}
  62%{opacity:1;transform:translate(-118px,275px) scale(.78)}
  65%,86%{opacity:1;transform:translate(-118px,275px) scale(1)}
  92%,100%{opacity:0;transform:translate(-118px,275px) scale(1)}
}
/* day 13 : ring qui pulse au moment du click */
@keyframes mk-book-day-ring{
  0%,22%{box-shadow:0 0 0 0 rgba(13,79,77,0)}
  24%{box-shadow:0 0 0 0 rgba(13,79,77,.55)}
  30%{box-shadow:0 0 0 8px rgba(13,79,77,0)}
  100%{box-shadow:0 0 0 0 rgba(13,79,77,0)}
}
.mb-day-target{animation:mk-book-day-ring 10s ease-out infinite;position:relative}
/* slot ring */
@keyframes mk-book-slot-ring{
  0%,40%{box-shadow:0 0 0 0 rgba(13,79,77,0)}
  42%{box-shadow:0 0 0 0 rgba(13,79,77,.45)}
  48%{box-shadow:0 0 0 6px rgba(13,79,77,0)}
  100%{box-shadow:0 0 0 0 rgba(13,79,77,0)}
}
.mb-slot-target{animation:mk-book-slot-ring 10s ease-out infinite}
/* CTA pulse + scale au moment du click */
@keyframes mk-book-cta{
  0%,58%{transform:scale(1);box-shadow:0 4px 12px -4px rgba(13,79,77,.25)}
  62%{transform:scale(.96);box-shadow:0 12px 28px -6px rgba(13,79,77,.5)}
  66%,86%{transform:scale(1);box-shadow:0 8px 20px -6px rgba(13,79,77,.4)}
  92%,100%{transform:scale(1);box-shadow:0 4px 12px -4px rgba(13,79,77,.25)}
}
.mb-cta-target{animation:mk-book-cta 10s ease-in-out infinite}
/* Toast confirmation booking — bottom right, slide-in après le click CTA */
@keyframes mk-book-toast{
  0%,62%{opacity:0;transform:translateY(8px) scale(.96)}
  68%,88%{opacity:1;transform:translateY(0) scale(1)}
  93%,100%{opacity:0;transform:translateY(8px) scale(.96)}
}
.mockup-booking__toast{
  position:absolute;left:14px;right:14px;bottom:14px;
  display:flex;align-items:flex-start;gap:10px;
  padding:11px 13px;background:#0c8a4f;color:#fff;
  border-radius:8px;box-shadow:0 14px 28px -10px rgba(12,138,79,.45),0 4px 8px -2px rgba(12,138,79,.25);
  z-index:10;opacity:0;will-change:transform,opacity;
  animation:mk-book-toast 10s ease-in-out infinite;
  transform-origin:center;
}
.mockup-booking__toast-tick{width:16px;height:16px;border-radius:50%;background:#fff;flex-shrink:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2.5 6.5l2.3 2.3L9.5 4' fill='none' stroke='%230c8a4f' stroke-width='2' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:center}
.mockup-booking__toast-body{display:flex;flex-direction:column;line-height:1.3}
.mockup-booking__toast-body strong{font-size:12.5px;font-weight:700;letter-spacing:.01em}
.mockup-booking__toast-body span{font-size:11px;font-weight:500;opacity:.85}

/* ════ Feature 03 — Avis : un nouvel avis arrive en haut de liste, compteur 47→48 ════
   Cycle de 8s : 0-25 % stable (3 avis), 30-50 % le NOUVEL avis se déploie, 50-90 % visible, 95-100 % reset.
   - Le nouveau prend SA place via max-height qui passe de 0 à 110px → les 3 autres restent visibles.
   - Le compteur a deux spans superposés (47 puis 48) qui se croisent en fade. */
@keyframes mk-review-appear{
  0%,25%{max-height:0;opacity:0;padding-top:0;padding-bottom:0;margin-bottom:0;transform:translateY(-8px)}
  35%,90%{max-height:140px;opacity:1;padding-top:12px;padding-bottom:12px;margin-bottom:18px;transform:translateY(0)}
  98%,100%{max-height:0;opacity:0;padding-top:0;padding-bottom:0;margin-bottom:0;transform:translateY(-8px)}
}
@keyframes mk-review-badge{
  0%,28%{opacity:0;transform:scale(.7)}
  35%{opacity:1;transform:scale(1)}
  78%{opacity:1;transform:scale(1)}
  86%,100%{opacity:0;transform:scale(.7)}
}
@keyframes mk-count-old{
  0%,29%{opacity:1}
  35%,100%{opacity:0}
}
@keyframes mk-count-new{
  0%,29%{opacity:0}
  35%,90%{opacity:1}
  98%,100%{opacity:0}
}
.mockup-reviews__list{position:relative}
.mockup-reviews__item--new{
  position:relative;
  display:flex;gap:12px;
  background:linear-gradient(90deg,var(--accent-fade),transparent 80%);
  border-left:2px solid var(--accent-3);
  border-radius:0 8px 8px 0;
  padding-left:10px;
  margin-left:-10px;
  overflow:hidden;
  animation:mk-review-appear 8s ease-in-out infinite;
}
.mockup-reviews__item--new::before{
  content:"NOUVEAU";
  position:absolute;top:8px;right:0;
  background:#22c55e;color:#fff;
  font-size:9px;font-weight:800;letter-spacing:.1em;
  padding:3px 8px;border-radius:4px;
  animation:mk-review-badge 8s ease-in-out infinite;
}
.mockup-reviews__count{position:relative;display:inline-block;min-height:1.3em}
.mockup-reviews__count-old,.mockup-reviews__count-new{display:block}
.mockup-reviews__count-new{position:absolute;inset:0;animation:mk-count-new 8s ease-in-out infinite;opacity:0}
.mockup-reviews__count-old{animation:mk-count-old 8s ease-in-out infinite}

/* ════ Feature 04 — Admin : modif tarif live (cursor → input change → save → toast publié) ════
   Cycle de 9s, timeline lisible :
   0-12 %  : cursor entre, atterrit sur l'input prix
   12-24 % : input "65 €" disparaît, "70 €" apparaît avec caret
   24-50 % : caret pulse pendant qu'elle "tape"
   50-62 % : cursor part vers le bouton Enregistrer
   62-70 % : bouton Save flash + clic
   70-92 % : toast "Publié sur votre site" entre par le haut
   92-100% : reset, retour à 65 € sans transition */

/* Timeline 9 s synchronisée :
   0-6 %   état initial (65 €, no toast, row plat, save gris)
   6-12 %  cursor entre par haut-gauche, atterrit sur input
   12-18 % prix 65→70 (croisement opacity), row passe en editing
   18-50 % input 70 €, caret blink, "elle tape"
   50-62 % cursor descend vers bouton Enregistrer
   62-66 % cursor presse le bouton (clic + scale)
   66-72 % bouton flash en accent + toast slide-in depuis le haut
   72-92 % toast visible "Publié sur votre site", prix reste à 70 €
   92-98 % toast fade-out
   98-100 % retour brutal à 65 € (snap) pour rebooter le cycle */

/* Timeline 9s synchronisée :
   0-5%   reset (curseur off, prix 65, bouton inactif gris, hint pending)
   5-12%  curseur fade-in en haut à droite, descend vers la price-cell
   12-22% caret blink dans le champ tarif
   22-32% prix 65 fade-out → 70 fade-in (sans shift, position absolue)
   32-58% prix 70 stable, row en accent, bouton devient cliquable (accent doux)
   58-66% curseur glisse vers le bouton "Enregistrer"
   66-70% CLICK SYNCHRO : curseur scale .80 + bouton scale .94 + flash accent intense + ripple
   70-72% release : tout remonte à scale 1
   72-90% toast slide-in à l'intérieur de la mockup, hint pending→done
   90-95% toast fade-out
   95-100% reset */
@keyframes mk-cursor{
  0%,4%{opacity:0;transform:translate(0,-30px) scale(1)}
  8%{opacity:1;transform:translate(0,-12px) scale(1)}
  14%,55%{opacity:1;transform:translate(20px,35px) scale(1)}
  62%,65%{opacity:1;transform:translate(-10px,300px) scale(1)}
  67%{opacity:1;transform:translate(-10px,300px) scale(.78)}
  70%{opacity:1;transform:translate(-10px,300px) scale(1)}
  88%{opacity:1;transform:translate(-10px,300px) scale(1)}
  94%,100%{opacity:0;transform:translate(-10px,300px) scale(1)}
}
@keyframes mk-row-editing{
  0%,5%{border-color:var(--line);background:var(--bg-soft)}
  12%,80%{border-color:var(--accent);background:var(--accent-fade)}
  88%,100%{border-color:var(--line);background:var(--bg-soft)}
}
@keyframes mk-price-old{
  0%,18%{opacity:1}
  26%,99%{opacity:0}
  100%{opacity:1}
}
@keyframes mk-price-new{
  0%,18%{opacity:0}
  26%,96%{opacity:1}
  100%{opacity:0}
}
@keyframes mk-caret{
  0%,8%{opacity:0}
  12%{opacity:1} 14%{opacity:0}
  16%{opacity:1} 18%{opacity:0}
  20%{opacity:1} 22%{opacity:0}
  24%{opacity:1} 26%{opacity:0}
  100%{opacity:0}
}
@keyframes mk-save-pulse{
  0%,30%{background:var(--ink-4);color:rgba(255,255,255,.5);box-shadow:none;transform:scale(1)}
  35%,65%{background:var(--accent);color:#fff;box-shadow:0 6px 14px -4px rgba(20,79,72,.35);transform:scale(1)}
  67%{background:var(--accent);color:#fff;transform:scale(.94);box-shadow:0 2px 6px -2px rgba(20,79,72,.4) inset}
  70%,86%{background:var(--accent);color:#fff;transform:scale(1);box-shadow:0 6px 14px -4px rgba(20,79,72,.35)}
  92%,100%{background:var(--ink-4);color:rgba(255,255,255,.5);box-shadow:none;transform:scale(1)}
}
/* Ripple visible au moment du click — anneau accent qui s'étend depuis le bouton */
@keyframes mk-ripple{
  0%,65%{opacity:0;transform:translate(-50%,-50%) scale(.4)}
  67%{opacity:.55;transform:translate(-50%,-50%) scale(.4)}
  74%{opacity:0;transform:translate(-50%,-50%) scale(2.2)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(2.2)}
}
@keyframes mk-savehint-pending{
  0%,68%{opacity:1}
  72%,95%{opacity:0}
  98%,100%{opacity:1}
}
@keyframes mk-savehint-done{
  0%,68%{opacity:0}
  72%,90%{opacity:1}
  94%,100%{opacity:0}
}
@keyframes mk-toast{
  0%,68%{opacity:0;transform:translateY(8px) scale(.96)}
  72%,88%{opacity:1;transform:translateY(0) scale(1)}
  93%,100%{opacity:0;transform:translateY(8px) scale(.96)}
}
.mockup-admin{position:relative;overflow:hidden;contain:layout paint}
.mockup-admin__main{position:relative;overflow:hidden;min-height:380px}
.mockup-admin__cursor{
  position:absolute;top:90px;left:78%;width:18px;height:18px;
  pointer-events:none;z-index:5;will-change:transform,opacity;
  animation:mk-cursor 9s cubic-bezier(.25,.46,.45,.94) infinite;
}
.mockup-admin__cursor svg{width:18px;height:18px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.3))}
.mockup-admin__row--editing{animation:mk-row-editing 9s ease-in-out infinite}
.mockup-admin__price-cell{position:relative;display:inline-flex;align-items:center;gap:2px;min-width:64px;justify-content:flex-end;font-family:var(--display);font-weight:700;font-size:15px;color:var(--accent)}
.mockup-admin__price-old{animation:mk-price-old 9s ease-in-out infinite}
.mockup-admin__price-new{position:absolute;inset:0;display:flex;align-items:center;justify-content:flex-end;animation:mk-price-new 9s ease-in-out infinite;opacity:0}
.mockup-admin__price-static{color:var(--ink)}
.mockup-admin__caret{display:inline-block;width:1.5px;height:14px;background:var(--accent);margin-left:2px;animation:mk-caret 9s linear infinite;opacity:0;vertical-align:middle}
.mockup-admin__save-bar{position:relative;display:flex;align-items:center;justify-content:space-between;margin-top:14px;padding:10px 14px;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px}
.mockup-admin__save-hint{font-size:12px;font-weight:600;transition:opacity .25s,transform .25s}
.mockup-admin__save-hint--pending{color:#dc2626;animation:mk-savehint-pending 9s ease-in-out infinite}
.mockup-admin__save-hint--done{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#0c8a4f;animation:mk-savehint-done 9s ease-in-out infinite;opacity:0;display:inline-flex;align-items:center;gap:4px}
.mockup-admin__save-btn{position:relative;padding:8px 16px;background:var(--ink-4);color:rgba(255,255,255,.5);font-size:12.5px;font-weight:600;border:0;border-radius:6px;cursor:pointer;animation:mk-save-pulse 9s ease-in-out infinite;will-change:transform,background-color;white-space:nowrap;overflow:visible}
.mockup-admin__save-btn::after{content:"";position:absolute;left:50%;top:50%;width:100%;height:100%;border-radius:6px;background:var(--accent);opacity:0;pointer-events:none;animation:mk-ripple 9s ease-out infinite;transform:translate(-50%,-50%) scale(.4)}
.mockup-admin__toast{
  position:absolute;bottom:80px;right:18px;
  display:inline-flex;align-items:flex-start;gap:10px;
  padding:10px 13px;background:#0c8a4f;color:#fff;
  border-radius:8px;box-shadow:0 14px 28px -10px rgba(12,138,79,.45),0 4px 8px -2px rgba(12,138,79,.25);
  z-index:10;opacity:0;will-change:transform,opacity;
  animation:mk-toast 9s ease-in-out infinite;
  max-width:calc(100% - 32px);
}
.mockup-admin__toast-tick{
  width:16px;height:16px;border-radius:50%;background:#fff;flex-shrink:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'><path d='M2.5 6.5l2.3 2.3L9.5 4' fill='none' stroke='%230c8a4f' stroke-width='2' stroke-linecap='round'/></svg>");
  background-repeat:no-repeat;background-position:center;
}
.mockup-admin__toast-body{display:flex;flex-direction:column;line-height:1.3}
.mockup-admin__toast-body strong{font-size:12.5px;font-weight:700;letter-spacing:.01em}
.mockup-admin__toast-body span{font-size:11px;font-weight:500;opacity:.85}
.mockup-admin__rows{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.mockup-admin__row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;transition:border-color .2s,background .2s}
.mockup-admin__row-info strong{display:block;font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink);letter-spacing:-.005em}
.mockup-admin__row-sub{font-size:11.5px;color:var(--ink-3);font-weight:500;margin-top:2px}
.mockup-admin__sub{font-size:12px;color:var(--ink-3);font-weight:500;margin-top:2px}

/* Google logo image */
img.mockup-google__logo{height:24px;width:auto;display:block}

/* (audience cards utilisent désormais .audience-card__photo, voir bloc principal) */

/* ════ Responsive mobile : mockups admin & booking compactés ════ */
@media(max-width:680px){
  .mockup-admin{grid-template-columns:1fr;min-height:auto}
  .mockup-admin__sidebar{display:none}
  .mockup-admin__main{padding:18px 18px;min-height:340px}
  .mockup-admin__title{font-size:15px}
  .mockup-admin__sub{font-size:11px}
  .mockup-admin__row{padding:12px 14px}
  .mockup-admin__row-info strong{font-size:13px}
  .mockup-admin__price-cell{font-size:14px;min-width:54px}
  /* Curseur recalibré pour mobile : main commence à 0 (pas de sidebar) */
  .mockup-admin__cursor{top:80px;left:74%}
  /* Toast adapté */
  .mockup-admin__toast{bottom:74px;right:14px;max-width:calc(100% - 28px);padding:9px 12px}
  .mockup-admin__toast-body strong{font-size:11.5px}
  .mockup-admin__toast-body span{font-size:10px}
  /* Mockup booking : full width et cursor fade-out (animation translate fixe ne fonctionne pas correctement à cette échelle) */
  .mockup-booking{max-width:100%}
  .mockup-booking__cursor{display:none}
  .mockup-booking__toast{position:absolute;left:14px;right:14px;bottom:14px}
}


/* ════════════════════════════════════════════════════════════
   ─── HOME KALMÉ NEUTRE (route `/` sans partenariat) ───
   ════════════════════════════════════════════════════════════ */

/* Ribbon neutre : présentation simple, pas de promo */
.ribbon--neutral{background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;gap:18px;padding:11px 24px;font-size:13px;font-weight:500;letter-spacing:.005em}
.ribbon--neutral .ribbon__brand-kalme{font-family:var(--display);font-weight:700;font-size:14px;letter-spacing:-.02em;color:#fff;line-height:1}
.ribbon--neutral .ribbon__brand-kalme em{color:var(--accent-3);font-style:normal;font-weight:700}
.ribbon--neutral .ribbon__sep{width:1px;height:14px;background:rgba(255,255,255,.2)}
.ribbon--neutral .ribbon__live{display:inline-flex;align-items:center;gap:8px;color:rgba(255,255,255,.85)}
.ribbon--neutral .ribbon__dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 0 rgba(34,197,94,.6);animation:pulse-dot 2s ease-out infinite}
@media(max-width:780px){.ribbon--neutral{flex-wrap:wrap;gap:10px;font-size:12px;padding:10px 16px}.ribbon--neutral .ribbon__sep{display:none}}

/* Hero eyebrow (remplace lockup AlloClients en home neutre) */
.hero__eyebrow-tag{display:inline-flex;align-items:center;padding:6px 14px;background:var(--bg-soft);border:1px solid var(--line);color:var(--ink-2);font-size:12px;font-weight:600;letter-spacing:.02em;border-radius:999px;margin-bottom:24px}

/* Hero price card (remplace hero__deal en home neutre) */
.hero__price-card{margin:28px 0 24px;border:1px solid var(--line);border-radius:var(--rad-md);overflow:hidden;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.hero__price-card-row{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--line)}
.hero__price-card-row:last-child{border-bottom:0;background:linear-gradient(0deg,var(--accent-fade),transparent 100%)}
.hero__price-card-label{font-size:13.5px;font-weight:500;color:var(--ink-2);letter-spacing:-.005em}
.hero__price-card-val{font-family:var(--display);font-weight:700;font-size:16px;color:var(--ink);text-align:right;line-height:1.2;display:flex;flex-direction:column;align-items:flex-end}
.hero__price-card-val small{font-family:var(--sans);font-size:11px;font-weight:500;color:var(--ink-3);margin-top:2px;letter-spacing:0}
.hero__price-card-val--accent{color:var(--accent)}

/* Manifesto section (remplace partner section en home neutre) */
.manifesto{padding:104px var(--gutter) 80px;background:linear-gradient(180deg,var(--bg-soft) 0%,var(--bg) 100%)}
.manifesto__inner{max-width:780px;margin:0 auto;text-align:center}
.manifesto__title{font-family:var(--display);font-size:clamp(2.2rem,4.4vw,3.4rem);font-weight:700;line-height:1.08;letter-spacing:-.025em;margin:18px 0 28px;color:var(--ink)}
.manifesto__title em{font-style:italic;font-weight:600;color:var(--accent);background:linear-gradient(180deg,transparent 60%,var(--accent-fade) 60%);padding:0 .15em}
.manifesto__body{font-size:17px;line-height:1.65;color:var(--ink-2);margin:0 auto 18px;max-width:680px}
.manifesto__body strong{color:var(--ink);font-weight:600}
@media(max-width:780px){.manifesto{padding:64px var(--pad)}.manifesto__title{font-size:1.9rem}.manifesto__body{font-size:15.5px}}

/* Footer pill partenariat (sur home neutre, pour pointer vers /alloclients) */
.footer__partner-pill{display:inline-flex;align-items:center;gap:14px;padding:10px 16px;background:var(--bg-soft);border:1px solid var(--line);border-radius:999px;color:var(--ink-2);font-size:12.5px;font-weight:500;text-decoration:none;margin-top:18px;transition:border-color .2s,background .2s}
.footer__partner-pill:hover{border-color:var(--accent);background:var(--accent-fade)}
.footer__partner-pill-label{font-weight:600;color:var(--ink-3);letter-spacing:.02em;text-transform:uppercase;font-size:10.5px}
.footer__partner-pill-logos{display:inline-flex;align-items:center;gap:6px;font-family:var(--display);font-weight:700;color:var(--ink);font-size:13.5px;letter-spacing:-.02em}
.footer__partner-pill-logos em{color:var(--accent);font-style:normal;font-weight:700}
.footer__partner-pill-logos img{height:16px;width:auto;opacity:.85}
.footer__partner-pill-arrow{font-weight:600;color:var(--accent);font-size:14px;margin-left:4px}

/* Body class home : couleur d'accent légèrement différente possible (réservé) */
body.home{}
