/* === Variables & Base === */
:root{
  --bg:#ffffff;
  --text:#151617;
  --muted:#6b7280;
  --accent:#2563eb;
  --accent-2:#0ea5e9;
  --surface:#f5f7fb;
  --card:#ffffff;
  --border:#e5e7eb;
  --radius:14px;
  --shadow:0 6px 30px rgba(2,6,23,.08);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,'Helvetica Neue',Arial;
  color:var(--text); background:var(--bg); line-height:1.6;
}
.wrap{width:min(1150px, 92%); margin-inline:auto}
.screen-reader-text{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}
.screen-reader-text:focus{position:static;width:auto;height:auto}
.muted{color:var(--muted)}
.accent{color:var(--accent)}

/* === Header === */
.site-header{
  background:#fff; border-bottom:1px solid var(--border);
  box-shadow:0 2px 8px rgba(15,23,42,.04);
  position:sticky; top:0; z-index:100;
}
.header__inner{
  height:70px; display:flex; align-items:center; justify-content:space-between;
}
.logo img{height:42px;width:auto}
.logo__text{font-weight:700;font-size:1.15rem;color:var(--text);text-decoration:none}


.nav-toggle{
  display:none;flex-direction:column;justify-content:center;align-items:center;gap:4px;
  width:36px;height:36px;border:1px solid var(--border);border-radius:8px;background:#fff;cursor:pointer;
}
.nav-toggle__bar{width:18px;height:2px;background-color:var(--text);border-radius:1px}
.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}



