/*
Theme Name: Conseil Investissement
Theme URI: https://conseilinvestissement.fr/
Author: Mathieu
Description: Thème éditorial sombre pour blog finance & investissement (Bourse, Immobilier, Cryptomonnaies, Banques, Livrets). Palette accent paramétrable, typographies multiples, sections d'accueil modulaires via la personnalisation du thème.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: conseilinvestissement
Tags: blog, news, two-columns, custom-colors, custom-menu, custom-logo, featured-images, footer-widgets, theme-options
*/

/* Conseil Investissement — design system */
/* Dark editorial palette inspired by modern finance media; original brand. */

:root {
  /* surfaces */
  --ci-bg: #0c0c0e;
  --ci-bg-2: #131316;
  --ci-surface: #18181c;
  --ci-surface-2: #1f1f24;
  --ci-line: rgba(255, 255, 255, 0.08);
  --ci-line-strong: rgba(255, 255, 255, 0.14);

  /* text */
  --ci-text: #f4f2ed;
  --ci-text-2: #c8c5bf;
  --ci-text-3: #8a8780;
  --ci-text-4: #56534d;

  /* accent — warm orange (default tweak: orange) */
  --ci-accent: oklch(0.74 0.14 60);
  --ci-accent-2: oklch(0.82 0.119 70);
  --ci-accent-soft: oklch(0.74 0.14 60 / 0.14);
  --ci-accent-ink: #2a1a05;

  /* semantic */
  --ci-pos: oklch(0.78 0.16 145);
  --ci-neg: oklch(0.66 0.17 25);
  --ci-warn: oklch(0.82 0.14 85);

  /* radii / shadows — radius=2 (Standard) */
  --ci-r-sm: 8px;
  --ci-r-md: 14px;
  --ci-r-lg: 20px;
  --ci-r-xl: 28px;
  --ci-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --ci-shadow-md: 0 8px 24px rgba(0, 0, 0, 0.35);
  --ci-shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.5);

  /* fonts — Premium aesthetic: heavy sans-serif display, Inter body */
  --ci-font-display: 'Inter Tight', 'Inter', -apple-system, system-ui, sans-serif;
  --ci-font-display-weight: 600;
  --ci-font-display-tracking: -0.025em;
  --ci-font-body: 'Inter Tight', 'Inter', -apple-system, system-ui, sans-serif;
  --ci-font-sans: 'Inter Tight', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif;
  --ci-font-mono: 'JetBrains Mono', ui-monospace, 'SF Mono', Menlo, monospace;
}

* { box-sizing: border-box; }

html, body { margin: 0; padding: 0; background: var(--ci-bg); }
body { font-family: var(--ci-font-sans); }

.ci-root {
  background: var(--ci-bg);
  color: var(--ci-text);
  font-family: var(--ci-font-sans);
  font-feature-settings: 'ss01', 'cv11';
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.5;
  min-height: 100vh;
}

/* ── typography ─────────────────────────────────────── */
.ci-eyebrow {
  font-family: var(--ci-font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ci-text-3);
}
.ci-display {
  font-family: var(--ci-font-display);
  font-weight: var(--ci-font-display-weight, 600);
  letter-spacing: var(--ci-font-display-tracking, -0.025em);
  line-height: 1.05;
  color: var(--ci-text);
}
.ci-h1 { font-size: clamp(48px, 5.6vw, 84px); }
.ci-h2 { font-size: clamp(34px, 4vw, 56px); }
.ci-h3 { font-size: clamp(22px, 2.2vw, 32px); }
.ci-italic-accent { color: var(--ci-accent); font-style: italic; }
.ci-lead {
  font-size: 18px;
  line-height: 1.55;
  color: var(--ci-text-2);
  max-width: 56ch;
}

/* ── buttons ────────────────────────────────────────── */
.ci-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 48px;
  padding: 0 22px;
  border-radius: var(--ci-r-sm);
  font-family: var(--ci-font-sans);
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.005em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 0.15s ease, background 0.15s ease, border-color 0.15s ease;
  user-select: none;
  white-space: nowrap;
  text-decoration: none;
}
a.ci-btn:hover, a.ci-btn:focus, a.ci-btn:visited { text-decoration: none; }
.ci-btn:active { transform: translateY(1px); }
.ci-btn-primary {
  background: var(--ci-accent);
  color: var(--ci-accent-ink);
  font-weight: 600;
  box-shadow: 0 8px 24px oklch(0.74 0.14 60 / 0.28);
}
.ci-btn-primary:hover { background: var(--ci-accent-2); transform: translateY(-1px); }
.ci-btn-ghost {
  background: transparent;
  color: var(--ci-text);
  border-color: var(--ci-line-strong);
}
.ci-btn-ghost:hover { background: rgba(255,255,255,0.04); border-color: rgba(255,255,255,0.22); }
.ci-btn-sm { height: 36px; padding: 0 14px; font-size: 13px; }

/* ── chips / tags ───────────────────────────────────── */
.ci-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 28px;
  padding: 0 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  color: var(--ci-text-2);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--ci-line);
}
.ci-chip-accent { color: var(--ci-accent-2); background: var(--ci-accent-soft); border-color: transparent; }
.ci-chip-pos { color: var(--ci-pos); background: oklch(0.78 0.16 145 / 0.12); border-color: transparent; }

/* ── cards ──────────────────────────────────────────── */
.ci-card {
  background: var(--ci-surface);
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
}
.ci-card-glass {
  background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01));
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
  backdrop-filter: blur(8px);
}

/* ── nav ────────────────────────────────────────────── */
.ci-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 32px;
  border-bottom: 1px solid var(--ci-line);
  background: rgba(12, 12, 14, 0.85);
  backdrop-filter: blur(12px);
  position: sticky;
  top: 0;
  z-index: 50;
}
.ci-nav-left { display: flex; align-items: center; gap: 38px; }
.ci-nav-links { display: flex; gap: 4px; }
.ci-nav-item { position: relative; }
.ci-nav-link {
  font-size: 14px;
  color: var(--ci-text-2);
  padding: 8px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  text-decoration: none;
}
.ci-nav-link:hover,
.ci-nav-item:hover .ci-nav-link,
.ci-nav-item:focus-within .ci-nav-link { color: var(--ci-text); background: rgba(255,255,255,0.04); }
.ci-nav-right { display: flex; align-items: center; gap: 10px; }

