/* =========================================================
   PlanningRH — Site vitrine (/public). Design clair v2.
   ========================================================= */
:root{
  --canvas:#EAECF1; --surface:#FFFFFF; --hair:#E6E9EF; --hair-strong:#DADEE6;
  --ink:#171A1F; --ink-2:#5C6470; --ink-3:#959CA8;
  --violet:#5B2EE5; --violet-600:#4B22CC; --violet-tint:#F1EDFE; --violet-tint-2:#F7F5FF;
  --navy:#101A2B;
  --ok:#0E9F6E; --ok-bg:#E6F6EF; --wait:#C77A0A; --err:#DC3A2C;
  --maxw:1140px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--surface);color:var(--ink);font-family:'Figtree',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.dsp{font-family:'Schibsted Grotesk','Figtree',sans-serif}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
h1,h2,h3{font-family:'Schibsted Grotesk','Figtree',sans-serif;letter-spacing:-.5px;line-height:1.12;margin:0}

/* ===== Boutons ===== */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15.5px;padding:13px 22px;border-radius:12px;border:1px solid transparent;cursor:pointer;transition:.14s;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--violet);color:#fff}
.btn-primary:hover{background:var(--violet-600);transform:translateY(-1px);box-shadow:0 14px 28px -12px rgba(91,46,229,.6)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--hair-strong)}
.btn-ghost:hover{border-color:var(--violet);color:var(--violet)}
.btn-white{background:#fff;color:var(--violet-600)}
.btn-white:hover{transform:translateY(-1px);box-shadow:0 14px 28px -12px rgba(0,0,0,.35)}
.btn-lg{padding:16px 28px;font-size:17px;border-radius:14px}

/* ===== Navigation ===== */
.nav{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--hair)}
.nav-in{display:flex;align-items:center;gap:14px;height:68px}
.nav-logo{font-family:'Baloo 2','Figtree',sans-serif;font-weight:800;font-size:24px;letter-spacing:-.5px;color:var(--navy)}
.nav-logo span{color:var(--violet)}
.nav-links{display:none;gap:2px;margin-left:6px}
.nav-links a{position:relative;white-space:nowrap;padding:7px 8px;color:var(--ink-2);font-weight:600;font-size:13.5px;transition:color .14s}
.nav-links a:hover{color:var(--ink)}
.nav-links a.active{color:var(--violet)}
.nav-links a:after{content:"";position:absolute;left:8px;right:8px;bottom:2px;height:2px;border-radius:2px;background:var(--violet);transform:scaleX(0);transform-origin:center;transition:transform .16s ease}
.nav-links a:hover:after,.nav-links a.active:after{transform:scaleX(1)}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.nav-login{font-weight:600;font-size:13.5px;color:var(--ink-2);padding:8px 10px;white-space:nowrap}
.nav-right .btn{font-size:14px;padding:10px 16px}
.nav-login:hover{color:var(--violet)}
.nav-login.mob{display:inline-flex}
@media(min-width:920px){ .nav-links{display:flex} }

