/*
Theme Name:  DENIS-TOL Prestations Services
Theme URI:   https://denistol.com
Author:      KeMObi Services SARLU — Lazare OBINOKO
Author URI:  https://kemobiservices.com
Description: Thème officiel DENIS-TOL Prestations Services. Développé par KeMObi Services SARLU. Palette Navy #0B1A3B + Gold #C8982A. Site public + Intranet intégré. 4 rôles : Fondateur, SG, Comptable, Employé.
Version:     2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
Text Domain: denis-tol
*/

/* ================================================================
   VARIABLES — PALETTE DENIS-TOL (inspiré KeMObi v31)
================================================================ */
:root {
  /* Palette DENIS-TOL */
  --navy:   #0B1A3B;
  --navy2:  #0E2154;
  --gold:   #C8982A;
  --gold2:  #E0B040;
  /* Adaptations Denis-TOL */
  --jaune:  #C8982A;   /* alias gold pour compat */
  --bleu:   #0B1A3B;   /* alias navy pour compat */
  --gray:   #F5F6FA;
  --text:   #1C2340;
  --text2:  #4A5272;
  --text3:  #8A91AE;
  --green:  #1E8A3A;
  --red:    #C0392B;
  --r:      8px;
  --r-lg:   14px;
  --ff:     'Montserrat', sans-serif;
  --sh:     0 4px 24px rgba(11,26,59,.10);
  --sh-lg:  0 12px 48px rgba(11,26,59,.18);
  --t:      all .25s cubic-bezier(.4,0,.2,1);
}

/* ================================================================
   RESET & BASE
================================================================ */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--ff);
  font-size: 15px;
  color: var(--text);
  background: #fff;
  line-height: 1.6;
  overflow-x: hidden;
}
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; transition:var(--t); }
ul { list-style:none; }
button { font-family:inherit; cursor:pointer; }
input,select,textarea { font-family:inherit; }
.wrap { max-width:1200px; margin:0 auto; padding:0 5%; }

/* ================================================================
   LOADER
================================================================ */
.dt-loader {
  position:fixed; inset:0; z-index:9999;
  background:var(--navy);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem;
  transition:opacity .4s ease;
}
.dt-loader.hidden { opacity:0; pointer-events:none; }
.dt-loader-logo {
  font-size:2rem; font-weight:800; color:#fff; letter-spacing:.1em;
}
.dt-loader-logo span { color:var(--gold); }
.dt-loader-bar {
  width:200px; height:3px; background:rgba(255,255,255,.15); border-radius:2px;
}
.dt-loader-fill {
  height:100%; width:0; background:var(--gold); border-radius:2px;
  animation: loaderFill 1.1s ease forwards;
}
@keyframes loaderFill { to { width:100%; } }
.dt-loader-sub {
  font-size:10px; font-weight:700; letter-spacing:.2em; text-transform:uppercase;
  color:rgba(255,255,255,.4);
}

/* ================================================================
   TOPBAR
================================================================ */
.dt-topbar {
  background: var(--navy);
  height: 40px;
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 5%;
  font-size: 11.5px;
  position: relative; z-index:600;
  border-bottom: 2px solid var(--gold);
}
.dt-tb-l { display:flex; align-items:center; gap:1.2rem; color:rgba(255,255,255,.65); }
.dt-tb-l a {
  color:rgba(255,255,255,.65);
  transition:color .2s;
  display:flex; align-items:center; gap:.35rem;
}
.dt-tb-l a:hover { color:var(--gold2); }
.dt-tb-sep { color:rgba(255,255,255,.18); }
.dt-tb-r { display:flex; align-items:center; gap:.6rem; }
.dt-tb-s {
  width:26px; height:26px; border-radius:50%;
  border:1px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.55); font-size:11px;
  transition:all .2s;
}
.dt-tb-s:hover { border-color:var(--gold); color:var(--gold); background:rgba(200,152,42,.1); }
.dt-btn-prive-discret {
  width:26px; height:26px; border-radius:50%;
  border:1px solid rgba(200,152,42,.4);
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:11px; cursor:pointer;
  transition:all .2s;
}
.dt-btn-prive-discret:hover { background:rgba(200,152,42,.15); }