/* ── Burger button (mobile only) ───────────────────── */
.ci-nav-burger {
  display: none;
  width: 42px; height: 42px;
  background: transparent;
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-sm);
  cursor: pointer;
  padding: 0;
  align-items: center; justify-content: center;
  transition: background 0.15s ease, border-color 0.15s ease;
}
.ci-nav-burger:hover { background: rgba(255,255,255,0.04); border-color: var(--ci-line-strong); }
.ci-nav-burger-bars {
  display: inline-flex; flex-direction: column; gap: 5px;
  width: 18px;
}
.ci-nav-burger-bars > span {
  display: block;
  height: 2px;
  background: var(--ci-text);
  border-radius: 2px;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
.ci-nav-burger[aria-expanded="true"] .ci-nav-burger-bars > span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.ci-nav-burger[aria-expanded="true"] .ci-nav-burger-bars > span:nth-child(2) {
  opacity: 0;
}
.ci-nav-burger[aria-expanded="true"] .ci-nav-burger-bars > span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* ── Mobile drawer ─────────────────────────────────── */
.ci-nav-drawer {
  display: none;
  position: fixed;
  top: 64px;
  left: 0; right: 0; bottom: 0;
  z-index: 80;
  overflow-y: auto;
  background: var(--ci-bg);
  border-top: 1px solid var(--ci-line);
  padding: 24px 20px 40px;
}
.ci-nav-drawer[hidden] { display: none; }
.ci-nav-drawer-menu { margin-bottom: 24px; }
.ci-nav-drawer-list,
.ci-nav-drawer-list ul {
  list-style: none; margin: 0; padding: 0;
}
.ci-nav-drawer-list > li { border-bottom: 1px solid var(--ci-line); }
.ci-nav-drawer-list > li > a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 4px;
  color: var(--ci-text);
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
}
.ci-nav-drawer-list > li.menu-item-has-children > a::after {
  content: ""; width: 10px; height: 10px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.2s ease;
}
.ci-nav-drawer-list > li.menu-item-has-children.is-open > a::after {
  transform: rotate(-135deg);
}
.ci-nav-drawer-list ul.sub-menu {
  display: none;
  padding: 4px 0 12px 16px;
  border-left: 2px solid var(--ci-line);
  margin-left: 4px;
}
.ci-nav-drawer-list > li.is-open > ul.sub-menu { display: block; }
.ci-nav-drawer-list ul.sub-menu a {
  display: block;
  padding: 8px 4px;
  color: var(--ci-text-2);
  text-decoration: none;
  font-size: 14.5px;
}
.ci-nav-drawer-list ul.sub-menu a:hover { color: var(--ci-text); }
.ci-nav-drawer-actions {
  display: flex; flex-direction: column; gap: 10px;
  padding-top: 16px;
}
.ci-nav-drawer-actions .ci-btn { width: 100%; }
html.ci-drawer-open { overflow: hidden; }
.ci-nav-dropdown {
  position: absolute; top: 100%; left: 0;
  background: var(--ci-surface); border: 1px solid var(--ci-line);
  border-radius: 12px; padding: 8px; min-width: 200px; z-index: 60;
  box-shadow: var(--ci-shadow-md);
  display: none;
}
/* Invisible bridge so the cursor can travel from the link to the dropdown without losing hover. */
.ci-nav-item::before {
  content: ""; position: absolute; top: 100%; left: 0; right: 0; height: 8px;
}
.ci-nav-item:hover > .ci-nav-dropdown,
.ci-nav-item:focus-within > .ci-nav-dropdown { display: block; }
.ci-nav-dropdown-item {
  display: block;
  padding: 9px 12px; font-size: 13px; color: var(--ci-text-2);
  border-radius: 6px; cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background 0.15s, color 0.15s;
}
.ci-nav-dropdown-item:hover { background: rgba(255,255,255,0.04); color: var(--ci-text); }
.ci-nav-dropdown-item + .ci-nav-dropdown-item { margin-top: 2px; }

/* ── logo ───────────────────────────────────────────── */
.ci-logo {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--ci-font-display);
  font-weight: 600;
  font-size: 17px;
  letter-spacing: -0.025em;
  color: var(--ci-text);
  text-decoration: none;
  white-space: nowrap;
}
.ci-logo-wordmark { display: inline-flex; align-items: baseline; gap: 4px; white-space: nowrap; }
.ci-logo-wordmark .alt { color: var(--ci-text-3); font-weight: 500; }

/* ── grid utilities ────────────────────────────────── */
.ci-container { max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.ci-container--wide { max-width: 1280px; }
.ci-section { padding: 56px 0; }
.ci-section-tight { padding: 36px 0; }
.ci-grid { display: grid; gap: 20px; }

/* ── tables ────────────────────────────────────────── */
.ci-table { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 14px; }
.ci-table th {
  text-align: left;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ci-text-3);
  padding: 14px 16px;
  border-bottom: 1px solid var(--ci-line);
}
.ci-table td {
  padding: 18px 16px;
  border-bottom: 1px solid var(--ci-line);
  color: var(--ci-text);
}
.ci-table tr:hover td { background: rgba(255,255,255,0.02); }
.ci-table tr:last-child td { border-bottom: none; }

/* ── stars ─────────────────────────────────────────── */
.ci-stars { display: inline-flex; gap: 2px; color: var(--ci-accent-2); font-size: 13px; }

/* ── animations ────────────────────────────────────── */
@keyframes ci-fadein { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.ci-fadein { animation: ci-fadein 0.6s ease-out both; }
@keyframes ci-pulse-dot { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
.ci-live-dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--ci-pos);
  animation: ci-pulse-dot 2s infinite;
}

/* ── inputs ────────────────────────────────────────── */
.ci-input {
  height: 48px;
  padding: 0 18px;
  border-radius: 12px;
  background: var(--ci-surface-2);
  border: 1px solid var(--ci-line);
  color: var(--ci-text);
  font-family: var(--ci-font-sans);
  font-size: 15px;
  outline: none;
  transition: border-color 0.15s;
}
.ci-input:focus { border-color: var(--ci-accent); }

/* ── divider ──────────────────────────────────────── */
.ci-divider { height: 1px; background: var(--ci-line); width: 100%; }

/* ── misc helpers ──────────────────────────────────── */
.ci-mono { font-family: var(--ci-font-mono); }
.ci-num { font-variant-numeric: tabular-nums; font-feature-settings: 'tnum'; }
.ci-pos { color: var(--ci-pos); }
.ci-neg { color: var(--ci-neg); }

/* ── press banner ─────────────────────────────────── */
.ci-press {
  padding: 40px 0;
  border-top: 1px solid var(--ci-line);
  border-bottom: 1px solid var(--ci-line);
}
.ci-press-eyebrow { text-align: center; margin-bottom: 28px; }
.ci-press-row {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 32px; opacity: 0.55;
}
.ci-press-name {
  font-family: var(--ci-font-display); font-size: 22px; color: var(--ci-text-2);
}
.ci-press-name.italic { font-style: italic; }

/* ── hero ─────────────────────────────────────────── */
.ci-hero {
  position: relative; overflow: hidden; padding: 80px 0 40px;
}
.ci-hero-glow {
  position: absolute; top: 0; right: -200px; width: 800px; height: 800px;
  background: radial-gradient(circle, oklch(0.74 0.14 60 / 0.16), transparent 60%);
  pointer-events: none;
  opacity: 0.5; /* glow=subtle */
}
.ci-hero-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center;
}
.ci-hero h1 {
  font-size: clamp(56px, 7vw, 104px);
  margin: 20px 0 24px;
  line-height: 1;
  letter-spacing: -0.03em;
}
.ci-hero-ctas { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }
.ci-hero-signals {
  display: flex; gap: 24px; font-size: 13px; color: var(--ci-text-3);
  flex-wrap: wrap;
}

/* ── dashboard mock ───────────────────────────────── */
.ci-dash { padding: 22px; position: relative; }
.ci-dash-head {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px;
}
.ci-dash-label {
  font-size: 11px; color: var(--ci-text-3); letter-spacing: 0.12em;
}
.ci-dash-value {
  font-family: var(--ci-font-display); font-size: 36px; margin-top: 4px;
}
.ci-dash-value .unit { font-size: 18px; color: var(--ci-text-3); }
.ci-dash-inputs {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px;
}
.ci-dash-input {
  padding: 12px;
  background: var(--ci-surface-2);
  border-radius: 10px;
  border: 1px solid var(--ci-line);
}
.ci-dash-input-label {
  font-size: 10px; color: var(--ci-text-3); letter-spacing: 0.1em;
}
.ci-dash-input-value {
  font-size: 16px; font-weight: 500; margin-top: 2px;
}

/* ── categories strip ────────────────────────────── */
.ci-cats {
  display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px;
}
.ci-cat {
  display: block; padding: 20px 18px;
  background: var(--ci-surface);
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
  text-decoration: none; color: inherit;
  transition: background 0.15s, border-color 0.15s;
}
.ci-cat:hover {
  background: var(--ci-surface-2);
  border-color: var(--ci-line-strong);
}
.ci-cat-glyph { margin-bottom: 12px; }
.ci-cat-title {
  font-family: var(--ci-font-display); font-size: 19px; margin-bottom: 4px;
}
.ci-cat-meta { font-size: 12px; color: var(--ci-text-3); }

