/* ======================================================
   Iliade Digital — Page Services (PRO)
   File: assets/css/page-services.css
   Depends: variables.css + styles.css
   Objectif: styles spécifiques à la page Services uniquement
   ====================================================== */

.il-servicesPage{
  position: relative;
}

/* ======================================================
   HERO
   ====================================================== */

.il-servicesHero{
  position: relative;
  overflow: hidden;
  padding-block: clamp(34px, 5.2vw, 84px);
  background:
    radial-gradient(900px 420px at 12% 20%, var(--alpha-brand-12, rgba(23,160,81,.12)), transparent 60%),
    radial-gradient(900px 420px at 86% 22%, rgba(47,128,237,.08), transparent 60%),
    linear-gradient(var(--white), var(--white));
  border-bottom: 1px solid var(--line);
}

.il-servicesHero__grid{
  display: grid;
  gap: clamp(16px, 3vw, 28px);
  align-items: start;
}

@media (min-width: 980px){
  .il-servicesHero__grid{
    grid-template-columns: 1.2fr .8fr;
    align-items: center;
  }
}

.il-servicesHero__kicker{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-head);
  font-weight: 900;
  color: var(--brand-green);
  margin: 0 0 10px;
}
.il-servicesHero__kicker::before{
  content: "";
  width: 26px;
  height: 10px;
  border-radius: 999px;
  background: var(--alpha-brand-18, rgba(23,160,81,.18));
  border: 1px solid var(--alpha-brand-22, rgba(23,160,81,.22));
}

.il-servicesHero__lead{
  max-width: 66ch;
  color: var(--text-2);
  font-size: clamp(16px, 1.35vw, 18px);
}

.il-servicesHero__cta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 16px;
}

/* facts */
.il-servicesHero__facts{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}
.il-servicesHero__fact{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
}
.il-servicesHero__factKpi{
  font-family: var(--font-head);
  font-weight: 900;
  color: var(--brand-green);
}
.il-servicesHero__factTxt{
  color: var(--muted);
  font-weight: 700;
}

/* right panel */
.il-servicesHero__panel{
  position: relative;
}

.il-servicesHero__panelInner{
  background: var(--panel-bg, rgba(255,255,255,.72));
  border: 1px solid var(--line);
  border-radius: var(--r-18);
  box-shadow: var(--shadow-md);
  padding: clamp(16px, 2.6vw, 22px);
  backdrop-filter: saturate(1.1) blur(2px);
}

.il-servicesHero__panelHead{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.il-servicesHero__panelTitle{
  font-size: var(--fs-20);
  margin: 0;
}

.il-servicesHero__badge{
  display:inline-flex;
  align-items:center;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--pill-soft-bg, rgba(23,160,81,.10));
  border: 1px solid var(--pill-soft-brd, rgba(23,160,81,.18));
  color: var(--brand-green);
  font-family: var(--font-head);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: .02em;
  text-transform: uppercase;
}

/* checklist */
.il-servicesHero__check{
  list-style: none;
  padding: 0;
  margin: 0 0 14px;
  display: grid;
  gap: 10px;
}
.il-servicesHero__check li{
  position: relative;
  padding-left: 28px;
  color: var(--text-2);
}
.il-servicesHero__check li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 0.45em;
  width: 12px;
  height: 12px;
  border-radius: 4px;
  background: var(--brand-green);
  box-shadow: 0 0 0 5px var(--alpha-brand-14, rgba(23,160,81,.14));
}

.il-servicesHero__panelCta{
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.il-servicesHero__mini{
  color: var(--brand-green);
  font-weight: 900;
  font-family: var(--font-head);
  text-decoration: none;
}
@media (hover:hover){
  .il-servicesHero__mini:hover{ text-decoration: underline; }
}

/* ======================================================
   HERO ANIMATION (Workflow console)
   ====================================================== */

.il-svcAnim{
  position: relative;
  display: grid;
  gap: 10px;
  margin-top: 6px;
  padding: 12px;
  border-radius: var(--r-16);
  border: 1px solid var(--alpha-ink-10, rgba(16,19,35,.10));
  background:
    radial-gradient(520px 220px at 20% 0%, rgba(23,160,81,.10), transparent 60%),
    rgba(255,255,255,.72);
  overflow: hidden;
}

.il-svcAnim::before{
  content:"";
  position:absolute;
  inset:-40% -20%;
  background: radial-gradient(closest-side, rgba(23,160,81,.18), transparent 70%);
  opacity: .50;
  transform: translateY(10px);
  pointer-events:none;
  transition: transform 650ms var(--ease), opacity 650ms var(--ease);
}
.il-svcAnim.is-inview::before{
  opacity: .85;
  transform: translateY(0);
}

.il-svcAnim__top{
  display:flex;
  flex-wrap: wrap;
  gap: 8px;
}

.il-svcAnim__pill{
  display:inline-flex;
  align-items:center;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--brand-green);
  color: var(--white);
  font-weight: 900;
  font-family: var(--font-head);
  font-size: 12px;
}
.il-svcAnim__pill--soft{
  background: rgba(255,255,255,.78);
  border: 1px solid var(--alpha-ink-10, rgba(16,19,35,.10));
  color: var(--text);
}

