@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800&display=swap";:root{--bg-color: #020617;--card-bg: rgba(15, 23, 42, .4);--accent-warm: #f43f5e;--accent-cool: #38bdf8;--accent-primary: var(--accent-warm);--text-primary: #f8fafc;--text-secondary: #94a3b8;--glass-border: rgba(255, 255, 255, .08);--shadow-glow: 0 8px 32px rgba(0, 0, 0, .6);--transition-smooth: all .5s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Outfit,sans-serif;background-color:var(--bg-color);background-image:radial-gradient(circle at 15% 50%,rgba(99,102,241,.15) 0%,transparent 60%),radial-gradient(circle at 85% 30%,rgba(220,38,38,.15) 0%,transparent 60%),radial-gradient(circle at 50% 80%,rgba(139,92,246,.1) 0%,transparent 50%);color:var(--text-primary);height:100vh;overflow:hidden;display:flex;flex-direction:column}.immersive-layout{display:grid;grid-template-columns:350px 1fr 350px;grid-template-rows:1fr auto;gap:2rem;height:100vh;padding:2rem;position:relative;z-index:1}@media(max-width:1200px){.immersive-layout{grid-template-columns:300px 1fr 300px;gap:1rem;padding:1rem}}.glass-panel{background:#1e293b66;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-top:1px solid rgba(255,255,255,.2);border-radius:24px;padding:2.2rem;box-shadow:0 16px 40px #00000080;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto}.glass-panel::-webkit-scrollbar{display:none}.glass-panel{-ms-overflow-style:none;scrollbar-width:none}.panel-left{grid-column:1;grid-row:1}.panel-center{grid-column:2;grid-row:1;display:flex;align-items:center;justify-content:center;position:relative;min-width:0;min-height:0;overflow:visible}.panel-right{grid-column:3;grid-row:1}.floating-dock{grid-column:1 / -1;grid-row:2;flex-direction:row;align-items:center;padding:1.5rem 2rem;margin:0 auto;width:100%;max-width:800px;min-height:80px}.app-header h1{font-size:2.2rem;font-weight:800;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem}.subtitle{color:var(--text-secondary);font-size:.95rem}.narrative-overlay{position:absolute;z-index:100;width:280px;background:#0f172af2;border:1px solid rgba(255,255,255,.1);padding:1.25rem;border-radius:16px;box-shadow:0 20px 50px #0009;pointer-events:none;transform:translate(-50%,-50%);transition:opacity .4s ease,transform .4s ease;opacity:0}.narrative-overlay.visible{opacity:1}.narrative-overlay h4{color:var(--accent-primary);margin-bottom:.25rem;font-size:1.1rem;text-transform:uppercase;letter-spacing:1px}.narrative-overlay p{line-height:1.4;margin-bottom:0}.narrative-overlay.has-image{padding-bottom:0;overflow:hidden}.milestone-image{width:calc(100% + 2.5rem);margin:1.25rem -1.25rem 0;display:block;object-fit:cover;max-height:160px;border-bottom-left-radius:11px;border-bottom-right-radius:11px}.chart-drawing-layer{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10;overflow:visible}.timeline-line{stroke:var(--accent-primary);stroke-width:2;stroke-dasharray:4 4;fill:none}.info-card h3{color:var(--accent-primary);margin-bottom:.5rem;font-size:1.1rem;display:flex;align-items:center;gap:.5rem}.info-card p{font-size:.95rem;color:var(--text-primary)}.chart-container{width:100%;height:100%;max-width:720px;max-height:720px;position:relative;filter:drop-shadow(0 0 40px rgba(0,0,0,.6));display:flex;align-items:center;justify-content:center}.center-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;pointer-events:none;z-index:5}.center-cumulative{font-size:3.8rem;font-weight:800;color:var(--text-primary);text-shadow:0 4px 20px rgba(0,0,0,.8);line-height:1;white-space:nowrap;font-variant-numeric:tabular-nums;min-width:400px}.center-year{font-size:1.5rem;font-weight:600;color:var(--text-secondary);margin-top:.5rem;font-variant-numeric:tabular-nums;text-shadow:0 2px 10px rgba(0,0,0,.5);transition:color .5s ease}.center-life-expectancy{font-size:1.2rem;font-weight:600;color:var(--accent-primary);margin-top:.25rem;text-transform:uppercase;letter-spacing:2px;text-shadow:0 2px 10px rgba(0,0,0,.5)}.life-expectancy-value{font-size:2.5rem;font-weight:800;color:var(--text-primary);margin-top:.5rem;font-variant-numeric:tabular-nums;line-height:1}.timeline-container{width:100%}.slider-wrapper{display:flex;align-items:center;gap:1.5rem;width:100%}.play-btn{background:var(--accent-primary);border:none;color:#fff;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-smooth);box-shadow:0 0 20px rgba(var(--accent-primary-rgb, 244, 63, 94),.4);flex-shrink:0}.play-btn:hover{transform:scale(1.1)}.timeline-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:#ffffff1a;border-radius:3px;outline:none;cursor:pointer}.timeline-slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;background:var(--accent-primary);border:4px solid var(--bg-color);border-radius:50%;box-shadow:0 0 15px var(--accent-primary);transition:transform .2s}.timeline-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.causes-header{display:flex;align-items:center;gap:.75rem;color:var(--accent-primary);flex-shrink:0}.causes-header svg{width:20px;height:20px;stroke:var(--accent-primary);flex-shrink:0}.causes-tab-switcher{display:flex;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:100px;padding:3px;gap:2px;flex:1}.causes-tab{flex:1;background:transparent;border:none;color:var(--text-secondary);font-family:Outfit,sans-serif;font-size:.8rem;font-weight:600;padding:.3rem .6rem;border-radius:100px;cursor:pointer;transition:all .25s ease;white-space:nowrap}.causes-tab.active{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px #0000004d}.causes-tab:not(.active):hover{color:var(--text-primary);background:#ffffff0d}.custom-legend{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.legend-item{display:grid;grid-template-columns:14px 1fr auto;align-items:center;column-gap:.6rem;font-size:.9rem;color:var(--text-secondary);transition:var(--transition-smooth);padding:.45rem .5rem;border-radius:8px;cursor:pointer}.legend-item:hover,.legend-item.active{background:#ffffff0d;color:var(--text-primary)}.legend-color{width:12px;height:12px;border-radius:50%;box-shadow:0 0 8px currentColor;flex-shrink:0}.legend-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-value{font-weight:800;font-variant-numeric:tabular-nums;font-size:.82rem;white-space:nowrap;text-align:right}.loading-screen{position:fixed;inset:0;background:var(--bg-color);display:flex;justify-content:center;align-items:center;z-index:1000;transition:opacity .5s ease}.loader{width:48px;height:48px;border:5px solid #FFF;border-bottom-color:var(--accent-primary);border-radius:50%;display:inline-block;box-sizing:border-box;animation:rotation 1s linear infinite}@keyframes rotation{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:767px){#app.immersive-layout{display:none!important}body{overflow:auto;height:auto;min-height:100dvh}}.mobile-layout{display:none;flex-direction:column;gap:.75rem;padding:.75rem;min-height:100dvh;box-sizing:border-box}.mobile-header{padding:1rem 1.25rem .85rem;gap:.25rem;flex-shrink:0}.mobile-header-title{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.mobile-header h1{font-size:1.35rem;font-weight:800;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.1;flex:1}.mobile-year-badge{font-size:.9rem;font-weight:700;color:var(--accent-primary);background:#f43f5e1f;border:1px solid rgba(244,63,94,.25);border-radius:100px;padding:.2rem .7rem;white-space:nowrap;flex-shrink:0;transition:color .4s ease,border-color .4s ease,background .4s ease}.mobile-subtitle{font-size:.78rem;color:var(--text-secondary)}.mobile-stats-bar{display:flex;align-items:center;padding:.75rem 1rem;gap:0;flex-direction:row;flex-shrink:0}.mobile-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:.1rem;min-width:0}.mobile-era-stat{flex:1.2}.mobile-stat-label{font-size:.62rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.mobile-stat-value{font-size:.9rem;font-weight:800;color:var(--text-primary);font-variant-numeric:tabular-nums;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center}.mobile-era-value{font-size:.72rem;font-weight:700;color:var(--accent-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;text-align:center;letter-spacing:.02em}.mobile-stat-divider{width:1px;height:2rem;background:#ffffff1a;flex-shrink:0;margin:0 .25rem}.mobile-chart-section{position:relative;display:flex;flex-direction:column;align-items:center}.mobile-chart-container{position:relative;width:100%;aspect-ratio:1;max-width:420px;margin:0 auto;filter:drop-shadow(0 0 28px rgba(0,0,0,.55));touch-action:pan-y}.mobile-chart-container canvas{width:100%!important;height:100%!important;touch-action:pan-y}.mobile-center-container{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;pointer-events:none;z-index:5;width:55%}.mobile-center-cumulative{font-size:clamp(1.1rem,5vw,2rem);font-weight:800;color:var(--text-primary);text-shadow:0 2px 12px rgba(0,0,0,.8);line-height:1.1;font-variant-numeric:tabular-nums;white-space:nowrap}.mobile-center-life-exp{font-size:clamp(.65rem,2.5vw,.9rem);font-weight:600;color:var(--accent-primary);text-transform:uppercase;letter-spacing:1.5px;margin-top:.2rem;transition:color .4s ease}.mobile-center-year{font-size:clamp(.7rem,3vw,1.05rem);font-weight:600;color:var(--text-secondary);margin-top:.1rem;font-variant-numeric:tabular-nums}.mobile-touch-tooltip{position:absolute;bottom:.5rem;left:50%;transform:translate(-50%);background:#0f172af7;border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:.75rem 1rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 8px 32px #0009;z-index:50;min-width:220px;max-width:90vw;animation:fadeInUp .2s ease}.mobile-tooltip-color{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:0 0 8px currentColor}.mobile-tooltip-body{flex:1;display:flex;flex-direction:column;gap:.15rem;min-width:0}.mobile-tooltip-name{font-size:.9rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-tooltip-value{font-size:.78rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.mobile-tooltip-close{background:#ffffff14;border:1px solid rgba(255,255,255,.12);color:var(--text-secondary);border-radius:50%;width:26px;height:26px;font-size:.75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.mobile-tooltip-close:hover,.mobile-tooltip-close:active{background:#ffffff26}.mobile-narrative-panel{padding:1rem 1.25rem;min-height:90px;flex-shrink:0;overflow:hidden}.mobile-narrative-inner{transition:opacity .4s ease}.mobile-narrative-placeholder{color:var(--text-secondary);font-size:.88rem;font-style:italic;text-align:center}.mobile-narrative-title{color:var(--accent-primary);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-bottom:.35rem;transition:color .4s ease}.mobile-narrative-message{color:var(--text-primary);font-size:.88rem;line-height:1.55;margin:0}.mobile-narrative-image{width:calc(100% + 2.5rem);margin:.75rem -1.25rem 0;display:block;object-fit:cover;max-height:140px;border-bottom-left-radius:18px;border-bottom-right-radius:18px}.mobile-legend-section{padding:1rem 1rem 1.25rem}.mobile-legend-header{display:flex;align-items:center;gap:.6rem;margin-bottom:.75rem;color:var(--accent-primary)}.mobile-legend-header svg{width:18px;height:18px;stroke:var(--accent-primary);flex-shrink:0}.mobile-legend-list{margin-bottom:0}.mobile-dock{position:sticky;bottom:.75rem;padding:.85rem 1rem;z-index:100;flex-shrink:0}.mobile-dock-controls{display:flex;align-items:center;gap:1rem;width:100%}.mobile-slider-track{flex:1;display:flex;flex-direction:column;gap:.4rem}.mobile-slider-labels{display:flex;justify-content:space-between;font-size:.72rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase}.mobile-slider-year{font-size:.85rem;color:var(--text-primary);font-weight:700}.mobile-timeline-slider{touch-action:none}.mobile-timeline-slider::-webkit-slider-thumb{width:28px;height:28px}#mobileEraDescription{font-size:.8rem;color:var(--text-secondary);line-height:1.45}.mobile-selection-panel{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.85rem 1rem;margin-top:.5rem;animation:fadeInDown .3s ease}.mobile-selection-panel h4{color:var(--accent-primary);font-size:.9rem;font-weight:700;margin-bottom:.35rem}.mobile-selection-panel p{font-size:.82rem;color:var(--text-primary);line-height:1.5}.mobile-selection-panel .mobile-selection-impact{font-size:.78rem;color:var(--text-secondary);margin-top:.35rem}@media(min-width:600px)and (max-width:767px){.mobile-chart-container{max-width:500px}}@media(max-width:767px)and (orientation:landscape)and (max-height:500px){.mobile-layout{gap:.5rem;padding:.5rem}.mobile-header{padding:.5rem 1rem}.mobile-header h1{font-size:1.1rem}.mobile-stats-bar{padding:.5rem 1rem}.mobile-chart-container{max-width:260px}}