/* ── crowdfunding ─────────────────────────────────── */
.ci-section-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 32px; flex-wrap: wrap; gap: 16px;
}
.ci-filters { display: flex; gap: 8px; flex-wrap: wrap; }
.ci-chip-btn {
  cursor: pointer;
  background: none; font-family: inherit;
}
.ci-chip-btn.active {
  background: var(--ci-text); color: var(--ci-bg); border: none;
}
.ci-crowd-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
}
.ci-crowd { padding: 22px; position: relative; }
.ci-crowd-head {
  display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 12px;
  gap: 12px;
}
.ci-crowd-platform {
  font-size: 12px; color: var(--ci-text-3); margin-bottom: 4px;
}
.ci-crowd-name {
  font-family: var(--ci-font-display); font-size: 22px; letter-spacing: -0.005em; line-height: 1.2;
}
.ci-crowd-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  padding: 14px 0;
  border-top: 1px solid var(--ci-line);
  border-bottom: 1px solid var(--ci-line);
  margin-bottom: 14px;
}
.ci-stat-label {
  font-size: 11px; color: var(--ci-text-3);
  text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 4px;
}
.ci-stat-value {
  font-family: var(--ci-font-display); font-size: 24px;
}
.ci-stat-value .small { font-size: 14px; color: var(--ci-text-3); }
.ci-crowd-note .small { font-size: 13px; color: var(--ci-text-3); font-weight: 400; }
.ci-crowd-note.is-high { color: var(--ci-pos); }
.ci-crowd-note.is-mid  { color: oklch(0.82 0.14 85); }
.ci-crowd-note.is-low  { color: var(--ci-accent); }
.ci-risk-dots { display: inline-flex; gap: 3px; margin-top: 8px; }
.ci-risk-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
}
.ci-risk-dot.on-low { background: var(--ci-pos); }
.ci-risk-dot.on-mid { background: oklch(0.82 0.14 85); }
.ci-risk-dot.on-high { background: var(--ci-accent); }
.ci-progress-row {
  display: flex; justify-content: space-between; margin-bottom: 6px;
  font-size: 12px; color: var(--ci-text-3);
}
.ci-progress-track {
  height: 4px; background: rgba(255, 255, 255, 0.06);
  border-radius: 2px; overflow: hidden;
}
.ci-progress-bar {
  height: 100%; background: var(--ci-accent); border-radius: 2px;
}

/* ── articles grid ────────────────────────────────── */
.ci-articles {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px;
}
.ci-article {
  display: block; text-decoration: none; color: inherit; cursor: pointer;
  transition: transform 0.35s ease;
}
.ci-article:hover { transform: translateY(-4px); }
.ci-cover {
  aspect-ratio: 16 / 10;
  border-radius: var(--ci-r-lg);
  overflow: hidden;
  position: relative;
  border: 1px solid var(--ci-line);
  transition: border-color 0.3s ease, box-shadow 0.35s ease;
}
.ci-article:hover .ci-cover {
  border-color: var(--ci-accent);
  box-shadow: 0 24px 52px rgba(0, 0, 0, 0.5);
}
.ci-cover img,
.ci-cover svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s ease;
}
.ci-article:hover .ci-cover img,
.ci-article:hover .ci-cover svg { transform: scale(1.03); }
.ci-cover-stripes {
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, rgba(0,0,0,0.18) 0 1px, transparent 1px 12px),
    repeating-linear-gradient(-45deg, rgba(255,255,255,0.06) 0 1px, transparent 1px 14px);
}
.ci-cover::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,0.4) 100%);
}
.ci-cover-chip {
  position: absolute; top: 20px; left: 20px; z-index: 2;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 16px;
  background: rgba(12, 12, 14, 0.62);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.95);
  text-transform: none;
}
.ci-cover-chip .cat {
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.12em;
  font-size: 11px;
}
.ci-cover-chip .sep { opacity: 0.35; }
.ci-cover-chip .date {
  font-family: var(--ci-font-mono); font-size: 11px;
  color: rgba(255, 255, 255, 0.75);
}
.ci-article-body { padding: 22px 0 0; }
.ci-article-title {
  font-family: var(--ci-font-display); font-size: 26px;
  margin: 0 0 12px; letter-spacing: -0.015em; line-height: 1.2;
  transition: color 0.2s ease;
}
.ci-article:hover .ci-article-title { color: var(--ci-accent); }
.ci-article-excerpt {
  font-size: 15px; color: var(--ci-text-2); margin: 0; line-height: 1.6;
}
@media (max-width: 760px) {
  .ci-articles { grid-template-columns: 1fr; gap: 36px; }
  .ci-article-title { font-size: 24px; }
}

/* ── newsletter ───────────────────────────────────── */
.ci-newsletter {
  padding: 64px 56px;
  border-radius: var(--ci-r-lg);
  background: linear-gradient(135deg, var(--ci-surface), var(--ci-surface-2));
  border: 1px solid var(--ci-line);
  position: relative; overflow: hidden; width: 100%;
}
.ci-newsletter-glow {
  position: absolute; right: -80px; top: -80px; width: 280px; height: 280px;
  background: radial-gradient(circle, oklch(0.74 0.14 60 / 0.18), transparent 70%);
  border-radius: 50%;
}
.ci-newsletter-grid {
  position: relative; display: grid; grid-template-columns: 1fr 1fr;
  gap: 40px; align-items: center;
}
.ci-newsletter-form { display: flex; gap: 10px; flex-wrap: wrap; }
.ci-newsletter-form .ci-input { flex: 1 1 240px; }
.ci-newsletter-slot { position: relative; }
.ci-newsletter-confirm {
  display: flex; flex-direction: column; align-items: flex-start; gap: 10px;
  padding: 22px 24px;
  background: var(--ci-accent-soft);
  border: 1px solid color-mix(in oklch, var(--ci-accent) 30%, transparent);
  border-radius: var(--ci-r-md);
  opacity: 0; transform: translateY(8px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.ci-newsletter-confirm[hidden] { display: none; }
.ci-newsletter-confirm.is-shown { opacity: 1; transform: translateY(0); }
.ci-newsletter-confirm-icon { display: inline-flex; }
.ci-newsletter-confirm-icon svg { display: block; }
.ci-confirm-circle {
  stroke-dasharray: 151;
  stroke-dashoffset: 151;
  transform-origin: center;
  transform: rotate(-90deg);
}
.is-shown .ci-confirm-circle {
  animation: ci-draw-circle 0.6s ease-out 0.05s forwards;
}
.ci-confirm-check {
  stroke-dasharray: 50;
  stroke-dashoffset: 50;
}
.is-shown .ci-confirm-check {
  animation: ci-draw-check 0.4s ease-out 0.5s forwards;
}
@keyframes ci-draw-circle { to { stroke-dashoffset: 0; } }
@keyframes ci-draw-check { to { stroke-dashoffset: 0; } }
.ci-newsletter-confirm-title {
  font-family: var(--ci-font-display); font-size: 22px;
  letter-spacing: -0.01em; color: var(--ci-text);
}
.ci-newsletter-confirm-text {
  font-size: 14.5px; color: var(--ci-text-2); line-height: 1.55;
}

/* ── about block ──────────────────────────────────── */
.ci-about-stats {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
  padding-block: 20px;
  border-top: 1px solid var(--ci-line);
  border-bottom: 1px solid var(--ci-line);
}
.ci-about-stat-value {
  font-family: var(--ci-font-display); font-size: 26px; line-height: 1;
}
.ci-about-stat-label {
  font-size: 11px; color: var(--ci-text-3); margin-top: 4px;
  text-transform: uppercase; letter-spacing: 0.06em;
}

/* ── footer ──────────────────────────────────────── */
.ci-footer {
  border-top: 1px solid var(--ci-line);
  padding: 64px 0 40px;
  margin-top: 80px;
}
.ci-footer-grid {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 56px; margin-bottom: 48px; align-items: start;
}
.ci-footer-brand { min-width: 0; }
.ci-footer-tagline {
  font-size: 14px; color: var(--ci-text-3);
  margin-top: 16px; max-width: 220px;
}
.ci-footer-col-title {
  font-size: 13px; font-weight: 600; color: var(--ci-text);
  margin-bottom: 14px; display: block;
  text-decoration: none; transition: color 0.15s ease;
}
a.ci-footer-col-title:hover { color: var(--ci-accent); }
.ci-footer-col-link {
  font-size: 13px; color: var(--ci-text-3); margin-bottom: 8px; cursor: pointer;
  text-decoration: none; display: block;
}
.ci-footer-col-link:hover { color: var(--ci-text-2); }
.ci-footer-cats-list {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) 3fr;
  gap: 32px 36px;
}
.ci-footer-cat-group { min-width: 0; }
.ci-footer-cat-parents {
  columns: 3;
  column-gap: 32px;
}
.ci-footer-cat-parents .ci-footer-cat-group {
  break-inside: avoid;
  margin-bottom: 28px;
}
.ci-footer-cat-parents .ci-footer-cat-group:last-child { margin-bottom: 0; }
@media (max-width: 760px) {
  .ci-footer-cats-list { grid-template-columns: 1fr; }
  .ci-footer-cat-parents { columns: 2; }
}
@media (max-width: 480px) {
  .ci-footer-cat-parents { columns: 1; }
}
.ci-footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px; border-top: 1px solid var(--ci-line);
  font-size: 12px; color: var(--ci-text-4);
  flex-wrap: wrap; gap: 16px;
}
.ci-footer-legal-menu {
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-wrap: wrap; gap: 0;
}
.ci-footer-legal-menu li { display: inline-flex; align-items: center; }
.ci-footer-legal-menu li + li::before {
  content: "·"; margin: 0 10px; color: var(--ci-text-4);
}
.ci-footer-legal-menu a {
  color: inherit; text-decoration: none; transition: color 0.15s ease;
}
.ci-footer-legal-menu a:hover { color: var(--ci-text-2); }

