/* ===== Praxia — Réalisations (carrousel) + comparateur avant/après ===== */
/* Réutilise les tokens CSS de index.html (:root) — mobile-first */

/* ---------- Section wrappers ---------- */
.px-real, .px-ba{position:relative}
.px-real .container, .px-ba .container{position:relative;z-index:1}

/* ---------- Carrousel Réalisations (marquee) ---------- */
.real-marquee{margin-top:30px;overflow:hidden;
  -webkit-mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
          mask:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent)}
.real-rows{display:flex;flex-direction:column;gap:16px}
.real-row{display:flex;gap:16px;width:max-content;will-change:transform}

.rc{flex:0 0 auto;width:172px;text-decoration:none;color:inherit;display:block}
@media(min-width:560px){.rc{width:212px}}
@media(min-width:880px){.rc{width:248px}}
.rc-shot{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:var(--paper);
  box-shadow:var(--shadow-md);transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s}
.rc:hover .rc-shot{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(196,90,47,.4)}
.rc-bar{display:flex;align-items:center;gap:5px;padding:7px 9px;background:var(--cream-3);border-bottom:1px solid var(--line)}
.rc-bar i{width:6px;height:6px;border-radius:50%;background:#cdbfa6;display:block}
.rc-bar i:nth-child(2){background:#d8c9ad}.rc-bar i:nth-child(3){background:#e2d3b6}
.rc-url{margin-left:6px;font-family:'JetBrains Mono',monospace;font-size:8.5px;color:var(--muted);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rc-img{aspect-ratio:1440/900;overflow:hidden;position:relative}
.rc-img img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;
  transition:transform .7s cubic-bezier(.2,.7,.2,1)}
.rc:hover .rc-img img{transform:scale(1.07)}
.rc-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 3px 0}
.rc-name{font-family:'Fraunces',serif;font-size:15px;font-weight:500;line-height:1.15;margin:0}
.rc-tag{font-size:11px;color:var(--muted);margin-top:1px}
.rc-go{flex:0 0 auto;color:var(--orange-deep);opacity:.7;transition:transform .35s,opacity .35s}
.rc:hover .rc-go{opacity:1;transform:translateX(3px)}
.real-hint{display:flex;justify-content:center;gap:8px;color:var(--muted);font-size:12.5px;margin-top:16px}

/* ---------- Comparateur avant / après ---------- */
.ba-wrap{margin-top:30px;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);
  border:1px solid var(--line);position:relative;touch-action:pan-y}
.ba{position:relative;aspect-ratio:16/10;user-select:none;-webkit-user-select:none}
@media(max-width:560px){
  .ba{aspect-ratio:3/4}
  .ba .win-body{padding:18px 20px;gap:11px}
  .pxa-h,.cls-h{font-size:18px!important}
  .pxa-chart,.cls-block{height:54px!important}
  .ba-grab{width:44px!important;height:44px!important}
}
.ba-pane{position:absolute;inset:0;overflow:hidden}
.ba-win{position:absolute;inset:0;display:flex;flex-direction:column}
.win-bar{display:flex;align-items:center;gap:7px;padding:12px 14px;flex:0 0 auto}
.win-bar i{width:10px;height:10px;border-radius:50%;display:block}
.win-body{flex:1;padding:26px clamp(20px,5vw,52px);display:flex;flex-direction:column;justify-content:center;gap:16px}

/* pane "Avec Praxia" (animé) */
.ba-after .ba-win{background:
  radial-gradient(120% 80% at 80% 0%,rgba(196,90,47,.14),transparent 60%),
  radial-gradient(120% 90% at 0% 100%,rgba(30,58,95,.12),transparent 55%),var(--paper)}
