/* ===================================================================
   CABINET MÉRIDIENNE — Experts-comptables · Strasbourg
   Marine profond + crème + ocre — corporate strict, IBM Plex family
   =================================================================== */
:root{
  --navy:#1a2e4d;
  --steel:#38567a;
  --steel-soft:#587496;
  --cream:#f6efe1;
  --cream-light:#fbf6ec;
  --slate:#2a3142;
  --slate-soft:#5d6478;
  --ocre:#b89163;
  --ocre-soft:#d6b287;
  --line:#d9cfbb;
  --line-soft:#e7dec9;
  --white:#ffffff;
  --bg-table:#fdfaf2;
  --serif:"IBM Plex Serif", Georgia, serif;
  --sans:"IBM Plex Sans", "Helvetica Neue", Arial, sans-serif;
  --mono:"IBM Plex Mono", Consolas, monospace;
  --pad:clamp(20px,4vw,72px);
  --rad:2px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--slate);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s ease}
ul{list-style:none}

h1,h2,h3,h4,h5{font-family:var(--serif);color:var(--navy);font-weight:500;line-height:1.2;letter-spacing:-0.005em}
h1{font-size:clamp(40px,5.4vw,68px);font-weight:400}
h2{font-size:clamp(28px,3.6vw,44px);font-weight:500}
h3{font-size:clamp(20px,2vw,26px);font-weight:500}
h4{font-size:18px;font-weight:600}
h5{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:0.18em;color:var(--steel);font-family:var(--sans)}

.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--ocre);
  display:inline-flex;
  align-items:center;
  gap:14px;
  margin-bottom:18px;
}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--ocre)}

.section{padding:96px var(--pad)}
.section-tight{padding:64px var(--pad)}
.container{max-width:1280px;margin:0 auto}

/* ===== HEADER — DOUBLE ROW STRICT CORPORATE ===== */
.site-header{
  position:sticky;top:0;z-index:80;
  background:var(--cream-light);
  border-bottom:1px solid var(--line);
}
.header-top{
  background:var(--navy);
  color:var(--cream-light);
}
.header-top-inner{
  max-width:1480px;margin:0 auto;
  padding:9px var(--pad);
  display:flex;align-items:center;justify-content:space-between;
  font-family:var(--mono);
  font-size:11.5px;
  letter-spacing:0.06em;
}
.ht-left{display:flex;gap:28px;align-items:center;flex-wrap:wrap}
.ht-right{display:flex;gap:14px;align-items:center}
.ht-item{display:inline-flex;align-items:center;gap:8px;color:var(--cream)}
.ht-ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:18px;height:18px;border:1px solid var(--steel-soft);
  border-radius:50%;color:var(--ocre-soft);font-size:10px;font-family:var(--serif);
}
.ht-item a{color:var(--cream-light)}
.ht-item a:hover{color:var(--ocre-soft)}
.ht-link{color:var(--cream-light);text-transform:uppercase;letter-spacing:0.16em;font-size:10.5px}
.ht-link:hover{color:var(--ocre-soft)}
.ht-link.ht-faded{color:var(--steel-soft)}
.ht-sep{color:var(--steel-soft)}
.header-bot-inner{
  max-width:1480px;margin:0 auto;
  padding:18px var(--pad);
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:40px;
}
.brand{display:inline-flex;align-items:center;gap:14px}
.brand-mono{display:flex;flex-direction:column;line-height:1;gap:4px}
.brand-line{font-family:var(--mono);font-size:10px;letter-spacing:0.42em;color:var(--ocre);text-transform:uppercase}
.brand-name{font-family:var(--serif);font-size:30px;color:var(--navy);font-weight:500;letter-spacing:-0.01em}
.brand-sub{font-family:var(--mono);font-size:9.5px;letter-spacing:0.28em;color:var(--slate-soft);text-transform:uppercase}

.main-nav{display:flex;justify-content:center;gap:36px}
.nav-link{
  font-family:var(--sans);
  font-size:13px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--slate);
  padding:10px 2px;
  position:relative;
}
.nav-link::after{
  content:"";position:absolute;left:0;bottom:2px;
  width:0;height:2px;background:var(--ocre);
  transition:width .3s ease;
}
.nav-link:hover{color:var(--navy)}
.nav-link:hover::after,.nav-link.is-active::after{width:100%}
.nav-link.is-active{color:var(--navy);font-weight:600}