/* ── responsive ──────────────────────────────────── */
@media (max-width: 960px) {
  .ci-hero-grid { grid-template-columns: 1fr; gap: 32px; }
  .ci-cats { grid-template-columns: repeat(2, 1fr); }
  .ci-crowd-grid { grid-template-columns: 1fr; }
  .ci-articles { grid-template-columns: 1fr; }
  .ci-newsletter-grid { grid-template-columns: 1fr; }
  .ci-newsletter { padding: 40px 32px; }
  .ci-footer-grid { grid-template-columns: 1fr; gap: 40px; }
  /* Mobile nav: hide desktop nav links + the inline header CTAs, show burger. */
  .ci-nav-links,
  .ci-nav-cta,
  .ci-nav-search { display: none; }
  .ci-nav-burger { display: inline-flex; }
  html.ci-drawer-open .ci-nav-drawer { display: block; }
}
@media (max-width: 600px) {
  .ci-cats { grid-template-columns: 1fr; }
  .ci-nav { padding: 14px 20px; }
  .ci-container { padding: 0 20px; }
}

/* ── customizer-driven variants ───────────────────── */
/* Radius scale */
:root[data-radius="0"] { --ci-r-sm: 0px; --ci-r-md: 0px; --ci-r-lg: 0px; --ci-r-xl: 0px; }
:root[data-radius="1"] { --ci-r-sm: 4px; --ci-r-md: 6px; --ci-r-lg: 10px; --ci-r-xl: 14px; }
:root[data-radius="2"] { --ci-r-sm: 8px; --ci-r-md: 14px; --ci-r-lg: 20px; --ci-r-xl: 28px; }
:root[data-radius="3"] { --ci-r-sm: 14px; --ci-r-md: 22px; --ci-r-lg: 32px; --ci-r-xl: 44px; }

/* Density */
:root[data-density="dense"]       .ci-section { padding: 36px 0; }
:root[data-density="dense"]       .ci-section-tight { padding: 24px 0; }
:root[data-density="compact"]     .ci-section { padding: 56px 0; }
:root[data-density="compact"]     .ci-section-tight { padding: 36px 0; }
:root[data-density="comfortable"] .ci-section { padding: 96px 0; }
:root[data-density="comfortable"] .ci-section-tight { padding: 60px 0; }
:root[data-density="airy"]        .ci-section { padding: 140px 0; }
:root[data-density="airy"]        .ci-section-tight { padding: 88px 0; }

/* Theme variants */
:root[data-theme="midnight"] {
  --ci-bg: #08090c;
  --ci-bg-2: #0d0f15;
  --ci-surface: #12141c;
  --ci-surface-2: #1a1d28;
}
:root[data-theme="cream"] {
  --ci-bg: #1a1814;
  --ci-bg-2: #221f1a;
  --ci-surface: #2a261f;
  --ci-surface-2: #322d24;
  --ci-text: #f8f3e6;
  --ci-text-2: #cdc4ad;
  --ci-text-3: #8e8674;
}
:root[data-theme="light"] {
  --ci-bg: #f7f5f0;
  --ci-bg-2: #ede9e0;
  --ci-surface: #ffffff;
  --ci-surface-2: #f3efe6;
  --ci-line: rgba(0, 0, 0, 0.08);
  --ci-line-strong: rgba(0, 0, 0, 0.16);
  --ci-text: #14130f;
  --ci-text-2: #3d3a32;
  --ci-text-3: #6e6a5e;
  --ci-text-4: #a39e91;
}
:root[data-theme="paper"] {
  --ci-bg: #faf6ee;
  --ci-bg-2: #f0ead8;
  --ci-surface: #fffdf6;
  --ci-surface-2: #f5efde;
  --ci-line: rgba(0, 0, 0, 0.1);
  --ci-line-strong: rgba(0, 0, 0, 0.2);
  --ci-text: #1c1810;
  --ci-text-2: #4a4133;
  --ci-text-3: #847a65;
  --ci-text-4: #a89d83;
}
:root[data-theme="light"] .ci-nav,
:root[data-theme="paper"] .ci-nav {
  background: rgba(255, 255, 255, 0.85);
}

/* Card styles */
:root[data-cards="flat"]     .ci-card { box-shadow: none; }
:root[data-cards="bordered"] .ci-card { border-width: 1.5px; }
:root[data-cards="elevated"] .ci-card { box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4); border-color: transparent; }
:root[data-cards="glass"]    .ci-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.01));
  backdrop-filter: blur(12px);
}
:root[data-cards="outline"]  .ci-card { background: transparent; border-width: 1px; }

/* Button styles */
:root[data-btnstyle="square"]  .ci-btn { border-radius: var(--ci-r-sm); }
:root[data-btnstyle="rounded"] .ci-btn { border-radius: 12px; }
:root[data-btnstyle="pill"]    .ci-btn { border-radius: 999px; }

/* Hero glow strength */
:root[data-glow="off"]    [data-glow-target] { display: none; }
:root[data-glow="subtle"] [data-glow-target] { opacity: 0.5; }
:root[data-glow="bold"]   [data-glow-target] { opacity: 1.2; filter: saturate(1.3); }

/* Film-grain overlay */
:root[data-grain="on"] body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 100;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  opacity: 0.06;
  mix-blend-mode: overlay;
}