/* === Boutons === */
.btn{
  display:inline-block;padding:.9rem 1.2rem;border-radius:12px;border:1px solid transparent;
  text-decoration:none;font-weight:600;box-shadow:var(--shadow);transition:transform .05s ease;
}
.btn:active{transform:translateY(1px)}
.btn--primary{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#fff}
.btn--secondary{background:#fff;border-color:var(--border)}
.btn--ghost{background:transparent;border-color:var(--border);color:var(--text)}

/* === HERO === */
.hero{
  position:relative;overflow:hidden;background:linear-gradient(180deg,#eef2ff,#ffffff);
  padding:clamp(3rem,6vw,6rem) 0;
}
.hero__title{font-size:clamp(1.9rem,4vw,3rem);line-height:1.15;margin:0 0 .6rem;z-index: 1;}
.hero__subtitle{max-width:62ch;margin:.2rem 0 1.2rem;color:var(--muted)}
.hero__cta{display:flex;gap:.7rem;flex-wrap:wrap;margin:1rem 0}
.hero__badges{display:flex;gap:1rem;padding:0;list-style:none;color:var(--muted);font-size:.95rem;margin:.8rem 0 0}
.hero__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0; /* derrière le texte */
  background:
	radial-gradient(60% 120% at 70% 0%, rgba(37,99,235,0.20), transparent 60%),
	radial-gradient(50% 120% at 0% 0%, rgba(14,165,233,0.15), transparent 60%),
    url('/wp-content/uploads/hero.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

  

/* === TRUST === */
.trust{padding:1.2rem 0}
.trust__grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem;list-style:none;margin:0;padding:0}
@media (min-width:900px){.trust__grid{grid-template-columns:repeat(4,1fr)}}

/* ---- BANDEAU DE RÉASSURANCE ---- */
.reassurance-bar {
  background: #f5f5f5; /* gris clair */
  padding: 12px 0;
  border-top: 1px solid #e0e0e0;
  border-bottom: 1px solid #e0e0e0;
  font-family: inherit;
}

.reassurance-inner {
  display: flex;
  align-items: center;
  gap: 12px;
}

.reassurance-icon svg {
  display: block;
}

.reassurance-text {
  margin: 0;
  font-size: 15px;
  color: #333;
  line-height: 1.4;
}

/* Responsive : centre et empile si mobile */
@media (max-width: 600px) {
  .reassurance-inner {
    flex-direction: column;
    text-align: center;
    gap: 8px;
  }
}

/* === SERVICES === */
.services{padding:3rem 0;background:var(--surface)}
.cards{display:grid;grid-template-columns:1fr;gap:1rem}
@media (min-width:900px){.cards{grid-template-columns:repeat(3,1fr)}}
.card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:1.2rem;box-shadow:var(--shadow);
}
.card h3{margin:.2rem 0 .4rem}
.list{margin:.6rem 0 1rem 1.1rem}

/* === PROCESS === */
.process{padding:3rem 0}
.steps{display:grid;grid-template-columns:1fr;gap:1rem;counter-reset:step;margin:0;padding:0;list-style:none}
.steps li{
  background:var(--card);border:1px solid var(--border);padding:1rem;border-radius:var(--radius);box-shadow:var(--shadow)
}
@media (min-width:900px){.steps{grid-template-columns:repeat(3,1fr)}}

/* === REGION === */
.region{padding:3rem 0;background:linear-gradient(180deg,#fff,#f9fafb)}
.region__cta{margin-top:1rem}

/* === TESTIMONIALS === */
.testi{padding:3rem 0}
.testi__grid{display:grid;grid-template-columns:1fr;gap:1rem}
@media (min-width:900px){.testi__grid{grid-template-columns:repeat(3,1fr)}}
.quote{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1rem;box-shadow:var(--shadow);font-style:italic;
}
.stars {
  font-size: 1.2rem;
  color: #3a5ba7; 
  margin: 0.5rem 0 0.5rem 0;
  letter-spacing: 2px;
}

/* === PRICING === */
.pricing{padding:3rem 0;background:var(--surface)}
.cards--pricing .card--price .price{font-size:1.1rem;margin:.4rem 0}

/* === FAQ === */
.faq{padding:3rem 0}
.faq details{
  background:#fff;border:1px solid var(--border);border-radius:12px;padding:.9rem 1rem;
  box-shadow:var(--shadow);margin:.6rem 0
}
.faq summary{cursor:pointer;font-weight:600}

/* === NEWSLETTER === */
.newsletter{padding:3rem 0;background:linear-gradient(180deg,#f9fafb,#ffffff)}

/* === CTA FINALE === */
.cta-final{padding:3rem 0 4rem}
.cta-final__inner{
  background:#0b1220;color:#fff;border-radius:16px;padding:2rem;text-align:center;box-shadow:var(--shadow);
}
.cta-final__inner .btn--ghost{color:#fff;border-color:rgba(255,255,255,.2)}

/* === Utilitaires de titres === */
.section-title{font-size:clamp(1.4rem,2.5vw,2rem);margin:0 0 1rem 0}


/* ===== HEADER ===== */
.site-header {
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  height: 80px;
  display: flex;
  align-items: center;
  position: relative;
  z-index: 1000;
}

.header-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 30px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

/* LOGO */
.site-logo img {
  max-height: 60px; /* le logo ne dépasse pas la hauteur du header */
  height: auto;
  width: auto;
  display: block;
}

/* MENU */



/* ===== SIMULATEUR — OVERRIDES FINALES ===== */

/* SCOPE : si la classe disparaît, on a des fallback plus bas */
body .site-main.page-simulateur-urbanisme { background: var(--surface) !important; }

/* Layout principal */
body .page-simulateur-urbanisme .wrap-simu-urbanisme {
  width: min(1150px,92%) !important;
  margin: 2.5rem auto 3.5rem !important;
}
body .page-simulateur-urbanisme .simulator-wrap {
  display: grid !important;
  grid-template-columns: minmax(0,2.2fr) minmax(260px,1fr) !important;
  gap: 1.5rem !important;
  align-items: flex-start !important;
}
@media (max-width:900px){
  body .page-simulateur-urbanisme .simulator-wrap { grid-template-columns: 1fr !important; }
}

/* Carte principale / champs */
body .page-simulateur-urbanisme .card-simu {
  background:#fff !important;
  border:1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 1.8rem 1.6rem 2rem !important;
  box-shadow: var(--shadow) !important;
  color: var(--text) !important;
}
body .page-simulateur-urbanisme .card-simu .lead {
  margin:0 0 1.2rem !important; color: var(--muted) !important; font-size:.95rem !important;
}
body .page-simulateur-urbanisme .section-title {
  margin:1.8rem 0 .6rem !important; font-weight:700 !important; color:var(--text) !important; font-size:1rem !important;
}
body .page-simulateur-urbanisme .card-simu .grid {
  display:grid !important; grid-template-columns: repeat(2,minmax(0,1fr)) !important; gap:1rem !important;
}
@media (max-width:800px){
  body .page-simulateur-urbanisme .card-simu .grid { grid-template-columns:1fr !important; }
}
body .page-simulateur-urbanisme .card-simu label {
  display:block !important; margin-bottom:.25rem !important; font-size:.9rem !important; font-weight:500 !important; color:var(--text) !important;
}
body .page-simulateur-urbanisme .card-simu input[type="text"],
body .page-simulateur-urbanisme .card-simu input[type="email"],
body .page-simulateur-urbanisme .card-simu input[type="tel"],
body .page-simulateur-urbanisme .card-simu input[type="number"],
body .page-simulateur-urbanisme .card-simu select,
body .page-simulateur-urbanisme .card-simu textarea {
  width:100% !important; padding:.6rem .7rem !important; border-radius:10px !important;
  border:1px solid var(--border) !important; font-size:.95rem !important; background:#fff !important;
  color: var(--text) !important;
}
body .page-simulateur-urbanisme .card-simu input:focus,
body .page-simulateur-urbanisme .card-simu select:focus,
body .page-simulateur-urbanisme .card-simu textarea:focus {
  outline:none !important; border-color: var(--accent) !important; box-shadow:0 0 0 3px rgba(37,99,235,.12) !important;
}
body .page-simulateur-urbanisme .helper-text { font-size:.78rem !important; color:var(--muted) !important; margin-top:.1rem !important; }

/* Boutons */
body .page-simulateur-urbanisme .actions { display:flex !important; flex-wrap:wrap !important; gap:.6rem !important; margin-top:1.2rem !important; }
body .page-simulateur-urbanisme #su-calc,
body .page-simulateur-urbanisme #su-save {
  background:linear-gradient(120deg,var(--accent),var(--accent-2)) !important;
  color:#fff !important; border:none !important; padding:.8rem 1.2rem !important; border-radius:12px !important;
  font-weight:600 !important; cursor:pointer !important; box-shadow:var(--shadow) !important;
}
body .page-simulateur-urbanisme #su-reset {
  background:transparent !important; border:1px solid var(--border) !important; padding:.8rem 1rem !important;
  border-radius:12px !important; font-weight:500 !important; color:var(--text) !important;
}

/* Résultat */
body .page-simulateur-urbanisme #su-out {
  margin-top:1rem !important; padding:1rem !important; border-radius:var(--radius) !important;
  border:1px dashed var(--border) !important; background:#f9fafb !important; box-shadow:var(--shadow) !important;
  font-size:.92rem !important; color:var(--text) !important;
}
body .page-simulateur-urbanisme #su-out .badge { display:inline-block !important; padding:.18rem .55rem !important; border-radius:999px !important; font-size:.7rem !important; font-weight:700 !important; margin-right:.3rem !important; }
body .page-simulateur-urbanisme #su-out .badge.dp { background:rgba(245,158,11,.08) !important; color:#92400e !important; }
body .page-simulateur-urbanisme #su-out .badge.pc { background:rgba(37,99,235,.08) !important; color:#1d4ed8 !important; }
body .page-simulateur-urbanisme #su-out .badge.na { background:rgba(16,185,129,.08) !important; color:#047857 !important; }
body .page-simulateur-urbanisme #su-out .err,
body .page-simulateur-urbanisme #su-out .err-msg { color:#b91c1c !important; font-weight:600 !important; }

/* Colonne droite */
body .page-simulateur-urbanisme .simulator-aside { display:flex !important; flex-direction:column !important; gap:1rem !important; }
body .page-simulateur-urbanisme .info-card {
  background:#0b1220 !important; color:#fff !important; padding:1rem 1rem 1.1rem !important;
  border-radius:var(--radius) !important; box-shadow:var(--shadow) !important; font-size:.9rem !important;
}
body .page-simulateur-urbanisme .info-card h3 { margin:.1rem 0 .3rem !important; font-size:1rem !important; }
body .page-simulateur-urbanisme .result-card {
  background:#fff !important; border:1px dashed var(--border) !important; border-radius:var(--radius) !important; box-shadow:var(--shadow) !important; padding:1rem !important;
}
body .page-simulateur-urbanisme .result-label { font-size:.75rem !important; text-transform:uppercase !important; color:var(--muted) !important; letter-spacing:.08em !important; margin-bottom:.2rem !important; }
body .page-simulateur-urbanisme .result-main { font-size:1.05rem !important; font-weight:700 !important; color:var(--accent) !important; }
body .page-simulateur-urbanisme .su-hidden { display:none !important; }

/* Bandeau HERO du simulateur */
body .page-simulateur-urbanisme .simulator-hero { padding: 2.5rem 0 1.5rem !important; }
body .page-simulateur-urbanisme .simulator-hero__content {
  background: linear-gradient(135deg,#eef2ff,#ffffff) !important; border-radius: var(--radius) !important;
  padding: 1.8rem 1.6rem !important; box-shadow: var(--shadow) !important;
}
body .page-simulateur-urbanisme .simulator-hero h1 { margin:0 0 .5rem !important; font-size: clamp(1.8rem,3vw,2.4rem) !important; }
body .page-simulateur-urbanisme .simulator-hero__text { margin:0 0 .8rem !important; color: var(--muted) !important; }
body .page-simulateur-urbanisme .simulator-steps { display:flex !important; flex-wrap:wrap !important; gap:.4rem !important; }
body .page-simulateur-urbanisme .simulator-step-tag { padding:.3rem .7rem !important; border-radius:999px !important; background: rgba(37,99,235,.06) !important; color: var(--accent) !important; font-size:.8rem !important; font-weight:500 !important; }

/* Fallback (au cas où la classe page-simulateur-urbanisme manquerait) */
body .wrap-simu-urbanisme:not(.__scoped__){
  width:min(1150px,92%) !important; margin: 2.5rem auto 3.5rem !important;
}


/*body{outline:3px solid hotpink !important;}*/


/* MODULE TELECHARGER PLU */

/* ================================
   Portail-Urbanisme.fr – Module PLU
   À coller dans style.css du thème enfant
   ou dans le CSS additionnel
==================================*/

:root {
  /* Palette sobre institutionnelle / startup */
  --pu-primary: #1f3c88;      /* Bleu profond sérieux */
  --pu-primary-light: #e6eeff;
  --pu-accent: #00a3ff;       /* Accent moderne */
  --pu-border: #d8dde6;
  --pu-bg-soft: #f5f7fb;
  --pu-error: #c62828;
  --pu-text-main: #111827;
  --pu-text-muted: #6b7280;
  --pu-radius-lg: 14px;
  --pu-radius-sm: 8px;
  --pu-shadow-soft: 0 10px 30px rgba(15, 23, 42, 0.08);
  --pu-font: system-ui, -apple-system, BlinkMacSystemFont, "SF Pro Text",
             -system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
             sans-serif;
}

/* Conteneur principal */
.plu-module {
  max-width: 720px;
  margin: 40px auto;
  padding: 28px 24px 26px;
  background: #ffffff;
  border-radius: var(--pu-radius-lg);
  box-shadow: var(--pu-shadow-soft);
  border: 1px solid rgba(148, 163, 253, 0.16);
  font-family: var(--pu-font);
}

/* Titre & intro */
.plu-module h2 {
  margin: 0 0 8px;
  font-size: 1.6rem;
  font-weight: 650;
  color: var(--pu-primary);
  letter-spacing: 0.01em;
}

.plu-module > p {
  margin: 0 0 18px;
  font-size: 0.96rem;
  color: var(--pu-text-muted);
}

/* Formulaire */
.plu-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 18px;
}

.plu-form label {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--pu-text-main);
}

.plu-form input[type="text"],
.plu-form input[type="email"] {
  width: 100%;
  padding: 10px 11px;
  border-radius: var(--pu-radius-sm);
  border: 1px solid var(--pu-border);
  font-size: 0.92rem;
  color: var(--pu-text-main);
  background-color: #ffffff;
  transition: all 0.18s ease;
}

.plu-form input::placeholder {
  color: #9ca3af;
}

.plu-form input:focus {
  outline: none;
  border-color: var(--pu-accent);
  box-shadow: 0 0 0 3px rgba(0, 163, 255, 0.12);
  background-color: #ffffff;
}

/* Checkbox consentement */
.plu-consent {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--pu-text-muted);
}

.plu-consent input[type="checkbox"] {
  margin-top: 3px;
  width: 15px;
  height: 15px;
  accent-color: var(--pu-primary);
}

/* Bouton */
#plu-search-btn {
  margin-top: 4px;
  width: 100%;
  padding: 11px 18px;
  border: none;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--pu-primary), var(--pu-accent));
  color: #ffffff;
  font-size: 0.98rem;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  box-shadow: 0 8px 22px rgba(37, 99, 235, 0.28);
  transition: all 0.18s ease;
}

