/* ============================================================
   StravaBoard — Design System v3
   ============================================================ */

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ===== DESIGN TOKENS ===== */
:root{
  --bg:       #0b0c14;
  --bg1:      #111420;
  --bg2:      #181b28;
  --bg3:      #1f2235;
  --border:   #1e2236;
  --border-l: #282d42;

  --text:  #d8deef;
  --text2: #727d9c;
  --text3: #404760;

  --orange: #fc5500;
  --orange-h: #e64d00;
  --orange-dim: rgba(252,85,0,.12);
  --orange-glow: rgba(252,85,0,.06);

  --green:  #1ecf96;
  --blue:   #4d8fff;
  --purple: #9b72f5;
  --red:    #f25168;
  --yellow: #f0ba30;

  --r:     8px;
  --r-sm:  5px;
  --r-lg:  14px;
  --r-xl:  20px;

  --dur:    160ms;
  --ease:   cubic-bezier(.2,.8,.2,1);

  --header-h: 54px;
  --max-w:    1240px;
}

html[data-theme="light"]{
  --bg:     #eef0f8;
  --bg1:    #ffffff;
  --bg2:    #f0f2fa;
  --bg3:    #e4e8f5;
  --border: #d8dcea;
  --border-l:#c6cce0;
  --text:   #111827;
  --text2:  #4e5a78;
  --text3:  #8b95b2;
  --orange-dim: rgba(252,85,0,.08);
  --orange-glow: rgba(252,85,0,.04);
}

/* ===== BASE ===== */
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100dvh;
  line-height:1.55;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
  transition:background .3s,color .3s;
}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;font:inherit;color:inherit}
input,select,textarea{font:inherit;color:inherit;background:none}

/* ===== UTILS ===== */
.mb-2{margin-bottom:8px}
.mt-2{margin-top:8px}
.text-muted{color:var(--text2);font-size:13px}

/* ===== OFFLINE BANNER ===== */
.offline-banner{
  background:#7a5c00;
  color:#ffd060;
  font-size:12px;
  font-weight:500;
  padding:7px 16px;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  letter-spacing:.02em;
}
html[data-theme="light"] .offline-banner{background:#fef3c7;color:#92400e}

/* ===== HEADER ===== */
.header{
  position:sticky;
  top:0;
  z-index:100;
  height:var(--header-h);
  background:color-mix(in srgb,var(--bg) 85%,transparent);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  padding:0 20px;
  gap:20px;
}
.header-left{display:flex;align-items:center;gap:24px;flex:1;min-width:0}
.header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}

/* Logo */
.logo-link{display:flex;align-items:center;gap:9px;flex-shrink:0}
.logo{color:var(--orange);display:block}
.logo-text{
  font-size:15px;
  font-weight:700;
  letter-spacing:-.03em;
  color:var(--text);
  white-space:nowrap;
}

/* Nav */
.nav{display:flex;align-items:center;gap:1px}
.nav-link{
  display:flex;
  align-items:center;
  gap:6px;
  padding:6px 11px;
  border-radius:var(--r-sm);
  color:var(--text3);
  font-size:13px;
  font-weight:500;
  transition:color var(--dur),background var(--dur);
  white-space:nowrap;
}
.nav-link:hover{color:var(--text);background:var(--bg2)}
.nav-link.active{color:var(--text);background:var(--bg2)}
.nav-link.active svg{color:var(--orange)}

/* Theme toggle */
.theme-toggle-btn{
  width:30px;height:30px;
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);
  transition:color var(--dur),background var(--dur);
}
.theme-toggle-btn:hover{color:var(--text);background:var(--bg2)}

/* User */
.user-info{display:flex;align-items:center;gap:8px}
.user-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;border:2px solid var(--border-l)}
.user-name{font-size:13px;font-weight:500;color:var(--text2);max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.btn-logout{
  font-size:12px;padding:5px 11px;
  border-radius:var(--r-sm);
  border:1px solid var(--border-l);
  color:var(--text2);
  transition:all var(--dur);
}
.btn-logout:hover{color:var(--red);border-color:var(--red);background:rgba(242,81,104,.08)}

/* Hamburger */
.hamburger{
  display:none;
  flex-direction:column;
  gap:5px;
  padding:8px;
  border-radius:var(--r-sm);
  color:var(--text2);
}
.hamburger span{
  display:block;width:18px;height:1.5px;
  background:currentColor;border-radius:2px;
  transition:transform .2s,opacity .2s;
}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile nav */
.mobile-nav-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.65);
  backdrop-filter:blur(4px);
  z-index:99;
  padding-top:var(--header-h);
  display:none;
  align-items:flex-start;
}
.mobile-nav{
  width:100%;
  background:var(--bg1);
  border-bottom:1px solid var(--border);
  padding:10px 14px 18px;
  display:flex;flex-direction:column;gap:2px;
}
.mobile-nav-link{
  display:flex;align-items:center;gap:12px;
  padding:11px 14px;
  border-radius:var(--r);
  color:var(--text2);font-size:15px;font-weight:500;
  transition:all var(--dur);
}
.mobile-nav-link:hover,.mobile-nav-link.active{color:var(--text);background:var(--bg2)}
.mobile-nav-link.logout{
  margin-top:10px;color:var(--red);
  border-top:1px solid var(--border);border-radius:0;padding-top:18px;
}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 15px;
  border-radius:var(--r-sm);
  font-size:13px;font-weight:500;
  transition:all var(--dur);
  white-space:nowrap;
  letter-spacing:.01em;
}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-h);transform:translateY(-1px)}
.btn-primary:active{transform:none}
.btn-primary.syncing{opacity:.65}
.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}

.btn-outline{
  background:transparent;
  border:1px solid var(--border-l);
  color:var(--text2);
}
.btn-outline:hover{border-color:var(--text3);color:var(--text);background:var(--bg2)}
.btn-outline.active{color:var(--orange);border-color:var(--orange);background:var(--orange-dim)}

.btn-red-outline{
  background:transparent;
  border:1px solid var(--border-l);
  color:var(--text3);
}
.btn-red-outline:hover{color:var(--red);border-color:var(--red);background:rgba(242,81,104,.08)}

.btn-sm{padding:5px 11px;font-size:12px}
.btn-full{width:100%;justify-content:center}
.btn-strava{
  background:var(--orange);color:#fff;
  padding:13px 28px;font-size:15px;font-weight:600;
  border-radius:var(--r);gap:10px;
  transition:all .2s var(--ease);
}
.btn-strava:hover{background:var(--orange-h);transform:translateY(-2px);box-shadow:0 10px 28px rgba(252,85,0,.3)}

