.page-container{min-height:100vh;background:#fff}.header{text-align:center;padding:40px 20px 30px}.logo{font-size:clamp(2.5rem,10vw,4rem);font-weight:700;display:flex;align-items:center;justify-content:center;gap:4px}.logo-401{color:#e91e63}.logo-group{color:#1a1a1a}.logo-maple{width:clamp(28px,6vw,45px);height:clamp(28px,6vw,45px);fill:#e91e63;margin:0 2px}.logo-subtitle{font-size:.9rem;color:#555;text-transform:uppercase;letter-spacing:4px;margin-top:-5px}.page-title{font-size:clamp(1.8rem,6vw,3rem);font-weight:600;text-transform:uppercase;letter-spacing:6px;margin-top:10px;color:#1a1a1a}.chart-panel{position:sticky;top:0;right:0;z-index:1000;background:#fff;padding:15px 20px 20px;display:flex;flex-direction:column;align-items:center;border-bottom:1px solid #e8e8ed;box-shadow:0 4px 20px rgba(0,0,0,.08)}.pie-chart{width:200px;height:200px;filter:drop-shadow(0 4px 15px rgba(0,0,0,.1))}.progress-container{width:100%;max-width:220px;margin-top:12px}.progress-bar{width:100%;height:6px;background:#e8e8ed;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#ff9800,#e91e63);border-radius:3px;transition:width .15s ease-out}.progress-text{display:flex;justify-content:space-between;margin-top:8px;font-size:11px;color:#888;text-transform:uppercase;letter-spacing:1px}.progress-text strong{color:#555;font-weight:600}.year-legend{display:flex;flex-wrap:wrap;justify-content:center;gap:6px;margin-top:12px;max-width:300px}.legend-item{display:flex;align-items:center;gap:4px;font-size:15px;color:#888;padding:3px 6px;background:#f5f5f7;border-radius:4px;transition:all .2s ease}.legend-item.active{background:#e8e8ed;color:#1a1a1a;transform:scale(1.08)}.legend-dot{width:8px;height:8px;border-radius:2px}.timeline-wrapper{padding-bottom:100px}.timeline-content{max-width:600px;margin:0 auto;padding:20px}.year-group{margin-bottom:30px}.year-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;position:sticky;top:365px;z-index:100;background:#fff;padding:8px 0}.year-badge{font-family:Oswald,sans-serif;font-size:20px;font-weight:700;padding:8px 16px;border-radius:4px;color:#fff;box-shadow:0 4px 15px rgba(0,0,0,.2)}.year-count{font-size:13px;color:#888}.locations-list{display:flex;flex-direction:column;gap:8px;padding-left:20px;border-left:2px solid #e8e8ed}.location-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#f5f5f7;border-radius:8px;transform:translateX(-30px);opacity:0;transition:all .5s cubic-bezier(.4,0,.2,1);transition-delay:var(--delay)}.location-item.visible{transform:translateX(0);opacity:1}.location-dot{width:10px;height:10px;background:var(--color);border-radius:50%;box-shadow:0 0 8px var(--color);flex-shrink:0}.location-name{font-size:14px;font-weight:500;color:#1a1a1a}@media(min-width:768px){.page-container{flex-direction:row-reverse}.chart-panel{position:sticky;top:0;right:0;width:420px;height:100vh;border-bottom:none;border-left:1px solid #e8e8ed;border-right:none;padding:40px 30px;justify-content:center}.pie-chart{width:280px;height:280px}.progress-container{max-width:280px;margin-top:20px}.year-legend{max-width:350px;margin-top:20px}.legend-item{font-size:15px;padding:4px 8px}.legend-dot{width:10px;height:10px}.timeline-wrapper{flex:1;padding-top:0;margin-left:0;min-height:100vh}.header{padding:60px 40px 40px}.timeline-content{max-width:700px;padding:40px}.year-header{top:0;background:#fff}.year-badge{font-size:24px;padding:10px 20px}.location-item{padding:14px 20px}.location-name{font-size:15px}}@media(min-width:1280px){.chart-panel{width:480px}.pie-chart{width:320px;height:320px}}.scroll-cta{position:sticky;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:#888;font-size:11px;text-transform:uppercase;letter-spacing:2px;animation:float 2s ease-in-out infinite;transition:opacity .3s ease;pointer-events:none;z-index:500}.scroll-arrow{width:20px;height:20px;border-right:2px solid #888;border-bottom:2px solid #888;transform:rotate(45deg)}@keyframes float{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-8px)}}@media(min-width:768px){.scroll-cta{left:calc((100% - 420px)/2)}}@media(min-width:1280px){.scroll-cta{left:calc((100% - 480px)/2)}}