/* Headline case / non-italic accents */
:root[data-headcase="upper"] .ci-display { text-transform: uppercase; letter-spacing: -0.01em; }
:root[data-headcase="small"] .ci-display { font-variant: small-caps; }
:root[data-italic="off"] .ci-italic-accent { font-style: normal; }

/* ── article-specific styles (single.php) ───────── */
.article-header {
  padding: 64px 0 40px;
  border-bottom: 1px solid var(--ci-line);
}
.article-header-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 480px;
  gap: 56px;
  align-items: start;
}
.article-meta-row {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 22px; flex-wrap: wrap;
}
.article-reading,
.article-meta-date {
  font-size: 13px;
  color: var(--ci-text-3);
}
.article-meta-date { margin-left: auto; }
a.ci-chip {
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
a.ci-chip:hover {
  background: var(--ci-accent-soft);
  color: var(--ci-text);
  border-color: var(--ci-accent);
}
a.ci-chip-accent:hover {
  background: var(--ci-accent);
  color: var(--ci-accent-ink);
}
.article-h1 {
  font-size: clamp(40px, 5vw, 64px);
  margin: 0 0 24px;
  line-height: 1.05;
}
.article-lead {
  font-size: 19px; color: var(--ci-text-2);
  line-height: 1.55; margin: 0 0 32px; max-width: 720px;
}
.article-byline { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
.article-layout {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 64px;
  align-items: flex-start;
  margin-top: 16px;
}
.article-toc { position: sticky; top: 96px; }
.article-toc a {
  display: block; padding: 8px 0; font-size: 13.5px;
  color: var(--ci-text-3); text-decoration: none;
  border-left: 2px solid transparent;
  padding-left: 12px; margin-left: -14px;
  transition: color 0.15s, border-color 0.15s;
}
.article-toc a:hover { color: var(--ci-text-2); }
.article-toc a.active { color: var(--ci-text); border-color: var(--ci-accent); }
.article-toc-tools {
  display: flex; align-items: center; gap: 8px;
  font-size: 13.5px; color: var(--ci-text-2);
  text-decoration: none; padding: 8px 0;
}
.article-toc-tools:hover { color: var(--ci-text); }

.article-body { font-size: 17px; line-height: 1.7; color: var(--ci-text); }
.article-body h2 {
  font-family: var(--ci-font-display);
  font-size: 36px;
  letter-spacing: -0.015em;
  line-height: 1.15;
  margin: 40px 0 18px;
  color: var(--ci-text);
}
.article-body h3 {
  font-family: var(--ci-font-display);
  font-size: 22px;
  letter-spacing: -0.01em;
  line-height: 1.25;
  margin: 28px 0 14px;
  color: var(--ci-text);
}
.article-body h2.first,
.article-body > h2:first-child { margin-top: 0; }
.article-body p { margin: 0 0 18px; }
.article-body ul { padding-left: 22px; margin-bottom: 24px; }
.article-body ul li { margin-bottom: 10px; }
.article-body strong { color: var(--ci-text); font-weight: 600; }
.article-body em { font-style: italic; }
.article-body a { color: var(--ci-accent); text-decoration: underline; text-underline-offset: 3px; }

.pullquote {
  margin: 40px 0; padding: 24px 32px;
  border-left: 3px solid var(--ci-accent);
  font-family: var(--ci-font-display);
  font-size: 26px; line-height: 1.3;
  font-style: italic; color: var(--ci-text);
  background: rgba(255, 255, 255, 0.02);
}
/* ── callouts — 5 variants ─────────────────────────── */
.callout {
  --callout-tint: #ea9344;
  padding: 20px 24px;
  margin: 28px 0;
  background: #18181c;
  color: #c8c5bf;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-left: 4px solid var(--callout-tint);
  border-radius: var(--ci-r-md);
  display: flex; gap: 14px; align-items: flex-start;
}
.callout__icon,
.callout-icon {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 700; line-height: 1;
  background: color-mix(in oklch, var(--callout-tint) 22%, transparent);
  color: var(--callout-tint);
}
.callout__icon svg, .callout-icon svg { display: block; }
.callout__body, .callout-body { flex: 1; min-width: 0; }
.callout__title, .callout-title {
  display: block;
  font-weight: 600;
  margin: 0 0 6px;
  color: #f4f2ed;
  font-size: 15px;
  line-height: 1.3;
}
.callout__text, .callout-text {
  font-size: 15px;
  color: #c8c5bf;
  line-height: 1.6;
}
.callout__text > :first-child, .callout-text > :first-child { margin-top: 0; }
.callout__text > :last-child, .callout-text > :last-child { margin-bottom: 0; }
.callout__text p, .callout-text p { margin: 0 0 12px; color: inherit; }
.callout__text p:last-child, .callout-text p:last-child { margin-bottom: 0; }
.callout__text strong, .callout-text strong { color: #f4f2ed; }
.callout__text a, .callout-text a { color: var(--callout-tint); text-decoration: underline; text-underline-offset: 3px; }
.callout-focus   { --callout-tint: #ea9344; }
.callout-tldr    { --callout-tint: #7da9ed; }
.callout-info    { --callout-tint: #5fbed1; }
.callout-warning { --callout-tint: #e8b04a; }
.callout-error   { --callout-tint: #e07560; }
.callout-caution { --callout-tint: #e8b04a; } /* legacy alias */

/* ── Plugin-emitted callouts (FAQ-snippets etc.) overrides ────────────
   Some extensions style .focus / .tldr / .info / .warning / .error
   directly with a light-grey background. We force them into our design.
   Doubled-class trick bumps specificity above the plugin's selectors
   without changing the matched set. */
.focus.focus,
.tldr.tldr,
.info.info,
.warning.warning,
.error.error {
  --callout-tint: #ea9344;
  padding: 20px 24px !important;
  margin: 28px 0 !important;
  background: #18181c !important;
  color: #c8c5bf !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-left: 4px solid var(--callout-tint) !important;
  border-radius: 0 !important;
}
.focus.focus   { --callout-tint: #ea9344; }
.tldr.tldr     { --callout-tint: #7da9ed; }
.info.info     { --callout-tint: #5fbed1; }
.warning.warning { --callout-tint: #e8b04a; }
.error.error   { --callout-tint: #e07560; }
.focus.focus *, .tldr.tldr *, .info.info *, .warning.warning *, .error.error * {
  color: inherit;
}
.focus.focus strong, .tldr.tldr strong, .info.info strong, .warning.warning strong, .error.error strong {
  color: #f4f2ed;
}
.focus.focus a, .tldr.tldr a, .info.info a, .warning.warning a, .error.error a {
  color: var(--callout-tint);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.article-disclaimer {
  padding: 28px;
  border-radius: var(--ci-r-md);
  background: var(--ci-surface);
  border: 1px solid var(--ci-line);
  margin-bottom: 32px;
}
.article-disclaimer-text { font-size: 14px; color: var(--ci-text-2); line-height: 1.6; }
.article-author {
  display: flex; align-items: center; gap: 16px;
}
.article-author-avatar {
  width: 56px; height: 56px; border-radius: 50%;
  background: linear-gradient(135deg, oklch(0.66 0.17 25), oklch(0.74 0.14 35));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--ci-font-display); font-size: 24px; color: #2a0a0a;
  flex-shrink: 0;
}
.article-author-name { font-size: 15px; font-weight: 500; }
.article-author-role { font-size: 13px; color: var(--ci-text-3); }
.article-cover {
  aspect-ratio: 16 / 9;
  border-radius: var(--ci-r-md);
  overflow: hidden;
  position: relative;
  background: linear-gradient(135deg, oklch(0.78 0.16 145), oklch(0.55 0.16 145));
}
.article-cover img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
}
.article-cover-stripes {
  position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(45deg, rgba(0, 0, 0, 0.18) 0 1px, transparent 1px 12px),
    repeating-linear-gradient(-45deg, rgba(255, 255, 255, 0.06) 0 1px, transparent 1px 14px);
}
.article-cover-label {
  position: absolute; left: 16px; bottom: 14px;
  font-family: var(--ci-font-mono); font-size: 10px; letter-spacing: 0.16em;
  color: rgba(0, 0, 0, 0.6); text-transform: uppercase;
}
.article-scenarios { padding: 4px; margin-bottom: 32px; }

/* ── pros / cons (two-column lists) ───────────────── */
.ci-proscons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin: 28px 0;
}
.ci-proscons-card {
  padding: 22px 24px;
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
  background: var(--ci-surface);
}
.ci-proscons-pros {
  background: oklch(0.78 0.16 145 / 0.05);
  border-color: oklch(0.78 0.16 145 / 0.25);
}
.ci-proscons-cons {
  background: oklch(0.66 0.17 25 / 0.05);
  border-color: oklch(0.66 0.17 25 / 0.25);
}
.ci-proscons-title {
  font-family: var(--ci-font-display);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.15;
  margin-bottom: 18px;
}
.ci-proscons-pros .ci-proscons-title { color: var(--ci-pos); }
.ci-proscons-cons .ci-proscons-title { color: var(--ci-neg); }
.ci-proscons-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.ci-proscons-list li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 0;
  font-size: 15px;
  line-height: 1.5;
  color: var(--ci-text-2);
  border-top: 1px solid var(--ci-line);
}
.ci-proscons-list li:first-child { border-top: none; }
.ci-proscons-list li::before {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  font-size: 11px;
  font-weight: 600;
  margin-top: 2px;
}
.ci-proscons-pros .ci-proscons-list li::before {
  content: "✓";
  background: oklch(0.78 0.16 145 / 0.18);
  color: var(--ci-pos);
}
.ci-proscons-cons .ci-proscons-list li::before {
  content: "✕";
  background: oklch(0.66 0.17 25 / 0.18);
  color: var(--ci-neg);
}
.ci-proscons-icon {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}
.ci-proscons-pros .ci-proscons-icon {
  background: oklch(0.78 0.16 145 / 0.18);
  color: var(--ci-pos);
}
.ci-proscons-cons .ci-proscons-icon {
  background: oklch(0.66 0.17 25 / 0.18);
  color: var(--ci-neg);
}
@media (max-width: 720px) {
  .ci-proscons { grid-template-columns: 1fr; }
}
.related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}
@media (max-width: 960px) {
  .article-header-grid { grid-template-columns: 1fr; gap: 32px; }
  .article-layout { grid-template-columns: 1fr; gap: 32px; }
  .article-toc { position: static; }
  .related-grid { grid-template-columns: 1fr; }
  .article-cover { height: 220px; }
}

/* ── simulator (page-simulateur.php) ─────────────── */
.sim-intro { padding: 64px 0 32px; }
.sim-back {
  font-size: 13px; color: var(--ci-text-3);
  text-decoration: none; margin-bottom: 24px; display: inline-block;
}
.sim-back:hover { color: var(--ci-text-2); }
.sim-h1 {
  font-size: clamp(48px, 6vw, 88px);
  margin: 0 0 18px; line-height: 1.05;
}
.sim-body { padding: 40px 0 80px; }
.sim-grid {
  display: grid; grid-template-columns: 380px 1fr;
  gap: 32px; align-items: flex-start;
}
.sim-controls { padding: 28px; position: sticky; top: 96px; }
.sim-control { margin-bottom: 22px; }
.sim-control-row {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 8px;
}
.sim-control-label { font-size: 13px; font-weight: 500; }
.sim-control-value { font-family: var(--ci-font-display); font-size: 22px; }
.sim-control-value .unit { font-size: 13px; color: var(--ci-text-3); }
.sim-control input[type=range] { width: 100%; accent-color: var(--ci-accent); }
.sim-strategies { margin-bottom: 20px; }
.sim-strategies-title { font-size: 13px; font-weight: 500; margin-bottom: 12px; }
.sim-strategy {
  width: 100%; text-align: left; padding: 12px 14px; margin-bottom: 6px;
  background: transparent;
  border: 1px solid var(--ci-line);
  border-radius: 10px; color: inherit; cursor: pointer;
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--ci-font-sans);
  transition: background 0.15s, border-color 0.15s;
}
.sim-strategy:hover { background: rgba(255, 255, 255, 0.03); }
.sim-strategy.active { background: var(--ci-accent-soft); border-color: var(--ci-accent); }
.sim-strategy-name { font-size: 14px; font-weight: 500; margin-bottom: 2px; }
.sim-strategy-desc { font-size: 12px; color: var(--ci-text-3); }
.sim-strategy-rate { font-family: var(--ci-font-display); font-size: 20px; }
.sim-results-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; margin-bottom: 24px;
}
.sim-result {
  padding: 22px;
  background: var(--ci-surface);
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
}
.sim-result.accent {
  background: linear-gradient(135deg, var(--ci-accent-soft), oklch(0.74 0.14 60 / 0.04));
  border-color: oklch(0.74 0.14 60 / 0.4);
}
.sim-result-value { font-family: var(--ci-font-display); font-size: 32px; line-height: 1; color: var(--ci-text); }
.sim-result-value.positive { color: var(--ci-pos); }
.sim-chart-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 20px; flex-wrap: wrap; gap: 16px;
}
.sim-chart-title { font-family: var(--ci-font-display); font-size: 24px; }
.sim-legend { display: flex; gap: 18px; font-size: 13px; flex-wrap: wrap; }
.sim-legend-item { display: flex; align-items: center; gap: 8px; }
.sim-legend-line { width: 16px; height: 3px; background: var(--ci-accent); }
.sim-legend-line.dashed { background: rgba(255, 255, 255, 0.3); }
.sim-comparison { margin-top: 32px; }
.sim-comparison-table { padding: 4px; }
.sim-row-active { background: rgba(255, 255, 255, 0.03); }
.sim-disclaimer {
  margin-top: 32px; padding: 24px;
  background: var(--ci-surface);
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
  font-size: 13.5px; color: var(--ci-text-3); line-height: 1.6;
}
.sim-disclaimer strong { color: var(--ci-text-2); }
@media (max-width: 960px) {
  .sim-grid { grid-template-columns: 1fr; gap: 24px; }
  .sim-controls { position: static; }
  .sim-results-grid { grid-template-columns: 1fr; }
}

/* ── inline simulators (shortcode `[ci_simulateur]`) ── */
.ci-sim {
  margin: 28px 0;
  padding: 28px;
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
  background: var(--ci-surface);
}
.ci-sim-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 16px; flex-wrap: wrap;
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--ci-line);
}
.ci-sim-eyebrow {
  font-family: var(--ci-font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ci-text-3);
  margin-bottom: 6px;
}
.ci-sim-title {
  font-family: var(--ci-font-display);
  font-size: 26px;
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.ci-sim-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  align-items: flex-start;
}
.ci-sim-controls {
  display: flex; flex-direction: column; gap: 16px;
}
.ci-sim-field {
  display: flex; flex-direction: column; gap: 6px;
}
.ci-sim-field-row {
  display: flex; justify-content: space-between; align-items: baseline;
}
.ci-sim-field-label { font-size: 13px; font-weight: 500; }
.ci-sim-field-value {
  font-family: var(--ci-font-display);
  font-size: 18px;
  line-height: 1;
}
.ci-sim-field-value .unit {
  font-size: 12px; color: var(--ci-text-3);
}
.ci-sim-field input[type=range] {
  width: 100%; accent-color: var(--ci-accent);
}
.ci-sim-field input[type=number],
.ci-sim-field select {
  height: 40px;
  padding: 0 12px;
  border-radius: 10px;
  background: var(--ci-surface-2);
  border: 1px solid var(--ci-line);
  color: var(--ci-text);
  font-family: var(--ci-font-sans);
  font-size: 14px;
  outline: none;
  transition: border-color 0.15s;
}
.ci-sim-field input[type=number]:focus,
.ci-sim-field select:focus { border-color: var(--ci-accent); }

/* Result panel */
.ci-sim-results {
  display: flex; flex-direction: column; gap: 12px;
}
.ci-sim-kpi {
  padding: 16px 18px;
  border-radius: 12px;
  background: var(--ci-surface-2);
  border: 1px solid var(--ci-line);
}
.ci-sim-kpi.accent {
  background: linear-gradient(135deg, var(--ci-accent-soft), oklch(0.74 0.14 60 / 0.04));
  border-color: oklch(0.74 0.14 60 / 0.4);
}
.ci-sim-kpi-label {
  font-family: var(--ci-font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ci-text-3);
  margin-bottom: 6px;
}
.ci-sim-kpi-value {
  font-family: var(--ci-font-display);
  font-size: 28px; line-height: 1;
  color: var(--ci-text);
}
.ci-sim-kpi-value.positive { color: var(--ci-pos); }
.ci-sim-kpi-value.negative { color: var(--ci-neg); }

.ci-sim-chart {
  margin-top: 12px;
}
.ci-sim-foot {
  margin-top: 14px;
  font-size: 12px; color: var(--ci-text-3);
  line-height: 1.55;
}

/* Simulator detail table (compound interest, etc.) */
.ci-sim-table {
  margin-top: 16px;
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}
.ci-sim-table th,
.ci-sim-table td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--ci-line);
}
.ci-sim-table th {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ci-text-3);
}
.ci-sim-table tr:last-child td { border-bottom: none; }

@media (max-width: 720px) {
  .ci-sim-grid { grid-template-columns: 1fr; }
  .ci-sim { padding: 20px; }
}

/* ── amortization chart (credit + capacité) ───────── */
.ci-sim-amort {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--ci-line);
}
.ci-sim-amort-title {
  font-family: var(--ci-font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ci-text-3);
  margin-bottom: 12px;
}
.ci-sim-amort-svg {
  width: 100%;
  height: 200px;
  display: block;
}
.ci-sim-amort-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  font-size: 13px;
  color: var(--ci-text-2);
  margin-top: 12px;
}
.ci-sim-amort-legend > span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.ci-sim-amort-legend .swatch {
  display: inline-block;
  width: 12px; height: 12px;
  border-radius: 3px;
}
.ci-sim-amort-legend .swatch-capital  { background: var(--ci-accent); opacity: 0.85; }
.ci-sim-amort-legend .swatch-interest { background: oklch(0.66 0.17 25); opacity: 0.55; }
.ci-sim-amort-legend .swatch-insurance{ background: rgba(255, 255, 255, 0.22); }

