/* ═══════════════════════════════════════════════════════
   INSTITUT BDA SONDAGES — style.css
   Design: Luxury Editorial | Vert #1a4a2e + Or #c9a84c
═══════════════════════════════════════════════════════ */

/* ── VARIABLES ── */
:root {
  --vert:        #1a4a2e;
  --vert-mid:    #2d6a4f;
  --vert-light:  #3d8b65;
  --vert-pale:   #e8f5ee;
  --or:          #c9a84c;
  --or-light:    #dfc077;
  --or-pale:     #fdf6e3;
  --blanc:       #ffffff;
  --creme:       #f9f7f3;
  --gris:        #6b7280;
  --gris-dark:   #374151;
  --noir:        #0d1a12;
  --shadow-sm:   0 2px 8px rgba(26,74,46,.08);
  --shadow-md:   0 8px 32px rgba(26,74,46,.12);
  --shadow-lg:   0 24px 64px rgba(26,74,46,.18);
  --shadow-or:   0 8px 32px rgba(201,168,76,.25);
  --radius:      16px;
  --radius-sm:   8px;
  --trans:       all .35s cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Outfit',sans-serif;color:var(--gris-dark);background:var(--blanc);overflow-x:hidden}
a{text-decoration:none;color:inherit}
ul{list-style:none}
img{max-width:100%;display:block}

/* ── CUSTOM CURSOR (desktop) ── */
.cursor,.cursor-follower{pointer-events:none;position:fixed;border-radius:50%;z-index:9999;display:none}
@media(hover:hover){
  .cursor{display:block;width:8px;height:8px;background:var(--or);top:0;left:0;transform:translate(-50%,-50%);transition:transform .1s}
  .cursor-follower{display:block;width:36px;height:36px;border:1.5px solid var(--or);opacity:.5;top:0;left:0;transform:translate(-50%,-50%);transition:top .12s ease,left .12s ease}
}

/* ═══════════════════════════════════════════════════════
   NAVBAR
═══════════════════════════════════════════════════════ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(13,26,18,.96);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(201,168,76,.2);
  transition:var(--trans);
}
.navbar.scrolled{
  background:rgba(13,26,18,.99);
  box-shadow:0 4px 24px rgba(0,0,0,.3);
}
.nav-inner{
  max-width:1300px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 2rem;
}
.nav-logo{display:flex;align-items:center;gap:.9rem;cursor:pointer}
.logo-box{
  width:52px;height:52px;
  background:linear-gradient(135deg,var(--vert),var(--vert-mid));
  border:2px solid var(--or);
  border-radius:var(--radius-sm);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.logo-box span{
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem;font-weight:700;
  color:var(--or);letter-spacing:1px;
}
.logo-text-wrap{display:flex;flex-direction:column;gap:1px}
.logo-main{
  font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-weight:700;
  color:var(--blanc);line-height:1;
}
.logo-sub{
  font-size:.65rem;font-weight:300;
  color:rgba(255,255,255,.5);
  letter-spacing:.5px;
}

.nav-links{display:flex;align-items:center;gap:.2rem}
.nl{
  position:relative;
  color:rgba(255,255,255,.8);
  font-size:.9rem;font-weight:400;
  padding:.5rem .9rem;border-radius:6px;
  transition:var(--trans);
}
.nl::after{
  content:'';position:absolute;bottom:2px;left:.9rem;right:.9rem;
  height:1px;background:var(--or);
  transform:scaleX(0);transform-origin:right;
  transition:transform .3s ease;
}
.nl:hover,.nl.active{color:var(--or)}
.nl:hover::after,.nl.active::after{transform:scaleX(1);transform-origin:left}

/* Dropdown */
.has-dropdown{position:relative}
.dropdown{
  position:absolute;top:calc(100% + .5rem);left:50%;
  transform:translateX(-50%) translateY(8px);
  background:var(--noir);
  border:1px solid rgba(201,168,76,.2);
  border-radius:var(--radius-sm);
  min-width:220px;padding:.5rem;
  opacity:0;visibility:hidden;
  transition:var(--trans);
  box-shadow:var(--shadow-lg);
}
.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{
  display:flex;align-items:center;gap:.7rem;
  color:rgba(255,255,255,.75);font-size:.88rem;
  padding:.6rem .9rem;border-radius:6px;
  transition:var(--trans);
}
.dropdown a i{color:var(--or);width:16px;text-align:center}
.dropdown a:hover{background:rgba(201,168,76,.1);color:var(--or)}

.nav-cta{
  background:linear-gradient(135deg,var(--or),var(--or-light));
  color:var(--noir)!important;
  font-size:.9rem;font-weight:600;
  padding:.55rem 1.4rem;border-radius:30px;
  transition:var(--trans);margin-left:.5rem;
  box-shadow:var(--shadow-or);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(201,168,76,.4)}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.burger span{display:block;width:24px;height:2px;background:var(--blanc);border-radius:2px;transition:var(--trans)}

/* ═══════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════ */
.hero{
  min-height:100vh;
  background:var(--noir);
  display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:8rem 2rem 5rem;
}
.hero-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 70% 40%,rgba(45,106,79,.4) 0%,transparent 60%),
    radial-gradient(ellipse 50% 40% at 20% 80%,rgba(201,168,76,.08) 0%,transparent 50%);
}
.hero-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(201,168,76,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(201,168,76,.04) 1px,transparent 1px);
  background-size:60px 60px;
}
.hero-particle{
  position:absolute;border-radius:50%;
  background:var(--or);opacity:.15;
  animation:float 6s ease-in-out infinite;
}
.hero-particle:nth-child(1){width:6px;height:6px;top:20%;left:15%;animation-delay:0s}
.hero-particle:nth-child(2){width:4px;height:4px;top:60%;left:80%;animation-delay:2s}
.hero-particle:nth-child(3){width:8px;height:8px;top:80%;left:30%;animation-delay:4s}

