:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.app-header{z-index:100;background:#1f4e5f;justify-content:space-between;align-items:center;height:64px;padding:0 2rem;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #0003}.header-logo{align-items:baseline;gap:.4rem;text-decoration:none;display:flex}.logo-osa{color:#fff;letter-spacing:.05em;font-size:1.4rem;font-weight:700}.logo-tagline{color:#a8cdd8;font-size:.9rem}.header-nav{gap:1.8rem;display:flex}.header-nav a{color:#a8cdd8;font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s}.header-nav a:hover,.header-nav a.active{color:#fff}.header-right{align-items:center;gap:.3rem;display:flex}.lang-btn{color:#a8cdd8;cursor:pointer;background:0 0;border:none;padding:.2rem .4rem;font-size:.85rem;font-weight:600;transition:color .2s}.lang-btn:hover,.lang-btn.active{color:#fff}.lang-sep{color:#a8cdd8;font-size:.8rem}.app-footer{color:#a8cdd8;background:#1f4e5f;justify-content:space-between;gap:2rem;margin-top:4rem;padding:2rem 3rem;display:flex}.footer-col{flex-direction:column;gap:.5rem;display:flex}.footer-brand{gap:.3rem}.footer-logo{color:#fff;font-size:1rem;font-weight:700}.footer-tagline{font-size:.85rem;font-style:italic}.footer-license{opacity:.7;margin-top:.4rem;font-size:.75rem}.footer-nav a,.footer-links a{color:#a8cdd8;font-size:.85rem;text-decoration:none;transition:color .2s}.footer-nav a:hover,.footer-links a:hover{color:#fff}.footer-copy{opacity:.6;margin-top:.8rem;font-size:.75rem}.map-container{justify-content:center;display:flex;position:relative}.africa-map{cursor:pointer;width:100%;max-width:500px;height:auto}.country-path{transition:fill .15s}.map-tooltip{color:#fff;pointer-events:none;z-index:200;background:#1f4e5f;border-radius:6px;min-width:130px;padding:.6rem .9rem;position:absolute;box-shadow:0 4px 12px #0000004d}.tooltip-name{font-size:.95rem;font-weight:700}.tooltip-iso{opacity:.7;margin-bottom:.3rem;font-size:.75rem}.tooltip-isa{margin-bottom:.3rem;font-size:.85rem}.tooltip-cta{color:#a8cdd8;font-size:.8rem;font-weight:600}.home-page{max-width:1100px;margin:0 auto}.home-hero{text-align:center;padding:2rem 0 1rem}.hero-title{color:#1f4e5f;margin-bottom:.5rem;font-size:2.2rem;font-weight:700}.hero-subtitle{color:#666;font-size:1rem}.home-body{align-items:flex-start;gap:3rem;margin-top:2rem;display:flex}.home-map{flex:1}.home-intro{flex:0 0 280px;padding-top:2rem}.home-intro p{color:#555;margin-bottom:1.5rem;line-height:1.6}.btn-explore{color:#fff;cursor:pointer;background:#1f4e5f;border:none;border-radius:6px;padding:.7rem 1.4rem;font-size:.9rem;font-weight:600;transition:background .2s}.btn-explore:hover{background:#2e7d6e}.countries-page{max-width:1100px;margin:0 auto}.countries-title{color:#1f4e5f;margin-bottom:1.5rem;font-size:1.8rem;font-weight:700}.countries-filters{flex-direction:column;gap:.8rem;margin-bottom:2rem;display:flex}.search-input{border:1px solid #ccc;border-radius:6px;max-width:300px;padding:.5rem 1rem;font-size:.9rem}.region-filters{flex-wrap:wrap;gap:.4rem;display:flex}.region-btn{color:#1f4e5f;cursor:pointer;background:#f0f7f4;border:1px solid #1f4e5f;border-radius:20px;padding:.3rem .8rem;font-size:.8rem;transition:all .2s}.region-btn.active,.region-btn:hover{color:#fff;background:#1f4e5f}.countries-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;display:grid}.country-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;padding:1rem;text-decoration:none;transition:all .2s;display:flex}.country-card:hover{border-color:#1f4e5f;box-shadow:0 2px 8px #1f4e5f26}.card-iso{color:#1f4e5f;letter-spacing:.05em;font-size:.75rem;font-weight:700}.card-name{color:#2d3748;margin:.2rem 0;font-size:.9rem;font-weight:600}.card-region{color:#888;font-size:.75rem}.score-table-wrapper{width:100%;overflow-x:auto}.year-nav{justify-content:center;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.year-nav-btn{color:#fff;cursor:pointer;background:#1f4e5f;border:none;border-radius:4px;padding:.4rem 1rem;font-size:.85rem;transition:background .2s}.year-nav-btn:disabled{cursor:not-allowed;background:#ccc}.year-nav-btn:hover:not(:disabled){background:#2e7d6e}.year-nav-range{color:#1f4e5f;text-align:center;min-width:100px;font-size:.9rem;font-weight:600}.score-table{border-collapse:collapse;width:100%;font-size:.9rem}.score-table th,.score-table td{text-align:center;border-bottom:1px solid #e2e8f0;padding:.6rem .8rem}.col-indicator{text-align:left;min-width:120px}.col-year{min-width:80px;font-size:.85rem;font-weight:600}.year-status{font-size:.7rem}.cell-label{text-align:left;color:#2d3748;font-weight:600}.cell-score{font-variant-numeric:tabular-nums;font-weight:500}.cell-score.collecting{font-style:italic;color:#aaa!important}.row-isa td{background:#f0f7f4;border-top:2px solid #1f4e5f;border-bottom:2px solid #1f4e5f;font-weight:700}.row-trajectory td{background:#f8f9fa;font-style:italic}.row-pillar:hover td{background:#f0f7f4}.cell-action{width:40px}.btn-pillar{color:#1f4e5f;cursor:pointer;background:0 0;border:1px solid #1f4e5f;border-radius:4px;padding:.2rem .5rem;font-size:.9rem;font-weight:700;transition:all .2s}.btn-pillar:hover{color:#fff;background:#1f4e5f}.country-page{max-width:1000px;margin:0 auto}.country-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.country-title{color:#1f4e5f;font-size:2rem;font-weight:700}.country-actions{justify-content:flex-end;margin-top:2rem;display:flex}.btn-projects{color:#fff;background:#1f4e5f;border-radius:6px;padding:.6rem 1.4rem;font-weight:600;text-decoration:none;transition:background .2s}.btn-projects:hover{background:#2e7d6e}.projects-page{max-width:1100px;margin:0 auto}.projects-header{align-items:flex-start;margin-bottom:1.5rem;display:flex}.projects-title{color:#1f4e5f;margin-top:.3rem;font-size:1.8rem;font-weight:700}.back-link{color:#1f4e5f;margin-bottom:.3rem;font-size:.85rem;text-decoration:none;display:block}.pillar-tabs{flex-wrap:wrap;gap:.4rem;margin-bottom:2rem;display:flex}.pillar-tab{color:#1f4e5f;cursor:pointer;background:#f0f7f4;border:1px solid #1f4e5f;border-radius:20px;padding:.3rem .7rem;font-size:.8rem;font-weight:600;transition:all .2s}.pillar-tab.active,.pillar-tab:hover{color:#fff;background:#1f4e5f}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.2rem;display:grid}.project-card{background:#fff;border:1px solid #e2e8f0;border-radius:8px;flex-direction:column;gap:.5rem;padding:1.2rem;text-decoration:none;transition:all .2s;display:flex}.project-card:hover{border-color:#1f4e5f;box-shadow:0 3px 12px #1f4e5f26}.card-pillar{color:#2e7d6e;letter-spacing:.08em;text-transform:uppercase;font-size:.7rem;font-weight:700}.card-warning{color:#7d4800;background:#fff8e6;border-radius:4px;padding:.3rem .6rem;font-size:.78rem}.card-title{color:#2d3748;flex:1;font-size:.95rem;font-weight:600}.card-status{font-size:.78rem}.status-available{color:#1b5e20;font-weight:600}.status-pending{color:#7d4800}.card-cta{color:#1f4e5f;margin-top:.3rem;font-size:.82rem;font-weight:600}.no-projects{text-align:center;color:#888;padding:2rem}.page-loading{text-align:center;color:#666;padding:2rem}.project-detail-page{max-width:800px;margin:0 auto}.detail-breadcrumb{color:#888;margin-bottom:1.5rem;font-size:.82rem}.detail-breadcrumb a{color:#1f4e5f;text-decoration:none}.detail-breadcrumb a:hover{text-decoration:underline}.detail-pillar{color:#2e7d6e;letter-spacing:.08em;text-transform:uppercase;font-size:.75rem;font-weight:700}.detail-title{color:#1f4e5f;margin:.4rem 0;font-size:1.8rem;font-weight:700}.detail-warning{color:#7d4800;background:#fff8e6;border-radius:6px;margin-top:.5rem;padding:.5rem 1rem;font-size:.85rem}.detail-body{flex-direction:column;gap:2rem;margin-top:2rem;display:flex}.detail-description h2,.premium-block h2{color:#1f4e5f;margin-bottom:.8rem;font-size:1.1rem;font-weight:600}.detail-description p{color:#4a5568;line-height:1.7}.detail-premium{flex-direction:column;gap:1.5rem;display:flex}.premium-block{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem}.premium-preview{color:#555;margin-bottom:1rem;font-size:.9rem;line-height:1.6}.premium-gate{border-top:1px solid #e2e8f0;justify-content:space-between;align-items:center;gap:1rem;padding-top:1rem;display:flex}.premium-gate p{color:#666;font-size:.85rem}.premium-na{color:#aaa;font-size:.9rem;font-style:italic}.btn-request{color:#fff;cursor:pointer;white-space:nowrap;background:#1f4e5f;border:none;border-radius:6px;padding:.6rem 1.2rem;font-size:.85rem;font-weight:600;transition:background .2s}.btn-request:hover{background:#2e7d6e}.page-loading,.page-error{text-align:center;color:#666;padding:2rem}.register-page{max-width:680px;margin:0 auto}.register-header{margin-bottom:2rem}.register-title{color:#1f4e5f;font-size:1.8rem;font-weight:700}.register-subtitle{color:#888;margin-top:.3rem;font-size:.9rem}.register-context{color:#555;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.8rem;font-size:.85rem;display:flex}.ctx-tag{color:#1f4e5f;background:#e8f4f8;border-radius:12px;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.register-form{flex-direction:column;gap:1.2rem;display:flex}.register-form label{color:#4a5568;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;display:flex}.register-form input,.register-form select,.register-form textarea{border:1px solid #cbd5e0;border-radius:6px;padding:.5rem .8rem;font-family:inherit;font-size:.9rem;transition:border-color .2s}.register-form input:focus,.register-form select:focus,.register-form textarea:focus{border-color:#1f4e5f;outline:none}.form-full{color:#4a5568;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;display:flex}.form-actions{justify-content:flex-end;margin-top:.5rem;display:flex}.btn-submit{color:#fff;cursor:pointer;background:#1f4e5f;border:none;border-radius:6px;padding:.7rem 1.8rem;font-size:.95rem;font-weight:600;transition:background .2s}.btn-submit:hover:not(:disabled){background:#2e7d6e}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.register-success{text-align:center;padding:3rem 2rem}.register-success h1{color:#1b5e20;margin-bottom:1rem;font-size:2rem}.register-success p{color:#555;margin-bottom:2rem}.btn-home{color:#fff;background:#1f4e5f;border-radius:6px;padding:.6rem 1.4rem;font-weight:600;text-decoration:none}.pillar-page{max-width:800px;margin:0 auto}.pillar-header{margin-bottom:2rem}.pillar-code-badge{color:#fff;letter-spacing:.08em;background:#1f4e5f;border-radius:4px;margin-bottom:.6rem;padding:.3rem .8rem;font-size:.85rem;font-weight:700;display:inline-block}.pillar-title{color:#1f4e5f;margin-bottom:.4rem;font-size:1.8rem;font-weight:700}.back-link{color:#1f4e5f;font-size:.85rem;text-decoration:none}.back-link:hover{text-decoration:underline}.pillar-section{border-bottom:1px solid #e2e8f0;margin-bottom:2rem;padding-bottom:1.5rem}.pillar-section h2{color:#1f4e5f;margin-bottom:.8rem;font-size:1.1rem;font-weight:700}.pillar-section p{color:#4a5568;line-height:1.8}.indicators-list{flex-wrap:wrap;gap:.5rem;display:flex}.indicator-tag{color:#2e7d6e;background:#f0f7f4;border:1px solid #2e7d6e;border-radius:20px;padding:.25rem .7rem;font-family:Consolas,monospace;font-size:.8rem;font-weight:600}.sources-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.sources-list li{color:#4a5568;padding-left:1rem;font-size:.9rem;position:relative}.sources-list li:before{content:"→";color:#2e7d6e;position:absolute;left:0}.about-page{max-width:800px;margin:0 auto}.about-title{color:#1f4e5f;margin-bottom:1rem;font-size:2rem;font-weight:700}.about-intro{color:#555;border-bottom:2px solid #e2e8f0;margin-bottom:2.5rem;padding-bottom:1.5rem;font-size:1rem;line-height:1.7}.about-blocks{flex-direction:column;gap:2.5rem;display:flex}.about-block{scroll-margin-top:80px}.block-title{color:#1f4e5f;border-bottom:1px solid #e2e8f0;margin-bottom:.8rem;padding-bottom:.4rem;font-size:1.25rem;font-weight:700}.block-body{color:#4a5568;line-height:1.8}.participate-page{max-width:680px;margin:0 auto}.participate-title{color:#1f4e5f;margin-bottom:1rem;font-size:2rem;font-weight:700}.participate-intro{color:#555;margin-bottom:2rem;line-height:1.7}.participate-context{background:#e8f4f8;border-radius:6px;margin-bottom:1.5rem;padding:.6rem 1rem;font-size:.85rem}.ctx-link{color:#1f4e5f;margin-left:.5rem}.participate-form{flex-direction:column;gap:1rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.participate-form label{color:#4a5568;flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;display:flex}.participate-form input,.participate-form textarea{border:1px solid #cbd5e0;border-radius:6px;padding:.5rem .8rem;font-family:inherit;font-size:.9rem}.participate-form input:focus,.participate-form textarea:focus{border-color:#1f4e5f;outline:none}.btn-submit{color:#fff;cursor:pointer;background:#1f4e5f;border:none;border-radius:6px;align-self:flex-end;padding:.7rem 1.8rem;font-size:.9rem;font-weight:600;transition:background .2s}.btn-submit:hover{background:#2e7d6e}.form-error{color:#b00020;background:#fff0f0;border-radius:6px;padding:.6rem 1rem;font-size:.85rem}.participate-success{color:#1b5e20;background:#f0f7f4;border-radius:8px;padding:1.5rem;font-weight:600}.data-page{max-width:900px;margin:0 auto}.data-title{color:#1f4e5f;margin-bottom:2rem;font-size:2rem;font-weight:700}.data-section{border-bottom:1px solid #e2e8f0;margin-bottom:2.5rem;padding-bottom:1.5rem}.data-section h2{color:#1f4e5f;margin-bottom:.8rem;font-size:1.2rem;font-weight:700}.data-section p{color:#4a5568;margin-bottom:1rem;line-height:1.8}.btn-download,.btn-api,.btn-affiliate{border-radius:6px;padding:.6rem 1.3rem;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.btn-download{color:#fff;background:#1b5e20}.btn-download:hover{background:#2e7d32}.btn-api{color:#fff;background:#1f4e5f}.btn-api:hover{background:#2e7d6e}.btn-affiliate{color:#fff;background:#7d4800}.btn-affiliate:hover{background:#9e6000}.endpoints-list{flex-direction:column;gap:.6rem;display:flex}.endpoint-row{background:#f8f9fa;border-radius:6px;flex-wrap:wrap;align-items:baseline;gap:1rem;padding:.5rem .8rem;font-size:.85rem;display:flex}.ep-method{color:#fff;background:#1f4e5f;border-radius:4px;flex-shrink:0;padding:.1rem .5rem;font-size:.75rem;font-weight:700}.ep-path{color:#2e7d6e;font-family:Consolas,monospace;font-size:.82rem}.ep-desc{color:#666}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
