/* ====================================================
   PAGE /demande-devis v2 — full-bleed navy + pattern mesh silos
   Aligné sur /contact (trait jaune signature, shadow couches,
   breadcrumb, banner contextuel, submit enrichi). Grid 60/40
   (form gauche, recap droite sticky). Le JS gère le toggle
   empty/content state sur la col droite.
   ==================================================== */

body:has(.devis-bleed){padding-top:0;background:var(--bleu-principal)}

.devis-bleed{
  min-height:100vh;
  position:relative;
  background:var(--bleu-principal);
  /* Dot grid 32px + 4 mesh gradients silos (même que /contact) */
  background-image:
    radial-gradient(circle,rgba(255,255,255,.09) 1px,transparent 1.5px),
    radial-gradient(ellipse 60% 50% at 80% 20%,rgba(255,255,255,.07) 0%,transparent 70%),
    radial-gradient(ellipse 55% 60% at 20% 70%,rgba(17,159,174,.16) 0%,transparent 70%),
    radial-gradient(ellipse 50% 45% at 65% 85%,rgba(60,149,210,.13) 0%,transparent 70%),
    radial-gradient(ellipse 45% 40% at 10% 15%,rgba(38,69,188,.12) 0%,transparent 70%);
  background-size:32px 32px,100% 100%,100% 100%,100% 100%,100% 100%
}

.devis-bleed__inner{padding:calc(var(--header-height,70px) + var(--s-7)) 0 var(--s-8);position:relative;z-index:1}

/* Breadcrumb top (pattern /contact) */
.devis-bleed__breadcrumb{font-size:var(--fs-small);color:color-mix(in srgb,var(--blanc) 65%,transparent);margin-bottom:var(--s-6);letter-spacing:.01em}
.devis-bleed__breadcrumb a{color:inherit;text-decoration:none;opacity:.85;transition:opacity .2s ease,color .2s ease}
.devis-bleed__breadcrumb a:hover{opacity:1;color:var(--jaune)}
.devis-bleed__breadcrumb .breadcrumbs-separator,.devis-bleed__breadcrumb span{opacity:.5;margin-inline:.4em}

/* Grid principal : form (60) | recap (40) */
.devis-bleed__grid{align-items:start;gap:var(--s-6)}

/* ====================================================
   CARD COMMUNE : form + recap partagent le pattern blanc
   avec trait jaune signature + shadow en couches
   ==================================================== */
.devis-bleed__form-card,
.devis-bleed__recap-card{
  background:var(--blanc);
  border-radius:var(--r-md);
  padding:var(--s-7) var(--s-6) var(--s-6);
  position:relative;
  z-index:1;
  box-shadow:
    0 0 0 1px color-mix(in srgb,var(--blanc) 6%,transparent),
    0 32px 80px rgba(0,0,0,.32),
    0 14px 36px rgba(0,0,0,.14),
    inset 0 1px 0 rgba(255,255,255,.85)
}

.devis-bleed__form-card::before,
.devis-bleed__recap-card::before{
  content:'';
  position:absolute;
  top:0;
  left:var(--s-6);
  width:48px;
  height:3px;
  background:var(--jaune);
  border-radius:0 0 var(--r-sm) var(--r-sm)
}

.devis-bleed__recap-card{position:sticky;top:calc(var(--header-height,70px) + var(--s-3))}

/* ====================================================
   COL GAUCHE : FORM
   ==================================================== */
.devis-bleed__form-head{margin-bottom:var(--s-5)}
.devis-bleed__form-head h1{font-size:var(--fs-h3);margin:0 0 var(--s-2);color:var(--text);font-weight:600;text-align:left;line-height:1.2}
.devis-bleed__form-head p{color:var(--muted);margin:0;font-size:var(--fs-body);line-height:1.5}

/* Override : pas de padding-top form dans la card */
.devis-bleed__form-card #form-devis{padding-top:0}

/* Bannière contextuelle réutilise le style /contact */
.devis-bleed .contact-context-banner{display:flex;align-items:center;gap:var(--s-3);padding:var(--s-3) var(--s-4);margin-bottom:var(--s-5);background:color-mix(in srgb,var(--jaune) 5%,var(--blanc));border-left:3px solid var(--jaune);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:var(--fs-small);color:var(--muted);line-height:1.5;animation:devisBannerIn .35s cubic-bezier(.4,0,.2,1) both}
.devis-bleed .contact-context-banner[hidden]{display:none}
.devis-bleed .contact-context-banner i{font-size:18px;color:var(--jaune);flex-shrink:0}
.devis-bleed .contact-context-banner strong{color:var(--text);font-weight:600}
@keyframes devisBannerIn{from{opacity:0;transform:translateX(-4px)}to{opacity:1;transform:translateX(0)}}