.hero-content{
  max-width:1200px;margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:center;position:relative;z-index:1;
}
.hero-left{}
.hero-tag{
  display:inline-flex;align-items:center;gap:.6rem;
  border:1px solid rgba(201,168,76,.4);
  border-radius:30px;padding:.35rem 1rem;
  font-size:.78rem;font-weight:500;
  color:var(--or);letter-spacing:1.5px;text-transform:uppercase;
  margin-bottom:1.8rem;
  background:rgba(201,168,76,.05);
  animation:fadeInDown .8s ease both;
}
.hero-tag i{font-size:.7rem}
.hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,5vw,4.2rem);
  font-weight:700;line-height:1.1;
  color:var(--blanc);
  margin-bottom:1.5rem;
  animation:fadeInUp .9s ease .1s both;
}
.hero h1 em{
  font-style:italic;color:var(--or);
  display:block;
}
.hero-desc{
  font-size:1.05rem;font-weight:300;
  color:rgba(255,255,255,.65);
  line-height:1.8;margin-bottom:2.5rem;
  animation:fadeInUp .9s ease .2s both;
}
.hero-btns{
  display:flex;gap:1rem;flex-wrap:wrap;
  animation:fadeInUp .9s ease .3s both;
}
.btn-or{
  display:inline-flex;align-items:center;gap:.6rem;
  background:linear-gradient(135deg,var(--or),var(--or-light));
  color:var(--noir);font-weight:600;font-size:.95rem;
  padding:.8rem 2rem;border-radius:30px;
  transition:var(--trans);box-shadow:var(--shadow-or);
  border:none;cursor:pointer;
}
.btn-or:hover{transform:translateY(-3px);box-shadow:0 16px 40px rgba(201,168,76,.45)}
.btn-ghost{
  display:inline-flex;align-items:center;gap:.6rem;
  background:transparent;color:rgba(255,255,255,.8);
  font-weight:400;font-size:.95rem;
  padding:.8rem 2rem;border-radius:30px;
  border:1px solid rgba(255,255,255,.2);
  transition:var(--trans);cursor:pointer;
}
.btn-ghost:hover{border-color:var(--or);color:var(--or);transform:translateY(-3px)}