.ba-after .win-bar i{background:#e6c8b6}
.ba-after .win-bar i:nth-child(2){background:#ecd7c5}.ba-after .win-bar i:nth-child(3){background:#f0e0cf}
.pxa-h{font-family:'Fraunces',serif;font-size:clamp(20px,3.4vw,30px);line-height:1.08;color:var(--ink);margin:0}
.pxa-h em{font-style:italic;color:var(--orange)}
.pxa-bars{display:flex;flex-direction:column;gap:11px;margin-top:4px}
.pxa-bar{height:13px;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--orange-soft));
  background-size:220% 100%;animation:pxa-shimmer 2.6s linear infinite}
.pxa-bar.w1{width:78%}
.pxa-bar.w2{width:54%;background:linear-gradient(90deg,var(--night),var(--night-soft));background-size:220% 100%;animation:pxa-shimmer 3.1s linear infinite}
.pxa-bar.w3{width:66%;animation-delay:.4s}
.pxa-chart{display:flex;align-items:flex-end;gap:9px;height:74px;margin-top:6px}
.pxa-chart span{flex:1;border-radius:7px 7px 0 0;background:linear-gradient(180deg,var(--orange-soft),var(--orange));
  transform-origin:bottom;animation:pxa-grow 2.4s ease-in-out infinite alternate}
.pxa-chart span:nth-child(2){animation-delay:.3s;background:linear-gradient(180deg,var(--night-soft),var(--night))}
.pxa-chart span:nth-child(3){animation-delay:.6s}
.pxa-chart span:nth-child(4){animation-delay:.9s;background:linear-gradient(180deg,var(--night-soft),var(--night))}
.pxa-chart span:nth-child(5){animation-delay:1.2s}
.pxa-cta{align-self:flex-start;margin-top:6px;background:linear-gradient(135deg,var(--orange),var(--orange-soft));
  color:#fff;font-size:13px;font-weight:600;padding:10px 18px;border-radius:999px;
  box-shadow:0 8px 22px -8px rgba(196,90,47,.7);animation:pxa-pulse 2.4s ease-in-out infinite}
@keyframes pxa-shimmer{to{background-position:-220% 0}}
@keyframes pxa-grow{from{transform:scaleY(.45)}to{transform:scaleY(1)}}
@keyframes pxa-pulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}

