@import url('https://fonts.googleapis.com/css2?family=Livvic:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400;1,500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --zodiac:#102441;--zodiac-mid:#1a3560;--zodiac-light:#243f72;
  --orchid:#DD928E;--orchid-light:#edb9b6;--orchid-pale:#f5e4e3;
  --white:#FFFFFF;--off-white:#F9F7F4;--gray-light:#F2F2F2;
  --gray-mid:#404040;--gray-dark:#262626;--livvic:'Livvic',system-ui,sans-serif;
}

html{scroll-behavior:smooth}

body{
  font-family:var(--livvic);
  background:var(--off-white);
  color:var(--gray-dark);
  font-size:19px;
  line-height:1.85;
  -webkit-font-smoothing:antialiased
}

.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);border:0
}

/* NAVIGATION */
nav{
  background:var(--zodiac);
  padding:1.1rem 3rem;
  display:flex;
  justify-content:space-between;
  align-items:center
}

.nav-logo-slot{display:flex;align-items:center;gap:0.5rem}

.nav-logo-badge{
  font-size:0.7rem;font-weight:500;color:rgba(255,255,255,0.3);
  font-style:italic;border:0px dashed rgba(255,255,255,0.2);
  padding:0.35rem 0.9rem;letter-spacing:0.05em
}

.nav-cta{
  font-family:var(--livvic);font-size:0.85rem;font-weight:600;
  letter-spacing:0.14em;text-transform:uppercase;color:var(--orchid);
  text-decoration:none;border-bottom:1px solid rgba(221,146,142,0.5);
  padding-bottom:2px;transition:color 0.2s
}

.nav-cta:hover{color:var(--white)}

/* HERO */
.hero{
  background:var(--zodiac);
  display:grid;
  grid-template-columns:1fr 1fr
}

.hero-text{padding:5rem 3rem 5rem 3.5rem}

.hero-eyebrow{
  font-size:0.82rem;font-weight:600;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--orchid);margin-bottom:1.5rem
}

.hero-h1{
  font-size:clamp(2.1rem,3.6vw,3rem);
  font-weight:600;line-height:1.2;color:var(--white);
  margin-bottom:1.75rem
}

.hero-accroche{
  font-size:1.15rem;font-weight:400;color:var(--white);
  line-height:1.9;margin-bottom:0.75rem
}

.hero-pivot{
  font-size:1.15rem;font-weight:500;font-style:italic;
  color:var(--white);margin-bottom:0.5rem
}

.hero-approche-link{
  display:inline-block;font-size:1.05rem;font-weight:500;
  color:var(--orchid-light);text-decoration:underline;
  text-underline-offset:4px;margin-bottom:2.5rem;cursor:pointer;
  background:none;border:none;font-family:var(--livvic);padding:0
}

.hero-approche-link:hover{color:var(--white)}

.btn-primary{
  display:inline-block;font-family:var(--livvic);font-size:0.9rem;
  font-weight:600;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--zodiac);background:var(--orchid);text-decoration:none;
  padding:1rem 2.4rem;transition:background 0.2s;border:none;cursor:pointer
}

.btn-primary:hover{background:var(--orchid-light)}

.hero-right{
  background:var(--zodiac-mid);min-height:520px;display:flex;
  flex-direction:column;justify-content:flex-end;position:relative;
  overflow:hidden
}

.hero-right::before{
  content:'';position:absolute;top:-15%;right:-20%;width:65%;height:65%;
  border-radius:50%;background:var(--zodiac-light);opacity:0.4
}

.photo-placeholder{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;background:var(--zodiac-mid)
}

.photo-silhouette{
  width:160px;height:200px;background:rgba(255,255,255,0.06);
  border-radius:4px;display:flex;align-items:center;justify-content:center;
  margin-bottom:1rem;border:1px dashed rgba(255,255,255,0.15)
}

.photo-silhouette svg{opacity:0.2}

.photo-label{
  font-size:0.72rem;font-weight:500;letter-spacing:0.1em;
  text-transform:uppercase;color:rgba(255,255,255,0.3);
  text-align:center;line-height:1.6
}

.photo-label strong{
  display:block;color:rgba(221,146,142,0.6);
  font-weight:600;margin-bottom:0.25rem
}

.hero-overlay{
  position:absolute;bottom:0;left:0;right:0;z-index:2;
  background:linear-gradient(to top,rgba(16,36,65,0.92) 0%,
  rgba(16,36,65,0.5) 55%,transparent 100%);
  padding:2rem 2rem 1.75rem
}

.hero-logo-over{
  display:block;margin-bottom:1rem;border:0px dashed rgba(255,255,255,0.2);
  padding:0.55rem 1rem;text-align:center;font-size:0.7rem;
  color:rgba(255,255,255,0.35);letter-spacing:0.08em;font-style:italic
}

.hero-card-mini{
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.15);padding:1.5rem
}

.hero-card-block{
  border-left:3px solid var(--orchid);
  padding-left:1.1rem;margin-bottom:0.85rem
}