.hero-right{animation:fadeInUp .9s ease .4s both}
.hero-card{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(201,168,76,.15);
  border-radius:var(--radius);
  padding:2rem;backdrop-filter:blur(8px);
}
.hero-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.hstat{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(201,168,76,.1);
  border-radius:var(--radius-sm);
  padding:1.4rem;text-align:center;
  transition:var(--trans);
}
.hstat:hover{background:rgba(201,168,76,.08);border-color:rgba(201,168,76,.3)}
.hstat-num{
  font-family:'Cormorant Garamond',serif;
  font-size:2.4rem;font-weight:700;color:var(--or);
  display:block;line-height:1;
}
.hstat-label{font-size:.78rem;color:rgba(255,255,255,.5);margin-top:.3rem;display:block}
.hero-quote{
  margin-top:1.2rem;
  padding:1.2rem;
  border-left:2px solid var(--or);
  background:rgba(201,168,76,.05);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.hero-quote p{
  font-family:'Cormorant Garamond',serif;
  font-size:.95rem;font-style:italic;
  color:rgba(255,255,255,.7);line-height:1.6;
}
.hero-quote cite{
  display:block;margin-top:.5rem;
  font-size:.75rem;color:var(--or);font-style:normal;
}

.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:rgba(255,255,255,.4);font-size:.75rem;letter-spacing:2px;
  text-transform:uppercase;animation:bounce 2s infinite;
  z-index:1;
}
.hero-scroll i{color:var(--or);font-size:.9rem}

/* ═══════════════════════════════════════════════════════
   STATS BAND
═══════════════════════════════════════════════════════ */
.stats-band{
  background:linear-gradient(135deg,var(--vert),var(--vert-mid));
  padding:3rem 2rem;position:relative;overflow:hidden;
}
.stats-band::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg width='40' height='40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40' fill='rgba(201,168,76,0.04)'/%3E%3C/svg%3E");
}
.stats-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1rem;position:relative;
}
.stat-box{
  text-align:center;padding:1rem;
  border-right:1px solid rgba(255,255,255,.1);
}
.stat-box:last-child{border-right:none}
.stat-num{
  font-family:'Cormorant Garamond',serif;
  font-size:3rem;font-weight:700;color:var(--or);
  display:block;line-height:1;
}
.stat-lbl{font-size:.85rem;color:rgba(255,255,255,.7);margin-top:.4rem;display:block;font-weight:300}

/* ═══════════════════════════════════════════════════════
   SECTIONS COMMUNES
═══════════════════════════════════════════════════════ */
.section{padding:6rem 2rem}
.section-alt{background:var(--creme)}
.container{max-width:1200px;margin:0 auto}

.section-head{text-align:center;margin-bottom:4rem}
.stag{
  display:inline-flex;align-items:center;gap:.5rem;
  color:var(--vert);font-size:.75rem;font-weight:600;
  letter-spacing:2.5px;text-transform:uppercase;
  margin-bottom:.8rem;
}
.stag::before,.stag::after{
  content:'';display:block;width:24px;height:1px;background:var(--or);
}
.section-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,3rem);font-weight:700;
  color:var(--vert);margin-bottom:1rem;line-height:1.2;
}
.section-head h2 span{color:var(--or)}
.section-head p{
  color:var(--gris);font-size:1rem;
  max-width:580px;margin:0 auto;line-height:1.8;font-weight:300;
}