/* ── donut chart (locatif) ────────────────────────── */
.ci-sim-donut-wrap {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--ci-line);
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 28px;
  align-items: center;
}
.ci-sim-donut {
  width: 240px; height: 240px;
  display: block;
  flex-shrink: 0;
}
.ci-sim-donut-legend {
  display: flex;
  flex-direction: column;
  gap: 10px;
  font-size: 14px;
}
.ci-sim-donut-legend-row {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 6px 0;
  border-bottom: 1px solid var(--ci-line);
}
.ci-sim-donut-legend-row:last-child { border-bottom: none; }
.ci-sim-donut-legend-swatch {
  width: 12px; height: 12px;
  border-radius: 3px;
}
.ci-sim-donut-legend-label { color: var(--ci-text-2); }
.ci-sim-donut-legend-value {
  font-family: var(--ci-font-mono);
  font-size: 13px;
  color: var(--ci-text);
  font-variant-numeric: tabular-nums;
}
@media (max-width: 720px) {
  .ci-sim-donut-wrap {
    grid-template-columns: 1fr;
    justify-items: center;
  }
}

/* ── WordPress core utility classes ─────────────── */
.alignleft   { float: left; margin: 0 24px 16px 0; }
.alignright  { float: right; margin: 0 0 16px 24px; }
.aligncenter { display: block; margin-left: auto; margin-right: auto; }
.alignwide   { max-width: 1080px; margin-left: auto; margin-right: auto; }
.alignfull   { width: 100%; }
.wp-caption .wp-caption-text {
  font-size: 13px; color: var(--ci-text-3); text-align: center; margin-top: 8px;
}
.screen-reader-text {
  border: 0; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%);
  height: 1px; width: 1px; margin: -1px; overflow: hidden; padding: 0;
  position: absolute !important; word-wrap: normal !important;
}
.sticky { background: var(--ci-surface-2); }
.bypostauthor { /* required by WP */ }