.header-actions{display:flex;align-items:center;gap:14px}
.btn-quote{
  background:var(--navy);
  color:var(--cream-light);
  padding:13px 24px;
  font-family:var(--sans);
  font-size:12px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-weight:600;
  border:1px solid var(--navy);
  border-radius:var(--rad);
  transition:background .2s ease, color .2s ease;
}
.btn-quote:hover{background:var(--cream-light);color:var(--navy)}

.burger{
  display:none;
  background:none;border:1px solid var(--steel);
  width:42px;height:42px;border-radius:var(--rad);
  cursor:pointer;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
}
.burger span{width:18px;height:1.5px;background:var(--navy);transition:transform .25s ease, opacity .25s ease}
.burger.is-open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

@media(max-width:1080px){
  .ht-hide-sm{display:none}
  .header-bot-inner{grid-template-columns:auto auto;gap:14px}
  .main-nav{
    display:none;
    position:absolute;top:100%;left:0;right:0;
    background:var(--cream-light);
    border-top:1px solid var(--line);
    border-bottom:1px solid var(--line);
    flex-direction:column;
    padding:20px var(--pad);
    gap:6px;
  }
  .main-nav.is-open{display:flex}
  .nav-link{padding:12px 0;font-size:14px}
  .burger{display:flex}
  .btn-quote{padding:10px 16px;font-size:11px}
}
@media(max-width:680px){
  .ht-right .ht-link:nth-child(n+4){display:none}
  .btn-quote{display:none}
}

/* ===== HERO — sobre, corporate ===== */
.hero{
  background:var(--cream-light);
  border-bottom:1px solid var(--line);
  padding:88px var(--pad) 96px;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;top:0;right:0;
  width:55%;height:100%;
  background:url('../img/hero.jpg') center/cover;
  opacity:0.22;
}
.hero::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(90deg,var(--cream-light) 45%,rgba(246,239,225,0.55) 70%,rgba(246,239,225,0.05) 100%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 280px;gap:60px;align-items:end}
.hero h1{margin:18px 0 24px;color:var(--navy);max-width:18ch}
.hero h1 em{font-style:italic;color:var(--steel);font-weight:400}
.hero .lede{font-family:var(--serif);font-size:21px;color:var(--slate);max-width:54ch;line-height:1.55;font-weight:400}
.hero .lede strong{color:var(--navy);font-weight:500}
.hero-cta{margin-top:32px;display:flex;gap:14px;flex-wrap:wrap}

.hero-meta{
  background:var(--white);
  border:1px solid var(--line);
  padding:24px;
  display:flex;flex-direction:column;gap:14px;
  font-family:var(--mono);font-size:12px;
}
.hero-meta-row{display:flex;justify-content:space-between;padding-bottom:10px;border-bottom:1px dashed var(--line-soft)}
.hero-meta-row:last-child{border:none;padding-bottom:0}
.hero-meta-row span:first-child{color:var(--slate-soft);letter-spacing:0.1em;text-transform:uppercase;font-size:10px}
.hero-meta-row span:last-child{color:var(--navy);font-weight:500;text-align:right}

@media(max-width:900px){
  .hero{padding:60px var(--pad) 70px}
  .hero::before{width:100%;opacity:0.1}
  .hero-inner{grid-template-columns:1fr;gap:34px}
}

.btn-pri{
  background:var(--navy);color:var(--cream-light);
  padding:16px 28px;
  font-family:var(--sans);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;font-weight:600;
  border:1px solid var(--navy);border-radius:var(--rad);cursor:pointer;display:inline-flex;align-items:center;gap:10px;
  transition:background .2s ease;
}
.btn-pri:hover{background:var(--steel)}
.btn-pri::after{content:"→";font-family:var(--serif);font-weight:300;font-size:18px}

.btn-out{
  background:transparent;color:var(--navy);
  padding:16px 28px;
  font-family:var(--sans);font-size:12px;letter-spacing:0.18em;text-transform:uppercase;font-weight:600;
  border:1px solid var(--navy);border-radius:var(--rad);cursor:pointer;display:inline-flex;align-items:center;gap:10px;
}
.btn-out:hover{background:var(--navy);color:var(--cream-light)}