/* PAGE HERO */
.page-hero{
  padding:9rem 2rem 5rem;
  background:linear-gradient(135deg,var(--noir) 0%,var(--vert) 100%);
  text-align:center;position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(201,168,76,.08) 0%,transparent 70%);
}
.page-hero-content{position:relative;z-index:1}
.breadcrumb{
  display:inline-flex;align-items:center;gap:.5rem;
  color:rgba(255,255,255,.45);font-size:.82rem;
  margin-bottom:1.2rem;
}
.breadcrumb a{color:var(--or);transition:var(--trans)}
.breadcrumb a:hover{color:var(--or-light)}
.breadcrumb i{font-size:.65rem}
.page-hero h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.5rem,6vw,4rem);font-weight:700;
  color:var(--blanc);line-height:1.1;margin-bottom:1rem;
}
.page-hero h1 span{color:var(--or)}
.page-hero p{color:rgba(255,255,255,.6);font-size:1.05rem;font-weight:300;max-width:600px;margin:0 auto}

/* ═══════════════════════════════════════════════════════
   SERVICES CARDS
═══════════════════════════════════════════════════════ */
.services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:1.5rem;
}
.svc-card{
  background:var(--blanc);
  border:1px solid rgba(26,74,46,.08);
  border-radius:var(--radius);
  padding:2.2rem;
  transition:var(--trans);
  position:relative;overflow:hidden;
  cursor:pointer;
}
.svc-card::after{
  content:'';position:absolute;
  bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--vert),var(--or));
  transform:scaleX(0);transform-origin:left;
  transition:transform .4s ease;
}
.svc-card:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-lg);
  border-color:rgba(26,74,46,.15);
}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{
  width:60px;height:60px;
  background:linear-gradient(135deg,var(--vert-pale),rgba(201,168,76,.1));
  border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;color:var(--vert);
  margin-bottom:1.4rem;transition:var(--trans);
  border:1px solid rgba(26,74,46,.1);
}
.svc-card:hover .svc-icon{background:linear-gradient(135deg,var(--vert),var(--vert-mid));color:var(--or)}
.svc-card h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.3rem;font-weight:700;
  color:var(--vert);margin-bottom:.7rem;
}
.svc-card p{font-size:.9rem;color:var(--gris);line-height:1.7;font-weight:300}
.svc-more{
  display:inline-flex;align-items:center;gap:.4rem;
  color:var(--or);font-size:.82rem;font-weight:600;
  margin-top:1.2rem;letter-spacing:.5px;
  transition:var(--trans);
}
.svc-card:hover .svc-more{gap:.8rem}

/* ═══════════════════════════════════════════════════════
   ÉQUIPE
═══════════════════════════════════════════════════════ */
.equipe-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:2rem;
}
.eq-card{
  background:var(--blanc);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:var(--trans);
  border:1px solid rgba(26,74,46,.06);
}
.eq-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.eq-card-top{
  background:linear-gradient(135deg,var(--vert),var(--vert-mid));
  padding:2.5rem 2rem 1.5rem;
  text-align:center;position:relative;
}
.eq-avatar{
  width:80px;height:80px;border-radius:50%;
  background:rgba(201,168,76,.15);
  border:3px solid var(--or);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1rem;
  font-family:'Cormorant Garamond',serif;
  font-size:2rem;font-weight:700;color:var(--or);
}
.eq-card-top h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.15rem;font-weight:700;color:var(--blanc);
}
.eq-poste{
  font-size:.8rem;color:var(--or);
  font-weight:500;margin-top:.3rem;
  letter-spacing:.5px;
}
.eq-xp{
  position:absolute;top:1rem;right:1rem;
  background:rgba(201,168,76,.2);
  border:1px solid rgba(201,168,76,.3);
  color:var(--or);font-size:.72rem;font-weight:600;
  padding:.2rem .6rem;border-radius:20px;
}
.eq-card-body{padding:1.5rem 2rem}
.eq-card-body p{font-size:.85rem;color:var(--gris);line-height:1.7;font-weight:300}

/* ═══════════════════════════════════════════════════════
   CLIENTS / LOGOS
═══════════════════════════════════════════════════════ */
.clients-logos{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:1rem;
}
.client-logo-box{
  background:var(--blanc);
  border:1px solid rgba(26,74,46,.08);
  border-radius:var(--radius-sm);
  padding:1.5rem;
  display:flex;align-items:center;justify-content:center;
  min-height:90px;
  transition:var(--trans);
  font-family:'Cormorant Garamond',serif;
  font-size:1rem;font-weight:600;color:var(--vert);
  text-align:center;
}
.client-logo-box:hover{
  border-color:var(--or);
  box-shadow:var(--shadow-or);
  transform:translateY(-4px);
}