/* ===== Hero ===== */
.hero{position:relative;overflow:hidden;background:radial-gradient(1100px 520px at 80% -10%,var(--violet-tint) 0%,transparent 60%),linear-gradient(180deg,#fff 0%,var(--violet-tint-2) 100%)}
.hero-in{display:grid;grid-template-columns:1fr;gap:42px;padding:54px 0 64px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--hair);color:var(--violet-600);font-weight:700;font-size:13px;padding:6px 13px;border-radius:99px;box-shadow:0 2px 10px -4px rgba(16,26,43,.12)}
.hero h1{font-size:clamp(33px,6vw,54px);font-weight:700;margin:18px 0 0}
.hero h1 em{font-style:normal;color:var(--violet);position:relative}
.hero-sub{font-size:clamp(17px,2.4vw,20px);color:var(--ink-2);margin:18px 0 0;max-width:560px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}
.hero-trust{display:flex;flex-wrap:wrap;gap:7px 18px;margin-top:24px;color:var(--ink-2);font-size:14px;font-weight:600}
.hero-trust span{display:inline-flex;align-items:center;gap:7px}
.hero-trust svg{width:17px;height:17px;color:var(--ok)}
@media(min-width:920px){ .hero-in{grid-template-columns:1.05fr .95fr;padding:72px 0 84px} }

/* ===== Maquette planning (hero) ===== */
.mock{background:#fff;border:1px solid var(--hair);border-radius:18px;box-shadow:0 40px 80px -40px rgba(16,26,43,.45);overflow:hidden;transform:rotate(.5deg)}
.mock-bar{display:flex;align-items:center;gap:7px;padding:12px 14px;background:var(--navy)}
.mock-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.25)}
.mock-bar b{margin-left:10px;color:#fff;font-family:'Baloo 2',sans-serif;font-size:14px}
.mock-bar b span{color:#A98BFF}
.mock-body{padding:14px}
.mock-row{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.mock-row.head{margin-bottom:6px}
.mock-row.head div{font-size:10px;font-weight:700;color:var(--ink-3);text-align:center;text-transform:uppercase}
.mock-cell{height:62px;background:#F7F8FB;border:1px solid var(--hair);border-radius:9px;padding:5px}
.mock-cell .n{font-size:10px;font-weight:700;color:var(--ink-3)}
.mock-cell.today{background:var(--violet-tint);border-color:var(--violet)}
.mock-chip{margin-top:4px;height:13px;border-radius:4px;background:var(--violet);opacity:.92}
.mock-chip.g{background:var(--ok)} .mock-chip.o{background:var(--wait)} .mock-chip.b{background:#2563EB}
.mock-chip.s{width:70%}

/* ===== Sections ===== */
.section{padding:74px 0}
.section.tint{background:var(--violet-tint-2)}
.section.navy{background:var(--navy);color:#fff}
.eyebrow{display:block;text-align:center;color:var(--violet);font-weight:800;font-size:13px;letter-spacing:1.2px;text-transform:uppercase;margin-bottom:12px}
.section-head{text-align:center;max-width:680px;margin:0 auto 48px}
.section-head h2{font-size:clamp(27px,4vw,40px);font-weight:700}
.section-head p{color:var(--ink-2);font-size:18px;margin:14px 0 0}
.section.navy .section-head p{color:#B7C0D0}

/* ===== Fonctionnalités ===== */
.features{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:640px){ .features{grid-template-columns:1fr 1fr} }
@media(min-width:980px){ .features{grid-template-columns:1fr 1fr 1fr} }
.feat{background:#fff;border:1px solid var(--hair);border-radius:16px;padding:24px;transition:.16s}
.feat:hover{border-color:var(--violet);box-shadow:0 18px 40px -24px rgba(91,46,229,.4);transform:translateY(-2px)}
.feat-ico{width:46px;height:46px;border-radius:12px;background:var(--violet-tint);color:var(--violet);display:flex;align-items:center;justify-content:center;margin-bottom:15px}
.feat-ico svg{width:24px;height:24px}
.feat h3{font-size:18.5px;font-weight:700}
.feat p{color:var(--ink-2);font-size:15.5px;margin:8px 0 0}

/* ===== Étapes ===== */
.steps{display:grid;grid-template-columns:1fr;gap:22px;counter-reset:s}
@media(min-width:820px){ .steps{grid-template-columns:repeat(3,1fr)} }
.step{position:relative;padding:26px 22px;background:#fff;border:1px solid var(--hair);border-radius:16px}
.step-num{width:38px;height:38px;border-radius:50%;background:var(--violet);color:#fff;font-family:'Schibsted Grotesk',sans-serif;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.step h3{font-size:18px;font-weight:700}
.step p{color:var(--ink-2);font-size:15.5px;margin:8px 0 0}

/* ===== Espace salarié ===== */
.split{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:920px){ .split{grid-template-columns:1fr 1fr} }
.split h2{font-size:clamp(26px,3.6vw,36px);font-weight:700}
.split p.lead{color:var(--ink-2);font-size:18px;margin:16px 0 22px}
.ticklist{list-style:none;padding:0;margin:0;display:grid;gap:13px}
.ticklist li{display:flex;gap:12px;align-items:flex-start;font-size:16px}
.ticklist svg{flex:none;width:22px;height:22px;color:var(--violet);margin-top:1px}
.phone-wrap{display:flex;justify-content:center}
.phone{width:300px;max-width:88vw;background:var(--navy);border-radius:34px;padding:11px;box-shadow:0 50px 90px -40px rgba(16,26,43,.6)}
.phone-screen{background:#EAECF1;border-radius:24px;overflow:hidden;padding:14px}
.ph-top{display:flex;align-items:center;gap:9px;margin-bottom:13px}
.ph-av{width:34px;height:34px;border-radius:50%;background:linear-gradient(140deg,#7C3AED,#5B2EE5);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.ph-hello{font-family:'Schibsted Grotesk',sans-serif;font-weight:700;font-size:16px}
.ph-next{background:linear-gradient(135deg,#5B2EE5,#4B22CC);color:#fff;border-radius:15px;padding:14px;margin-bottom:11px}
.ph-next .tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:rgba(255,255,255,.18);padding:3px 9px;border-radius:99px;display:inline-block}
.ph-next .d{font-family:'Schibsted Grotesk',sans-serif;font-weight:700;font-size:17px;margin-top:9px}
.ph-next .t{font-size:12.5px;color:#EADFFF;margin-top:4px}
.ph-card{background:#fff;border:1px solid var(--hair);border-radius:13px;padding:11px;display:flex;align-items:center;gap:11px;margin-bottom:8px}
.ph-day{width:40px;height:44px;border-radius:10px;background:var(--violet-tint);color:var(--violet-600);display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;flex:none}
.ph-day b{font-family:'Schibsted Grotesk',sans-serif;font-size:17px}
.ph-day span{font-size:9px;font-weight:700;text-transform:uppercase}
.ph-meta .l1{font-weight:600;font-size:13px}
.ph-meta .l2{font-size:11.5px;color:var(--ink-2);margin-top:2px}

/* ===== Tarifs ===== */
.price-grid{display:grid;grid-template-columns:1fr;gap:20px;max-width:760px;margin:0 auto}
@media(min-width:760px){ .price-grid{grid-template-columns:1fr 1fr} }
.price{position:relative;background:#fff;border:1px solid var(--hair);border-radius:20px;padding:30px 26px}
.price.featured{border:2px solid var(--violet);box-shadow:0 30px 60px -30px rgba(91,46,229,.45)}
.price-tag{position:absolute;top:-13px;left:26px;background:var(--violet);color:#fff;font-size:12px;font-weight:700;padding:5px 12px;border-radius:99px}
.price h3{font-size:20px;font-weight:700}
.price .amount{display:flex;align-items:baseline;gap:6px;margin:14px 0 4px}
.price .amount b{font-family:'Schibsted Grotesk',sans-serif;font-size:42px;font-weight:700}
.price .amount span{color:var(--ink-2);font-size:15px;font-weight:600}
.price .ht{color:var(--ink-3);font-size:13px}
.price-list{list-style:none;padding:0;margin:20px 0 24px;display:grid;gap:11px}
.price-list li{display:flex;gap:10px;align-items:flex-start;font-size:15px;color:var(--ink)}
.price-list svg{flex:none;width:20px;height:20px;color:var(--ok);margin-top:1px}
.price .btn{width:100%;justify-content:center}

/* ===== FAQ ===== */
.faq{max-width:760px;margin:0 auto;display:grid;gap:12px}
.faq details{background:#fff;border:1px solid var(--hair);border-radius:13px;padding:4px 18px;transition:.15s}
.faq details[open]{border-color:var(--violet-tint);box-shadow:0 12px 30px -20px rgba(16,26,43,.3)}
.faq summary{list-style:none;cursor:pointer;font-weight:700;font-size:16.5px;padding:16px 0;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";font-size:22px;color:var(--violet);font-weight:400;transition:.2s}
.faq details[open] summary:after{transform:rotate(45deg)}
.faq p{margin:0 0 16px;color:var(--ink-2);font-size:15.5px}

/* ===== Bande CTA ===== */
.cta-band{background:linear-gradient(135deg,var(--violet) 0%,var(--violet-600) 55%,var(--navy) 100%);border-radius:24px;padding:48px 32px;text-align:center;color:#fff;position:relative;overflow:hidden}
.cta-band:before{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:rgba(255,255,255,.07)}
.cta-band h2{font-size:clamp(26px,4vw,38px);font-weight:700;position:relative}
.cta-band p{color:#E1D7FF;font-size:18px;margin:14px auto 26px;max-width:520px;position:relative}
.cta-band .btn{position:relative}

/* ===== Contact ===== */
.contact-grid{display:grid;grid-template-columns:1fr;gap:34px;max-width:920px;margin:0 auto}
@media(min-width:820px){ .contact-grid{grid-template-columns:.9fr 1.1fr} }
.contact-info h2{font-size:28px;font-weight:700}
.contact-info p{color:var(--ink-2);margin:12px 0 0}
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--ink-3);margin-bottom:6px}
.field input,.field textarea{width:100%;font-family:inherit;font-size:16px;color:var(--ink);background:#fff;border:1px solid var(--hair-strong);border-radius:11px;padding:13px 14px}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px var(--violet-tint)}
.field textarea{resize:vertical;min-height:120px}
#form-ok{display:none;align-items:center;gap:9px;background:var(--ok-bg);color:var(--ok);font-weight:600;padding:13px 15px;border-radius:11px;margin-bottom:14px}

/* ===== Footer ===== */
.footer{background:var(--navy);color:#C7CEDA;padding:50px 0 30px}
.footer-top{display:grid;grid-template-columns:1fr;gap:26px;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.1)}
@media(min-width:760px){ .footer-top{grid-template-columns:1.4fr 1fr 1fr} }
.footer-logo{font-family:'Baloo 2',sans-serif;font-weight:800;font-size:24px;color:#fff}
.footer-logo span{color:#A98BFF}
.footer p{font-size:14.5px;margin:12px 0 0;max-width:300px}
.footer h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:.6px;margin:0 0 14px}
.footer-col a{display:block;color:#C7CEDA;font-size:15px;padding:5px 0;transition:.12s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center;padding-top:22px;font-size:13.5px;color:#8E99AC}

/* =========================================================
   Maquettes décoratives supplémentaires
   ========================================================= */

/* --- Bulles flottantes autour du hero --- */
.hero-visual{position:relative}
.float-chip{position:absolute;background:#fff;border:1px solid var(--hair);border-radius:13px;box-shadow:0 14px 34px -16px rgba(16,26,43,.45);padding:9px 13px;display:flex;align-items:center;gap:9px;font-weight:700;font-size:13px;z-index:3}
.float-chip .dot{width:27px;height:27px;display:flex;align-items:center;justify-content:center;border-radius:8px;flex:none}
.float-chip svg{width:16px;height:16px}
.float-dpae{top:-20px;left:-12px;color:var(--ok)}
.float-dpae .dot{background:var(--ok-bg);color:var(--ok);border-radius:50%}
.float-contrat{bottom:-18px;right:-10px;color:var(--violet-600)}
.float-contrat .dot{background:var(--violet-tint);color:var(--violet)}
.float-avs{position:absolute;bottom:-22px;left:24px;display:flex;z-index:3}
.float-avs span{width:36px;height:36px;border-radius:50%;border:3px solid #fff;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:12px;margin-left:-11px;box-shadow:0 8px 16px -8px rgba(0,0,0,.4)}
@media(max-width:919px){ .float-chip,.float-avs{display:none} }

/* --- Maquette contrat PDF --- */
.doc-mock{background:#fff;border:1px solid var(--hair);border-radius:14px;box-shadow:0 40px 80px -40px rgba(16,26,43,.45);padding:26px 24px;max-width:370px;margin:0 auto;transform:rotate(-1.2deg)}
.doc-logo{width:42px;height:42px;border-radius:9px;background:var(--violet-tint);margin-bottom:16px;display:flex;align-items:center;justify-content:center;color:var(--violet)}
.doc-logo svg{width:22px;height:22px}
.doc-title{height:24px;border-radius:6px;background:var(--violet);width:78%;margin-bottom:20px}
.doc-line{height:8px;border-radius:4px;background:#E9ECF2;margin-bottom:9px}
.doc-line.w2{width:92%}.doc-line.w3{width:70%}
.doc-sub{height:11px;border-radius:5px;background:var(--violet-tint);width:44%;margin:20px 0 13px}
.doc-sign{margin-top:24px;display:flex;justify-content:space-between;align-items:flex-end}
.doc-sign .s{height:8px;width:36%;background:#E9ECF2;border-radius:4px}
.doc-stamp{width:54px;height:54px;border-radius:50%;border:2px dashed var(--violet);color:var(--violet);display:flex;align-items:center;justify-content:center;transform:rotate(-12deg);font-weight:800;font-size:11px;font-family:'Schibsted Grotesk',sans-serif}

/* --- Maquette suivi des heures --- */
.hours-mock{background:#fff;border:1px solid var(--hair);border-radius:16px;box-shadow:0 40px 80px -40px rgba(16,26,43,.4);padding:20px;max-width:420px;margin:0 auto}
.hm-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:17px}
.hm-head b{font-family:'Schibsted Grotesk',sans-serif;font-size:16px}
.hm-head span{font-size:12px;color:var(--ink-3);font-weight:700;background:var(--violet-tint);color:var(--violet-600);padding:3px 9px;border-radius:99px}
.hm-row{display:flex;align-items:center;gap:11px;margin-bottom:15px}
.hm-av{width:34px;height:34px;border-radius:50%;color:#fff;font-weight:700;font-size:12px;display:flex;align-items:center;justify-content:center;flex:none}
.hm-mid{flex:1;min-width:0}
.hm-name{font-size:13px;display:flex;justify-content:space-between;align-items:center}
.hm-name b{font-weight:600}
.hm-name em{font-style:normal;color:var(--ink-2);font-weight:700}
.hm-gauge{height:7px;border-radius:99px;background:#EEF0F4;margin-top:7px;overflow:hidden}
.hm-gauge i{display:block;height:100%;border-radius:99px;background:var(--ok)}
.hm-gauge.warn i{background:var(--wait)} .hm-gauge.over i{background:var(--err)}
.hm-badge{font-size:11px;font-weight:700;color:var(--err);background:var(--err-bg);padding:2px 8px;border-radius:99px}
.hm-total{display:flex;justify-content:space-between;border-top:1px solid var(--hair);padding-top:14px;font-weight:700}
.hm-total b{font-family:'Schibsted Grotesk',sans-serif;color:var(--violet-600)}

/* --- Mini-visuels des étapes --- */
.step-visual{height:98px;border-radius:12px;background:var(--violet-tint-2);border:1px solid var(--hair);margin-bottom:18px;display:flex;align-items:center;justify-content:center;gap:9px;padding:12px;flex-wrap:wrap}
.sv-card{background:#fff;border:1px solid var(--hair);border-radius:9px;padding:7px 10px;display:flex;align-items:center;gap:8px;box-shadow:0 8px 18px -10px rgba(16,26,43,.3);font-size:12px;font-weight:600}
.sv-av{width:26px;height:26px;border-radius:50%;background:linear-gradient(140deg,#7C3AED,#5B2EE5);color:#fff;font-weight:700;font-size:10px;display:flex;align-items:center;justify-content:center;flex:none}
.sv-chip{font-size:11px;font-weight:700;padding:4px 9px;border-radius:99px;background:var(--violet);color:#fff}
.sv-drop{width:46px;height:36px;border:2px dashed var(--violet);border-radius:8px;opacity:.55}
.sv-ok,.sv-pdf{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;padding:7px 11px;border-radius:99px}
.sv-ok{background:var(--ok-bg);color:var(--ok)} .sv-ok svg{width:14px;height:14px}
.sv-pdf{background:var(--violet-tint);color:var(--violet-600);border-radius:9px}
.sv-phone{width:50px;height:80px;background:var(--navy);border-radius:11px;padding:4px;flex:none}
.sv-phone>div{background:#fff;border-radius:7px;height:100%;padding:6px}
.sv-phone .l{height:7px;background:var(--violet);border-radius:3px;width:70%;margin-bottom:5px}
.sv-phone .l2{height:5px;background:#E9ECF2;border-radius:3px;width:92%;margin-bottom:4px}