.hero-card-line{
  font-size:1rem;font-weight:400;font-style:italic;
  color:var(--white);line-height:1.75;margin:0
}

.hero-card-line+.hero-card-line{margin-top:0.5rem}

.hero-card-meta{
  font-size:0.75rem;font-weight:600;letter-spacing:0.12em;
  text-transform:uppercase;color:var(--orchid)
}

/* CERTIFICATION STRIP */
.cert-strip{
  background:var(--zodiac-mid);border-top:1px solid rgba(255,255,255,0.1);
  padding:1.1rem 3.5rem;display:flex;align-items:center;
  gap:2rem;flex-wrap:wrap
}

.cert-item{
  display:flex;align-items:center;gap:0.6rem;font-size:0.8rem;
  font-weight:500;letter-spacing:0.08em;color:var(--white);
  text-transform:uppercase
}

.cert-dot{
  width:5px;height:5px;border-radius:50%;background:var(--orchid);
  flex-shrink:0
}

.cert-sep{
  width:1px;height:16px;background:rgba(255,255,255,0.2)
}

/* SECTIONS */
section{padding:5rem 3.5rem}

.section-label{
  font-size:0.8rem;font-weight:600;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--orchid);margin-bottom:1rem
}

.section-title{
  font-size:clamp(1.9rem,3.1vw,2.5rem);font-weight:600;
  line-height:1.25;color:var(--zodiac);margin-bottom:1.5rem
}

.section-title em{
  font-style:italic;color:var(--orchid);font-weight:400
}

.section-body,.section-body-after{
  font-size:1.12rem;color:var(--gray-mid);line-height:1.95;max-width:640px
}

.section-body p,.section-body-after p{margin-bottom:1.1rem}

.section-body p:last-child,.section-body-after p:last-child{margin-bottom:0}

.section-body strong,.section-body-after strong{
  color:var(--gray-dark);font-weight:600
}

.valeur-highlight{
  font-size:1.08rem;font-weight:400;font-style:italic;color:var(--zodiac);
  border-left:3px solid var(--orchid);padding:1.3rem 1.6rem;margin:2rem 0;
  background:var(--orchid-pale);line-height:1.9;max-width:740px
}

.valeur-highlight p{margin-bottom:0.85rem}

.valeur-highlight p:last-child{margin-bottom:0}

.valeur-highlight strong{
  font-weight:600;font-style:normal;color:var(--zodiac)
}

.transform-list{
  margin-top:1.75rem;display:flex;flex-direction:column;gap:0.85rem
}

.transform-item{
  display:flex;align-items:center;gap:0.9rem;font-size:1.1rem;
  font-weight:500;color:var(--gray-dark)
}

.transform-item::before{
  content:'';display:inline-block;width:7px;height:7px;border-radius:50%;
  background:var(--orchid);flex-shrink:0
}

.transform-close{
  font-size:1.25rem;font-weight:600;font-style:italic;
  color:var(--zodiac);margin-top:2rem
}

/* TERRAIN */
.terrain{
  background:var(--gray-light);padding:2.75rem 3.5rem;
  border-top:1px solid #ddd5cc;border-bottom:1px solid #ddd5cc
}

.terrain-label{
  font-size:0.8rem;font-weight:600;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--orchid);margin-bottom:0.75rem
}

.terrain-text{
  font-size:1.1rem;color:var(--gray-mid);line-height:1.9;max-width:700px
}

.terrain-text strong{
  color:var(--gray-dark);font-weight:600
}

/* FOR WHO */
.forwho{
  background:var(--zodiac);padding:5rem 3.5rem
}

.forwho .section-label,.contact-section .section-label{
  color:var(--orchid-light)
}

.forwho .section-title,.contact-section .section-title{
  color:var(--white)
}

.forwho .section-title em,.contact-section .section-title em{
  color:var(--orchid)
}

.forwho-intro{
  font-size:1.12rem;font-weight:400;color:var(--white);
  line-height:1.95;max-width:620px;margin-bottom:2.5rem
}

.forwho-intro strong{
  color:var(--white);font-weight:600
}

.forwho-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.25rem;margin-bottom:2rem
}

.forwho-card{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.15);padding:2rem
}

.forwho-mark{
  font-size:1.6rem;font-weight:300;font-style:italic;
  color:var(--orchid);opacity:0.7;margin-bottom:0.75rem;line-height:1
}

.forwho-title{
  font-size:1.08rem;font-weight:600;color:var(--white);
  margin-bottom:0.5rem
}

.forwho-desc{
  font-size:1rem;font-weight:400;color:var(--white);
  line-height:1.8
}

.forwho-geo{
  font-size:1.02rem;font-weight:400;color:var(--white);
  font-style:italic;border-top:1px solid rgba(255,255,255,0.12);
  padding-top:1.5rem;opacity:0.85
}

.forwho-geo strong{
  color:var(--white);font-weight:600;font-style:normal
}

