﻿*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{--bg-white:#FEFEFE;--bg-surface:#F8F9FC;--bg-muted:#EEF0F5;--bg-green-tint:#EFF3FB;--bg-green-subtle:#DCE5F5;--bg-dark:#080C18;--bg-dark-elevated:#0E1425;--bg-dark-card:#141B2E;--bg-glass:rgba(254,254,254,0.65);--bg-glass-strong:rgba(254,254,254,0.88);--text-primary:#0C1024;--text-secondary:#2A3352;--text-tertiary:#5A6380;--text-muted:#8891A8;--text-on-dark:#E8ECF5;--text-on-dark-muted:rgba(232,236,245,0.55);--emerald-50:#EFF3FB;--emerald-100:#DCE5F5;--emerald-200:#B3C7EB;--emerald-300:#7BA0DB;--emerald-400:#4A7ACC;--emerald-500:#1A53BD;--emerald-600:#002395;--emerald-700:#001D7A;--emerald-800:#001660;--emerald-900:#001048;--amber-50:#FFF5F5;--amber-100:#FFE0E3;--amber-500:#ED2939;--sky-50:#F0F9FF;--sky-100:#E0F2FE;--sky-500:#0EA5E9;--rose-50:#FFF5F5;--rose-100:#FFE0E3;--violet-50:#F5F3FF;--violet-100:#EDE9FE;--success:#22C55E;--warning:#F59E0B;--error:#ED2939;--score-excellent:#002395;--score-bon:#1A53BD;--score-correct:#F59E0B;--score-moyen:#F97316;--score-faible:#ED2939;--data-value:#7BA0DB;--gradient-hero:linear-gradient(160deg,#050820 0%,#0A1240 25%,#0E1A5C 50%,#122070 75%,#002395 100%);--gradient-cta:linear-gradient(135deg,#002395 0%,#001D7A 100%);--gradient-glow:radial-gradient(ellipse at 50% 0%,rgba(0,35,149,0.15) 0%,transparent 60%);--gradient-border:linear-gradient(135deg,rgba(0,35,149,0.3),rgba(75,122,204,0.1));--shadow-xs:0 1px 2px rgba(0,0,0,0.03);--shadow-sm:0 1px 3px rgba(0,0,0,0.04),0 1px 2px rgba(0,0,0,0.02);--shadow-md:0 4px 16px rgba(0,0,0,0.05),0 1px 3px rgba(0,0,0,0.03);--shadow-lg:0 10px 40px rgba(0,0,0,0.06),0 2px 8px rgba(0,0,0,0.03);--shadow-xl:0 20px 60px rgba(0,0,0,0.08),0 4px 16px rgba(0,0,0,0.04);--shadow-2xl:0 32px 80px rgba(0,0,0,0.12);--shadow-green:0 4px 20px rgba(0,35,149,0.2);--shadow-green-lg:0 8px 40px rgba(0,35,149,0.25);--shadow-glow:0 0 60px rgba(0,35,149,0.12);--shadow-inner:inset 0 1px 2px rgba(0,0,0,0.04);--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:28px;--radius-full:9999px;--border:rgba(0,0,0,0.08);--border-light:rgba(0,0,0,0.04);--ease-out:cubic-bezier(0.16,1,0.3,1);--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--ease-smooth:cubic-bezier(0.4,0,0.2,1)}html{scroll-behavior:smooth}body{font-family:'Source Sans 3','DM Sans',system-ui,sans-serif;color:var(--text-primary);background:var(--bg-white);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;font-size:16px;letter-spacing:0.01em}h1,h2,h3,h4,h5,h6{font-family:'DM Sans',system-ui,sans-serif;letter-spacing:-0.03em;line-height:1.15}.font-mono,.stat-number,.city-score-val,.ranking-val{font-family:'DM Sans',sans-serif;font-weight:700;font-feature-settings:'tnum'}::selection{background:#DCE5F5;color:#001048}a{color:inherit;text-decoration:none}img{max-width:100%;height:auto;display:block}.container{max-width:1220px;margin:0 auto;padding:0 24px}.container-narrow{max-width:960px;margin:0 auto;padding:0 24px}.breadcrumbs{padding:16px 24px 8px;max-width:1220px;margin:0 auto}main>.breadcrumbs:first-child{padding-top:88px}.breadcrumbs ol{display:flex;align-items:center;gap:0;list-style:none;flex-wrap:wrap;font-size:0.82rem;font-weight:500}.breadcrumbs ol li{display:flex;align-items:center;color:var(--text-tertiary)}.breadcrumbs ol li:not(:last-child)::after{content:'';display:inline-block;width:16px;height:16px;margin:0 8px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238891A8' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M9 18l6-6-6-6'/%3E%3C/svg%3E");background-size:contain;background-repeat:no-repeat;flex-shrink:0}.breadcrumbs ol li a{color:var(--text-tertiary);transition:color 0.2s}.breadcrumbs ol li a:hover{color:var(--emerald-600)}.breadcrumbs .breadcrumb-current{color:var(--text-primary);font-weight:600}.header{position:fixed;top:0;left:0;right:0;z-index:1000;height:72px;transition:all 0.4s var(--ease-smooth)}.header::before{content:'';position:absolute;inset:0;background:var(--bg-glass-strong);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border-bottom:1px solid transparent;transition:all 0.4s var(--ease-smooth);opacity:0}.header.scrolled::before{opacity:1;border-bottom-color:rgba(0,0,0,0.05)}.header-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;height:100%}.logo{display:flex;align-items:center;gap:10px;font-size:1.15rem;font-weight:800;letter-spacing:-0.035em}.logo-mark{width:38px;height:38px;border-radius:var(--radius-md);background:var(--gradient-cta);display:flex;align-items:center;justify-content:center;color:white;box-shadow:var(--shadow-green);transition:transform 0.3s var(--ease-spring)}.logo:hover .logo-mark{transform:scale(1.05) rotate(-3deg)}.logo-text{color:rgba(255,255,255,0.95);transition:color 0.4s var(--ease-smooth)}.logo-text span{color:#7BA0DB;transition:color 0.4s var(--ease-smooth)}.header.scrolled .logo-text{color:var(--emerald-600)}.header.scrolled .logo-text span{color:#ED2939}.nav{display:flex;align-items:center;gap:4px}.nav-link{position:relative;padding:8px 16px;border-radius:var(--radius-sm);font-size:0.875rem;font-weight:500;color:rgba(255,255,255,0.75);transition:all 0.3s var(--ease-smooth)}.nav-link:hover{color:white;background:rgba(255,255,255,0.1)}.header.scrolled .nav-link{color:#2A3352}.header.scrolled .nav-link:hover{color:var(--emerald-600);background:var(--bg-green-tint)}.nav-cta{margin-left:12px;padding:10px 22px !important;background:var(--gradient-cta);color:white !important;border-radius:var(--radius-md);font-weight:600;box-shadow:var(--shadow-green);transition:all 0.3s var(--ease-smooth)}.nav-cta:hover{transform:translateY(-1px);box-shadow:var(--shadow-green-lg);color:white !important;background:var(--gradient-cta) !important}.header:not(.scrolled) .nav-cta{box-shadow:var(--shadow-green),0 0 0 1px rgba(255,255,255,0.1)}.mobile-toggle{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;border-radius:var(--radius-sm);color:rgba(255,255,255,0.9);transition:all 0.3s var(--ease-smooth)}.mobile-toggle:hover{background:rgba(255,255,255,0.1)}.header.scrolled .mobile-toggle{color:var(--text-primary)}.header.scrolled .mobile-toggle:hover{background:var(--bg-muted)}.mobile-toggle svg{width:22px;height:22px;display:block;margin:auto}.mobile-menu{display:none;position:fixed;top:72px;left:0;right:0;bottom:0;background:var(--bg-white);padding:16px;flex-direction:column;gap:4px;animation:menuSlide 0.35s var(--ease-out)}.mobile-menu.open{display:flex}.mobile-menu a{display:block;padding:16px 20px;border-radius:var(--radius-md);font-size:1rem;font-weight:500;color:var(--text-primary);transition:background 0.2s}.mobile-menu a:hover{background:var(--bg-muted)}@keyframes menuSlide{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.hero{position:relative;min-height:100vh;background:var(--gradient-hero);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:100px 24px 80px}.hero.hero-pillar{min-height:42vh;padding:92px 24px 48px}.hero.hero-pillar .hero-content{padding-top:0 !important;padding-bottom:0 !important}.hero.hero-detail{min-height:34vh;padding:92px 24px 40px}.hero.hero-detail .hero-content{padding-top:0 !important;padding-bottom:0 !important}.hero.hero-tool{min-height:28vh;padding:88px 24px 32px}.hero.hero-tool .hero-content{padding-top:0 !important;padding-bottom:0 !important}.hero-pillar .hero-content h1,.hero-detail .hero-content h1,.hero-tool .hero-content h1{font-size:clamp(1.8rem,3.6vw,2.6rem);margin-bottom:10px}.hero-pillar .hero-sub,.hero-detail .hero-sub,.hero-tool .hero-sub{font-size:clamp(0.95rem,1.4vw,1.05rem);max-width:620px}.hero-pillar .hero-orb,.hero-detail .hero-orb,.hero-tool .hero-orb{opacity:0.7}@media (max-width:768px){.hero.hero-pillar{min-height:32vh;padding:88px 20px 32px}.hero.hero-detail{min-height:28vh;padding:84px 20px 28px}.hero.hero-tool{min-height:24vh;padding:80px 20px 24px}}.hero-bg{position:absolute;inset:0;overflow:hidden}.hero-orb{position:absolute;border-radius:50%;filter:blur(120px)}.hero-orb:nth-child(1){width:700px;height:700px;background:radial-gradient(circle,rgba(0,35,149,0.25) 0%,transparent 70%);top:-20%;left:-15%;animation:orbDrift1 24s ease-in-out infinite}.hero-orb:nth-child(2){width:500px;height:500px;background:radial-gradient(circle,rgba(237,41,57,0.12) 0%,transparent 70%);bottom:-25%;right:-10%;animation:orbDrift2 28s ease-in-out infinite}.hero-orb:nth-child(3){width:400px;height:400px;background:radial-gradient(circle,rgba(75,122,204,0.15) 0%,transparent 70%);top:30%;left:40%;animation:orbDrift3 20s ease-in-out infinite}.hero-orb:nth-child(4){width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,0.06) 0%,transparent 70%);top:10%;right:15%;animation:orbDrift1 32s ease-in-out infinite reverse}@keyframes orbDrift1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(80px,-50px) scale(1.08)}66%{transform:translate(-40px,40px) scale(0.94)}}@keyframes orbDrift2{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(-60px,40px) scale(1.12)}66%{transform:translate(50px,-60px) scale(0.88)}}@keyframes orbDrift3{0%,100%{transform:translate(0,0)}50%{transform:translate(100px,-80px)}}.hero-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.025) 1px,transparent 1px);background-size:48px 48px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%)}.hero-noise{position:absolute;inset:0;opacity:0.015;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.hero-content{position:relative;z-index:2;text-align:center;max-width:780px}.hero-badge{display:inline-flex;align-items:center;gap:10px;padding:8px 20px 8px 14px;border-radius:var(--radius-full);background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);backdrop-filter:blur(12px);font-size:0.8rem;font-weight:500;color:var(--emerald-200);letter-spacing:0.01em;margin-bottom:36px}.hero-badge-dot{width:7px;height:7px;border-radius:50%;background:#ED2939;box-shadow:0 0 8px #ED2939;animation:badgePulse 2.5s ease-in-out infinite}@keyframes badgePulse{0%,100%{opacity:1;box-shadow:0 0 8px #ED2939}50%{opacity:0.4;box-shadow:0 0 16px #ED2939}}.hero h1{font-family:'DM Sans',sans-serif;font-size:clamp(2.6rem,6vw,4.5rem);font-weight:900;color:white;line-height:1.05;letter-spacing:-0.045em;margin-bottom:28px}.hero h1 em{font-style:normal;color:#ED2939;-webkit-text-fill-color:#ED2939}@keyframes shimmer{0%{background-position:0% center}100%{background-position:200% center}}.hero-sub{font-size:clamp(1.05rem,1.8vw,1.25rem);color:var(--text-on-dark-muted);max-width:540px;margin:0 auto 48px;line-height:1.7;font-weight:400}.search-wrapper{max-width:620px;margin:0 auto}.search-bar{display:flex;align-items:center;background:white;border-radius:var(--radius-xl);padding:7px 7px 7px 24px;box-shadow:0 20px 60px rgba(0,0,0,0.25),0 0 0 1px rgba(255,255,255,0.08);transition:box-shadow 0.4s var(--ease-smooth)}.search-bar:focus-within{box-shadow:0 20px 60px rgba(0,0,0,0.25),0 0 80px rgba(5,150,105,0.15)}.search-icon{width:20px;height:20px;color:var(--text-muted);flex-shrink:0}.search-bar input{flex:1;border:none;outline:none;padding:16px 14px;font-size:1rem;font-family:inherit;color:var(--text-primary);background:transparent;font-weight:400}.search-bar input::placeholder{color:var(--text-muted);font-weight:400}.search-btn{background:var(--gradient-cta);color:white;border:none;border-radius:var(--radius-lg);padding:16px 28px;font-size:0.92rem;font-weight:600;cursor:pointer;white-space:nowrap;font-family:inherit;box-shadow:var(--shadow-green);transition:all 0.3s var(--ease-smooth)}.search-btn:hover{transform:translateY(-1px);box-shadow:var(--shadow-green-lg)}.search-pills{display:flex;gap:8px;justify-content:center;margin-top:18px;flex-wrap:wrap}.search-pill{background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1);color:var(--text-on-dark-muted);padding:7px 16px;border-radius:var(--radius-full);font-size:0.8rem;font-weight:500;cursor:pointer;transition:all 0.25s var(--ease-smooth)}.search-pill:hover{background:rgba(255,255,255,0.14);color:white;border-color:rgba(255,255,255,0.2)}.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);width:28px;height:44px;border-radius:14px;border:2px solid rgba(255,255,255,0.15);display:flex;align-items:flex-start;justify-content:center;padding-top:8px}.hero-scroll-dot{width:4px;height:8px;border-radius:2px;background:rgba(255,255,255,0.4);animation:scrollBounce 2s ease-in-out infinite}@keyframes scrollBounce{0%,100%{transform:translateY(0);opacity:1}50%{transform:translateY(12px);opacity:0.2}}.section{padding:clamp(80px,10vw,140px) 0}.section-surface{background:var(--bg-surface)}.section-green{background:var(--bg-green-tint)}.section-dark{background:var(--bg-dark);color:var(--text-on-dark)}.section-header{text-align:center;margin-bottom:clamp(48px,6vw,80px)}.section-label{display:inline-flex;align-items:center;gap:12px;font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.14em;color:var(--emerald-600);margin-bottom:20px}.section-label::before{content:'';width:24px;height:2px;background:linear-gradient(90deg,#002395,#ED2939);border-radius:1px}.section-label::after{content:'';width:24px;height:2px;background:linear-gradient(90deg,#ED2939,#002395);border-radius:1px}.section-header h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;letter-spacing:-0.035em;margin-bottom:18px;line-height:1.1;color:var(--text-primary)}.section-header p{color:var(--text-tertiary);max-width:540px;margin:0 auto;font-size:1.08rem;line-height:1.7;font-weight:400}.stats-section{padding:80px 0;border-bottom:1px solid var(--bg-muted)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:48px}.stat-item{text-align:center;position:relative}.stat-item:not(:last-child)::after{content:'';position:absolute;right:-24px;top:15%;height:70%;width:1px;background:linear-gradient(to bottom,transparent,var(--bg-muted),transparent)}.stat-number{font-family:'Space Grotesk',monospace;font-size:clamp(2.4rem,4.5vw,3.5rem);font-weight:500;color:var(--emerald-600);line-height:1;letter-spacing:-0.04em}.stat-label{font-size:0.88rem;color:var(--text-tertiary);margin-top:10px;font-weight:500}.cities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.city-card{position:relative;background:var(--bg-white);border:1px solid rgba(0,0,0,0.06);border-radius:var(--radius-xl);padding:30px;transition:all 0.4s var(--ease-out);cursor:pointer;overflow:hidden}.city-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#002395 33%,#FEFEFE 33%,#FEFEFE 66%,#ED2939 66%);opacity:0;transition:opacity 0.4s var(--ease-out);pointer-events:none}.city-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl);border-color:var(--emerald-200)}.city-card:hover::before{opacity:1}.city-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.city-info{flex:1}.city-rank{font-size:0.7rem;font-weight:700;color:var(--emerald-600);background:var(--emerald-50);padding:3px 10px;border-radius:var(--radius-full);margin-bottom:8px;display:inline-block;letter-spacing:0.03em}.city-name{font-size:1.25rem;font-weight:800;letter-spacing:-0.02em;margin-bottom:2px}.city-dept{font-size:0.8rem;color:var(--text-tertiary);font-weight:500}.city-score{position:relative;width:64px;height:64px;flex-shrink:0}.city-score svg{position:absolute;top:0;left:0;width:64px;height:64px;transform:rotate(-90deg)}.score-track{fill:none;stroke:var(--bg-muted);stroke-width:3.5}.score-fill{fill:none;stroke-width:3.5;stroke-linecap:round;transition:stroke-dashoffset 1.8s var(--ease-out)}.city-score>div{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;line-height:1}.city-score-val{font-family:'Space Grotesk',monospace;font-size:1rem;font-weight:500;display:block}.city-score-max{font-size:0.55rem;color:var(--text-muted);font-weight:500;display:block;margin-top:1px}.city-metrics{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding-top:20px;border-top:1px solid var(--bg-muted)}.city-metric{display:flex;align-items:center;gap:10px}.metric-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.metric-dot.immo{background:var(--amber-500)}.metric-dot.sun{background:#FBBF24}.metric-dot.health{background:#F472B6}.metric-dot.school{background:var(--sky-500)}.city-metric-text{font-size:0.78rem;color:var(--text-tertiary);line-height:1.3}.city-metric-text strong{display:block;font-size:0.88rem;color:var(--text-primary);font-weight:600}.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative}.steps-connector{position:absolute;top:60px;left:calc(33.33% - 14px);width:calc(33.33% + 28px);height:2px;background:linear-gradient(90deg,var(--emerald-200),var(--emerald-100))}.steps-connector:nth-of-type(2){left:calc(66.66% - 14px)}.step-card{text-align:center;position:relative;background:var(--bg-white);border:1px solid rgba(0,0,0,0.04);border-radius:var(--radius-xl);padding:40px 28px 36px;transition:all 0.35s var(--ease-out)}.step-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--emerald-100)}.step-num{position:absolute;top:-18px;left:50%;transform:translateX(-50%);width:36px;height:36px;border-radius:50%;background:var(--gradient-cta);color:white;font-size:0.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-green);z-index:1}.step-icon{width:72px;height:72px;margin:8px auto 20px;border-radius:var(--radius-lg);background:var(--bg-green-tint);border:1px solid var(--emerald-100);display:flex;align-items:center;justify-content:center;font-size:1.8rem}.step-card h3{font-size:1.05rem;font-weight:700;margin-bottom:8px;letter-spacing:-0.01em}.step-card p{font-size:0.88rem;color:var(--text-tertiary);line-height:1.6}.rankings-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.ranking-card{position:relative;background:var(--bg-white);border:1px solid rgba(0,0,0,0.05);border-radius:var(--radius-xl);padding:32px;transition:all 0.35s var(--ease-out);cursor:pointer;overflow:hidden}.ranking-card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#002395 33%,#FEFEFE 33%,#FEFEFE 66%,#ED2939 66%);opacity:0;transition:opacity 0.35s}.ranking-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--emerald-100)}.ranking-card:hover::after{opacity:1}.ranking-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.ranking-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.ranking-card h3{font-size:0.95rem;font-weight:700;letter-spacing:-0.01em}.ranking-source{font-size:0.75rem;color:var(--text-muted);font-weight:500;margin-top:4px}.ranking-list{display:flex;flex-direction:column;gap:8px}.ranking-entry{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-md);background:var(--bg-surface);transition:background 0.2s}.ranking-card:hover .ranking-entry{background:var(--bg-muted)}.ranking-pos{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:700;flex-shrink:0}.ranking-pos.gold{background:#FDE68A;color:#92400E}.ranking-pos.silver{background:#E2E8F0;color:#475569}.ranking-pos.bronze{background:#FED7AA;color:#9A3412}.ranking-city{font-size:0.85rem;font-weight:600;flex:1}.ranking-val{font-family:'JetBrains Mono',monospace;font-size:0.78rem;color:var(--emerald-600);font-weight:600}.themes-wrap{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;max-width:800px;margin:0 auto}.theme-pill{display:inline-flex;align-items:center;gap:10px;background:var(--bg-white);border:1px solid rgba(0,0,0,0.06);padding:14px 24px;border-radius:var(--radius-full);font-size:0.92rem;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all 0.3s var(--ease-smooth);box-shadow:var(--shadow-xs)}.theme-pill:hover{background:var(--emerald-50);border-color:var(--emerald-200);color:var(--emerald-700);transform:translateY(-3px);box-shadow:var(--shadow-md)}.theme-emoji{font-size:1.15rem}.tools-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.tools-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.tool-card{position:relative;display:flex;gap:24px;align-items:flex-start;background:var(--bg-white);border:1px solid rgba(0,0,0,0.05);border-radius:var(--radius-xl);padding:32px;transition:all 0.35s var(--ease-out);cursor:pointer;overflow:hidden}.tool-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#002395 33%,#FEFEFE 33%,#FEFEFE 66%,#ED2939 66%);opacity:0;transition:opacity 0.35s}.tool-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--emerald-200)}.tool-card:hover::before{opacity:1}.tool-icon{width:56px;height:56px;border-radius:var(--radius-lg);background:var(--bg-green-tint);border:1px solid var(--emerald-100);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.tool-body{flex:1}.tool-card h3{font-size:1rem;font-weight:700;margin-bottom:6px;letter-spacing:-0.01em}.tool-card p{font-size:0.85rem;color:var(--text-tertiary);line-height:1.55;margin-bottom:12px}.tool-link{font-size:0.85rem;color:var(--emerald-600);font-weight:600;display:inline-flex;align-items:center;gap:6px}.tool-link .arrow{transition:transform 0.3s var(--ease-spring);display:inline-block}.tool-card:hover .tool-link .arrow{transform:translateX(5px)}.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:48px}.trust-item{text-align:center;padding:32px 20px;background:var(--bg-white);border:1px solid rgba(0,0,0,0.04);border-radius:var(--radius-xl);transition:all 0.3s var(--ease-out)}.trust-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--emerald-100)}.trust-icon{width:56px;height:56px;margin:0 auto 16px;border-radius:var(--radius-lg);background:var(--bg-green-tint);border:1px solid var(--emerald-100);display:flex;align-items:center;justify-content:center;font-size:1.4rem}.trust-item h4{font-size:0.88rem;font-weight:700;margin-bottom:4px;letter-spacing:-0.01em}.trust-item p{font-size:0.78rem;color:var(--text-muted)}.trust-text{text-align:center;max-width:640px;margin:0 auto;font-size:0.95rem;color:var(--text-tertiary);line-height:1.75}.trust-text strong{color:var(--emerald-700);font-weight:600}.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.article-card{position:relative;background:var(--bg-white);border:1px solid rgba(0,0,0,0.05);border-radius:var(--radius-xl);overflow:hidden;transition:all 0.4s var(--ease-out);cursor:pointer;text-decoration:none;color:inherit;display:block}.article-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#002395 33%,#FEFEFE 33%,#FEFEFE 66%,#ED2939 66%);opacity:0;transition:opacity 0.4s}.article-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-xl);border-color:var(--emerald-100)}.article-card:hover::after{opacity:1}.article-thumb{height:200px;position:relative;overflow:hidden}.article-thumb-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3.5rem;opacity:0.15;transition:transform 0.6s var(--ease-out)}.article-card:hover .article-thumb-bg{transform:scale(1.1)}.article-thumb-gradient{position:absolute;bottom:0;left:0;right:0;height:60%;background:linear-gradient(to top,rgba(0,0,0,0.4),transparent)}.article-body{padding:24px 28px 28px}.article-tag{display:inline-block;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--emerald-600);background:var(--emerald-50);padding:4px 12px;border-radius:var(--radius-full);margin-bottom:12px}.article-card h3{font-size:1.05rem;font-weight:700;line-height:1.4;margin-bottom:10px;letter-spacing:-0.01em}.article-card p{font-size:0.85rem;color:var(--text-tertiary);line-height:1.6}.article-meta{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--bg-muted);font-size:0.78rem;color:var(--text-muted);font-weight:500}.cta-banner{position:relative;overflow:hidden;background:var(--gradient-hero);border-radius:var(--radius-2xl);padding:clamp(60px,8vw,100px) clamp(24px,4vw,60px);text-align:center}.cta-banner::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#002395 33%,#FEFEFE 33%,#FEFEFE 66%,#ED2939 66%)}.cta-banner-glow{position:absolute;top:-50%;left:25%;width:50%;height:200%;background:radial-gradient(ellipse,rgba(16,185,129,0.2),transparent 60%);pointer-events:none}.cta-banner h2{position:relative;color:white;font-size:clamp(1.5rem,3vw,2.2rem);font-weight:800;letter-spacing:-0.03em;margin-bottom:16px}.cta-banner p{position:relative;color:var(--text-on-dark-muted);font-size:1.05rem;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto}.cta-btn{position:relative;display:inline-flex;align-items:center;gap:10px;background:white;color:var(--emerald-700);padding:18px 36px;border-radius:var(--radius-lg);font-size:1rem;font-weight:700;border:none;cursor:pointer;font-family:inherit;letter-spacing:-0.01em;box-shadow:0 8px 32px rgba(0,0,0,0.15);transition:all 0.3s var(--ease-smooth)}.cta-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 12px 48px rgba(0,0,0,0.2)}.cta-btn svg{flex-shrink:0}.footer{position:relative;background:var(--bg-dark);padding:96px 0 36px;color:var(--text-on-dark-muted)}.footer::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#002395 33%,#FEFEFE 33%,#FEFEFE 66%,#ED2939 66%)}.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:56px;margin-bottom:64px}.footer-brand .logo{margin-bottom:16px}.footer-brand>p{font-size:0.88rem;line-height:1.65;margin-bottom:24px;max-width:280px}.footer-badges{display:flex;gap:8px;flex-wrap:wrap}.footer-badge{font-size:0.72rem;font-weight:500;padding:5px 14px;border-radius:var(--radius-full);background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);color:var(--text-on-dark-muted)}.footer-col h4{color:var(--text-on-dark);font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:24px}.footer-col a{display:block;padding:6px 0;font-size:0.88rem;font-weight:400;color:var(--text-on-dark-muted);transition:color 0.2s}.footer-col a:hover{color:var(--emerald-400)}.footer-divider{height:1px;background:rgba(255,255,255,0.05);margin-bottom:28px}.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-size:0.78rem;color:rgba(255,255,255,0.25)}.view-more{text-align:center;margin-top:48px}.view-more a{display:inline-flex;align-items:center;gap:8px;color:var(--emerald-600);font-weight:600;font-size:0.92rem;padding:12px 24px;border-radius:var(--radius-md);transition:all 0.25s var(--ease-smooth)}.view-more a:hover{background:var(--emerald-50);gap:12px}.fade-up{opacity:0;transform:translateY(40px);transition:opacity 0.7s var(--ease-out),transform 0.7s var(--ease-out)}.fade-up.visible{opacity:1;transform:translateY(0)}.fade-up-delay-1{transition-delay:0.08s}.fade-up-delay-2{transition-delay:0.16s}.fade-up-delay-3{transition-delay:0.24s}.fade-up-delay-4{transition-delay:0.32s}.fade-up-delay-5{transition-delay:0.40s}@media (max-width:1024px){.cities-grid{grid-template-columns:repeat(2,1fr)}.tools-grid{grid-template-columns:1fr}.tools-grid-3{grid-template-columns:repeat(2,1fr)}.footer-top{grid-template-columns:repeat(2,1fr);gap:40px}.rankings-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.nav{display:none}.mobile-toggle{display:flex}.tools-grid-3{grid-template-columns:1fr}.section{padding:80px 0}.hero{min-height:auto;padding:140px 24px 80px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:32px}.stat-item::after{display:none}.cities-grid{grid-template-columns:1fr}.steps-grid{grid-template-columns:1fr;gap:40px}.rankings-grid{grid-template-columns:1fr}.articles-grid{grid-template-columns:1fr}.trust-grid{grid-template-columns:repeat(2,1fr)}.footer-top{grid-template-columns:1fr;gap:32px}.footer-bottom{flex-direction:column;text-align:center}.search-bar{flex-direction:column;padding:12px;gap:8px}.search-btn{width:100%;text-align:center}.cta-banner{padding:48px 24px;border-radius:var(--radius-xl)}}@media (max-width:480px){.trust-grid{grid-template-columns:1fr}.themes-wrap{gap:8px}.theme-pill{padding:10px 18px;font-size:0.85rem}}.ranking-source-badge{display:inline-flex;align-items:center;font-size:0.82rem;color:var(--text-muted);font-weight:500;background:var(--bg-surface);padding:6px 14px;border-radius:var(--radius-full);margin-top:8px}.ranking-cta{margin-top:16px;font-size:0.85rem;font-weight:600;color:var(--emerald-600)}.ranking-table-wrap{overflow-x:auto;margin-top:32px;background:var(--bg-white);border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,0.04);box-shadow:var(--shadow-sm)}.ranking-table{width:100%;border-collapse:collapse}.ranking-table th{padding:14px 20px;text-align:left;font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;color:var(--text-muted);border-bottom:2px solid var(--border);background:var(--bg-surface)}.ranking-th-pos{width:60px;text-align:center}.ranking-th-val{text-align:right}.ranking-table td{padding:14px 20px;font-size:0.88rem;border-bottom:1px solid rgba(0,0,0,0.04)}.ranking-table tr:last-child td{border-bottom:0}.ranking-table tr:hover td{background:var(--bg-surface)}.ranking-city-link{font-weight:600;color:var(--text-primary);text-decoration:none}.ranking-city-link:hover{color:var(--emerald-600);text-decoration:underline}.ranking-dept{color:var(--text-muted);font-size:0.82rem}.ranking-value{text-align:right;font-family:'JetBrains Mono',monospace;font-size:0.85rem;font-weight:600;color:var(--emerald-600)}.ranking-filters{display:flex;flex-wrap:wrap;gap:16px;align-items:center;margin-bottom:24px;padding:16px 20px;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.ranking-filter-group{display:flex;align-items:center;gap:8px}.ranking-filter-label{font-size:0.82rem;font-weight:600;color:var(--text-muted);white-space:nowrap}.ranking-pills{display:flex;gap:6px;flex-wrap:wrap}.ranking-pill{display:inline-block;padding:5px 14px;border-radius:20px;font-size:0.8rem;font-weight:500;text-decoration:none;color:var(--text-secondary);background:var(--bg-card);border:1px solid var(--border-color);transition:all 0.2s}.ranking-pill:hover{border-color:var(--emerald-600);color:var(--emerald-600)}.ranking-pill.active{background:var(--emerald-600);color:#fff;border-color:var(--emerald-600)}.ranking-select{padding:5px 12px;border-radius:var(--radius-md);font-size:0.82rem;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);cursor:pointer;max-width:260px}.ranking-select:focus{outline:none;border-color:var(--emerald-600)}@media (max-width:640px){.ranking-filters{flex-direction:column;align-items:flex-start}.ranking-select{max-width:100%;width:100%}}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:32px;padding:16px 0}.pagination-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border-radius:var(--radius-md);background:var(--bg-white);border:1px solid var(--border);font-size:0.85rem;font-weight:600;color:var(--text-primary);text-decoration:none;transition:all 0.2s}.pagination-btn:hover{background:var(--emerald-50);border-color:var(--emerald-200);color:var(--emerald-700)}.pagination-info{font-size:0.85rem;color:var(--text-secondary)}.pagination-total{color:var(--text-muted);margin-left:4px}.compare-form{background:var(--bg-white);border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,0.04);padding:40px;box-shadow:var(--shadow-md);margin-top:32px}.compare-inputs{display:flex;align-items:flex-start;gap:24px}.compare-field{flex:1}.compare-field label{display:block;font-size:0.82rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;color:var(--text-muted);margin-bottom:8px}.compare-input-wrap{position:relative}.compare-input{width:100%;padding:14px 18px;border-radius:var(--radius-md);border:1px solid var(--border);font-size:0.95rem;font-family:inherit;background:var(--bg-surface);transition:border-color 0.2s}.compare-input:focus{outline:none;border-color:var(--emerald-400);box-shadow:0 0 0 3px rgba(5,150,105,0.1)}.compare-vs{display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:var(--text-muted);padding-top:28px;flex-shrink:0}.compare-dropdown{display:none;position:absolute;top:100%;left:0;right:0;background:var(--bg-white);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:50;max-height:240px;overflow-y:auto;margin-top:4px}.compare-dropdown-item{padding:10px 18px;cursor:pointer;font-size:0.9rem;transition:background 0.15s}.compare-dropdown-item:hover{background:var(--emerald-50)}.compare-dropdown-dept{color:var(--text-muted);font-size:0.8rem}.compare-dropdown-empty{padding:12px 18px;font-size:0.85rem;color:var(--text-muted)}.compare-btn{display:block;width:100%;margin-top:24px;padding:14px;font-size:1rem;font-weight:700;border-radius:var(--radius-md);cursor:pointer}.compare-btn:disabled{opacity:0.5;cursor:not-allowed}.compare-examples{margin-top:32px;text-align:center}.compare-examples-label{font-size:0.82rem;color:var(--text-muted);font-weight:600;margin-bottom:12px}.compare-examples-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.compare-example-pill{display:inline-block;padding:8px 18px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-full);font-size:0.85rem;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all 0.2s}.compare-example-pill:hover{background:var(--emerald-50);border-color:var(--emerald-200);color:var(--emerald-700)}.compare-scores{display:flex;align-items:center;justify-content:center;gap:40px;margin:32px 0}.compare-score-card{text-align:center}.compare-score-name{display:block;font-size:1.1rem;font-weight:700;color:var(--text-primary);text-decoration:none;margin-bottom:12px}.compare-score-name:hover{color:var(--emerald-600)}.compare-gauge{position:relative;display:inline-block}.compare-gauge-val{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:'JetBrains Mono',monospace;font-size:1.4rem;font-weight:700}.compare-gauge-val span{font-size:0.7rem;color:var(--text-muted)}.compare-gauge-na{font-size:0.9rem;color:var(--text-muted);padding:32px 0}.compare-vs-badge{font-size:1.2rem;font-weight:800;color:var(--text-muted);padding:8px 16px;background:var(--bg-surface);border-radius:var(--radius-full)}.compare-table-wrap{overflow-x:auto;margin-top:16px;background:var(--bg-white);border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,0.04);box-shadow:var(--shadow-sm)}.compare-table{width:100%;border-collapse:collapse}.compare-table th{padding:14px 20px;text-align:left;font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.04em;color:var(--text-muted);border-bottom:2px solid var(--border);background:var(--bg-surface)}.compare-th-city{text-align:center;min-width:140px}.compare-table td{padding:14px 20px;font-size:0.88rem;border-bottom:1px solid rgba(0,0,0,0.04)}.compare-table tr:last-child td{border-bottom:0}.compare-table tr:hover td{background:var(--bg-surface)}.compare-label{font-weight:600}.compare-val{text-align:center;font-family:'JetBrains Mono',monospace;font-size:0.85rem}.compare-winner{background:rgba(5,150,105,0.08);font-weight:700;color:var(--emerald-700)}.compare-back{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:40px}.btn-outline{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-white);font-size:0.88rem;font-weight:600;color:var(--text-primary);text-decoration:none;transition:all 0.2s}.btn-outline:hover{background:var(--emerald-50);border-color:var(--emerald-200);color:var(--emerald-700)}.cmp-score-row{margin-bottom:20px}.cmp-score-label{display:flex;align-items:center;gap:8px;font-size:0.88rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.cmp-score-icon{font-size:1rem}.cmp-score-bars{display:flex;gap:4px}.cmp-bar-side{display:flex;align-items:center;gap:8px;flex:1}.cmp-bar-left{justify-content:flex-end}.cmp-bar-right{justify-content:flex-start}.cmp-bar-track{flex:1;height:10px;border-radius:5px;background:var(--bg-muted);overflow:hidden}.cmp-bar-fill{height:100%;border-radius:5px;transition:width 0.8s var(--ease-out)}.cmp-bar-fill-left{margin-left:auto}.cmp-bar-val{min-width:36px;text-align:center;font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.85rem;font-feature-settings:'tnum'}.cmp-score-names{display:flex;justify-content:space-between;font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.04em;margin-top:2px}.cmp-grid{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:0;background:var(--bg-white);border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,0.04);box-shadow:var(--shadow-sm);overflow:hidden}.cmp-row{display:grid;grid-template-columns:1fr 1fr 1fr;border-bottom:1px solid rgba(0,0,0,0.04)}.cmp-row:last-child{border-bottom:0}.cmp-row:hover .cmp-cell{background:var(--bg-surface)}.cmp-cell{padding:16px 20px;transition:background 0.15s}.cmp-cell-label{font-weight:700;font-size:0.88rem;color:var(--text-secondary);display:flex;align-items:center}.cmp-cell-val{text-align:center;font-family:'DM Sans',sans-serif;font-weight:700;font-size:0.92rem;font-feature-settings:'tnum';position:relative}.cmp-city-tag{display:none;font-size:0.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.04em;margin-bottom:4px}.cmp-na{color:var(--text-muted)}.cmp-winner{background:rgba(34,197,94,0.06);color:var(--emerald-700)}.cmp-loser{color:var(--text-muted)}.cmp-badge-win{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--success);color:white;font-size:0.65rem;font-weight:800;margin-left:6px;vertical-align:middle}.cmp-row-header{background:var(--bg-surface);border-bottom:2px solid rgba(0,0,0,0.06)}.cmp-row-header .cmp-cell{padding:12px 20px}.cmp-cell-header{font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-secondary)}.header-search-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:6px;margin-left:4px;border-radius:8px;transition:all 0.2s;display:inline-flex;align-items:center}.header-search-btn:hover{color:var(--emerald-600);background:rgba(5,150,105,0.08)}.header-search-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,0.5);backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding-top:120px;opacity:0;visibility:hidden;transition:opacity 0.25s,visibility 0.25s}.header-search-overlay.open{opacity:1;visibility:visible}.header-search-box{width:100%;max-width:640px;background:var(--bg-surface);border:1px solid var(--border);border-radius:24px;box-shadow:0 24px 64px rgba(0,0,0,0.2);overflow:hidden;transform:translateY(-20px);transition:transform 0.3s cubic-bezier(0.4,0,0.2,1)}.header-search-overlay.open .header-search-box{transform:translateY(0)}@media (max-width:900px){.header-search-btn{display:none}.header-search-overlay{padding-top:80px;padding:80px 16px 0}.header-search-box{border-radius:16px}}@media (max-width:700px){.cmp-row{grid-template-columns:1fr;gap:0}.cmp-cell-label{background:var(--bg-surface);font-size:0.82rem;padding:10px 16px;border-bottom:1px solid rgba(0,0,0,0.04)}.cmp-cell-val{padding:12px 16px}.cmp-city-tag{display:block}.cmp-row-header{display:none}.cmp-score-bars{flex-direction:column;gap:6px}.cmp-bar-left{flex-direction:row;justify-content:flex-start}.cmp-bar-fill-left{margin-left:0}.cmp-score-names{display:none}}.theme-weights{background:var(--bg-white);border-radius:var(--radius-xl);border:1px solid rgba(0,0,0,0.04);padding:32px;box-shadow:var(--shadow-sm);margin-top:32px}.theme-weights-title{font-size:1rem;font-weight:700;margin-bottom:20px}.theme-weights-grid{display:flex;flex-direction:column;gap:12px}.theme-weight-item{}.theme-weight-bar-wrap{width:100%;height:8px;background:var(--bg-surface);border-radius:4px;overflow:hidden}.theme-weight-bar{height:100%;background:var(--emerald-500);border-radius:4px;transition:width 0.6s var(--ease-out)}.theme-weight-meta{display:flex;justify-content:space-between;margin-top:4px}.theme-weight-label{font-size:0.82rem;font-weight:600}.theme-weight-pct{font-size:0.78rem;color:var(--text-muted)}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:0.95rem}@media (max-width:768px){.compare-inputs{flex-direction:column}.compare-vs{padding-top:0}.compare-scores{flex-direction:column;gap:24px}.rankings-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:0.01ms !important;transition-duration:0.01ms !important}}.tools-category{margin-bottom:48px}.tools-category-title{font-size:1.25rem;font-weight:700;margin-bottom:20px;color:var(--text-secondary);letter-spacing:-0.01em}.tools-category-divider{display:flex;align-items:center;gap:16px;margin-bottom:24px}.tools-category-divider::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--border),transparent)}.tools-category-label{font-size:0.75rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--emerald-600);white-space:nowrap}.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.tools-grid-small{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.tool-card{position:relative;background:var(--bg-glass,rgba(255,255,255,0.7));border:1px solid var(--border,rgba(0,0,0,0.06));border-radius:20px;padding:32px 28px;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);cursor:pointer;text-decoration:none;color:inherit;display:flex;flex-direction:column;overflow:hidden}.tool-card::before{content:'';position:absolute;inset:-1px;border-radius:20px;padding:1px;background:linear-gradient(135deg,var(--emerald-400,#34d399),transparent 60%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity 0.4s;pointer-events:none}.tool-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(5,150,105,0.12),0 0 0 1px rgba(5,150,105,0.1);border-color:transparent}.tool-card:hover::before{opacity:1}.tool-card-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;font-size:1.8rem;background:linear-gradient(135deg,rgba(5,150,105,0.08),rgba(5,150,105,0.02));border-radius:16px;margin-bottom:20px}.tool-card-tag{display:inline-block;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--emerald-600,#059669);background:rgba(5,150,105,0.08);padding:4px 10px;border-radius:6px;margin-bottom:16px;width:fit-content}.tool-card-title{font-size:1.05rem;font-weight:700;margin-bottom:8px;color:var(--text-primary);letter-spacing:-0.01em}.tool-card-desc{font-size:0.88rem;color:var(--text-tertiary);line-height:1.55;margin-bottom:16px}.tool-card-cta{margin-top:auto;padding-top:16px;font-size:0.85rem;font-weight:600;color:var(--emerald-600,#059669);display:flex;align-items:center;gap:6px;transition:all 0.3s}.tool-card-cta .arrow{display:inline-block;transition:transform 0.3s}.tool-card:hover .tool-card-cta{color:var(--emerald-500,#10b981)}.tool-card:hover .tool-card-cta .arrow{transform:translateX(5px)}.tool-form{max-width:700px;margin:0 auto}.slider-group{margin-bottom:24px}.slider-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:0.9rem;font-weight:500}.slider-value{font-family:'JetBrains Mono',monospace;font-weight:600;color:var(--emerald-600);min-width:24px;text-align:right}input[type="range"]{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:var(--bg-muted);outline:none;transition:background 0.2s}input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--emerald-600);cursor:pointer;border:3px solid white;box-shadow:0 2px 8px rgba(5,150,105,0.3);transition:transform 0.2s,box-shadow 0.2s}input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 3px 12px rgba(5,150,105,0.4)}input[type="range"]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:var(--emerald-600);cursor:pointer;border:3px solid white;box-shadow:0 2px 8px rgba(5,150,105,0.3)}.finder-actions{display:flex;gap:12px;justify-content:center;margin-top:32px;flex-wrap:wrap}.finder-loading{text-align:center;padding:48px 24px;color:var(--text-muted)}.finder-spinner{width:36px;height:36px;border:3px solid var(--bg-muted);border-top-color:var(--emerald-600);border-radius:50%;animation:spin 0.8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.tool-results{margin-top:40px}.tool-results-title{font-size:1.15rem;font-weight:700;margin-bottom:20px;text-align:center}.tool-results-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.result-rank{position:absolute;top:12px;right:16px;font-family:'JetBrains Mono',monospace;font-size:0.82rem;font-weight:600;color:var(--text-muted)}.result-city-name{font-size:1.05rem;font-weight:700;margin-bottom:4px;color:var(--text-primary)}.result-dept{font-size:0.82rem;color:var(--text-tertiary);margin-bottom:12px}.result-score{margin-bottom:12px}.result-score-value{font-family:'JetBrains Mono',monospace;font-size:1.6rem;font-weight:700;color:var(--emerald-600)}.result-score-label{font-size:0.82rem;color:var(--text-muted);font-weight:500}.result-indicators{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:10px}.result-mini{display:flex;justify-content:space-between;align-items:center;font-size:0.78rem;padding:4px 8px;background:var(--bg-muted);border-radius:var(--radius-xs)}.result-mini-label{color:var(--text-tertiary)}.result-mini-value{font-family:'JetBrains Mono',monospace;font-weight:600;color:var(--text-secondary)}.result-pop{font-size:0.78rem;color:var(--text-muted);margin-top:4px}.quiz-container{max-width:600px;margin:0 auto}.quiz-question{background:white;border:1px solid rgba(0,0,0,0.05);border-radius:var(--radius-xl);padding:32px;margin-bottom:20px}.quiz-question-num{font-size:0.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.05em;margin-bottom:12px}.quiz-question h3{font-size:1.05rem;margin-bottom:20px;font-weight:600}.quiz-option{display:block;width:100%;padding:14px 20px;border:1px solid rgba(0,0,0,0.08);border-radius:var(--radius-md);margin-bottom:8px;cursor:pointer;font-size:0.92rem;text-align:left;background:white;font-family:inherit;transition:all 0.2s;color:var(--text-primary)}.quiz-option:hover{border-color:var(--emerald-300);background:var(--emerald-50)}.quiz-option.selected{border-color:var(--emerald-500);background:var(--emerald-50);color:var(--emerald-700);font-weight:600}.quiz-progress{height:4px;background:var(--bg-muted);border-radius:2px;margin-bottom:32px;overflow:hidden}.quiz-progress-bar{height:100%;background:var(--gradient-cta);border-radius:2px;transition:width 0.4s var(--ease-out)}.quiz-result-header{text-align:center;margin-bottom:28px}.quiz-result-header h2{font-size:1.3rem;font-weight:700;margin-bottom:8px}.quiz-result-header p{color:var(--text-tertiary);font-size:0.92rem}.quiz-result-card{text-align:center}.quiz-result-card .result-rank{position:static;font-size:1.8rem;margin-bottom:8px}.quiz-result-actions{display:flex;gap:12px;justify-content:center;margin-top:32px;flex-wrap:wrap}.tool-coming-soon{text-align:center;padding:60px 24px;background:white;border:1px solid rgba(0,0,0,0.05);border-radius:var(--radius-xl);margin-bottom:40px}.tool-coming-soon-icon{font-size:3rem;margin-bottom:16px}.tool-coming-soon h2{font-size:1.2rem;font-weight:700;margin-bottom:12px}.tool-coming-soon p{color:var(--text-tertiary);font-size:0.92rem;max-width:480px;margin:0 auto 24px}.tool-coming-soon-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.tool-suggestions{margin-top:48px}.tool-suggestions h3{font-size:1.1rem;font-weight:700;margin-bottom:20px}.tool-input{width:100%;padding:16px 20px;font-size:1rem;font-family:inherit;border-radius:14px;border:1.5px solid var(--border);background:var(--bg-glass);color:var(--text-primary);outline:none;transition:all 0.3s}.tool-input:focus{border-color:var(--emerald-400);box-shadow:0 0 0 3px rgba(5,150,105,0.1)}.tool-input::placeholder{color:var(--text-muted)}.tool-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:100;background:var(--bg-surface);border:1.5px solid var(--border);border-radius:14px;max-height:320px;overflow-y:auto;display:none;box-shadow:0 12px 32px rgba(0,0,0,0.08)}.tool-dropdown-item{padding:12px 20px;cursor:pointer;border-bottom:1px solid var(--border);transition:background 0.15s;font-size:0.92rem}.tool-dropdown-item:last-child{border-bottom:none}.tool-dropdown-item:hover{background:rgba(5,150,105,0.06)}.tool-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 36px;font-size:1rem;font-weight:600;font-family:inherit;color:white;background:linear-gradient(135deg,var(--emerald-600),var(--emerald-500));border:none;border-radius:14px;cursor:pointer;transition:all 0.3s;box-shadow:0 4px 12px rgba(5,150,105,0.25)}.tool-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px rgba(5,150,105,0.35)}.tool-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none}.tool-btn-outline{background:transparent;color:var(--emerald-600);border:1.5px solid var(--emerald-400);box-shadow:none}.tool-btn-outline:hover:not(:disabled){background:rgba(5,150,105,0.06);box-shadow:none}.tool-selected-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:10px;background:rgba(5,150,105,0.08);border:1px solid rgba(5,150,105,0.2);color:var(--emerald-600);font-size:0.9rem;font-weight:500;margin-top:10px}.tool-result-card{background:var(--bg-glass);border:1px solid var(--border);border-radius:16px;padding:24px;text-decoration:none;color:inherit;transition:all 0.3s;display:block;position:relative;cursor:pointer}.tool-result-card:hover{transform:translateY(-3px);box-shadow:0 12px 24px rgba(0,0,0,0.06);border-color:var(--emerald-300)}.slider-group input[type="range"]{-webkit-appearance:none;width:100%;height:6px;border-radius:3px;background:var(--border);outline:none;transition:background 0.2s}.slider-group input[type="range"]::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-400));cursor:pointer;box-shadow:0 2px 8px rgba(5,150,105,0.3);border:2px solid white;transition:all 0.2s}.slider-group input[type="range"]::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 4px 12px rgba(5,150,105,0.4)}.slider-group input[type="range"]::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-400));cursor:pointer;box-shadow:0 2px 8px rgba(5,150,105,0.3);border:2px solid white}.quick-access-card{background:var(--bg-glass);border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;text-decoration:none;color:inherit;transition:all 0.3s;display:flex;flex-direction:column;align-items:center;gap:8px}.quick-access-card:hover{transform:translateY(-3px);border-color:var(--emerald-300);box-shadow:0 8px 20px rgba(0,0,0,0.05)}.quick-access-card .city-name{font-weight:700;font-size:1rem;color:var(--text-primary)}.quick-access-card .card-link{font-size:0.82rem;color:var(--emerald-600);font-weight:600}@media (max-width:768px){.tools-grid{grid-template-columns:1fr}.tool-results-grid{grid-template-columns:1fr}.tool-card{padding:20px}.finder-actions{flex-direction:column;align-items:stretch}.quiz-result-actions{flex-direction:column;align-items:stretch}}.pill-link{padding:6px 14px;border-radius:var(--radius-full);background:var(--bg-white);border:1px solid var(--border);font-size:0.82rem;color:var(--text-secondary);font-weight:500;transition:all 0.2s;text-decoration:none;display:inline-block}.pill-link:hover{background:var(--bg-green-tint);color:var(--emerald-600);border-color:var(--emerald-300)}.pill-link-sm{padding:5px 12px;font-size:0.78rem;color:var(--text-tertiary)}@media (prefers-color-scheme:dark){:root:not([data-theme="light"]){--bg-white:#080C18;--bg-surface:#0E1425;--bg-muted:#1A2040;--bg-green-tint:#0C1230;--bg-green-subtle:#1A2040;--bg-glass:rgba(8,12,24,0.85);--bg-glass-strong:rgba(8,12,24,0.92);--text-primary:#E8ECF5;--text-secondary:#B0BCDA;--text-tertiary:#7A88A8;--text-muted:#5A6580;--text-on-dark:#E8ECF5;--emerald-50:#0C1230;--emerald-100:#121A40;--emerald-200:#2A3F7A;--emerald-300:#4A6CB0;--emerald-400:#6B8FD4;--emerald-500:#8BAEE8;--emerald-600:#7BA0DB;--emerald-700:#9BB8E8;--emerald-800:#B3C7EB;--emerald-900:#DCE5F5;--amber-50:#1A1210;--amber-100:#2A1A14;--border:rgba(255,255,255,0.08);--border-light:rgba(255,255,255,0.05);--shadow-green:0 4px 20px rgba(75,160,220,0.15);--shadow-green-lg:0 8px 40px rgba(75,160,220,0.2);--shadow-glow:0 0 60px rgba(75,160,220,0.08);--gradient-cta:linear-gradient(135deg,#1A53BD 0%,#002395 100%);--score-excellent:#7BA0DB;--score-bon:#6B8FD4;--score-correct:#F59E0B;--score-moyen:#F97316;--score-faible:#FF6B78;--data-value:#9BB8E8}}[data-theme="dark"]{--bg-white:#080C18;--bg-surface:#0E1425;--bg-muted:#1A2040;--bg-green-tint:#0C1230;--bg-green-subtle:#1A2040;--bg-glass:rgba(8,12,24,0.85);--bg-glass-strong:rgba(8,12,24,0.92);--text-primary:#E8ECF5;--text-secondary:#B0BCDA;--text-tertiary:#7A88A8;--text-muted:#5A6580;--text-on-dark:#E8ECF5;--emerald-50:#0C1230;--emerald-100:#121A40;--emerald-200:#2A3F7A;--emerald-300:#4A6CB0;--emerald-400:#6B8FD4;--emerald-500:#8BAEE8;--emerald-600:#7BA0DB;--emerald-700:#9BB8E8;--emerald-800:#B3C7EB;--emerald-900:#DCE5F5;--amber-50:#1A1210;--amber-100:#2A1A14;--border:rgba(255,255,255,0.08);--border-light:rgba(255,255,255,0.05);--shadow-green:0 4px 20px rgba(75,160,220,0.15);--shadow-green-lg:0 8px 40px rgba(75,160,220,0.2);--shadow-glow:0 0 60px rgba(75,160,220,0.08);--gradient-cta:linear-gradient(135deg,#1A53BD 0%,#002395 100%);--score-excellent:#7BA0DB;--score-bon:#6B8FD4;--score-correct:#F59E0B;--score-moyen:#F97316;--score-faible:#FF6B78;--data-value:#9BB8E8}[data-theme="dark"] .header.scrolled .nav-link{color:#B0BCDA}[data-theme="dark"] .header.scrolled .nav-link:hover{color:#E8ECF5}[data-theme="dark"] .header.scrolled .nav-cta{color:white}[data-theme="dark"] .mobile-menu a{color:#B0BCDA}[data-theme="dark"] .header.scrolled{background:rgba(8,12,24,0.95);border-color:rgba(255,255,255,0.08)}[data-theme="dark"] .header-search-btn{color:#B0BCDA}[data-theme="dark"] .header-search-btn:hover{color:#E8ECF5}.theme-toggle{width:36px;height:36px;border:1px solid var(--border,rgba(0,0,0,0.08));border-radius:var(--radius-full,9999px);background:var(--bg-glass,rgba(255,255,255,0.65));cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:background 0.2s,border-color 0.2s}.theme-toggle:hover{background:var(--bg-muted)}.fav-link svg{stroke:rgba(255,255,255,0.7);transition:stroke 0.3s}.header.scrolled .fav-link svg{stroke:var(--text-secondary)}.header.scrolled .fav-link svg:hover{stroke:#ED2939}.header.scrolled .theme-toggle{border-color:rgba(0,0,0,0.1)}.fav-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:#DC2626;color:#fff;border-radius:50%;font-size:0.65rem;font-weight:700;display:none;align-items:center;justify-content:center;line-height:1}.france-map-container{position:relative;max-width:100%;margin:0 auto}.section .france-map-container{max-width:600px}.carte-page .france-map-container{max-width:100%}.france-map-wrapper{position:relative;width:100%}.france-map-wrapper svg{width:100%;height:auto;display:block}.france-map-wrapper svg .dept-group{cursor:pointer;transition:transform 0.15s}.france-map-wrapper svg .dept-group rect{transition:fill 0.2s,filter 0.2s}.france-map-wrapper svg .dept-group text{transition:fill 0.2s;pointer-events:none;user-select:none}.france-map-wrapper svg .dept-group:hover rect{fill:#002395 !important;filter:drop-shadow(0 2px 6px rgba(0,35,149,0.35))}.france-map-wrapper svg .dept-group:hover text{fill:white !important}.france-map-tooltip{position:absolute;padding:10px 16px;background:var(--bg-dark,#080C18);color:white;border-radius:8px;font-size:0.85rem;font-weight:500;pointer-events:none;z-index:100;box-shadow:0 4px 20px rgba(0,0,0,0.25);white-space:nowrap;transform:translate(-50%,-120%);display:none;opacity:0;transition:opacity 0.15s}.france-map-tooltip.visible{display:block;opacity:1}.france-map-tooltip::after{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid var(--bg-dark,#080C18)}.france-map-legend{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;font-size:0.78rem;color:var(--text-tertiary)}.france-map-legend-bar{width:120px;height:8px;border-radius:4px;background:linear-gradient(90deg,#DCE5F5,#002395)}.france-map-container svg .dept-path{fill:#DCE5F5;stroke:white;stroke-width:0.8;cursor:pointer;transition:fill 0.2s,stroke 0.2s,stroke-width 0.2s}.france-map-container svg .dept-path:hover{fill:#002395;stroke:white;stroke-width:2;filter:drop-shadow(0 2px 6px rgba(0,35,149,0.35))}.france-map-container svg{width:100%;height:auto;display:block}@media (max-width:640px){.france-map-container{max-width:100%}.france-map-wrapper svg .dept-group rect{}.france-map-tooltip{font-size:0.78rem;padding:8px 12px}}.city-data-card{background:var(--bg-white);border:1px solid rgba(0,0,0,0.06);border-radius:var(--radius-xl);padding:32px;transition:all 0.3s var(--ease-out)}.city-data-card:hover{box-shadow:var(--shadow-lg);border-color:rgba(0,35,149,0.12)}.city-data-card .card-icon{font-size:1.5rem;margin-bottom:16px}.city-data-card .card-value{font-family:'Space Grotesk',monospace;font-size:2rem;font-weight:500;line-height:1;margin-bottom:4px}.city-data-card .card-label{font-family:'DM Sans',sans-serif;font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-tertiary);margin-bottom:12px}.city-data-card .card-context{font-size:0.82rem;color:var(--text-tertiary);line-height:1.5}.city-data-card .card-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;font-size:0.82rem;font-weight:600;color:var(--emerald-600);transition:gap 0.3s var(--ease-out)}.city-data-card .card-link:hover{gap:10px}.city-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.city-grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.city-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width:1024px){.city-grid-3{grid-template-columns:repeat(2,1fr)}.city-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.city-grid-3{grid-template-columns:1fr}.city-grid-4{grid-template-columns:1fr}.city-grid-2{grid-template-columns:1fr}.city-data-card{padding:24px}}.score-bar-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid rgba(0,0,0,0.04)}.score-bar-row:last-child{border-bottom:none}.score-bar-icon{font-size:1.1rem;width:28px;text-align:center}.score-bar-label{font-size:0.85rem;font-weight:600;width:100px}.score-bar-track{flex:1;height:8px;background:var(--bg-muted);border-radius:4px;overflow:hidden}.score-bar-fill{height:100%;border-radius:4px;transition:width 1.5s var(--ease-out)}.score-bar-value{font-family:'Space Grotesk',monospace;font-size:0.85rem;font-weight:500;width:40px;text-align:right}.badge-desert{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:var(--radius-full);background:#FFF5F5;color:#ED2939;font-size:0.78rem;font-weight:700;border:1px solid #FFE0E3}.mini-stat{display:flex;align-items:baseline;gap:6px}.mini-stat-value{font-family:'Space Grotesk',monospace;font-size:1.1rem;font-weight:500}.mini-stat-label{font-size:0.78rem;color:var(--text-tertiary)}.nearby-scroll{display:flex;gap:16px;overflow-x:auto;padding-bottom:12px;scroll-snap-type:x mandatory}.nearby-scroll::-webkit-scrollbar{height:4px}.nearby-scroll::-webkit-scrollbar-track{background:var(--bg-muted);border-radius:2px}.nearby-scroll::-webkit-scrollbar-thumb{background:#B3C7EB;border-radius:2px}.nearby-card{flex-shrink:0;width:200px;scroll-snap-align:start;background:var(--bg-white);border:1px solid rgba(0,0,0,0.06);border-radius:var(--radius-lg);padding:20px;text-align:center;transition:all 0.3s;text-decoration:none;color:inherit}.nearby-card:hover{border-color:#B3C7EB;box-shadow:var(--shadow-md);transform:translateY(-2px)}.faq-item{border-bottom:1px solid rgba(0,0,0,0.06)}.faq-item summary{padding:18px 0;font-size:0.95rem;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center}.faq-item summary::-webkit-details-marker{display:none}.faq-item summary::after{content:'+';font-size:1.2rem;color:var(--text-muted);transition:transform 0.3s}.faq-item[open] summary::after{content:'\2212'}.faq-item .faq-answer{padding:0 0 18px;font-size:0.9rem;color:var(--text-secondary);line-height:1.7}.city-section{padding:80px 0}.city-section-surface{padding:80px 0;background:var(--bg-surface)}@media (max-width:768px){.city-section,.city-section-surface{padding:48px 0}}.hero-city::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#002395 33%,#FEFEFE 33%,#FEFEFE 66%,#ED2939 66%)}.article-content{font-size:1.08rem;line-height:1.75;color:var(--text-primary);letter-spacing:-0.005em}.article-content h2{font-size:1.5rem;font-weight:800;margin:56px 0 24px;padding:24px 28px 20px;color:var(--text-primary);background:var(--bg-glass);border-radius:16px;border-left:4px solid var(--emerald-400)}.article-content h3{font-size:1.18rem;font-weight:700;margin:36px 0 16px;color:var(--text-primary);padding-left:16px;border-left:3px solid var(--emerald-300)}.article-content p{margin-bottom:22px;line-height:1.75}.article-content a{color:var(--emerald-600);text-decoration:underline;text-underline-offset:3px;font-weight:500;transition:color 0.2s}.article-content a:hover{color:var(--emerald-400)}.article-content ul,.article-content ol{margin:20px 0 28px;padding-left:20px}.article-content li{margin-bottom:10px;padding-left:6px;line-height:1.65}.article-content ul li::marker{color:var(--emerald-500)}.article-content ol li::marker{color:var(--emerald-500);font-weight:700}.article-content img{max-width:100%;height:auto;border-radius:16px;margin:28px 0;border:1px solid var(--border)}.article-content strong{font-weight:700;color:var(--text-primary)}.article-content table{width:100%;border-collapse:separate;border-spacing:0;margin:28px 0;border-radius:14px;overflow:hidden;border:1px solid var(--border)}.article-content th{background:var(--bg-glass);padding:14px 18px;text-align:left;font-weight:700;font-size:0.85rem;color:var(--text-primary);border-bottom:2px solid var(--border);text-transform:uppercase;letter-spacing:0.04em}.article-content td{padding:14px 18px;border-bottom:1px solid var(--border);font-size:0.92rem}.article-content tr:last-child td{border-bottom:none}.article-content tr:hover td{background:rgba(5,150,105,0.03)}.article-content blockquote{margin:28px 0;padding:24px 28px;border-left:4px solid var(--emerald-400);background:rgba(5,150,105,0.04);border-radius:0 16px 16px 0;font-style:italic;color:var(--text-secondary);font-size:1.05rem}.article-lead{font-size:1.15rem;font-weight:500;line-height:1.7;color:var(--emerald-800);border-left:4px solid var(--emerald-400);padding:20px 24px;margin-bottom:32px;background:rgba(5,150,105,0.04);border-radius:0 16px 16px 0}.article-author{display:flex;align-items:center;gap:16px;padding:20px 24px;margin-bottom:28px;background:var(--bg-glass);border:1px solid var(--border);border-radius:16px}.author-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid var(--emerald-200)}.author-name{font-weight:700;font-size:0.95rem;color:var(--text-primary)}.author-bio{font-size:0.82rem;color:var(--text-muted);line-height:1.45;margin-top:3px}.article-author-card{display:flex;gap:24px;padding:36px;align-items:flex-start;border:1px solid var(--border)}.article-author-card h3{margin:0 0 10px;font-size:1.15rem;font-weight:800}.article-author-card p{font-size:0.92rem;color:var(--text-secondary);line-height:1.6;margin:0}.author-avatar-lg{width:88px;height:88px;border-radius:50%;object-fit:cover;flex-shrink:0;border:3px solid var(--emerald-200)}.author-links{display:flex;gap:16px;margin-top:16px}.author-links a{font-size:0.85rem;color:var(--emerald-600);font-weight:600;text-decoration:none;padding:6px 16px;border-radius:8px;background:rgba(5,150,105,0.08);transition:all 0.2s}.author-links a:hover{background:rgba(5,150,105,0.15)}.article-callout{padding:24px 28px;margin:32px 0;border-left:4px solid var(--emerald-400);background:rgba(5,150,105,0.04);border-radius:0 16px 16px 0}.article-callout strong{color:var(--emerald-700)}.article-callout p:last-child{margin-bottom:0}.article-ranking{margin:28px 0}.article-ranking-item{display:flex;align-items:flex-start;gap:18px;padding:20px;margin-bottom:10px;border-radius:16px;background:var(--bg-glass);border:1px solid var(--border);transition:all 0.2s}.article-ranking-item:hover{border-color:var(--emerald-300);transform:translateX(4px)}.article-ranking-num{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,var(--emerald-500),var(--emerald-400));color:white;font-weight:800;font-size:0.95rem;flex-shrink:0;box-shadow:0 4px 12px rgba(5,150,105,0.25)}.article-featured-img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:24px;border:1px solid var(--border);margin-bottom:36px;box-shadow:0 8px 32px rgba(0,0,0,0.06)}.article-share-btns{display:flex;gap:10px;flex-wrap:wrap}.article-share-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:12px;color:white;font-size:0.85rem;font-weight:600;text-decoration:none;transition:all 0.2s;border:none;cursor:pointer}.article-share-btn:hover{opacity:0.85;transform:translateY(-1px)}.article-share-btn--x{background:#000}.article-share-btn--fb{background:#1877F2}.article-share-btn--li{background:#0A66C2}.article-share-btn--copy{background:var(--bg-glass);border:1.5px solid var(--border);color:var(--text-primary)}.article-source{margin-top:40px;padding:20px 24px;font-size:0.82rem;color:var(--text-muted);background:var(--bg-glass);border-radius:12px;border:1px solid var(--border);line-height:1.5}.article-content .faq-item{margin-bottom:8px;border-radius:14px;background:var(--bg-glass);border:1px solid var(--border);overflow:hidden}.article-content .faq-item summary{padding:16px 20px;font-weight:600;font-size:0.98rem;cursor:pointer;color:var(--text-primary)}.article-content .faq-item .faq-answer{padding:0 20px 16px;font-size:0.95rem;color:var(--text-secondary);line-height:1.65}.article-cocon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}@media (max-width:600px){.article-author-card{flex-direction:column;align-items:center;text-align:center}.author-links{justify-content:center}.article-content h2{font-size:1.25rem;padding:18px 20px 14px}.article-featured-img{border-radius:16px}.article-ranking-item{padding:14px;gap:12px}}@media print{.header,.footer,.mobile-menu,.hero-scroll,.nav-cta,.search-bar,.search-pills,.view-more,.cta-banner,[data-fav-slug],.internal-links,.theme-toggle,.fav-link,.print-btn{display:none !important}.hero{min-height:auto !important;padding:40px 20px !important}.section{padding:24px 0 !important}body{font-size:11pt;color:#000;background:#fff}.stat-number{color:#002395 !important}a{color:#001D7A !important;text-decoration:underline}a::after{content:" (" attr(href) ")" !important;font-size:0.8em;color:#666}}