.il-svcAnim__row{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 10px;
  align-items: stretch;
}
@media (max-width: 520px){
  .il-svcAnim__row{ grid-template-columns: 1fr; }
}

.il-svcAnim__scan{
  position: relative;
  border-radius: var(--r-14);
  border: 1px solid var(--alpha-ink-10, rgba(16,19,35,.10));
  background: rgba(255,255,255,.78);
  padding: 10px 12px;
  overflow: hidden;
  min-height: 52px;
}

.il-svcAnim__scanBar{
  position:absolute;
  left: -30%;
  top: 0;
  width: 30%;
  height: 100%;
  background: linear-gradient(90deg, rgba(23,160,81,0), rgba(23,160,81,.18), rgba(23,160,81,0));
  filter: blur(.2px);
  opacity: 0;
}
.il-svcAnim.is-inview .il-svcAnim__scanBar{
  opacity: 1;
  animation: il-scan 1600ms linear infinite;
}
@keyframes il-scan{
  from{ transform: translateX(0); }
  to{ transform: translateX(520%); }
}

.il-svcAnim__scanTxt{
  position: relative;
  display:grid;
  gap: 2px;
}
.il-svcAnim__scanK{
  font-size: 12px;
  color: var(--muted);
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.il-svcAnim__scanV{
  font-family: var(--font-head);
  font-weight: 900;
  color: var(--text);
  letter-spacing: -0.01em;
  font-size: 13px;
}

.il-svcAnim__kpis{
  display:grid;
  gap: 8px;
}
.il-svcAnim__kpi{
  border-radius: var(--r-14);
  border: 1px solid var(--alpha-ink-10, rgba(16,19,35,.10));
  background: rgba(255,255,255,.72);
  padding: 10px 12px;
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.il-svcAnim__k{
  font-size: 12px;
  font-family: var(--font-head);
  font-weight: 900;
  color: var(--text);
}
.il-svcAnim__v{
  font-family: var(--font-head);
  font-weight: 900;
  color: var(--brand-green);
  letter-spacing: -0.01em;
}

/* Progress */
.il-svcAnim__progress{
  display:grid;
  gap: 8px;
  padding-top: 2px;
}
.il-svcAnim__progressLabel{
  font-size: 12px;
  color: var(--muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .02em;
}
.il-svcAnim__bar{
  position: relative;
  height: 10px;
  border-radius: 999px;
  background: rgba(16,19,35,.10);
  overflow:hidden;
}
.il-svcAnim__barFill{
  position:absolute;
  inset: 0;
  width: 0%;
  background: linear-gradient(90deg, rgba(23,160,81,.20), rgba(23,160,81,.95));
  border-radius: 999px;
  transition: width 1200ms var(--ease);
}
.il-svcAnim.is-inview .il-svcAnim__barFill{
  width: 86%;
}

.il-svcAnim__progressMeta{
  display:flex;
  justify-content: space-between;
  font-size: 11px;
  color: var(--muted);
}

/* reduce motion */
@media (prefers-reduced-motion: reduce){
  .il-svcAnim::before{ transition:none !important; }
  .il-svcAnim__barFill{ transition:none !important; }
  .il-svcAnim.is-inview .il-svcAnim__scanBar{ animation:none !important; opacity: 0 !important; }
}

/* ======================================================
   CONTENT (éditeur)
   ====================================================== */
.il-servicesPage__content{
  max-width: 880px;
}

/* ======================================================
   OFFER / SERVICES GRID
   ====================================================== */

.il-servicesOffer{
  position: relative;
}

.il-servicesOffer__head{
  max-width: 820px;
  margin-bottom: clamp(18px, 3vw, 26px);
}

.il-svcCard{
  position: relative;
  overflow: hidden;
}

.il-svcCard__top{
  display: flex;
  justify-content: flex-start;
  margin-bottom: 10px;
}

.il-svcCard__tag{
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--pill-soft-brd, rgba(23,160,81,.18));
  background: var(--pill-soft-bg, rgba(23,160,81,.10));
  color: var(--brand-green);
  font-family: var(--font-head);
  font-weight: 900;
  font-size: var(--fs-12);
  letter-spacing: .02em;
}

.il-svcCard__title{
  margin: 0 0 8px;
}

.il-svcCard__desc{
  margin: 0 0 14px;
}

.il-svcCard__link{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-head);
  font-weight: 900;
  color: var(--brand-green);
}
@media (hover:hover){
  .il-svcCard__link:hover{ text-decoration: underline; }
}

.il-servicesOffer__cta{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: clamp(18px, 3vw, 26px);
}

/* léger glow sur cartes (sans toucher à .il-card global) */
.il-svcCard::before{
  content:"";
  position: absolute;
  inset: -40% -25%;
  background: radial-gradient(closest-side, var(--alpha-brand-16, rgba(23,160,81,.16)), transparent 70%);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity var(--t-med) var(--ease), transform var(--t-med) var(--ease);
  pointer-events: none;
}
@media (hover:hover){
  .il-svcCard:hover::before{
    opacity: 1;
    transform: translateY(0);
  }
}

/* ======================================================
   METHOD / TIMELINE
   ====================================================== */

.il-servicesMethod__head{
  max-width: 820px;
  margin-bottom: clamp(18px, 3vw, 26px);
}

.il-method{
  --lineW: 2px;
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 14px;
}

.il-method__item{
  position: relative;
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 14px;
  align-items: start;
}

.il-method__item::before{
  content:"";
  position: absolute;
  left: 12px;
  top: 0;
  bottom: -14px;
  width: var(--lineW);
  background: rgba(23,160,81,.22);
  border-radius: 99px;
}
.il-method__item:last-child::before{
  bottom: 50%;
}

.il-method__dot{
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--brand-green);
  box-shadow: 0 0 0 6px var(--alpha-brand-14, rgba(23,160,81,.14));
  margin-top: 14px;
}

