/* ===================================================================
   FORMA PACA — Feuille de styles
   Design 2025 : pastel, formes arrondies, mobile-first, rapide
   =================================================================== */

/* ---------- Variables ---------- */
:root{
  --blue:#2B73B8;
  --blue-bright:#3D8BFF;
  --blue-deep:#1E5A93;
  --mint:#4FC3A1;
  --mint-deep:#2E9E7E;
  --bg-blue:#F1F7FD;
  --bg-mint:#EAF7F1;
  --ink:#1C2B3A;
  --slate:#5A6B7B;
  --line:#E3ECF5;
  --white:#FFFFFF;

  --grad-blue:linear-gradient(135deg,#3D8BFF 0%,#2B73B8 100%);
  --grad-mint:linear-gradient(135deg,#5FD3B0 0%,#2E9E7E 100%);
  --grad-soft:linear-gradient(160deg,#F1F7FD 0%,#EAF7F1 100%);

  --r-sm:12px;
  --r:20px;
  --r-lg:28px;
  --r-xl:40px;

  --shadow-sm:0 4px 14px rgba(43,115,184,.08);
  --shadow:0 14px 38px rgba(43,115,184,.14);
  --shadow-lg:0 28px 60px rgba(43,115,184,.20);

  --wrap:1140px;
  --gap:clamp(1.5rem,4vw,4rem);

  --font-head:"Poppins",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  font-size:clamp(1rem,.96rem + .2vw,1.075rem);
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}

h1,h2,h3,h4{font-family:var(--font-head);line-height:1.15;font-weight:700;letter-spacing:-.02em}
h1{font-size:clamp(2.1rem,1.4rem + 3.4vw,3.6rem)}
h2{font-size:clamp(1.7rem,1.2rem + 2.4vw,2.6rem)}
h3{font-size:clamp(1.2rem,1.05rem + .8vw,1.5rem)}
p{color:var(--slate)}
strong{color:var(--ink)}

/* ---------- Layout ---------- */
.wrap{width:min(var(--wrap),92%);margin-inline:auto}
.section{padding:clamp(3.5rem,8vw,7rem) 0}
.section--tint{background:var(--grad-soft)}
.center{text-align:center}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-head);font-weight:600;font-size:.82rem;
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--blue);background:rgba(61,139,255,.10);
  padding:.45rem .9rem;border-radius:999px;margin-bottom:1.1rem;
}
.eyebrow--mint{color:var(--mint-deep);background:rgba(79,195,161,.14)}
.lead{font-size:1.15rem;max-width:60ch}
.section-head{max-width:62ch;margin-bottom:clamp(2rem,5vw,3.4rem)}
.section-head.center{margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--font-head);font-weight:600;font-size:1rem;
  padding:.95rem 1.7rem;border-radius:999px;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s;
  will-change:transform;white-space:nowrap;
}
.btn svg{width:1.1em;height:1.1em}
.btn--primary{background:var(--grad-blue);color:#fff;box-shadow:0 10px 24px rgba(61,139,255,.34)}
.btn--primary:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(61,139,255,.45)}
.btn--mint{background:var(--grad-mint);color:#fff;box-shadow:0 10px 24px rgba(79,195,161,.34)}
.btn--mint:hover{transform:translateY(-3px);box-shadow:0 16px 32px rgba(79,195,161,.45)}
.btn--ghost{background:#fff;color:var(--blue);border:2px solid var(--line)}
.btn--ghost:hover{transform:translateY(-3px);border-color:var(--blue-bright);color:var(--blue-deep);box-shadow:var(--shadow-sm)}
.btn--light{background:rgba(255,255,255,.16);color:#fff;border:2px solid rgba(255,255,255,.45);backdrop-filter:blur(4px)}
.btn--light:hover{background:rgba(255,255,255,.26);transform:translateY(-3px)}
.btn--lg{padding:1.1rem 2.1rem;font-size:1.05rem}

/* ---------- Header ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:60;
  padding:1.1rem 0;transition:padding .3s ease,background .3s ease,box-shadow .3s ease;
}
.site-header.scrolled{padding:.5rem 0;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);box-shadow:0 6px 24px rgba(28,43,58,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem;flex-shrink:0}
.brand__mark{width:46px;height:46px;flex-shrink:0;transition:transform .4s ease}
.brand:hover .brand__mark{transform:rotate(-6deg) scale(1.05)}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--font-head);font-weight:800;font-size:1.18rem;color:var(--blue);letter-spacing:-.01em}
.brand__tag{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);font-weight:600;margin-top:.18rem}

.nav{display:flex;align-items:center;gap:.4rem}
.nav a{
  font-family:var(--font-head);font-weight:500;font-size:.98rem;color:var(--ink);
  padding:.5rem .9rem;border-radius:999px;transition:color .2s,background .2s;position:relative;
}
.nav a:hover{color:var(--blue)}
.nav a.active{color:var(--blue);background:rgba(61,139,255,.10)}
.nav__cta{margin-left:.5rem}
.burger{display:none;width:46px;height:46px;border-radius:14px;background:#fff;box-shadow:var(--shadow-sm);position:relative}
.burger span{position:absolute;left:13px;right:13px;height:2.5px;border-radius:2px;background:var(--ink);transition:.3s}
.burger span:nth-child(1){top:16px}
.burger span:nth-child(2){top:22px}
.burger span:nth-child(3){top:28px}
body.menu-open .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
body.menu-open .burger span:nth-child(2){opacity:0}
body.menu-open .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;padding:clamp(7rem,16vw,10rem) 0 clamp(3rem,8vw,5.5rem);overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-2;background:var(--grad-soft);
}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero h1{margin-bottom:1.2rem}
.hero h1 .hl{color:var(--blue);position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.28em;background:rgba(79,195,161,.35);z-index:-1;border-radius:4px}
.hero .lead{margin-bottom:1.8rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem}
.hero__art{position:relative}
.hero__art svg{width:100%;height:auto;filter:drop-shadow(0 24px 44px rgba(43,115,184,.20))}

/* floating blobs */
.blob{position:absolute;z-index:-1;border-radius:50%;filter:blur(8px);opacity:.5;animation:float 9s ease-in-out infinite}
.blob--1{width:280px;height:280px;background:radial-gradient(circle at 30% 30%,#BFE0FF,#7FB6F2);top:-60px;right:-40px}
.blob--2{width:220px;height:220px;background:radial-gradient(circle at 30% 30%,#C7F2E4,#74D9BC);bottom:-50px;left:-60px;animation-delay:-3s}
@keyframes float{0%,100%{transform:translateY(0) translateX(0) scale(1)}50%{transform:translateY(-26px) translateX(14px) scale(1.06)}}

/* ---------- Stats band ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.8rem 1.2rem;text-align:center;box-shadow:var(--shadow-sm)}
.stat__num{font-family:var(--font-head);font-weight:800;font-size:clamp(1.9rem,1.3rem + 2vw,2.7rem);color:var(--blue);line-height:1}
.stat__num .suffix{color:var(--mint-deep)}
.stat__label{margin-top:.5rem;font-size:.92rem;color:var(--slate)}

/* ---------- Cards (métiers) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  padding:2.1rem 1.7rem;box-shadow:var(--shadow-sm);
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s;position:relative;overflow:hidden;
}
.card::after{content:"";position:absolute;inset:auto -40% -40% auto;width:180px;height:180px;border-radius:50%;background:var(--bg-blue);z-index:0;transition:transform .4s}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:rgba(61,139,255,.35)}
.card:hover::after{transform:scale(1.3)}
.card>*{position:relative;z-index:1}
.card__icon{width:64px;height:64px;border-radius:18px;display:grid;place-items:center;margin-bottom:1.2rem;background:var(--grad-blue);box-shadow:0 10px 22px rgba(61,139,255,.30)}
.card__icon.mint{background:var(--grad-mint);box-shadow:0 10px 22px rgba(79,195,161,.30)}
.card__icon svg{width:32px;height:32px;stroke:#fff}
.card h3{margin-bottom:.6rem}
.card p{font-size:.98rem;margin-bottom:1.1rem}
.card__link{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-head);font-weight:600;color:var(--blue);font-size:.95rem}
.card__link svg{width:1.1em;height:1.1em;transition:transform .25s}
.card__link:hover svg{transform:translateX(5px)}

/* ---------- Feature list (pourquoi) ---------- */
.features{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.feature{display:flex;gap:1.1rem;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.4rem;box-shadow:var(--shadow-sm)}
.feature__ic{width:46px;height:46px;flex-shrink:0;border-radius:13px;display:grid;place-items:center;background:var(--bg-mint)}
.feature__ic svg{width:24px;height:24px;stroke:var(--mint-deep)}
.feature h3{font-size:1.12rem;margin-bottom:.3rem}
.feature p{font-size:.95rem;margin:0}

/* ---------- Split (qui suis-je) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.split__art svg{width:100%;height:auto}
.about-list{margin-top:1.4rem;display:grid;gap:.8rem}
.about-list li{display:flex;gap:.7rem;align-items:flex-start;color:var(--slate)}
.about-list svg{width:22px;height:22px;flex-shrink:0;margin-top:.2rem;stroke:var(--mint-deep)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;border-radius:var(--r-xl);padding:clamp(2.5rem,6vw,4.5rem);overflow:hidden;background:var(--grad-blue);color:#fff;text-align:center}
.cta-band h2{color:#fff;margin-bottom:.8rem}
.cta-band p{color:rgba(255,255,255,.9);max-width:54ch;margin:0 auto 1.8rem}
.cta-band .blob{opacity:.25;filter:blur(2px)}
.cta-band .blob--a{width:240px;height:240px;background:#fff;top:-80px;left:-60px}
.cta-band .blob--b{width:200px;height:200px;background:#9CD9C5;bottom:-70px;right:-40px}
.cta-actions{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center;position:relative;z-index:1}

/* ---------- Prestations ---------- */
.prestation{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(1.8rem,4vw,3.5rem);align-items:center;padding:clamp(2rem,5vw,3.2rem) 0;border-bottom:1px solid var(--line)}
.prestation:last-of-type{border-bottom:none}
.prestation--rev .prestation__art{order:2}
.prestation__art{display:grid;place-items:center}
.prestation__art .ill{width:min(360px,100%);height:auto}
.prestation h3{font-size:clamp(1.4rem,1.1rem + 1.2vw,1.9rem);margin-bottom:.4rem}
.prestation .tagline{color:var(--blue);font-weight:600;font-family:var(--font-head);margin-bottom:1rem;display:block}
.checklist{display:grid;gap:.6rem;margin:1.1rem 0 1.4rem}
.checklist li{display:flex;gap:.6rem;align-items:flex-start;color:var(--slate)}
.checklist svg{width:20px;height:20px;flex-shrink:0;margin-top:.25rem;stroke:var(--mint-deep)}
.price-tags{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:1.2rem}
.price-tag{background:var(--bg-blue);border:1px solid var(--line);border-radius:14px;padding:.7rem 1rem;font-size:.95rem}
.price-tag b{display:block;font-family:var(--font-head);color:var(--blue);font-size:1.1rem}

/* ---------- Packs ---------- */
.packs{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.pack{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:2rem 1.8rem;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.pack:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pack--feat{border:2px solid var(--blue-bright);box-shadow:var(--shadow)}
.pack__badge{align-self:flex-start;font-family:var(--font-head);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--mint-deep);background:rgba(79,195,161,.14);padding:.35rem .8rem;border-radius:999px;margin-bottom:.9rem}
.pack h3{margin-bottom:.3rem}
.pack__sub{font-size:.92rem;color:var(--slate);margin-bottom:1rem}
.pack__price{font-family:var(--font-head);font-weight:800;font-size:2rem;color:var(--blue);line-height:1}
.pack__price span{font-size:.95rem;font-weight:500;color:var(--slate)}
.pack__old{font-size:.85rem;color:var(--slate);margin-bottom:1rem}
.pack ul.checklist{flex:1}
.pack .btn{margin-top:1rem}

/* ---------- Tarifs table ---------- */
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--line);box-shadow:var(--shadow-sm);background:#fff}
table.tarifs{width:100%;border-collapse:collapse;min-width:560px}
table.tarifs th,table.tarifs td{padding:1rem 1.1rem;text-align:left;border-bottom:1px solid var(--line);font-size:.95rem}
table.tarifs thead th{background:var(--bg-blue);font-family:var(--font-head);color:var(--ink);font-weight:600}
table.tarifs tbody tr:last-child td{border-bottom:none}
table.tarifs tbody tr:hover{background:var(--bg-mint)}
table.tarifs td b{color:var(--blue);font-family:var(--font-head)}
.table-cat{background:#fff;font-family:var(--font-head);font-weight:700;color:var(--blue-deep);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem!important}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,3.5rem);align-items:start}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.6rem,4vw,2.6rem);box-shadow:var(--shadow)}
.field{margin-bottom:1.1rem}
.field label{display:block;font-family:var(--font-head);font-weight:500;font-size:.92rem;margin-bottom:.45rem;color:var(--ink)}
.field input,.field select,.field textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--line);border-radius:14px;
  font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-bright);box-shadow:0 0 0 4px rgba(61,139,255,.14)}
.field textarea{resize:vertical;min-height:130px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem}
.form-note{font-size:.82rem;color:var(--slate);margin-top:.4rem}
.form-msg{display:none;margin-top:1rem;padding:1rem 1.2rem;border-radius:14px;font-size:.95rem}
.form-msg.ok{display:block;background:var(--bg-mint);color:var(--mint-deep);border:1px solid rgba(79,195,161,.4)}
.form-msg.err{display:block;background:#FDECEC;color:#C0392B;border:1px solid #F5C6C6}

.contact-info{display:grid;gap:1rem}
.info-item{display:flex;gap:1rem;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:1.2rem 1.3rem;box-shadow:var(--shadow-sm);transition:transform .25s}
.info-item:hover{transform:translateY(-3px)}
.info-item__ic{width:48px;height:48px;flex-shrink:0;border-radius:14px;display:grid;place-items:center;background:var(--grad-blue)}
.info-item__ic svg{width:24px;height:24px;stroke:#fff}
.info-item h4{font-family:var(--font-head);font-size:1rem;margin-bottom:.15rem}
.info-item p,.info-item a{font-size:.95rem;color:var(--slate)}
.info-item a:hover{color:var(--blue)}
.zone-card{background:var(--grad-soft);border:1px solid var(--line);border-radius:var(--r);padding:1.4rem;text-align:center}
.zone-card svg{width:100%;max-width:300px;height:auto;margin:0 auto}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:rgba(255,255,255,.8);padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.footer-brand .brand__name{color:#fff}
.footer-brand .brand__tag{color:rgba(255,255,255,.55)}
.footer-brand p{color:rgba(255,255,255,.65);font-size:.92rem;margin-top:1rem;max-width:34ch}
.footer-col h4{font-family:var(--font-head);color:#fff;font-size:1rem;margin-bottom:1rem}
.footer-col ul{display:grid;gap:.6rem}
.footer-col a{color:rgba(255,255,255,.72);font-size:.94rem;transition:color .2s}
.footer-col a:hover{color:var(--mint)}
.footer-col .ic-row{display:flex;gap:.6rem;align-items:center}
.footer-col .ic-row svg{width:18px;height:18px;stroke:var(--mint);flex-shrink:0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.6rem;display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;justify-content:space-between;font-size:.85rem;color:rgba(255,255,255,.55)}
.footer-bottom a{color:rgba(255,255,255,.7)}
.footer-bottom a:hover{color:var(--mint)}

/* ---------- Back to top ---------- */
.to-top{position:fixed;right:1.2rem;bottom:1.2rem;width:50px;height:50px;border-radius:16px;background:var(--grad-blue);box-shadow:var(--shadow);display:grid;place-items:center;z-index:50;opacity:0;transform:translateY(20px) scale(.8);pointer-events:none;transition:.35s}
.to-top.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.to-top:hover{transform:translateY(-4px)}
.to-top svg{width:22px;height:22px;stroke:#fff}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}

/* ---------- Legal pages ---------- */
.legal{padding:clamp(7rem,14vw,9rem) 0 4rem}
.legal h1{margin-bottom:1.5rem}
.legal h2{font-size:1.4rem;margin:2rem 0 .8rem;color:var(--blue-deep)}
.legal p,.legal li{color:var(--slate);margin-bottom:.7rem}
.legal ul{list-style:disc;padding-left:1.3rem}
.legal a{color:var(--blue);text-decoration:underline}

/* ---------- Page header (sous-pages) ---------- */
.page-hero{padding:clamp(7rem,15vw,9.5rem) 0 clamp(2rem,5vw,3.5rem);background:var(--grad-soft);position:relative;overflow:hidden}
.page-hero .blob--1{top:-80px;right:-30px;opacity:.4}
.page-hero h1{margin-bottom:.8rem}
.crumbs{font-size:.9rem;color:var(--slate);margin-bottom:1rem}
.crumbs a{color:var(--blue)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .hero__actions{justify-content:center}
  .hero__art{order:-1;max-width:440px;margin:0 auto}
  .split,.contact-grid{grid-template-columns:1fr}
  .split__art{order:-1;max-width:440px;margin:0 auto}
  .prestation,.prestation--rev{grid-template-columns:1fr;text-align:left}
  .prestation--rev .prestation__art{order:-1}
  .prestation__art{margin-bottom:.5rem}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav{
    position:fixed;inset:0 0 0 auto;width:min(320px,82%);background:#fff;
    flex-direction:column;align-items:stretch;justify-content:flex-start;gap:.3rem;
    padding:6rem 1.5rem 2rem;box-shadow:-20px 0 50px rgba(28,43,58,.18);
    transform:translateX(110%);transition:transform .35s ease;
  }
  body.menu-open .nav{transform:none}
  .nav a{padding:.9rem 1rem;border-radius:14px;font-size:1.05rem}
  .nav__cta{margin:.5rem 0 0}
  .burger{display:block;z-index:70}
  .stats{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr}
  .features,.packs{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{justify-content:center;text-align:center}
}
@media(max-width:420px){
  .stats{grid-template-columns:1fr}
  .brand__tag{display:none}
}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}
