
:root{--navy:#06172b;--navy2:#102943;--navy3:#18395a;--gold:#c89632;--gold2:#e2b862;--cream:#f6f0e6;--cream2:#fbf8f2;--ink:#142132;--muted:#647184;--line:rgba(6,23,43,.13);--white:#fff;--shadow:0 28px 80px rgba(6,23,43,.18);--soft:0 18px 45px rgba(6,23,43,.10);--radius:26px;--serif:'Cormorant Garamond',Georgia,'Times New Roman',serif;--sans:'DM Sans','Helvetica Neue',ui-sans-serif,system-ui,sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sans);background:var(--cream2);color:var(--ink);line-height:1.5;margin:0;padding:0}.mockup-shell{width:100%;margin:0;background:var(--cream2);border:0;border-radius:0;padding:0;box-shadow:none}.top-note{display:none}.top-note strong{color:var(--navy)}.tabs{display:none}.tab{border:1px solid rgba(6,23,43,.16);background:rgba(255,255,255,.7);color:#3a4658;padding:8px 14px;border-radius:999px;cursor:pointer;font-size:12px;font-weight:750}.tab.active{background:var(--navy);color:#fff;border-color:var(--navy)}.browser{overflow:hidden;border-radius:0;background:var(--cream2);border:0}.browser-bar{display:none}.dots{display:flex;gap:6px}.dot{width:11px;height:11px;border-radius:50%}.red{background:#ff5f57}.yellow{background:#febc2e}.green{background:#28c840}.url{flex:1;background:#fff;border:1px solid rgba(6,23,43,.09);border-radius:999px;padding:6px 14px;color:#66768a;font-size:12px}.lang{font-size:12px;color:#56667b;font-weight:800}.page{display:block}.site{background:var(--cream2);min-height:100vh;width:100%}.nav{height:82px;padding:0 54px;display:flex;justify-content:space-between;align-items:center;background:rgba(6,23,43,.98);color:white;position:relative;z-index:5}.brand{font-weight:800;letter-spacing:.02em;font-size:18px}.brand span{color:var(--gold)}.nav-right{display:flex;align-items:center;gap:19px;font-size:13px}.nav-right a{color:rgba(255,255,255,.72);text-decoration:none;cursor:pointer}.nav-right a.active,.nav-right a:hover{color:#fff}.nav-social{display:flex;gap:6px}.social-dot{width:28px;height:28px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:grid;place-items:center;color:rgba(255,255,255,.76);font-size:10px;font-weight:900;text-decoration:none}.nav-cta{background:var(--gold);color:#07182d!important;padding:11px 16px;border-radius:999px;font-weight:900}.nav-lang{border:1px solid rgba(255,255,255,.22);padding:8px 10px;border-radius:999px;color:rgba(255,255,255,.8)}.hero{background:linear-gradient(135deg,var(--navy),var(--navy2));color:white;display:grid;grid-template-columns:minmax(0,1.08fr) 410px;gap:48px;padding:78px 54px 58px;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;right:-160px;bottom:-220px;width:610px;height:610px;background:radial-gradient(circle,rgba(200,150,50,.24),transparent 63%)}.hero:after{content:"";position:absolute;left:54px;bottom:0;width:260px;height:3px;background:var(--gold)}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--gold2);font-weight:900;margin-bottom:18px}.h1{font-family:var(--serif);font-size:60px;line-height:.98;font-weight:500;letter-spacing:-.045em;max-width:760px}.h1 em{font-style:normal;color:var(--gold2)}.sub{font-size:17px;color:rgba(255,255,255,.76);max-width:660px;margin-top:24px;line-height:1.75}.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:32px}.btn{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:14px 20px;font-size:14px;font-weight:900;text-decoration:none;cursor:pointer;border:0}.btn-primary{background:var(--gold);color:#07182d}.btn-ghost{border:1px solid rgba(255,255,255,.25);color:white;background:rgba(255,255,255,.03)}.cred-strip{display:grid;grid-template-columns:repeat(4,1fr);background:white;border-bottom:1px solid var(--line)}.cred{padding:23px 22px;border-right:1px solid var(--line)}.cred:last-child{border-right:0}.cred strong{display:block;color:var(--navy);font-size:16px}.cred span{display:block;color:var(--muted);font-size:12px;margin-top:5px}.portrait-card{position:relative;z-index:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:30px;padding:18px;align-self:end}.portrait{height:470px;border-radius:22px;background:linear-gradient(150deg,#1c3b5d,#081a2f 55%,#d2a044);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.portrait:before{content:"PHOTO PROFESSIONNELLE";position:absolute;top:24px;right:22px;font-size:10px;letter-spacing:.16em;color:rgba(255,255,255,.48);font-weight:900}.person{width:190px;height:255px;border-radius:95px 95px 22px 22px;background:linear-gradient(#e4c292 0 22%,#172a43 23% 100%);box-shadow:0 24px 55px rgba(0,0,0,.25);position:relative}.person:before{content:"";position:absolute;top:-58px;left:51px;width:88px;height:88px;background:#7b4f32;border-radius:50%}.portrait-caption{display:flex;justify-content:space-between;gap:12px;margin-top:14px;font-size:12px;color:rgba(255,255,255,.76)}.section{padding:76px 54px}.section.dark{background:var(--navy);color:white}.section-header{display:grid;grid-template-columns:260px 1fr;gap:42px;align-items:start;margin-bottom:36px}.kicker{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:var(--gold);font-weight:900}.title{font-family:var(--serif);font-size:44px;line-height:1.07;font-weight:500;letter-spacing:-.025em;color:var(--navy)}.dark .title{color:#fff}.lead{font-size:17px;color:#647184;max-width:760px;line-height:1.75;margin-top:14px}.dark .lead{color:rgba(255,255,255,.7)}.project-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.project{background:white;border:1px solid var(--line);border-radius:24px;padding:32px;box-shadow:var(--soft);min-height:360px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.project:after{content:"";position:absolute;right:-80px;bottom:-80px;width:210px;height:210px;border-radius:50%;background:rgba(200,150,50,.12)}.project.featured{background:linear-gradient(135deg,var(--navy),var(--navy3));color:white}.project h3{font-family:var(--serif);font-size:36px;font-weight:500;line-height:1.08}.project p{margin-top:16px;color:var(--muted);line-height:1.75}.project.featured p{color:rgba(255,255,255,.72)}.project-meta{font-size:12px;text-transform:uppercase;letter-spacing:.16em;font-weight:900;color:var(--gold);margin-bottom:18px}.project-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}.project .btn-ghost{color:var(--navy);border-color:rgba(6,23,43,.16)}.project.featured .btn-ghost{color:white;border-color:rgba(255,255,255,.25)}.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.service{background:white;border:1px solid var(--line);border-radius:20px;padding:24px;min-height:260px;box-shadow:var(--soft);display:flex;flex-direction:column;justify-content:space-between}.num{font-family:var(--serif);font-size:36px;color:var(--gold)}.service h3{font-size:18px;color:var(--navy);line-height:1.2;margin-top:12px}.service p{font-size:14px;color:var(--muted);line-height:1.65;margin-top:12px}.service a{color:var(--gold);font-weight:900;text-decoration:none;font-size:13px;margin-top:20px}.split{display:grid;grid-template-columns:1fr 1fr;gap:28px}.card{background:white;border:1px solid var(--line);border-radius:24px;padding:34px;box-shadow:var(--soft)}.card.gold{background:linear-gradient(135deg,#fff7e5,#f7e8c7)}.card h3,.card h2{font-family:var(--serif);font-size:32px;font-weight:500;color:var(--navy);line-height:1.12}.card p{font-size:15px;color:#5d6a7d;line-height:1.75;margin-top:16px}.quote{font-family:var(--serif);font-size:34px;line-height:1.18;color:var(--navy)}.quote span{color:var(--gold)}.process{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.step{border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:28px;background:rgba(255,255,255,.04)}.step small{color:var(--gold);font-weight:900;letter-spacing:.14em}.step h3{font-size:20px;margin-top:16px}.step p{font-size:14px;color:rgba(255,255,255,.68);line-height:1.7;margin-top:10px}.page-hero{background:linear-gradient(135deg,var(--navy),var(--navy2));color:white;padding:66px 54px}.page-hero .h1{font-size:52px}.content-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:28px;padding:58px 54px;background:var(--cream2)}.mini-list{margin-top:22px;display:grid;gap:12px}.mini{border-left:3px solid var(--gold);padding:12px 0 12px 16px}.mini strong{display:block;color:var(--navy)}.mini span{font-size:13px;color:var(--muted)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field.full{grid-column:1/-1}.field label{font-size:12px;font-weight:900;color:#405065}.field input,.field select,.field textarea{width:100%;border:1px solid rgba(6,23,43,.16);background:#fbfaf7;border-radius:12px;padding:13px;color:var(--navy)}.field textarea{min-height:116px;resize:vertical}.submit{width:100%;border:0;background:var(--gold);color:#07182d;border-radius:999px;padding:15px;font-weight:900;margin-top:16px;cursor:pointer}.cta{margin:0 54px 76px;background:var(--gold);border-radius:28px;padding:40px;display:flex;justify-content:space-between;gap:24px;align-items:center;color:#07182d}.cta h2{font-family:var(--serif);font-weight:500;font-size:34px;letter-spacing:-.02em}.cta p{color:#243348;margin-top:8px}.cta .btn{background:#07182d;color:white;white-space:nowrap}.footer{background:#061324;color:white;padding:46px 54px;display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr 1.2fr;gap:28px}.footer h4{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:var(--gold);margin-bottom:12px}.footer p,.footer a{display:block;color:rgba(255,255,255,.62);font-size:13px;text-decoration:none;line-height:1.7;margin-bottom:6px}.footer-social{display:flex;gap:8px;margin-top:12px}.footer-social .social-dot{width:34px;height:34px}.social-panel{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.social-chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 14px;text-decoration:none;color:var(--navy);font-weight:850;font-size:13px}@media(max-width:980px){body{padding:0}.nav{padding:0 22px}.nav-right{display:none}.hero{grid-template-columns:1fr;padding:52px 24px}.h1{font-size:43px}.portrait{height:360px}.cred-strip,.service-grid,.process,.split,.content-grid,.footer,.project-grid{grid-template-columns:1fr}.cred{border-right:0;border-bottom:1px solid var(--line)}.section,.page-hero,.content-grid{padding:46px 24px}.section-header{grid-template-columns:1fr;gap:12px}.cta{margin:0 24px 46px;display:block}.cta .btn{margin-top:18px}.footer{padding:36px 24px}.title{font-size:34px}.page-hero .h1{font-size:38px}.form-grid{grid-template-columns:1fr}}


/* === Premium decorative border system - production-ready === */
.site{
  position:relative;
  overflow:hidden;
}
.site::before,
.site::after{
  content:"";
  position:fixed;
  top:0;
  bottom:0;
  width:1px;
  pointer-events:none;
  z-index:40;
  background:linear-gradient(to bottom, transparent 0%, rgba(200,150,50,.28) 14%, rgba(255,255,255,.14) 50%, rgba(200,150,50,.24) 86%, transparent 100%);
}
.site::before{left:22px;}
.site::after{right:22px;}
.nav{
  border-bottom:1px solid rgba(226,184,98,.22);
  box-shadow:0 1px 0 rgba(255,255,255,.045) inset;
}
.hero,
.page-hero{
  box-shadow:inset 0 0 0 1px rgba(226,184,98,.105), inset 0 -1px 0 rgba(226,184,98,.18);
}
.hero::after,
.page-hero::after{
  content:"";
  position:absolute;
  left:54px;
  bottom:0;
  width:260px;
  height:3px;
  background:linear-gradient(90deg,var(--gold),rgba(226,184,98,.28),transparent);
}
.page-hero{position:relative;overflow:hidden;}
.page-hero::before{
  content:"";
  position:absolute;
  right:-150px;
  bottom:-210px;
  width:520px;
  height:520px;
  background:radial-gradient(circle,rgba(200,150,50,.18),transparent 64%);
}
.section{
  position:relative;
}
.section::before{
  content:"";
  position:absolute;
  top:0;
  left:54px;
  right:54px;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(6,23,43,.10),rgba(200,150,50,.22),rgba(6,23,43,.10),transparent);
}
.section.dark::before{
  background:linear-gradient(90deg,transparent,rgba(226,184,98,.10),rgba(226,184,98,.32),rgba(226,184,98,.10),transparent);
}
.project,
.service,
.card,
.portrait-card,
.cta{
  border-color:rgba(6,23,43,.14);
  box-shadow:var(--soft), inset 0 0 0 1px rgba(255,255,255,.58);
}
.project.featured,
.portrait-card{
  box-shadow:0 28px 80px rgba(6,23,43,.18), inset 0 0 0 1px rgba(226,184,98,.16);
  border-color:rgba(226,184,98,.22);
}
.portrait{
  box-shadow:inset 0 0 0 1px rgba(226,184,98,.20);
}
.card.gold{
  border-color:rgba(200,150,50,.28);
}
.cred-strip{
  border-top:1px solid rgba(200,150,50,.16);
  border-bottom:1px solid rgba(6,23,43,.13);
}
.cred{
  position:relative;
}
.cred::after{
  content:"";
  position:absolute;
  left:22px;
  right:22px;
  bottom:0;
  height:1px;
  background:linear-gradient(90deg,rgba(200,150,50,.38),transparent);
  opacity:.55;
}
.cta{
  border:1px solid rgba(200,150,50,.48);
  position:relative;
  overflow:hidden;
  box-shadow:
    0 22px 55px rgba(6,23,43,.10),
    0 1px 0 rgba(255,255,255,.34) inset,
    inset 0 0 0 1px rgba(255,255,255,.10);
}
.cta::before{
  content:"";
  position:absolute;
  inset:13px;
  border:1px solid rgba(255,255,255,.24);
  border-radius:22px;
  pointer-events:none;
}
.cta::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:28px;
  pointer-events:none;
  background:linear-gradient(135deg,rgba(255,255,255,.16),transparent 42%,rgba(6,23,43,.035));
}
.cta > *{
  position:relative;
  z-index:1;
}
.footer{
  border-top:1px solid rgba(226,184,98,.28);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.045);
}
.footer > div{
  position:relative;
}
.footer > div:not(:last-child)::after{
  content:"";
  position:absolute;
  top:0;
  right:-14px;
  width:1px;
  height:100%;
  background:linear-gradient(to bottom,rgba(226,184,98,.22),transparent 72%);
}
@media(max-width:900px){
  .site::before,.site::after{display:none;}
  .hero::after,.page-hero::after{left:24px;width:180px;}
  .section::before{left:24px;right:24px;}
  .footer > div:not(:last-child)::after{display:none;}
  .cta::before{display:none;}
}

