/* ==========================================================
   Devis public — Iliade Digital (Premium clean + cards mobile)
   Path: /assets/css/devis-public.css
   ========================================================== */

.il-devis-public{
  margin:0;
  padding:0;
  font-family: var(--font-sans, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif);
  color: var(--text, #111827);
  background:
    radial-gradient(1200px 600px at 20% 0%, rgba(23,160,81,.12), transparent 55%),
    radial-gradient(900px 500px at 90% 10%, rgba(16,19,35,.03), transparent 60%),
    var(--bg-soft, #F2F3F4);
  line-height: 1.55;
}
.il-devis-public *{ box-sizing:border-box; }

.il-devis-public__wrap{
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: clamp(12px, 2.2vw, 22px);
}

/* ✅ plus large */
.il-devis-public__shell{
  width:100%;
  max-width: 1240px;
}

/* ==========================================================
   Topbar
   ========================================================== */
.il-devis-public__topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(10px);
  box-shadow: 0 14px 34px rgba(16,19,35,.10);
  margin-bottom: 12px;
}

.il-devis-public__brand{
  display:flex;
  align-items:center;
  gap: 12px;
  min-width:0;
}

/* ✅ logo réel */
.il-devis-public__brandLogo{
  width: 150px;
  height: 44px;
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 26px rgba(16,19,35,.12);
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
  overflow:hidden;
}
.il-devis-public__brandLogoImg{
  width: 100%;
  height: 90%;
  object-fit: contain;
  display:block;
}

.il-devis-public__kicker{
  font-family: var(--font-head, var(--font-sans));
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--muted, #666672);
}
.il-devis-public__meta{
  display:flex;
  align-items:center;
  gap: 8px;
  margin-top: 2px;
  min-width:0;
}
.il-devis-public__doc{
  font-family: var(--font-head, var(--font-sans));
  font-size: 18px;
  font-weight: 900;
  color: var(--text, #111827);
}
.il-devis-public__sep{ color: var(--muted-2, #98999D); }
.il-devis-public__docId{
  font-size: 14px;
  font-weight: 900;
  color: var(--text-2, #2B2F3A);
  white-space:nowrap;
}

/* status badge */
.il-devis-public__statusWrap{
  display:grid;
  justify-items:end;
  gap: 6px;
}
.il-devis-public__statusLabel{
  font-size: 12px;
  font-weight: 900;
  color: var(--muted, #666672);
}
.il-devis-public__badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 12px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 22px rgba(16,19,35,.08);
}
.il-devis-public__badge::before{
  content:"";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--muted-2, #98999D);
  box-shadow: 0 0 0 3px rgba(16,19,35,.06);
}
.il-devis-public__badge.is-accepted{ background: rgba(23,160,81,.10); }
.il-devis-public__badge.is-accepted::before{ background: var(--brand-green,#17A051); box-shadow: 0 0 0 3px rgba(23,160,81,.14); }
.il-devis-public__badge.is-sent::before{ background:#2F80ED; box-shadow: 0 0 0 3px rgba(47,128,237,.14); }
.il-devis-public__badge.is-refused::before{ background:#E11D48; box-shadow: 0 0 0 3px rgba(225,29,72,.14); }
.il-devis-public__badge.is-expired::before{ background:#F59E0B; box-shadow: 0 0 0 3px rgba(245,158,11,.16); }

/* ==========================================================
   Card
   ========================================================== */
.il-devis-public__card{
  width:100%;
  border-radius: 20px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 26px 70px rgba(16,19,35,.16);
  overflow:hidden;
}

.il-devis-public__notice{
  margin: 14px;
  padding: 12px 14px;
  border-radius: 14px;
  font-weight: 900;
}
.il-devis-public__notice.is-error{ background: rgba(225,29,72,.08); color:#9F1239; }
.il-devis-public__notice.is-success{ background: rgba(23,160,81,.10); color:#065F46; }

/* ==========================================================
   Panels
   ========================================================== */
.il-devis-public__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 14px;
}
.il-devis-public__panel{
  border-radius: 16px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 30px rgba(16,19,35,.08);
  padding: 12px;
}
.il-devis-public__panelHead{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.il-devis-public__h2{
  margin:0;
  font-family: var(--font-head, var(--font-sans));
  font-size: 16px;
  font-weight: 900;
}
.il-devis-public__hint{
  font-size: 12px;
  color: var(--muted, #666672);
  font-weight: 800;
  white-space:nowrap;
}

.il-devis-public__kv{ display:grid; gap: 8px; }
.il-kv{
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--surface-2, #F7F8FA);
}
.il-kv__k{
  font-size: 12px;
  color: var(--muted, #666672);
  font-weight: 900;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.il-kv__v{
  margin-top: 2px;
  font-size: 14px;
  font-weight: 800;
  color: var(--text, #111827);
  word-break: break-word;
}

/* ==========================================================
   Sections
   ========================================================== */
.il-devis-public__section{
  padding: 14px;
  border-top: 1px solid rgba(16,19,35,.06);
}
.il-devis-public__sectionHead{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 10px;
  margin-bottom: 10px;
}

/* ==========================================================
   TABLE (desktop)
   - lignes plus basses + “Total TTC”
   ========================================================== */
.il-devis-public__tableWrap{
  border-radius: 16px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 12px 30px rgba(16,19,35,.08);
  overflow:hidden;
}
.il-devis-public__tableScroll{
  overflow:auto;
  -webkit-overflow-scrolling: touch;
  padding: 6px;
}
.il-table{
  width:100%;
  min-width: 780px;
  border-collapse: separate;
  border-spacing: 0;
  font-weight: 850;
  color: var(--text-2, #2B2F3A);
}
.il-table thead th{
  position: sticky;
  top: 0;
  z-index: 2;
  text-align:left;
  font-size: 12px;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--muted, #666672);
  background: linear-gradient(135deg, rgba(23,160,81,.10), rgba(255,255,255,.92));
  padding: 10px 12px; /* ✅ hauteur réduite */
  border-bottom: 1px solid rgba(16,19,35,.08);
}
.il-table tbody td{
  padding: 10px 12px; /* ✅ hauteur réduite */
  border-bottom: 1px solid rgba(16,19,35,.06);
  background: rgba(255,255,255,.96);
}
.il-table tbody tr:last-child td{ border-bottom: 0; }

.col-qty, .col-unit, .col-tva, .col-total { width: 140px; }
.cell-label{ font-weight: 900; color: var(--text, #111827); }
.cell-num{ text-align:right; font-variant-numeric: tabular-nums; }
.cell-strong{ color: var(--brand-navy, #101323); }

/* ==========================================================
   CARDS (mobile)
   ========================================================== */
.il-devis-public__cards{
  display:none;
  gap: 10px;
}
.il-cardLine{
  border-radius: 16px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 12px 30px rgba(16,19,35,.08);
  padding: 12px;
}
.il-cardLine__title{
  font-weight: 950;
  color: var(--text, #111827);
  margin-bottom: 10px;
}
.il-cardLine__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.il-cardLine__kv{
  border-radius: 14px;
  background: var(--surface-2, #F7F8FA);
  padding: 10px 12px;
}
.il-cardLine__kv span{
  display:block;
  font-size: 12px;
  color: var(--muted, #666672);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .03em;
}
.il-cardLine__kv strong{
  display:block;
  margin-top: 4px;
  font-weight: 950;
  color: var(--text, #111827);
  font-variant-numeric: tabular-nums;
}
.il-cardLine__kv--total{
  grid-column: 1 / -1;
  background: linear-gradient(135deg, rgba(23,160,81,.12), rgba(247,248,250,.92));
}

/* ==========================================================
   Totals
   ========================================================== */
.il-devis-public__totals{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 10px;
}
.il-total{
  border-radius: 16px;
  padding: 12px 14px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 12px 30px rgba(16,19,35,.08);
}
.il-total span{
  display:block;
  font-size: 12px;
  color: var(--muted, #666672);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing:.03em;
}
.il-total strong{
  display:block;
  margin-top: 4px;
  font-family: var(--font-head, var(--font-sans));
  font-size: 18px;
  font-weight: 900;
  color: var(--text, #111827);
}
.il-total--grand{
  background: linear-gradient(135deg, rgba(23,160,81,.12), rgba(255,255,255,.94));
}

/* ==========================================================
   Logistics list
   ========================================================== */
.il-devis-public__list{
  margin:0;
  padding-left: 18px;
  color: var(--text-2, #2B2F3A);
  font-weight: 750;
}
.il-devis-public__list li{ margin: 8px 0; }
.il-devis-public__list strong{ color: var(--text, #111827); font-weight: 900; }

/* ==========================================================
   Legal
   ========================================================== */
.il-devis-public__legal{
  border-radius: 16px;
  padding: 12px;
  background: rgba(247,248,250,.92);
  box-shadow: inset 0 0 0 1px rgba(16,19,35,.06);
}
.il-devis-public__legalText{
  margin:0 0 10px;
  color: var(--text-2, #2B2F3A);
  font-weight: 750;
}
.il-devis-public__cgv{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight: 900;
  color: var(--brand-green, #17A051);
  text-decoration:none;
}
.il-devis-public__cgv:hover{ text-decoration:underline; }

.il-devis-public__check{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  margin-top: 10px;
  font-weight: 900;
  color: var(--text, #111827);
}
.il-devis-public__check input{
  margin-top: 4px;
  width: 18px;
  height: 18px;
  accent-color: var(--brand-green, #17A051);
}
.il-devis-public__check span{ font-size: 14px; font-weight: 850; }

/* ==========================================================
   Buttons
   ========================================================== */
.il-devis-public__btn{
  width:100%;
  height: 46px;
  border:0;
  border-radius: 12px;
  padding: 0 16px;
  font-weight: 950;
  cursor:pointer;
  color:#fff;
  background: linear-gradient(135deg, var(--brand-green,#17A051), var(--brand-green-2,#64CA4F));
  box-shadow: 0 16px 40px rgba(23,160,81,.20);
  transition: transform .15s cubic-bezier(.2,.8,.2,1), box-shadow .15s cubic-bezier(.2,.8,.2,1), opacity .15s;
}
.il-devis-public__btn:hover{ transform: translateY(-1px); box-shadow: 0 20px 50px rgba(23,160,81,.24); }
.il-devis-public__btn:active{ transform: translateY(0); }
.il-devis-public__btn:disabled{ opacity:.6; cursor:not-allowed; transform:none; box-shadow:none; }
.il-devis-public__btn--inline{ margin-top: 12px; }

/* ==========================================================
   Sticky mobile CTA
   ========================================================== */
.il-devis-public__sticky{
  position:fixed;
  left:0; right:0; bottom:0;
  z-index: 999999;
  padding: 12px clamp(12px, 2.2vw, 20px);
  background: rgba(255,255,255,.84);
  backdrop-filter: blur(10px);
  box-shadow: 0 -18px 44px rgba(16,19,35,.14);
}
.il-devis-public__stickyHint{
  margin-top: 6px;
  font-size: 12px;
  font-weight: 850;
  color: var(--muted, #666672);
  text-align:center;
}
@media (max-width: 820px){
  .il-devis-public__wrap{ padding-bottom: 92px; }
}

/* ==========================================================
   Modal
   ========================================================== */
.il-modal[hidden]{ display:none; }
.il-modal{
  position:fixed;
  inset:0;
  z-index: 999999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 18px;
}
.il-modal__backdrop{ position:absolute; inset:0; background: rgba(16,19,35,.55); }
.il-modal__dialog{
  position:relative;
  width:100%;
  max-width: 560px;
  border-radius: 20px;
  padding: 18px;
  background: rgba(255,255,255,.94);
  box-shadow: 0 30px 80px rgba(16,19,35,.25);
  backdrop-filter: blur(10px);
}
.il-modal__title{
  font-family: var(--font-head, var(--font-sans));
  font-size: 20px;
  font-weight: 950;
  margin-bottom: 8px;
}
.il-modal__text{ color: var(--text-2,#2B2F3A); font-weight: 750; }
.il-modal__btn{
  margin-top: 14px;
  width:100%;
  height: 46px;
  border:0;
  border-radius: 12px;
  padding:0 16px;
  font-weight: 950;
  cursor:pointer;
  background: var(--brand-navy, #101323);
  color:#fff;
}

/* ==========================================================
   Responsive
   ========================================================== */
@media (max-width: 920px){
  .il-devis-public__grid{ grid-template-columns: 1fr; }
  .il-devis-public__statusWrap{ justify-items:start; }
}
@media (max-width: 820px){
  /* ✅ mobile : cards ON, table OFF */
  .il-devis-public__tableWrap{ display:none; }
  .il-devis-public__cards{ display:grid; }
  .il-devis-public__totals{ grid-template-columns: 1fr; }
  .il-devis-public__btn--inline{ display:none; }
}
@media (min-width: 821px){
  .il-devis-public__sticky{ display:none; }
}




/* =========================
   PATCH — Cards mobile : 3 colonnes + total full width
   ========================= */
@media (max-width: 820px){

  .il-cardLine__grid{
    grid-template-columns: repeat(3, 1fr); /* ✅ 3 colonnes */
    gap: 10px;
  }

  /* ✅ Total passe en dessous sur toute la largeur */
  .il-cardLine__kv--total{
    grid-column: 1 / -1;
  }

  /* ✅ un peu plus compact (tu voulais réduire la hauteur) */
  .il-cardLine{
    padding: 10px;
  }

  .il-cardLine__kv{
    padding: 9px 10px;
  }

  .il-cardLine__title{
    margin-bottom: 8px;
  }
}



/* ==========================================================
   Logistics icons (premium)
   ========================================================== */
.il-devis-public__list--icons{
  list-style: none;
  padding-left: 0;
  margin: 0;
  display: grid;
  gap: 10px;
}

.il-devis-public__list--icons .il-li{
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 22px rgba(16,19,35,.06);
  border: 1px solid rgba(16,19,35,.06);
}

.il-devis-public__list--icons .il-ico{
  width: 26px;
  height: 26px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(23,160,81,.14), rgba(16,19,35,.06));
  border: 1px solid rgba(23,160,81,.16);
  position: relative;
  box-shadow: 0 10px 18px rgba(16,19,35,.10);
}

.il-devis-public__list--icons .il-ico::after{
  content:"";
  position:absolute;
  inset: 6px;
  background: var(--brand-green, #17A051);
  -webkit-mask: var(--il-mask) center / contain no-repeat;
          mask: var(--il-mask) center / contain no-repeat;
}

/* Icons (inline SVG masks) */
.il-devis-public__list--icons .is-address{ --il-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 22s7-4.4 7-11a7 7 0 1 0-14 0c0 6.6 7 11 7 11zm0-9a2 2 0 1 1 0-4 2 2 0 0 1 0 4z'/%3E%3C/svg%3E"); }
.il-devis-public__list--icons .is-delivery{ --il-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3 7h11v10H3V7zm12 2h3l3 3v5h-6V9zm-9 9a2 2 0 1 0 0 4 2 2 0 0 0 0-4zm12 0a2 2 0 1 0 0 4 2 2 0 0 0 0-4z'/%3E%3C/svg%3E"); }
.il-devis-public__list--icons .is-pickup{ --il-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2a6 6 0 0 1 6 6c0 4-6 10-6 10S6 12 6 8a6 6 0 0 1 6-6zm0 8a2 2 0 1 0 0-4 2 2 0 0 0 0 4zM6 20h12v2H6v-2z'/%3E%3C/svg%3E"); }
.il-devis-public__list--icons .is-lead{ --il-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 8V4h2v6l-5 3-1-1 4-2zM12 2a10 10 0 1 0 0 20 10 10 0 0 0 0-20z'/%3E%3C/svg%3E"); }
.il-devis-public__list--icons .is-deadline{ --il-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2v2H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6a2 2 0 0 0-2-2h-2V2h-2v2H9V2H7zm12 8H5V8h14v2z'/%3E%3C/svg%3E"); }
.il-devis-public__list--icons .is-contact{ --il-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 12a5 5 0 1 0-5-5 5 5 0 0 0 5 5zm0 2c-5 0-9 3-9 7h18c0-4-4-7-9-7z'/%3E%3C/svg%3E"); }
.il-devis-public__list--icons .is-constraints{ --il-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l9 4v6c0 5-4 9-9 10C7 21 3 17 3 12V6l9-4zm1 6h-2v6h2V8zm0 8h-2v2h2v-2z'/%3E%3C/svg%3E"); }

/* Mobile: un peu plus compact */
@media (max-width: 820px){
  .il-devis-public__list--icons .il-li{ padding: 9px 10px; }
  .il-devis-public__list--icons .il-ico{ width: 24px; height: 24px; border-radius: 9px; }
}