/* ===== KPI BAND ===== */
.kpi-band{
  background:var(--navy);color:var(--cream-light);
  padding:60px var(--pad);
}
.kpi-grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--steel)}
.kpi{background:var(--navy);padding:30px 24px;text-align:center}
.kpi-num{font-family:var(--serif);font-size:clamp(40px,5vw,58px);color:var(--cream);font-weight:400;line-height:1}
.kpi-num sup{font-family:var(--mono);font-size:14px;color:var(--ocre-soft);vertical-align:super;margin-left:4px}
.kpi-lbl{font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--ocre-soft);margin-top:12px}
@media(max-width:780px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}

/* ===== SECTION HEAD ===== */
.section-head{margin-bottom:56px;max-width:780px}
.section-head h2{margin-top:8px}
.section-head p{font-family:var(--serif);font-size:19px;color:var(--slate-soft);margin-top:18px;line-height:1.55;font-style:italic}

/* ===== EXPERTISES CARDS ===== */
.exp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.exp-card{
  background:var(--cream-light);
  padding:38px 34px;
  display:flex;flex-direction:column;gap:14px;
  transition:background .25s ease;
}
.exp-card:hover{background:var(--white)}
.exp-num{font-family:var(--mono);font-size:11px;letter-spacing:0.3em;color:var(--ocre);text-transform:uppercase}
.exp-card h3{color:var(--navy)}
.exp-card p{color:var(--slate);font-size:15px;line-height:1.65}
.exp-card .exp-meta{display:flex;gap:18px;margin-top:10px;font-family:var(--mono);font-size:11px;letter-spacing:0.1em;color:var(--slate-soft);text-transform:uppercase}
.exp-card .exp-meta span{display:inline-flex;align-items:center;gap:6px}
.exp-card .exp-meta span::before{content:"■";color:var(--ocre);font-size:8px}
@media(max-width:820px){.exp-grid{grid-template-columns:1fr}}

/* ===== TÉMOIGNAGES ===== */
.testi-band{background:var(--cream-light);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;max-width:1280px;margin:0 auto}
.testi{
  background:var(--white);
  border:1px solid var(--line);
  padding:32px;
  display:flex;flex-direction:column;gap:18px;
}
.testi-quote{font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.55;color:var(--slate)}
.testi-quote::before{content:"«";font-size:32px;color:var(--ocre);line-height:0;vertical-align:-12px;margin-right:6px}
.testi-quote::after{content:"»";font-size:32px;color:var(--ocre);line-height:0;vertical-align:-12px;margin-left:6px}
.testi-foot{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px dashed var(--line-soft)}
.testi-name{font-family:var(--sans);font-size:14px;font-weight:600;color:var(--navy)}
.testi-role{font-family:var(--mono);font-size:11px;letter-spacing:0.14em;color:var(--slate-soft);text-transform:uppercase;margin-top:2px}
.testi-photo{width:48px;height:48px;border-radius:50%;background-size:cover;background-position:center;flex-shrink:0;border:1px solid var(--line)}
@media(max-width:900px){.testi-grid{grid-template-columns:1fr}}

/* ===== CTA BAND ===== */
.cta-band{
  background:linear-gradient(135deg,var(--navy) 0%,var(--steel) 100%);
  color:var(--cream-light);
  padding:80px var(--pad);
  text-align:center;
}
.cta-band h2{color:var(--cream-light);margin-bottom:16px}
.cta-band p{color:var(--ocre-soft);max-width:600px;margin:0 auto 30px;font-family:var(--serif);font-size:18px;font-style:italic}
.cta-band .btn-pri{background:var(--ocre);border-color:var(--ocre);color:var(--navy)}
.cta-band .btn-pri:hover{background:var(--ocre-soft)}

