/* ═══ Citizen Analyzer — Site Web ═══ */
:root {
  --bg: #080d19;
  --bg-card: #111827;
  --bg-hover: #0f1629;
  --border: #1e293b;
  --border-hover: rgba(99,102,241,0.2);
  --text: #e2e8f0;
  --text-dim: #94a3b8;
  --text-muted: #475569;
  --text-faint: #334155;
  --accent: #818cf8;
  --accent-light: #a5b4fc;
  --accent-bg: rgba(99,102,241,0.1);
  --accent-border: rgba(99,102,241,0.25);
  --green: #4ade80;
  --yellow: #f59e0b;
  --red: #ef4444;
  --pink: #fb7185;
  --blue: #60a5fa;
  --font: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-mono: 'JetBrains Mono', monospace;
  --max-w: 1100px;
  --radius: 12px;
  --radius-sm: 8px;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
body { font-family:var(--font); background:var(--bg); color:var(--text); -webkit-font-smoothing:antialiased; overflow-x:hidden; }
a { color:var(--accent); text-decoration:none; }
a:hover { color:var(--accent-light); }
img { max-width:100%; }
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--border); border-radius:3px; }

/* ═══ NAV ═══ */
.nav { display:flex; align-items:center; justify-content:space-between; padding:12px 24px; border-bottom:1px solid var(--border); background:rgba(10,15,26,0.95); backdrop-filter:blur(12px); position:sticky; top:0; z-index:100; }
.nav-brand { display:flex; align-items:center; gap:8px; text-decoration:none; color:var(--text); }
.nav-logo { width:32px; height:32px; border-radius:8px; background:#6366f1; display:flex; align-items:center; justify-content:center; font-size:18px; font-weight:900; color:white; }
.nav-name { font-size:15px; font-weight:700; }
.nav-name span { color:var(--accent); }
.nav-links { display:flex; gap:16px; align-items:center; }
.nav-links a { color:var(--text-dim); font-size:12px; font-weight:600; transition:color .2s; }
.nav-links a:hover, .nav-links a.active { color:var(--accent-light); }
.nav-cta { padding:6px 14px !important; border-radius:6px; background:#6366f1; color:white !important; font-size:11px !important; }
.nav-cta:hover { background:#4f46e5; }
.nav-hamburger { display:none; background:none; border:none; color:var(--text-dim); font-size:20px; cursor:pointer; }
@media (max-width:768px) {
  .nav-links { display:none; flex-direction:column; position:absolute; top:100%; left:0; right:0; background:var(--bg-card); border-bottom:1px solid var(--border); padding:16px; gap:12px; }
  .nav-links.open { display:flex; }
  .nav-hamburger { display:block; }
}

/* ═══ LAYOUT ═══ */
.container { max-width:var(--max-w); margin:0 auto; padding:0 20px; }
.page-header { text-align:center; padding:48px 20px 28px; }
.section-label { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.15em; color:var(--accent); margin-bottom:8px; }
.page-title { font-size:32px; font-weight:800; font-family:var(--font-display); background:linear-gradient(135deg,#c7d2fe,#818cf8); -webkit-background-clip:text; -webkit-text-fill-color:transparent; margin-bottom:8px; }
.page-sub { font-size:14px; color:var(--text-dim); max-width:600px; margin:0 auto; line-height:1.6; }
.section-title { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--text-faint); margin:24px 0 10px; padding-top:14px; border-top:1px solid var(--border); }

/* ═══ SEARCH ═══ */
.search-wrapper { position:relative; margin-bottom:24px; }
.search-box { display:flex; align-items:center; gap:8px; padding:12px 16px; background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); transition:border-color .2s; }
.search-box:focus-within { border-color:rgba(99,102,241,0.4); }
.search-icon { font-size:16px; color:var(--text-muted); flex-shrink:0; }
.search-input { flex:1; background:transparent; border:none; color:var(--text); font-size:14px; font-family:var(--font); outline:none; }
.search-input::placeholder { color:var(--text-faint); }
.search-clear { font-size:12px; color:var(--text-muted); cursor:pointer; padding:4px; }
.search-results { position:absolute; top:100%; left:0; right:0; margin-top:4px; background:var(--bg-card); border:1px solid var(--accent-border); border-radius:var(--radius); max-height:400px; overflow-y:auto; z-index:50; box-shadow:0 12px 40px rgba(0,0,0,0.5); }
.search-section { padding:8px 14px 4px; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--text-faint); }
.search-item { display:flex; align-items:center; gap:10px; padding:10px 14px; cursor:pointer; transition:background .15s; }
.search-item:hover { background:rgba(99,102,241,0.06); }
.search-item-icon { width:32px; height:32px; border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; background:var(--accent-bg); }
.search-item-icon.person { border-radius:50%; }
.search-item-info { flex:1; min-width:0; }
.search-item-name { font-size:12px; font-weight:600; }
.search-item-name mark { background:transparent; color:var(--accent); font-weight:700; }
.search-item-sub { font-size:10px; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.search-item-score { font-size:12px; font-weight:700; flex-shrink:0; }
.search-empty { padding:20px; text-align:center; color:var(--text-muted); font-size:12px; }
.search-hints { display:flex; gap:6px; justify-content:center; flex-wrap:wrap; margin-top:8px; }
.search-hint { font-size:10px; padding:4px 10px; border-radius:20px; background:var(--accent-bg); color:var(--accent); cursor:pointer; border:1px solid rgba(99,102,241,0.1); }
.search-hint:hover { border-color:var(--accent-border); }

/* ═══ COUNTRY SELECTOR ═══ */
.countries { display:flex; gap:8px; justify-content:center; margin:16px 0 24px; flex-wrap:wrap; }
.country-btn { padding:8px 16px; border:1px solid var(--border); border-radius:var(--radius-sm); background:var(--bg-card); color:var(--text-dim); font-size:12px; font-weight:600; cursor:pointer; font-family:var(--font); transition:all .2s; display:flex; align-items:center; gap:6px; }
.country-btn:hover { border-color:var(--border-hover); }
.country-btn.active { background:var(--accent-bg); color:var(--accent-light); border-color:var(--accent-border); }
.country-flag { font-size:18px; }
.country-count { font-size:9px; color:var(--text-muted); background:rgba(100,116,139,0.1); padding:1px 5px; border-radius:3px; }

/* ═══ CATEGORY TABS ═══ */
.cat-tabs { display:flex; gap:4px; margin-bottom:20px; flex-wrap:wrap; }
.cat-tab { padding:8px 14px; border:1px solid var(--border); border-radius:var(--radius-sm); background:transparent; color:var(--text-muted); font-size:11px; font-weight:600; cursor:pointer; font-family:var(--font); transition:all .2s; }
.cat-tab.active { background:var(--accent-bg); color:var(--accent-light); border-color:var(--accent-border); }

/* ═══ ENTITY GRID ═══ */
.entity-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:10px; margin-bottom:30px; }
.entity-card { background:var(--bg-card); border:1px solid var(--border); border-radius:var(--radius); padding:16px; cursor:pointer; transition:all .2s; text-decoration:none; color:inherit; display:block; }
.entity-card:hover { border-color:var(--border-hover); transform:translateY(-2px); }
.entity-head { display:flex; align-items:center; gap:10px; margin-bottom:8px; }
.entity-avatar { width:36px; height:36px; border-radius:var(--radius-sm); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.entity-avatar[data-type="party"] { background:var(--accent-bg); }
.entity-avatar[data-type="institution"] { background:rgba(245,158,11,0.1); }
.entity-avatar[data-type="media"] { background:rgba(239,68,68,0.1); }
.entity-avatar[data-type="org"] { background:rgba(74,222,128,0.1); }
.entity-avatar[data-type="syndicat"] { background:rgba(96,165,250,0.1); }
.entity-avatar[data-type="thinktank"] { background:rgba(168,85,247,0.1); }
.entity-avatar[data-type="personnalite"] { background:rgba(251,113,133,0.1); }
.entity-name { font-size:13px; font-weight:700; }
.entity-sub { font-size:10px; color:var(--text-muted); }
.entity-stats { display:flex; gap:12px; margin-top:8px; }
.entity-stat { font-size:9px; color:var(--text-muted); }
.entity-stat strong { color:var(--text-dim); }
.entity-score-bar { height:3px; border-radius:2px; background:var(--border); margin-top:6px; overflow:hidden; }
.entity-score-fill { height:100%; border-radius:2px; }

/* ═══ SCORE COLORS ═══ */
.score-ok { color:var(--green); }
.score-warn { color:var(--yellow); }
.score-bad { color:var(--red); }
[data-l="ok"] { color:var(--green); border-color:rgba(74,222,128,0.3); }
[data-l="warn"] { color:var(--yellow); border-color:rgba(245,158,11,0.3); }
[data-l="bad"] { color:var(--red); border-color:rgba(239,68,68,0.3); }

/* ═══ BADGES ═══ */
.badge { font-size:9px; font-weight:700; padding:2px 6px; border-radius:4px; }
.badge-accent { background:var(--accent-bg); color:var(--accent); }
.badge-green { background:rgba(74,222,128,0.1); color:var(--green); }
.badge-yellow { background:rgba(245,158,11,0.1); color:var(--yellow); }
.badge-red { background:rgba(239,68,68,0.1); color:var(--red); }

/* ═══ BUTTONS ═══ */
.btn { padding:10px 20px; border:none; border-radius:var(--radius-sm); font-size:13px; font-weight:700; cursor:pointer; font-family:var(--font); transition:all .2s; text-align:center; display:inline-block; }
.btn-primary { background:#6366f1; color:white; }
.btn-primary:hover { background:#4f46e5; }
.btn-outline { background:transparent; border:1px solid var(--border); color:var(--text-dim); }
.btn-outline:hover { border-color:var(--accent-border); color:var(--accent-light); }

/* ═══ STATS ═══ */
.stats-row { display:flex; gap:30px; justify-content:center; padding:20px; margin-bottom:20px; }
.stat-item { text-align:center; }
.stat-value { font-size:32px; font-weight:800; color:var(--accent); }
.stat-label { font-size:11px; color:var(--text-muted); margin-top:2px; }

/* ═══ PENDING BANNER ═══ */
.pending-banner { text-align:center; padding:14px; margin:30px 0; border:1px dashed rgba(99,102,241,0.15); border-radius:var(--radius-sm); color:var(--text-muted); font-size:12px; }

/* ═══ FOOTER ═══ */
.footer { border-top:1px solid var(--border); padding:24px; text-align:center; margin-top:40px; }
.footer-text { font-size:12px; color:var(--text-muted); }
.footer-small { font-size:11px; color:var(--text-faint); margin-top:4px; }

/* ═══ HERO ═══ */
.hero { padding:60px 20px 40px; text-align:center; position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; top:-50%; left:-20%; width:140%; height:200%; background:radial-gradient(ellipse at 50% 0%, rgba(99,102,241,0.06) 0%, transparent 60%); pointer-events:none; }
.hero-title { font-size:42px; font-weight:900; font-family:var(--font-display); background:linear-gradient(135deg,#e2e8f0,#818cf8,#c7d2fe); -webkit-background-clip:text; -webkit-text-fill-color:transparent; margin-bottom:12px; line-height:1.1; }
.hero-sub { font-size:16px; color:var(--text-dim); max-width:550px; margin:0 auto 24px; line-height:1.6; }
.hero-actions { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }
@media (max-width:768px) {
  .hero-title { font-size:28px; }
  .hero-sub { font-size:14px; }
  .entity-grid { grid-template-columns:1fr; }
  .stats-row { flex-wrap:wrap; gap:16px; }
}
