/**
 * IJVA - CSS Minifié (variables + base + components + pages)
 * Version: 1.1.0 - Responsive amélioré
 */
:root{--ijva-gold:#F6B91E;--ijva-emerald:#0FA58A;--ijva-teal:#0B6F6A;--ijva-charcoal:#4A4F55;--primary:var(--ijva-emerald);--primary-light:#12C4A0;--primary-dark:var(--ijva-teal);--accent:var(--ijva-gold);--accent-light:#F9C84A;--gold:var(--ijva-gold);--gold-dark:#D9A31A;--bg-cream:#F8FAFC;--bg-light:#FAFAFA;--bg-white:#FFFFFF;--bg-dark:#0B1220;--text-dark:#111827;--text-medium:#6B7280;--text-light:#9CA3AF;--text-white:#FFFFFF;--pilier-securite:#4A148C;--pilier-securite-light:#7B1FA2;--pilier-materiel:#0277BD;--pilier-materiel-light:#0288D1;--pilier-ubuntu:var(--ijva-teal);--pilier-ubuntu-light:var(--ijva-emerald);--pilier-vitalite:#E65100;--pilier-vitalite-light:#EF6C00;--cat-epanoui:var(--ijva-emerald);--cat-serein:#10B981;--cat-resilient:var(--ijva-gold);--cat-fragile:#F59E0B;--cat-vulnerable:#EF4444;--score-excellent:var(--ijva-emerald);--score-bon:#10B981;--score-moyen:var(--ijva-gold);--score-faible:#F59E0B;--score-critique:#DC2626;--shadow-sm:0 1px 3px rgba(0,0,0,.08);--shadow-md:0 4px 6px rgba(0,0,0,.1);--shadow-lg:0 10px 25px rgba(0,0,0,.15);--shadow-xl:0 20px 40px rgba(0,0,0,.2);--border-light:1px solid #E5E7EB;--border-medium:1px solid #D1D5DB;--radius-sm:8px;--radius-md:12px;--radius-lg:20px;--radius-full:50%;--space-xs:0.25rem;--space-sm:0.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--space-3xl:4rem;--font-title:'Montserrat','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;--font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:2rem;--text-4xl:2.5rem;--text-5xl:3rem;--max-width:1200px;--max-width-narrow:800px;--transition-fast:150ms ease;--transition-base:300ms ease;--transition-slow:500ms ease;--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-tooltip:400}
@media(prefers-color-scheme:dark){:root{--bg-cream:#0F1A2E;--bg-light:#0B1220;--bg-white:#0B1220;--bg-dark:#060A10;--text-dark:#F9FAFB;--text-medium:#B6C2D2;--text-light:#6B7280;--border-light:1px solid #22324D;--border-medium:1px solid #334155;--primary:#18BFA2;--primary-light:#20D9B8;--accent:#FFD36B;--shadow-sm:0 1px 3px rgba(0,0,0,.3);--shadow-md:0 4px 6px rgba(0,0,0,.4);--shadow-lg:0 10px 25px rgba(0,0,0,.5)}}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);font-size:var(--text-base);line-height:1.6;color:var(--text-dark);background:var(--bg-cream);min-height:100vh}
h1,h2,h3,h4,h5,h6{font-family:var(--font-title);font-weight:600;line-height:1.2;color:var(--primary-dark);margin-bottom:var(--space-md)}
h1{font-size:var(--text-5xl)}h2{font-size:var(--text-4xl)}h3{font-size:var(--text-3xl)}h4{font-size:var(--text-2xl)}h5{font-size:var(--text-xl)}h6{font-size:var(--text-lg)}
p{margin-bottom:var(--space-md)}
a{color:var(--primary);text-decoration:none;transition:color var(--transition-fast)}
a:hover{color:var(--accent)}
ul,ol{margin-bottom:var(--space-md);padding-left:var(--space-xl)}
li{margin-bottom:var(--space-xs)}
img{max-width:100%;height:auto;display:block}
table{width:100%;border-collapse:collapse;margin-bottom:var(--space-lg)}
th,td{padding:var(--space-sm) var(--space-md);text-align:left;border-bottom:var(--border-light)}
th{font-weight:600;background:var(--bg-light);color:var(--primary-dark)}
tbody tr:hover{background:rgba(27,94,32,.03)}
input,select,textarea,button{font-family:inherit;font-size:inherit}
input[type="text"],input[type="email"],input[type="search"],select,textarea{width:100%;padding:var(--space-sm) var(--space-md);border:var(--border-medium);border-radius:var(--radius-sm);background:var(--bg-white);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(27,94,32,.1)}
.container{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 var(--space-lg)}
.container-narrow{max-width:var(--max-width-narrow)}
.section{padding:var(--space-3xl) 0}
.section-title{text-align:center;margin-bottom:var(--space-2xl)}
.section-title h2{margin-bottom:var(--space-sm)}
.section-title p{color:var(--text-medium);font-size:var(--text-lg);max-width:600px;margin:0 auto}
.grid{display:grid;gap:var(--space-lg)}
.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-wrap{flex-wrap:wrap}
.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}
.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--text-medium)}.text-sm{font-size:var(--text-sm)}.text-lg{font-size:var(--text-lg)}.font-bold{font-weight:700}
.mt-1{margin-top:var(--space-sm)}.mt-2{margin-top:var(--space-md)}.mt-3{margin-top:var(--space-lg)}.mt-4{margin-top:var(--space-xl)}
.mb-1{margin-bottom:var(--space-sm)}.mb-2{margin-bottom:var(--space-md)}.mb-3{margin-bottom:var(--space-lg)}.mb-4{margin-bottom:var(--space-xl)}
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-to-content{position:absolute;top:-100px;left:50%;transform:translateX(-50%);background:var(--primary-dark);color:var(--text-white);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-sm);z-index:9999;font-weight:600;text-decoration:none;transition:top .3s ease}
.skip-to-content:focus{top:var(--space-md);outline:3px solid var(--gold);outline-offset:2px}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--gold);outline-offset:2px}
.card:focus-visible,.btn:focus-visible,.top-item:focus-visible,.region-card:focus-visible,.pilier-card:focus-visible{outline:3px solid var(--gold);outline-offset:2px;box-shadow:0 0 0 6px rgba(246,185,30,.3)}
.desktop-nav a:focus-visible,.mobile-nav a:focus-visible{outline:2px solid var(--gold);outline-offset:2px;background:rgba(255,255,255,.2)}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.skip-to-content{transition:none}}
@media(max-width:1024px){html{font-size:15px}}
@media(max-width:768px){html{font-size:14px}.container{padding:0 var(--space-md)}.section{padding:var(--space-2xl) 0}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--text-base);font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}
.btn-primary{background:var(--primary);color:var(--text-white)}.btn-primary:hover{background:var(--primary-dark);color:var(--text-white);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn-secondary{background:var(--bg-white);color:var(--primary);border:2px solid var(--primary)}.btn-secondary:hover{background:var(--primary);color:var(--text-white)}
.btn-accent{background:var(--accent);color:var(--ijva-charcoal);font-weight:600}.btn-accent:hover{background:var(--accent-light);color:var(--ijva-charcoal)}
.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--text-sm)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--text-lg)}
.card{background:var(--bg-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform var(--transition-base),box-shadow var(--transition-base)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-body{padding:var(--space-lg)}.card-header{padding:var(--space-md) var(--space-lg);border-bottom:var(--border-light);background:var(--bg-light)}.card-footer{padding:var(--space-md) var(--space-lg);border-top:var(--border-light);background:var(--bg-light)}
.card-glass{background:rgba(255,255,255,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}
.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:var(--text-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-sm)}
.badge-epanoui{background:rgba(15,165,138,.15);color:var(--cat-epanoui)}.badge-serein{background:rgba(76,175,80,.15);color:var(--cat-serein)}.badge-resilient{background:rgba(255,193,7,.15);color:#B8860B}.badge-fragile{background:rgba(255,152,0,.15);color:var(--cat-fragile)}.badge-vulnerable{background:rgba(244,67,54,.15);color:var(--cat-vulnerable)}
.score-display{display:flex;flex-direction:column;align-items:center;justify-content:center}.score-value{font-family:var(--font-title);font-size:var(--text-5xl);font-weight:700;line-height:1}.score-label{font-size:var(--text-sm);color:var(--text-medium);text-transform:uppercase;letter-spacing:1px}
.score-excellent{color:var(--score-excellent)}.score-bon{color:var(--score-bon)}.score-moyen{color:var(--score-moyen)}.score-faible{color:var(--score-faible)}.score-critique{color:var(--score-critique)}
.pilier-card{padding:var(--space-lg);border-radius:var(--radius-md);text-align:center}
.pilier-securite{background:linear-gradient(135deg,var(--pilier-securite) 0%,var(--pilier-securite-light) 100%);color:white}
.pilier-materiel{background:linear-gradient(135deg,var(--pilier-materiel) 0%,var(--pilier-materiel-light) 100%);color:white}
.pilier-ubuntu{background:linear-gradient(135deg,var(--pilier-ubuntu) 0%,var(--pilier-ubuntu-light) 100%);color:white}
.pilier-vitalite{background:linear-gradient(135deg,var(--pilier-vitalite) 0%,var(--pilier-vitalite-light) 100%);color:white}
.pilier-icon{font-size:var(--text-3xl);margin-bottom:var(--space-sm)}
.pilier-icon-img{width:48px;height:48px;object-fit:contain;vertical-align:middle}
.pilier-icon-img.small{width:24px;height:24px}.pilier-icon-img.medium{width:32px;height:32px}.pilier-icon-img.large{width:48px;height:48px}.pilier-icon-img.xlarge{width:64px;height:64px}
th .pilier-icon-img{width:24px;height:24px}
.pilier-score{font-family:var(--font-title);font-size:var(--text-4xl);font-weight:700}
.pilier-name{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:1px;opacity:.9;margin-bottom:var(--space-xs);color:inherit}h3.pilier-name{font-size:var(--text-sm);color:inherit;margin-bottom:var(--space-xs)}
.rang{display:flex;align-items:center;justify-content:center;width:40px;height:40px;font-family:var(--font-title);font-weight:700;border-radius:var(--radius-full);background:var(--bg-light);color:var(--text-dark)}
.rang-1{background:linear-gradient(135deg,#FFD700 0%,#FFA000 100%);color:white;box-shadow:0 4px 15px rgba(255,215,0,.4)}
.rang-2{background:linear-gradient(135deg,#C0C0C0 0%,#A0A0A0 100%);color:white}
.rang-3{background:linear-gradient(135deg,#CD7F32 0%,#A0522D 100%);color:white}
.classement-table{width:100%;background:var(--bg-white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.classement-table th{background:var(--primary);color:var(--text-white);font-weight:600;padding:var(--space-md)}
.classement-table td{padding:var(--space-md);vertical-align:middle}
.classement-table tbody tr{transition:background var(--transition-fast)}.classement-table tbody tr:hover{background:rgba(15,165,138,.08)}
.pays-cell{display:flex;align-items:center;gap:var(--space-sm)}
.progress-bar{height:8px;background:var(--bg-light);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:4px;transition:width var(--transition-base)}
.alert{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}
.alert-info{background:rgba(2,119,189,.1);color:var(--pilier-materiel);border-left:4px solid var(--pilier-materiel)}
.alert-success{background:rgba(46,125,50,.1);color:var(--primary);border-left:4px solid var(--primary)}
.alert-warning{background:rgba(255,152,0,.1);color:var(--cat-fragile);border-left:4px solid var(--cat-fragile)}
.alert-error{background:rgba(244,67,54,.1);color:var(--cat-vulnerable);border-left:4px solid var(--cat-vulnerable)}
.search-box{position:relative}.search-input{padding-left:45px!important}.search-icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);color:var(--text-medium)}
.search-results{position:absolute;top:100%;left:0;right:0;background:var(--bg-white);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);max-height:300px;overflow-y:auto}
.search-result-item{padding:var(--space-sm) var(--space-md);cursor:pointer;display:flex;align-items:center;gap:var(--space-sm);transition:background var(--transition-fast)}.search-result-item:hover{background:var(--bg-light)}
.filters{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}
.filter-btn{padding:var(--space-xs) var(--space-md);background:var(--bg-white);border:var(--border-medium);border-radius:var(--radius-lg);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast)}
.filter-btn:hover,.filter-btn.active{background:var(--primary);color:var(--text-white);border-color:var(--primary)}
.filter-select{padding:var(--space-sm) var(--space-md);border:var(--border-medium);border-radius:var(--radius-sm);background:var(--bg-white);cursor:pointer}
[data-tooltip]{position:relative}[data-tooltip]::after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translateX(-50%);padding:var(--space-xs) var(--space-sm);background:var(--bg-dark);color:var(--text-white);font-size:var(--text-xs);border-radius:var(--radius-sm);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity var(--transition-fast);z-index:var(--z-tooltip)}[data-tooltip]:hover::after{opacity:1;visibility:visible}
.spinner{width:40px;height:40px;border:3px solid var(--bg-light);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal)}
.site-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-white);padding:var(--space-md) 0;position:sticky;top:0;z-index:var(--z-sticky);box-shadow:var(--shadow-md)}
.header-content{display:flex;align-items:center;justify-content:space-between}
.site-logo{display:flex;align-items:center;text-decoration:none}
.site-logo .logo-img{height:50px;width:auto;transition:transform var(--transition-fast)}.site-logo:hover .logo-img{transform:scale(1.05)}
.desktop-nav{display:flex;align-items:center;gap:var(--space-lg)}
.desktop-nav a{color:rgba(255,255,255,.9);font-weight:500;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast)}
.desktop-nav a:hover,.desktop-nav a.active{color:var(--text-white);background:rgba(255,255,255,.15)}
.mobile-nav{display:none!important}
@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-white);font-size:var(--text-2xl);cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast)}
.mobile-menu-btn:hover{background:rgba(255,255,255,.15)}
@media(max-width:968px){.desktop-nav{display:none!important}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.mobile-nav{display:none!important;flex-direction:column;background:var(--primary-dark);padding:0;box-shadow:0 10px 30px rgba(0,0,0,.3);width:100%}.mobile-nav.active{display:flex!important;animation:slideDown .25s ease-out}.mobile-nav a{width:100%;text-align:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid rgba(255,255,255,.1);font-size:var(--text-lg);color:rgba(255,255,255,.95);display:block;text-decoration:none}.mobile-nav a:last-child{border-bottom:none}.mobile-nav a:hover,.mobile-nav a.active{background:rgba(255,255,255,.15);color:white}.hero-stats{flex-wrap:wrap;gap:var(--space-lg)}.hero-stat{flex:1 1 40%}.pays-header-content{flex-direction:column;text-align:center}.pays-score-hero{margin-left:0;margin-top:var(--space-lg)}.pays-meta{flex-wrap:wrap;justify-content:center;gap:var(--space-sm)}.region-stats{flex-wrap:wrap}.region-stat{flex:1 1 40%}}
@media(max-width:480px){.site-logo .logo-img{height:40px}.hero h1{font-size:var(--text-3xl)}.hero-subtitle{font-size:var(--text-base)}.hero-stat-value{font-size:var(--text-2xl)}.pays-score-value{font-size:3.5rem}.classement-header{flex-direction:column;align-items:stretch}.classement-filters{flex-direction:column}.classement-search{min-width:100%}.classement-table{font-size:var(--text-sm)}.classement-table th,.classement-table td{padding:var(--space-xs) var(--space-sm)}.pays-piliers{grid-template-columns:repeat(2,1fr)}.pilier-score{font-size:var(--text-2xl)}}
.site-footer{background:var(--bg-dark);color:var(--text-white);padding:var(--space-3xl) 0 var(--space-xl);margin-top:auto}
.footer-content{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2xl)}
.footer-section h4{color:var(--gold);margin-bottom:var(--space-lg);font-size:var(--text-lg)}
.footer-section ul{list-style:none;padding:0}.footer-section li{margin-bottom:var(--space-sm)}
.footer-section a{color:rgba(255,255,255,.7)}.footer-section a:hover{color:var(--text-white)}
.footer-bottom{margin-top:var(--space-2xl);padding-top:var(--space-lg);border-top:1px solid rgba(255,255,255,.1);text-align:center;color:rgba(255,255,255,.5);font-size:var(--text-sm)}
@media(max-width:768px){.footer-content{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.footer-content{grid-template-columns:1fr}}
.hero{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-white);padding:var(--space-3xl) 0;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><circle cx="50" cy="50" r="40" fill="none" stroke="rgba(255,255,255,0.05)" stroke-width="2"/></svg>') repeat;opacity:.5}
.hero-content{position:relative;z-index:1;max-width:800px;margin:0 auto}
.hero h1{color:var(--text-white);font-size:var(--text-5xl);margin-bottom:var(--space-md)}.hero h1 span{color:var(--gold)}
.hero-subtitle{font-size:var(--text-xl);opacity:.9;margin-bottom:var(--space-xl)}
.hero-stats{display:flex;justify-content:center;gap:var(--space-2xl);margin-top:var(--space-2xl)}
.hero-stat{text-align:center}.hero-stat-value{font-family:var(--font-title);font-size:var(--text-4xl);font-weight:700;color:var(--gold)}.hero-stat-label{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:1px;opacity:.8}
.map-section{padding:var(--space-3xl) 0;background:var(--bg-white)}
.africa-map-container{max-width:800px;margin:0 auto;position:relative}
.africa-map{width:100%;height:auto}.africa-map path{transition:all var(--transition-fast);cursor:pointer;stroke:#fff;stroke-width:.5}.africa-map path:hover{filter:brightness(1.1);stroke-width:2}
.map-tooltip{position:absolute;background:var(--bg-dark);color:var(--text-white);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:var(--text-sm);pointer-events:none;opacity:0;transition:opacity var(--transition-fast);z-index:var(--z-tooltip)}.map-tooltip.active{opacity:1}
.map-legend{display:flex;justify-content:center;gap:var(--space-lg);margin-top:var(--space-lg);flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--text-sm)}.legend-color{width:20px;height:20px;border-radius:4px}
.region-card{position:relative;min-height:200px;background-size:cover;background-position:center;border-radius:var(--radius-md);overflow:hidden;text-decoration:none;display:block}
.region-card-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,rgba(11,111,106,.85) 0%,rgba(15,165,138,.75) 100%);padding:var(--space-xl);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-white);transition:all var(--transition-base)}
.region-card:hover .region-card-overlay{background:rgba(0,0,0,.3)}
.region-card h4{color:var(--text-white);margin-bottom:var(--space-sm);font-size:var(--text-xl)}
.region-card .score-value{color:var(--ijva-gold)!important;font-weight:700}
.region-card .score-label{color:rgba(255,255,255,.9);text-transform:uppercase;font-size:var(--text-xs);letter-spacing:1px}
.region-card .text-sm{color:rgba(255,255,255,.8);margin-top:var(--space-sm)}
.top-section{background:var(--bg-cream)}
.top-list{display:grid;gap:var(--space-md);max-width:800px;margin:0 auto;list-style:none;padding:0}.top-list li{margin:0}
.top-item{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);background:var(--bg-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);text-decoration:none;color:var(--text-dark)}
.top-item:hover{transform:translateX(10px);box-shadow:var(--shadow-md);color:var(--text-dark)}
.top-item .rang{flex-shrink:0}
.top-item-info{flex:1}.top-item-name{font-family:var(--font-title);font-size:var(--text-lg);font-weight:600}.top-item-region{font-size:var(--text-sm);color:var(--text-medium)}
.top-item-score{font-family:var(--font-title);font-size:var(--text-2xl);font-weight:700;color:var(--primary)}
.classement-page{padding:var(--space-2xl) 0}
.classement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}
.classement-filters{display:flex;gap:var(--space-md);flex-wrap:wrap}
.classement-search{min-width:300px}
.pays-header{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-white);padding:var(--space-3xl) 0}
.pays-header-content{display:flex;align-items:center;gap:var(--space-2xl)}
.pays-title h1{color:var(--text-white);margin-bottom:var(--space-xs)}
.pays-meta{display:flex;gap:var(--space-lg);opacity:.9}
.pays-score-hero{margin-left:auto;text-align:center}
.pays-score-value{font-family:var(--font-title);font-size:5rem;font-weight:700;color:var(--gold);line-height:1}
.pays-score-rank{font-size:var(--text-lg)}
.pays-content{padding:var(--space-2xl) 0}
.pays-grid{display:grid;grid-template-columns:2fr 1fr;gap:var(--space-2xl)}
@media(max-width:968px){.pays-grid{grid-template-columns:1fr}}
.pays-piliers{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-2xl)}
@media(max-width:768px){.pays-piliers{grid-template-columns:repeat(2,1fr)}}
.pays-illustration{margin:var(--space-xl) 0;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.pays-illustration-img{width:100%;height:auto;display:block}
.region-illustration{margin-bottom:var(--space-xl);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg)}.region-illustration-img{width:100%;height:auto;display:block}
.pays-article{background:var(--bg-white);padding:var(--space-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.pays-article h2{border-bottom:3px solid var(--primary);padding-bottom:var(--space-sm);margin-bottom:var(--space-lg)}
.pays-article .chapeau{font-size:var(--text-lg);font-style:italic;color:var(--text-medium);padding:var(--space-lg);background:var(--bg-light);border-left:4px solid var(--accent);border-radius:var(--radius-sm);margin-bottom:var(--space-xl)}
.pays-proverbe{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:var(--text-white);padding:var(--space-xl);border-radius:var(--radius-md);text-align:center;margin:var(--space-xl) 0}
.pays-proverbe blockquote{font-family:var(--font-title);font-size:var(--text-2xl);font-style:italic;margin-bottom:var(--space-md)}
.pays-proverbe .traduction{font-size:var(--text-lg);opacity:.9;margin-bottom:var(--space-sm)}.pays-proverbe .langue{font-size:var(--text-sm);opacity:.7}
.pays-sidebar{display:flex;flex-direction:column;gap:var(--space-lg)}
.sidebar-card{background:var(--bg-white);padding:var(--space-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}
.sidebar-card h3{font-size:var(--text-lg);margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:var(--border-light)}
.voisins-list{display:flex;flex-direction:column;gap:var(--space-sm)}
.voisin-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm);background:var(--bg-light);border-radius:var(--radius-sm);text-decoration:none;color:var(--text-dark);transition:all var(--transition-fast)}
.voisin-item:hover{background:rgba(15,165,138,.1);color:var(--text-dark)}
.region-header{background:linear-gradient(135deg,var(--pilier-ubuntu) 0%,var(--pilier-ubuntu-light) 100%);color:var(--text-white);padding:var(--space-2xl) 0;text-align:center}
.region-stats{display:flex;justify-content:center;gap:var(--space-2xl);margin-top:var(--space-lg)}
.region-stat{text-align:center}.region-stat-value{font-family:var(--font-title);font-size:var(--text-3xl);font-weight:700}.region-stat-label{font-size:var(--text-sm);opacity:.9}
.comparaison-selector{background:var(--bg-white);padding:var(--space-xl);border-radius:var(--radius-md);margin-bottom:var(--space-xl)}
.comparaison-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}
.comparaison-item{background:var(--bg-white);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.comparaison-item-header{background:var(--primary);color:var(--text-white);padding:var(--space-md);text-align:center}
.comparaison-item-body{padding:var(--space-lg)}
.error-page{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:var(--space-2xl)}
.error-code{font-family:var(--font-title);font-size:8rem;font-weight:700;color:var(--primary);line-height:1;margin-bottom:var(--space-md)}
.error-message{font-size:var(--text-xl);color:var(--text-medium);margin-bottom:var(--space-xl)}