#plu-search-btn::after {
  content: "→";
  font-size: 0.9rem;
  transform: translateX(0);
  transition: transform 0.18s ease;
}

#plu-search-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 32px rgba(37, 99, 235, 0.32);
}

#plu-search-btn:hover::after {
  transform: translateX(3px);
}

#plu-search-btn:active {
  transform: translateY(1px);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.22);
}

/* Zone de résultat */
.plu-result {
  margin-top: 6px;
  font-size: 0.9rem;
}

/* Cartes PLU / PLUi */
.plu-card {
  margin-top: 10px;
  padding: 11px 12px;
  border-radius: var(--pu-radius-sm);
  background: var(--pu-bg-soft);
  border: 1px solid rgba(148, 163, 253, 0.35);
  box-shadow: 0 4px 14px rgba(15, 23, 42, 0.04);
}

.plu-card h3 {
  margin: 0 0 4px;
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--pu-primary);
}

.plu-card p {
  margin: 0 0 4px;
  color: var(--pu-text-main);
  font-size: 0.86rem;
}

.plu-card p.plu-partition {
  margin-top: 2px;
  font-size: 0.7rem;
  color: var(--pu-text-muted);
}

.plu-card a {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--pu-accent);
  text-decoration: none;
}

.plu-card a::after {
  content: "↗";
  font-size: 0.78rem;
}

.plu-card a:hover {
  text-decoration: underline;
}

/* Cartes d'erreur */
.plu-card-error {
  background: #fff5f5;
  border-color: rgba(198, 40, 40, 0.2);
}

.plu-card-error p {
  color: var(--pu-error);
}

/* Messages simples */
.plu-result > p {
  margin: 8px 0 0;
  font-size: 0.85rem;
  color: var(--pu-text-muted);
}

/* Responsive */
@media (max-width: 640px) {
  .plu-module {
    margin: 24px 12px;
    padding: 18px 14px 16px;
  }

  .plu-module h2 {
    font-size: 1.35rem;
  }

  #plu-search-btn {
    font-size: 0.9rem;
    padding: 10px 14px;
  }
}

/* FIN MODULE TELECHARGER PLU */

/* FOOTER PORTAIL URBANISME - WordPress */
.pu-footer {
  background: #f5f7fb;
  padding: 50px 0 20px;
  color: #1a1a1a;
  font-family: system-ui, sans-serif;
}

.pu-footer__top {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  max-width: 1200px;
  margin: 0 auto 40px;
  padding: 0 20px;
}

.pu-footer__col h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 15px;
}

.pu-footer__logo-wrapper img {
  max-width: 160px;
  height: auto;
  display: block;
  margin-bottom: 15px;
}

.pu-footer__site-title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 10px;
}

.pu-footer__tagline {
  font-size: 15px;
  color: #555;
  line-height: 1.5;
  max-width: 260px;
}

.pu-footer__menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

.pu-footer__menu li {
  margin: 8px 0;
}

.pu-footer__menu a {
  text-decoration: none;
  color: #1f4f9c;
  font-weight: 500;
  transition: 0.2s;
}

.pu-footer__menu a:hover {
  color: #20b486;
}

/* Réseaux sociaux */
.pu-footer__socials {
  margin-top: 20px;
}

.pu-footer__socials a {
  font-size: 20px;
  color: #1a1a1a;
  margin-right: 12px;
  transition: 0.2s;
}

.pu-footer__socials a:hover {
  color: #20b486;
}

/* Bas de footer */
.pu-footer__bottom {
  text-align: center;
  padding: 20px 10px 0;
  font-size: 14px;
  color: #666;
  border-top: 1px solid rgba(0,0,0,0.08);
}

/* Responsive */
@media (max-width: 900px) {
  .pu-footer__top {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .pu-footer__tagline {
    max-width: 100%;
    margin: 0 auto;
  }

  .pu-footer__socials a {
    margin: 0 10px;
  }
}

/* Conteneur général du footer bottom */
.pu-footer__bottom {
  text-align: center !important;
  display: flex;
  flex-direction: column;
  align-items: center !important;
  justify-content: center;
}

/* Ligne des cookies centrée */
.pu-footer__cookies-link {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: 100%;
  text-align: center !important;
  margin-top: 8px;
}

/* Bouton Complianz centré */
.pu-footer__cookies-link .cmplz-manage-consent {
  display: inline-flex !important;
  text-align: center !important;
  justify-content: center !important;
  align-items: center !important;
  width: auto !important;
  margin: 0 auto !important;
}

/* Lien Complianz centré (si version < 7 utilise <a>) */
.pu-footer__cookies-link a {
  display: inline-flex !important;
  text-align: center !important;
  margin: 0 auto !important;
}

/* FIN FOOTER PORTAIL URBANISME - WordPress */

/* PAGES NOS SERVICES (DP, PC,etc.. */

.service-page h1 {
  font-size: 42px;
  font-weight: 700;
}

.service-hero {
  background: #f5f7fb;
  padding: 80px 0;
  text-align: center;
}

.service-section {
  padding: 60px 0;
}

.service-cta {
  background: #1f4f9c;
  color: #fff;
  text-align: center;
  padding: 60px 0;
}

.service-cta .btn-primary {
  background: #20b486;
  padding: 16px 32px;
  border-radius: 6px;
  color: #fff;
  font-size: 18px;
}

/* FIN PAGES NOS SERVICES (DP, PC,etc.. */

.pc-page .service-hero {
  text-align: center;
  padding: 80px 0 60px;
}

.pc-page .service-hero .subtitle {
  max-width: 720px;
  margin: 16px auto 24px;
}

.pc-page .service-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.pc-page .service-card {
  background: #ffffff;
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.pc-page .service-section {
  padding: 60px 0;
}

.pc-page .service-faq .faq-item + .faq-item {
  margin-top: 24px;
}

.pc-page .service-cta {
  text-align: center;
  background: #1f4f9c;
  color: #fff;
}

.pc-page .service-cta .btn-primary {
  margin-right: 12px;
}


/* ================================
   VARIABLES GLOBALES (optionnel)
   ================================ */

:root {
  --pu-bg: #f5f7fb;
  --pu-primary: #1f4f9c;
  --pu-primary-soft: rgba(31, 79, 156, 0.06);
  --pu-accent: #20b486;
  --pu-text: #111827;
  --pu-muted: #6b7280;
  --pu-radius-lg: 18px;
  --pu-radius-xl: 24px;
  --pu-shadow-soft: 0 18px 40px rgba(15, 23, 42, 0.10);
}

/* ================================
   STRUCTURE GÉNÉRALE
   ================================ */

.service-page {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--pu-text);
  background-color: #ffffff;
}

/* Conteneur central – au cas où .wrap n’existerait pas déjà */
.service-page .wrap {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 20px;
}

/* Sections */
.service-page .service-section {
  padding: 64px 0;
}

@media (max-width: 768px) {
  .service-page .service-section {
    padding: 40px 0;
  }
}

/* Titres */
.service-page h1 {
  font-size: 2.6rem;
  line-height: 1.1;
  font-weight: 700;
  margin: 0 0 12px;
}

.service-page h2 {
  font-size: 1.9rem;
  margin-bottom: 16px;
}

.service-page h3 {
  font-size: 1.2rem;
  margin-bottom: 8px;
}

/* Texte */
.service-page p {
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 12px;
  color: var(--pu-text);
}

.service-page .subtitle {
  font-size: 1.1rem;
  color: var(--pu-muted);
  max-width: 720px;
  margin: 8px auto 0;
}

/* ================================
   HERO
   ================================ */

.service-page .service-hero {
  background: linear-gradient(135deg, var(--pu-bg), #ffffff);
  border-bottom: 1px solid rgba(148, 163, 184, 0.25);
  padding: 80px 0 56px;
  text-align: center;
}

.service-page .service-hero__cta,
.service-page .service-cta__buttons {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 24px;
}

/* ================================
   BOUTONS
   ================================ */

.service-page .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  border-radius: 999px;
  font-size: 0.98rem;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 0.12s ease-out, box-shadow 0.12s ease-out, background-color 0.12s ease-out, border-color 0.12s ease-out;
}

.service-page .btn-primary {
  background-color: var(--pu-accent);
  color: #ffffff;
  box-shadow: 0 12px 30px rgba(32, 180, 134, 0.35);
}

.service-page .btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 40px rgba(32, 180, 134, 0.45);
}