/* ===== TABLEAU DES PRESTATIONS ===== */
.tariff-wrap{margin-top:40px;background:var(--white);border:1px solid var(--line);border-radius:var(--rad);overflow:hidden}
.tariff-head{display:grid;grid-template-columns:1.4fr 1fr 1fr 0.8fr;background:var(--navy);color:var(--cream-light);font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;padding:18px 24px;gap:18px}
.tariff-row{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 0.8fr;
  padding:22px 24px;border-bottom:1px solid var(--line-soft);
  align-items:center;gap:18px;
}
.tariff-row:last-child{border:none}
.tariff-row:nth-child(even){background:var(--bg-table)}
.tariff-row strong{font-family:var(--serif);font-size:17px;color:var(--navy);font-weight:500;display:block;margin-bottom:4px}
.tariff-row .t-desc{font-size:13px;color:var(--slate-soft);line-height:1.5}
.tariff-row .t-cell{font-family:var(--mono);font-size:13px;color:var(--slate)}
.tariff-row .t-price{font-family:var(--serif);font-size:22px;color:var(--navy);font-weight:500}
.tariff-row .t-price span{font-family:var(--mono);font-size:11px;color:var(--slate-soft);display:block;margin-top:2px;letter-spacing:0.1em;text-transform:uppercase}
.tariff-foot{padding:18px 24px;background:var(--cream-light);font-family:var(--mono);font-size:11px;color:var(--slate-soft);letter-spacing:0.1em;border-top:1px solid var(--line)}
@media(max-width:780px){
  .tariff-head{display:none}
  .tariff-row{grid-template-columns:1fr 1fr;padding:18px;gap:10px}
  .tariff-row strong{grid-column:1/-1}
  .tariff-row .t-desc{grid-column:1/-1;margin-bottom:8px}
}

/* ===== PRESTATIONS DETAIL ===== */
.preset-row{
  display:grid;grid-template-columns:280px 1fr;
  border-top:1px solid var(--line);
  padding:50px 0;gap:50px;
  align-items:start;
}
.preset-row:last-child{border-bottom:1px solid var(--line)}
.preset-meta{font-family:var(--mono);font-size:12px;color:var(--slate-soft);letter-spacing:0.06em;line-height:1.7}
.preset-meta .preset-num{font-size:11px;letter-spacing:0.32em;text-transform:uppercase;color:var(--ocre);margin-bottom:14px;display:block}
.preset-meta .preset-tag{display:inline-block;border:1px solid var(--ocre);color:var(--ocre);padding:3px 8px;margin-top:8px;font-size:10px;letter-spacing:0.18em;text-transform:uppercase}
.preset-body h3{color:var(--navy);margin-bottom:16px}
.preset-body p{margin-bottom:14px;color:var(--slate);font-size:15.5px}
.preset-body ul{margin:12px 0 18px 0;display:grid;grid-template-columns:1fr 1fr;gap:8px 24px}
.preset-body ul li{padding-left:18px;position:relative;font-size:14px;color:var(--slate)}
.preset-body ul li::before{content:"▸";color:var(--ocre);position:absolute;left:0;font-size:11px;top:5px}
@media(max-width:820px){
  .preset-row{grid-template-columns:1fr;gap:24px;padding:40px 0}
  .preset-body ul{grid-template-columns:1fr}
}

/* ===== PAGE TITLE ===== */
.page-title{
  background:var(--cream-light);
  border-bottom:1px solid var(--line);
  padding:70px var(--pad) 56px;
}
.page-title-inner{max-width:1280px;margin:0 auto;display:flex;flex-direction:column;gap:18px}
.page-title h1{font-size:clamp(36px,4.5vw,56px);margin-top:8px}
.page-title .lede{font-family:var(--serif);font-size:18px;color:var(--slate-soft);max-width:60ch;line-height:1.55}
.crumb{font-family:var(--mono);font-size:11px;letter-spacing:0.2em;color:var(--slate-soft);text-transform:uppercase}
.crumb a:hover{color:var(--ocre)}
.crumb span{margin:0 8px;color:var(--line)}

/* ===== CABINET PAGE ===== */
.story-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center}
.story-grid img{border:1px solid var(--line);width:100%;aspect-ratio:4/3;object-fit:cover}
.story-grid p{margin-bottom:14px;color:var(--slate);font-size:15.5px}
.story-grid p strong{color:var(--navy);font-weight:600}
@media(max-width:900px){.story-grid{grid-template-columns:1fr}}

.timeline{margin-top:50px;border-left:2px solid var(--line);padding-left:34px;display:flex;flex-direction:column;gap:34px}
.t-item{position:relative}
.t-item::before{
  content:"";position:absolute;left:-43px;top:6px;
  width:14px;height:14px;border-radius:50%;
  background:var(--cream-light);border:2px solid var(--ocre);
}
.t-year{font-family:var(--mono);font-size:12px;letter-spacing:0.22em;color:var(--ocre);text-transform:uppercase;font-weight:500}
.t-item h4{margin:6px 0 6px;color:var(--navy)}
.t-item p{font-size:14.5px;color:var(--slate)}