/* ================================================================
   NAVBAR
================================================================ */
.dt-navbar {
  background: #fff;
  position: sticky; top:0; z-index:500;
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 3%;
  height: 68px;
  box-shadow: 0 2px 16px rgba(11,26,59,.08);
  border-bottom: 1px solid rgba(11,26,59,.06);
}
.dt-brand { display:flex; align-items:center; gap:12px; }
.dt-brand-icon {
  width:46px; height:46px; background:var(--gold); border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:16px; color:var(--navy);
}
.dt-brand-name { font-size:20px; font-weight:900; color:var(--gold); letter-spacing:.5px; }
.dt-brand-sub { font-size:10px; color:var(--navy); font-weight:700; letter-spacing:1.5px; text-transform:uppercase; }
.dt-nav-links { display:flex; align-items:center; gap:0; }
.dt-nav-links > li { position:relative; }
.dt-nav-links > li > a {
  display:block; padding:.55rem .72rem;
  font-size:12px; font-weight:600; color:var(--text2);
  border-bottom: 2.5px solid transparent;
  transition:color .2s, border-color .2s; white-space:nowrap;
}
.dt-nav-links > li > a:hover,
.dt-nav-links > li > a.active { color:var(--navy); border-bottom-color:var(--gold); }
.dt-nav-links > li > a.current { color:var(--navy); border-bottom-color:var(--gold); }
/* Dropdown */
.dt-dd {
  display:none; position:absolute; top:100%; left:0; min-width:230px;
  background:#fff; border:1px solid rgba(11,26,59,.08);
  border-top:2.5px solid var(--gold);
  box-shadow:0 8px 32px rgba(11,26,59,.12);
  border-radius:0 0 var(--r) var(--r); z-index:600;
}
.dt-nav-links li:hover .dt-dd { display:block; }
.dt-dd a {
  display:block; padding:.65rem 1.1rem;
  font-size:12.5px; color:var(--text2);
  border-bottom:.5px solid rgba(11,26,59,.05);
  transition:background .15s, color .15s, padding .15s;
}
.dt-dd a:last-child { border-bottom:none; }
.dt-dd a:hover { background:var(--gray); color:var(--navy); padding-left:1.4rem; }
.dt-nav-r { display:flex; align-items:center; gap:.5rem; flex-shrink:0; }
.dt-nav-cta {
  font-size:11px; font-weight:700; letter-spacing:.05em; text-transform:uppercase;
  color:#fff; background:var(--gold);
  padding:.55rem 1.1rem; border-radius:var(--r);
  transition:background .2s; display:flex; align-items:center; gap:.4rem;
}
.dt-nav-cta:hover { background:var(--navy); color:#fff; }
.dt-nav-tarifs {
  font-size:11px; font-weight:700;
  color:var(--navy); background:rgba(200,152,42,.1);
  border:1.5px solid var(--gold);
  padding:.5rem 1rem; border-radius:var(--r);
  transition:all .2s; display:flex; align-items:center; gap:.4rem;
}
.dt-nav-tarifs:hover { background:var(--gold); color:#fff; }
.dt-hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; padding:6px; background:none; border:none;
}
.dt-hamburger span {
  display:block; width:22px; height:2px;
  background:var(--navy); border-radius:2px; transition:all .3s;
}

/* ================================================================
   HERO
================================================================ */
.dt-hero {
  position:relative; min-height:88vh;
  display:flex; align-items:center; overflow:hidden;
  background:var(--navy);
}
.dt-hero-bg {
  position:absolute; inset:0;
  background:url('assets/images/hero-bg.jpg') center/cover;
  opacity:.18;
}
.dt-hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(11,26,59,.93) 50%,rgba(14,33,84,.72) 100%);
}
.dt-hero-dots {
  position:absolute; inset:0;
  background-image:radial-gradient(circle,rgba(200,152,42,.14) 1px,transparent 1px);
  background-size:38px 38px;
}
.dt-hero-inner {
  position:relative; z-index:2; padding:5rem 5%;
  max-width:1200px; margin:0 auto; width:100%;
  display:grid; grid-template-columns:1fr 380px; gap:4rem; align-items:center;
}
.dt-hero-label {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(200,152,42,.12); border:1px solid rgba(200,152,42,.3);
  color:var(--gold2); font-size:10.5px; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  padding:.35rem .9rem; border-radius:20px; margin-bottom:1.2rem;
}
.dt-hero-line { width:40px; height:2px; background:var(--gold); display:inline-block; vertical-align:middle; margin-right:.6rem; }
.dt-hero h1 {
  font-size:clamp(2rem,4vw,3.4rem); font-weight:800;
  color:#fff; line-height:1.1; margin-bottom:1rem;
}
.dt-hero h1 b { color:var(--gold); }
.dt-hero h1 span { font-weight:300; font-size:.48em; display:block; color:rgba(255,255,255,.65); letter-spacing:.06em; }
.dt-hero-desc { font-size:14.5px; color:rgba(255,255,255,.72); margin-bottom:2rem; line-height:1.85; max-width:540px; }
.dt-hero-btns { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.btn-gold {
  background:var(--gold); color:var(--navy);
  padding:.85rem 1.8rem; border-radius:var(--r);
  font-weight:700; font-size:13px;
  display:inline-flex; align-items:center; gap:.5rem;
  transition:background .2s, transform .2s;
}
.btn-gold:hover { background:var(--gold2); transform:translateY(-2px); color:var(--navy); }
.btn-outline {
  background:transparent; color:#fff;
  padding:.85rem 1.8rem; border-radius:var(--r);
  font-weight:700; font-size:13px;
  border:2px solid rgba(255,255,255,.28);
  transition:all .2s; display:inline-flex; align-items:center; gap:.5rem;
}
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.dt-hero-stats { display:flex; gap:2.5rem; }
.dt-hs-n { font-size:1.7rem; font-weight:800; color:var(--gold2); }
.dt-hs-l { font-size:10.5px; color:rgba(255,255,255,.5); font-weight:600; letter-spacing:.05em; text-transform:uppercase; margin-top:.1rem; }
/* Carte hero droite */
.dt-hero-card {
  background:rgba(255,255,255,.06); backdrop-filter:blur(14px);
  border:1px solid rgba(200,152,42,.2); border-radius:16px;
  padding:2rem; text-align:center;
}
.dt-hero-card-ico {
  width:80px; height:80px; background:var(--gold); border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; font-weight:900; color:var(--navy);
  margin:0 auto 1rem;
}
.dt-hero-card h3 { color:#fff; font-size:1rem; font-weight:700; margin-bottom:.3rem; }
.dt-hero-card p { color:rgba(255,255,255,.5); font-size:12px; margin-bottom:1.2rem; }
.dt-hci { display:flex; align-items:center; gap:.7rem; color:rgba(255,255,255,.75); font-size:12.5px; margin-bottom:.7rem; text-align:left; }
.dt-hci-icon {
  width:32px; height:32px; background:rgba(200,152,42,.15); border-radius:50%;
  display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:.9rem;
}
.dt-hero-card-btn {
  width:100%; margin-top:1rem;
  background:var(--gold); color:var(--navy);
  border:none; padding:.75rem; border-radius:var(--r);
  font-weight:800; font-size:13.5px;
  display:flex; align-items:center; justify-content:center; gap:.5rem;
  cursor:pointer; transition:background .2s;
}
.dt-hero-card-btn:hover { background:var(--gold2); }

/* ================================================================
   SECTIONS COMMUNES
================================================================ */
.dt-section { padding:5rem 0; }
.dt-section-bg { background:var(--gray); }
.dt-section-head { text-align:center; margin-bottom:3.5rem; }
.dt-s-badge {
  display:inline-block; font-size:10.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
  color:var(--gold); margin-bottom:.6rem;
}
.dt-s-title {
  font-size:clamp(1.5rem,3vw,2.1rem); font-weight:800; color:var(--navy); margin-bottom:.8rem;
}
.dt-s-title span { color:var(--gold); }
.dt-s-line {
  width:56px; height:4px; background:linear-gradient(90deg,var(--gold),var(--navy)); border-radius:2px; margin:14px auto 0;
}
.dt-s-desc { font-size:14.5px; color:var(--text2); max-width:600px; margin:.8rem auto 0; }

/* ================================================================
   SERVICES
================================================================ */
.dt-services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.5rem; }
.dt-svc-card {
  background:#fff; border-radius:var(--r-lg); padding:1.8rem 1.5rem;
  box-shadow:var(--sh); border:1px solid rgba(11,26,59,.06);
  border-top:3px solid var(--gold);
  transition:transform .2s, box-shadow .2s; position:relative; overflow:hidden;
}
.dt-svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--gold),var(--navy));
  transform:scaleX(0); transform-origin:left; transition:var(--t);
}
.dt-svc-card:hover::before { transform:scaleX(1); }
.dt-svc-card:hover { transform:translateY(-5px); box-shadow:var(--sh-lg); }
.dt-svc-icon {
  width:56px; height:56px;
  background:linear-gradient(135deg,rgba(200,152,42,.14),rgba(11,26,59,.08));
  border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-size:24px; margin-bottom:1rem; transition:var(--t);
}
.dt-svc-card:hover .dt-svc-icon { background:var(--gold); }
.dt-svc-card h3 { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:.6rem; }
.dt-svc-card p { font-size:13px; color:var(--text2); line-height:1.75; margin-bottom:1rem; }
.dt-svc-link { color:var(--gold); font-weight:700; font-size:12.5px; display:inline-flex; align-items:center; gap:.3rem; }
.dt-svc-link:hover { color:var(--navy); }