.service-page .btn-secondary {
  background-color: #ffffff;
  color: var(--pu-primary);
  border-color: rgba(148, 163, 184, 0.6);
}

.service-page .btn-secondary:hover {
  background-color: var(--pu-primary-soft);
}

.service-page .btn-ghost {
  background-color: transparent;
  color: var(--pu-primary);
  border-color: transparent;
}

.service-page .btn-ghost:hover {
  background-color: var(--pu-primary-soft);
}

/* ================================
   GRILLES & CARTES
   ================================ */

.service-page .service-grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  margin-top: 24px;
}

.service-page .service-card {
  background-color: #ffffff;
  border-radius: var(--pu-radius-lg);
  padding: 22px 22px 20px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06);
}

.service-page .service-card p {
  margin-bottom: 0;
  color: var(--pu-muted);
}

/* ================================
   LISTES PROCESS & FAQ
   ================================ */

.service-page .process-list {
  list-style: none;
  counter-reset: step-counter;
  padding-left: 0;
  margin: 24px 0 0;
}

.service-page .process-list li {
  position: relative;
  padding-left: 44px;
  margin-bottom: 18px;
}

.service-page .process-list li::before {
  counter-increment: step-counter;
  content: counter(step-counter);
  position: absolute;
  left: 0;
  top: 2px;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background-color: var(--pu-primary-soft);
  color: var(--pu-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.85rem;
  font-weight: 600;
}

/* FAQ */

.service-page .service-faq .faq-item {
  border-radius: var(--pu-radius-lg);
  border: 1px solid rgba(148, 163, 184, 0.4);
  padding: 18px 20px;
  background-color: #ffffff;
}

.service-page .service-faq .faq-item + .faq-item {
  margin-top: 16px;
}

.service-page .service-faq h3 {
  margin-bottom: 6px;
}

/* ================================
   CTA BAS DE PAGE
   ================================ */

.service-page .service-cta {
  background: radial-gradient(circle at top left, var(--pu-primary-soft), #ffffff);
  text-align: center;
  padding: 64px 0;
  border-top: 1px solid rgba(148, 163, 184, 0.25);
  border-bottom: 1px solid rgba(148, 163, 184, 0.25);
}

.service-page .service-cta h2 {
  margin-bottom: 10px;
}

.service-page .service-cta p {
  max-width: 640px;
  margin: 0 auto 22px;
  color: var(--pu-muted);
}

/* ================================
   LISTES CLASSIQUES
   ================================ */

.service-page ul {
  padding-left: 18px;
}

.service-page ul li {
  margin-bottom: 6px;
}

/* ================================
   RESPONSIVE
   ================================ */

@media (max-width: 640px) {
  .service-page h1 {
    font-size: 2rem;
  }

  .service-page h2 {
    font-size: 1.6rem;
  }

  .service-page .service-hero {
    padding: 64px 0 40px;
  }

  .service-page .btn {
    width: 100%;
    max-width: 260px;
  }
}




/* ===== PAGES SERVICES - LAYOUT GÉNÉRAL ===== */

.pu-service {
  padding: 4rem 0;
  background: #f5f7fb;
}

.pu-service__wrapper {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 2.1fr) minmax(0, 1.1fr);
  gap: 3rem;
  align-items: flex-start;
}

.pu-service__content {
  min-width: 0;
}

.pu-service__sidebar {
  min-width: 0;
}

/* Version mobile / tablette */
@media (max-width: 960px) {
  .pu-service__wrapper {
    grid-template-columns: 1fr;
  }
}

/* ===== HERO / INTRO ===== */

.pu-service-hero {
  margin-bottom: 2.5rem;
}

.pu-service-hero__kicker {
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #6c727f;
  margin-bottom: 0.4rem;
}

.pu-service-hero__title {
  font-size: 2.4rem;
  line-height: 1.15;
  margin: 0 0 0.6rem;
}

.pu-service-hero__subtitle {
  font-size: 1.05rem;
  color: #4b5563;
  max-width: 40rem;
}

/* ===== SECTIONS ===== */

.pu-section {
  margin-bottom: 3rem;
}

.pu-section--tight {
  margin-bottom: 2.2rem;
}

.pu-section--accent {
  background: #ffffff;
  border-radius: 20px;
  padding: 2rem;
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.06);
}

.pu-section--cta {
  text-align: left;
}

.pu-section__title {
  font-size: 1.6rem;
  margin-bottom: 1rem;
}

/* ===== LISTES ===== */

.pu-list {
  padding-left: 1.1rem;
  margin: 0 0 1.2rem;
}

.pu-list li {
  margin-bottom: 0.4rem;
}

.pu-list--bullets {
  list-style: disc;
}

.pu-list--check {
  list-style: none;
  padding-left: 0;
}

.pu-list--check li::before {
  content: "✓";
  display: inline-block;
  margin-right: 0.5rem;
  font-weight: 600;
  color: #20b486;
}

.pu-list--icon {
  list-style: none;
  padding-left: 0;
}

.pu-list--icon li::before {
  content: "•";
  display: inline-block;
  margin-right: 0.5rem;
  font-weight: 700;
  color: #1f4f9c;
}

/* ===== GRID ===== */

.pu-grid {
  display: grid;
  gap: 1.5rem;
}

.pu-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.pu-grid__full {
  grid-column: 1 / -1;
}

@media (max-width: 960px) {
  .pu-grid--2 {
    grid-template-columns: 1fr;
  }
}

/* ===== CARDS ===== */

.pu-card {
  background: #ffffff;
  border-radius: 18px;
  padding: 1.5rem 1.7rem;
  border: 1px solid rgba(148, 163, 253, 0.15);
  box-shadow: 0 14px 40px rgba(15, 23, 42, 0.05);
}

.pu-card--soft {
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.04);
}

.pu-card--primary {
  background: linear-gradient(135deg, #1f4f9c 0%, #2758a8 40%, #20b486 100%);
  color: #ffffff;
  border: none;
}

.pu-card--helper {
  margin-top: 1.5rem;
}

.pu-card--sticky {
  position: sticky;
  top: 1.5rem;
}

.pu-card__title {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}

.pu-card__subtitle {
  font-size: 0.95rem;
  opacity: 0.9;
  margin-bottom: 1.1rem;
}

.pu-card__text {
  font-size: 0.98rem;
}

/* ===== HIGHLIGHT TEXTE ===== */

.pu-highlight {
  margin-top: 1rem;
  padding: 0.9rem 1rem;
  border-radius: 12px;
  background: rgba(31, 79, 156, 0.06);
  border: 1px solid rgba(31, 79, 156, 0.12);
}

/* ===== BOUTONS ===== */

.pu-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1rem;
}

.pu-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1.3rem;
  border-radius: 999px;
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.12s ease, color 0.12s ease;
}

.pu-button--primary {
  background: #ffffff;
  color: #1f4f9c;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.35);
}

.pu-card--primary .pu-button--primary {
  background: #ffffff;
  color: #1f4f9c;
}

.pu-button--ghost {
  background: transparent;
  color: #1f4f9c;
  border: 1px solid rgba(31, 79, 156, 0.35);
}

.pu-button--outline {
  background: transparent;
  color: #1f4f9c;
  border: 1px solid rgba(31, 79, 156, 0.3);
}

.pu-button--full {
  width: 100%;
}

.pu-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 35px rgba(15, 23, 42, 0.18);
}

/* ===== WIDGET ESTIMATION ===== */

.pu-estimation-widget {
  margin-top: 0.8rem;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 16px;
  padding: 1rem 1.1rem;
}

.pu-card--primary .pu-estimation-widget {
  border: 1px solid rgba(255, 255, 255, 0.25);
}

.pu-estimation-widget__result {
  margin-bottom: 1rem;
}