.il-method__card{
  background: rgba(255,255,255,.78);
  border: 1px solid var(--line);
  border-radius: var(--r-16);
  padding: 16px 16px 18px;
  box-shadow: var(--shadow-sm);
}

.il-method__card h3{
  margin: 0 0 6px;
  font-size: var(--fs-18);
}

.il-method__card p{
  margin: 0;
}

/* desktop: 2 colonnes */
@media (min-width: 980px){
  .il-method{
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 22px;
  }
  .il-method__item::before{
    bottom: -18px;
  }
}

/* ======================================================
   GUARANTEES
   ====================================================== */

.il-servicesGuarantees__head{
  max-width: 820px;
  margin-bottom: clamp(18px, 3vw, 26px);
}

.il-gCard__icon{
  width: 46px;
  height: 46px;
  border-radius: var(--r-14);
  display: grid;
  place-items: center;
  background: var(--pill-soft-bg, rgba(23,160,81,.10));
  border: 1px solid var(--pill-soft-brd, rgba(23,160,81,.18));
  color: var(--brand-green);
  font-family: var(--font-head);
  font-weight: 900;
  margin-bottom: 12px;
}

/* ======================================================
   FAQ
   ====================================================== */

.il-servicesFaq__head{
  max-width: 820px;
  margin-bottom: clamp(18px, 3vw, 26px);
}

.il-faq{
  padding: 0;
}
.il-faq > summary{
  cursor: pointer;
  padding: 16px 16px;
  font-family: var(--font-head);
  font-weight: 900;
  list-style: none;
}
.il-faq > summary::-webkit-details-marker{ display:none; }
.il-faq > summary::after{
  content: "+";
  float: right;
  color: var(--brand-green);
  font-weight: 900;
}
.il-faq[open] > summary::after{ content: "–"; }

.il-faq__body{
  padding: 0 16px 16px;
}

/* ======================================================
   FINAL CTA
   ====================================================== */

.il-servicesFinal__box{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: clamp(16px, 3vw, 26px);
  border-radius: var(--r-20);
}

.il-servicesFinal__txt{
  max-width: 70ch;
}

.il-servicesFinal__btns{
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

/* ======================================================
   Small tweaks
   ====================================================== */

@media (max-width: 520px){
  .il-servicesHero__panelInner{
    box-shadow: var(--shadow-sm);
  }
  .il-method__card{
    padding: 14px 14px 16px;
  }
}