.pays-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:.8rem;
}
.pays-item{
  background:linear-gradient(135deg,var(--vert),var(--vert-mid));
  border-radius:var(--radius-sm);
  padding:1rem;text-align:center;
  transition:var(--trans);
  border:1px solid transparent;
}
.pays-item:hover{transform:translateY(-4px);border-color:var(--or)}
.pays-flag{font-size:1.6rem;display:block;margin-bottom:.4rem}
.pays-name{font-size:.8rem;color:rgba(255,255,255,.85);font-weight:400}

.secteur-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
  gap:1rem;
}
.secteur-item{
  background:var(--blanc);
  border:1px solid rgba(26,74,46,.08);
  border-radius:var(--radius-sm);
  padding:1.5rem;
  display:flex;align-items:center;gap:1rem;
  transition:var(--trans);
}
.secteur-item:hover{border-color:var(--or);transform:translateX(4px);box-shadow:var(--shadow-sm)}
.secteur-item i{
  width:40px;height:40px;flex-shrink:0;
  background:var(--vert-pale);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  color:var(--vert);font-size:1rem;
}
.secteur-item span{font-size:.9rem;color:var(--gris-dark);font-weight:400}

/* ═══════════════════════════════════════════════════════
   CONTACT
═══════════════════════════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1fr 1.6fr;gap:4rem;align-items:start}
.contact-info-card{
  background:linear-gradient(145deg,var(--vert),var(--vert-mid));
  border-radius:var(--radius);
  padding:2.5rem;
}
.contact-info-card h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.8rem;font-weight:700;color:var(--blanc);
  margin-bottom:.5rem;
}
.contact-info-card>p{
  color:rgba(255,255,255,.6);font-size:.9rem;
  line-height:1.7;margin-bottom:2rem;font-weight:300;
}
.cinfo-item{
  display:flex;gap:1rem;align-items:flex-start;
  margin-bottom:1.4rem;
}
.cinfo-icon{
  width:44px;height:44px;flex-shrink:0;
  background:rgba(201,168,76,.15);
  border:1px solid rgba(201,168,76,.3);
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  color:var(--or);font-size:1rem;
}
.cinfo-item h4{font-size:.82rem;font-weight:600;color:var(--or);text-transform:uppercase;letter-spacing:1px;margin-bottom:.2rem}
.cinfo-item p{font-size:.88rem;color:rgba(255,255,255,.7);line-height:1.5}
.contact-dg-quote{
  margin-top:2rem;
  padding:1.5rem;
  background:rgba(201,168,76,.08);
  border:1px solid rgba(201,168,76,.2);
  border-radius:var(--radius-sm);
}
.contact-dg-quote p{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-size:1rem;
  color:rgba(255,255,255,.8);line-height:1.6;
}
.contact-dg-quote cite{
  display:block;margin-top:.8rem;
  font-size:.8rem;color:var(--or);font-style:normal;font-weight:500;
}

.contact-form-card{
  background:var(--blanc);
  border:1px solid rgba(26,74,46,.1);
  border-radius:var(--radius);
  padding:2.5rem;
  box-shadow:var(--shadow-md);
}
.contact-form-card h3{
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;font-weight:700;color:var(--vert);
  margin-bottom:1.5rem;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-grp{margin-bottom:1.2rem}
.form-grp label{
  display:block;font-size:.82rem;font-weight:500;
  color:var(--gris-dark);margin-bottom:.4rem;letter-spacing:.3px;
}
.form-grp label span{color:var(--or)}
.form-grp input,.form-grp textarea,.form-grp select{
  width:100%;padding:.8rem 1.1rem;
  border:2px solid rgba(26,74,46,.1);
  border-radius:var(--radius-sm);
  font-family:'Outfit',sans-serif;font-size:.9rem;
  color:var(--gris-dark);background:var(--creme);
  transition:var(--trans);
}
.form-grp input:focus,.form-grp textarea:focus,.form-grp select:focus{
  outline:none;
  border-color:var(--or);
  background:var(--blanc);
  box-shadow:0 0 0 4px rgba(201,168,76,.08);
}
.form-grp textarea{resize:vertical;min-height:130px}
.btn-submit{
  width:100%;padding:1rem;
  background:linear-gradient(135deg,var(--vert),var(--vert-mid));
  color:var(--blanc);font-family:'Outfit',sans-serif;
  font-size:.95rem;font-weight:600;
  border:none;border-radius:30px;cursor:pointer;
  transition:var(--trans);
  display:flex;align-items:center;justify-content:center;gap:.7rem;
  box-shadow:var(--shadow-md);
}
.btn-submit:hover{
  background:linear-gradient(135deg,var(--or),var(--or-light));
  color:var(--noir);transform:translateY(-2px);
  box-shadow:var(--shadow-or);
}

/* ═══════════════════════════════════════════════════════
   À PROPOS
═══════════════════════════════════════════════════════ */
.about-layout{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.about-visual{position:relative}
.about-img-box{
  background:linear-gradient(135deg,var(--vert),var(--vert-mid));
  border-radius:var(--radius);
  aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.about-img-box::after{
  content:'';position:absolute;
  bottom:-2rem;right:-2rem;
  width:200px;height:200px;
  border:2px solid var(--or);
  border-radius:var(--radius);
  opacity:.3;
}
.about-year-badge{
  position:absolute;bottom:1.5rem;left:1.5rem;
  background:var(--or);color:var(--noir);
  border-radius:var(--radius-sm);
  padding:1rem 1.4rem;font-weight:700;
  font-family:'Cormorant Garamond',serif;
}
.about-year-badge span{font-size:2rem;display:block;line-height:1}
.about-year-badge small{font-size:.75rem;font-style:italic}
.about-text h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2rem,4vw,2.8rem);font-weight:700;
  color:var(--vert);line-height:1.2;margin-bottom:1rem;
}
.about-text h2 span{color:var(--or)}
.about-text p{
  color:var(--gris);line-height:1.8;
  font-size:.95rem;font-weight:300;margin-bottom:1rem;
}
.about-text blockquote{
  border-left:3px solid var(--or);
  padding:1rem 1.5rem;
  background:var(--or-pale);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  margin:1.5rem 0;
}
.about-text blockquote p{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;font-size:1rem;color:var(--vert);
}
.about-text blockquote cite{
  font-size:.8rem;color:var(--or);font-style:normal;
  font-weight:600;display:block;margin-top:.5rem;
}