/* pane "Site classique" (gris, figé) */
.ba-before{z-index:2}
.ba-before .ba-win{background:#fafafa}
.ba-before .win-bar i{background:#dcdcdc}
.cls-h{height:22px;width:62%;border-radius:5px;background:#e3e3e3;margin:0}
.cls-bars{display:flex;flex-direction:column;gap:11px;margin-top:4px}
.cls-bar{height:13px;border-radius:5px;background:#e9e9e9}
.cls-bar.w1{width:90%}.cls-bar.w2{width:72%}.cls-bar.w3{width:80%}.cls-bar.w4{width:48%}
.cls-block{height:74px;border-radius:6px;background:#ededed;margin-top:6px}
.cls-btn{align-self:flex-start;margin-top:6px;height:34px;width:120px;border-radius:6px;background:#e0e0e0}

/* labels + handle */
.ba-label{position:absolute;top:14px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;padding:6px 12px;border-radius:999px;backdrop-filter:blur(6px);z-index:3}
.ba-label.l{left:14px;background:rgba(255,255,255,.8);color:#8a8a8a;border:1px solid #e3e3e3}
.ba-label.r{right:14px;background:rgba(196,90,47,.14);color:var(--orange-deep);border:1px solid rgba(196,90,47,.3)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:#fff;transform:translateX(-50%);
  z-index:4;box-shadow:0 0 0 1px rgba(26,26,26,.12),0 0 24px rgba(0,0,0,.25);cursor:ew-resize;touch-action:none}
.ba-grab{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50px;height:50px;border-radius:50%;
  background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow-md);display:grid;place-items:center;color:var(--ink-soft)}
.ba-grab svg{display:block}
.ba-nudge{animation:ba-nudge 2.6s ease-in-out 1s 2}
@keyframes ba-nudge{0%,100%{left:50%}25%{left:38%}60%{left:62%}}

@media(prefers-reduced-motion:reduce){
  .pxa-bar,.pxa-chart span,.pxa-cta,.ba-nudge{animation:none}
}

/* ---------- Comparateur : panneau "Avec Praxia" enrichi ---------- */
.ba-after{overflow:hidden}
.ba-after .ba-win{background:linear-gradient(rgba(251,247,238,.80),rgba(251,247,238,.80));position:relative;z-index:1}
.pxa-aurora{position:absolute;inset:-25%;z-index:0;pointer-events:none;opacity:.75;filter:blur(20px);
  background:
   radial-gradient(40% 40% at 30% 30%,rgba(196,90,47,.40),transparent 60%),
   radial-gradient(45% 45% at 72% 62%,rgba(30,58,95,.34),transparent 60%),
   radial-gradient(35% 35% at 56% 24%,rgba(225,129,90,.34),transparent 60%);
  animation:pxa-aurora 9s ease-in-out infinite alternate}
@keyframes pxa-aurora{0%{transform:translate(-4%,-3%) scale(1)}100%{transform:translate(5%,4%) scale(1.14)}}
.pxa-kpi{align-self:flex-start;display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;
  color:var(--orange-deep);background:rgba(196,90,47,.12);border:1px solid rgba(196,90,47,.28);
  padding:5px 11px;border-radius:999px}
.pxa-kpi b{font-family:'JetBrains Mono',monospace}
.pxa-cta.pxa-press{filter:brightness(1.18) saturate(1.1)}
.pxa-cursor{position:absolute;left:50%;top:60%;z-index:3;pointer-events:none;width:16px;height:16px;
  transition:left 1.5s cubic-bezier(.5,0,.2,1),top 1.5s cubic-bezier(.5,0,.2,1)}
.pxa-cursor::before{content:"";position:absolute;left:0;top:0;width:14px;height:14px;border-radius:50%;
  background:rgba(26,26,26,.82);box-shadow:0 0 0 3px rgba(255,255,255,.7),0 2px 6px rgba(0,0,0,.3)}
.pxa-cursor.click::after{content:"";position:absolute;left:7px;top:7px;width:6px;height:6px;border-radius:50%;
  transform:translate(-50%,-50%);animation:pxa-ripple .6s ease-out}
@keyframes pxa-ripple{from{box-shadow:0 0 0 0 rgba(196,90,47,.55)}to{box-shadow:0 0 0 24px rgba(196,90,47,0)}}

/* ---------- Formulaire de devis ---------- */
.px-devis .container{position:relative;z-index:1}
.devis-wrap{max-width:780px;margin:30px auto 0}
.devis-form{display:grid;grid-template-columns:1fr 1fr;gap:16px;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r-xl);padding:clamp(20px,4vw,34px);box-shadow:var(--shadow-md)}
.devis-form .full{grid-column:1/-1}
@media(max-width:560px){.devis-form{grid-template-columns:1fr;gap:14px}}
.devis-field label{display:block;font-size:13px;font-weight:500;color:var(--ink-soft);margin-bottom:6px}
.devis-field input,.devis-field select,.devis-field textarea{width:100%;font:inherit;font-size:16px;color:var(--ink);
  background:var(--cream);border:1px solid var(--line-2);border-radius:var(--r-md);padding:12px 14px;
  transition:border-color .2s,box-shadow .2s}
.devis-field textarea{min-height:120px;resize:vertical;line-height:1.5}
.devis-field input:focus,.devis-field select:focus,.devis-field textarea:focus{outline:none;
  border-color:var(--orange);box-shadow:0 0 0 3px rgba(196,90,47,.15)}
.devis-hp{position:absolute!important;left:-9999px;width:1px;height:1px;overflow:hidden;opacity:0}
.devis-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:2px}
.devis-note{font-size:13px;color:var(--muted)}
.devis-status{font-size:14.5px;border-radius:var(--r-md);padding:0;max-height:0;overflow:hidden;transition:max-height .3s,padding .3s}
.devis-status.show{padding:13px 16px;max-height:160px;margin-top:4px}
.devis-status.ok{background:rgba(52,120,80,.12);border:1px solid rgba(52,120,80,.3);color:#2c5e3f}
.devis-status.err{background:rgba(196,90,47,.10);border:1px solid rgba(196,90,47,.3);color:var(--orange-deep)}
.btn[disabled]{opacity:.6;pointer-events:none}

/* ---------- Cartes démo (non cliquables) ---------- */
.rc-demo{cursor:default}
.rc-demo .rc-shot{transition:box-shadow .4s}
.rc-demo:hover .rc-shot{transform:none;border-color:var(--line);box-shadow:var(--shadow-md)}
.rc-demo:hover .rc-img img{transform:none}
.rc-badge{flex:0 0 auto;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  color:var(--muted);background:var(--cream-3);border:1px solid var(--line);padding:3px 9px;border-radius:999px}

/* ---------- Bannière Parrainage (mise en avant home) ---------- */
.px-parrain{padding:30px 0}
@media(min-width:780px){.px-parrain{padding:54px 0}}
.parrain-band{position:relative;overflow:hidden;border-radius:var(--r-xl);text-align:center;
  background:radial-gradient(120% 130% at 100% 0,rgba(196,90,47,.34),transparent 55%),
             linear-gradient(135deg,#15233b,#1E3A5F 55%,#13202f);
  color:#fff;padding:clamp(34px,6vw,66px) clamp(22px,5vw,48px);
  box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.08)}
.parrain-band::before{content:"";position:absolute;top:0;left:-60%;width:42%;height:100%;pointer-events:none;
  background:linear-gradient(110deg,transparent,rgba(255,255,255,.10),transparent);transform:skewX(-18deg);
  animation:parrain-sheen 6.5s ease-in-out infinite}
@keyframes parrain-sheen{0%{left:-60%}45%,100%{left:135%}}
.parrain-watermark{position:absolute;right:-1%;bottom:-26%;font-family:'Fraunces',serif;font-weight:600;
  font-size:clamp(130px,26vw,300px);line-height:1;color:rgba(255,255,255,.055);pointer-events:none;letter-spacing:-.04em;user-select:none}
.parrain-badge{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);color:#fff;font-size:13px;font-weight:600;padding:7px 14px;border-radius:999px;backdrop-filter:blur(4px)}
.parrain-band h2{position:relative;z-index:1;font-family:'Fraunces',serif;font-weight:400;line-height:1.06;
  font-size:clamp(30px,5.4vw,52px);margin:.35em 0 .3em;color:#fff;letter-spacing:-.01em}
.parrain-band h2 em{font-style:italic;background:linear-gradient(120deg,var(--orange-soft),#f3b094);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.parrain-band p{position:relative;z-index:1;color:rgba(255,255,255,.82);max-width:540px;margin:0 auto;
  font-size:clamp(15px,2.3vw,18px);line-height:1.6}
.parrain-band p strong{color:#fff}
.parrain-cta{position:relative;z-index:1;display:inline-flex;align-items:center;gap:.5em;margin-top:22px;
  background:linear-gradient(135deg,var(--orange),var(--orange-soft));color:#fff;font-weight:700;font-size:16px;
  padding:15px 28px;border-radius:999px;text-decoration:none;box-shadow:0 14px 30px -10px rgba(196,90,47,.85);
  transition:transform .15s,box-shadow .2s}
.parrain-cta:hover{transform:translateY(-2px);color:#fff;box-shadow:0 20px 44px -10px rgba(196,90,47,.95)}
.parrain-points{position:relative;z-index:1;display:flex;gap:18px;justify-content:center;flex-wrap:wrap;
  margin-top:18px;color:rgba(255,255,255,.72);font-size:13.5px}
@media(max-width:560px){.parrain-points{gap:10px 14px;font-size:12.5px}}
@media(prefers-reduced-motion:reduce){.parrain-band::before{animation:none;display:none}}