.pu-estimation-widget__label {
  display: block;
  font-size: 0.85rem;
  opacity: 0.9;
}

.pu-estimation-widget__price-wrapper {
  display: flex;
  flex-direction: column;
}

.pu-estimation-widget__price {
  font-size: 1.7rem;
  font-weight: 700;
  margin-top: 0.2rem;
}

.pu-estimation-widget__note {
  font-size: 0.8rem;
  opacity: 0.9;
}

/* ===== FAQ ===== */

.pu-section--faq {
  margin-top: 2rem;
}

.pu-faq {
  margin-bottom: 0.8rem;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(148, 163, 253, 0.22);
  padding: 0.7rem 0.9rem;
}

.pu-faq__question {
  cursor: pointer;
  list-style: none;
}

.pu-faq__question::-webkit-details-marker {
  display: none;
}

.pu-faq__question::after {
  content: "＋";
  float: right;
  font-weight: 700;
  color: #1f4f9c;
}

details[open] .pu-faq__question::after {
  content: "−";
}

.pu-faq__answer {
  margin-top: 0.4rem;
  font-size: 0.95rem;
  color: #4b5563;
}

/* === CONTACT === */
.contact-container {
  display: flex;
  justify-content: center;
}

.contact-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 2rem 1.5rem 4rem;
}

/* TITRES */
.contact-header {
  text-align: center;
  margin-bottom: 2.5rem;
}

.contact-title {
  font-size: 2.4rem;
  margin: 0;
}

.contact-subtitle {
  color: #555;
  max-width: 650px;
  margin: 0.5rem auto 0;
}

/* NOTICES */
.contact-notice {
  padding: 1rem 1.2rem;
  border-radius: 10px;
  margin-bottom: 1.5rem;
}

.contact-notice.success {
  background: #dcfce7;
  border-left: 4px solid #16a34a;
}

.contact-notice.error {
  background: #fee2e2;
  border-left: 4px solid #dc2626;
}

/* GRID 2 COLONNES */
.contact-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 2rem;
}

/* CARTES */
.contact-form-card,
.contact-info-card {
  background: #fff;
  border-radius: 14px;
  padding: 1.8rem;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.06);
  border: 1px solid rgba(0,0,0,0.06);
}

/* FORMULAIRE */
.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.form-group {
  margin-bottom: 1rem;
}

.form-group label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.4rem;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  padding: 0.65rem 0.8rem;
  font-size: 1rem;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: #2563eb;
  outline: none;
  box-shadow: 0 0 0 2px rgba(37,99,235,0.15);
}

.form-group.checkbox {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
}

.contact-btn {
  background: #2563eb;
  color: #fff;
  padding: 0.9rem 1.8rem;
  border-radius: 999px;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
  margin-top: 0.5rem;
  transition: 0.15s;
}

.contact-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(37,99,235,0.3);
}

/* SIDEBAR */
.contact-sidebar h3 {
  margin-top: 0;
}

.contact-link {
  display: inline-block;
  margin-top: 0.6rem;
  padding: 0.45rem 1rem;
  border-radius: 8px;
  background: #2563eb;
  color: #fff;
  text-decoration: none;
}

.contact-link:hover {
  background: #1e40af;
}

/* RESPONSIVE */
@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
  .form-row {
    grid-template-columns: 1fr;
  }
}

/* === FIN CONTACT === */

/* ==== Messages AJAX ======*/
.contact-ajax-message {
  margin-bottom: 1rem;
  font-size: 0.95rem;
}

.contact-ajax-message.success {
  padding: 0.8rem 1rem;
  border-radius: 8px;
  background: #dcfce7;
  border-left: 4px solid #16a34a;
}

.contact-ajax-message.error {
  padding: 0.8rem 1rem;
  border-radius: 8px;
  background: #fee2e2;
  border-left: 4px solid #dc2626;
}

.contact-ajax-message.error ul {
  margin: 0;
  padding-left: 1.2rem;
}

/* Loader sur le bouton */
.contact-btn.is-loading {
  position: relative;
  color: transparent; /* cache le texte pendant le spinner */
}

.contact-btn.is-loading::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid rgba(255, 255, 255, 0.7);
  border-top-color: transparent;
  transform: translate(-50%, -50%);
  animation: pu-spin 0.7s linear infinite;
}

