:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a25;--bg-card-hover: #222230;--accent-cyan: #00f0ff;--accent-magenta: #ff00ff;--accent-green: #00ff88;--accent-orange: #ff8800;--accent-red: #ff3366;--accent-yellow: #ffcc00;--accent-purple: #9966ff;--text-primary: #ffffff;--text-secondary: #8888aa;--text-dim: #555566;--border-color: #2a2a3a;--glow-cyan: 0 0 20px rgba(0, 240, 255, .5);--glow-magenta: 0 0 20px rgba(255, 0, 255, .5);--glow-green: 0 0 20px rgba(0, 255, 136, .5);--glow-orange: 0 0 20px rgba(255, 136, 0, .5);--glow-red: 0 0 20px rgba(255, 51, 102, .5);--transition: all .3s cubic-bezier(.4, 0, .2, 1)}[data-theme=light]{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #f0f0f5;--text-primary: #1a1a1a;--text-secondary: #666666;--text-dim: #999999;--border-color: #e0e0e5}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;transition:var(--transition)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--accent-cyan);border-radius:3px}.font-display{font-family:Orbitron,monospace}.app{max-width:1400px;margin:0 auto;padding:20px}.header{display:flex;justify-content:space-between;align-items:center;padding:20px 0;border-bottom:1px solid var(--border-color);margin-bottom:30px}.header-title{font-family:Orbitron,monospace;font-size:28px;font-weight:900;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-magenta));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{color:var(--text-secondary);font-size:14px;margin-top:4px;letter-spacing:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:20px;position:relative;overflow:hidden;transition:var(--transition)}.stat-card:hover{transform:translateY(-4px);border-color:var(--accent-cyan);box-shadow:var(--glow-cyan)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--accent-cyan),transparent)}.stat-card.green:before{background:linear-gradient(90deg,var(--accent-green),transparent)}.stat-card.orange:before{background:linear-gradient(90deg,var(--accent-orange),transparent)}.stat-card.magenta:before{background:linear-gradient(90deg,var(--accent-magenta),transparent)}.stat-card.red:before{background:linear-gradient(90deg,var(--accent-red),transparent)}.stat-card.purple:before{background:linear-gradient(90deg,var(--accent-purple),transparent)}.stat-card.yellow:before{background:linear-gradient(90deg,var(--accent-yellow),transparent)}.stat-label{color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;display:flex;align-items:center;gap:6px}.stat-value{font-family:Orbitron,monospace;font-size:28px;font-weight:700}.stat-value.cyan{color:var(--accent-cyan)}.stat-value.green{color:var(--accent-green)}.stat-value.orange{color:var(--accent-orange)}.stat-value.magenta{color:var(--accent-magenta)}.stat-value.red{color:var(--accent-red)}.stat-value.purple{color:var(--accent-purple)}.stat-value.yellow{color:var(--accent-yellow)}.stat-unit{font-size:12px;color:var(--text-secondary);margin-left:2px}.stat-change{font-size:11px;margin-top:6px;color:var(--accent-green)}.section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;padding:24px;margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-title{font-family:Orbitron,monospace;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 900px){.charts-grid{grid-template-columns:1fr}}.activity-list{background:var(--bg-card);border:1px solid var(--border-color);border-radius:16px;overflow:hidden}.activity-item{display:grid;grid-template-columns:70px 1fr auto;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border-color);align-items:center;transition:var(--transition);cursor:pointer}.activity-item:hover{background:var(--bg-card-hover)}.activity-item:last-child{border-bottom:none}.activity-date{text-align:center}.activity-date-day{font-family:Orbitron,monospace;font-size:24px;font-weight:700;color:var(--accent-cyan)}.activity-date-month{font-size:10px;color:var(--text-secondary);text-transform:uppercase}.activity-info h3{font-size:14px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:12px;color:var(--text-secondary)}.activity-meta span{display:inline-flex;align-items:center;gap:3px}.activity-stats{text-align:right}.activity-distance{font-family:Orbitron,monospace;font-size:20px;font-weight:700;color:var(--accent-green)}.activity-pace{font-size:11px;color:var(--text-secondary);margin-top:2px}.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:500}.badge-hr{background:#ff336626;color:var(--accent-red)}.badge-streak{background:#ff880026;color:var(--accent-orange)}.badge-pb{background:#00ff8826;color:var(--accent-green)}.badge-long{background:#00f0ff26;color:var(--accent-cyan)}.heatmap{display:grid;grid-template-columns:repeat(52,1fr);gap:2px}.heatmap-day{aspect-ratio:1;border-radius:2px;background:var(--bg-secondary);transition:var(--transition)}.heatmap-day:hover{transform:scale(1.5)}.heatmap-level-0{background:var(--bg-secondary)}.heatmap-level-1{background:#00f0ff33}.heatmap-level-2{background:#00f0ff66}.heatmap-level-3{background:#00f0ff99}.heatmap-level-4{background:var(--accent-cyan);box-shadow:var(--glow-cyan)}.progress-ring{position:relative;display:inline-flex;align-items:center;justify-content:center}.progress-ring-text{position:absolute;text-align:center}.progress-ring-value{font-family:Orbitron,monospace;font-size:24px;font-weight:700;color:var(--accent-cyan)}.progress-ring-label{font-size:10px;color:var(--text-secondary)}.pb-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.pb-card{background:var(--bg-secondary);border-radius:12px;padding:16px;text-align:center;border:1px solid var(--border-color);transition:var(--transition)}.pb-card:hover{border-color:var(--accent-yellow);box-shadow:0 0 20px #fc03}.pb-type{font-size:10px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}.pb-value{font-family:Orbitron,monospace;font-size:20px;font-weight:700;color:var(--accent-yellow)}.pb-date{font-size:10px;color:var(--text-dim);margin-top:4px}.theme-toggle{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:8px 16px;color:var(--text-primary);cursor:pointer;font-size:12px;display:flex;align-items:center;gap:6px;transition:var(--transition)}.theme-toggle:hover{border-color:var(--accent-cyan)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:60vh;gap:24px}.loading-spinner{width:50px;height:50px;border:3px solid var(--border-color);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-family:Orbitron,monospace;font-size:12px;letter-spacing:3px}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeInUp .5s ease forwards}.fade-in-delay-1{animation:fadeInUp .5s ease .1s forwards;opacity:0}.fade-in-delay-2{animation:fadeInUp .5s ease .2s forwards;opacity:0}.fade-in-delay-3{animation:fadeInUp .5s ease .3s forwards;opacity:0}.footer{text-align:center;padding:40px 0;color:var(--text-dim);font-size:12px}.footer a{color:var(--accent-cyan);text-decoration:none}.recharts-tooltip-wrapper{z-index:100}.card-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}@media (max-width: 768px){.card-grid-3{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:30px;max-width:400px;width:90%;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close{position:absolute;top:16px;right:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:var(--transition)}.modal-close:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.modal-title{font-size:18px;font-weight:700;margin-bottom:4px;padding-right:40px}.modal-date{font-size:12px;color:var(--text-secondary);margin-bottom:24px}.modal-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.modal-stat{text-align:center;padding:16px;background:var(--bg-secondary);border-radius:12px}.modal-stat-value{font-family:Orbitron,monospace;font-size:22px;font-weight:700}.modal-stat-label{font-size:10px;color:var(--text-secondary);margin-top:4px}.modal-details{display:flex;flex-direction:column;gap:12px}.modal-detail-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:8px 0;border-bottom:1px solid var(--border-color)}.modal-detail-row:last-child{border-bottom:none}.modal-detail-row span:first-child{color:var(--text-secondary)}.skeleton{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-card-hover) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.activity-map{height:250px;border-radius:12px;overflow:hidden;margin-top:12px}.map-placeholder{height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:12px;color:var(--text-secondary);gap:8px}.modal-lg{max-width:500px}.modal-map-section{margin-top:20px}.modal-section-title{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;margin-bottom:8px}@media (max-width: 768px){.app{padding:12px}.header{flex-direction:column;align-items:flex-start;gap:12px;padding:16px 0}.header-title{font-size:22px}.header-subtitle{font-size:11px;letter-spacing:1px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:14px}.stat-value{font-size:22px}.stat-label{font-size:10px}.charts-grid{grid-template-columns:1fr;gap:16px}.section{padding:16px;border-radius:12px}.section-title{font-size:13px}.activity-item{grid-template-columns:50px 1fr auto;gap:10px;padding:12px 14px}.activity-date-day{font-size:18px}.activity-distance{font-size:16px}.pb-grid{grid-template-columns:repeat(3,1fr);gap:8px}.pb-card{padding:12px 8px}.pb-value{font-size:16px}.modal-content{padding:20px;border-radius:16px;max-height:85vh;overflow-y:auto}.modal-stats{gap:10px}.modal-stat{padding:12px}.modal-stat-value{font-size:18px}.activity-map{height:200px}.heatmap{grid-template-columns:repeat(26,1fr)}.footer{padding:24px 0;font-size:11px}}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border-color);padding:8px 0;z-index:100}@media (max-width: 768px){.bottom-nav{display:flex;justify-content:space-around}.app{padding-bottom:70px}}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 16px;color:var(--text-secondary);font-size:10px;cursor:pointer;transition:color .2s;text-decoration:none}.bottom-nav-item:hover,.bottom-nav-item.active{color:var(--accent-cyan)}.bottom-nav-item svg{width:22px;height:22px}.quick-stats-float{position:fixed;bottom:80px;right:20px;z-index:99}@media (min-width: 769px){.quick-stats-float{bottom:20px}}.quick-stats-btn{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--accent-cyan),var(--accent-magenta));border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #00f0ff66;transition:transform .3s,box-shadow .3s}.quick-stats-btn:hover{transform:scale(1.1);box-shadow:0 6px 25px #00f0ff99}.quick-stats-panel{position:absolute;bottom:60px;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;padding:16px;min-width:140px;box-shadow:0 4px 20px #0000004d;animation:slideUp .2s ease}.quick-stat-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color);font-size:13px}.quick-stat-item:last-child{border-bottom:none}.quick-stat-item .accent{color:var(--accent-cyan);font-weight:600}@keyframes pulse{0%,to{box-shadow:0 4px 20px #00f0ff66}50%{box-shadow:0 4px 30px #00f0ffcc}}.quick-stats-btn{animation:pulse 2s infinite}.activity-item{-webkit-tap-highlight-color:transparent}.activity-item:active{background:var(--bg-card-hover)}html{scroll-behavior:smooth}@media (max-width: 768px){::-webkit-scrollbar{display:none}body{-ms-overflow-style:none;scrollbar-width:none}}@keyframes loadingDots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}.loading-text:after{content:"...";animation:loadingDots 1.5s infinite}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:12px}.achievement{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:16px 12px;text-align:center;transition:all .3s}.achievement.locked{opacity:.4;filter:grayscale(1)}.achievement.unlocked{border-color:var(--accent-cyan);box-shadow:0 0 15px #00f0ff33}.achievement-icon{font-size:28px;margin-bottom:8px}.achievement-name{font-size:12px;font-weight:600;margin-bottom:4px}.achievement-desc{font-size:10px;color:var(--text-secondary)}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--accent-cyan),var(--accent-magenta));border-radius:1px}.timeline-item{position:relative;padding-bottom:20px}.timeline-item:last-child{padding-bottom:0}.timeline-marker{position:absolute;left:-20px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--accent-cyan);box-shadow:0 0 10px var(--accent-cyan);animation:timelinePulse 2s infinite}@keyframes timelinePulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.timeline-content{background:var(--bg-secondary);border-radius:10px;padding:12px 16px}.timeline-month{font-size:13px;font-weight:600;margin-bottom:8px}.timeline-bar-container{height:8px;background:var(--bg-primary);border-radius:4px;overflow:hidden;margin-bottom:8px}.timeline-bar{height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-green));border-radius:4px;transition:width 1s ease}.timeline-stats{font-size:11px;color:var(--text-secondary)}.section{position:relative;overflow:hidden}.section:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-cyan),transparent);opacity:.3}.app{background:radial-gradient(ellipse at top left,rgba(0,240,255,.03) 0%,transparent 50%),radial-gradient(ellipse at bottom right,rgba(255,0,255,.03) 0%,transparent 50%),var(--bg-primary);min-height:100vh}.header{position:relative}.header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-cyan) 20%,var(--accent-magenta) 50%,var(--accent-cyan) 80%,transparent)}.stat-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:12px;opacity:0;transition:opacity .3s;pointer-events:none;background:radial-gradient(circle at center,rgba(0,240,255,.1) 0%,transparent 70%)}.stat-card:hover:after{opacity:1}.section{border:1px solid var(--border-color);position:relative;overflow:hidden}.section:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-green),var(--accent-cyan));background-size:200% 100%;animation:gradientMove 3s linear infinite}@keyframes gradientMove{0%{background-position:0% 0%}to{background-position:200% 0%}}.section-title{font-weight:600;letter-spacing:.5px}.activity-item{position:relative;overflow:hidden}.activity-item:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent-cyan);transform:scaleY(0);transition:transform .3s}.activity-item:hover:before{transform:scaleY(1)}.activity-item:hover{padding-left:20px;transition:padding-left .3s}.theme-toggle{background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-secondary) 100%);border:1px solid var(--border-color)}.theme-toggle:hover{border-color:var(--accent-cyan);box-shadow:0 0 15px #00f0ff33}@keyframes float{0%,to{transform:translateY(0) rotate(0);opacity:.3}50%{transform:translateY(-20px) rotate(180deg);opacity:.6}}.loading{background:radial-gradient(circle at 30% 30%,rgba(0,240,255,.05) 0%,transparent 50%),var(--bg-primary)}.loading-spinner{box-shadow:0 0 20px #00f0ff4d,inset 0 0 20px #00f0ff1a}@media (min-width: 769px){::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:4px}::-webkit-scrollbar-thumb{background:linear-gradient(to bottom,var(--accent-cyan),var(--accent-magenta));border-radius:4px}}.recharts-tooltip-wrapper{filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.stat-card:hover,.section:hover{box-shadow:0 4px 20px #0003,0 0 30px #00f0ff1a}.modal-content{animation:modalSlideIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.quick-stats-panel{animation:panelSlideIn .2s ease}@keyframes panelSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.progress-ring circle:last-child{filter:drop-shadow(0 0 8px currentColor)}.scroll-to-top{position:fixed;bottom:140px;right:20px;width:44px;height:44px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-color);color:var(--accent-cyan);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;z-index:98;opacity:0;animation:fadeIn .3s forwards}@media (max-width: 768px){.scroll-to-top{bottom:150px;right:15px;width:40px;height:40px}}.scroll-to-top:hover{background:var(--accent-cyan);color:var(--bg-primary);transform:translateY(-3px);box-shadow:0 4px 15px #00f0ff66}.pr-timeline{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px}.pr-item{flex:1;min-width:80px;background:var(--bg-secondary);border-radius:10px;padding:12px 8px;text-align:center;border:1px solid var(--border-color);transition:all .3s}.pr-item:hover{border-color:var(--accent-yellow);transform:translateY(-2px)}.pr-distance{font-size:11px;color:var(--text-secondary);margin-bottom:4px}.pr-time{font-family:Orbitron,monospace;font-size:14px;font-weight:700;color:var(--accent-yellow);margin-bottom:4px}.pr-date{font-size:9px;color:var(--text-dim)}.section:hover{transform:translateY(-2px);transition:transform .3s}.recharts-default-tooltip{background:var(--bg-card)!important;border:1px solid var(--border-color)!important;border-radius:8px!important;padding:8px 12px!important}.recharts-wrapper{animation:fadeInUp .5s ease}.route-chip{padding:6px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;font-size:11px;cursor:pointer;white-space:nowrap;transition:all .2s}.route-chip:hover,.route-chip.active{background:var(--accent-cyan);color:var(--bg-primary);border-color:var(--accent-cyan)}.location-list{display:flex;flex-direction:column;gap:12px}.location-item{display:flex;align-items:center;gap:12px}.location-rank{width:24px;height:24px;border-radius:50%;background:var(--accent-cyan);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.location-info{flex:1;min-width:0}.location-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-stats{font-size:11px;color:var(--text-secondary)}.location-bar{width:60px;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.location-bar div{height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-green));border-radius:3px;transition:width .5s ease}.leaflet-container{background:var(--bg-secondary)!important}.leaflet-control-zoom a{background:var(--bg-card)!important;color:var(--text-primary)!important;border-color:var(--border-color)!important}.leaflet-control-zoom a:hover{background:var(--bg-card-hover)!important}.search-filter{padding:12px 20px;border-bottom:1px solid var(--border-color)}.search-input-wrapper{margin-bottom:12px}.search-input{width:100%;padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:14px;transition:border-color .2s}.search-input:focus{outline:none;border-color:var(--accent-cyan)}.search-input::placeholder{color:var(--text-dim)}.filter-row{display:flex;gap:10px;margin-bottom:12px}.filter-select{flex:1;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:12px;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--accent-cyan)}.filter-results{font-size:11px;color:var(--text-secondary);text-align:center}.export-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s}.export-btn:hover{background:var(--accent-cyan);color:var(--bg-primary);border-color:var(--accent-cyan)}.section-header{margin-bottom:16px}.goal-progress{display:flex;align-items:center;gap:24px}.goal-ring{position:relative;width:120px;height:120px;flex-shrink:0}.goal-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.goal-current{font-family:Orbitron,monospace;font-size:28px;font-weight:700;color:var(--accent-cyan)}.goal-label{font-size:11px;color:var(--text-secondary)}.goal-stats{flex:1;display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.goal-stat{text-align:center;padding:12px 8px;background:var(--bg-secondary);border-radius:10px}.goal-stat-value{font-family:Orbitron,monospace;font-size:16px;font-weight:700;color:var(--accent-green)}.goal-stat-label{font-size:10px;color:var(--text-secondary);margin-top:4px}.training-tip{display:flex;align-items:center;gap:16px;padding:16px 20px}.tip-icon{font-size:32px}.tip-text{font-size:14px;line-height:1.5;color:var(--text-secondary)}@media (max-width: 500px){.goal-progress{flex-direction:column;text-align:center}.goal-stats{width:100%}}.share-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .2s}.share-btn:hover{background:var(--accent-magenta);color:#fff;border-color:var(--accent-magenta)}.header>div:last-child{display:flex;align-items:center;gap:8px}@media (max-width: 768px){.header>div:last-child{flex-wrap:wrap;justify-content:flex-end}.share-btn,.export-btn{padding:6px 10px;font-size:11px}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state-text{font-size:16px;color:var(--text-secondary);margin-bottom:8px}.empty-state-hint{font-size:13px;color:var(--text-dim)}@keyframes particleFloat{0%,to{transform:translateY(0) translate(0) scale(1);opacity:.3}25%{transform:translateY(-20px) translate(10px) scale(1.1);opacity:.6}50%{transform:translateY(-40px) translate(-5px) scale(.9);opacity:.4}75%{transform:translateY(-20px) translate(-10px) scale(1.05);opacity:.5}}.particle{position:absolute;width:4px;height:4px;background:var(--accent-cyan);border-radius:50%;opacity:.3;animation:particleFloat 8s ease-in-out infinite}.particle:nth-child(2){left:20%;top:30%;animation-delay:-2s;background:var(--accent-magenta)}.particle:nth-child(3){left:60%;top:20%;animation-delay:-4s;background:var(--accent-green)}.particle:nth-child(4){left:80%;top:60%;animation-delay:-1s}.particle:nth-child(5){left:40%;top:70%;animation-delay:-3s;background:var(--accent-orange)}@keyframes glow{0%,to{text-shadow:0 0 10px currentColor,0 0 20px currentColor}50%{text-shadow:0 0 20px currentColor,0 0 40px currentColor,0 0 60px currentColor}}.glow-text{animation:glow 2s ease-in-out infinite}@keyframes slideInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}.stagger-up{animation:slideInUp .6s ease forwards}.stagger-left{animation:slideInLeft .6s ease forwards}.stagger-right{animation:slideInRight .6s ease forwards}.card-lift{transition:transform .4s cubic-bezier(.34,1.56,.64,1),box-shadow .3s}.card-lift:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #0000004d,0 0 30px #00f0ff33}@keyframes ripple{to{transform:scale(4);opacity:0}}.ripple-effect{position:relative;overflow:hidden}.ripple-effect:after{content:"";position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;background-image:radial-gradient(circle,var(--accent-cyan) 10%,transparent 10%);background-repeat:no-repeat;background-position:50%;transform:scale(0);opacity:1}.ripple-effect:active:after{animation:ripple .6s ease-out}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.count-up{animation:countUp .5s ease forwards}@keyframes gradientBorder{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.gradient-border{position:relative}.gradient-border:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-magenta),var(--accent-cyan));background-size:200% 200%;animation:gradientBorder 3s ease infinite;border-radius:inherit;z-index:-1}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.breathe{animation:breathe 4s ease-in-out infinite}@keyframes blink{50%{border-color:transparent}}.typing{overflow:hidden;white-space:nowrap;border-right:2px solid var(--accent-cyan);animation:typing 3s steps(30) forwards,blink .7s step-end infinite}@keyframes typing{0%{width:0}to{width:100%}}.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}@keyframes floatLabel{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.float-label{animation:floatLabel 3s ease-in-out infinite}@keyframes morph{0%,to{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}25%{border-radius:30% 60% 70% 40%/50% 60% 30%}50%{border-radius:50% 60% 30%/30% 60% 70% 40%}75%{border-radius:60% 40% 60% 30%/60% 30% 50% 60%}}.morph{animation:morph 8s ease-in-out infinite}.hero-banner{background:linear-gradient(135deg,#00f0ff1a,#ff00ff1a);border:1px solid var(--border-color);border-radius:20px;padding:30px;margin-bottom:24px;position:relative;overflow:hidden}.hero-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 50%,rgba(0,240,255,.15) 0%,transparent 50%);pointer-events:none}.hero-content{display:flex;align-items:center;justify-content:center;gap:40px}.hero-stat-value{font-family:Orbitron,monospace;font-size:42px;font-weight:900;color:var(--accent-cyan);line-height:1;margin-bottom:8px}.hero-stat-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.hero-divider{width:1px;height:60px;background:linear-gradient(to bottom,transparent,var(--accent-cyan),transparent)}@media (max-width: 600px){.hero-banner{padding:20px}.hero-content{gap:20px}.hero-stat-value{font-size:28px}.hero-divider{height:40px}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.fade-in-scale{animation:fadeInScale .5s ease forwards}.glow-border{position:relative}.glow-border:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(45deg,var(--accent-cyan),var(--accent-magenta),var(--accent-cyan));background-size:300% 300%;animation:gradientBorder 4s ease infinite;border-radius:inherit;z-index:-1;filter:blur(4px);opacity:.5}@keyframes cardEnter{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.section{animation:cardEnter .5s ease forwards}.stat-value{position:relative;display:inline-block}.stat-value:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,currentColor,transparent);opacity:.5}@keyframes progressFill{0%{width:0}}.progress-animate{animation:progressFill 1.5s ease forwards}.particles{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.particle{position:absolute;width:4px;height:4px;background:var(--accent-cyan);border-radius:50%;opacity:.4;animation:particleFloat 8s ease-in-out infinite}.particle:nth-child(2){left:25%;animation-delay:-2s;background:var(--accent-magenta)}.particle:nth-child(3){left:50%;top:40%;animation-delay:-4s;background:var(--accent-green)}.particle:nth-child(4){left:75%;animation-delay:-1s}.particle:nth-child(5){left:90%;top:60%;animation-delay:-3s;background:var(--accent-orange)}@keyframes particleFloat{0%,to{transform:translateY(0) scale(1);opacity:.4}50%{transform:translateY(-30px) scale(1.2);opacity:.7}}.hero-stats{display:flex;align-items:center;justify-content:center;gap:20px;margin:12px 0;padding:16px 24px;background:linear-gradient(135deg,#00f0ff14,#ff00ff14);border-radius:12px;border:1px solid rgba(0,240,255,.2)}.hero-stat{text-align:center}.hero-value{font-family:Orbitron,monospace;font-size:24px;font-weight:700;color:var(--accent-cyan)}.hero-value.green{color:var(--accent-green)}.hero-label{font-size:10px;color:var(--text-secondary);text-transform:uppercase;margin-top:2px}.hero-sep{color:var(--border-color);font-size:20px}@media (max-width: 500px){.hero-stats{gap:12px;padding:12px 16px}.hero-value{font-size:18px}}.pwa-prompt{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:var(--bg-card);border:1px solid var(--accent-cyan);border-radius:12px;padding:12px 16px;display:flex;align-items:center;gap:12px;z-index:1000;box-shadow:0 4px 20px #00f0ff4d;animation:slideUp .3s ease}.pwa-prompt span{font-size:13px}.pwa-prompt button:first-of-type{background:var(--accent-cyan);color:var(--bg-primary);border:none;border-radius:6px;padding:6px 12px;cursor:pointer;font-size:12px}.pwa-prompt button:last-of-type{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:18px}.year-compare{display:flex;align-items:center;justify-content:space-around;padding:20px 0}.year-col{text-align:center}.year-num{font-family:Orbitron,monospace;font-size:36px;font-weight:700;color:var(--accent-cyan)}.year-label{font-size:11px;color:var(--text-secondary);margin-top:4px}.year-dist{font-size:14px;color:var(--text-primary);margin-top:8px}.year-arrow{font-size:24px;color:var(--text-dim)}.year-vs{text-align:center;padding:12px 20px;background:var(--bg-secondary);border-radius:12px}.year-diff{font-family:Orbitron,monospace;font-size:20px;font-weight:700}.year-diff.positive{color:var(--accent-green)}.year-diff.negative{color:var(--accent-red)}.year-vs-label{font-size:10px;color:var(--text-secondary);margin-top:4px}.best-month{display:flex;align-items:center;gap:16px;padding:16px;background:linear-gradient(135deg,#ffcc001a,#ff88001a);border-radius:12px;border:1px solid rgba(255,204,0,.3)}.best-icon{font-size:40px}.best-month-name{font-size:16px;font-weight:600;margin-bottom:4px}.best-stats{font-size:13px;color:var(--text-secondary)}.fitness-score{display:flex;align-items:center;gap:24px}.fitness-ring{width:100px;height:100px;border-radius:50%;border:4px solid;display:flex;flex-direction:column;align-items:center;justify-content:center;flex-shrink:0}.fitness-value{font-family:Orbitron,monospace;font-size:32px;font-weight:700}.fitness-label{font-size:11px}.fitness-details{flex:1}.fitness-item{display:flex;align-items:center;gap:12px;margin-bottom:12px}.fitness-item span:first-child{width:50px;font-size:12px;color:var(--text-secondary)}.fitness-bar{flex:1;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.fitness-bar div{height:100%;border-radius:4px;transition:width 1s ease}.recovery-card{display:flex;align-items:center;gap:20px}.recovery-status{font-size:18px;font-weight:700;padding:12px 24px;border:2px solid;border-radius:12px;background:#0003}.recovery-changes{flex:1}.recovery-change{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border-color);font-size:13px}.recovery-change:last-child{border-bottom:none}.weather-widget{display:flex;align-items:center;gap:12px;padding:12px 16px;background:linear-gradient(135deg,#00f0ff0d,#ffffff05);border-radius:12px;border:1px solid rgba(0,240,255,.1);margin-top:12px}.weather-icon{font-size:32px}.weather-text{font-size:14px;font-weight:500;margin-bottom:4px}.weather-last{font-size:11px;color:var(--text-secondary)}.streak-calendar{display:grid;grid-template-columns:repeat(10,1fr);gap:8px}.streak-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:8px;position:relative;font-size:12px;color:var(--text-secondary);transition:all .2s}.streak-day.active{background:linear-gradient(135deg,var(--accent-cyan),var(--accent-green));color:var(--bg-primary);font-weight:600}.streak-dot{position:absolute;bottom:4px;width:4px;height:4px;background:var(--bg-primary);border-radius:50%}.streak-day:nth-child(1){grid-column:1 / span 2}*:focus-visible{outline:2px solid var(--accent-cyan);outline-offset:2px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 768px){button,[role=button],input,select{min-height:44px;min-width:44px}}@media print{.bottom-nav,.scroll-to-top,.quick-stats-float,.pwa-prompt,.particles{display:none!important}body{background:#fff;color:#000}.stat-card,.section{border:1px solid #ccc;break-inside:avoid}}::selection{background:var(--accent-cyan);color:var(--bg-primary)}::-moz-selection{background:var(--accent-cyan);color:var(--bg-primary)}a{color:var(--accent-cyan);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;height:auto}.no-js{display:none}.gradient-text{background:linear-gradient(90deg,var(--accent-cyan),var(--accent-magenta),var(--accent-cyan));background-size:200% 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradientFlow 3s ease infinite}@keyframes gradientFlow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.stat-card:hover{box-shadow:0 8px 32px #00f0ff26,0 0 0 1px #00f0ff1a}@keyframes shimmerStat{0%{background-position:-200% 0}to{background-position:200% 0}}.stat-card.loading{background:linear-gradient(90deg,var(--bg-card) 25%,var(--bg-card-hover) 50%,var(--bg-card) 75%);background-size:200% 100%;animation:shimmerStat 1.5s infinite}.animated-grid>*:nth-child(1){animation-delay:0ms}.animated-grid>*:nth-child(2){animation-delay:50ms}.animated-grid>*:nth-child(3){animation-delay:.1s}.animated-grid>*:nth-child(4){animation-delay:.15s}.animated-grid>*:nth-child(5){animation-delay:.2s}.animated-grid>*:nth-child(6){animation-delay:.25s}.animated-grid>*:nth-child(7){animation-delay:.3s}.animated-grid>*:nth-child(8){animation-delay:.35s}@keyframes cardEntrance{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.animated-grid>*{animation:cardEntrance .5s ease forwards;opacity:0}.neon-glow:hover{box-shadow:0 0 20px var(--accent-cyan),0 0 40px var(--accent-cyan),0 0 60px var(--accent-cyan)}img{opacity:0;transition:opacity .3s}img.loaded{opacity:1}.section{overflow-y:auto;max-height:500px}.tip-carousel{display:flex;align-items:center;gap:12px;padding:14px 18px;background:linear-gradient(135deg,#ff880014,#ffcc0014);border:1px solid rgba(255,204,0,.2);border-radius:12px;margin-bottom:12px;cursor:pointer;transition:all .3s}.tip-carousel:hover{border-color:#fc06;transform:scale(1.01)}.tip-icon{font-size:28px;flex-shrink:0}.tip-text{flex:1;font-size:13px;line-height:1.5}.tip-hint{font-size:10px;color:var(--text-dim);flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:40px}.empty-icon{font-size:80px;margin-bottom:20px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.empty-title{font-size:24px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.empty-desc{font-size:16px;color:var(--text-secondary)}.weekly-summary{margin-bottom:24px}.weekly-stats{display:flex;justify-content:space-around;text-align:center;padding:16px 0}.weekly-value{font-family:Orbitron,monospace;font-size:28px;font-weight:700;color:var(--accent-cyan)}.weekly-value.green{color:var(--accent-green)}.weekly-value.red{color:var(--accent-red)}.weekly-label{font-size:12px;color:var(--text-secondary);margin-top:4px}.body-metrics{display:flex;gap:16px;margin-top:8px}.body-metric{display:flex;align-items:baseline;gap:4px}.body-value{font-family:Orbitron,monospace;font-size:18px;font-weight:600;color:var(--accent-cyan)}.body-label{font-size:12px;color:var(--text-secondary)}.pace-bars{display:flex;flex-direction:column;gap:10px}.pace-bar-item{display:flex;align-items:center;gap:12px}.pace-range{width:50px;font-size:12px;color:var(--text-secondary);font-family:Orbitron,monospace}.pace-bar-bg{flex:1;height:20px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.pace-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-green));border-radius:4px;transition:width .5s ease}.pace-count{width:40px;font-size:12px;color:var(--text-secondary);text-align:right}