/* ===== INPUTS ===== */
.input-field{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--r-sm);
  padding:8px 11px;
  color:var(--text);
  font-size:13px;
  width:100%;
  outline:none;
  transition:border-color var(--dur);
  appearance:none;
}
.input-field:focus{border-color:var(--orange)}
.input-field::placeholder{color:var(--text3)}
.input-sm{padding:6px 9px;font-size:12px}
.textarea{resize:vertical;min-height:60px;line-height:1.5}

select.input-field{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23727d9c' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 10px center;
  padding-right:28px;
}

/* ===== CONTAINER ===== */
.container{max-width:var(--max-w);margin:0 auto;padding:22px 20px}
.page{min-height:calc(100dvh - var(--header-h))}

/* ===== LOGIN ===== */
.login-hero{
  min-height:calc(100dvh - var(--header-h));
  display:flex;align-items:center;justify-content:center;
  padding:40px 20px;
  background:
    radial-gradient(ellipse 600px 500px at 50% 35%,rgba(252,85,0,.07) 0%,transparent 70%),
    radial-gradient(ellipse 300px 200px at 70% 70%,rgba(77,143,255,.05) 0%,transparent 60%);
}
.login-card{text-align:center;max-width:400px;width:100%}
.login-icon{
  width:68px;height:68px;
  background:var(--orange-dim);
  border:1px solid rgba(252,85,0,.22);
  border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 24px;
  color:var(--orange);
}
.login-card h1{
  font-size:34px;font-weight:800;letter-spacing:-.04em;
  color:var(--text);margin-bottom:10px;
}
.login-sub{
  font-size:15px;color:var(--text2);
  line-height:1.65;margin-bottom:30px;
}
.login-features{display:flex;justify-content:center;gap:28px;margin-bottom:36px}
.login-feature{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  font-size:11px;color:var(--text2);font-weight:500;
  text-transform:uppercase;letter-spacing:.06em;
}
.feat-icon{font-size:22px}

/* ===== DASHBOARD ===== */

/* Spotlight */
.spotlight{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  margin-bottom:14px;
  overflow:hidden;
  display:flex;
  transition:border-color var(--dur);
}
.spotlight:hover{border-color:var(--border-l)}
.spotlight-info{
  flex:1;padding:22px 26px;
  cursor:pointer;min-width:0;
}
.spotlight-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--orange);margin-bottom:10px;
}
.spotlight-badge::before{
  content:'';width:5px;height:5px;
  border-radius:50%;background:var(--orange);
  animation:pulse 2s ease infinite;
}
.spotlight-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.spotlight-icon{font-size:20px;flex-shrink:0}
.spotlight-header h3{
  font-size:19px;font-weight:700;letter-spacing:-.02em;
  color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.spotlight-date{font-size:12px;color:var(--text2);margin-bottom:18px}
.spotlight-stats{display:flex;flex-wrap:wrap;gap:16px 28px}
.spotlight-stat{display:flex;flex-direction:column;gap:2px}
.spotlight-stat-val{
  font-size:17px;font-weight:700;
  letter-spacing:-.01em;font-variant-numeric:tabular-nums;
  line-height:1.1;
}
.spotlight-stat-label{
  font-size:10px;color:var(--text3);
  text-transform:uppercase;letter-spacing:.07em;font-weight:600;
}
.spotlight-map{
  width:260px;flex-shrink:0;
  border-left:1px solid var(--border);
  background:var(--bg2);
}

/* Stats Bar */
.stats-bar{
  display:flex;
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  margin-bottom:18px;
  overflow-x:auto;
  scrollbar-width:none;
}
.stats-bar::-webkit-scrollbar{display:none}
.stat-card{
  padding:12px 18px;
  border-right:1px solid var(--border);
  flex-shrink:0;
  position:relative;
}
.stat-card:last-child{border-right:none}
.stat-card.dragging{opacity:.4}
.stat-card.drag-over{border-left:2px solid var(--orange)}
.stat-card-period{padding:10px 14px}

.period-selector{display:flex;gap:2px;align-items:center;height:100%}
.period-btn{
  padding:5px 9px;border-radius:var(--r-sm);
  font-size:12px;font-weight:500;
  color:var(--text3);background:transparent;
  transition:all var(--dur);cursor:pointer;white-space:nowrap;
}
.period-btn:hover{color:var(--text2);background:var(--bg2)}
.period-btn.active{color:var(--orange);background:var(--orange-dim)}

.stat-label{
  font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.07em;
  color:var(--text3);margin-bottom:4px;white-space:nowrap;
}
.stat-value{
  font-size:18px;font-weight:700;
  letter-spacing:-.02em;font-variant-numeric:tabular-nums;
  line-height:1.2;
}
.stat-trend{display:flex;align-items:center;gap:5px;margin-top:3px}
.trend-badge{
  font-size:10px;font-weight:700;
  padding:1px 5px;border-radius:4px;
}
.trend-up{color:var(--green);background:rgba(30,207,150,.12)}
.trend-down{color:var(--red);background:rgba(242,81,104,.12)}
.trend-neutral{color:var(--text3);background:var(--bg3)}
.stat-prev{font-size:11px;color:var(--text3)}
.stat-avg{font-size:10px;color:var(--text3);margin-top:2px}

/* Customize mode */
.is-customizing .stat-card[data-id]{cursor:grab}
.drag-handle{
  position:absolute;top:4px;left:50%;transform:translateX(-50%);
  font-size:13px;color:var(--text3);cursor:grab;
}
.hide-card-btn{
  position:absolute;top:4px;right:5px;
  width:16px;height:16px;
  display:flex;align-items:center;justify-content:center;
  border-radius:3px;font-size:14px;
  color:var(--text3);
  transition:all var(--dur);
}
.hide-card-btn:hover{color:var(--red);background:rgba(242,81,104,.1)}
.card-is-hidden{opacity:.4;filter:grayscale(.4)}

/* Toolbar */
.toolbar{
  display:flex;align-items:center;
  justify-content:space-between;
  gap:10px;margin-bottom:10px;
}
.toolbar-sep{width:1px;height:20px;background:var(--border-l);flex-shrink:0}
.btn-icon{padding:6px;border-radius:var(--r-sm);display:inline-flex;align-items:center;justify-content:center}
.btn-ghost-danger{color:var(--text3);background:transparent;transition:all var(--dur)}
.btn-ghost-danger:hover{color:var(--red);background:rgba(242,81,104,.08)}
.toolbar h2#activityTitle{
  font-size:13px;font-weight:600;
  color:var(--text3);white-space:nowrap;
}
.toolbar-right{
  display:flex;align-items:center;
  gap:6px;flex-wrap:wrap;justify-content:flex-end;
}
.search-input{width:170px}