/* Simulator detail lead spans full container width (default .ci-lead is 56ch). */
.sim-intro .ci-lead { max-width: none; }

/* ── simulator SEO block (plein largeur, sous le widget) ────────────── */
.sim-seo-section {
  padding: 32px 0 80px;
  border-top: 1px solid var(--ci-line);
  margin-top: 24px;
}
.sim-seo {
  max-width: none;
  margin: 0;
  font-size: 16px;
  line-height: 1.7;
  color: var(--ci-text-2);
}
.sim-seo p { margin: 0 0 16px; }
.sim-seo p:last-child { margin-bottom: 0; }
.sim-seo strong { color: var(--ci-text); font-weight: 600; }
.sim-seo em { font-style: italic; color: var(--ci-text); }
.sim-seo code {
  font-family: var(--ci-font-mono);
  font-size: 0.92em;
  background: var(--ci-surface-2);
  border: 1px solid var(--ci-line);
  padding: 1px 6px;
  border-radius: 4px;
  color: var(--ci-text);
}

/* ── simulator hub ─────────────────────────────────── */
.sim-hub-intro { padding: 64px 0 32px; }
.sim-hub-h1 {
  font-size: clamp(40px, 5vw, 72px);
  margin: 0 0 18px;
  line-height: 1.05;
  letter-spacing: -0.02em;
}
.sim-hub-lead { max-width: 720px; margin: 0; }
.sim-hub-content { max-width: 720px; margin: 28px 0 0; }
.sim-hub-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.sim-hub-card {
  display: grid;
  grid-template-columns: 56px 1fr 24px;
  gap: 20px;
  align-items: center;
  padding: 24px 26px;
  background: var(--ci-surface);
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
  text-decoration: none;
  color: inherit;
  transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.sim-hub-card:hover {
  border-color: var(--ci-accent);
  transform: translateY(-2px);
  background: var(--ci-surface-2);
}
.sim-hub-card-glyph {
  width: 56px; height: 56px;
  border-radius: 14px;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(255, 255, 255, 0.04);
  flex-shrink: 0;
}
.sim-hub-card-title {
  font-family: var(--ci-font-display);
  font-size: 19px;
  letter-spacing: -0.005em;
  margin-bottom: 4px;
  color: var(--ci-text);
}
.sim-hub-card-desc {
  font-size: 13.5px;
  color: var(--ci-text-3);
  line-height: 1.45;
}
.sim-hub-card-arrow {
  font-size: 18px;
  color: var(--ci-text-3);
  transition: color 0.2s ease, transform 0.2s ease;
}
.sim-hub-card:hover .sim-hub-card-arrow {
  color: var(--ci-accent);
  transform: translateX(4px);
}
@media (max-width: 760px) {
  .sim-hub-grid { grid-template-columns: 1fr; }
}

/* ── archive / blog index ──────────────────────────── */
.ci-archive-head {
  margin-bottom: 56px;
  max-width: 100%;
}
.ci-archive-title {
  margin: 0;
  font-family: var(--ci-font-display);
  font-size: clamp(36px, 5vw, 56px);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.ci-archive-lead {
  margin-top: 18px;
  font-size: 17px;
  color: var(--ci-text-2);
  line-height: 1.6;
}
.ci-archive .ci-articles { grid-template-columns: repeat(3, 1fr); gap: 40px; }
.ci-archive .ci-article-title { font-size: 22px; }
.ci-archive .ci-article-excerpt { font-size: 14px; }
.ci-archive .ci-cover { aspect-ratio: 16 / 10; }
.ci-pagination {
  margin-top: 56px;
  display: flex; justify-content: center;
}
.ci-pagination .nav-links {
  display: flex; gap: 6px; flex-wrap: wrap;
}
.ci-pagination a,
.ci-pagination .current,
.ci-pagination .dots {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px;
  padding: 0 12px;
  border-radius: var(--ci-r-sm);
  font-size: 14px;
  text-decoration: none;
  color: var(--ci-text-2);
  border: 1px solid var(--ci-line);
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.ci-pagination a:hover {
  border-color: var(--ci-accent);
  color: var(--ci-text);
  background: var(--ci-accent-soft);
}
.ci-pagination .current {
  background: var(--ci-accent);
  color: var(--ci-accent-ink);
  border-color: var(--ci-accent);
  font-weight: 600;
}
.ci-pagination .dots { border-color: transparent; }
@media (max-width: 1100px) {
  .ci-archive .ci-articles { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .ci-archive .ci-articles { grid-template-columns: 1fr; }
}

/* ── Native forms + Contact Form 7 ─────────────────── */
.article-body input[type="text"],
.article-body input[type="email"],
.article-body input[type="url"],
.article-body input[type="tel"],
.article-body input[type="number"],
.article-body input[type="search"],
.article-body input[type="password"],
.article-body input[type="date"],
.article-body textarea,
.article-body select,
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="url"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="number"],
.wpcf7-form input[type="search"],
.wpcf7-form input[type="password"],
.wpcf7-form input[type="date"],
.wpcf7-form textarea,
.wpcf7-form select,
.ci-form input[type="text"],
.ci-form input[type="email"],
.ci-form input[type="url"],
.ci-form input[type="tel"],
.ci-form input[type="number"],
.ci-form input[type="search"],
.ci-form input[type="password"],
.ci-form input[type="date"],
.ci-form textarea,
.ci-form select {
  width: 100%;
  height: 48px;
  padding: 0 14px;
  border: 1px solid var(--ci-line-strong);
  border-radius: var(--ci-r-sm);
  background: var(--ci-bg-2);
  color: var(--ci-text);
  font-family: var(--ci-font-sans);
  font-size: 15px;
  line-height: 1.4;
  transition: border-color 0.15s ease, background 0.15s ease;
  appearance: none;
  -webkit-appearance: none;
}
.article-body textarea,
.wpcf7-form textarea,
.ci-form textarea {
  height: auto;
  min-height: 140px;
  padding: 12px 14px;
  resize: vertical;
}
.article-body select,
.wpcf7-form select,
.ci-form select {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23c8c5bf' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  padding-right: 38px;
}
.article-body input::placeholder,
.wpcf7-form input::placeholder,
.ci-form input::placeholder,
.article-body textarea::placeholder,
.wpcf7-form textarea::placeholder,
.ci-form textarea::placeholder { color: var(--ci-text-4); }
.article-body input:focus,
.article-body textarea:focus,
.article-body select:focus,
.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus,
.ci-form input:focus,
.ci-form textarea:focus,
.ci-form select:focus {
  outline: none;
  border-color: var(--ci-accent);
  background: var(--ci-surface);
}
.article-body label,
.wpcf7-form label,
.ci-form label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--ci-text-2);
  margin-bottom: 8px;
}
.article-body input[type="checkbox"],
.article-body input[type="radio"],
.wpcf7-form input[type="checkbox"],
.wpcf7-form input[type="radio"],
.ci-form input[type="checkbox"],
.ci-form input[type="radio"] {
  width: auto; height: auto;
  accent-color: var(--ci-accent);
  margin-right: 6px;
}
.article-body input[type="submit"],
.wpcf7-form input[type="submit"],
.wpcf7-submit,
.ci-form button[type="submit"] {
  display: inline-flex; align-items: center; justify-content: center;
  height: 48px; padding: 0 22px;
  border: 1px solid transparent;
  border-radius: var(--ci-r-sm);
  background: var(--ci-accent);
  color: var(--ci-accent-ink);
  font-family: var(--ci-font-sans);
  font-size: 15px; font-weight: 600;
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.15s ease;
  text-decoration: none;
}
.article-body input[type="submit"]:hover,
.wpcf7-form input[type="submit"]:hover,
.wpcf7-submit:hover,
.ci-form button[type="submit"]:hover {
  background: var(--ci-accent-2);
  transform: translateY(-1px);
}
.wpcf7-not-valid-tip { color: oklch(0.74 0.17 25); font-size: 13px; margin-top: 6px; }
.wpcf7-response-output {
  margin: 16px 0 0 !important;
  padding: 12px 16px !important;
  border-radius: var(--ci-r-sm) !important;
  border: 1px solid var(--ci-line-strong) !important;
  background: var(--ci-surface) !important;
  color: var(--ci-text-2);
  font-size: 14px;
}
.wpcf7-spinner { background: var(--ci-accent); }
:focus-visible {
  outline: 2px solid var(--ci-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

/* ── Editorial tables (wp-block-table + raw <table>) ─── */
.article-body figure.wp-block-table,
.article-body table {
  margin: 28px 0;
  font-size: 14.5px;
}
.article-body figure.wp-block-table {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.article-body figure.wp-block-table > table,
.article-body table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  border: 1px solid var(--ci-line);
  border-radius: var(--ci-r-md);
  overflow: hidden;
  background: var(--ci-bg-2);
}
.article-body figure.wp-block-table caption,
.article-body table caption {
  caption-side: top;
  text-align: left;
  padding: 0 0 10px;
  color: var(--ci-text-2);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.article-body figcaption {
  margin-top: 10px;
  color: var(--ci-text-3);
  font-size: 13px;
  font-style: italic;
  text-align: center;
}
.article-body th,
.article-body td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--ci-line);
  text-align: left;
  vertical-align: top;
}
.article-body th {
  background: var(--ci-surface-2);
  color: var(--ci-text);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.article-body th[scope="row"] {
  background: var(--ci-bg-2);
  color: var(--ci-text);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
  border-right: 1px solid var(--ci-line);
}
.article-body tr:last-child td,
.article-body tr:last-child th { border-bottom: none; }
.article-body tbody tr:nth-child(even) td { background: rgba(255,255,255,0.02); }
.article-body tr:hover td { background: var(--ci-accent-soft); }
.article-body figure.wp-block-table.is-warm > table,
.article-body table.is-style-stripes,
.article-body table.is-warm {
  border-color: oklch(0.74 0.14 60 / 0.32);
}
.article-body figure.wp-block-table.is-warm th:not([scope="row"]),
.article-body table.is-style-stripes thead th,
.article-body table.is-warm thead th {
  background: oklch(0.74 0.14 60 / 0.18);
  color: var(--ci-text);
}
.article-body figure.wp-block-table.is-warm tbody tr:nth-child(even) td,
.article-body table.is-style-stripes tbody tr:nth-child(even) td,
.article-body table.is-warm tbody tr:nth-child(even) td {
  background: oklch(0.74 0.14 60 / 0.06);
}
@media (max-width: 640px) {
  .article-body th, .article-body td { padding: 10px 10px; font-size: 13.5px; }
}