@keyframes pu-spin {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
/* ==== FIN Messages AJAX ======*/

/* ==== Page guide et tutoriels ======*/

/* Layout global guides */
.guide-page .wrap.guide-layout {
  display: grid;
  grid-template-columns: minmax(0, 2.2fr) minmax(260px, 1fr);
  gap: 40px;
  align-items: flex-start;
  margin-top: 40px;
  margin-bottom: 60px;
}

/* Sur mobile : empiler */
@media (max-width: 900px) {
  .guide-page .wrap.guide-layout {
    grid-template-columns: 1fr;
  }
}

/* Contenu principal */
.guide-article__title {
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

.guide-article__body {
  font-size: 1rem;
  line-height: 1.7;
}

.guide-article__body h2,
.guide-article__body h3 {
  margin-top: 1.8rem;
  margin-bottom: 0.6rem;
}

.guide-article__body ul {
  margin-left: 1.2rem;
  margin-bottom: 1rem;
}

/* Sidebar */
.guide-layout__sidebar {
  position: sticky;
  top: 110px; /* ajuste en fonction de ton header */
}

/* Blocs sidebar */
.guide-sidebar__block {
  background: #f7f8fc;
  border-radius: 16px;
  padding: 18px 20px;
  margin-bottom: 18px;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.guide-sidebar__block--muted {
  background: #f5f5f5;
  box-shadow: none;
}

.guide-sidebar__title {
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 0.4rem;
}

.guide-sidebar__block p {
  font-size: 0.95rem;
  margin-bottom: 0.8rem;
}

/* Boutons / liens sidebar */
.guide-sidebar__btn,
.guide-sidebar__link {
  display: inline-block;
  font-size: 0.95rem;
  font-weight: 600;
  text-decoration: none;
}

.guide-sidebar__btn {
  padding: 10px 18px;
  border-radius: 999px;
  background: #1f4f9c;        /* bleu principal */
  color: #fff;
}

.guide-sidebar__btn:hover {
  filter: brightness(1.05);
}

.guide-sidebar__link {
  color: #1f4f9c;
}

.guide-sidebar__link::after {
  content: " →";
}

/* Accessibilité */
.skip-link {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.skip-link:focus {
  position: static;
  width: auto;
  height: auto;
  padding: 8px 12px;
  background: #000;
  color: #fff;
  z-index: 1000;
}

.guide-article__body .guide-intro {
  margin-bottom: 2rem;
}

.guide-toc {
  padding: 16px 18px;
  border-radius: 12px;
  background: #f5f7fb;
  border: 1px solid rgba(148, 163, 253, 0.4);
  margin-bottom: 2rem;
}

.guide-toc h3 {
  margin-top: 0;
  margin-bottom: 0.6rem;
  font-size: 1rem;
  font-weight: 600;
}

.guide-toc ul {
  margin: 0;
  padding-left: 1.1rem;
  font-size: 0.95rem;
}

.guide-toc a {
  text-decoration: none;
}

.guide-toc a:hover {
  text-decoration: underline;
}

.guide-callout {
  margin: 1.2rem 0;
  padding: 12px 14px;
  border-radius: 10px;
  background: #fff7e6;
  border: 1px solid #facc6b;
}

.guide-cta {
  margin-top: 2.5rem;
  padding: 18px 20px;
  border-radius: 14px;
  background: #1f4f9c;
  color: #fff;
}

.guide-cta a {
  color: #fff;
  text-decoration: underline;
  font-weight: 600;
}


/* ==== FIN Page guide et tutoriels ======*/

/* ==== LISTE DES GUIDES ET TUTORIELS ======*/

/* Page liste des guides */
.guides-list-page .guides-list-layout {
  margin-top: 40px;
  margin-bottom: 60px;
}

/* Header de la page */
.guides-list-header {
  max-width: 1024px;
  margin: 0 auto 32px auto;
  text-align: left;
}

.guides-list-title {
  font-size: 2.1rem;
  font-weight: 700;
  margin-bottom: 0.75rem;
}

.guides-list-intro {
  font-size: 1rem;
  line-height: 1.7;
  color: #4b5563;
}

/* Grille de guides */
.guides-list-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
  margin-top: 32px;
}

/* Adaptation responsive */
@media (max-width: 1024px) {
  .guides-list-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .guides-list-grid {
    grid-template-columns: 1fr;
  }
}

/* Cartes guides */
.guide-card {
  margin: 0;
}

.guide-card__inner {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 18px 18px 16px;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 14px 40px rgba(15, 23, 42, 0.08);
  border: 1px solid rgba(148, 163, 253, 0.15);
  text-decoration: none;
  transition: transform 0.15s ease-out, box-shadow 0.15s ease-out, border-color 0.15s ease-out;
}

.guide-card__inner:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 50px rgba(15, 23, 42, 0.12);
  border-color: rgba(79, 70, 229, 0.4);
}

.guide-card__meta {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 8px;
}

.guide-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .06em;
  background: #eef2ff;
  color: #3730a3;
}

.guide-card__title {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 6px 0 10px 0;
  color: #111827;
}

.guide-card__excerpt {
  font-size: 0.93rem;
  line-height: 1.6;
  color: #4b5563;
  margin-bottom: 14px;
  flex: 1 1 auto;
}

.guide-card__cta {
  display: inline-flex;
  align-items: center;
  font-size: 0.9rem;
  font-weight: 600;
  color: #1f4f9c;
  margin-top: auto;
}

.guide-card__cta-arrow {
  margin-left: 6px;
  transition: transform 0.15s ease-out;
}

.guide-card__inner:hover .guide-card__cta-arrow {
  transform: translateX(3px);
}

/* Sommaire automatique des guides */
.guides-list-toc {
  max-width: 840px;
  margin: 24px auto 32px auto;
  padding: 16px 18px;
  border-radius: 18px;
  background: #f5f7ff;
  border: 1px solid rgba(148, 163, 253, 0.5);
}

.guides-list-toc__title {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0 0 8px 0;
}

.guides-list-toc__intro {
  margin: 0 0 10px 0;
  font-size: 0.95rem;
  color: #4b5563;
}

.guides-list-toc__list {
  margin: 0;
  padding-left: 18px;
  columns: 2;
  column-gap: 32px;
}

.guides-list-toc__item {
  break-inside: avoid;
  margin-bottom: 4px;
  font-size: 0.92rem;
}

.guides-list-toc__link {
  text-decoration: none;
  color: #1f4f9c;
}

.guides-list-toc__link:hover {
  text-decoration: underline;
}

/* Sur mobile : une seule colonne pour la liste */
@media (max-width: 700px) {
  .guides-list-toc__list {
    columns: 1;
  }
}

/* ALIGNER TOUTES LES SECTIONS SUR LA MÊME LARGEUR */
.guides-list-layout {
  width: 100%;
  max-width: 1100px; /* même largeur que la grille */
  margin: 0 auto;
}

/* Le header (titre + intro) doit matcher la grille */
.guides-list-header {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto 32px auto;
  padding: 0;
}

/* Titre */
.guides-list-title {
  font-size: 2.1rem;
  font-weight: 700;
  margin-bottom: 14px;
}

/* Intro */
.guides-list-intro {
  font-size: 1rem;
  line-height: 1.7;
  color: #4b5563;
}

/* Sommaire auto : même largeur */
.guides-list-toc {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto 32px auto;
  padding: 18px 20px;
  border-radius: 18px;
  background: #f5f7ff;
  border: 1px solid rgba(148, 163, 253, 0.5);
}

/* Grille déjà dans la même largeur */
.guides-list-grid {
  width: 100%;
  max-width: 1100px;
  margin: 32px auto 0 auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

/* Responsive */
@media (max-width: 1024px) {
  .guides-list-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .guides-list-grid {
    grid-template-columns: 1fr;
  }
}

/* Style générique des badges */
.guide-badge,
.guide-card__badge {
  display: inline-block;
  padding: 4px 10px;
  font-size: 13px;
  font-weight: 600;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  line-height: 1;
}

/* Badge Tutoriel — JAUNE */
.guide-badge--tutorial {
  background-color: #f4c533; /* jaune */
  color: #000; /* contraste parfait */
  border: 1px solid #e0b22e;
  box-shadow: 0 2px 4px rgba(0,0,0,0.06);
}
/* Bloc sommaire tutoriels */
.tutoriels-list-toc {
  background: #fff7d1;      /* jaune pastel très léger */
  border: 1px solid #f4e3a4;
  padding: 25px 30px;
  border-radius: 12px;
  margin: 40px 0;
}

.tutoriels-list-toc__title {
  font-size: 26px;
  margin-bottom: 10px;
}

.tutoriels-list-toc__intro {
  font-size: 16px;
  margin-bottom: 15px;
  color: #6a5f00;
}

.tutoriels-list-toc__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.tutoriels-list-toc__item {
  margin-bottom: 8px;
}

.tutoriels-list-toc__link {
  color: #b58a00;
  /*font-weight: 600;*/
  text-decoration: none;
  transition: 0.2s;
}

.tutoriels-list-toc__link:hover {
  text-decoration: underline;
  color: #826300;
}

/* Harmonisation du titre Sommaire des Tutoriels avec celui des Guides */
.guides-list-toc__title,
.tutoriels-list-toc__title {
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  margin-bottom: 10px !important;
}

/* Liste des tutoriels — même style que la liste des guides */
.tutoriels-list-toc__list {
  columns: 2;           /* deux colonnes */
  column-gap: 40px;     /* espace entre colonnes */
  list-style: disc;     /* mêmes puces que guides (si guides utilisent disc) */
  padding-left: 20px;   /* aligne avec guides */
  margin: 15px 0;
}

/* Chaque item de la liste */
.tutoriels-list-toc__item {
  break-inside: avoid;  /* évite coupure d'un item entre colonnes */
  margin-bottom: 8px;
}

/* Style du lien (reprend celui du sommaire des guides) */
.tutoriels-list-toc__link {
  color: #b58a00;
  font-weight: 600;
  text-decoration: none;
  transition: 0.2s;
}

.tutoriels-list-toc__link:hover {
  text-decoration: underline;
  color: #826300;
}

/* Liens du sommaire des tutoriels : pas de gras */
.tutoriels-list-toc__link {
  font-weight: normal !important;
}

.tutoriels-list-toc__link {
  color: #8c6d00; /* un jaune-brun plus doux */
}
/* Card tutoriel : hover jaune */
.guide-card:hover .guide-badge--tutorial {
    border-color: #f4c533;
}

/* Card tutoriel : bordure jaune sur la card elle-même au hover */
.guide-card.tutoriel-card:hover,
.guide-card:hover .guide-card__inner.tutoriel-card-inner {
    border-color: #f4c533 !important;    /* jaune */
    box-shadow: 0 0 0 3px rgba(244, 197, 51, 0.35); /* léger glow jaune */
}

/* Hover par défaut (bleu) – on suppose que tu as déjà quelque chose comme ça */
.guides-list-grid .guide-card .guide-card__inner {
  border: 1px solid #e2e8f0;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.guides-list-grid .guide-card .guide-card__inner:hover {
  border-color: #1e7be8; /* bleu pour tous par défaut */
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.10);
  transform: translateY(-2px);
}

/* 🔥 Exception : si la card contient un badge Tutoriel, hover = JAUNE */
.guides-list-grid .guide-card:has(.guide-badge--tutorial) .guide-card__inner:hover {
  border-color: #f4c533; /* jaune tutoriel */
  box-shadow: 0 10px 25px rgba(244, 197, 51, 0.35);
}


/* ==== FIN LISTE DES GUIDES ET TUTORIELS ======*/

/* ===========================
   STRUCTURE GÉNÉRALE TUTORIEL
   =========================== */

.guide-single {
  max-width: 900px;
  margin: 0 auto 60px;
  padding: 0 16px;
  font-family: system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  color: #1f2933;
}

.guide-content {
  margin-top: 30px;
  font-size: 16px;
  line-height: 1.7;
}

.guide-content p {
  margin-bottom: 1em;
}

.guide-content ul,
.guide-content ol {
  margin: 0 0 1.2em 1.3em;
  padding: 0;
}

.guide-content li {
  margin-bottom: 0.35em;
}

/* ===========================
   HEADER / META / BADGE
   =========================== */

.guide-header {
  margin-bottom: 30px;
}

.guide-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.guide-category {
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #4b6bfb;
  text-decoration: none;
}

.guide-category:hover {
  text-decoration: underline;
}

/* Badge générique (guide ou tutoriel) */
.guide-badge {
  display: inline-block;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1;
}

/* Badge Tutoriel JAUNE */
.guide-badge--tutorial {
  background: linear-gradient(135deg, #f7d24a, #f4c533);
  color: #111;
  border: 1px solid rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 6px rgba(244, 197, 51, 0.35);
}

.guide-title {
  font-size: 30px;
  line-height: 1.2;
  margin: 0 0 12px;
}

.guide-intro {
  font-size: 17px;
  color: #4b5563;
  margin-bottom: 10px;
}

.guide-intro-highlights {
  margin: 0;
  padding-left: 1.2em;
  color: #374151;
}

/* ===========================
   TITRES & SECTIONS
   =========================== */

.guide-content h2 {
  font-size: 24px;
  margin: 32px 0 12px;
  padding-top: 8px;
  border-top: 1px solid #e5e7eb;
}

.guide-content h3 {
  font-size: 18px;
  margin: 18px 0 8px;
  color: #111827;
}

/* ===========================
   TABLEAU DES SURFACES
   =========================== */

.guide-table {
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0 25px;
  font-size: 14px;
}

.guide-table th,
.guide-table td {
  border: 1px solid #e5e7eb;
  padding: 10px 12px;
  vertical-align: top;
}

.guide-table thead {
  background: #f9fafb;
}

.guide-table th {
  font-weight: 600;
  text-align: left;
}

/* Optionnel : légère alternance de lignes */
.guide-table tbody tr:nth-child(odd) {
  background: #fdfdfd;
}

/* ===========================
   ENCARTS (ASIDE / CALLOUTS)
   =========================== */

.guide-callout {
  border-radius: 12px;
  padding: 16px 18px;
  margin: 24px 0;
  border: 1px solid transparent;
  background: #f9fafb;
}

.guide-callout__title {
  font-size: 16px;
  margin: 0 0 6px;
}

/* Info (bleu léger) */
.guide-callout--info {
  border-color: #d1e3ff;
  background: #f3f6ff;
}

/* Alerte / Attention (orange/rouge doux) */
.guide-callout--warning {
  border-color: #fed7aa;
  background: #fff7ed;
}

/* Astuce (vert) */
.guide-callout--tip {
  border-color: #bbf7d0;
  background: #ecfdf3;
}

/* ===========================
   CTA FINAL
   =========================== */

.guide-cta-block {
  margin-top: 30px;
  padding: 18px 20px;
  background: #f3f4ff;
  border-radius: 14px;
  border: 1px solid #d0d4ff;
  text-align: left;
}

.guide-cta-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 8px;
  padding: 10px 18px;
  border-radius: 999px;
  border: none;
  background: linear-gradient(135deg, #4b6bfb, #3753d9);
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.15s ease, opacity 0.15s ease;
}

.guide-cta-button:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(55, 65, 81, 0.25);
  opacity: 0.95;
}

/* ===========================
   LIENS DANS LE CONTENU
   =========================== */

.guide-content a {
  color: #2563eb;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

.guide-content a:hover {
  color: #1d4ed8;
}

/* ===========================
   RESPONSIVE
   =========================== */

@media (max-width: 768px) {
  .guide-single {
    padding: 0 14px;
  }

  .guide-title {
    font-size: 24px;
  }

  .guide-content h2 {
    font-size: 21px;
  }

  .guide-content h3 {
    font-size: 17px;
  }

  .guide-table {
    font-size: 13px;
  }
}

/* ===========================
   PAGE ARTICLES
   =========================== */

.pu-articles-wrapper {
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 20px 60px;
}

.pu-articles-title {
  font-size: 38px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 10px;
}

.pu-articles-intro {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 30px;
  font-size: 15px;
  color: #4b5563;
}

.pu-articles-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin-bottom: 30px;
  align-items: flex-end;
}

.pu-filter-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 14px;
}

