:root{--bg-primary: #0a0a0a;--bg-secondary: #111111;--bg-card: #161616;--bg-card-hover: #1a1a1a;--bg-elevated: #1e1e1e;--bg-input: #1c1c1e;--border-primary: rgba(255, 255, 255, .08);--border-secondary: rgba(255, 255, 255, .05);--border-hover: rgba(255, 255, 255, .12);--text-primary: rgba(255, 255, 255, .92);--text-secondary: rgba(255, 255, 255, .56);--text-tertiary: rgba(255, 255, 255, .36);--text-inverse: #0a0a0a;--accent-amber: #d4915e;--accent-amber-muted: rgba(212, 145, 94, .15);--accent-amber-text: #e8a96e;--accent-blue: #6b8aad;--accent-blue-muted: rgba(107, 138, 173, .12);--accent-blue-text: #8ba8c8;--accent-green: #6b9a7e;--accent-green-muted: rgba(107, 154, 126, .12);--accent-green-text: #8ab89d;--power-color: #6b8aad;--power-bg: rgba(107, 138, 173, .08);--power-fill: rgba(107, 138, 173, .15);--pollution-color: #d4915e;--pollution-bg: rgba(212, 145, 94, .08);--pollution-fill: rgba(212, 145, 94, .15);--water-color: #6b9a9a;--water-bg: rgba(107, 154, 154, .08);--water-fill: rgba(107, 154, 154, .15);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-7: 28px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--sp-20: 80px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.45, 0, .55, 1);--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--content-max: 1280px;--nav-height: 56px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden}a{color:inherit;text-decoration:none}button{font-family:var(--font-family);cursor:pointer;border:none;background:none;color:inherit}.btn-secondary,.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;transition:all var(--duration-fast) var(--ease-out)}.btn-secondary{color:var(--text-secondary);background:#ffffff0a;border:1px solid var(--border-primary)}.btn-secondary:hover:not(:disabled){color:var(--text-primary);background:#ffffff14;border-color:var(--border-hover)}.btn-primary{color:var(--text-primary);background:#6b8aad33;border:1px solid rgba(107,138,173,.45)}.btn-primary:hover:not(:disabled){background:#6b8aad47;border-color:#6b8aad9e}.btn-untrack{color:var(--accent-amber-text);background:var(--accent-amber-muted);border:1px solid rgba(212,145,94,.5)}.btn-untrack:hover:not(:disabled){color:var(--accent-amber-text);background:#d4915e33;border-color:#d4915eb3}.btn-secondary:disabled,.btn-primary:disabled,.btn-untrack:disabled{opacity:.55;cursor:not-allowed}input,select{font-family:var(--font-family);color:var(--text-primary);background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3);font-size:.875rem;outline:none;transition:border-color var(--duration-fast) var(--ease-out)}input:focus,select:focus{border-color:var(--accent-blue)}.text-display{font-size:2rem;font-weight:600;letter-spacing:-.025em;line-height:1.2}.text-title{font-size:1.375rem;font-weight:600;letter-spacing:-.02em;line-height:1.25}.text-headline{font-size:1.125rem;font-weight:600;letter-spacing:-.015em;line-height:1.3}.text-body{font-size:.9375rem;font-weight:400;line-height:1.5}.text-caption{font-size:.8125rem;font-weight:400;line-height:1.4;color:var(--text-secondary)}.text-overline{font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary)}.text-mono{font-family:var(--font-mono);font-size:.8125rem}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1;padding:var(--sp-8) var(--sp-6);max-width:var(--content-max);margin:0 auto;width:100%}.nav-bar{position:sticky;top:0;z-index:100;height:var(--nav-height);background:#0a0a0ad1;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-primary);display:flex;align-items:center;padding:0 var(--sp-6)}.nav-inner{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:var(--content-max);margin:0 auto}.nav-brand{display:flex;align-items:center;gap:var(--sp-2);font-size:.9375rem;font-weight:600;letter-spacing:-.01em;white-space:nowrap}.nav-brand-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-green);flex-shrink:0}.nav-links{display:flex;align-items:center;gap:var(--sp-1)}.nav-link{padding:var(--sp-2) var(--sp-3);font-size:.8125rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.nav-link:hover{color:var(--text-primary);background:#ffffff0a}.nav-link.active{color:var(--text-primary);background:#ffffff0f}.nav-auth{display:flex;align-items:center;gap:var(--sp-3)}.nav-user{display:flex;align-items:center;gap:var(--sp-2)}.nav-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.nav-user-name{font-size:.8125rem;font-weight:500;color:var(--text-secondary)}.btn-auth{padding:var(--sp-2) var(--sp-4);font-size:.8125rem;font-weight:500;border-radius:var(--radius-sm);transition:all var(--duration-fast) var(--ease-out)}.btn-login{color:var(--text-primary);background:#ffffff0f;border:1px solid var(--border-primary)}.btn-login:hover{background:#ffffff1a;border-color:var(--border-hover)}.btn-logout{color:var(--text-secondary);font-size:.75rem}.btn-logout:hover{color:var(--text-primary)}.card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6);transition:background var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-hover)}.card-clickable{cursor:pointer}.divider{height:1px;background:var(--border-primary);border:none;margin:var(--sp-6) 0}.divider-subtle{background:var(--border-secondary)}.pillar-label{display:inline-flex;align-items:center;gap:var(--sp-1);font-size:.6875rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:2px var(--sp-2);border-radius:4px}.pillar-power{color:var(--power-color);background:var(--power-bg)}.pillar-pollution{color:var(--pollution-color);background:var(--pollution-bg)}.pillar-water{color:var(--water-color);background:var(--water-bg)}.index-score{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;line-height:1}.index-score-sm{font-size:1.125rem}.delta{display:inline-flex;align-items:center;gap:2px;font-size:.75rem;font-weight:500}.delta-up{color:var(--accent-amber-text)}.delta-down{color:var(--accent-green-text)}.delta-neutral{color:var(--text-tertiary)}.pillar-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border-primary);border-radius:var(--radius-md);overflow:hidden}.pillar-cell{background:var(--bg-card);padding:var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-2)}.pillar-cell:first-child{border-radius:var(--radius-md) 0 0 var(--radius-md)}.pillar-cell:last-child{border-radius:0 var(--radius-md) var(--radius-md) 0}.status-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border-primary);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--sp-8)}.status-item{background:var(--bg-card);padding:var(--sp-5) var(--sp-6);text-align:center}.status-value{font-family:var(--font-mono);font-size:1.75rem;font-weight:600;line-height:1;margin-bottom:var(--sp-1)}.status-label{font-size:.6875rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary)}.macro-summary{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6) var(--sp-8);margin-bottom:var(--sp-8)}.macro-summary p{font-size:.9375rem;line-height:1.7;color:var(--text-secondary)}.macro-label{font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--accent-blue);margin-bottom:var(--sp-3)}.section-header{margin-bottom:var(--sp-6)}.section-title{font-size:1.25rem;font-weight:600;letter-spacing:-.02em;margin-bottom:var(--sp-1)}.section-subtitle{font-size:.8125rem;color:var(--text-tertiary)}.category-block{margin-bottom:var(--sp-12)}.category-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--sp-6);padding-bottom:var(--sp-4);border-bottom:1px solid var(--border-primary)}.category-meta{flex:1}.category-name{font-size:1.125rem;font-weight:600;letter-spacing:-.015em;margin-bottom:var(--sp-1)}.category-desc{font-size:.8125rem;color:var(--text-tertiary);max-width:600px;line-height:1.5}.category-averages{display:flex;gap:var(--sp-4);flex-shrink:0}.avg-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-2) var(--sp-3);border-radius:var(--radius-sm);background:#ffffff08}.avg-chip-value{font-family:var(--font-mono);font-size:.9375rem;font-weight:600}.avg-chip-label{font-size:.625rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary)}.tech-list{display:flex;flex-direction:column;gap:var(--sp-3)}.tech-card{display:grid;grid-template-columns:240px 1fr auto;align-items:center;gap:var(--sp-6);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-5) var(--sp-6);cursor:pointer;transition:background var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.tech-card:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translateY(-1px)}.tech-card-info{min-width:0}.tech-card-name{font-size:.9375rem;font-weight:600;letter-spacing:-.01em;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tech-card-desc{font-size:.75rem;color:var(--text-tertiary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.tech-card-pillars{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border-secondary);border-radius:var(--radius-md);overflow:hidden;flex:1}.tech-pillar-cell{background:var(--bg-card);padding:var(--sp-3) var(--sp-4);display:flex;flex-direction:column;gap:var(--sp-1)}.tech-card-actions{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-3);min-width:72px}.alert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:var(--sp-4)}.alert-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-5) var(--sp-6);cursor:pointer;transition:background var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.alert-card:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translateY(-1px)}.alert-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--sp-4)}.alert-card-name{font-size:.9375rem;font-weight:600;letter-spacing:-.01em}.alert-card-meta{font-size:.6875rem;color:var(--text-tertiary);margin-top:2px}.filter-bar{display:flex;flex-wrap:wrap;gap:var(--sp-3);align-items:center;margin-bottom:var(--sp-6);padding:var(--sp-4) var(--sp-5);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.filter-bar input,.filter-bar select{height:36px}.filter-bar input[type=text]{min-width:240px}.filter-label{font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary);margin-right:var(--sp-1)}.scenario-controls{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:var(--sp-4);align-items:end;margin-bottom:var(--sp-8);padding:var(--sp-6);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg)}.control-group{display:flex;flex-direction:column;gap:var(--sp-2)}.control-label{font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary)}.control-group select,.control-group input{height:40px;font-size:.875rem}.btn-simulate{height:40px;padding:0 var(--sp-6);background:#ffffff14;border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-size:.8125rem;font-weight:600;color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out);white-space:nowrap}.btn-simulate:hover{background:#ffffff1f;border-color:var(--border-hover)}.charts-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--sp-4);margin-bottom:var(--sp-6)}.chart-panel{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-5)}.chart-panel-title{font-size:.8125rem;font-weight:600;letter-spacing:-.01em;margin-bottom:var(--sp-4)}.detail-header{margin-bottom:var(--sp-8)}.detail-back{display:inline-flex;align-items:center;gap:var(--sp-2);font-size:.8125rem;color:var(--text-tertiary);margin-bottom:var(--sp-4);transition:color var(--duration-fast) var(--ease-out)}.detail-back:hover{color:var(--text-primary)}.detail-title{font-size:1.75rem;font-weight:600;letter-spacing:-.03em;margin-bottom:var(--sp-2)}.detail-desc{font-size:.9375rem;color:var(--text-secondary);max-width:720px;line-height:1.6}.detail-section{margin-bottom:var(--sp-10)}.detail-section-title{font-size:1rem;font-weight:600;letter-spacing:-.01em;margin-bottom:var(--sp-5);padding-bottom:var(--sp-3);border-bottom:1px solid var(--border-primary)}.driver-breakdown{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-4);display:grid;gap:var(--sp-3)}.driver-card{border:1px solid var(--border-secondary);border-radius:var(--radius-md);padding:var(--sp-4);background:linear-gradient(180deg,#ffffff03,#fff0)}.driver-card-head{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-bottom:var(--sp-3)}.driver-card-label{font-size:.86rem;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.driver-card-value{font-family:var(--font-mono);font-size:.75rem;color:var(--accent-blue-text);background:var(--accent-blue-muted);border:1px solid rgba(107,138,173,.35);border-radius:999px;padding:3px 10px;white-space:nowrap}.driver-card-meter{height:6px;border-radius:999px;background:var(--border-secondary);overflow:hidden}.driver-card-meter-fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--power-color),var(--accent-blue))}.slider-group{display:flex;flex-direction:column;gap:var(--sp-2)}.slider-header{display:flex;justify-content:space-between;align-items:center}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;background:var(--border-primary);border-radius:2px;outline:none;border:none;padding:0}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--text-primary);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.about-content{max-width:720px}.about-content h2{font-size:1.25rem;font-weight:600;letter-spacing:-.02em;margin-top:var(--sp-10);margin-bottom:var(--sp-4)}.about-content p{font-size:.9375rem;color:var(--text-secondary);line-height:1.7;margin-bottom:var(--sp-4)}.about-content ul{list-style:none;padding:0;margin-bottom:var(--sp-6)}.about-content li{font-size:.875rem;color:var(--text-secondary);padding:var(--sp-2) 0;padding-left:var(--sp-5);position:relative}.about-content li:before{content:"";position:absolute;left:0;top:50%;width:4px;height:4px;border-radius:50%;background:var(--text-tertiary);transform:translateY(-50%)}.microcopy{font-size:.6875rem;color:var(--text-tertiary);line-height:1.5;font-style:italic;padding-top:var(--sp-4);border-top:1px solid var(--border-secondary)}.region-panel{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6)}.region-list{display:flex;flex-direction:column;gap:var(--sp-3)}.region-row{display:grid;grid-template-columns:200px 1fr 1fr;gap:var(--sp-4);align-items:center;padding:var(--sp-3) 0;border-bottom:1px solid var(--border-secondary)}.region-row:last-child{border-bottom:none}.region-name{font-size:.8125rem;font-weight:500}.region-bar{height:4px;background:var(--border-primary);border-radius:2px;overflow:hidden}.region-bar-fill{height:100%;border-radius:2px;transition:width var(--duration-slow) var(--ease-out)}.region-value{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);text-align:right}.toggle-group{display:inline-flex;background:#ffffff0a;border:1px solid var(--border-primary);border-radius:var(--radius-sm);overflow:hidden}.toggle-btn{padding:var(--sp-2) var(--sp-4);font-size:.75rem;font-weight:500;color:var(--text-tertiary);transition:all var(--duration-fast) var(--ease-out)}.toggle-btn.active{background:#ffffff14;color:var(--text-primary)}.explorer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:var(--sp-4)}.page-shell{display:grid;gap:var(--sp-8)}.page-header{display:flex;flex-direction:column;gap:var(--sp-2)}.page-header .page-title,.page-header .page-subtitle{margin-bottom:0}.page-intro{margin-bottom:var(--sp-8)}.page-title{font-size:1.5rem;font-weight:600;letter-spacing:-.025em;margin-bottom:var(--sp-2)}.page-subtitle{font-size:.875rem;color:var(--text-tertiary);max-width:640px;line-height:1.6}.home-two-col{display:grid;grid-template-columns:1fr 300px;gap:var(--sp-6);align-items:start}@media (max-width: 900px){.home-two-col{grid-template-columns:1fr}.home-two-col aside{position:static!important}}.mobile-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:#0a0a0aeb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-primary);padding:var(--sp-2) 0 var(--sp-3)}.mobile-nav-inner{display:flex;justify-content:space-around;align-items:center}.mobile-nav-link{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-1) var(--sp-2);font-size:.625rem;font-weight:500;color:var(--text-tertiary);transition:color var(--duration-fast) var(--ease-out)}.notfound-shell{min-height:calc(100vh - var(--nav-height) - var(--sp-12));display:flex;align-items:center;justify-content:center}.notfound-card{width:min(560px,100%);border:1px solid var(--border-primary);background:linear-gradient(180deg,#ffffff08,#ffffff03);border-radius:var(--radius-lg);padding:var(--sp-10);display:flex;flex-direction:column;gap:var(--sp-4);align-items:flex-start}.notfound-code{display:inline-flex;align-items:center;justify-content:center;height:30px;padding:0 var(--sp-3);border-radius:999px;font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-blue-text);background:var(--accent-blue-muted);border:1px solid rgba(107,138,173,.4)}.notfound-title{font-size:2rem;letter-spacing:-.03em;margin:0}.notfound-subtitle{color:var(--text-secondary);max-width:42ch;margin:0}.notfound-actions{margin-top:var(--sp-2)}.notfound-home-btn{min-width:160px}@media (max-width: 640px){.notfound-card{padding:var(--sp-6)}.notfound-title{font-size:1.5rem}}.mobile-nav-link.active{color:var(--text-primary)}.mobile-nav-icon{font-size:1.125rem;line-height:1}@media (max-width: 1024px){.tech-card{grid-template-columns:1fr;gap:var(--sp-4)}.charts-row{grid-template-columns:1fr}.scenario-controls{grid-template-columns:1fr 1fr}.status-strip{grid-template-columns:repeat(2,1fr)}.category-header{flex-direction:column;gap:var(--sp-4)}}@media (max-width: 768px){.nav-links{display:none}.mobile-nav{display:block}.app-content{padding:var(--sp-5) var(--sp-4);padding-bottom:80px}.alert-grid,.explorer-grid,.scenario-controls{grid-template-columns:1fr}.region-row{grid-template-columns:1fr;gap:var(--sp-2)}.pillar-grid,.tech-card-pillars{grid-template-columns:1fr}.pillar-cell:first-child,.pillar-cell:last-child{border-radius:0}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar input[type=text]{min-width:unset}}.sr-only{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);border:0}.fade-in{animation:fadeIn var(--duration-slow) var(--ease-out)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff2e}.news-empty{text-align:center;padding:var(--sp-20) var(--sp-8);color:var(--text-secondary)}.news-empty-icon{font-size:2.5rem;margin-bottom:var(--sp-4);opacity:.4}.news-empty h3{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--sp-2)}.news-grid{display:grid;gap:var(--sp-6)}.news-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-7);transition:border-color var(--duration-normal) var(--ease-out),background var(--duration-normal) var(--ease-out);overflow:hidden}.news-card-image{width:calc(100% + var(--sp-7) * 2);margin:calc(var(--sp-7) * -1) calc(var(--sp-7) * -1) var(--sp-5);height:220px;object-fit:cover;border-bottom:1px solid var(--border-secondary)}.news-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.news-card--expanded{border-color:var(--accent-blue)}.news-card-header{margin-bottom:var(--sp-4)}.news-card-meta{display:flex;align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-3);flex-wrap:wrap}.news-timestamp{font-size:.75rem;font-family:var(--font-mono);color:var(--text-tertiary)}.news-source-count{font-size:.68rem;font-family:var(--font-mono);color:var(--text-secondary);background:var(--bg-elevated);border:1px solid var(--border-primary);border-radius:999px;padding:2px 8px}.news-tags{display:flex;gap:var(--sp-1);flex-wrap:wrap}.news-tag{font-size:.7rem;font-family:var(--font-mono);background:var(--accent-blue-muted);color:var(--accent-blue-text);padding:2px 8px;border-radius:100px;letter-spacing:.02em;text-transform:lowercase}.news-card-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);line-height:1.35;margin-bottom:var(--sp-2)}.news-card-summary{font-size:.9rem;color:var(--text-secondary);line-height:1.55}.news-read-btn,.news-collapse-btn{margin-top:var(--sp-4);font-size:.82rem}.news-card-body{margin-top:var(--sp-4);padding-top:var(--sp-4);border-top:1px solid var(--border-secondary)}.news-content{font-size:.9rem;line-height:1.7;color:var(--text-secondary)}.news-content p{margin-bottom:var(--sp-4)}.news-content p:last-child{margin-bottom:0}.news-content h2,.news-content h3,.news-content h4{color:var(--text-primary);margin:var(--sp-4) 0 var(--sp-2);font-weight:600}.news-content h2{font-size:1.15rem}.news-content h3{font-size:1.05rem}.news-content h4{font-size:.95rem}.news-content strong{color:var(--text-primary);font-weight:600}.news-content ul{padding-left:var(--sp-6);margin:var(--sp-3) 0 var(--sp-4)}.news-content li{margin-bottom:var(--sp-1)}.news-content li:last-child{margin-bottom:0}.news-back-btn{align-self:flex-start;margin-bottom:var(--sp-4)}.news-detail-title{max-width:900px}.news-detail-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-7);max-width:980px}.news-detail-card .news-card-meta,.news-hero-wrap{margin-bottom:var(--sp-5)}.news-hero-image{width:100%;max-height:360px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--border-secondary)}.news-hero-credit{margin-top:var(--sp-2);font-size:.72rem;color:var(--text-tertiary)}.news-hero-credit a{color:var(--accent-blue-text)}.news-audio-block{margin-bottom:var(--sp-5);padding-bottom:var(--sp-4);border-bottom:1px solid var(--border-secondary);display:flex;flex-direction:column;align-items:center;gap:var(--sp-2)}.news-audio-player{width:min(460px,100%)}.news-audio-loading,.news-audio-error{color:var(--text-secondary);font-size:.85rem}.news-sources{margin-top:var(--sp-6);padding-top:var(--sp-4);border-top:1px solid var(--border-secondary)}.news-sources h3{font-size:.95rem;color:var(--text-primary);margin-bottom:var(--sp-2)}.news-sources ul{margin:0;padding-left:var(--sp-5)}.news-sources li{margin-bottom:var(--sp-2);color:var(--text-secondary);font-size:.84rem;line-height:1.45}.news-sources a{color:var(--accent-blue-text)}.gen-panel{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6);margin-bottom:var(--sp-8)}.gen-controls{display:flex;align-items:flex-end;gap:var(--sp-4);flex-wrap:wrap}.gen-label{display:flex;flex-direction:column;gap:var(--sp-2);font-size:.82rem;font-weight:500;color:var(--text-secondary);flex:1;min-width:200px}.gen-select{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.88rem;padding:var(--sp-2) var(--sp-3);font-family:var(--font-family);outline:none;transition:border-color var(--duration-fast) var(--ease-out)}.gen-select:focus{border-color:var(--accent-blue)}.gen-btn{padding:var(--sp-2) var(--sp-5);white-space:nowrap;font-size:.88rem;display:flex;align-items:center;gap:var(--sp-2);min-height:38px}.gen-btn--loading{opacity:.7;cursor:wait}.gen-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--text-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.gen-error{margin-top:var(--sp-4);padding:var(--sp-3) var(--sp-4);background:#dc50501a;border:1px solid rgba(220,80,80,.25);border-radius:var(--radius-sm);color:#e87070;font-size:.85rem}.gen-success{margin-top:var(--sp-4);padding:var(--sp-3) var(--sp-4);background:var(--accent-green-muted);border:1px solid rgba(107,154,126,.25);border-radius:var(--radius-sm);color:var(--accent-green-text);font-size:.85rem;display:flex;align-items:flex-start;gap:var(--sp-3)}.gen-success-icon{font-size:1.1rem;line-height:1;flex-shrink:0}.gen-success-meta{margin-top:var(--sp-1);font-size:.8rem;opacity:.8}.gen-history{margin-top:var(--sp-4)}.gen-history-loading{display:grid;gap:var(--sp-2);margin-bottom:var(--sp-3);color:var(--text-tertiary);font-size:.78rem;font-family:var(--font-mono)}.gen-loading-bar{position:relative;height:8px;border-radius:999px;background:var(--bg-elevated);border:1px solid var(--border-primary);overflow:hidden}.gen-loading-bar:before{content:"";position:absolute;top:0;bottom:0;left:-35%;width:35%;border-radius:inherit;background:linear-gradient(90deg,var(--accent-blue),var(--accent-green));animation:gen-loading-slide 1.2s ease-in-out infinite}@keyframes gen-loading-slide{0%{left:-35%}to{left:100%}}.gen-history-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-bottom:var(--sp-3)}.gen-filter-group{display:inline-flex;align-items:center;gap:6px;padding:4px;border:1px solid var(--border-primary);border-radius:999px;background:var(--bg-elevated)}.gen-filter-btn{border:1px solid transparent;background:transparent;color:var(--text-secondary);border-radius:999px;padding:6px 10px;font-size:.72rem;font-family:var(--font-mono);cursor:pointer}.gen-filter-btn:hover{color:var(--text-primary)}.gen-filter-btn.active{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-hover)}.gen-history-empty{color:var(--text-tertiary);font-size:.88rem}.gen-history-list{display:grid;gap:var(--sp-3)}.gen-history-item{background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-md);padding:var(--sp-4);transition:border-color var(--duration-fast) var(--ease-out)}.gen-history-item:hover{border-color:var(--border-hover)}.gen-history-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--sp-1)}.gen-history-title-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-2)}.gen-status-badge{font-size:.65rem;font-family:var(--font-mono);padding:3px 8px;border-radius:999px;border:1px solid var(--border-primary);text-transform:uppercase;letter-spacing:.04em}.gen-status-badge.draft{color:var(--text-secondary);background:var(--bg-elevated)}.gen-status-badge.published{color:var(--accent-green-text);background:var(--accent-green-muted);border-color:#6b9a7e59}.gen-history-meta{display:flex;gap:var(--sp-3);font-size:.75rem;font-family:var(--font-mono);color:var(--text-tertiary);margin-bottom:var(--sp-2)}.gen-history-tags{color:var(--accent-blue-text)}.gen-history-summary{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.gen-edit-btn{margin-top:var(--sp-3)}.gen-history-actions{display:flex;gap:var(--sp-2);flex-wrap:wrap}.gen-delete-btn{border-color:#dc505059;color:#e88d8d}.gen-delete-btn:hover{border-color:#dc50508c;color:#f5aaaa}.gen-editor{margin-top:var(--sp-8);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6);display:grid;gap:var(--sp-4)}.gen-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1300;background:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:var(--sp-4)}.gen-modal{margin-top:0;width:min(860px,100%);max-height:86vh;overflow:auto;border-color:var(--border-hover)}.gen-delete-modal{width:min(560px,100%)}.gen-delete-confirm{background:#6b1f1f;border-color:#8e2a2a}.gen-delete-confirm:hover{background:#822626;border-color:#a03232}.gen-input,.gen-textarea{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;padding:var(--sp-3);font-family:var(--font-family);outline:none;width:100%}.gen-input:focus,.gen-textarea:focus{border-color:var(--accent-blue)}.gen-textarea{resize:vertical}.gen-textarea--summary{min-height:90px}.gen-textarea--content{min-height:320px;font-family:var(--font-mono)}.gen-editor-actions{display:flex;gap:var(--sp-3)}.about-page{max-width:1100px}.about-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-4)}.about-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6)}.about-card-title{font-size:1rem;color:var(--text-primary);margin-bottom:var(--sp-2)}.about-card p{font-size:.88rem;color:var(--text-secondary);line-height:1.6}.about-section{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6)}.about-pillars{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-4)}.about-pillar{border:1px solid var(--border-secondary);border-radius:var(--radius-md);padding:var(--sp-4)}.about-pillar h3{font-size:.95rem;margin-bottom:var(--sp-2)}.about-pillar p{font-size:.84rem;color:var(--text-secondary);line-height:1.55}.about-pillar--power h3{color:var(--power-color)}.about-pillar--pollution h3{color:var(--pollution-color)}.about-pillar--water h3{color:var(--water-color)}.about-list{margin-top:var(--sp-2);padding-left:var(--sp-6);display:grid;gap:var(--sp-2);color:var(--text-secondary);font-size:.88rem}.about-copy{color:var(--text-secondary);line-height:1.65;font-size:.9rem}.about-note{border-style:dashed}.learn-page{max-width:1200px}.learn-section{display:grid;gap:var(--sp-4)}.learn-concepts-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--sp-4)}.learn-concept-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-5)}.learn-concept-card h3{font-size:.92rem;color:var(--text-primary);margin-bottom:var(--sp-2)}.learn-concept-card p{color:var(--text-secondary);font-size:.84rem;line-height:1.6}.learn-tech-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-4)}.learn-tech-card{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6);display:grid;gap:var(--sp-3)}.learn-tech-top{display:flex;justify-content:space-between;gap:var(--sp-3);align-items:baseline}.learn-tech-top h3{font-size:1rem;color:var(--text-primary)}.learn-tech-meta{font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono)}.learn-tech-desc{font-size:.86rem;color:var(--text-secondary);line-height:1.55}.learn-detail-block{border:1px solid var(--border-secondary);border-radius:var(--radius-sm);padding:var(--sp-3)}.learn-detail-block h4{font-size:.78rem;color:var(--text-primary);letter-spacing:.02em;margin-bottom:var(--sp-1)}.learn-detail-block p{font-size:.82rem;color:var(--text-secondary);line-height:1.5}.learn-pillars-row{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.learn-pillars-row span{font-size:.72rem;color:var(--text-secondary);border:1px solid var(--border-secondary);border-radius:999px;padding:2px 8px}.learn-open-btn{margin-top:var(--sp-1);justify-self:start}.learn-petition-row{display:flex;align-items:center;justify-content:space-between;gap:var(--sp-3);margin-top:var(--sp-1)}.learn-petition-count{font-size:.72rem;font-family:var(--font-mono);color:var(--text-tertiary)}.learn-petition-feedback{color:var(--accent-green-text);font-size:.82rem;background:var(--accent-green-muted);border:1px solid rgba(107,154,126,.24);border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3)}.learn-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--sp-4);z-index:200}.learn-modal{width:min(560px,100%);background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6);display:grid;gap:var(--sp-4)}.learn-modal-title{font-size:1.05rem;color:var(--text-primary)}.learn-modal-subtitle{color:var(--text-secondary);font-size:.85rem}.learn-modal-cities{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--sp-2)}.learn-city-option{background:var(--bg-input);border:1px solid var(--border-primary);color:var(--text-secondary);border-radius:var(--radius-sm);padding:var(--sp-2) var(--sp-3);text-align:left;font-size:.84rem;transition:border-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.learn-city-option:hover{border-color:var(--border-hover);color:var(--text-primary)}.learn-city-option.active{border-color:var(--accent-blue);color:var(--text-primary);background:var(--accent-blue-muted)}.learn-other-input{background:var(--bg-input);border:1px solid var(--border-primary);border-radius:var(--radius-sm);color:var(--text-primary);padding:var(--sp-2) var(--sp-3);font-size:.88rem;width:100%}.learn-other-input:focus{outline:none;border-color:var(--accent-blue)}.learn-modal-actions{display:flex;gap:var(--sp-3);justify-content:flex-end}.landing{margin:calc(-1 * var(--sp-8)) calc(-1 * var(--sp-6));width:calc(100% + var(--sp-6) * 2)}.landing-hero{position:relative;min-height:min(85vh,720px);display:flex;align-items:center;justify-content:center;overflow:hidden}.landing-hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.landing-hero-img{width:100%;height:100%;object-fit:cover;filter:brightness(.35) saturate(.7)}.landing-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(10,10,10,.3) 0%,rgba(10,10,10,.65) 60%,var(--bg-primary) 100%)}.landing-hero-content{position:relative;z-index:1;max-width:780px;padding:var(--sp-12) var(--sp-6);text-align:center}.landing-hero-eyebrow{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-blue-text);margin-bottom:var(--sp-4)}.landing-hero-title{font-size:clamp(2rem,5vw,3.25rem);font-weight:700;line-height:1.15;letter-spacing:-.025em;color:var(--text-primary);margin-bottom:var(--sp-5)}.landing-hero-accent{background:linear-gradient(135deg,var(--power-color),var(--accent-amber));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.landing-hero-subtitle{font-size:1.05rem;line-height:1.7;color:var(--text-secondary);max-width:620px;margin:0 auto var(--sp-8)}.landing-hero-actions{display:flex;align-items:center;justify-content:center;gap:var(--sp-3);flex-wrap:wrap}.landing-btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-family);font-size:.875rem;font-weight:600;border:none;border-radius:var(--radius-md);padding:12px 28px;cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.landing-btn:hover{transform:translateY(-1px)}.landing-btn-primary{background:linear-gradient(135deg,var(--accent-blue),var(--power-color));color:#fff;box-shadow:0 4px 20px #6b8aad4d}.landing-btn-primary:hover{box-shadow:0 6px 28px #6b8aad73}.landing-btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-primary)}.landing-btn-secondary:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.landing-stats{background:var(--bg-card);border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary)}.landing-stats-inner{max-width:var(--content-max);margin:0 auto;padding:var(--sp-8) var(--sp-6);display:flex;align-items:center;justify-content:center;gap:var(--sp-10);flex-wrap:wrap}.landing-stat{text-align:center}.landing-stat-number{display:block;font-family:var(--font-mono);font-size:2rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:var(--sp-1)}.landing-stat-label{font-size:.75rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary)}.landing-stat-divider{width:1px;height:40px;background:var(--border-primary)}.landing-section{max-width:var(--content-max);margin:0 auto;padding:var(--sp-20) var(--sp-6)}.landing-section--dark{background:var(--bg-secondary);max-width:100%;padding-left:var(--sp-6);padding-right:var(--sp-6)}.landing-section--dark>.landing-section-header,.landing-section--dark>.landing-features{max-width:var(--content-max);margin-left:auto;margin-right:auto}.landing-section-header{text-align:center;max-width:640px;margin:0 auto var(--sp-12)}.landing-section-eyebrow{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-blue-text);margin-bottom:var(--sp-3)}.landing-section-title{font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:700;letter-spacing:-.02em;line-height:1.2;color:var(--text-primary);margin-bottom:var(--sp-4)}.landing-section-subtitle{font-size:.95rem;color:var(--text-secondary);line-height:1.65}.landing-pillars{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-5)}.landing-pillar{border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border-primary);background:var(--bg-card);transition:transform var(--duration-normal) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out)}.landing-pillar:hover{transform:translateY(-4px);box-shadow:0 12px 40px #00000080;border-color:var(--border-hover)}.landing-pillar-img-wrap{position:relative;height:200px;overflow:hidden}.landing-pillar-img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}.landing-pillar:hover .landing-pillar-img{transform:scale(1.06)}.landing-pillar-img-overlay{position:absolute;top:0;right:0;bottom:0;left:0}.landing-pillar-body{padding:var(--sp-5) var(--sp-6) var(--sp-6)}.landing-pillar-badge{display:inline-block;font-size:.65rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 10px;border-radius:999px;margin-bottom:var(--sp-3)}.landing-pillar-title{font-size:1.25rem;font-weight:700;margin-bottom:var(--sp-2)}.landing-pillar-desc{font-size:.88rem;color:var(--text-secondary);line-height:1.6}.landing-features{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-5)}.landing-feature{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:var(--sp-6);transition:border-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.landing-feature:hover{border-color:var(--border-hover);transform:translateY(-2px)}.landing-feature-icon{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:1.25rem;background:var(--accent-blue-muted);color:var(--accent-blue-text);border-radius:var(--radius-md);margin-bottom:var(--sp-4)}.landing-feature-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--sp-2)}.landing-feature-desc{font-size:.84rem;color:var(--text-secondary);line-height:1.6}.landing-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--sp-8);position:relative}.landing-steps-line{position:absolute;top:28px;left:15%;right:15%;height:2px;background:linear-gradient(90deg,var(--power-color),var(--accent-amber),var(--water-color));opacity:.25;border-radius:2px}.landing-step{text-align:center;position:relative;z-index:1}.landing-step-num{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;font-family:var(--font-mono);font-size:1.125rem;font-weight:700;color:var(--accent-blue-text);background:var(--bg-card);border:2px solid var(--accent-blue-muted);border-radius:50%;margin-bottom:var(--sp-4)}.landing-step-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--sp-2)}.landing-step-desc{font-size:.84rem;color:var(--text-secondary);line-height:1.6;max-width:280px;margin:0 auto}.landing-showcase{background:var(--bg-secondary);border-top:1px solid var(--border-primary);border-bottom:1px solid var(--border-primary)}.landing-showcase-inner{max-width:var(--content-max);margin:0 auto;padding:var(--sp-16) var(--sp-6);display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-12);align-items:center}.landing-showcase-title{font-size:clamp(1.25rem,2.5vw,1.75rem);font-weight:700;line-height:1.3;letter-spacing:-.015em;color:var(--text-primary);margin-bottom:var(--sp-4)}.landing-showcase-desc{font-size:.92rem;color:var(--text-secondary);line-height:1.7;margin-bottom:var(--sp-6)}.landing-showcase-img-wrap{border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--border-primary)}.landing-showcase-img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3;filter:brightness(.75) saturate(.8);transition:filter .4s var(--ease-out)}.landing-showcase-img-wrap:hover .landing-showcase-img{filter:brightness(.85) saturate(1)}.landing-cta{max-width:var(--content-max);margin:0 auto;padding:var(--sp-20) var(--sp-6);text-align:center}.landing-cta-title{font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:var(--sp-3)}.landing-cta-desc{font-size:1rem;color:var(--text-secondary);margin-bottom:var(--sp-8)}.landing-footer{text-align:center;padding:var(--sp-6);border-top:1px solid var(--border-secondary)}.landing-footer p{font-size:.75rem;color:var(--text-tertiary);font-style:italic;max-width:600px;margin:0 auto;line-height:1.6}@media (max-width: 1024px){.landing-pillars,.landing-features,.landing-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.landing-steps-line{display:none}.landing-showcase-inner{grid-template-columns:1fr;gap:var(--sp-8)}}@media (max-width: 768px){.landing{margin:calc(-1 * var(--sp-4)) calc(-1 * var(--sp-4))}.landing-pillars,.landing-features,.landing-steps{grid-template-columns:1fr}.landing-hero{min-height:60vh}.landing-hero-content{padding:var(--sp-8) var(--sp-4)}.landing-stats-inner{gap:var(--sp-6)}.landing-stat-divider{display:none}.landing-section{padding:var(--sp-12) var(--sp-4)}}@media (max-width: 1024px){.about-grid,.about-pillars,.learn-tech-grid,.learn-concepts-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.about-grid,.about-pillars,.learn-concepts-grid,.learn-tech-grid{grid-template-columns:1fr}}.chat-page{display:flex;flex-direction:column;height:calc(100vh - var(--nav-height) - var(--sp-8) * 2);max-width:860px;margin:0 auto;overflow:hidden}.chat-header{display:flex;align-items:center;gap:var(--sp-4);padding-bottom:var(--sp-5);border-bottom:1px solid var(--border-primary);margin-bottom:var(--sp-4);flex-shrink:0}.chat-header-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent-blue-muted),var(--accent-amber-muted));color:var(--accent-blue-text);font-size:1.25rem;flex-shrink:0}.chat-header-title{font-size:1.25rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.chat-header-subtitle{font-size:.75rem;color:var(--text-tertiary);margin-top:2px}.chat-body{flex:1;overflow-y:auto;padding:var(--sp-4) 0;display:flex;flex-direction:column;gap:var(--sp-4);scroll-behavior:smooth}.chat-body::-webkit-scrollbar{width:4px}.chat-body::-webkit-scrollbar-track{background:transparent}.chat-body::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:2px}.chat-bubble{display:flex;gap:var(--sp-3);max-width:88%;animation:chatFadeIn .25s var(--ease-out)}@keyframes chatFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-bubble--user{align-self:flex-end;flex-direction:row-reverse}.chat-bubble--assistant{align-self:flex-start}.chat-bubble-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0;background:var(--accent-blue-muted);color:var(--accent-blue-text);margin-top:2px}.chat-bubble-content{padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-lg);font-size:.875rem;line-height:1.65;color:var(--text-primary)}.chat-bubble--assistant .chat-bubble-content{background:var(--bg-card);border:1px solid var(--border-primary);border-top-left-radius:var(--radius-sm)}.chat-bubble--user .chat-bubble-content{background:linear-gradient(135deg,#6b8aad33,#6b8aad1f);border:1px solid rgba(107,138,173,.35);border-top-right-radius:var(--radius-sm)}.chat-bubble-content h3,.chat-bubble-content h4{font-size:.875rem;font-weight:600;margin:var(--sp-3) 0 var(--sp-1);color:var(--text-primary)}.chat-bubble-content strong{color:var(--text-primary);font-weight:600}.chat-bubble-content ul{margin:var(--sp-2) 0;padding-left:var(--sp-5)}.chat-bubble-content li{margin-bottom:var(--sp-1)}.chat-bubble-content code{font-family:var(--font-mono);font-size:.8rem;background:#ffffff0f;padding:1px 5px;border-radius:4px}.chat-bubble-content pre{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);padding:var(--sp-3);margin:var(--sp-3) 0;overflow-x:auto}.chat-bubble-content pre code{background:none;padding:0}.chat-typing{display:flex;align-items:center;gap:5px;padding:var(--sp-3) var(--sp-5)!important}.chat-typing span{width:7px;height:7px;border-radius:50%;background:var(--text-tertiary);animation:chatDot 1.4s ease-in-out infinite}.chat-typing span:nth-child(2){animation-delay:.16s}.chat-typing span:nth-child(3){animation-delay:.32s}@keyframes chatDot{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.chat-error{align-self:center;font-size:.78rem;color:var(--accent-amber-text);background:var(--accent-amber-muted);padding:var(--sp-2) var(--sp-4);border-radius:var(--radius-sm);text-align:center}.chat-input-bar{display:flex;align-items:flex-end;gap:var(--sp-2);padding-top:var(--sp-4);border-top:1px solid var(--border-primary);flex-shrink:0}.chat-input{flex:1;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);padding:var(--sp-3) var(--sp-4);font-family:var(--font-family);font-size:.875rem;color:var(--text-primary);resize:none;outline:none;min-height:44px;max-height:120px;transition:border-color var(--duration-fast) var(--ease-out)}.chat-input::placeholder{color:var(--text-tertiary)}.chat-input:focus{border-color:var(--accent-blue)}.chat-send-btn{width:44px;height:44px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent-blue),var(--power-color));color:#fff;font-size:1.125rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.chat-send-btn:hover:not(:disabled){transform:translateY(-1px)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 768px){.chat-page{height:calc(100vh - var(--nav-height) - var(--sp-5) * 2 - 60px)}.chat-bubble{max-width:94%}}
