/* Projet SAT+ - styles extraits du HTML de reference */

:root{
      --bg:#ffffff;
      --ink:#111111;
      --muted:#5f5f5f;
      --soft:#8a857d;
      --line:#ebebeb;
      --panel:#ffffff;
      --panel-soft:#f7f5f1;
      --panel-warm:#fbfaf7;
      --dark:#121212;
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{margin:0;background:var(--bg);color:var(--ink);font-family:'Acumin',Arial,Helvetica,sans-serif}
    a{color:inherit;text-decoration:none}
    img{max-width:100%;display:block}

    .topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,.05)}
    .topbar .wrap{max-width:1280px;margin:0 auto;padding:22px 32px;display:flex;gap:24px;align-items:center;justify-content:space-between}
    .brand{font-family:'Acumin',Arial,sans-serif;font-size:15px;letter-spacing:.10em;text-transform:uppercase}
    .nav{display:flex;gap:30px;font-size:15px;color:var(--muted);flex-wrap:wrap}
    .nav a.active{color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:6px}

    .page{max-width:1320px;margin:0 auto;padding:0 32px 90px}

    .hero{position:relative;min-height:76vh;margin:0 calc(50% - 50vw) 0;display:flex;align-items:flex-end;background:#ddd center/cover no-repeat;width:100vw}
    .hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.22),rgba(0,0,0,.04) 42%,rgba(0,0,0,.08))}
    .hero-card{position:relative;z-index:1;background:rgba(255,255,255,.96);padding:34px 40px;max-width:620px;margin:0 0 7vh 7vw;box-shadow:0 24px 80px rgba(0,0,0,.10)}
    .kicker{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#7a746d;margin-bottom:16px}
    .hero h1{font-family:'Oswald',Georgia,serif;font-size:100px;line-height:.88;font-weight:300;margin:0;letter-spacing:-.04em}

    .satplus-foundation{position:relative;margin:0 calc(50% - 50vw) 54px;width:100vw;padding:0;background:#ddd url('../../images/satplus-fond-intro.png') center bottom/cover no-repeat}
    .satplus-foundation::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,.89)}
    .satplus-foundation-grid{position:relative;z-index:1;max-width:1320px;margin:0 auto;padding:34px 32px 64px;display:grid;grid-template-columns:4fr 3fr;gap:64px;align-items:start}
    .satplus-foundation-text{max-width:760px}
    .satplus-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:22px;color:var(--soft)}
    .satplus-eyebrow strong{font-family:'Oswald',Georgia,serif;font-weight:300;font-size:68px;line-height:.95;letter-spacing:-.04em;color:var(--ink)}
    .satplus-eyebrow span{font-size:11px;letter-spacing:.22em;text-transform:uppercase}
    .satplus-foundation h2{font-family:'Oswald',Georgia,serif;font-size:42px;line-height:1.08;font-weight:300;letter-spacing:-.03em;margin:0 0 28px;max-width:18em}
    .satplus-foundation h2 span{display:block}
    .satplus-foundation-body{font-size:17px;line-height:1.72;color:#3f3e3a;max-width:38em}
    .satplus-foundation-body p{margin:0 0 18px}
    .satplus-fields{margin-top:30px;padding-top:22px;border-top:1px solid var(--line);color:#4c4a45}
    .satplus-fields p{margin:0 0 14px;font-size:17px;line-height:1.72;color:#3f3e3a;max-width:40em}
    .satplus-field-list{
      display:flex;
      flex-wrap:wrap;
      align-items:center;
      gap:10px 14px;
      margin:16px 0 12px;
      font-family:'Oswald',Georgia,serif;
      font-size:22px;
      line-height:1;
      font-weight:300;
      letter-spacing:.06em;
      text-transform:uppercase;
      color:var(--ink);
    }
    .satplus-field-sep{color:#b9b2a8;font-family:'Acumin',Arial,Helvetica,sans-serif;font-size:15px;letter-spacing:0}
    .satplus-fields-caption{font-size:16px!important;line-height:1.68!important;color:#4c4a45!important;max-width:42em!important;margin-top:10px!important}

    .satplus-publication-stack{position:sticky;top:96px;align-self:start;background:transparent;border:0;padding:0 0 0 24px}
    .satplus-publication-stack .kicker{margin-bottom:18px}
    .satplus-cover-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
    .satplus-cover-card{display:block;background:#fff;border:1px solid rgba(0,0,0,.06);transition:transform .18s ease, box-shadow .18s ease}
    .satplus-cover-card:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(0,0,0,.09)}
    .satplus-cover-card img{width:100%;height:auto}
    .satplus-publication-note{font-size:13px;line-height:1.55;color:var(--muted);margin:18px 0 0;max-width:30em}
    .satplus-publications-link{display:block;text-align:center;background:#fff;color:var(--ink);border:1px solid var(--ink);padding:12px 14px;margin-top:16px;font-size:11px;letter-spacing:.16em;text-transform:uppercase}
    .satplus-publications-link:hover{background:var(--ink);color:#fff}

    .satplus-log{padding:34px 0 28px}
    .satplus-log-head{border-top:1px solid var(--line);padding-top:24px;margin-bottom:18px;max-width:760px}
    .satplus-log-intro h2{font-family:'Oswald',Georgia,serif;font-size:68px;line-height:.95;font-weight:300;letter-spacing:-.04em;margin:0 0 24px}
    .satplus-log-intro p{font-size:17px;line-height:1.72;color:#3f3e3a;margin:0;max-width:38em;font-style:italic}
    .satplus-log-nav{position:sticky;top:69px;z-index:49;display:flex;align-items:stretch;gap:8px;margin:0 calc(50% - 50vw) 28px;padding:10px max(32px,calc((100vw - 1320px)/2 + 32px));background:#fff;border:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 8px 22px rgba(0,0,0,.035);overflow-x:auto}
    .satplus-log-nav-title{display:flex;align-items:center;flex:0 0 auto;padding:0 12px 0 4px;font-size:10px;letter-spacing:.20em;text-transform:uppercase;color:var(--soft);white-space:nowrap}
    .satplus-log-link{display:grid;grid-template-columns:34px minmax(0,1fr);gap:10px;align-items:center;min-width:190px;flex:1 1 0;border:1px solid var(--line);background:#fff;padding:10px 12px;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
    .satplus-log-link:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(0,0,0,.07);border-color:#d8d2c8}
    .satplus-log-link-number{font-family:'Oswald',Georgia,serif;font-size:24px;line-height:1;font-weight:300;letter-spacing:-.04em;color:var(--ink)}
    .satplus-log-link-text{font-size:10px;line-height:1.25;letter-spacing:.12em;text-transform:uppercase;color:#4c4a45}

    .satplus-steps{display:grid;gap:22px}
    .satplus-step{display:grid;grid-template-columns:180px minmax(0,1fr) 230px;gap:34px;align-items:start;border:1px solid var(--line);background:#fff;padding:30px;position:relative;scroll-margin-top:166px}
    .satplus-step::before{content:'';position:absolute;left:-1px;top:-1px;bottom:-1px;width:2px;background:#111111}
    .satplus-step-index{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--soft)}
    .satplus-step-index strong{display:block;font-family:'Oswald',Georgia,serif;font-size:52px;line-height:1;font-weight:300;letter-spacing:-.04em;color:var(--ink);margin-bottom:10px}
    .satplus-step-index span{display:block;font-size:11px;line-height:1.35;letter-spacing:.13em;text-transform:uppercase;color:var(--soft);max-width:12em}
    .satplus-step-content h3{font-family:'Oswald',Georgia,serif;font-size:34px;line-height:normal;font-weight:300;letter-spacing:-.03em;margin:0 0 14px;max-width:20em}
    .satplus-step-subtitle{font-size:12px;line-height:1.45;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin:0 0 18px;max-width:44em}
    .satplus-step-content p{font-size:17px;line-height:1.72;color:#3f3e3a;margin:0 0 14px;max-width:44em}
    .satplus-step-content p:last-child{margin-bottom:0}
    .satplus-step-aside{background:var(--panel-soft);padding:18px;border:1px solid rgba(0,0,0,.04)}
    .satplus-step-visual{background:transparent;padding:0;border:0}
    .satplus-step-visual img{width:100%;height:auto;display:block;margin:0 0 14px}
    .satplus-dashboard-link{display:block;text-align:center;background:#fff;color:var(--ink);border:1px solid var(--ink);padding:12px 14px;font-size:11px;letter-spacing:.16em;text-transform:uppercase}
    .satplus-dashboard-link:hover{background:var(--ink);color:#fff}
    .satplus-soliha-card{display:block;background:#fff;border:1px solid rgba(0,0,0,.08);transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease}
    .satplus-soliha-card:hover{transform:translateY(-3px);box-shadow:0 18px 42px rgba(0,0,0,.09);border-color:rgba(0,0,0,.16)}
    .satplus-soliha-card img{width:100%;height:154px;object-fit:cover;display:block;margin:0}
    .satplus-soliha-card span{display:block;text-align:center;background:#fff;color:var(--ink);border-top:1px solid rgba(0,0,0,.08);padding:13px 12px;font-size:11px;line-height:1.35;letter-spacing:.16em;text-transform:uppercase}

    .satplus-adopta-card img{height:154px;object-fit:contain;background:#fff;padding:26px 18px}
    .satplus-program-link{display:block;text-align:center;background:rgba(180,214,112,.50);color:#111;border:0;border-radius:999px;padding:12px 14px;margin-top:14px;font-size:11px;line-height:1.35;letter-spacing:.16em;text-transform:uppercase;pointer-events:none}
    .satplus-soliha-note{margin-top:18px;padding-top:18px;border-top:1px solid var(--line);background:transparent}
    .satplus-soliha-note p{font-size:15px;line-height:1.62;color:#4a4742;margin:0 0 13px}
    .satplus-soliha-note p:last-child{margin-bottom:0}
    .satplus-construction-box{
      margin-top:24px;
      padding:20px;
      border:1px solid rgba(17,17,17,.10);
      border-radius:22px;
      background:#fbfaf7;
      box-shadow:0 14px 34px rgba(40,48,42,.045);
      max-width:44em;
    }
    .satplus-construction-box p{
      font-size:16px;
      line-height:1.66;
      color:#4a4742;
      margin:0 0 14px;
      max-width:40em;
    }
    .satplus-construction-box p:last-child{margin-bottom:0}
    .satplus-construction-box .satplus-status{margin-bottom:14px}
    .satplus-construction-link{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      background:rgba(180,214,112,.50);
      color:#111;
      border:0;
      border-radius:999px;
      padding:12px 16px;
      margin-top:2px;
      font-size:11px;
      line-height:1.25;
      letter-spacing:.16em;
      text-transform:uppercase;
      pointer-events:none;
    }
    .satplus-step-sticky{position:sticky;top:158px;align-self:start}
    .satplus-step > .satplus-step-index.satplus-step-sticky,
    .satplus-step > .satplus-step-aside.satplus-step-sticky{
      position:sticky;
      top:158px;
      align-self:start;
      z-index:1;
    }

    /* Ajustement spécifique des blocs 02 et 03 : seule la vignette de renvoi reste sticky ; l'encart explicatif reste dans le flux du bloc */
    #carnet-02 > .satplus-step-aside.satplus-step-sticky,
    #carnet-03 > .satplus-step-aside.satplus-step-sticky{
      position:relative;
      top:auto;
      align-self:stretch;
      z-index:1;
    }
    #carnet-02 .satplus-soliha-card,
    #carnet-03 .satplus-soliha-card{
      position:sticky;
      top:158px;
      z-index:2;
    }
    .satplus-status{display:inline-block;font-size:10px;letter-spacing:.20em;text-transform:uppercase;border:1px solid #cfc7ba;padding:7px 9px;margin-bottom:18px;color:#5b554d;background:#fff}
    .satplus-mini-link{display:block;margin-top:12px;border-top:1px solid rgba(0,0,0,.08);padding-top:13px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink)}
    .satplus-mini-link:hover{text-decoration:underline;text-underline-offset:4px}
    .satplus-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
    .satplus-tags span{font-size:11px;letter-spacing:.12em;text-transform:uppercase;border:1px solid #d8d2c8;background:#fff;padding:7px 9px;color:#5e5850}

    .satplus-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px}
    .satplus-mediation-card{background:#fff;border:1px solid rgba(0,0,0,.08);padding:12px;min-height:70px}
    .satplus-mediation-card strong{display:block;font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}
    .satplus-mediation-card span{display:block;font-size:13px;line-height:1.35;color:var(--muted)}



    /* Carnet de mise en œuvre — étapes en préparation */
    .satplus-step-prep{
      display:grid;
      grid-template-columns:180px minmax(0,1fr);
      gap:34px;
      align-items:start;
      border:1px solid rgba(17,17,17,.88);
      border-radius:24px;
      background:rgba(255,255,255,.88);
      box-shadow:0 18px 48px rgba(40,48,42,.07);
      padding:30px;
      position:relative;
      scroll-margin-top:166px;
    }
    .satplus-step-prep .satplus-step-index span{
      max-width:13em;
    }
    .satplus-step-prep-content h3{
      margin:0 0 14px;
      font-family:'Oswald',Georgia,serif;
      font-size:34px;
      line-height:normal;
      font-weight:300;
      letter-spacing:-.03em;
      max-width:20em;
    }
    .satplus-step-prep-content p{
      margin:0 0 14px;
      color:#3f3e3a;
      font-size:17px;
      line-height:1.72;
      max-width:52em;
    }
    .satplus-step-prep-content p:last-child{margin-bottom:0}
    .satplus-element-list{
      display:grid;
      grid-template-columns:repeat(2,minmax(0,1fr));
      gap:10px;
      margin-top:18px;
    }
    .satplus-element-card{
      min-height:86px;
      border:1px solid rgba(17,17,17,.12);
      border-radius:18px;
      background:#fff;
      padding:14px 15px;
    }
    .satplus-element-card strong{
      display:block;
      margin-bottom:8px;
      font-size:11px;
      letter-spacing:.18em;
      text-transform:uppercase;
      color:#111;
    }
    .satplus-element-card span{
      display:block;
      color:#5f5f5f;
      font-size:14px;
      line-height:1.45;
    }
    .satplus-prep-note{
      display:inline-block;
      margin-bottom:16px;
      border:1px solid #cfc7ba;
      background:#fff;
      color:#5b554d;
      padding:7px 9px;
      font-size:10px;
      letter-spacing:.20em;
      text-transform:uppercase;
    }
    .satplus-future-link{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      margin-top:10px;
      border:0;
      border-radius:999px;
      background:rgba(180,214,112,.50);
      color:#111;
      padding:11px 17px 10px;
      font-size:11px;
      line-height:1;
      letter-spacing:.16em;
      text-transform:uppercase;
      pointer-events:none;
    }

    .satplus-step.future{background:linear-gradient(135deg,#fff,#fbfaf7)}
    .satplus-step.future::before{background:#ece4d8}

    .footer{border-top:1px solid var(--line);padding:30px 0 60px;color:var(--muted);font-size:14px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:40px}

    @media (max-width:1100px){
      .satplus-foundation-grid{grid-template-columns:1fr;gap:34px}
      .satplus-publication-stack{position:relative;top:auto;max-width:620px;padding-left:0}
      .satplus-step{grid-template-columns:130px minmax(0,1fr);gap:24px}

      .satplus-step-prep{grid-template-columns:130px minmax(0,1fr);gap:24px}
      .satplus-step-aside{grid-column:2}
      .satplus-step-sticky{position:relative;top:auto}
    }

    @media (max-width:900px){
      .page{padding:0 22px 70px}
      .topbar .wrap{padding:18px 22px}
      .hero{min-height:440px;margin-bottom:0}
      .hero-card{margin:24px;max-width:none;padding:28px}
      .hero h1{font-size:56px}
      .satplus-foundation-grid{padding:30px 22px 52px}
      .satplus-foundation h2{font-size:34px}
      .satplus-foundation-body{font-size:17px}
      .satplus-log-head{margin-bottom:18px}
      .satplus-log-intro h2{font-size:48px}
      .satplus-log-nav{top:63px;margin:0 calc(50% - 50vw) 22px;padding:8px 22px}
      .satplus-log-nav-title{display:none}
      .satplus-log-link{grid-template-columns:36px minmax(0,1fr);min-width:176px;padding:11px 12px}
      .satplus-log-link:hover{transform:translateY(-2px)}
      .satplus-log-link-number{font-size:26px}
      .satplus-log-link-text{font-size:10px}
      .satplus-step{grid-template-columns:1fr;padding:24px;scroll-margin-top:142px}

      .satplus-step-prep{grid-template-columns:1fr;padding:24px;scroll-margin-top:142px}
      .satplus-step-aside{grid-column:auto}
      .satplus-cover-grid{max-width:420px}
    }

    @media (max-width:620px){
      .satplus-cover-grid,
      .satplus-card-grid{grid-template-columns:1fr}

      .satplus-element-list{grid-template-columns:1fr}
      .satplus-field-sep{display:none}
      .satplus-field-list{gap:0;font-size:20px}
      .satplus-field-list span{display:inline-block;margin:0 18px 10px 0}
    }