/* Filters */
.filters-panel{
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:14px;margin-bottom:10px;
}
.filters-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}
.filter-group{display:flex;flex-direction:column;gap:5px;min-width:120px}
.filter-label{
  font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.07em;
  color:var(--text3);
}
.filters-actions{
  display:flex;gap:8px;
  margin-top:10px;padding-top:10px;
  border-top:1px solid var(--border);
}

/* Sync progress */
.sync-bar{
  display:flex;align-items:center;gap:12px;
  padding:9px 14px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r-sm);
  margin-bottom:10px;
  font-size:12px;color:var(--text2);
}
.sync-bar-track{
  flex:1;height:2px;background:var(--border-l);
  border-radius:2px;overflow:hidden;
}
.sync-bar-fill{
  width:50%;height:100%;
  background:var(--orange);border-radius:2px;
  animation:bar-slide 1.4s ease infinite;
}

/* ===== ACTIVITY LIST ===== */
.activity-grid{
  display:flex;flex-direction:column;
  background:var(--bg1);
  border:1px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
}

.date-group-header{
  padding:7px 18px;
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;
  color:var(--text3);
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  border-top:1px solid var(--border);
}
.date-group-header:first-child{border-top:none}

.activity-card{
  display:flex;align-items:center;gap:12px;
  padding:12px 18px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  position:relative;
  transition:background var(--dur);
}
.activity-card:last-child{border-bottom:none}
.activity-card::before{
  content:'';
  position:absolute;left:0;top:0;bottom:0;width:2px;
  background:var(--orange);
  transform:scaleY(0);transform-origin:center;
  transition:transform var(--dur);
}
.activity-card:hover{background:var(--bg2)}
.activity-card:hover::before{transform:scaleY(1)}

.activity-icon{
  font-size:18px;flex-shrink:0;
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg3);
  border-radius:var(--r-sm);
}
.activity-info{flex:1;min-width:0}
.activity-info h3{
  font-size:13px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  margin-bottom:3px;
}
.activity-meta{
  display:flex;align-items:center;gap:7px;
  font-size:11px;color:var(--text2);flex-wrap:wrap;
}
.activity-meta span{white-space:nowrap}
.activity-stats{
  display:flex;align-items:center;gap:18px;flex-shrink:0;
}
.activity-stat-item{
  display:flex;flex-direction:column;align-items:flex-end;gap:1px;
  min-width:44px;
}
.activity-stat-val{
  font-size:13px;font-weight:600;
  color:var(--text);font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.activity-stat-label{
  font-size:10px;color:var(--text3);
  text-transform:uppercase;letter-spacing:.05em;font-weight:500;
}
.activity-stats svg.sparkline{flex-shrink:0;opacity:.7}

/* Infinite scroll */
.infinite-spinner{
  display:flex;justify-content:center;
  padding:20px;color:var(--text3);
}

/* Empty state */
.empty-state{
  display:flex;flex-direction:column;align-items:center;
  gap:14px;padding:70px 20px;
  color:var(--text2);font-size:14px;text-align:center;
}

/* ===== MAP PAGE ===== */
.map-layout{display:flex;height:calc(100dvh - var(--header-h))}

.map-sidebar{
  width:272px;flex-shrink:0;
  background:var(--bg1);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  overflow:hidden;position:relative;
  transition:width .3s var(--ease);
}
.map-sidebar.collapsed{width:0}
.sidebar-toggle{
  position:absolute;right:-13px;top:50%;
  transform:translateY(-50%);z-index:10;
  width:26px;height:26px;
  background:var(--bg1);border:1px solid var(--border);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  color:var(--text2);cursor:pointer;
  transition:all var(--dur);
}
.sidebar-toggle:hover{color:var(--text);background:var(--bg2)}
.sidebar-toggle.flipped svg{transform:rotate(180deg)}

.sidebar-section{padding:14px;border-bottom:1px solid var(--border)}
.sidebar-title{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;
  color:var(--text3);margin-bottom:10px;
}
.sidebar-subtitle{
  font-size:12px;font-weight:600;
  color:var(--text2);margin:10px 0 8px;
}
.sidebar-divider{border-top:1px solid var(--border);margin:8px 0}
.sidebar-scroll{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--border) transparent}

.mode-tabs{display:flex;gap:4px}
.mode-tab{
  flex:1;padding:6px 10px;border-radius:var(--r-sm);
  font-size:12px;font-weight:500;
  color:var(--text2);background:var(--bg2);
  transition:all var(--dur);
}
.mode-tab.active{color:var(--orange);background:var(--orange-dim)}
.mode-tab:hover:not(.active){color:var(--text);background:var(--bg3)}

.vis-controls{display:flex;flex-direction:column;gap:10px}
.toggle-row{display:flex;align-items:center;gap:10px;cursor:pointer}
.toggle-label{font-size:12px;color:var(--text2)}
input[type="checkbox"]{accent-color:var(--orange)}

.sidebar-search{padding:10px 14px;border-bottom:1px solid var(--border)}

.map-activity-list{display:flex;flex-direction:column}
.map-act-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 14px;
  border-bottom:1px solid var(--border);
  cursor:pointer;
  transition:background var(--dur);
}
.map-act-item:last-child{border-bottom:none}
.map-act-item:hover{background:var(--bg2)}
.map-act-item.active{background:var(--orange-dim);border-left:2px solid var(--orange)}
.map-act-item.dimmed{opacity:.35}
.map-act-icon{font-size:16px;flex-shrink:0}
.map-act-info{flex:1;min-width:0}
.map-act-info h4{
  font-size:12px;font-weight:600;color:var(--text);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.map-act-info p{font-size:11px;color:var(--text2)}

.map-container{flex:1;position:relative;isolation:isolate}
.leaflet-map{width:100%;height:100%}

.draw-form{display:flex;flex-direction:column;gap:9px}
.draw-info{
  display:flex;gap:14px;font-size:12px;font-weight:600;
  color:var(--text2);padding:8px 10px;
  background:var(--bg2);border-radius:var(--r-sm);
}
.draw-colors{display:flex;gap:7px;flex-wrap:wrap}
.color-dot{
  width:20px;height:20px;border-radius:50%;
  border:2px solid transparent;cursor:pointer;
  transition:transform var(--dur),box-shadow var(--dur);
}
.color-dot:hover{transform:scale(1.2)}
.color-dot.active{border-color:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.15)}
.draw-actions{display:flex;gap:6px}