/* ================================================================
   PUBLICATIONS — Onglets
================================================================ */
.dt-pub-tabs { display:flex; gap:.5rem; justify-content:center; flex-wrap:wrap; margin-bottom:2.5rem; }
.dt-ptab {
  padding:.55rem 1.4rem; border-radius:20px; font-size:13px; font-weight:700;
  border:2px solid rgba(11,26,59,.12); background:#fff; color:var(--text2);
  cursor:pointer; transition:var(--t); font-family:var(--ff);
}
.dt-ptab.active, .dt-ptab:hover { background:var(--gold); color:var(--navy); border-color:var(--gold); }
.dt-pub-panel { display:none; }
.dt-pub-panel.active { display:block; }
.dt-pub-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(290px,1fr)); gap:1.5rem; }
.dt-pub-card { background:#fff; border-radius:var(--r-lg); box-shadow:var(--sh); overflow:hidden; transition:var(--t); }
.dt-pub-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); }
.dt-pub-thumb {
  height:165px; background:linear-gradient(135deg,var(--navy),var(--navy2));
  display:flex; align-items:center; justify-content:center; font-size:48px;
  position:relative; overflow:hidden;
}
.dt-pub-thumb img { width:100%; height:100%; object-fit:cover; position:absolute; top:0; left:0; }
.dt-pub-type {
  position:absolute; top:12px; left:12px;
  background:var(--gold); color:var(--navy);
  font-size:10px; font-weight:800; padding:3px 10px; border-radius:12px;
  letter-spacing:.5px; text-transform:uppercase; z-index:1;
}
.dt-pub-body { padding:1.2rem; }
.dt-pub-body h3 { font-size:15px; font-weight:700; color:var(--navy); margin-bottom:.5rem; }
.dt-pub-body p { font-size:13px; color:var(--text2); line-height:1.6; margin-bottom:.8rem; }
.dt-pub-meta { display:flex; justify-content:space-between; align-items:center; }
.dt-pub-date { font-size:11px; color:var(--text3); }
.dt-pub-lire { color:var(--gold); font-weight:700; font-size:12px; }
.dt-pub-lire:hover { color:var(--navy); }
.dt-empty-pub { text-align:center; padding:4rem; color:var(--text2); }
.dt-empty-pub .ep-icon { font-size:3rem; margin-bottom:.75rem; }