.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:40px}
.team-card{background:var(--white);border:1px solid var(--line);overflow:hidden}
.team-photo{aspect-ratio:1/1;background-size:cover;background-position:center top}
.team-info{padding:24px}
.team-info .t-name{font-family:var(--serif);font-size:21px;color:var(--navy);margin-bottom:4px}
.team-info .t-role{font-family:var(--mono);font-size:11px;letter-spacing:0.16em;color:var(--ocre);text-transform:uppercase;margin-bottom:14px}
.team-info p{font-size:14px;color:var(--slate-soft);line-height:1.55}
.team-info .t-credentials{margin-top:12px;font-family:var(--mono);font-size:11px;color:var(--steel);letter-spacing:0.08em}
@media(max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.team-grid{grid-template-columns:1fr}}

.collab-list{margin-top:30px;display:grid;grid-template-columns:repeat(3,1fr);gap:14px 30px;border-top:1px solid var(--line);padding-top:28px}
.collab{display:flex;flex-direction:column;font-size:14px;padding:10px 0;border-bottom:1px dashed var(--line-soft)}
.collab-name{font-family:var(--serif);color:var(--navy);font-size:16px}
.collab-role{font-family:var(--mono);font-size:11px;color:var(--slate-soft);letter-spacing:0.12em;text-transform:uppercase;margin-top:2px}
@media(max-width:780px){.collab-list{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.collab-list{grid-template-columns:1fr}}

.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px}
.value{background:var(--cream-light);border:1px solid var(--line);padding:30px 24px}
.value .v-ico{font-family:var(--serif);font-size:34px;color:var(--ocre);font-weight:400;line-height:1;margin-bottom:14px}
.value h4{margin-bottom:10px;color:var(--navy)}
.value p{font-size:14px;color:var(--slate);line-height:1.55}
@media(max-width:900px){.values-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.values-grid{grid-template-columns:1fr}}

.cert-band{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:40px;background:var(--white);border:1px solid var(--line);padding:36px}
.cert{display:flex;flex-direction:column;gap:8px}
.cert-name{font-family:var(--serif);font-size:17px;color:var(--navy)}
.cert-desc{font-size:13px;color:var(--slate-soft);line-height:1.5}
.cert-num{font-family:var(--mono);font-size:11px;color:var(--ocre);letter-spacing:0.12em;margin-top:6px}
@media(max-width:900px){.cert-band{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.cert-band{grid-template-columns:1fr}}

/* ===== CONTACT PAGE ===== */
.contact-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:60px}
.contact-form{background:var(--white);border:1px solid var(--line);padding:44px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:18px}
.form-row.single{grid-template-columns:1fr}
.form-field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:0.18em;color:var(--steel);text-transform:uppercase;margin-bottom:8px}
.form-field input,
.form-field select,
.form-field textarea{
  width:100%;
  padding:13px 14px;
  border:1px solid var(--line);
  background:var(--cream-light);
  font-family:var(--sans);font-size:14.5px;color:var(--slate);
  border-radius:var(--rad);
  transition:border-color .2s ease, background .2s ease;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{outline:none;border-color:var(--ocre);background:var(--white)}
.form-field textarea{min-height:140px;resize:vertical;line-height:1.55}
.form-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;gap:20px;flex-wrap:wrap}
.form-foot small{font-family:var(--mono);font-size:11px;color:var(--slate-soft);letter-spacing:0.06em;max-width:38ch;line-height:1.5}
.form-check{display:flex;gap:10px;align-items:flex-start;margin:18px 0;font-size:13px;color:var(--slate-soft)}
.form-check input{margin-top:3px;flex-shrink:0}
.form-check a{color:var(--ocre);text-decoration:underline}