.saved-routes-list{display:flex;flex-direction:column}
.saved-route-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:9px 0;border-bottom:1px solid var(--border);
  cursor:pointer;transition:opacity var(--dur);
}
.saved-route-item:last-child{border-bottom:none}
.saved-route-item:hover{opacity:.85}
.saved-route-left{display:flex;align-items:center;gap:10px}
.saved-route-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.saved-route-info h4{font-size:12px;font-weight:600;color:var(--text)}
.saved-route-info p{font-size:11px;color:var(--text2)}
.saved-route-actions{display:flex;gap:4px}
.saved-route-btn{
  padding:3px 8px;border-radius:var(--r-sm);
  font-size:12px;font-weight:500;
  border:1px solid var(--border);
  color:var(--text2);background:transparent;
  transition:all var(--dur);
}
.saved-route-btn:hover{color:var(--text);border-color:var(--border-l)}
.saved-route-btn.del:hover{color:var(--red);border-color:var(--red);background:rgba(242,81,104,.08)}

.map-advanced-panel{
  background:var(--bg2);border-radius:var(--r-sm);
  padding:10px;margin-top:6px;
}

/* ===== STATS PAGE ===== */
.stats-header{
  display:flex;align-items:center;
  justify-content:space-between;gap:14px;
  margin-bottom:22px;flex-wrap:wrap;
}
.page-title{font-size:21px;font-weight:700;letter-spacing:-.03em}
.stats-filter select{width:190px}
.sport-tabs{display:flex;gap:4px;flex-wrap:wrap;align-items:center}
.sport-tab{
  padding:5px 12px;border-radius:var(--r-sm);
  font-size:12px;font-weight:500;
  color:var(--text2);background:var(--bg2);
  border:1px solid transparent;
  cursor:pointer;transition:all var(--dur);white-space:nowrap;
}
.sport-tab:hover:not(.active){color:var(--text);background:var(--bg3)}
.sport-tab.active{color:var(--orange);background:var(--orange-dim);border-color:rgba(252,85,0,.25)}

.section-title{
  display:flex;align-items:center;gap:8px;
  font-size:13px;font-weight:600;color:var(--text2);
  margin:24px 0 12px;
  padding-bottom:9px;
  border-bottom:1px solid var(--border);
}
.section-title svg{color:var(--orange);flex-shrink:0}

/* Goals */
.goals-section{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-lg);
  padding:18px;margin-bottom:6px;
}
.goals-header{
  display:flex;align-items:center;
  justify-content:space-between;margin-bottom:14px;
}
.goals-header .section-title{
  margin:0;padding:0;border:none;
  font-size:14px;color:var(--text);
}
.goals-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(210px,1fr));
  gap:10px;margin-bottom:10px;
}
.goal-card{
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);padding:13px;
}
.goal-card-header{
  display:flex;justify-content:space-between;
  align-items:center;margin-bottom:7px;
}
.goal-card-title{font-size:13px;font-weight:600;color:var(--text)}
.goal-progress-text{font-size:12px;color:var(--text2);margin-bottom:7px}
.goal-current{font-weight:600;color:var(--text)}
.goal-bar-wrap{
  height:4px;background:var(--bg3);
  border-radius:3px;overflow:hidden;margin-bottom:6px;
}
.goal-bar{
  height:100%;background:var(--orange);
  border-radius:3px;transition:width .4s var(--ease);
}
.goal-footer{display:flex;justify-content:space-between;font-size:10px}
.goal-pct{color:var(--orange);font-weight:700}
.goal-period{color:var(--text3)}
.goal-form{
  display:flex;flex-direction:column;gap:8px;
  background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--r);padding:14px;margin-top:6px;
}
.goal-form-actions{display:flex;gap:8px;margin-top:4px}

/* KPIs */
.kpi-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.kpi-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);padding:14px 18px;min-width:110px;
}
.kpi-val{
  font-size:24px;font-weight:800;
  letter-spacing:-.04em;font-variant-numeric:tabular-nums;
  line-height:1.1;
}
.kpi-label{
  font-size:10px;color:var(--text3);
  text-transform:uppercase;letter-spacing:.07em;
  font-weight:600;margin-top:4px;
}

/* Best week */
.best-week-banner{
  display:flex;align-items:center;gap:14px;
  background:linear-gradient(135deg,var(--orange-dim),transparent);
  border:1px solid rgba(252,85,0,.18);
  border-radius:var(--r);
  padding:14px 18px;margin-bottom:6px;
}
.best-week-icon{font-size:26px}
.best-week-content{flex:1}
.best-week-title{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.09em;color:var(--orange);
}
.best-week-subtitle{font-size:13px;font-weight:600;color:var(--text)}
.best-week-stats{display:flex;gap:18px;flex-wrap:wrap;margin-top:4px}
.best-week-stat{font-size:12px;color:var(--text2)}

/* Avg grid */
.avg-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:8px;margin-bottom:6px;
}
.avg-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);padding:12px 14px;
  display:flex;align-items:center;gap:10px;
}
.avg-icon{font-size:20px;flex-shrink:0}
.avg-info{flex:1;min-width:0}
.avg-val{
  font-size:15px;font-weight:700;
  color:var(--text);font-variant-numeric:tabular-nums;
}
.avg-val.red{color:var(--red)}
.avg-val.yellow{color:var(--yellow)}
.avg-val.orange{color:var(--orange)}
.avg-val.green{color:var(--green)}
.avg-label{
  font-size:10px;color:var(--text3);
  text-transform:uppercase;letter-spacing:.06em;font-weight:500;
}

/* Records */
.records-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:8px;margin-bottom:6px;
}
.record-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);padding:14px;
  cursor:pointer;transition:border-color var(--dur),background var(--dur);
}
.record-card:hover{border-color:var(--border-l);background:var(--bg2)}
.record-label{
  font-size:10px;font-weight:600;
  text-transform:uppercase;letter-spacing:.07em;
  color:var(--text3);margin-bottom:5px;
}
.record-value{
  font-size:18px;font-weight:700;
  font-variant-numeric:tabular-nums;letter-spacing:-.01em;line-height:1.2;
}
.record-activity{
  font-size:10px;color:var(--text3);
  margin-top:5px;white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;
}

/* Sport distribution */
.sport-grid{display:flex;flex-direction:column;gap:6px}
.sport-row{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);cursor:pointer;
  transition:border-color var(--dur);
}
.sport-row:hover{border-color:var(--border-l)}
.sport-icon{font-size:20px;flex-shrink:0;width:32px}
.sport-info{flex:1;min-width:0}
.sport-name{font-size:12px;font-weight:600;color:var(--text)}
.sport-detail{font-size:11px;color:var(--text2);margin:2px 0}
.sport-bar-wrap{height:3px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:5px}
.sport-bar{height:100%;background:var(--orange);border-radius:2px}
.sport-count{font-size:18px;font-weight:700;color:var(--text3);flex-shrink:0}

