/* ═══════════════════════════════════════════════════════
   DEVENTRI — Main CSS
   Fidèle à la landing originale + burger menu + pages WP
═══════════════════════════════════════════════════════ */

/* ── VARIABLES ── */
:root {
  --sidebar-bg: #151b26;
  --sidebar-hover: rgba(255,255,255,0.06);
  --sidebar-active: rgba(255,255,255,0.1);
  --card-bg: rgba(255,255,255,0.93);
  --card-radius: 20px;
  --blue: #2d7cf6;
  --blue-light: #5b9fff;
  --text-dark: #1a2035;
  --text-muted: #6b7a99;
  --text-light: #9baabb;
  --border: rgba(255,255,255,0.15);
  --shadow-card: 0 4px 32px rgba(0,0,0,0.18), 0 1px 3px rgba(0,0,0,0.1);
  --sidebar-width: 220px;
  --topbar-h: 58px;
  --transition: 0.28s cubic-bezier(0.4,0,0.2,1);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 15px; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { background: none; border: none; cursor: pointer; font: inherit; }
input, textarea { font: inherit; }

body {
  font-family: 'DM Sans', sans-serif;
  background: #0a0f1e;
  color: var(--text-dark);
  min-height: 100vh;
  overflow-x: hidden;
  line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════
   LAYOUT SHELL
═══════════════════════════════════════════════════════ */
.shell { display: flex; min-height: 100vh; }

/* ═══════════════════════════════════════════════════════
   SIDEBAR
═══════════════════════════════════════════════════════ */
.sidebar {
  width: var(--sidebar-width);
  background: var(--sidebar-bg);
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 200;
  border-right: 1px solid rgba(255,255,255,0.05);
  transform: translateX(0);
  transition: transform var(--transition), box-shadow var(--transition);
  will-change: transform;
}

/* Sidebar masquée (burger) */
.sidebar.sidebar--hidden {
  transform: translateX(calc(-1 * var(--sidebar-width)));
  box-shadow: none;
}

/* Sidebar ouverte sur mobile */
.sidebar.sidebar--open {
  transform: translateX(0);
  box-shadow: 8px 0 40px rgba(0,0,0,0.5);
}

/* ── Logo ── */
.sidebar-logo {
  padding: 1.5rem 1.4rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.7rem;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: 0.75rem;
  flex-shrink: 0;
}
.logo-icon {
  width: 34px; height: 34px;
  background: var(--blue);
  border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.95rem; font-weight: 700;
  font-family: 'Syne', sans-serif;
  color: white; flex-shrink: 0;
}
.logo-text { font-family:'Syne',sans-serif; font-weight:700; font-size:1.05rem; color:#fff; letter-spacing:-0.01em; }
.logo-sub { font-size:0.65rem; color:var(--text-light); font-weight:400; letter-spacing:0.05em; text-transform:uppercase; }
/* Logo WP custom */
.sidebar-logo .custom-logo-link img { height: 34px; width: auto; border-radius: 10px; }

/* ── Nav ── */
.nav-group { padding:0 0.6rem; flex:1; display:flex; flex-direction:column; gap:2px; overflow-y:auto; }
.nav-item {
  display:flex; align-items:center; gap:0.75rem;
  padding:0.6rem 0.85rem; border-radius:10px;
  cursor:pointer; text-decoration:none;
  color:var(--text-light); font-size:0.875rem; font-weight:400;
  transition:background 0.15s, color 0.15s;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.nav-item:hover { background:var(--sidebar-hover); color:#e0e8ff; }
.nav-item.active { background:var(--sidebar-active); color:#fff; }
.nav-icon { width:18px; height:18px; opacity:0.7; flex-shrink:0; display:flex; align-items:center; justify-content:center; }
.nav-item.active .nav-icon { opacity:1; }
.nav-item:focus-visible { outline: 2px solid var(--blue); outline-offset: 2px; }
.nav-sep { height:1px; background:rgba(255,255,255,0.06); margin:0.5rem 0.85rem; flex-shrink: 0; }

/* WP Nav Menu reset */
.nav-group ul, .nav-group li { all: unset; display: contents; }

/* ── Footer sidebar ── */
.sidebar-footer { padding:1rem 1.2rem; border-top:1px solid rgba(255,255,255,0.06); flex-shrink: 0; }
.sidebar-user { display:flex; align-items:center; gap:0.7rem; }
.user-avatar {
  width:32px; height:32px; border-radius:50%;
  background:linear-gradient(135deg,#2d7cf6,#5b9fff);
  display:flex; align-items:center; justify-content:center;
  font-size:0.75rem; font-weight:600; color:white; flex-shrink:0;
}
.user-name { font-size:0.82rem; font-weight:500; color:#d0d8f0; }
.user-role { font-size:0.72rem; color:var(--text-light); }

/* ── Overlay mobile ── */
.sidebar-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 150;
  opacity: 0;
  transition: opacity var(--transition);
}
.sidebar-overlay.is-visible {
  display: block;
  opacity: 1;
}

/* ═══════════════════════════════════════════════════════
   MAIN
═══════════════════════════════════════════════════════ */
.main {
  margin-left: var(--sidebar-width);
  flex: 1;
  min-height: 100vh;
  position: relative;
  transition: margin-left var(--transition);
}
.main--full { margin-left: 0; }

/* ═══════════════════════════════════════════════════════
   TOPBAR
═══════════════════════════════════════════════════════ */
.topbar {
  position: sticky; top: 0; z-index: 100;
  height: var(--topbar-h);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 1.5rem 0 1rem;
  background: rgba(10,15,30,0.75);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.topbar-left { display: flex; align-items: center; gap: 0.75rem; }
.page-title { font-family:'Syne',sans-serif; font-weight:700; font-size:1.1rem; color:#fff; }
.topbar-right { display:flex; align-items:center; gap:0.75rem; }

/* ── Search form ── */
.topbar-search {
  display: flex; align-items: center; gap: 0.5rem;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 9px; padding: 0.35rem 0.85rem;
  color: var(--text-light);
}
.topbar-search input {
  background: none; border: none; outline: none;
  color: #fff; font-size: 0.82rem; width: 120px;
}
.topbar-search input::placeholder { color: var(--text-light); }
.topbar-search svg { flex-shrink: 0; }

/* ── Topbar user ── */
.topbar-user { display:flex; align-items:center; gap:0.6rem; cursor:pointer; }
.topbar-user-info .name { font-size:0.85rem; font-weight:500; color:#e0e8ff; }
.topbar-user-info .role { font-size:0.7rem; color:var(--text-light); }

/* ═══════════════════════════════════════════════════════
   BURGER BUTTON
═══════════════════════════════════════════════════════ */
.burger-btn {
  display: flex; flex-direction: column; justify-content: center;
  gap: 5px; width: 36px; height: 36px;
  padding: 6px; border-radius: 9px;
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.1);
  cursor: pointer; transition: background 0.15s;
  flex-shrink: 0;
}
.burger-btn:hover { background: rgba(255,255,255,0.13); }
.burger-btn:focus-visible { outline: 2px solid var(--blue); outline-offset: 2px; }
.burger-bar {
  display: block; width: 16px; height: 2px;
  background: #9baabb; border-radius: 2px;
  transition: transform var(--transition), opacity var(--transition), width var(--transition);
  transform-origin: left center;
}
/* État "X" quand ouvert */
.burger-btn.is-open .burger-bar:nth-child(1) { transform: rotate(45deg) translate(1px, -1px); }
.burger-btn.is-open .burger-bar:nth-child(2) { opacity: 0; width: 0; }
.burger-btn.is-open .burger-bar:nth-child(3) { transform: rotate(-45deg) translate(1px, 1px); }

/* ═══════════════════════════════════════════════════════
   SECTION BG SYSTEM
═══════════════════════════════════════════════════════ */
.section-bg { position:relative; overflow:hidden; }
.bg-photo { position:absolute; inset:0; background-size:cover; background-position:center; z-index:0; }
.bg-overlay { position:absolute; inset:0; z-index:1; }
.bg-content { position:relative; z-index:2; }

/* ═══════════════════════════════════════════════════════
   HERO — LANDING
═══════════════════════════════════════════════════════ */
.hero-section { min-height:500px; display:flex; flex-direction:column; }
.hero-bg {
  background-image:url('https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1600&q=80');
  filter:brightness(0.5) saturate(0.75);
}
.hero-overlay { background:linear-gradient(135deg,rgba(8,14,38,0.68) 0%,rgba(5,10,22,0.38) 100%); }
.hero-content { padding:4rem 2rem 3rem; max-width:680px; }

.hero-badge {
  display:inline-flex; align-items:center; gap:0.45rem;
  padding:0.3rem 0.85rem;
  background:rgba(45,124,246,0.18); border:1px solid rgba(45,124,246,0.38);
  border-radius:100px; font-size:0.72rem; font-weight:500; color:#8dbfff;
  letter-spacing:0.05em; text-transform:uppercase; margin-bottom:1.25rem;
}
.badge-dot { width:5px; height:5px; border-radius:50%; background:var(--blue); animation:blink 2s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0.3} }

.hero-h1 {
  font-family:'Syne',sans-serif; font-weight:800;
  font-size:clamp(2rem,4vw,3.4rem); line-height:1.1;
  letter-spacing:-0.03em; color:#fff; margin-bottom:1rem;
}
.hero-h1 em { font-style:normal; color:var(--blue-light); }
.hero-desc { font-size:0.975rem; line-height:1.75; color:rgba(255,255,255,0.68); font-weight:300; margin-bottom:2rem; max-width:520px; }
.hero-actions { display:flex; gap:0.75rem; flex-wrap:wrap; }

/* ═══════════════════════════════════════════════════════
   BUTTONS
═══════════════════════════════════════════════════════ */
.btn-primary {
  padding:0.7rem 1.6rem; background:var(--blue); color:#fff;
  border-radius:10px; font-size:0.875rem; font-weight:500;
  text-decoration:none; border:none; cursor:pointer;
  transition:background 0.2s, transform 0.15s;
  box-shadow:0 4px 20px rgba(45,124,246,0.4);
  font-family:'DM Sans',sans-serif;
  display: inline-block;
}
.btn-primary:hover { background:var(--blue-light); transform:translateY(-1px); }
.btn-ghost {
  padding:0.7rem 1.4rem; background:rgba(255,255,255,0.1); color:#fff;
  border-radius:10px; font-size:0.875rem; font-weight:400;
  text-decoration:none; border:1px solid rgba(255,255,255,0.2);
  cursor:pointer; transition:background 0.2s; backdrop-filter:blur(8px);
  font-family:'DM Sans',sans-serif;
  display: inline-block;
}
.btn-ghost:hover { background:rgba(255,255,255,0.17); }

/* ═══════════════════════════════════════════════════════
   STATS ROW
═══════════════════════════════════════════════════════ */
.stats-row { background:#0d1322; padding:1.5rem 2rem; display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:1rem; }
.card { background:var(--card-bg); backdrop-filter:blur(12px); border-radius:var(--card-radius); box-shadow:var(--shadow-card); overflow:hidden; }
.card-inner { padding:1.4rem 1.5rem; }
.card-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:0.85rem; }
.card-title { font-family:'Syne',sans-serif; font-weight:600; font-size:0.9rem; color:var(--text-dark); }
.stat-big { font-family:'Syne',sans-serif; font-weight:800; font-size:2.6rem; letter-spacing:-0.04em; color:var(--text-dark); line-height:1; margin-bottom:0.2rem; }
.stat-big span { color:var(--blue); }
.stat-label { font-size:0.8rem; color:var(--text-muted); font-weight:400; }

/* ═══════════════════════════════════════════════════════
   MODULES
═══════════════════════════════════════════════════════ */
.modules-section { min-height:480px; }
.modules-bg { background-image:url('https://images.unsplash.com/photo-1521737711867-e3b97375f902?w=1600&q=80'); filter:brightness(0.3) saturate(0.6); }
.modules-overlay { background:linear-gradient(180deg,rgba(8,12,28,0.72) 0%,rgba(5,8,22,0.88) 100%); }
.modules-content { padding:3rem 2rem; }

.section-tag {
  display:inline-block; padding:0.25rem 0.7rem;
  background:rgba(45,124,246,0.15); border:1px solid rgba(45,124,246,0.3);
  border-radius:6px; font-size:0.68rem; font-weight:500; color:#8dbfff;
  text-transform:uppercase; letter-spacing:0.07em; margin-bottom:0.75rem;
}
.section-title { font-family:'Syne',sans-serif; font-weight:700; font-size:clamp(1.5rem,2.5vw,2.2rem); letter-spacing:-0.025em; color:#fff; line-height:1.15; margin-bottom:0.5rem; }
.section-sub { font-size:0.9rem; color:rgba(255,255,255,0.55); font-weight:300; line-height:1.65; max-width:480px; }
.section-header { margin-bottom:2rem; }

.modules-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1rem; }
.module-card { background:var(--card-bg); border-radius:var(--card-radius); padding:1.5rem; box-shadow:var(--shadow-card); transition:transform 0.2s,box-shadow 0.2s; }
.module-card:hover { transform:translateY(-3px); box-shadow:0 12px 40px rgba(0,0,0,0.25); }
.module-icon { width:40px; height:40px; border-radius:11px; background:rgba(45,124,246,0.1); border:1px solid rgba(45,124,246,0.2); display:flex; align-items:center; justify-content:center; font-size:1.1rem; margin-bottom:1rem; color:var(--blue); }
.module-title { font-family:'Syne',sans-serif; font-weight:600; font-size:0.9rem; color:var(--text-dark); margin-bottom:0.4rem; }
.module-desc { font-size:0.8rem; line-height:1.6; color:var(--text-muted); font-weight:300; }

/* ═══════════════════════════════════════════════════════
   CIBLES
═══════════════════════════════════════════════════════ */
.target-section { min-height:400px; }
.target-bg { background-image:url('https://images.unsplash.com/photo-1532187863486-abf9dbad1b69?w=1600&q=80'); filter:brightness(0.28) saturate(0.5); }
.target-overlay { background:linear-gradient(135deg,rgba(5,12,35,0.82),rgba(10,20,50,0.62)); }
.target-content { padding:3rem 2rem; display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:start; }
.target-cards { display:flex; flex-direction:column; gap:0.85rem; }
.target-card { background:var(--card-bg); border-radius:var(--card-radius); padding:1.25rem 1.4rem; box-shadow:var(--shadow-card); }
.target-card-title { font-family:'Syne',sans-serif; font-weight:600; font-size:0.875rem; color:var(--text-dark); margin-bottom:0.3rem; display:flex; align-items:center; gap:0.5rem; }
.target-card-title::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--blue); flex-shrink:0; }
.target-card-text { font-size:0.8rem; color:var(--text-muted); line-height:1.6; font-weight:300; }

/* ═══════════════════════════════════════════════════════
   DESIGN PHILOSOPHY
═══════════════════════════════════════════════════════ */
.design-section { min-height:380px; }
.design-bg { background-image:url('https://images.unsplash.com/photo-1557804506-669a67965ba0?w=1600&q=80'); filter:brightness(0.22) saturate(0.4); }
.design-overlay { background:linear-gradient(180deg,rgba(5,10,30,0.78),rgba(8,15,40,0.9)); }
.design-content { padding:3rem 2rem; text-align:center; }
.design-content .section-sub { margin:0 auto; }
.design-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1rem; margin-top:2rem; }
.design-card { background:var(--card-bg); border-radius:var(--card-radius); padding:1.75rem 1.5rem; box-shadow:var(--shadow-card); text-align:left; }
.design-card-icon { font-size:1.4rem; margin-bottom:0.85rem; }
.design-card-name { font-family:'Syne',sans-serif; font-weight:700; font-size:1rem; color:var(--text-dark); margin-bottom:0.4rem; }
.design-card-desc { font-size:0.8rem; color:var(--text-muted); line-height:1.65; font-weight:300; }
.design-quote { background:var(--card-bg); border-radius:var(--card-radius); padding:1.75rem 2rem; box-shadow:var(--shadow-card); margin:1rem auto 0; max-width:700px; text-align:left; border-left:3px solid var(--blue); }
.design-quote p { font-size:0.875rem; line-height:1.75; color:var(--text-muted); font-style:italic; }

/* ═══════════════════════════════════════════════════════
   INTÉGRATIONS
═══════════════════════════════════════════════════════ */
.integrations-section { min-height:300px; }
.integrations-bg { background-image:url('https://images.unsplash.com/photo-1451187580459-43490279c0fa?w=1600&q=80'); filter:brightness(0.22) saturate(0.5); }
.integrations-overlay { background:linear-gradient(135deg,rgba(5,12,35,0.84),rgba(10,18,45,0.77)); }
.integrations-content { padding:3rem 2rem; }
.integrations-inner { display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center; }
.badges-wrap { display:flex; flex-wrap:wrap; gap:0.65rem; }
.ibadge { background:var(--card-bg); border-radius:11px; padding:0.65rem 1.1rem; font-size:0.82rem; font-weight:500; color:var(--text-dark); box-shadow:var(--shadow-card); display:flex; align-items:center; gap:0.45rem; }

/* ═══════════════════════════════════════════════════════
   CTA
═══════════════════════════════════════════════════════ */
.cta-section { min-height:340px; }
.cta-bg { background-image:url('https://images.unsplash.com/photo-1519681393784-d120267933ba?w=1600&q=80'); filter:brightness(0.28) saturate(0.6); }
.cta-overlay { background:linear-gradient(180deg,rgba(5,10,28,0.72),rgba(10,15,35,0.88)); }
.cta-content { padding:4.5rem 2rem; display:flex; flex-direction:column; align-items:center; text-align:center; }
.cta-content .section-title { max-width:520px; margin:.75rem auto; }
.cta-content .section-sub { margin:0 auto 2rem; }

/* ═══════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════ */
.footer { background:#090e1d; border-top:1px solid rgba(255,255,255,0.05); padding:1.5rem 2rem; display:flex; align-items:center; justify-content:space-between; flex-wrap: wrap; gap: 1rem; }
.footer-logo { font-family:'Syne',sans-serif; font-weight:700; color:#2a3a55; font-size:0.95rem; }
.footer-copy { font-size:0.75rem; color:#1e2b42; }
.footer-nav ul { display: flex; gap: 1rem; flex-wrap: wrap; }
.footer-nav a { font-size: 0.78rem; color: #2a3a55; transition: color 0.15s; }
.footer-nav a:hover { color: var(--text-light); }

/* ═══════════════════════════════════════════════════════
   DECO
═══════════════════════════════════════════════════════ */
.deco-line { height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,0.07),transparent); }

/* ═══════════════════════════════════════════════════════
   REVEAL ANIMATIONS
═══════════════════════════════════════════════════════ */
.reveal { opacity:0; transform:translateY(20px); transition:opacity 0.55s ease, transform 0.55s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.rd1 { transition-delay:.08s } .rd2 { transition-delay:.16s } .rd3 { transition-delay:.24s } .rd4 { transition-delay:.32s }

/* ═══════════════════════════════════════════════════════
   PAGE PAR DÉFAUT
═══════════════════════════════════════════════════════ */
.page-hero { min-height: 280px; display: flex; flex-direction: column; }
.page-hero-bg { filter: brightness(0.4) saturate(0.6); }
.page-hero-overlay { background: linear-gradient(135deg, rgba(8,14,38,0.75), rgba(5,10,22,0.5)); }
.page-hero-content {
  padding: 4rem 2.5rem 2.5rem;
  display: flex; flex-direction: column;
  justify-content: flex-end;
}
.page-hero-content.no-image { padding-top: 3rem; }
.page-hero-title { font-family:'Syne',sans-serif; font-weight:800; font-size:clamp(1.8rem,3vw,2.8rem); letter-spacing:-0.03em; color:#fff; line-height:1.1; margin-bottom:0.75rem; }
.page-hero-sub { font-size:1rem; color:rgba(255,255,255,0.65); font-weight:300; max-width:560px; }
.page-breadcrumb { display:flex; align-items:center; gap:0.5rem; font-size:0.78rem; color:rgba(255,255,255,0.45); margin-bottom:1rem; flex-wrap: wrap; }
.page-breadcrumb a { color:rgba(255,255,255,0.5); transition:color 0.15s; }
.page-breadcrumb a:hover { color:#fff; }
.page-breadcrumb span[aria-current] { color:rgba(255,255,255,0.7); }

.page-content-wrap { max-width: 820px; margin: 0 auto; padding: 3rem 2rem 4rem; }
.page-content-inner { color: rgba(255,255,255,0.85); }
.page-content-inner h1,.page-content-inner h2,.page-content-inner h3 { font-family:'Syne',sans-serif; color:#fff; margin: 1.5rem 0 0.75rem; }
.page-content-inner p { margin-bottom: 1.25rem; line-height: 1.8; font-size: 0.95rem; color: rgba(255,255,255,0.72); }
.page-content-inner ul, .page-content-inner ol { margin: 1rem 0 1.25rem 1.5rem; list-style: revert; color: rgba(255,255,255,0.72); }
.page-content-inner li { margin-bottom: 0.4rem; line-height: 1.7; }
.page-content-inner a { color: var(--blue-light); text-decoration: underline; }
.page-content-inner blockquote { border-left: 3px solid var(--blue); padding: 0.75rem 1.25rem; margin: 1.5rem 0; background: rgba(255,255,255,0.04); border-radius: 0 8px 8px 0; color: rgba(255,255,255,0.6); font-style: italic; }
.page-content-inner img { border-radius: 12px; margin: 1.5rem 0; }
.page-content-inner .wp-caption-text { font-size:0.78rem; color:var(--text-muted); margin-top:0.25rem; }

.page-edit-link { padding: 0 2rem 2rem; }
.page-edit-link a { font-size: 0.8rem; color: var(--blue); }

/* ═══════════════════════════════════════════════════════
   BLOG — GRILLE
═══════════════════════════════════════════════════════ */
.blog-hero-bg { background-image:url('https://images.unsplash.com/photo-1506905925346-21bda4d32df4?w=1600&q=80'); filter:brightness(0.3) saturate(0.5); }
.blog-hero-overlay { background:linear-gradient(135deg,rgba(5,10,28,0.85),rgba(10,15,35,0.65)); }

.blog-wrap { padding: 3rem 2rem 4rem; }
.blog-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 1.5rem; margin-bottom: 3rem; }

.blog-card { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); border-radius: 20px; overflow: hidden; transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s; }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(0,0,0,0.35); border-color: rgba(45,124,246,0.25); }
.blog-card-thumb { display: block; aspect-ratio: 16/9; overflow: hidden; position: relative; }
.blog-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.blog-card:hover .blog-card-thumb img { transform: scale(1.04); }
.blog-card-featured-label { position: absolute; top: 0.75rem; left: 0.75rem; background: var(--blue); color: #fff; padding: 0.2rem 0.65rem; border-radius: 6px; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.04em; }

.blog-card-body { padding: 1.4rem 1.5rem 1.5rem; }
.blog-card-meta { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 0.75rem; flex-wrap: wrap; }
.blog-card-cat { background: rgba(45,124,246,0.15); border: 1px solid rgba(45,124,246,0.3); color: #8dbfff; font-size: 0.68rem; font-weight: 500; letter-spacing: 0.05em; text-transform: uppercase; padding: 0.2rem 0.55rem; border-radius: 5px; transition: background 0.15s; }
.blog-card-cat:hover { background: rgba(45,124,246,0.28); }
.blog-card-date { font-size: 0.75rem; color: var(--text-light); }
.blog-card-reading { font-size: 0.72rem; color: var(--text-light); background: rgba(255,255,255,0.06); padding: 0.15rem 0.5rem; border-radius: 5px; }
.blog-card-type { font-size: 0.72rem; color: var(--text-light); text-transform: capitalize; }
.blog-card-title { font-family:'Syne',sans-serif; font-weight:700; font-size:1rem; line-height:1.3; color:#fff; margin-bottom:0.6rem; }
.blog-card-title a { color:#fff; transition:color 0.15s; }
.blog-card-title a:hover { color:var(--blue-light); }
.blog-card-excerpt { font-size:0.82rem; color:rgba(255,255,255,0.5); line-height:1.65; margin-bottom:1rem; }
.blog-card-link { font-size:0.82rem; color:var(--blue-light); font-weight:500; transition:color 0.15s; }
.blog-card-link:hover { color:#fff; }

.blog-empty { grid-column: 1/-1; text-align:center; padding:4rem 2rem; color:rgba(255,255,255,0.45); display:flex; flex-direction:column; align-items:center; gap:1.5rem; }

.blog-pagination { display: flex; gap: 0.5rem; justify-content: center; flex-wrap: wrap; }
.blog-pagination a, .blog-pagination span { display:flex; align-items:center; justify-content:center; min-width:38px; height:38px; padding:0 0.75rem; border-radius:9px; font-size:0.85rem; font-weight:500; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); color:var(--text-light); transition:all 0.15s; }
.blog-pagination a:hover { background:rgba(255,255,255,0.12); color:#fff; }
.blog-pagination .current { background:var(--blue); border-color:var(--blue); color:#fff; }

/* ═══════════════════════════════════════════════════════
   ARTICLE SIMPLE
═══════════════════════════════════════════════════════ */
.single-hero { min-height: 340px; display: flex; flex-direction: column; }
.single-hero-bg { filter: brightness(0.35) saturate(0.6); }
.single-hero-overlay { background: linear-gradient(180deg,rgba(5,10,28,0.6),rgba(10,15,35,0.92)); }
.single-hero-content { padding: 4rem 2.5rem 2.5rem; max-width: 800px; }
.single-hero-meta { display:flex; align-items:center; gap:0.6rem; margin-bottom:0.85rem; flex-wrap:wrap; }
.single-author { display:flex; align-items:center; gap:0.6rem; font-size:0.83rem; color:rgba(255,255,255,0.55); margin-top:1.25rem; }
.single-author-avatar { border-radius:50%; width:36px; height:36px; flex-shrink:0; }
.single-author strong { color:rgba(255,255,255,0.75); }

.no-thumb.single-hero-bg { background: linear-gradient(135deg,#0a0f1e,#101828); filter:none; }

.single-content-wrap { max-width: 780px; margin: 0 auto; padding: 2.5rem 2rem 4rem; }
.single-content { color: rgba(255,255,255,0.82); font-size: 0.975rem; line-height: 1.85; }
.single-content h2,.single-content h3,.single-content h4 { font-family:'Syne',sans-serif; color:#fff; margin:2rem 0 0.85rem; }
.single-content h2 { font-size:1.4rem; } .single-content h3 { font-size:1.15rem; }
.single-content p { margin-bottom:1.35rem; }
.single-content ul,.single-content ol { margin:1rem 0 1.35rem 1.5rem; list-style:revert; }
.single-content li { margin-bottom:0.4rem; }
.single-content a { color:var(--blue-light); text-decoration:underline; }
.single-content blockquote { border-left:3px solid var(--blue); padding:0.75rem 1.25rem; margin:1.5rem 0; background:rgba(255,255,255,0.04); border-radius:0 8px 8px 0; color:rgba(255,255,255,0.6); font-style:italic; }
.single-content img { border-radius:12px; margin:1.5rem 0; }
.single-content figure { margin:1.5rem 0; }
.single-content figcaption { font-size:0.78rem; color:var(--text-muted); margin-top:0.35rem; }
.single-content pre { background:rgba(255,255,255,0.06); border-radius:10px; padding:1.25rem; overflow-x:auto; font-size:0.85rem; margin:1.5rem 0; border:1px solid rgba(255,255,255,0.08); }
.single-content code { background:rgba(255,255,255,0.08); padding:0.15rem 0.4rem; border-radius:5px; font-size:0.85em; }
.single-content table { width:100%; border-collapse:collapse; margin:1.5rem 0; font-size:0.88rem; }
.single-content th { background:rgba(45,124,246,0.12); color:#8dbfff; font-family:'Syne',sans-serif; font-weight:600; padding:0.75rem 1rem; text-align:left; border-bottom:1px solid rgba(255,255,255,0.1); }
.single-content td { padding:0.65rem 1rem; border-bottom:1px solid rgba(255,255,255,0.06); color:rgba(255,255,255,0.7); }

.single-tags { display:flex; flex-wrap:wrap; gap:0.5rem; margin:2.5rem 0; }
.single-tag { background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); color:var(--text-light); font-size:0.78rem; padding:0.3rem 0.75rem; border-radius:100px; transition:all 0.15s; }
.single-tag:hover { background:rgba(255,255,255,0.12); color:#fff; }

.single-nav { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-top:3rem; padding-top:2rem; border-top:1px solid rgba(255,255,255,0.07); }
.single-nav-link { display:flex; flex-direction:column; gap:0.3rem; padding:1rem 1.25rem; background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.08); border-radius:14px; transition:all 0.15s; }
.single-nav-link:hover { background:rgba(255,255,255,0.08); border-color:rgba(45,124,246,0.3); }
.single-nav-dir { font-size:0.75rem; color:var(--text-light); }
.single-nav-title { font-family:'Syne',sans-serif; font-size:0.88rem; font-weight:600; color:#fff; line-height:1.3; }
.single-nav-next { text-align:right; }

/* ═══════════════════════════════════════════════════════
   404
═══════════════════════════════════════════════════════ */
.error-section { min-height: calc(100vh - var(--topbar-h)); display: flex; flex-direction: column; }
.error-bg { background-image:url('https://images.unsplash.com/photo-1451187580459-43490279c0fa?w=1600&q=80'); filter:brightness(0.15) saturate(0.3); }
.error-overlay { background: radial-gradient(ellipse at center, rgba(10,20,50,0.3) 0%, rgba(5,10,25,0.95) 100%); }
.error-content { display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:4rem 2rem; flex:1; }
.error-code { font-family:'Syne',sans-serif; font-weight:800; font-size:clamp(6rem,15vw,12rem); line-height:1; color:rgba(45,124,246,0.12); letter-spacing:-0.05em; margin-bottom:-1rem; }
.error-content .section-title { max-width: 480px; white-space: pre-line; }
.error-content .section-sub { margin: 0 auto 2.5rem; }
.error-actions { display:flex; gap:0.75rem; flex-wrap:wrap; justify-content:center; }
.error-search { margin-top:3rem; }
.error-search-label { font-size:0.85rem; color:rgba(255,255,255,0.4); margin-bottom:0.75rem; }
.error-search-form { display:flex; gap:0.65rem; align-items:center; flex-wrap:wrap; justify-content:center; }
.error-search-input { background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.12); border-radius:10px; padding:0.7rem 1.1rem; color:#fff; font-size:0.875rem; width:260px; outline:none; transition:border-color 0.15s; }
.error-search-input::placeholder { color:var(--text-light); }
.error-search-input:focus { border-color:rgba(45,124,246,0.5); }

/* ═══════════════════════════════════════════════════════
   SCROLLBAR
═══════════════════════════════════════════════════════ */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.12); border-radius:10px; }
::-webkit-scrollbar-thumb:hover { background:rgba(255,255,255,0.22); }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  /* Sur mobile/tablette, sidebar cachée par défaut */
  .sidebar { transform: translateX(calc(-1 * var(--sidebar-width))); }
  .sidebar.sidebar--open { transform: translateX(0); box-shadow: 8px 0 40px rgba(0,0,0,0.5); }
  .main { margin-left: 0 !important; }

  .target-content { grid-template-columns: 1fr; gap: 2rem; }
  .integrations-inner { grid-template-columns: 1fr; gap: 2rem; }
  .single-nav { grid-template-columns: 1fr; }
  .single-nav-next { text-align: left; }
}

@media (max-width: 600px) {
  .stats-row { grid-template-columns: 1fr; padding: 1rem; }
  .modules-grid { grid-template-columns: 1fr; }
  .design-grid { grid-template-columns: 1fr; }
  .blog-grid { grid-template-columns: 1fr; }
  .hero-content, .page-hero-content, .single-hero-content { padding: 3rem 1.25rem 2rem; }
  .topbar { padding: 0 1rem 0 0.75rem; }
  .topbar-user-info { display: none; }
  .topbar-search input { width: 80px; }
  .footer { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
}

/* Accessibilité — skip link */
.skip-link { position:absolute; top:-100px; left:0; z-index:9999; background:var(--blue); color:#fff; padding:0.5rem 1rem; font-size:0.875rem; transition:top 0.2s; }
.skip-link:focus { top:0; }