.contact-side{display:flex;flex-direction:column;gap:24px}
.contact-box{background:var(--white);border:1px solid var(--line);padding:30px}
.contact-box h4{color:var(--navy);margin-bottom:18px}
.contact-line{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px dashed var(--line-soft);font-size:14px}
.contact-line:last-child{border:none}
.contact-line span:first-child{color:var(--slate-soft);font-family:var(--mono);font-size:11.5px;letter-spacing:0.12em;text-transform:uppercase}
.contact-line span:last-child{color:var(--navy);font-weight:500}
.contact-box .map-stub{
  height:200px;
  background:linear-gradient(135deg,var(--steel) 0%,var(--navy) 100%);
  display:flex;align-items:center;justify-content:center;
  color:var(--cream-light);font-family:var(--mono);font-size:12px;letter-spacing:0.2em;text-transform:uppercase;
  position:relative;overflow:hidden;
}
.contact-box .map-stub::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(transparent 49.5%,rgba(184,145,99,0.18) 50%,transparent 50.5%) repeat,
    linear-gradient(90deg,transparent 49.5%,rgba(184,145,99,0.18) 50%,transparent 50.5%) repeat;
  background-size:24px 24px;
}
.contact-box .map-stub::after{
  content:"📍 22 quai Kléber · 67000 Strasbourg";
  position:relative;z-index:2;
  background:var(--navy);padding:8px 14px;border:1px solid var(--ocre);
}

@media(max-width:980px){
  .contact-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
}

/* ===== FOOTER ===== */
.site-footer{background:var(--navy);color:var(--cream-light)}
.footer-top{
  max-width:1480px;margin:0 auto;
  padding:70px var(--pad) 50px;
  display:grid;grid-template-columns:1.2fr 2.4fr;gap:60px;
}
.f-brand{display:flex;align-items:center;gap:18px}
.f-mark{
  width:62px;height:62px;
  border:1px solid var(--ocre);color:var(--ocre);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:24px;font-weight:500;
}
.f-name{color:var(--cream);font-family:var(--serif);font-size:22px;margin-bottom:4px}
.f-tag{font-family:var(--mono);font-size:11px;color:var(--ocre-soft);letter-spacing:0.1em;text-transform:uppercase;line-height:1.5}

.f-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.f-col h5{font-family:var(--mono);font-size:11px;color:var(--ocre);letter-spacing:0.22em;margin-bottom:18px;text-transform:uppercase;font-weight:500}
.f-col a,.f-col span{display:block;color:var(--cream-light);font-size:13.5px;padding:5px 0;line-height:1.5}
.f-col a:hover{color:var(--ocre-soft)}
.f-mute{color:var(--steel-soft) !important;font-family:var(--mono);font-size:11.5px !important}

.footer-mid{
  max-width:1480px;margin:0 auto;
  padding:24px var(--pad);
  border-top:1px solid var(--steel);
  border-bottom:1px solid var(--steel);
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
.fm-item{display:flex;flex-direction:column;gap:4px}
.fm-tag{font-family:var(--mono);font-size:10px;color:var(--ocre-soft);letter-spacing:0.22em;text-transform:uppercase}
.fm-val{font-size:12.5px;color:var(--cream-light);font-family:var(--sans)}

.footer-bot{
  max-width:1480px;margin:0 auto;
  padding:24px var(--pad);
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:0.06em;color:var(--steel-soft);
}
.footer-bot a{margin-left:18px}
.footer-bot a:hover{color:var(--ocre-soft)}
.f-legal{display:flex;flex-wrap:wrap}

@media(max-width:900px){
  .footer-top{grid-template-columns:1fr;gap:40px}
  .f-grid{grid-template-columns:repeat(2,1fr)}
  .footer-mid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .f-grid{grid-template-columns:1fr}
  .footer-mid{grid-template-columns:1fr}
  .footer-bot{flex-direction:column;align-items:flex-start}
  .footer-bot a{margin-left:0;margin-right:14px}
}

/* ===== REVEAL ===== */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease, transform .7s ease}
.reveal.is-in{opacity:1;transform:translateY(0)}

/* ===== TABLE TOGGLE ===== */
.toggle-bar{display:inline-flex;background:var(--cream-light);border:1px solid var(--line);border-radius:var(--rad);overflow:hidden;margin-top:30px}
.toggle-bar button{
  background:transparent;border:none;
  padding:10px 22px;cursor:pointer;
  font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;
  color:var(--slate-soft);
}
.toggle-bar button.is-active{background:var(--navy);color:var(--cream-light)}

/* ===== UTILS ===== */
.txt-center{text-align:center}
.mt-30{margin-top:30px}
.intro-block{max-width:980px;margin:0 auto;text-align:center;padding-bottom:40px}
.intro-block p{font-family:var(--serif);font-size:21px;color:var(--slate);line-height:1.6;font-style:italic}