.pu-filter-group label {
  font-weight: 500;
  color: #374151;
}

.pu-articles-filters select {
  padding: 9px 14px;
  border-radius: 8px;
  border: 1px solid #d1d5db;
  font-size: 14px;
  background: #fff;
}

.pu-articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.pu-article-card {
  background: #ffffff;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.pu-article-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 35px rgba(15, 23, 42, 0.08);
  border-color: #facc15; /* léger rappel "urbanisme" / jaune */
}

.pu-article-link {
  display: block;
  color: inherit;
  text-decoration: none;
  height: 100%;
}

.pu-article-thumb img,
.pu-no-thumb {
  width: 100%;
  height: 200px;
  object-fit: cover;
  background: #f3f4f6;
}

.pu-no-thumb {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  color: #6b7280;
}

.pu-article-content {
  padding: 18px 18px 16px;
}

.pu-article-category {
  display: inline-block;
  margin-bottom: 8px;
  font-size: 12px;
  background: #eff6ff;
  padding: 4px 10px;
  border-radius: 999px;
  color: #1d4ed8;
}

.pu-article-title {
  font-size: 18px;
  margin: 6px 0 8px;
  line-height: 1.3;
}

.pu-article-excerpt {
  font-size: 14px;
  color: #4b5563;
  margin-bottom: 12px;
}

.pu-article-meta {
  font-size: 12px;
  color: #9ca3af;
}

.pu-articles-pagination {
  margin-top: 30px;
  text-align: center;
}

/* Responsive */
@media (max-width: 900px) {
  .pu-articles-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .pu-articles-grid {
    grid-template-columns: 1fr;
  }

  .pu-articles-filters {
    flex-direction: column;
    align-items: stretch;
  }
}


/* ===========================
   FIN PAGE ARTICLES
   =========================== */



/* ===========================
ESPACE CLIENT
   =========================== */


.espace-client {
  max-width: 960px;
  margin: 2rem auto;
  padding: 1.5rem;
  background: #f7f7f7;
  border-radius: 8px;
}

.espace-client h2 {
  margin-top: 0;
}

.espace-client__dossiers {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.5rem;
}

.dossier-card {
  background: #fff;
  border-radius: 8px;
  padding: 1rem 1.25rem;
  border: 1px solid #ddd;
}