/* === Optimisation chirurgicale 9.4/9.6 === */
.nav{flex-wrap:wrap;}
.mobile-nav{display:none;width:100%;gap:8px;overflow-x:auto;padding:0 0 14px;scrollbar-width:none;}
.mobile-nav::-webkit-scrollbar{display:none;}
.mobile-nav a{white-space:nowrap;color:rgba(255,255,255,.82);text-decoration:none;border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:8px 12px;font-size:12px;font-weight:850;background:rgba(255,255,255,.04);}
.hero-signature{display:inline-flex;align-items:center;gap:10px;margin-top:24px;color:rgba(255,255,255,.72);font-size:13px;font-weight:800;letter-spacing:.02em;}
.hero-signature::before{content:"";width:42px;height:1px;background:var(--gold);display:block;}
.project.s2b{background:linear-gradient(135deg,#fff,#fff8e8);}
.project.s2b::before{content:"";position:absolute;left:0;top:0;width:100%;height:5px;background:linear-gradient(90deg,var(--gold),rgba(226,184,98,.18));}
.project-points{display:grid;gap:10px;margin-top:22px;position:relative;z-index:1;}
.project-points li{list-style:none;border:1px solid rgba(6,23,43,.10);background:rgba(255,255,255,.58);border-radius:14px;padding:10px 12px;color:#405065;font-size:13px;font-weight:750;}
.project.featured .project-points li{border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.06);color:rgba(255,255,255,.78);}
.intent-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;}
.intent-chip{border:1px solid rgba(6,23,43,.13);background:rgba(255,255,255,.72);border-radius:999px;padding:9px 13px;color:var(--navy);font-size:13px;font-weight:850;}
.dark .intent-chip{border-color:rgba(255,255,255,.16);background:rgba(255,255,255,.06);color:rgba(255,255,255,.82);}
.vision-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:stretch;}
.vision-statement{background:linear-gradient(135deg,#fff7e5,#f7e8c7);border:1px solid rgba(200,150,50,.34);border-radius:24px;padding:38px;box-shadow:var(--soft);position:relative;overflow:hidden;}
.vision-statement::after{content:"";position:absolute;right:-70px;bottom:-70px;width:220px;height:220px;border-radius:50%;background:rgba(200,150,50,.13);}
.vision-statement h3{font-family:var(--serif);font-size:36px;line-height:1.1;font-weight:500;color:var(--navy);position:relative;z-index:1;}
.vision-statement p{font-size:16px;color:#465469;line-height:1.8;margin-top:18px;position:relative;z-index:1;}
.social-proof{display:grid;gap:12px;margin-top:20px;}
.social-proof a{display:flex;justify-content:space-between;align-items:center;text-decoration:none;color:var(--navy);border:1px solid rgba(6,23,43,.12);border-radius:16px;padding:13px 15px;background:#fff;font-weight:850;}
.social-proof span{color:var(--muted);font-weight:700;font-size:13px;}
.cta-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px;}
.cta-links a{color:#07182d;text-decoration:none;border:1px solid rgba(7,24,45,.20);border-radius:999px;padding:9px 13px;font-size:13px;font-weight:900;background:rgba(255,255,255,.20);}
@media(max-width:980px){
  .nav{height:auto;min-height:78px;padding:18px 22px 0;align-items:flex-start;}
  .mobile-nav{display:flex;}
  .h1{font-size:39px;line-height:1.02;}
  .hero{padding:44px 22px 48px;gap:32px;}
  .sub{font-size:16px;line-height:1.65;}
  .project{min-height:auto;padding:26px;}
  .project h3{font-size:31px;}
  .vision-grid{grid-template-columns:1fr;}
  .vision-statement{padding:28px;}
  .vision-statement h3{font-size:30px;}
  .cta-links a{background:rgba(255,255,255,.34);}
}


/* === Optimisation mobile chirurgicale — excellence finale === */
@media (max-width: 980px) {
  .nav {
    min-height: auto;
    padding: 16px 20px 0;
  }

  .brand {
    font-size: 17px;
  }

  .mobile-nav {
    display: flex;
    gap: 8px;
    padding: 12px 0 13px;
  }

  .mobile-nav a {
    font-size: 11.5px;
    padding: 7px 11px;
    border-radius: 999px;
  }

  .mobile-nav a[data-target="insights"] {
    display: none;
  }

  .hero {
    padding: 38px 22px 38px;
    gap: 26px;
  }

  .eyebrow {
    font-size: 10.5px;
    letter-spacing: .17em;
    margin-bottom: 14px;
  }

  .h1 {
    font-size: clamp(34px, 9.1vw, 40px);
    line-height: 1.01;
    letter-spacing: -.035em;
  }

  .sub {
    font-size: 15.5px;
    line-height: 1.62;
    margin-top: 18px;
  }

  .actions {
    margin-top: 24px;
    gap: 10px;
  }

  .btn {
    padding: 12px 17px;
    font-size: 13.5px;
  }

  .hero-signature {
    margin-top: 18px;
    font-size: 12px;
    line-height: 1.45;
  }

  .hero-signature::before {
    width: 34px;
  }

  .portrait-card {
    padding: 13px;
    border-radius: 24px;
    max-width: 420px;
    margin: 0 auto;
  }

  .portrait {
    height: 300px;
    border-radius: 18px;
  }

  .portrait:before {
    top: 18px;
    right: 16px;
    font-size: 8.5px;
  }

  .person {
    width: 138px;
    height: 190px;
    border-radius: 72px 72px 18px 18px;
  }

  .person:before {
    width: 68px;
    height: 68px;
    top: -45px;
    left: 35px;
  }

  .portrait-caption {
    font-size: 11.5px;
    margin-top: 10px;
  }

  .cred-strip {
    grid-template-columns: repeat(2, 1fr);
  }

  .cred {
    padding: 18px 18px;
    border-right: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }

  .cred:nth-child(2n) {
    border-right: 0;
  }

  .cred strong {
    font-size: 14.5px;
    line-height: 1.25;
  }

  .cred span {
    font-size: 11.5px;
    line-height: 1.45;
  }

  .section,
  .page-hero,
  .content-grid {
    padding: 42px 22px;
  }

  .section-header {
    gap: 10px;
    margin-bottom: 28px;
  }

  .title {
    font-size: clamp(31px, 8vw, 36px);
    line-height: 1.08;
  }

  .lead {
    font-size: 15.5px;
    line-height: 1.66;
    margin-top: 12px;
  }

  .intent-row {
    gap: 8px;
    margin-top: 18px;
  }

  .intent-chip {
    font-size: 12.5px;
    padding: 8px 11px;
  }

  .project {
    padding: 25px;
    border-radius: 24px;
  }

  .project h3 {
    font-size: clamp(31px, 8.6vw, 38px);
    line-height: 1.06;
  }

  .project p {
    font-size: 15px;
    line-height: 1.65;
    margin-top: 14px;
  }

  .project-meta {
    font-size: 10.5px;
    letter-spacing: .15em;
    margin-bottom: 14px;
  }

  .project-points {
    gap: 9px;
    margin-top: 18px;
  }

  .project-points li {
    font-size: 12.5px;
    padding: 9px 11px;
  }

  .project-actions {
    gap: 9px;
    margin-top: 22px;
  }

  .service {
    min-height: auto;
    padding: 22px;
  }

  .service h3 {
    font-size: 17px;
  }

  .service p {
    font-size: 13.5px;
  }

  .process {
    gap: 13px;
  }

  .step {
    padding: 24px;
    border-radius: 20px;
  }

  .step h3 {
    font-size: 19px;
  }

  .step p {
    font-size: 13.5px;
  }

  .vision-statement {
    padding: 26px;
    border-radius: 22px;
  }

  .vision-statement h3 {
    font-size: clamp(30px, 8.5vw, 38px);
    line-height: 1.08;
  }

  .vision-statement p {
    font-size: 15px;
    line-height: 1.68;
  }

  .card {
    padding: 26px;
    border-radius: 22px;
  }

  .card h3,
  .card h2 {
    font-size: clamp(29px, 8vw, 35px);
    line-height: 1.1;
  }

  .card p {
    font-size: 14.5px;
    line-height: 1.68;
  }

  .social-proof {
    gap: 10px;
  }

  .social-proof a {
    padding: 12px 13px;
    border-radius: 14px;
    gap: 10px;
  }

  .social-proof span {
    font-size: 12.2px;
  }

  .cta {
    margin: 0 22px 42px;
    padding: 30px 24px;
    border-radius: 24px;
  }

  .cta h2 {
    font-size: clamp(32px, 8.8vw, 40px);
    line-height: 1.08;
  }

  .cta p {
    font-size: 15px;
    line-height: 1.58;
  }

  .cta-links {
    gap: 8px;
    margin-top: 15px;
  }

  .cta-links a {
    font-size: 12.5px;
    padding: 8px 11px;
  }

  .cta .btn {
    margin-top: 18px;
  }

  .footer {
    padding: 32px 22px 34px;
    gap: 22px;
  }

  .footer .brand {
    font-size: 17px;
  }

  .footer p,
  .footer a {
    font-size: 12.5px;
    line-height: 1.55;
    margin-bottom: 5px;
  }

  .footer h4 {
    font-size: 10.5px;
    margin-bottom: 9px;
  }

  .footer-social {
    gap: 6px;
    margin-top: 10px;
  }

  .footer-social .social-dot {
    width: 30px;
    height: 30px;
  }

  .cta::before {
    inset: 10px;
    border-radius: 18px;
  }

  .section::before {
    left: 22px;
    right: 22px;
  }

  .hero::after,
  .page-hero::after {
    left: 22px;
    width: 155px;
  }
}

@media (max-width: 420px) {
  .h1 {
    font-size: 35px;
  }

  .hero {
    padding-left: 20px;
    padding-right: 20px;
  }

  .cred-strip {
    grid-template-columns: 1fr 1fr;
  }

  .cred {
    padding: 16px 15px;
  }

  .project,
  .card,
  .vision-statement {
    padding: 23px;
  }

  .cta {
    padding: 28px 22px;
  }

  .footer {
    padding-left: 22px;
    padding-right: 22px;
  }
}



/* === Production static site adjustments === */
a{transition:color .18s ease, background .18s ease, border-color .18s ease, transform .18s ease;}
a[href]{cursor:pointer;}
.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;}
.skip-link:focus{left:16px;top:16px;width:auto;height:auto;background:#fff;color:#06172b;padding:10px 14px;border-radius:999px;z-index:999;}
.current-page{color:#fff!important;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.form-status{font-size:13px;color:#405065;margin-top:12px;line-height:1.55;}
.field input:focus,.field select:focus,.field textarea:focus{outline:2px solid rgba(200,150,50,.45);border-color:rgba(200,150,50,.75);}
.placeholder-note{font-size:12px;color:rgba(255,255,255,.62);margin-top:8px;}
@media(max-width:980px){.nav-right{display:none!important;}.mobile-nav{display:flex!important;}}

/* === Correction header brand link - local validation === */
.brand,
.brand:link,
.brand:visited,
.nav .brand,
.nav .brand:link,
.nav .brand:visited,
.footer .brand,
.footer .brand:link,
.footer .brand:visited {
  color: #ffffff;
  text-decoration: none;
}

.brand:hover,
.brand:focus,
.nav .brand:hover,
.nav .brand:focus,
.footer .brand:hover,
.footer .brand:focus {
  color: #ffffff;
  text-decoration: none;
}

.brand span,
.brand:link span,
.brand:visited span,
.nav .brand span,
.footer .brand span {
  color: var(--gold);
}

/* === Sprint 2 grouped corrections - FR home === */
.portrait::before{
  content:none!important;
}
.portrait-img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center bottom;
  display:block;
  position:relative;
  z-index:1;
  filter:drop-shadow(0 28px 40px rgba(0,0,0,.28));
}
.portrait{
  background:linear-gradient(150deg,#1c3b5d,#081a2f 55%,#d2a044);
}
@media(max-width:980px){
  .portrait-img{object-fit:contain;object-position:center bottom;}
}

/* === Sprint 2 grouped corrections - FR home v1.6 === */
@media (min-width: 981px) {
  .cred:first-child {
    padding-left: 54px;
  }
}
@media (max-width: 980px) {
  .cred:first-child {
    padding-left: 22px;
  }
}

/* === Sprint 2 v1.7 - Home FR visual polish === */
.social-dot,
.nav-social .social-dot,
.footer-social .social-dot {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  text-align: center !important;
  text-decoration: none !important;
  font-family: var(--sans) !important;
  letter-spacing: 0 !important;
  padding: 0 !important;
}

@media (min-width: 981px) {
  .hero {
    grid-template-columns: minmax(0, .98fr) 440px;
    gap: 72px;
    align-items: center;
  }
  .hero > div:first-child {
    max-width: 790px;
  }
  .hero .hero-title {
    max-width: 760px;
    font-size: clamp(56px, 5.05vw, 72px);
    line-height: .98;
    letter-spacing: -.043em;
  }
  .hero-title .hero-line {
    display: block;
  }
  .hero .sub {
    max-width: 720px;
  }
  .portrait-card {
    align-self: center;
    max-width: 500px;
  }
  .portrait {
    height: 520px;
    padding: 22px 26px 0;
    align-items: flex-end;
    justify-content: center;
  }
  .portrait-img {
    width: 94%;
    height: 100%;
    object-fit: contain;
    object-position: center bottom;
  }
}

@media (max-width: 980px) {
  .hero-title .hero-line {
    display: inline;
  }
  .portrait {
    padding: 18px 16px 0;
  }
  .portrait-img {
    width: 90%;
    height: 100%;
    object-fit: contain;
    object-position: center bottom;
  }
}


/* === Sprint 2 v1.9 - Home FR mobile polish === */
@media (max-width: 980px) {
  /* Keep desktop hero untouched; fix mobile H1 word collisions by restoring block lines. */
  .hero-title .hero-line {
    display: block;
  }
  .hero .hero-title {
    max-width: 100%;
    line-height: 1.02;
    letter-spacing: -.035em;
  }
  /* Slightly compact portrait on mobile only. */
  .portrait {
    height: 276px;
    padding: 16px 15px 0;
  }
  .portrait-img {
    width: 88%;
    object-position: center bottom;
  }
  /* Mobile footer: identity full-width, then 2 x 2 grid for the four link groups. */
  .footer {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 24px;
    row-gap: 24px;
  }
  .footer > div:first-child {
    grid-column: 1 / -1;
  }
  .footer p,
  .footer a {
    overflow-wrap: anywhere;
  }
}

@media (max-width: 420px) {
  .hero .hero-title {
    font-size: clamp(31px, 8.55vw, 35px);
  }
  .portrait {
    height: 260px;
  }
  .footer {
    column-gap: 18px;
    row-gap: 22px;
  }
  .footer p,
  .footer a {
    font-size: 12px;
  }
}

/* === v1.11 - Mobile nav scroll/fitting fix === */
@media (max-width: 980px) {
  .mobile-nav {
    width: 100%;
    max-width: 100%;
    display: flex !important;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;
    scroll-padding-inline: 0 18px;
  }
  .mobile-nav::-webkit-scrollbar {
    display: none;
  }
  .mobile-nav a {
    flex: 0 0 auto;
    white-space: nowrap;
    line-height: 1;
  }
}

@media (max-width: 480px) {
  .mobile-nav {
    gap: 6px;
    padding: 12px 0 13px;
  }
  .mobile-nav a {
    font-size: 10.75px;
    padding: 7px 9px;
  }
}


/* === Sprint 3 About FR social network grid === */
.about-social-block{
  margin-top:24px;
  padding-top:22px;
  border-top:1px solid var(--line);
}
.about-social-block h3{
  font-family:var(--serif);
  font-size:28px;
  font-weight:500;
  line-height:1.1;
  color:var(--navy);
}
.about-social-block p{
  margin-top:8px;
  max-width:620px;
}
.about-social-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:18px;
}
.about-social-item{
  display:block;
  border-left:3px solid var(--gold);
  padding:12px 12px 12px 16px;
  border-radius:0 14px 14px 0;
  text-decoration:none;
  background:rgba(255,255,255,.72);
  transition:background .18s ease, transform .18s ease;
}
.about-social-item:hover{
  background:#fff;
  transform:translateY(-1px);
}
.about-social-item strong{
  display:block;
  color:var(--navy);
  font-size:14px;
  font-weight:900;
}
.about-social-item span{
  display:block;
  color:var(--muted);
  font-size:12.5px;
  margin-top:3px;
}
.about-social-item:last-child{
  grid-column:1 / -1;
}
@media(max-width:980px){
  .about-social-grid{
    grid-template-columns:1fr;
  }
  .about-social-item:last-child{
    grid-column:auto;
  }
}


/* === v1.20 - CK logo header test === */
.nav .brand{display:inline-flex;align-items:center;gap:9px;}
.brand-text{display:inline-flex;gap:4px;align-items:baseline;}

/* v1.20 logo text color guard */
.nav .brand .brand-text{color:#ffffff;}
.nav .brand .brand-text > span{color:var(--gold);}


/* === v1.22 - Simple CK logo in header === */
.nav .brand{display:inline-flex;align-items:center;gap:10px;}
.nav .brand .brand-logo{
  width:28px;
  height:28px;
  display:block;
  flex:0 0 28px;
  border-radius:4px;
  object-fit:contain;
}
@media(max-width:980px){
  .nav .brand .brand-logo{width:26px;height:26px;flex-basis:26px;}
}


/* === v1.27 - About EN typography alignment === */
@media(min-width:981px){
  .about-en-page .page-hero .sub{
    font-size:18px;
    line-height:1.72;
    max-width:700px;
  }
  .about-en-page .content-grid .card p{
    font-size:15.5px;
    line-height:1.75;
  }
  .about-en-page .mini span{
    font-size:13.5px;
    line-height:1.65;
  }
  .about-en-page .about-social-item span{
    font-size:13px;
  }
}


/* === v1.29 - Internal page hero cleanup + mobile language visibility test === */
.page-hero{
  background:var(--navy);
}
.page-hero::before{
  content:none!important;
  display:none!important;
}
@media(max-width:980px){
  .mobile-nav .mobile-lang-switch{
    background:var(--gold)!important;
    color:#07182d!important;
    border-color:var(--gold)!important;
    font-weight:950!important;
    padding:8px 13px!important;
  }
}
@media(max-width:420px){
  .mobile-nav .mobile-lang-switch{
    padding:7px 11px!important;
  }
}


/* === v1.30 - Mobile navigation complete wrap fix === */
@media(max-width:980px){
  .mobile-nav{
    display:flex!important;
    flex-wrap:wrap!important;
    overflow:visible!important;
    row-gap:8px;
    column-gap:7px;
    width:100%;
    max-width:100%;
    padding:12px 0 15px!important;
  }
  .mobile-nav a,
  .mobile-nav a[data-target="insights"]{
    display:inline-flex!important;
    align-items:center;
    flex:0 1 auto!important;
    white-space:nowrap!important;
    max-width:100%;
  }
}
@media(max-width:420px){
  .mobile-nav{
    column-gap:6px;
    row-gap:7px;
  }
  .mobile-nav a{
    font-size:10.4px!important;
    padding:7px 8px!important;
  }
  .mobile-nav .mobile-lang-switch{
    padding:7px 10px!important;
  }
}

/* === v1.31 - Premium mobile header/menu test === */
.mobile-actions{display:none;}
@media(max-width:980px){
  .nav{
    display:grid!important;
    grid-template-columns:minmax(0,1fr) auto;
    align-items:center!important;
    gap:12px 12px;
    padding:16px 20px!important;
  }
  .nav .brand{
    min-width:0;
    grid-column:1;
  }
  .mobile-actions{
    grid-column:2;
    display:flex!important;
    align-items:center;
    justify-content:flex-end;
    gap:8px;
  }
  .mobile-top-lang,
  .mobile-menu-toggle{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-height:34px;
    border-radius:999px;
    padding:8px 12px;
    font-size:11.5px;
    font-family:var(--sans);
    font-weight:950;
    line-height:1;
    text-decoration:none;
    cursor:pointer;
  }
  .mobile-top-lang{
    background:var(--gold);
    border:1px solid var(--gold);
    color:#07182d!important;
  }
  .mobile-menu-toggle{
    background:rgba(255,255,255,.05);
    color:#fff;
    border:1px solid rgba(255,255,255,.22);
  }
  .mobile-nav{
    grid-column:1 / -1;
    display:none!important;
    width:100%;
    max-width:100%;
    grid-template-columns:1fr;
    gap:8px;
    margin-top:2px;
    padding:13px 0 0!important;
    border-top:1px solid rgba(255,255,255,.12);
    overflow:visible!important;
  }
  .nav.mobile-menu-open .mobile-nav{
    display:grid!important;
  }
  .mobile-nav .mobile-lang-switch{
    display:none!important;
  }
  .mobile-nav a,
  .mobile-nav a[data-target="insights"]{
    display:flex!important;
    align-items:center;
    justify-content:space-between;
    width:100%;
    min-height:40px;
    border-radius:14px;
    padding:11px 13px!important;
    font-size:13px!important;
    font-weight:850;
    letter-spacing:.01em;
    white-space:normal!important;
    color:rgba(255,255,255,.88)!important;
    background:rgba(255,255,255,.045);
    border:1px solid rgba(255,255,255,.13);
  }
  .mobile-nav a.current-page{
    background:rgba(200,150,50,.18);
    border-color:rgba(200,150,50,.42);
    color:#fff!important;
  }
}
@media(max-width:390px){
  .nav{
    padding:14px 18px!important;
    gap:10px 10px;
  }
  .nav .brand{
    font-size:16px;
  }
  .nav .brand .brand-logo{
    width:24px;
    height:24px;
    flex-basis:24px;
  }
  .mobile-actions{
    gap:6px;
  }
  .mobile-top-lang,
  .mobile-menu-toggle{
    min-height:32px;
    padding:7px 10px;
    font-size:10.75px;
  }
}

/* === Sprint 4 - Immobilier FR hero === */
.realestate-hero{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:34px;
  align-items:end;
  background:linear-gradient(135deg,#06172b 0%,#0d243d 58%,#143553 100%);
}
.realestate-hero-copy,
.realestate-hero-panel{
  position:relative;
  z-index:1;
}
.realestate-hero .h1{
  max-width:850px;
}
.realestate-hero .sub{
  max-width:760px;
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:30px;
}
.realestate-hero-panel{
  border:1px solid rgba(226,184,98,.24);
  border-radius:26px;
  padding:24px;
  background:linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.035));
  box-shadow:0 24px 70px rgba(0,0,0,.18), inset 0 0 0 1px rgba(255,255,255,.055);
}
.realestate-status{
  display:inline-flex;
  width:fit-content;
  border-radius:999px;
  padding:8px 11px;
  background:rgba(200,150,50,.16);
  border:1px solid rgba(226,184,98,.28);
  color:var(--gold2);
  font-size:11px;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.realestate-brokerage{
  margin-top:18px;
  font-family:var(--serif);
  color:#fff;
  font-size:30px;
  line-height:1.05;
  font-weight:500;
  letter-spacing:-.02em;
}
.realestate-quick-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:8px;
  margin-top:22px;
}
.realestate-quick-grid a{
  border:1px solid rgba(255,255,255,.15);
  border-radius:999px;
  padding:9px 10px;
  color:rgba(255,255,255,.82);
  font-size:12px;
  font-weight:850;
  text-align:center;
  background:rgba(255,255,255,.045);
  text-decoration:none;
  transition:background .18s ease,border-color .18s ease,transform .18s ease;
}
.realestate-quick-grid a:hover,
.realestate-quick-grid a:focus-visible{
  background:rgba(200,150,50,.16);
  border-color:rgba(226,184,98,.42);
  color:#fff;
  transform:translateY(-1px);
}
.realestate-hero-panel p{
  margin-top:18px;
  color:rgba(255,255,255,.66);
  font-size:13px;
  line-height:1.6;
}
@media(max-width:980px){
  .realestate-hero{
    grid-template-columns:1fr;
    gap:26px;
  }
  .realestate-hero-panel{
    max-width:560px;
  }
}
@media(max-width:420px){
  .realestate-hero{
    padding-top:40px;
  }
  .realestate-hero .h1{
    font-size:34px;
    line-height:1.02;
  }
  .realestate-hero .sub{
    font-size:15px;
    line-height:1.65;
  }
  .hero-actions .btn{
    width:100%;
    justify-content:center;
  }
  .realestate-hero-panel{
    padding:19px;
    border-radius:22px;
  }
  .realestate-brokerage{
    font-size:25px;
  }
  .realestate-quick-grid{
    grid-template-columns:1fr;
  }
}

/* === Sprint 4 — Immobilier FR : cartes publics servis === */
.service-grid.service-grid-five{
  grid-template-columns:repeat(5,minmax(0,1fr));
}

@media(max-width:1280px){
  .service-grid.service-grid-five{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

@media(max-width:980px){
  .service-grid.service-grid-five{
    grid-template-columns:1fr;
  }
}

/* === Sprint 4 — Immobilier FR : CTA final flottant premium === */
.cta{
  width:min(1600px,calc(100% - 128px));
  margin:72px auto 92px;
  padding:44px 50px;
  border-radius:34px;
  box-shadow:
    0 30px 78px rgba(6,23,43,.13),
    0 18px 48px rgba(200,150,50,.12),
    0 1px 0 rgba(255,255,255,.36) inset,
    inset 0 0 0 1px rgba(255,255,255,.12);
}
.cta::before{
  inset:16px;
  border-radius:25px;
  border-color:rgba(255,255,255,.26);
}
.cta::after{
  border-radius:34px;
  background:linear-gradient(135deg,rgba(255,255,255,.18),transparent 45%,rgba(6,23,43,.04));
}
.cta .btn{
  box-shadow:0 14px 30px rgba(6,23,43,.18);
}
.cta .btn:hover,
.cta .btn:focus-visible{
  transform:translateY(-1px);
}
@media(max-width:980px){
  .cta{
    width:calc(100% - 48px);
    margin:54px auto 56px;
    padding:32px 26px;
    border-radius:28px;
  }
  .cta::before{
    inset:11px;
    border-radius:20px;
  }
  .cta::after{
    border-radius:28px;
  }
}
@media(max-width:420px){
  .cta{
    width:calc(100% - 36px);
    margin-top:44px;
    padding:29px 22px;
  }
}

/* === Sprint 5 — Skills2Business FR première version === */
.s2b-hero .realestate-brokerage{
  font-size:28px;
}
.s2b-hero-panel p{
  margin-top:18px;
}
.s2b-quick-grid{
  margin-top:22px;
}
.s2b-today .card{
  min-height:420px;
}
.s2b-final-cta .cta-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.s2b-final-cta .btn-secondary-dark{
  background:rgba(7,24,45,.08);
  color:#07182d;
  border:1px solid rgba(7,24,45,.20);
  box-shadow:none;
}
@media(max-width:980px){
  .s2b-hero .realestate-brokerage{
    font-size:25px;
  }
  .s2b-today .card{
    min-height:auto;
  }
  .s2b-final-cta .cta-actions{
    justify-content:flex-start;
    margin-top:18px;
  }
  .s2b-final-cta .cta-actions .btn{
    width:100%;
    justify-content:center;
  }
}

/* === Sprint 5 — Skills2Business FR v2 refinements === */
.s2b-today-points{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  margin-top:22px;
}
.s2b-today-points span{
  border:1px solid rgba(6,23,43,.12);
  border-radius:999px;
  padding:10px 12px;
  color:var(--navy);
  background:rgba(200,150,50,.055);
  font-size:12px;
  font-weight:850;
}
@media(max-width:640px){
  .s2b-today-points{
    grid-template-columns:1fr;
  }
}


/* === Sprint 5 — Skills2Business FR v2.1 micro-corrections === */
.s2b-hero-panel .realestate-status{
  display:flex;
  width:100%;
  justify-content:center;
  padding:9px 14px;
  margin-bottom:20px;
}
.s2b-today .card > p:last-child{
  max-width:760px;
}

/* === Sprint 5 — Skills2Business brand casing correction === */
.s2b-hero .eyebrow,
#s2b-approach .kicker,
.s2b-today .kicker{
  text-transform:none;
}

/* === Sprint 5 — Skills2Business brand title balance === */
.s2b-hero .eyebrow,
#s2b-approach .kicker,
.s2b-today .kicker{
  font-size:13px;
  letter-spacing:.12em;
  text-transform:none;
}
@media(max-width:640px){
  .s2b-hero .eyebrow,
  #s2b-approach .kicker,
  .s2b-today .kicker{
    font-size:12.5px;
    letter-spacing:.10em;
  }
}

/* === Sprint 5 — Skills2Business brand title final emphasis === */
.s2b-hero .eyebrow,
#s2b-approach .kicker,
.s2b-today .kicker{
  font-size:15px;
  letter-spacing:.10em;
}
@media(max-width:640px){
  .s2b-hero .eyebrow,
  #s2b-approach .kicker,
  .s2b-today .kicker{
    font-size:14px;
    letter-spacing:.08em;
  }
}


/* Sprint 6 - Contact FR backend conversion */
.contact-routing{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:28px 54px 0;background:var(--cream2)}
.route-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 12px 28px rgba(6,23,43,.07);text-align:left;cursor:pointer;font:inherit;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease} .route-card:hover{transform:translateY(-2px);border-color:rgba(200,150,50,.55);box-shadow:0 18px 36px rgba(6,23,43,.1)}.route-card.is-active{border-color:rgba(200,150,50,.9);box-shadow:0 0 0 3px rgba(200,150,50,.14),0 18px 36px rgba(6,23,43,.1)}
.route-card strong{display:block;color:var(--navy);font-weight:900;margin-bottom:7px}.route-card span{display:block;color:var(--muted);font-size:13px;line-height:1.55}.contact-grid{align-items:start}.contact-form-intro{margin-top:10px!important}.contextual-help{border-left:3px solid var(--gold);background:#fbf4e6;border-radius:14px;padding:13px 15px;margin:18px 0 20px!important;color:#34445a!important;font-size:14px!important}.field-emphasis input{border-color:rgba(200,150,50,.75);box-shadow:0 0 0 3px rgba(200,150,50,.16)}.hp-field{position:absolute;left:-9999px;height:0;overflow:hidden}.submit:disabled{opacity:.72;cursor:not-allowed}.form-status a{color:var(--navy);font-weight:800}.form-status[data-kind="success"]{color:#176b3a}.form-status[data-kind="error"]{color:#9b2d20}.form-status[data-kind="info"]{color:#405065}.contact-side-card{position:sticky;top:24px}@media(max-width:980px){.contact-routing{grid-template-columns:1fr;padding:24px 24px 0}.contact-side-card{position:static}}

/* Sprint 6 v1.47 — Contact FR dynamic form */
.phone-code-field select{min-width:0;}
.phone-number-field input{min-width:0;}
@media(max-width:980px){.phone-code-field,.phone-number-field{grid-column:1/-1}}
.field .is-invalid{border-color:#9b2d20;box-shadow:0 0 0 3px rgba(155,45,32,.12)}.field-error{margin:7px 0 0;color:#9b2d20;font-size:12.5px;line-height:1.4;font-weight:700}


/* === Sprint 7 — Lire mes idées / Insights static editorial page === */
.insights-hero .sub{
  max-width:840px;
}
.insights-intro .lead + .lead{
  margin-top:12px;
}
.insight-topic-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.insight-topic{
  min-height:300px;
  display:flex;
  flex-direction:column;
}
.insight-topic .insight-tag{
  align-self:flex-start;
  display:inline-flex;
  border:1px solid rgba(200,150,50,.34);
  background:rgba(200,150,50,.08);
  color:var(--navy);
  border-radius:999px;
  padding:7px 11px;
  font-size:11px;
  font-weight:900;
  letter-spacing:.10em;
  text-transform:uppercase;
  margin-bottom:18px;
}
.insight-topic.gold .insight-tag{
  background:rgba(255,255,255,.48);
}
.insight-reflection-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.insight-reflection-grid .step{
  min-height:315px;
}
.insight-reflection-grid .step h3{
  line-height:1.22;
}
.insights-final-cta p{
  max-width:780px;
}
@media(max-width:1180px){
  .insight-topic-grid,
  .insight-reflection-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:980px){
  .insight-topic-grid,
  .insight-reflection-grid{
    grid-template-columns:1fr;
  }
  .insight-topic,
  .insight-reflection-grid .step{
    min-height:auto;
  }
}
@media(max-width:640px){
  .insight-topic .insight-tag{
    font-size:10px;
    letter-spacing:.08em;
  }
}