/* CONTACT */
.contact-section{
  background:var(--zodiac);padding:5rem 3.5rem;
  display:grid;grid-template-columns:1fr 1fr;gap:5rem;
  align-items:start;border-top:1px solid rgba(255,255,255,0.1)
}

.contact-intro{
  font-size:1.1rem;font-weight:400;color:var(--white);
  line-height:1.9;margin-bottom:2rem;max-width:380px
}

.contact-details{
  display:flex;flex-direction:column;gap:1.25rem
}

.contact-row{
  display:flex;flex-direction:column;gap:0.25rem
}

.contact-lbl{
  font-size:0.78rem;font-weight:600;letter-spacing:0.14em;
  text-transform:uppercase;color:var(--orchid)
}

.contact-val{
  font-size:1.08rem;font-weight:400;color:var(--white)
}

.contact-sep{
  width:100%;height:1px;background:rgba(255,255,255,0.1)
}

.contact-note{
  font-size:0.95rem;font-weight:400;color:var(--white);
  line-height:1.8;margin-top:2rem;font-style:italic
}

/* FAQ */
.faq-mini{
  padding:3rem 3.5rem 4rem;background:var(--off-white);
  border-top:1px solid #e7dfd6
}

.faq-mini .section-title{color:var(--zodiac)}

.faq-item{
  max-width:760px;padding:1rem 0;border-bottom:1px solid #e7dfd6
}

.faq-q{
  font-size:1.05rem;font-weight:600;color:var(--zodiac);
  margin:0 0 0.5rem 0
}

.faq-a{
  font-size:1rem;line-height:1.8;color:var(--gray-mid);margin:0
}

/* SEO SIGNATURE */
.seo-signature{
  background:var(--off-white);padding:1.5rem 3.5rem;
  border-top:1px solid #e0d8d0
}

.seo-signature p{
  font-size:0.78rem;color:#999;line-height:1.7;
  max-width:800px;margin:0
}

.seo-signature a{color:#aaa}

/* FOOTER */
footer{
  background:var(--zodiac);border-top:1px solid rgba(255,255,255,0.08);
  padding:1.35rem 3.5rem;display:flex;justify-content:space-between;
  align-items:center
}

.footer-logo-badge{
  font-size:0.7rem;color:rgba(255,255,255,0.3);font-style:italic;
  border:0px dashed rgba(255,255,255,0.18);padding:0.3rem 0.75rem;
  letter-spacing:0.05em
}

.footer-cert{
  font-size:0.78rem;font-weight:500;color:var(--white);
  letter-spacing:0.05em
}

.footer-cta{
  font-family:var(--livvic);font-size:0.78rem;font-weight:500;
  letter-spacing:0.05em;text-transform:uppercase;color:var(--white);
  text-decoration:none;border-bottom:1px solid rgba(221,146,142,0.5);
  padding-bottom:2px;transition:color 0.2s
}

/* MODAL */
.modal-overlay{
  display:none;position:fixed;inset:0;background:rgba(16,36,65,0.9);
  z-index:1000;align-items:center;justify-content:center
}

.modal-overlay.open{display:flex}

.modal-box{
  background:var(--white);padding:2.75rem;max-width:500px;width:90%
}

.modal-title{
  font-size:1.4rem;font-weight:600;color:var(--zodiac);
  margin-bottom:0.4rem
}

.modal-sub{
  font-size:0.97rem;color:var(--gray-mid);margin-bottom:1.75rem;
  line-height:1.65
}

.modal-field{
  display:flex;flex-direction:column;gap:0.35rem;margin-bottom:1.1rem
}

.modal-field label{
  font-size:0.78rem;font-weight:600;letter-spacing:0.1em;
  text-transform:uppercase;color:var(--zodiac)
}

.modal-field input,.modal-field textarea{
  font-family:var(--livvic);font-size:1rem;color:var(--gray-dark);
  background:var(--off-white);border:1px solid #c8bfb4;
  padding:0.75rem 1rem;outline:none;transition:border-color 0.2s;
  resize:vertical
}

.modal-field input:focus,.modal-field textarea:focus{
  border-color:var(--orchid)
}

.modal-actions{
  display:flex;gap:1rem;margin-top:1.5rem;align-items:center
}

.modal-close-link{
  font-size:0.92rem;font-weight:500;color:var(--gray-mid);
  text-decoration:underline;cursor:pointer;background:none;
  border:none;font-family:var(--livvic)
}

.modal-confirm{
  font-size:0.92rem;color:#3B6D11;font-style:italic;
  display:none;margin-top:1.1rem;padding:0.75rem 1rem;
  background:#EAF3DE;border-left:3px solid #639922
}

/* RESPONSIVE */
@media(max-width:700px){
  .hero,.contact-section{grid-template-columns:1fr}
  .hero-right{display:none}
  nav,.hero-text,section,.terrain,.cert-strip,.contact-section,
  .faq-mini,.seo-signature,footer{
    padding-left:1.5rem;padding-right:1.5rem