/* Charts */
.chart-container{position:relative}
.chart-canvas-wrap{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px;
  height:250px;margin-bottom:6px;
}

/* Heatmaps */
.heatmap-row{
  display:flex;gap:8px;align-items:flex-end;
  flex-wrap:wrap;padding:14px 18px;
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-lg);margin-bottom:6px;
}
.heatmap-hours{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}
.heat-col{display:flex;flex-direction:column;align-items:center;gap:6px}
.heat-cell{border-radius:4px;transition:transform var(--dur)}
.heat-cell:hover{transform:scale(1.25);z-index:1}
.heat-label{font-size:9px;color:var(--text3);font-weight:600}

/* Calendar heatmap */
.calendar-section{margin-bottom:6px}
.cal-heatmap-wrap{
  overflow-x:auto;background:var(--bg1);
  border:1px solid var(--border);border-radius:var(--r-lg);
  padding:14px 18px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
.cal-months{display:grid;padding-left:30px;margin-bottom:5px}
.cal-month-label{
  font-size:9px;color:var(--text3);
  font-weight:700;text-transform:uppercase;letter-spacing:.07em;
}
.cal-grid{display:grid;gap:3px}
.cal-day-label{
  font-size:8px;color:var(--text3);font-weight:600;
  display:flex;align-items:center;justify-content:flex-end;
  padding-right:4px;height:11px;
}
.cal-cell{
  width:11px;height:11px;border-radius:2px;
  background:var(--bg3);
  transition:transform var(--dur);
}
.cal-cell:hover{transform:scale(1.5);z-index:1}
.cal-empty{background:transparent}
.cal-level-0{background:var(--bg3)}
.cal-level-1{background:rgba(252,85,0,.22)}
.cal-level-2{background:rgba(252,85,0,.44)}
.cal-level-3{background:rgba(252,85,0,.7)}
.cal-level-4{background:var(--orange)}

/* Best efforts */
.best-efforts-showcase{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:8px;margin-bottom:6px;
}
.effort-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r);padding:14px;
  cursor:pointer;transition:border-color var(--dur);
}
.effort-card:hover{border-color:var(--orange)}
.effort-card-empty{opacity:.45;cursor:default}
.effort-card-empty:hover{border-color:var(--border)}
.effort-card-top{
  display:flex;justify-content:space-between;
  align-items:center;margin-bottom:7px;
}
.effort-distance{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;color:var(--text3);
}
.effort-pace{
  font-size:13px;font-weight:700;
  color:var(--orange);font-variant-numeric:tabular-nums;
}
.effort-time{
  font-size:19px;font-weight:800;
  letter-spacing:-.03em;color:var(--text);
  font-variant-numeric:tabular-nums;margin-bottom:7px;
}
.effort-bar-wrap{height:3px;background:var(--bg3);border-radius:2px;overflow:hidden;margin-bottom:7px}
.effort-bar{
  height:100%;background:linear-gradient(90deg,var(--orange),rgba(252,85,0,.4));
  border-radius:2px;
}
.effort-detail{font-size:10px;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* HR Analysis */
.hr-analysis-grid{
  display:grid;
  grid-template-columns:auto 1fr 2fr;
  gap:14px;align-items:start;
}
.hr-analysis-kpis{display:flex;flex-direction:column;gap:8px}
.hr-chart-wrap{height:200px}
.hr-monthly-wrap{height:200px}

/* ===== PROFILE ===== */
.profile-id-card{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:24px;
  margin-bottom:14px;
  display:flex;align-items:center;gap:18px;
}
.profile-id-left{display:flex;align-items:center;gap:16px}
.profile-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;border:2px solid var(--border-l)}
.profile-avatar-placeholder{
  width:56px;height:56px;border-radius:50%;
  background:var(--bg3);border:2px solid var(--border-l);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);
}
.profile-id-name{font-size:18px;font-weight:700;letter-spacing:-.02em}
.profile-id-username{font-size:13px;color:var(--text3);margin-top:2px}

.profile-summary{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:18px;margin-bottom:18px;
}
.profile-kpi-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;
}
.profile-kpi{padding:12px;background:var(--bg2);border-radius:var(--r-sm)}
.profile-kpi-val{
  font-size:18px;font-weight:700;
  font-variant-numeric:tabular-nums;letter-spacing:-.02em;
}
.profile-kpi-label{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;font-weight:600;margin-top:4px}

.profile-form{
  background:var(--bg1);border:1px solid var(--border);
  border-radius:var(--r-lg);padding:22px;
}
.profile-form-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));
  gap:14px;margin-bottom:18px;
}
.profile-field{display:flex;flex-direction:column;gap:5px}
.profile-field label{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;color:var(--text3);
}
.profile-form-actions{
  display:flex;align-items:center;gap:12px;
  padding-top:14px;border-top:1px solid var(--border);
}
.profile-save-msg{
  font-size:13px;color:var(--green);font-weight:500;
  opacity:0;transition:opacity .3s;
}
.profile-save-msg.visible{opacity:1}

/* ===== MODAL ===== */
.modal-overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.78);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  z-index:200;
  display:flex;align-items:center;justify-content:center;
  padding:20px;overflow-y:auto;
  opacity:0;
  transition:opacity 180ms var(--ease);
}
.modal-overlay.modal-visible{opacity:1}
.modal{
  background:var(--bg1);
  border:1px solid var(--border-l);
  border-radius:var(--r-xl);
  width:100%;max-width:700px;
  position:relative;margin:auto;
  box-shadow:0 24px 60px rgba(0,0,0,.7);
  opacity:0;
  transform:scale(.97) translateY(8px);
  transition:opacity 180ms var(--ease),transform 180ms var(--ease);
}
.modal-overlay.modal-visible .modal{opacity:1;transform:none}
.modal-close{
  position:absolute;top:14px;right:14px;
  width:26px;height:26px;
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  color:var(--text2);font-size:20px;
  background:var(--bg2);z-index:1;
  transition:all var(--dur);
}
.modal-close:hover{color:var(--text);background:var(--bg3)}
.modal-content{padding:26px}

.modal-header{margin-bottom:18px}
.modal-type{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;
  color:var(--orange);margin-bottom:5px;
}
.modal-title{
  font-size:20px;font-weight:700;
  letter-spacing:-.03em;color:var(--text);margin-bottom:3px;
}
.modal-date{font-size:12px;color:var(--text2)}

