@import "https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&display=swap";body{background:#fafafa;margin:0;padding:20px;font-family:sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#fff;--color-text:#1a1a1a;--color-text-secondary:#666;--color-border:#e0e0e0;--color-surface:#f5f5f5;--color-accent:#333;--color-highlight:#fcd116;--font-body:"Montserrat", -apple-system, BlinkMacSystemFont, sans-serif;--shadow-sm:0 1px 3px #0000000f;--max-width:900px;--transition:.3s ease}html,body{overscroll-behavior-y:none}body{color:var(--color-text);-webkit-font-smoothing:antialiased;background-color:#fafafa;font-family:sans-serif}.navbar{z-index:100;background:var(--color-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);position:sticky;top:0}.navbar:before{content:"";background:var(--color-bg);height:200px;position:absolute;bottom:100%;left:0;right:0}.nav-container{max-width:var(--max-width);justify-content:space-between;align-items:center;height:56px;margin:0 auto;padding:0 24px;display:flex}.lang-toggle{border:1.5px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-body);cursor:pointer;letter-spacing:.05em;transition:color var(--transition), border-color var(--transition), background var(--transition);background:0 0;border-radius:14px;padding:4px 10px;font-size:.75rem;font-weight:600}.lang-toggle:hover{color:var(--color-text);border-color:var(--color-text)}.nav-links{gap:40px;list-style:none;display:flex}.nav-links a{color:var(--color-text-secondary);letter-spacing:.12em;text-transform:uppercase;transition:color var(--transition);cursor:pointer;font-size:.8rem;font-weight:500;text-decoration:none;position:relative}.nav-links a:hover,.nav-links a.active{color:var(--color-text)}.nav-links a:after{content:"";background:var(--color-text);width:0;height:2px;transition:width .3s;position:absolute;bottom:-4px;left:0}.nav-links a:hover:after,.nav-links a.active:after{width:100%}.app{min-height:100vh}.main{max-width:var(--max-width);margin:0 auto;padding:48px 24px}.lesson-content h2{margin-bottom:6px;font-size:22px;font-weight:700}.lesson-content h3{margin-top:24px;margin-bottom:8px;font-size:16px;font-weight:600}.lesson-subtitle{color:var(--color-text-secondary);margin-bottom:28px;font-size:14px}.lesson-content p{margin-bottom:12px;font-size:14px;line-height:1.7}.lesson-content code{background:var(--color-surface);border-radius:3px;padding:2px 6px;font-size:13px}.viz-toggle{gap:0;margin-bottom:24px;display:flex}.toggle-btn{border:1.5px solid var(--color-text);cursor:pointer;font-family:var(--font-body);color:var(--color-text);background:0 0;padding:8px 24px;font-size:13px;font-weight:500;transition:all .15s}.toggle-btn:first-child{border-radius:4px 0 0 4px}.toggle-btn:not(:first-child){border-left:none}.toggle-btn:last-child{border-radius:0 4px 4px 0}.toggle-active{background:var(--color-text);color:#fff}.continent-legend{flex-wrap:wrap;justify-content:center;gap:16px;margin-bottom:8px;display:flex}.legend-item{font-size:12px;font-family:var(--font-body);color:var(--color-text-secondary);align-items:center;gap:6px;display:flex}.legend-dot{border-radius:3px;flex-shrink:0;width:12px;height:12px}.viz-container{justify-content:center;padding:24px 0;display:flex}.economist-viz{justify-content:flex-start;overflow-x:auto}.economist-chart{width:min(100%,820px);min-width:720px;height:auto;font-family:Arial,Helvetica,sans-serif;display:block}.economist-notes{border-top:1px solid var(--color-border);max-width:720px;margin-top:8px;padding-top:16px}.gapminder-project{max-width:880px}.gapminder-viz{justify-content:flex-start;padding:8px 0 18px;overflow-x:auto}.bubble-plot{background:0 0;min-width:800px;height:auto;font-family:sans-serif;display:block}.axis text,.color-legend text,.bubble-legend text,.median-label,.country-label{font-family:sans-serif}.axis text{fill:#333;font-size:11px}.axis-label{fill:#666;font-size:12px;font-weight:400}.direction-arrow{stroke:#b5b5b5;stroke-width:.85px}.direction-label{fill:#a5a5a5;font-family:var(--font-body);letter-spacing:0;font-size:18px;font-weight:400}.median-line{stroke:#c9c9c9;stroke-width:1px;stroke-dasharray:none}.median-label{fill:#5f5f5f;font-family:var(--font-body);font-size:11px;font-weight:500}.median-label-life{paint-order:stroke;stroke:#fafafae6;stroke-width:4px;stroke-linejoin:round}.quadrant-label{fill:#8a8a8a;font-family:sans-serif;font-size:17px;font-weight:600}.quadrant-shade{fill:#f3f3f4;opacity:.8}.country-label{fill:#4d7771;paint-order:stroke;stroke:#fafafaeb;stroke-width:4px;stroke-linejoin:round;font-size:13px;font-weight:400}.color-legend text,.bubble-legend text{fill:#666;font-size:10.5px}.bubble-legend .legend-title{fill:#333;font-size:11px;font-weight:700}.data-message{color:var(--color-text-secondary);font-size:14px}.encoding-summary{border-top:1px solid var(--color-border);grid-template-columns:230px 1fr;align-items:center;column-gap:36px;max-width:800px;margin-top:2px;padding:14px 0 16px;display:grid}.encoding-item{align-items:center;gap:10px;display:flex}.encoding-item p{min-width:86px;margin:0;line-height:1.35}.encoding-item p strong,.encoding-item p span{font-size:12px;display:block}.encoding-item p strong{color:var(--color-text);font-weight:600}.encoding-item p span{color:var(--color-text-secondary)}.encoding-colors{align-items:flex-start;gap:16px}.encoding-size-svg{flex-shrink:0;display:block}.continent-key{color:var(--color-text-secondary);flex-wrap:nowrap;align-items:center;gap:20px;padding-top:2px;font-size:11px;display:flex}.continent-key span{white-space:nowrap;align-items:center;gap:7px;display:inline-flex}.continent-key i{border-radius:50%;flex:none;width:8px;height:8px;display:inline-block}.quadrant-summary{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 28px;max-width:800px;padding-top:8px;display:grid}.quadrant-note{border-top:1px solid var(--color-border);max-width:800px;color:var(--color-text-secondary);margin:0 0 8px;padding-top:16px;font-size:12px;line-height:1.6}.quadrant-summary-item{grid-template-columns:28px 1fr;align-items:baseline;column-gap:10px;display:grid}.quadrant-summary-number{border:1px solid var(--color-border);width:22px;height:22px;color:var(--color-text-secondary);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:inline-flex}.quadrant-summary-item h3{margin:0 0 2px;font-size:13px;font-weight:600}.quadrant-summary-item p{color:var(--color-text-secondary);margin:0;font-size:12px;line-height:1.5}.method-note{border-top:1px solid var(--color-border);max-width:800px;color:var(--color-text-secondary);margin:36px 0 0;padding-top:18px;font-size:11px;font-style:italic;line-height:1.6}.chart-source{color:#8a8a8a;max-width:800px;margin:18px 0 0;font-size:11px}.home-section{margin-bottom:24px}.status-list{padding:0;list-style:none}.status-list li{align-items:center;gap:10px;padding:6px 0;font-size:14px;display:flex}.dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.dot.done{background:var(--color-highlight)}.dot.pending{background:var(--color-border)}.home-note{color:var(--color-text-secondary);margin-top:8px;font-size:13px;font-style:italic}.tips-list{margin-top:8px;padding-left:20px}.tips-list li{margin-bottom:8px;font-size:14px;line-height:1.7}.folder-section{padding-top:4px}.folder-tree{border-left:2px solid var(--color-border);color:var(--color-text-secondary);margin:10px 0 22px;padding:2px 0 2px 16px}.folder-tree p{grid-template-columns:118px 1fr;align-items:baseline;column-gap:18px;margin-bottom:6px;font-size:13px;line-height:1.7;display:grid}.folder-tree code{background:var(--color-surface);color:var(--color-text);padding:2px 6px;font-family:ui-monospace,SFMono-Regular,Consolas,Liberation Mono,monospace;font-size:12px}.folder-tree span:before{content:""}.yan-tips-list{margin-top:8px;padding-left:20px}.yan-tips-list li{margin-bottom:8px;padding-left:0;font-size:14px;line-height:1.7}.yan-tips-list li:before{content:none}.highlight-link{color:var(--color-text);background:linear-gradient(#0000 60%,#b8e6b0 60% 100%);padding:0 .15em;font-weight:600;text-decoration:none;transition:background .3s}.highlight-link:hover{background:linear-gradient(#0000 40%,#b8e6b0 40% 100%)}@media (width<=768px){.nav-links{gap:20px}.nav-links a{font-size:.7rem}.main{padding:32px 16px}.folder-tree{padding-left:14px}.folder-tree p{font-size:13px;display:block}.folder-tree span{margin-top:2px;padding-left:0;display:block}.encoding-summary,.quadrant-summary{grid-template-columns:1fr}.continent-key{justify-content:flex-start}}