.dossier-card__title {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

.dossier-card__meta {
  font-size: 0.85rem;
  color: #666;
}

.dossier-card__statut {
  margin: 0.75rem 0;
}

.statut-badge {
  display: inline-block;
  padding: 0.2rem 0.6rem;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 600;
}

/* Couleurs de statuts (à adapter) */
.statut-brouillon { background:#e0e0e0; color:#333; }
.statut-en_attente_infos { background:#fff3cd; color:#856404; }
.statut-en_cours { background:#cce5ff; color:#004085; }
.statut-depose_mairie { background:#d1ecf1; color:#0c5460; }
.statut-en_instruction { background:#d6d8d9; color:#383d41; }
.statut-valide { background:#d4edda; color:#155724; }
.statut-refuse { background:#f8d7da; color:#721c24; }
.statut-clos { background:#e2e3e5; color:#383d41; }

.btn {
  display: inline-block;
  padding: 0.45rem 0.9rem;
  border-radius: 4px;
  text-decoration: none;
  font-size: 0.9rem;
}

.btn-primary {
  background: #3a5ba7;
  color: #fff;
}

.btn-secondary {
  background: #fff;
  color: #3a5ba7;
  border: 1px solid #3a5ba7;
}

.espace-client--detail .dossier-header {
  margin-bottom: 1.5rem;
}

.espace-client__back-link {
  display: inline-block;
  margin-bottom: 1rem;
  font-size: 0.9rem;
}

.dossier-section {
  background: #fff;
  border-radius: 8px;
  padding: 1rem 1.25rem;
  margin-bottom: 1.25rem;
  border: 1px solid #ddd;
}

.dossier-documents-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.dossier-document-item {
  padding: 0.4rem 0;
  border-bottom: 1px solid #eee;
}

.dossier-document-item:last-child {
  border-bottom: none;
}

.dossier-documents-list--admin .dossier-document-item--admin strong {
  font-weight: 600;
}

.dossier-documents-list--client .dossier-document-item--client strong {
  font-weight: 600;
}

.dossier-documents-list--admin {
  border-left: 3px solid #3a5ba7;
  padding-left: 0.75rem;
  margin-bottom: 1rem;
}

.dossier-documents-list--client {
  border-left: 3px solid #888;
  padding-left: 0.75rem;
}

.dossier-documents-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.dossier-document-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.6rem 0;
  border-bottom: 1px solid #eee;
}

.dossier-document-item:last-child {
  border-bottom: none;
}

.dossier-document-icon {
  font-size: 1.4rem;
  line-height: 1;
  margin-top: 0.15rem;
}

.dossier-document-icon--admin {
  /* couleur Portail-Urbanisme */
  color: #666;
}

.dossier-document-icon--client {
  opacity: 0.8;
}

.dossier-document-content {
  flex: 1;
}

.dossier-document-title-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.dossier-document-meta {
  font-size: 0.8rem;
  color: #666;
  margin: 0.15rem 0 0.35rem;
}

.doc-badge {
  display: inline-block;
  padding: 0.1rem 0.4rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 600;
}

.doc-badge--new {
  background: #ffeeba;
  color: #8a6d3b;
}

/* Petit bouton plus compact */
.btn-sm {
  padding: 0.3rem 0.6rem;
  font-size: 0.8rem;
}

/* Bouton Mon compte */

.menu-item-mon-compte a.btn-mon-compte {
    background-color: #3A5BA7;
    color: #ffffff;
    padding: 10px 18px;
    border-radius: 8px;
    border: none;
    font-weight: 600;
    font-size: 15px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
    transition: background-color 0.25s ease, transform 0.15s ease;
    text-decoration: none;
}

.menu-item-mon-compte a.btn-mon-compte:hover {
    background-color: #466ABC;
    transform: translateY(-1px);
}

.menu-item-mon-compte a.btn-mon-compte:active {
    transform: translateY(0);
}

.menu-item-mon-compte a.btn-mon-compte {
    color: #ffffff !important;
padding: 10px 18px !important;

}



/* Fin bouton mon compte */

/* Page Mon compte */

.portail-mon-compte {
  max-width: 480px;
  margin: 2rem auto;
  padding: 1.5rem;
  background: #f7f7f7;
  border-radius: 8px;
}

.portail-mon-compte h2 {
  margin-top: 0;
}

.portail-mon-compte__actions {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0;
}

.portail-mon-compte__actions li {
  margin-bottom: 0.6rem;
}

.portail-mon-compte {
  max-width: 640px;
  margin: 2rem auto;
  padding: 1.5rem;
  background: #f7f7f7;
  border-radius: 8px;
}

.portail-mon-compte h2 {
  margin-top: 0;
}

.portail-profile-form fieldset {
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 1rem 1.2rem;
  margin-bottom: 1rem;
}

.portail-profile-form legend {
  padding: 0 0.4rem;
  font-weight: 600;
}

.portail-profile-form input[type="text"],
.portail-profile-form input[type="email"],
.portail-profile-form input[type="password"] {
  width: 100%;
  max-width: 100%;
  padding: 0.35rem 0.5rem;
  border-radius: 4px;
  border: 1px solid #ccc;
}

.portail-alert {
  padding: 0.6rem 0.8rem;
  border-radius: 4px;
  margin-bottom: 1rem;
  font-size: 0.9rem;
}

.portail-alert--success {
  background: #d4edda;
  color: #155724;
}

.portail-alert--error {
  background: #f8d7da;
  color: #721c24;
}
.portail-mon-compte {
  max-width: 800px;
  margin: 2rem auto;
  padding: 1.5rem;
  background: #f7f7f7;
  border-radius: 8px;
}

.portail-mon-compte h2 {
  margin-top: 0;
}

.portail-mon-compte__header-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 1rem;
}

.portail-section {
  background: #fff;
  border-radius: 8px;
  padding: 1rem 1.25rem;
  margin-bottom: 1rem;
  border: 1px solid #ddd;
}

.portail-infos-list {
  margin: 0;
  padding: 0;
}

.portail-infos-list > div {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.3rem 0;
  border-bottom: 1px solid #eee;
}

.portail-infos-list > div:last-child {
  border-bottom: none;
}

.portail-infos-list dt {
  font-weight: 600;
}

.portail-infos-list dd {
  margin: 0;
  text-align: right;
}

.portail-infos-missing {
  color: #999;
}

.portail-alert {
  padding: 0.6rem 0.8rem;
  border-radius: 4px;
  margin-bottom: 1rem;
  font-size: 0.9rem;
}

.portail-alert--success {
  background: #d4edda;
  color: #155724;
}

.portail-alert--error {
  background: #f8d7da;
  color: #721c24;
}

/* Mini résumé dossiers */
.portail-dossiers-mini-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.8rem;
}

.mini-dossier-card {
  background: #f9f9f9;
  border-radius: 6px;
  padding: 0.7rem 0.9rem;
  border: 1px solid #e1e1e1;
}

.mini-dossier-title {
  margin: 0 0 0.3rem;
  font-size: 0.95rem;
}

.mini-dossier-meta {
  margin: 0;
  font-size: 0.8rem;
  color: #666;
}

.mini-dossier-statut {
  margin: 0.4rem 0 0.5rem;
  font-size: 0.85rem;
}

.portail-mon-compte__logout {
  text-align: right;
  font-size: 0.85rem;
}

/* Timeline horizontale du dossier */
.dossier-section--timeline {
  margin-bottom: 1.5rem;
}

.dossier-timeline {
  list-style: none;
  margin: 0.8rem 0 0.4rem;
  padding: 0;
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  position: relative;
}

/* Ligne centrale derrière les bullets */
.dossier-timeline::before {
  content: "";
  position: absolute;
  top: 18px; /* aligné avec le centre des bullets */
  left: 0;
  right: 0;
  height: 2px;
  background: #e0e0e0;
  z-index: 0;
}

.dossier-timeline__step {
  position: relative;
  z-index: 1;
  flex: 1;
  text-align: center;
  font-size: 0.8rem;
}

.dossier-timeline__bullet {
  width: 16px;
  height: 16px;
  margin: 0 auto 0.2rem;
  border-radius: 50%;
  border: 2px solid #ccc;
  background: #fff;
}

.dossier-timeline__label {
  font-weight: 500;
  margin-bottom: 0.1rem;
}

.dossier-timeline__date {
  font-size: 0.75rem;
  color: #666;
}

/* Étape accomplie */
.dossier-timeline__step--done .dossier-timeline__bullet {
  background: #3a5ba7;
  border-color: #3a5ba7;
}

.dossier-timeline__step--done .dossier-timeline__label {
  color: #3a5ba7;
}

/* Étape actuelle */
.dossier-timeline__step--current .dossier-timeline__bullet {
  background: #fff;
  border-color: #3a5ba7;
  box-shadow: 0 0 0 3px rgba(58, 91, 167, 0.2);
}

.dossier-timeline__step--current .dossier-timeline__label {
  color: #3a5ba7;
}

/* Étape à venir */
.dossier-timeline__step--upcoming .dossier-timeline__bullet {
  background: #fff;
  border-color: #ddd;
}

.dossier-timeline__step--upcoming .dossier-timeline__label {
  color: #999;
}

.dossier-timeline__note {
  font-size: 0.8rem;
  color: #666;
  margin-top: 0.4rem;
}

/* Refusé — rouge */
.dossier-timeline__step--refuse .dossier-timeline__bullet {
  background: #ff4d4f;
  border-color: #ff4d4f;
}

.dossier-timeline__step--refuse .dossier-timeline__label {
  color: #ff4d4f;
}

.dossier-timeline__step--refuse .dossier-timeline__date {
  color: #b20000;
}

/* Validé — vert */
.dossier-timeline__step--valide .dossier-timeline__bullet {
  background: #4caf50;
  border-color: #4caf50;
}

.dossier-timeline__step--valide .dossier-timeline__label {
  color: #4caf50;
}

.dossier-timeline__step--valide .dossier-timeline__date {
  color: #2e7d32;
}

.dossier-timeline__explanation {
  font-size: 0.9rem;
  color: #555;
  margin-top: 0.5rem;
}

/* Fin Page Mon compte */


/* ===========================
   FIN ESPACE CLIENT
   =========================== */

/* =========== HEADER GLOBAL =========== */

.site-header {
  position: relative;
  z-index: 100;
  background: #ffffff;
  border-bottom: 1px solid #e5e7eb;
}

.header-container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0.75rem 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.site-logo a {
  display: flex;
  align-items: center;
  text-decoration: none;
}