/* Detail stats */
.detail-stats{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(105px,1fr));
  gap:10px;margin-bottom:18px;
}
.detail-stat{
  background:var(--bg2);border-radius:var(--r-sm);
  padding:10px 13px;
}
.detail-stat-label{
  font-size:9px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
  color:var(--text3);margin-bottom:3px;
}
.detail-stat-val{
  font-size:15px;font-weight:700;
  font-variant-numeric:tabular-nums;
}

/* Map in modal */
.detail-map{
  height:260px;border-radius:var(--r);overflow:hidden;
  margin-bottom:5px;border:1px solid var(--border);
}
.intensity-legend{
  display:flex;align-items:center;gap:8px;
  font-size:10px;color:var(--text3);
  margin-bottom:10px;padding:0 2px;
}
.intensity-legend-bar{
  flex:1;height:3px;border-radius:2px;
  background:linear-gradient(90deg,#1ecf96,#f0ba30,#f25168);
}

/* Elevation */
.elevation-profile-wrap{
  margin-bottom:14px;
  background:var(--bg2);border-radius:var(--r-sm);
  padding:8px 10px 5px;border:1px solid var(--border);
}
#elevationCanvas{width:100%;display:block}
.elevation-profile-info{
  display:flex;justify-content:space-between;
  font-size:10px;color:var(--text3);font-weight:500;margin-top:3px;
}

/* Splits pace chart */
.splits-pace-chart-wrap{margin-bottom:14px}
.splits-pace-chart-wrap h4{
  font-size:12px;font-weight:600;color:var(--text2);margin-bottom:7px;
}
.splits-pace-chart-canvas{height:170px}

/* HR Zones / Power zones */
.zones-section{margin-bottom:14px}
.zones-title{
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;
  color:var(--text3);margin-bottom:9px;
}
.zones-bars{display:flex;flex-direction:column;gap:7px}
.zone-row{display:flex;align-items:center;gap:8px}
.zone-name{font-size:11px;color:var(--text2);min-width:108px}
.zone-bar-track{flex:1;height:5px;background:var(--bg3);border-radius:3px;overflow:hidden}
.zone-bar-fill{height:100%;border-radius:3px;transition:width .4s var(--ease)}
.zone-pct{font-size:11px;font-weight:700;color:var(--text);min-width:30px;text-align:right}
.zone-time{font-size:10px;color:var(--text3);min-width:42px;text-align:right}
.zones-note{font-size:10px;color:var(--text3);margin-top:5px;font-style:italic}

/* Splits table */
.splits-section{margin-bottom:14px}
.splits-table{background:var(--bg2);border-radius:var(--r-sm);overflow:hidden}
.splits-header{
  display:grid;grid-template-columns:38px 58px 1fr 2fr;
  padding:7px 13px;
  font-size:9px;font-weight:700;
  text-transform:uppercase;letter-spacing:.07em;
  color:var(--text3);border-bottom:1px solid var(--border);
}
.split-row{
  display:grid;grid-template-columns:38px 58px 1fr 2fr;
  align-items:center;padding:7px 13px;
  border-bottom:1px solid var(--border);
}
.split-row:last-child{border-bottom:none}
.split-km{font-size:12px;font-weight:600;color:var(--text2)}
.split-time{font-size:11px;color:var(--text2)}
.split-pace{font-size:12px;font-weight:600;font-variant-numeric:tabular-nums}
.split-bar-track{height:3px;background:var(--bg3);border-radius:2px;overflow:hidden}
.split-bar-fill{height:100%;border-radius:2px}

/* Detail extras */
.detail-extra{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.detail-extra-item{display:flex;flex-direction:column;gap:2px}
.detail-extra-label{
  font-size:9px;color:var(--text3);
  text-transform:uppercase;letter-spacing:.07em;font-weight:600;
}
.detail-extra-val{font-size:13px;font-weight:600;color:var(--text)}

/* Detail actions */
.detail-actions{
  display:flex;gap:8px;flex-wrap:wrap;
  padding-top:14px;border-top:1px solid var(--border);
}
.strava-link{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:500;
  padding:5px 11px;border-radius:var(--r-sm);
  border:1px solid var(--border-l);
  color:var(--orange);background:var(--orange-dim);
  transition:all var(--dur);
}
.strava-link:hover{background:rgba(252,85,0,.2);border-color:var(--orange)}

/* ===== TOAST ===== */
.toast-container{
  position:fixed;bottom:24px;right:24px;
  z-index:500;display:flex;flex-direction:column;gap:8px;
  pointer-events:none;
}
.toast{
  display:flex;align-items:center;gap:10px;
  padding:11px 16px;
  background:var(--bg2);border:1px solid var(--border-l);
  border-radius:var(--r);
  font-size:13px;font-weight:500;color:var(--text);
  box-shadow:0 8px 28px rgba(0,0,0,.55);
  max-width:340px;pointer-events:auto;
  opacity:0;transform:translateY(6px);
  transition:opacity .2s var(--ease),transform .2s var(--ease);
}
.toast.toast-show{opacity:1;transform:none}
.toast.toast-hide{opacity:0;transform:translateY(-4px)}
.toast-icon{font-size:16px;flex-shrink:0}
.toast-msg{flex:1}
.toast.toast-success{border-left:3px solid var(--green)}
.toast.toast-error{border-left:3px solid var(--red)}
.toast.toast-record{border-left:3px solid var(--yellow)}
.toast.toast-info{border-left:3px solid var(--blue)}

/* ===== ANIMATIONS ===== */
@keyframes pulse{
  0%,100%{opacity:1;transform:scale(1)}
  50%{opacity:.5;transform:scale(.7)}
}
@keyframes spinning{to{transform:rotate(360deg)}}
@keyframes bar-slide{
  from{transform:translateX(-100%)}
  to{transform:translateX(300%)}
}
@keyframes pageFadeIn{
  from{opacity:0;transform:translateY(4px)}
  to{opacity:1;transform:none}
}

.spin{animation:spinning .75s linear infinite}
.page-enter{animation:pageFadeIn 160ms var(--ease) both}

/* ===== COLOR UTILITIES (declared last for correct cascade) ===== */
.orange{color:var(--orange)!important}
.green{color:var(--green)!important}
.blue{color:var(--blue)!important}
.purple{color:var(--purple)!important}
.red{color:var(--red)!important}
.yellow{color:var(--yellow)!important}

/* ===== BOTTOM TAB NAV (mobile) ===== */
.bottom-nav{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  z-index:100;
  background:color-mix(in srgb,var(--bg1) 96%,transparent);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--border);
  padding:6px 0 max(8px,env(safe-area-inset-bottom));
}
.bottom-nav-item{
  flex:1;display:flex;flex-direction:column;
  align-items:center;gap:3px;
  padding:5px 4px 3px;
  position:relative;
  color:var(--text3);font-size:10px;font-weight:500;
  text-decoration:none;
  transition:color var(--dur) var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.bottom-nav-item::before{
  content:'';
  position:absolute;
  top:3px;left:50%;transform:translateX(-50%) scale(.6);
  width:52px;height:32px;
  border-radius:16px;
  background:var(--orange-dim);
  opacity:0;
  transition:opacity var(--dur) var(--ease),transform var(--dur) var(--ease);
  pointer-events:none;
}
.bottom-nav-item.active::before{opacity:1;transform:translateX(-50%) scale(1)}
.bottom-nav-item svg{position:relative;z-index:1;flex-shrink:0;transition:transform var(--dur) var(--ease)}
.bottom-nav-item span{position:relative;z-index:1}
.bottom-nav-item.active{color:var(--orange)}
.bottom-nav-item.active svg{transform:scale(1.15) translateY(-1px)}

/* ===== MAP FAB + DRAWER BACKDROP ===== */
.map-fab{
  display:none;
  position:absolute;
  bottom:20px;left:50%;transform:translateX(-50%);
  z-index:1000;
  align-items:center;gap:8px;
  padding:11px 20px;
  background:var(--bg1);
  border:1px solid var(--border-l);
  border-radius:28px;
  box-shadow:0 4px 24px rgba(0,0,0,.45);
  color:var(--text);
  font-size:13px;font-weight:600;
  cursor:pointer;
  white-space:nowrap;
  transition:transform var(--dur) var(--ease),box-shadow var(--dur);
}
.map-fab:hover{transform:translateX(-50%) translateY(-1px);box-shadow:0 6px 28px rgba(0,0,0,.5)}
.map-drawer-backdrop{
  display:none;
  position:fixed;inset:0;
  z-index:149;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(2px);
  -webkit-backdrop-filter:blur(2px);
}
.map-drawer-backdrop.visible{display:block}

/* ===== MOBILE CARD STATS ===== */
.activity-stats-mobile{
  display:none;
  gap:7px;margin-top:3px;
  flex-wrap:wrap;align-items:center;
}
.activity-stat-m{
  font-size:11px;font-weight:600;
  color:var(--text2);font-variant-numeric:tabular-nums;
  white-space:nowrap;
}
.activity-stat-m.orange{color:var(--orange)}
.activity-stat-m.sep{color:var(--border-l);font-weight:400}

/* ===== MODAL DRAG HANDLE ===== */
.modal-handle{
  display:none;
  width:36px;height:4px;
  background:var(--border-l);
  border-radius:2px;
  margin:10px auto 0;
  flex-shrink:0;
}

/* ===== RESPONSIVE ===== */

/* --- 900px: tablet --- */
@media(max-width:900px){
  .nav{display:none!important}
  .hamburger{display:flex}
  .spotlight{flex-direction:column}
  .spotlight-map{width:100%;height:180px;border-left:none;border-top:1px solid var(--border)}
  .hr-analysis-grid{grid-template-columns:1fr}
  .map-sidebar{position:absolute;z-index:10;height:100%}
}

/* --- 640px: phones --- */
@media(max-width:640px){
  html{-webkit-tap-highlight-color:transparent}
  .page{padding-bottom:calc(64px + env(safe-area-inset-bottom))}
  #mapPage.page{padding-bottom:0}
  body{overflow-x:clip}
  .container{padding:12px;overflow-x:clip;max-width:100%;width:100%}

  /* Header */
  .header{padding:0 14px}
  .hamburger{display:none!important}
  .bottom-nav{display:flex}
  .user-name{display:none}
  .btn-logout{padding:7px;min-width:34px;justify-content:center}
  .btn-label{display:none}

  /* Stats bar */
  .stats-bar{border-radius:var(--r)}
  .stat-card{padding:9px 12px}
  .stat-value{font-size:15px}

  /* Spotlight */
  .spotlight{border-radius:var(--r);flex-direction:column}
  .spotlight-info{padding:14px 16px}
  .spotlight-stats{gap:10px 20px}
  .spotlight-stat-val{font-size:14px}
  .spotlight-map{width:100%;height:160px;border-left:none;border-top:1px solid var(--border)}

  /* Toolbar */
  .toolbar{flex-wrap:wrap;gap:8px}
  .toolbar h2#activityTitle{width:100%;order:-1;font-size:12px}
  .toolbar-right{width:100%;gap:5px}
  .search-input{flex:1;min-width:0;width:auto}
  #syncBtn{padding:7px 10px}

  /* Filters */
  .filters-panel{padding:12px}
  .filters-row{gap:8px}
  .filter-group{min-width:calc(50% - 4px);flex:0 0 calc(50% - 4px)}

  /* Activity list */
  .activity-grid{border-radius:var(--r)}
  .activity-card{padding:10px 13px;gap:10px}
  .activity-icon{width:32px;height:32px;font-size:15px}
  .activity-info h3{font-size:13px;margin-bottom:2px}
  .activity-stats{display:none}
  .activity-stats-mobile{display:flex}
  .date-group-header{padding:5px 13px}

  /* Modal — bottom sheet */
  .modal-overlay{align-items:flex-end;padding:0;overflow-y:hidden}
  .modal{
    border-radius:var(--r-xl) var(--r-xl) 0 0;
    max-height:92dvh;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    width:100%;max-width:100%;margin:0;
    transform:translateY(50%);
  }
  .modal-overlay.modal-visible .modal{transform:translateY(0)}
  .modal-handle{display:block}
  .modal-close{top:10px;right:12px}
  .modal-content{padding:14px 14px max(18px,env(safe-area-inset-bottom))}
  .detail-stats{grid-template-columns:1fr 1fr}
  .detail-map{height:200px}

  /* Stats page */
  .stats-header{flex-direction:column;align-items:flex-start;gap:10px;margin-bottom:14px}
  .sport-tabs{
    flex-wrap:nowrap;overflow-x:auto;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
    padding-bottom:2px;
  }
  .sport-tabs::-webkit-scrollbar{display:none}
  .section-title{margin:16px 0 10px}
  .records-grid{grid-template-columns:1fr 1fr}
  .record-card,.effort-card,.avg-card,.goal-card{min-width:0}
  .kpi-row{
    flex-wrap:nowrap;overflow-x:auto;
    scrollbar-width:none;-webkit-overflow-scrolling:touch;
    gap:8px;padding-bottom:2px;
    width:100%;max-width:100%;
  }
  .kpi-row::-webkit-scrollbar{display:none}
  .kpi-card{flex-shrink:0;min-width:90px;padding:10px 12px}
  .kpi-val{font-size:20px}
  .best-efforts-showcase{grid-template-columns:1fr 1fr}
  .avg-grid{grid-template-columns:1fr 1fr}
  .goals-grid{grid-template-columns:1fr 1fr}
  .goals-section{padding:14px}
  .chart-canvas-wrap{height:190px;padding:14px;max-width:100%;overflow:hidden}
  .chart-canvas-wrap canvas{max-width:100%}
  .heatmap-row{padding:12px 14px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;max-width:100%}
  .heatmap-row::-webkit-scrollbar{display:none}
  .cal-heatmap-wrap{max-width:100%}
  .stats-bar{max-width:100%}
  .heat-col{flex-shrink:0}
  .sport-detail{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}
  .record-activity{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

  /* Map — FAB + drawer on mobile */
  #mapPage.page{
    height:calc(100dvh - var(--header-h) - 64px - env(safe-area-inset-bottom));
    min-height:0;
    overflow:hidden;
    padding:0;
  }
  .map-layout{
    position:relative;
    height:100%;
    flex-direction:row;
  }
  .map-container{position:absolute;inset:0}
  .leaflet-map{height:100%}
  .map-fab{display:flex}
  .map-sidebar{
    position:fixed;
    bottom:0;left:0;right:0;
    z-index:150;
    width:auto!important;
    height:82dvh;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    border-radius:20px 20px 0 0;
    border-right:none;border-bottom:none;
    border-top:1px solid var(--border);
    transform:translateY(110%);
    transition:transform .38s cubic-bezier(.32,.72,0,1);
  }
  .map-sidebar.drawer-open{transform:translateY(0)}
  .sidebar-toggle{
    position:sticky;
    top:0;z-index:2;
    right:auto;bottom:auto;transform:none;
    width:100%;height:52px;
    border-radius:20px 20px 0 0;
    border:none;border-bottom:1px solid var(--border);
    background:var(--bg1);
    box-shadow:none;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    padding:0;gap:4px;
    cursor:pointer;
  }
  .sidebar-toggle svg{display:none}
  .sidebar-toggle::before{
    content:'';
    display:block;
    width:36px;height:4px;
    background:var(--border-l);
    border-radius:2px;
  }
  .map-sidebar-toggle-label{
    font-size:11px;font-weight:600;
    color:var(--text2);letter-spacing:.01em;
  }

  /* HR Analysis stacked */
  .hr-analysis-grid{grid-template-columns:1fr}
  .hr-chart-wrap{height:180px}
  .hr-monthly-wrap{height:180px}
  .best-week-banner{flex-wrap:wrap;gap:10px}
  .best-week-stats{flex-direction:column;gap:4px}

  /* Profile */
  .profile-form-grid{grid-template-columns:1fr 1fr}
  .profile-id-card{padding:14px;flex-wrap:wrap;gap:12px}
  .profile-form{padding:14px}

  /* Login */
  .login-card h1{font-size:28px}
  .login-features{gap:18px}
}

/* ===== SKELETON LOADING ===== */
@keyframes skeleton-pulse{0%,100%{opacity:.6}50%{opacity:.3}}
.skeleton{background:var(--bg2);border-radius:var(--r-sm);animation:skeleton-pulse 1.4s ease-in-out infinite}
.skeleton-activity{display:flex;align-items:center;gap:12px;padding:12px 14px;border-bottom:1px solid var(--border)}
.skeleton-icon{width:36px;height:36px;border-radius:50%;flex-shrink:0}
.skeleton-body{flex:1;display:flex;flex-direction:column;gap:8px}
.skeleton-title{height:13px;width:60%}
.skeleton-meta{height:11px;width:80%}

/* ===== PULL-TO-REFRESH ===== */
.pull-refresh-indicator{
  display:flex;align-items:center;justify-content:center;
  height:0;overflow:hidden;
  color:var(--text2);font-size:12px;gap:6px;
  transition:height .2s ease;
}
.pull-refresh-indicator svg{animation:spin .8s linear infinite}

/* ===== ADDITIONAL MOBILE FIXES ===== */
@media(max-width:640px){
  /* Bigger touch targets */
  .btn-sm{min-height:40px}
  .period-btn{min-height:32px;padding:5px 10px}

  /* Scrollable rows: fade right edge to hint there's more */
  .sport-tabs{
    -webkit-mask-image:linear-gradient(to right,black 0,black calc(100% - 36px),transparent 100%);
    mask-image:linear-gradient(to right,black 0,black calc(100% - 36px),transparent 100%);
  }
  .kpi-row{
    -webkit-mask-image:linear-gradient(to right,black 0,black calc(100% - 36px),transparent 100%);
    mask-image:linear-gradient(to right,black 0,black calc(100% - 36px),transparent 100%);
  }
  .heatmap-row{
    -webkit-mask-image:linear-gradient(to right,black 0,black calc(100% - 40px),transparent 100%);
    mask-image:linear-gradient(to right,black 0,black calc(100% - 40px),transparent 100%);
  }

  /* Leaflet zoom: bigger touch targets */
  .leaflet-touch .leaflet-control-zoom a{width:38px;height:38px;line-height:38px;font-size:17px}

  /* Modal swipe — smooth reset after aborted swipe */
  .modal{transition:transform .35s cubic-bezier(.32,.72,0,1)}
  .modal.swiping{transition:none}
}

/* ===== VERY SMALL SCREENS (< 380px) ===== */
@media(max-width:380px){
  .goals-grid{grid-template-columns:1fr!important}
  .records-grid{grid-template-columns:1fr!important}
  .best-efforts-showcase{grid-template-columns:1fr!important}
  .avg-grid{grid-template-columns:1fr!important}
  .profile-form-grid{grid-template-columns:1fr!important}
}

/* ===== LANDSCAPE MOBILE ===== */
@media(max-width:640px) and (orientation:landscape){
  .bottom-nav{height:44px;padding-bottom:env(safe-area-inset-bottom)}
  .bottom-nav-item{gap:2px}
  .bottom-nav-item span{font-size:9px}
  .page{padding-bottom:calc(44px + env(safe-area-inset-bottom))}
  #mapPage.page{
    padding:0;
    min-height:0;
    height:calc(100dvh - var(--header-h) - 44px - env(safe-area-inset-bottom));
  }
  .map-layout{height:100%}
  .modal{max-height:96dvh}
  .header{padding:0 12px}
}