/* ================================================================
   TARIFS
================================================================ */
.dt-tarifs-intro {
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:var(--r-lg); padding:2.2rem; color:#fff; text-align:center; margin-bottom:2.5rem;
  border:1px solid rgba(200,152,42,.25);
}
.dt-tarifs-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1.2rem; }
.dt-tarif-card {
  background:#fff; border-radius:var(--r-lg); padding:1.6rem;
  box-shadow:var(--sh); text-align:center;
  border:1px solid rgba(11,26,59,.06); border-top:3px solid var(--gold);
  transition:var(--t);
}
.dt-tarif-card:hover { border-color:var(--gold); transform:translateY(-3px); box-shadow:var(--sh-lg); }
.dt-tarif-ico { font-size:1.8rem; margin-bottom:.7rem; }
.dt-tarif-nom { font-size:14px; font-weight:700; color:var(--navy); margin-bottom:.5rem; }
.dt-tarif-prix { font-size:1.25rem; font-weight:800; color:var(--gold); margin-bottom:.5rem; }
.dt-tarif-note { font-size:11.5px; color:var(--text2); margin-bottom:.8rem; }
.dt-btn-negocier {
  display:inline-flex; align-items:center; gap:.4rem;
  background:var(--gold); color:var(--navy);
  padding:.5rem 1.1rem; border-radius:var(--r);
  font-size:12px; font-weight:700; border:none; cursor:pointer;
  transition:background .2s; font-family:var(--ff);
}
.dt-btn-negocier:hover { background:var(--navy); color:#fff; }

/* ================================================================
   PROPOSER
================================================================ */
.dt-prop-grid { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; }
.dt-prop-item {
  display:flex; align-items:center; gap:.8rem;
  padding:.9rem 1rem; background:#fff; border-radius:var(--r);
  box-shadow:var(--sh); border-left:4px solid var(--gold);
  margin-bottom:.8rem;
}
.dt-prop-ico { font-size:1.3rem; flex-shrink:0; }
.dt-prop-t { font-size:13px; font-weight:700; color:var(--navy); }
.dt-prop-s { font-size:11.5px; color:var(--text3); }

/* ================================================================
   FORMULAIRES
================================================================ */
.dt-form-box {
  background:#fff; border-radius:var(--r-lg); padding:2.2rem;
  box-shadow:var(--sh); border:1px solid rgba(11,26,59,.06);
}
.dt-form-box h3 { font-size:1.1rem; font-weight:700; color:var(--navy); margin-bottom:1.4rem; }
.dt-fg { margin-bottom:1rem; }
.dt-fg label {
  display:block; font-size:10.5px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  color:var(--text3); margin-bottom:.35rem;
}
.dt-fc {
  width:100%; padding:.72rem 1rem;
  border:1.5px solid rgba(11,26,59,.12);
  border-radius:var(--r); font-size:13.5px;
  font-family:var(--ff); background:#fff; color:var(--text);
  transition:border-color .2s;
}
.dt-fc:focus { outline:none; border-color:var(--gold); }
.dt-fr { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.dt-btn-submit {
  width:100%; padding:.9rem;
  background:var(--gold); color:var(--navy);
  border:none; border-radius:var(--r);
  font-size:14px; font-weight:700; font-family:var(--ff);
  cursor:pointer; transition:background .2s;
  display:flex; align-items:center; justify-content:center; gap:.5rem;
}
.dt-btn-submit:hover { background:var(--gold2); }
.dt-form-msg {
  display:flex; align-items:center; gap:.5rem;
  padding:.75rem 1rem; border-radius:var(--r);
  font-size:13.5px; font-weight:600; margin-bottom:1rem;
}
.dt-form-msg.ok { background:rgba(30,138,58,.1); color:var(--green); border:1px solid rgba(30,138,58,.2); }
.dt-form-msg.err { background:rgba(192,57,43,.1); color:var(--red); border:1px solid rgba(192,57,43,.2); }

/* ================================================================
   POURQUOI NOUS
================================================================ */
.dt-pourquoi-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:start; }
.dt-pq-item {
  display:flex; align-items:flex-start; gap:1rem;
  margin-bottom:1.4rem;
}
.dt-pq-num {
  width:38px; height:38px; border-radius:50%;
  background:var(--gold); color:var(--navy);
  font-size:.9rem; font-weight:800;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.dt-pq-item h4 { font-size:14.5px; font-weight:700; color:var(--navy); margin-bottom:.25rem; }
.dt-pq-item p { font-size:13px; color:var(--text2); line-height:1.7; }
.dt-pq-visual {
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:16px; padding:2.5rem; text-align:center;
  border:1px solid rgba(200,152,42,.2);
}
.dt-pq-slogan { font-size:2rem; font-weight:800; color:rgba(255,255,255,.5); line-height:1.3; margin-bottom:2rem; }
.dt-pq-slogan span { color:var(--gold2); }
.dt-pq-stats { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.dt-pq-stat .v { font-size:1.6rem; font-weight:800; color:var(--gold2); }
.dt-pq-stat .l { font-size:10.5px; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:.06em; margin-top:.15rem; }

/* ================================================================
   FONDATEUR
================================================================ */
.dt-fondateur-grid { display:grid; grid-template-columns:300px 1fr; gap:4rem; align-items:start; }
.dt-f-card {
  background:#fff; border-radius:16px; box-shadow:var(--sh);
  overflow:hidden; border:1px solid rgba(11,26,59,.06);
}
.dt-f-photo {
  width:100%; aspect-ratio:3/4; overflow:hidden;
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  display:flex; align-items:center; justify-content:center;
  font-size:5rem;
}
.dt-f-photo img { width:100%; height:100%; object-fit:cover; }
.dt-f-info { padding:1.4rem; }
.dt-f-info h3 { font-size:1rem; font-weight:800; color:var(--navy); margin-bottom:.2rem; }
.dt-f-role { font-size:11.5px; color:var(--gold); font-weight:600; margin-bottom:1rem; }
.dt-f-contacts { display:flex; flex-direction:column; gap:.5rem; }
.dt-f-contact-item {
  display:flex; align-items:center; gap:.5rem;
  font-size:12px; color:var(--text2);
  padding:.4rem .6rem; background:var(--gray); border-radius:var(--r);
}
.dt-f-contact-item:hover { color:var(--gold); }
.dt-f-content h2 { font-size:1.6rem; font-weight:800; color:var(--navy); margin-bottom:.3rem; }
.dt-f-subtitle { color:var(--gold); font-weight:600; font-size:13.5px; margin-bottom:1.5rem; }
.dt-f-content p { font-size:13.5px; color:var(--text2); line-height:1.85; margin-bottom:.9rem; }
.dt-f-expertises { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.5rem; }
.dt-f-exp {
  background:rgba(200,152,42,.08); border:1px solid rgba(200,152,42,.2);
  color:var(--gold); font-size:11px; font-weight:600;
  padding:.3rem .8rem; border-radius:20px;
}
.dt-f-vision {
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  color:rgba(255,255,255,.82); border-radius:10px;
  padding:1.5rem; margin-top:1.5rem;
  font-style:italic; font-size:13.5px; line-height:1.85;
  border-left:4px solid var(--gold);
}

/* ================================================================
   CONTACT
================================================================ */
.dt-contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:start; }
.dt-ci { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.4rem; }
.dt-ci-icon {
  width:44px; height:44px; background:rgba(200,152,42,.1); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; color:var(--gold); flex-shrink:0;
}
.dt-ci h4 { font-weight:700; font-size:13px; color:var(--navy); }
.dt-ci p, .dt-ci a { font-size:13px; color:var(--text2); margin-top:.2rem; }
.dt-ci a:hover { color:var(--gold); }
.dt-soc-btns { display:flex; gap:.8rem; margin-top:1.5rem; }
.dt-soc-btn {
  width:42px; height:42px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1rem; color:#fff; transition:transform .2s, opacity .2s;
}
.dt-soc-btn:nth-child(1) { background:#1877F2; }
.dt-soc-btn:nth-child(2) { background:#25D366; }
.dt-soc-btn:nth-child(3) { background:#C8982A; }
.dt-soc-btn:hover { transform:translateY(-3px); opacity:.9; }

/* ================================================================
   FOOTER
================================================================ */
.dt-footer {
  background:var(--navy); color:rgba(255,255,255,.7);
  padding:3.5rem 5% 1.5rem;
}
.dt-footer-slogan {
  background:var(--gold); color:var(--navy);
  text-align:center; padding:.5rem;
  font-size:11px; font-weight:800; letter-spacing:.2em;
}
.dt-footer-main {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:2rem; margin-bottom:2.5rem; margin-top:2rem;
}
.dt-fc-brand h3 { color:#fff; font-size:1.05rem; font-weight:800; margin-bottom:.5rem; }
.dt-fc-brand h3 b { color:var(--gold); }
.dt-fc-brand p { font-size:12.5px; line-height:1.75; margin-bottom:1rem; }
.dt-fc-col h4 {
  color:#fff; font-size:11.5px; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase; margin-bottom:1rem;
}
.dt-fc-col a { display:block; font-size:12.5px; color:rgba(255,255,255,.6); margin-bottom:.4rem; }
.dt-fc-col a:hover { color:var(--gold); }
.dt-fc-ci { display:flex; align-items:flex-start; gap:.5rem; font-size:12.5px; margin-bottom:.5rem; }
.dt-fc-ci .icon { color:var(--gold); flex-shrink:0; width:16px; margin-top:.15rem; }
.dt-ft-socials { display:flex; gap:.6rem; margin-top:1rem; }
.dt-ft-socials a {
  width:32px; height:32px; border-radius:50%;
  background:rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; color:rgba(255,255,255,.6);
  transition:all .2s;
}
.dt-ft-socials a:hover { background:var(--gold); color:var(--navy); }
.dt-footer-bot {
  display:flex; align-items:center; justify-content:space-between;
  padding-top:1.5rem; border-top:1px solid rgba(255,255,255,.08);
  font-size:12px; color:rgba(255,255,255,.35); flex-wrap:wrap; gap:.5rem;
}

/* ================================================================
   FLOTTANTS
================================================================ */
.dt-wa-float {
  position:fixed; bottom:2rem; right:2rem; z-index:400;
  width:54px; height:54px; background:#25D366; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; color:#fff;
  box-shadow:0 4px 16px rgba(37,211,102,.4);
  transition:transform .2s, box-shadow .2s;
}
.dt-wa-float:hover { transform:scale(1.1); box-shadow:0 8px 24px rgba(37,211,102,.5); }
.dt-scroll-top {
  position:fixed; bottom:6rem; right:2rem; z-index:400;
  width:40px; height:40px; background:var(--navy); border:2px solid var(--gold);
  border-radius:50%; color:var(--gold); font-size:.9rem;
  cursor:pointer; display:none; align-items:center; justify-content:center;
  transition:all .2s;
}
.dt-scroll-top.show { display:flex; }
.dt-scroll-top:hover { background:var(--gold); color:var(--navy); }

/* ================================================================
   INTRANET
================================================================ */
.dt-intranet-wrap {
  display:none; position:fixed; inset:0; z-index:1000;
  background:var(--gray);
  flex-direction:row;
}
.dt-intranet-wrap.open { display:flex; }
/* Sidebar */
.dt-in-sidebar {
  width:240px; flex-shrink:0;
  background:var(--navy);
  display:flex; flex-direction:column;
  overflow-y:auto;
}
.dt-in-sb-hd {
  padding:1.4rem 1.2rem;
  border-bottom:1px solid rgba(255,255,255,.08);
  display:flex; align-items:center; gap:.8rem;
}
.dt-in-sb-ico {
  width:38px; height:38px; background:var(--gold); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:900; color:var(--navy); flex-shrink:0;
}
.dt-in-sb-nm { font-size:14px; font-weight:800; color:#fff; }
.dt-in-sb-sub { font-size:10px; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.1em; }
.dt-in-nav { padding:.8rem 0; flex:1; }
.dt-in-sec { font-size:9.5px; font-weight:700; letter-spacing:.15em; text-transform:uppercase; color:rgba(255,255,255,.28); padding:.5rem 1.2rem .3rem; }
.dt-in-lnk {
  display:flex; align-items:center; gap:.7rem;
  width:100%; padding:.6rem 1.2rem;
  font-size:13px; font-weight:600; color:rgba(255,255,255,.65);
  background:none; border:none; text-align:left; cursor:pointer;
  font-family:var(--ff); transition:background .15s, color .15s;
}
.dt-in-lnk:hover, .dt-in-lnk.active { background:rgba(200,152,42,.12); color:var(--gold2); }
.dt-in-badge {
  background:var(--red); color:#fff;
  font-size:10px; font-weight:700;
  padding:.15rem .45rem; border-radius:10px; margin-left:auto;
}
/* Topbar intranet */
.dt-in-tb {
  height:56px; background:#fff;
  border-bottom:1px solid rgba(11,26,59,.08);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 1.5rem; flex-shrink:0;
}
.dt-in-tb-center { display:flex; align-items:center; gap:.8rem; }
.dt-role-badge {
  font-size:11px; font-weight:800;
  padding:.3rem .8rem; border-radius:12px;
}
.dt-in-username { font-size:13px; font-weight:600; color:var(--text2); }
.dt-in-dot { width:8px; height:8px; background:var(--green); border-radius:50%; }
.dt-in-tb-right { display:flex; align-items:center; gap:.6rem; }
.dt-btn-site {
  font-size:12px; font-weight:600; color:var(--text2);
  background:none; border:1px solid rgba(11,26,59,.12);
  padding:.35rem .9rem; border-radius:var(--r); cursor:pointer;
  display:flex; align-items:center; gap:.4rem; font-family:var(--ff);
  transition:all .2s;
}
.dt-btn-site:hover { border-color:var(--gold); color:var(--gold); }
.dt-btn-deco {
  font-size:12px; font-weight:700; color:var(--red);
  background:rgba(192,57,43,.08); border:1px solid rgba(192,57,43,.2);
  padding:.35rem .9rem; border-radius:var(--r);
  transition:all .2s;
}
.dt-btn-deco:hover { background:var(--red); color:#fff; }
/* Main content */
.dt-in-main { flex:1; display:flex; flex-direction:column; min-width:0; }
.dt-in-content { flex:1; overflow-y:auto; padding:1.5rem; }
/* Pages */
.dt-in-page { display:none; }
.dt-in-page.active { display:block; }
.dt-pg-title { font-size:1.2rem; font-weight:800; color:var(--navy); margin-bottom:.25rem; }
.dt-pg-sub { font-size:13px; color:var(--text2); margin-bottom:1.5rem; }
/* KPI cards */
.dt-kpi-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1rem; margin-bottom:1.5rem; }
.dt-kpi {
  background:#fff; border-radius:var(--r); padding:1.2rem;
  box-shadow:var(--sh); border-left:4px solid var(--gold);
}
.dt-kpi .kn { font-size:1.6rem; font-weight:800; color:var(--navy); }
.dt-kpi .kl { font-size:12px; color:var(--text2); margin-top:.15rem; }
/* Tables */
.dt-table-wrap { background:#fff; border-radius:var(--r); box-shadow:var(--sh); overflow:hidden; margin-bottom:1.5rem; }
.dt-th { display:flex; align-items:center; justify-content:space-between; padding:1rem 1.2rem; border-bottom:1px solid rgba(11,26,59,.06); }
.dt-th-t { font-size:14px; font-weight:700; color:var(--navy); }
.dt-tbl { width:100%; border-collapse:collapse; }
.dt-tbl th { font-size:11px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--text3); padding:.7rem 1rem; text-align:left; border-bottom:1px solid rgba(11,26,59,.06); background:var(--gray); }
.dt-tbl td { font-size:13px; color:var(--text2); padding:.8rem 1rem; border-bottom:.5px solid rgba(11,26,59,.04); }
.dt-tbl tr:last-child td { border-bottom:none; }
.dt-tbl tr:hover td { background:rgba(200,152,42,.03); }
/* Badges status */
.dt-st {
  font-size:10.5px; font-weight:700; padding:.2rem .6rem; border-radius:12px;
}
.dt-st-new { background:rgba(30,138,58,.1); color:var(--green); }
.dt-st-prog { background:rgba(230,126,34,.1); color:#E67E22; }
.dt-st-done { background:rgba(11,26,59,.1); color:var(--navy); }
.dt-st-rej { background:rgba(192,57,43,.1); color:var(--red); }
/* Btn gold sm */
.dt-btn-sm {
  font-size:12px; font-weight:700;
  background:var(--gold); color:var(--navy);
  border:none; padding:.4rem .9rem; border-radius:var(--r);
  cursor:pointer; font-family:var(--ff); transition:background .2s;
}
.dt-btn-sm:hover { background:var(--gold2); }
.dt-btn-sm.navy { background:var(--navy); color:#fff; }
.dt-btn-sm.navy:hover { background:var(--navy2); }
/* Forms intranet */
.dt-if { margin-bottom:.9rem; }
.dt-if label { display:block; font-size:10.5px; font-weight:700; color:var(--text3); letter-spacing:.08em; text-transform:uppercase; margin-bottom:.3rem; }
.dt-if input, .dt-if select, .dt-if textarea {
  width:100%; padding:.65rem .9rem;
  border:1.5px solid rgba(11,26,59,.12); border-radius:var(--r);
  font-size:13.5px; font-family:var(--ff); background:#fff; color:var(--text);
  transition:border-color .2s;
}
.dt-if input:focus, .dt-if select:focus, .dt-if textarea:focus { outline:none; border-color:var(--gold); }
.dt-if-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.dt-lock { text-align:center; padding:3rem; color:var(--red); }
.dt-lock i { font-size:2.5rem; margin-bottom:.7rem; }
.dt-lock p { font-size:13.5px; color:var(--text2); }
.dt-loading-state { text-align:center; padding:2.5rem; color:var(--text3); font-size:13px; }

/* ================================================================
   ANIMATIONS
================================================================ */
.dt-fade-up { animation:fadeUp .7s ease both; }
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ================================================================
   RESPONSIVE
================================================================ */
@media (max-width:1024px) {
  .dt-footer-main { grid-template-columns:1fr 1fr; }
  .dt-fondateur-grid { grid-template-columns:260px 1fr; gap:2.5rem; }
}
@media (max-width:768px) {
  .dt-topbar { display:none; }
  .dt-navbar { padding:0 4%; height:60px; }
  .dt-nav-links { display:none; flex-direction:column; position:absolute; top:60px; left:0; right:0; background:#fff; box-shadow:0 8px 24px rgba(11,26,59,.12); padding:1rem; gap:.2rem; }
  .dt-nav-links.open { display:flex; }
  .dt-nav-links > li > a { padding:.7rem .8rem; border-bottom:none; border-radius:var(--r); }
  .dt-nav-r { display:none; }
  .dt-nav-r.open { display:flex; padding:.5rem 1rem 1rem; }
  .dt-hamburger { display:flex; }
  .dt-hero-inner { grid-template-columns:1fr; }
  .dt-hero-card { display:none; }
  .dt-hero-stats { gap:1.5rem; }
  .dt-fondateur-grid { grid-template-columns:1fr; }
  .dt-f-card { display:grid; grid-template-columns:140px 1fr; }
  .dt-f-photo { aspect-ratio:unset; min-height:180px; }
  .dt-pourquoi-grid { grid-template-columns:1fr; }
  .dt-contact-grid { grid-template-columns:1fr; }
  .dt-prop-grid { grid-template-columns:1fr; }
  .dt-fr { grid-template-columns:1fr; }
  .dt-footer-main { grid-template-columns:1fr 1fr; }
  .dt-in-sidebar { width:200px; }
}
@media (max-width:480px) {
  .dt-hero h1 { font-size:2rem; }
  .dt-hero-stats { gap:1rem; }
  .dt-footer-main { grid-template-columns:1fr; }
  .dt-in-sidebar { display:none; }
  .dt-in-sidebar.open { display:flex; position:fixed; inset:0; z-index:2000; width:240px; }
}

/* ================================================================
   INTRANET COMPLÉMENTAIRE
================================================================ */
.dt-in-title { font-size:1.25rem; font-weight:800; color:var(--navy); margin-bottom:.2rem; }
.dt-in-desc { font-size:13px; color:var(--text2); margin-bottom:1.5rem; }
.dt-ig2 { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
@media(max-width:768px){ .dt-ig2{grid-template-columns:1fr;} }

/* Cards intranet */
.dt-i-card {
  background:#fff; border-radius:var(--r); box-shadow:var(--sh);
  margin-bottom:1rem; overflow:hidden;
}
.dt-i-card-hd {
  display:flex; align-items:center; justify-content:space-between;
  padding:.9rem 1.2rem; border-bottom:1px solid rgba(11,26,59,.06);
}
.dt-i-card-title { font-size:13.5px; font-weight:700; color:var(--navy); }
.dt-i-card-body { padding:1.2rem; }
.dt-i-card-body.np { padding:0; }

/* Tabs intranet */
.dt-i-tabs { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:1rem; }
.dt-i-tab {
  padding:.4rem 1rem; border-radius:20px; font-size:12.5px; font-weight:600;
  border:1.5px solid rgba(11,26,59,.12); background:#fff; color:var(--text2);
  cursor:pointer; font-family:var(--ff); transition:all .2s;
}
.dt-i-tab.active, .dt-i-tab:hover { background:var(--gold); color:var(--navy); border-color:var(--gold); }

/* Tableaux */
.dt-i-table { width:100%; border-collapse:collapse; font-size:13px; }
.dt-i-table th {
  font-size:10.5px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  color:var(--text3); padding:.65rem 1rem; text-align:left;
  border-bottom:1px solid rgba(11,26,59,.06); background:var(--gray);
}
.dt-i-table td { padding:.75rem 1rem; border-bottom:.5px solid rgba(11,26,59,.04); vertical-align:middle; }
.dt-i-table tr:last-child td { border-bottom:none; }
.dt-i-table tr:hover td { background:rgba(200,152,42,.03); }

/* Status badges */
.dt-sb { font-size:10.5px; font-weight:700; padding:.2rem .6rem; border-radius:10px; white-space:nowrap; }
.dt-sb.at { background:rgba(230,126,34,.12); color:#E67E22; }
.dt-sb.ap { background:rgba(30,138,58,.12); color:var(--green); }
.dt-sb.rf { background:rgba(192,57,43,.12); color:var(--red); }
.dt-sb.nv { background:rgba(200,152,42,.12); color:var(--gold); }
.dt-sb.pr { background:rgba(11,26,59,.1); color:var(--navy); }

/* Boutons intranet */
.dt-ib {
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.4rem .9rem; border-radius:var(--r);
  font-size:12px; font-weight:700; border:none; cursor:pointer;
  font-family:var(--ff); transition:all .2s; text-decoration:none;
}
.dt-ib.pr { background:var(--gold); color:var(--navy); }
.dt-ib.pr:hover { background:var(--gold2); }
.dt-ib.ok { background:rgba(30,138,58,.1); color:var(--green); border:1px solid rgba(30,138,58,.2); }
.dt-ib.ok:hover { background:var(--green); color:#fff; }
.dt-ib.dg { background:rgba(192,57,43,.1); color:var(--red); border:1px solid rgba(192,57,43,.2); }
.dt-ib.dg:hover { background:var(--red); color:#fff; }
.dt-ib.sm { padding:.3rem .7rem; font-size:11px; }
.dt-ib.ico { padding:.3rem .5rem; }

/* KPI row */
.dt-kpi-row { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:1rem; margin-bottom:1.5rem; }
.dt-kpi { background:#fff; border-radius:var(--r); padding:1.1rem 1.2rem; box-shadow:var(--sh); border-left:4px solid var(--gold); }
.dt-kpi.bl { border-left-color:#3b82f6; }
.dt-kpi.gr { border-left-color:var(--green); }
.dt-kpi.ye { border-left-color:var(--gold); }
.dt-kpi.pu { border-left-color:#8b5cf6; }
.dt-kpi.rd { border-left-color:var(--red); }
.dt-kpi-val { font-size:1.5rem; font-weight:800; color:var(--navy); }
.dt-kpi-lbl { font-size:12px; color:var(--text2); margin-top:.15rem; }

/* Alerts */
.dt-if-alert {
  display:flex; align-items:flex-start; gap:.5rem;
  padding:.7rem 1rem; border-radius:var(--r);
  font-size:12.5px; margin-bottom:.8rem;
}
.dt-if-alert.info { background:rgba(59,130,246,.08); color:#3b82f6; border:1px solid rgba(59,130,246,.2); }
.dt-if-alert.warn { background:rgba(245,158,11,.08); color:#d97706; border:1px solid rgba(245,158,11,.2); }
.dt-if-alert.err  { background:rgba(192,57,43,.08); color:var(--red); border:1px solid rgba(192,57,43,.2); }
.dt-if-alert.ok   { background:rgba(30,138,58,.08); color:var(--green); border:1px solid rgba(30,138,58,.2); }

/* Formulaire intranet */
.dt-if-group { margin-bottom:.85rem; }
.dt-if-label { display:block; font-size:10.5px; font-weight:700; color:var(--text3); letter-spacing:.08em; text-transform:uppercase; margin-bottom:.3rem; }
.dt-if-ctrl {
  width:100%; padding:.65rem .9rem;
  border:1.5px solid rgba(11,26,59,.12); border-radius:var(--r);
  font-size:13.5px; font-family:var(--ff); background:#fff; color:var(--text);
}
.dt-if-ctrl:focus { outline:none; border-color:var(--gold); }
.dt-if-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
@media(max-width:600px){ .dt-if-row{grid-template-columns:1fr;} }

/* Empty states */
.dt-i-empty { text-align:center; padding:3rem; color:var(--text2); }
.dt-i-empty .ei { font-size:2.5rem; margin-bottom:.7rem; }
.dt-i-empty p { font-size:13.5px; }

/* Visiteurs KPIs */
.dt-kpi-val { font-size:1.5rem; font-weight:800; color:var(--navy); }

/* ================================================================
   INTRANET COMPLÉMENTS FINANCES & SESSIONS
================================================================ */
.dt-sb.rc { background:rgba(30,138,58,.12); color:var(--green); }
.dt-sb.dp { background:rgba(192,57,43,.12); color:var(--red); }
.dt-sb.or { background:rgba(230,126,34,.12); color:#E67E22; }

/* Progress bars */
.dt-prog { height:6px; background:rgba(11,26,59,.08); border-radius:3px; overflow:hidden; margin-top:.4rem; }
.dt-prog-fill { height:100%; background:linear-gradient(90deg,var(--gold),var(--gold2)); border-radius:3px; transition:width .6s ease; }

/* Bouton sc (secondary) */
.dt-ib.sc { background:rgba(11,26,59,.08); color:var(--navy); border:1px solid rgba(11,26,59,.15); }
.dt-ib.sc:hover { background:var(--navy); color:#fff; }

/* Sidebar KPI colors */
.dt-kpi.or { border-left-color:#E67E22; }

/* Visiteurs — drapeaux */
.dt-flag { font-size:1.1rem; }

/* Intranet sidebar mobile toggle */
.dt-sb-toggle {
  display:none; position:fixed; bottom:6rem; left:1rem; z-index:1100;
  width:44px; height:44px; background:var(--navy); border-radius:50%;
  color:var(--gold); font-size:1.1rem; border:none; cursor:pointer;
  box-shadow:0 4px 16px rgba(11,26,59,.3);
}
@media(max-width:480px){ .dt-sb-toggle{display:flex;align-items:center;justify-content:center;} }

/* Formulaire intranet — textarea */
.dt-if-ctrl[rows] { resize:vertical; min-height:80px; }

/* Rapport financier — tableau couleurs */
.dt-fin-pos { color:var(--green); font-weight:700; }
.dt-fin-neg { color:var(--red); font-weight:700; }
.dt-fin-neu { color:var(--text2); }

/* Séparateur de section dans le contenu */
.dt-in-divider {
  height:1px; background:linear-gradient(90deg,transparent,rgba(11,26,59,.1),transparent);
  margin:1.5rem 0;
}

/* Section équipe — cartes employés */
.dt-emp-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1rem; }
.dt-emp-card {
  background:#fff; border-radius:var(--r); padding:1.2rem; box-shadow:var(--sh);
  border:1px solid rgba(11,26,59,.06); text-align:center;
}
.dt-emp-card .emp-ico {
  width:48px; height:48px; border-radius:50%; background:var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; font-weight:800; color:var(--navy);
  margin:0 auto .7rem;
}
.dt-emp-card h4 { font-size:14px; font-weight:700; color:var(--navy); margin-bottom:.2rem; }
.dt-emp-card .emp-role { font-size:11.5px; color:var(--text3); margin-bottom:.6rem; }
.dt-emp-card .emp-contact { font-size:12px; color:var(--text2); }

/* Avis clients — étoiles */
.dt-stars { color:var(--gold); font-size:1rem; letter-spacing:.15rem; }
.dt-star-empty { color:#dde3ea; }

/* Section profil */
.dt-profil-card {
  background:linear-gradient(135deg,var(--navy),var(--navy2));
  border-radius:16px; padding:2rem; color:#fff; margin-bottom:1.5rem;
  border:1px solid rgba(200,152,42,.2);
}
.dt-profil-ico {
  width:72px; height:72px; background:var(--gold); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; font-weight:900; color:var(--navy); margin-bottom:1rem;
}
.dt-profil-name { font-size:1.1rem; font-weight:800; color:#fff; }
.dt-profil-role { font-size:12px; color:var(--gold); margin-top:.2rem; }

/* Dashboard — barre latérale compacte sur écrans moyens */
@media(min-width:769px) and (max-width:1024px) {
  .dt-in-sidebar { width:200px; }
  .dt-in-lnk { font-size:12px; padding:.55rem 1rem; }
}