/* Submit enrichi (pattern /contact) */
.devis-bleed__form-card .btn-submit{display:inline-flex;align-items:baseline;gap:var(--s-3);flex-wrap:wrap;justify-content:center;min-width:260px}
.devis-bleed__form-card .btn-submit .btn-submit__hint{font-family:'Satoshi',sans-serif;font-weight:400;font-size:var(--fs-small);opacity:.78;position:relative;padding-left:var(--s-3);border-left:1px solid color-mix(in srgb,var(--blanc) 30%,transparent);letter-spacing:0;text-transform:none;color:var(--blanc)}
.devis-bleed__form-card .form-navigation{display:flex;flex-direction:column;gap:var(--s-3);align-items:flex-start;margin-top:var(--s-4)}

/* ====================================================
   COL DROITE : RECAP (empty ou content state)
   ==================================================== */

/* Empty state : kicker + titre + sub + silos + 3 steps */
.devis-bleed__empty{display:flex;flex-direction:column;gap:var(--s-5);text-align:left;align-items:stretch}
.devis-bleed__empty-head{display:flex;flex-direction:column;gap:var(--s-2)}
.devis-bleed__empty-kicker,
.devis-bleed__recap-kicker{
  display:inline-flex;align-items:center;gap:var(--s-2);
  padding:var(--s-1) var(--s-3);
  background:color-mix(in srgb,var(--jaune) 10%,transparent);
  border:1px solid color-mix(in srgb,var(--jaune) 40%,transparent);
  border-radius:var(--r-pill);
  font-size:var(--fs-small);
  color:var(--text);
  font-weight:500;
  align-self:flex-start;
  margin:0 0 var(--s-2)
}
.devis-bleed__empty-kicker i,
.devis-bleed__recap-kicker i{font-size:14px;color:var(--bleu-principal)}

.devis-bleed__empty-title{font-family:'Satoshi',sans-serif;font-weight:600;font-size:var(--fs-h4);color:var(--text);line-height:1.25;margin:0}
.devis-bleed__empty-sub{color:var(--muted);margin:0;font-size:var(--fs-small);line-height:1.55}

/* Silos : grid 3 cols compact (override du pattern header.css si besoin) */
.devis-bleed__silos{width:100%;margin:0}
.devis-bleed__silos .search-silo img{width:56px;height:56px;object-fit:contain}
.devis-bleed__silos .search-silo{padding:var(--s-4) var(--s-2)}
.devis-bleed__silos .search-silo-label{font-size:var(--fs-small)}
.devis-bleed__silos .search-silo-meta{font-size:11px}

/* 3 steps process : timeline micro */
.devis-bleed__steps{list-style:none;padding:var(--s-4) 0 0;margin:0;display:flex;flex-direction:column;gap:var(--s-3);border-top:1px solid color-mix(in srgb,var(--text) 10%,transparent)}
.devis-bleed__steps li{display:flex;align-items:center;gap:var(--s-3);color:var(--text);font-size:var(--fs-small);line-height:1.5}
.devis-bleed__step-num{
  font-family:'Satoshi',sans-serif;
  font-weight:700;
  font-size:14px;
  width:24px;
  height:24px;
  border-radius:50%;
  background:var(--jaune);
  color:var(--bleu-principal);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  line-height:1
}
.devis-bleed__step-label{color:var(--muted)}
.devis-bleed__step-label strong{color:var(--text);font-weight:600}

/* Content state (panier rempli) */
.devis-bleed__content{display:flex;flex-direction:column;gap:var(--s-4)}
.devis-bleed__recap-head{display:flex;flex-direction:column;gap:var(--s-2);margin-bottom:var(--s-2)}
.devis-bleed__recap-title{font-family:'Satoshi',sans-serif;font-weight:600;font-size:var(--fs-h4);color:var(--text);line-height:1.25;margin:0}
.devis-bleed__recap-sub{color:var(--muted);margin:0;font-size:var(--fs-small);line-height:1.55}

/* ====================================================
   RESPONSIVE
   ==================================================== */
@media (max-width:1024px){
  .devis-bleed__inner{padding:calc(var(--header-height-mobile,60px) + var(--s-5)) 0 var(--s-6)}

  .devis-bleed__grid{gap:var(--s-5)}

  /* Card recap : ne plus être sticky en mobile (grid stacke) */
  .devis-bleed__recap-card{position:static}

  /* Cards : décaler trait jaune + réduire padding */
  .devis-bleed__form-card::before,
  .devis-bleed__recap-card::before{left:var(--s-4)}
  .devis-bleed__form-card,
  .devis-bleed__recap-card{padding:var(--s-5) var(--s-4) var(--s-5)}

  .devis-bleed__form-head{margin-bottom:var(--s-4)}
  .devis-bleed__form-head h1{font-size:var(--fs-h4)}

  /* Submit full-width mobile + hint dessous */
  .devis-bleed__form-card .btn-submit{min-width:0;width:100%;padding:14px 24px}
  .devis-bleed__form-card .btn-submit__hint{display:block;font-size:var(--fs-small);margin-top:2px;border-left:none;padding-left:0;opacity:.78}
  .devis-bleed__form-card .form-navigation{align-items:stretch;width:100%}
}

@media (max-width:640px){
  .devis-bleed__form-card,
  .devis-bleed__recap-card{padding:var(--s-4)}
}