.valeurs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.valeur-item{
  background:var(--vert-pale);
  border-radius:var(--radius-sm);
  padding:1.2rem;text-align:center;
  border:1px solid rgba(26,74,46,.1);
  transition:var(--trans);
}
.valeur-item:hover{background:var(--vert);color:var(--blanc)}
.valeur-item:hover .vi-icon{background:rgba(201,168,76,.2);color:var(--or)}
.valeur-item:hover h4,.valeur-item:hover p{color:rgba(255,255,255,.8)}
.vi-icon{
  width:44px;height:44px;
  background:rgba(26,74,46,.1);
  border-radius:10px;margin:0 auto .8rem;
  display:flex;align-items:center;justify-content:center;
  color:var(--vert);font-size:1.1rem;transition:var(--trans);
}
.valeur-item h4{font-size:.85rem;font-weight:600;color:var(--vert);margin-bottom:.3rem;transition:var(--trans)}
.valeur-item p{font-size:.78rem;color:var(--gris);transition:var(--trans)}

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.footer{background:var(--noir);position:relative;overflow:hidden}
.footer-glow{
  position:absolute;top:-100px;left:50%;transform:translateX(-50%);
  width:600px;height:200px;
  background:radial-gradient(ellipse,rgba(45,106,79,.3) 0%,transparent 70%);
  pointer-events:none;
}
.footer-inner{
  max-width:1300px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;
  gap:3rem;padding:4rem 2rem 3rem;
  border-bottom:1px solid rgba(255,255,255,.06);
  position:relative;
}
.footer-brand .footer-logo{display:flex;align-items:center;gap:.8rem;margin-bottom:1.2rem}
.footer-brand p{
  font-size:.88rem;color:rgba(255,255,255,.45);
  line-height:1.8;font-weight:300;
}
.footer-social{display:flex;gap:.8rem;margin-top:1.5rem}
.footer-social a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.5);font-size:.85rem;
  transition:var(--trans);
}
.footer-social a:hover{background:var(--or);border-color:var(--or);color:var(--noir)}

.footer-col h4{
  font-size:.75rem;color:var(--or);
  letter-spacing:2px;text-transform:uppercase;
  margin-bottom:1.2rem;font-weight:600;
}
.footer-col ul li{margin-bottom:.6rem}
.footer-col ul a{
  font-size:.88rem;color:rgba(255,255,255,.45);
  transition:var(--trans);display:inline-block;
}
.footer-col ul a:hover{color:var(--or);transform:translateX(4px)}
.footer-contact-list li{
  display:flex;align-items:flex-start;gap:.7rem;
  margin-bottom:.8rem;
}
.footer-contact-list i{color:var(--or);font-size:.85rem;margin-top:.15rem;flex-shrink:0}
.footer-contact-list span{font-size:.85rem;color:rgba(255,255,255,.45);line-height:1.5}

.footer-bottom{padding:1.5rem 2rem}
.footer-bottom-inner{
  max-width:1300px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:.5rem;
}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.25)}

/* ═══════════════════════════════════════════════════════
   FLASH MESSAGES
═══════════════════════════════════════════════════════ */
.flash-messages{position:fixed;top:80px;right:1.5rem;z-index:999;display:flex;flex-direction:column;gap:.5rem}
.flash{
  display:flex;align-items:center;gap:.8rem;
  padding:.9rem 1.3rem;border-radius:var(--radius-sm);
  font-size:.9rem;font-weight:500;min-width:280px;
  box-shadow:var(--shadow-md);
  animation:slideIn .4s ease;
}
.flash button{margin-left:auto;background:none;border:none;cursor:pointer;color:inherit;font-size:1.1rem;opacity:.6}
.flash-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}
.flash-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* ═══════════════════════════════════════════════════════
   ANIMATIONS
═══════════════════════════════════════════════════════ */
@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes bounce{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-8px)}}
@keyframes slideIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-28px);transition:opacity .7s ease,transform .7s ease}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(28px);transition:opacity .7s ease,transform .7s ease}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-content{grid-template-columns:1fr;gap:3rem;text-align:center}
  .hero-btns{justify-content:center}
  .hero-right{max-width:480px;margin:0 auto}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .contact-layout{grid-template-columns:1fr}
  .about-layout{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .nav-links{
    display:none;flex-direction:column;
    position:absolute;top:100%;left:0;right:0;
    background:var(--noir);padding:1rem 2rem 2rem;
    border-bottom:2px solid var(--or);gap:.5rem;
  }
  .nav-links.open{display:flex}
  .burger{display:flex}
  .dropdown{position:static;transform:none;opacity:1;visibility:visible;background:rgba(255,255,255,.05);margin-top:.5rem}
  .has-dropdown:hover .dropdown{transform:none}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-box{border-right:none;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:1.2rem}
  .stat-box:nth-child(odd){border-right:1px solid rgba(255,255,255,.1)}
  .hero-stats-grid{grid-template-columns:repeat(2,1fr)}
  .valeurs-grid{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
  .footer-bottom-inner{flex-direction:column;text-align:center}
}
@media(max-width:480px){
  .hero h1{font-size:2.2rem}
  .stats-inner{grid-template-columns:1fr 1fr}
  .valeurs-grid{grid-template-columns:1fr}
}
