/* styles.css — Astraverse Redesign v4 */
*{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#0c0a14;
  --bg-card:rgba(18,16,28,.55);
  --bg-secondary:rgba(18,16,28,.6);
  --text:#dce2ea;
  --text-primary:#dce2ea;
  --text-secondary:#7a8799;
  --text-tertiary:#3d4b5e;
  --dim:#7a8799;
  --faint:#3d4b5e;
  --accent:#d4956a;
  --accent-dim:rgba(212,149,106,.12);
  --accent-border:rgba(212,149,106,.2);
  --blue:#6b7fa8;
  --blue-dim:rgba(107,127,168,.06);
  --border-color:rgba(107,127,168,.12);
  --success:#6ec8d5;
  --warning:#d4956a;
  --danger:#e06c75;
  --purple:#a078c8;
  --purple-dim:rgba(160,120,200,.08);
  --purple-border:rgba(160,120,200,.18);
  --red:#c0635a;
  --red-dim:rgba(192,99,90,.08);
  --red-border:rgba(192,99,90,.18);
  --nav-h:62px;
}

.light-theme{
  --bg:#f0ede8;
  --bg-card:rgba(255,255,255,.85);
  --bg-secondary:rgba(255,255,255,.9);
  --text:#1a1612;
  --text-primary:#1a1612;
  --text-secondary:#5a5248;
  --text-tertiary:#a09890;
  --dim:#5a5248;
  --faint:#a09890;
  --accent:#b8743a;
  --accent-dim:rgba(184,116,58,.12);
  --accent-border:rgba(184,116,58,.25);
  --blue:#4a5e8a;
  --blue-dim:rgba(74,94,138,.06);
  --border-color:rgba(74,94,138,.15);
  --success:#3ba5b2;
  --warning:#b8743a;
  --danger:#c05050;
  --purple:#825a8c;
  --purple-dim:rgba(130,90,140,.08);
  --purple-border:rgba(130,90,140,.25);
  --red:#a0504a;
  --red-dim:rgba(160,80,74,.08);
  --red-border:rgba(160,80,74,.2);
}

html{scroll-behavior:smooth}

body{
  font-family:'Sora',sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  transition:background .3s,color .3s;
}

body::before{
  content:'';position:fixed;inset:0;opacity:.015;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='4' height='4' fill='%23fff' opacity='.4'/%3E%3Crect x='0' y='0' width='1' height='1' fill='%23000' opacity='.3'/%3E%3Crect x='2' y='2' width='1' height='1' fill='%23000' opacity='.2'/%3E%3C/svg%3E");
  pointer-events:none;z-index:9999;
}
.light-theme::before{opacity:.008}

.constellation-bg,.constellations{display:none!important}
.star-glow{display:none!important}

.icon-moon{display:none}
.light-theme .icon-sun{display:none!important}
.light-theme .icon-moon{display:inline!important}

.nav-brand .logo-dark{display:block !important}
.nav-brand .logo-light{display:none !important}

.light-theme .nav-brand .logo-dark{display:none !important}
.light-theme .nav-brand .logo-light{display:block !important}

/* ── NAV ── */
.top-nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:grid;grid-template-columns:auto 1fr auto;
  align-items:center;
  padding:0 clamp(20px,3vw,48px);height:var(--nav-h);
  background:rgba(12,10,20,.6);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);
  border-bottom:1px solid rgba(255,255,255,.03);
  transition:background .3s;
}
.light-theme .top-nav{background:rgba(240,237,232,.95);border-bottom-color:rgba(0,0,0,.08)}
.nav-brand{display:flex;align-items:center;gap:8px;text-decoration:none;background:none}
.nav-brand img{display:block;height:28px;width:148px}
.nav-brand svg{display:block;flex-shrink:0}
.nav-center{display:flex;gap:24px;align-items:center;justify-content:center}
.nav-link{
  font-size:10px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;
  color:var(--faint);text-decoration:none;padding-bottom:4px;position:relative;transition:color .25s;
}
.nav-link:hover{color:var(--text)}
.nav-link.active{color:var(--text)}
.nav-link.active::after{
  content:'';position:absolute;bottom:0;left:0;width:100%;height:1.5px;
  background:linear-gradient(90deg,var(--accent),rgba(212,149,106,.05));border-radius:1px;
}
.upload-button-nav{
  background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  font-family:'Sora',sans-serif;font-size:10px;font-weight:600;letter-spacing:1.8px;
  text-transform:uppercase;color:var(--accent);padding:4px 0;position:relative;transition:color .25s;
}
.upload-button-nav::after{
  content:'';position:absolute;bottom:0;left:0;width:100%;height:1.5px;
  background:linear-gradient(90deg,var(--accent),rgba(212,149,106,.05));border-radius:1px;
}
.upload-button-nav:hover{color:var(--text)}
.nav-icon-btn{
  background:none;border:none;cursor:pointer;color:var(--dim);
  font-family:'Sora',sans-serif;font-size:11px;font-weight:600;letter-spacing:1px;
  transition:color .25s;padding:0 4px;display:flex;align-items:center;
}
.nav-icon-btn:hover{color:var(--text)}
.nav-right{display:flex;gap:14px;align-items:center;height:100%}

.user-profile{
  display:flex;align-items:center;gap:8px;cursor:pointer;height:100%;
  padding:0 clamp(16px,2vw,28px);border-left:1px solid rgba(255,255,255,.04);position:relative;
}
.user-name{font-size:11px;font-weight:500;color:var(--dim);letter-spacing:.3px}
.user-avatar{
  width:28px;height:28px;border-radius:50%;background:rgba(212,149,106,.15);
  border:1px solid rgba(212,149,106,.25);display:flex;align-items:center;justify-content:center;
  font-size:10px;font-weight:600;color:var(--accent);
}
.user-dropdown{
  position:absolute;top:calc(100% + 8px);right:0;
  background:rgba(18,16,28,.97);backdrop-filter:blur(40px);
  border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:8px 0;
  min-width:190px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .2s;z-index:400;
}
.user-dropdown.active{opacity:1;visibility:visible;transform:translateY(0)}
.user-dropdown-header{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.05)}
.user-dropdown-name{font-size:13px;font-weight:500;color:var(--text);margin-bottom:2px}
.user-dropdown-email{font-size:11px;color:var(--dim)}
.user-dropdown-item{
  display:flex;align-items:center;gap:10px;padding:10px 16px;
  color:var(--dim);text-decoration:none;font-size:12px;font-weight:500;transition:color .2s;cursor:pointer;
}
.user-dropdown-item:hover{color:var(--text)}
.user-dropdown-item svg{width:13px;height:13px;stroke:currentColor;fill:none;flex-shrink:0}
.user-dropdown-divider{height:1px;background:rgba(255,255,255,.04)}
.light-theme .user-dropdown-divider{background:rgba(0,0,0,.06)}
.light-theme .user-dropdown{background:rgba(244,241,236,.99);border-color:rgba(0,0,0,.1)}

/* ── LAYOUT ── */
.main-wrapper{
  position:relative;z-index:1;max-width:1200px;margin:0 auto;
  padding:calc(var(--nav-h) + 48px) clamp(24px,4vw,56px) 80px;
}

/* ── SECTION DIVIDER ── */
.section-divider{display:flex;align-items:center;gap:16px;margin:56px 0 0}
.section-divider-line{flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(107,127,168,.12) 20%,rgba(107,127,168,.12) 80%,transparent)}
.section-divider-label{
  font-size:9px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--faint);white-space:nowrap;
}

/* ── SECTION HEADERS ── */
.section-header{margin:32px 0 24px}
.section-title{font-size:26px;font-weight:300;letter-spacing:-.5px;color:var(--text);margin-bottom:6px}
.section-title em{font-style:normal;color:var(--accent)}
.section-subtitle{
  font-size:13px;color:var(--dim);cursor:pointer;display:inline-flex;
  align-items:center;gap:6px;line-height:1.5;
}
.info-icon{
  width:14px;height:14px;border-radius:50%;border:1px solid var(--faint);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:9px;color:var(--faint);flex-shrink:0;
}
.section-info-expand{overflow:hidden;max-height:0;transition:max-height .35s ease}
.section-info-expand.open{max-height:300px}
.section-info-box{
  margin-top:10px;padding:14px 16px;
  background:rgba(107,127,168,.04);border:1px solid rgba(107,127,168,.1);
  border-radius:10px;font-size:12px;color:var(--dim);line-height:1.7;
}
.light-theme .section-info-box{background:rgba(0,0,0,.03)}

/* ── PAGE HEADERS ── */
.page-header{margin-bottom:40px}
.page-title{
  font-size:clamp(32px,5vw,48px);font-weight:300;line-height:1.05;
  letter-spacing:-2px;margin-bottom:16px;color:var(--text);
}
.page-title em{font-style:normal;color:var(--accent)}
.page-subtitle{font-size:15px;color:var(--dim);margin-bottom:32px;line-height:1.7}

/* ── HERO SECTION ── */
.hero-section{
  padding:40px;position:relative;
  background:rgba(18,16,28,.45);backdrop-filter:blur(20px);
  border:1px solid rgba(107,127,168,.07);border-radius:20px;overflow:hidden;
}
.hero-section::before{
  content:'';position:absolute;top:0;left:0;width:3px;height:100%;
  background:linear-gradient(180deg,var(--accent),rgba(212,149,106,.1));border-radius:20px 0 0 20px;
}
.light-theme .hero-section{background:rgba(255,255,255,.9);border-color:rgba(0,0,0,.09)}

.hero-status{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.hero-status-line{width:24px;height:1.5px;background:linear-gradient(90deg,var(--accent),rgba(212,149,106,.1))}
.hero-status-text{font-size:10px;font-weight:600;letter-spacing:2.2px;text-transform:uppercase;color:var(--accent)}
.hero-title{
  font-size:clamp(48px,6vw,72px);font-weight:300;line-height:1;
  letter-spacing:-2.5px;color:var(--text);margin-bottom:12px;
}
.hero-subtitle{font-size:15px;line-height:1.65;color:var(--dim);max-width:600px;margin-bottom:32px}

/* ── QUICK STATS ── */
.quick-stats{display:flex;gap:40px;padding-top:24px;margin-bottom:8px;border-top:1px solid rgba(107,127,168,.08)}
.quick-stat-val{font-size:36px;font-weight:300;color:var(--accent);letter-spacing:-1.5px;line-height:1;margin-bottom:6px}
.quick-stat-label{font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--faint)}

/* ── CARDS ── */
.stat-card,.impact-stat-card,.chart-card,.mission-card,.challenge-card{
  background:var(--bg-card);backdrop-filter:blur(20px);
  border:1px solid var(--border-color);border-radius:16px;
  padding:28px;transition:all .3s;
}
.light-theme .stat-card,.light-theme .impact-stat-card,.light-theme .chart-card,
.light-theme .mission-card,.light-theme .challenge-card{
  background:rgba(255,255,255,.92);border-color:rgba(0,0,0,.09);
}
.stat-card:hover,.impact-stat-card:hover,.chart-card:hover{border-color:rgba(212,149,106,.3)}

.stats-grid,.impact-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-bottom:40px}
.stat-label,.impact-label{font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:1.8px;margin-bottom:12px;font-weight:600}
.stat-value,.impact-value{font-size:36px;font-weight:300;color:var(--accent);margin-bottom:8px;line-height:1;letter-spacing:-2px}
.stat-value.blue,.impact-value.blue{color:var(--blue)}
.stat-change,.impact-change{font-size:11px;font-weight:600;display:flex;align-items:center;gap:6px;letter-spacing:.3px}
.stat-change.positive,.impact-change{color:var(--success)}
.stat-change.negative{color:var(--danger)}

.impact-stat-card{position:relative;overflow:hidden}
.impact-stat-card::before{content:'';position:absolute;top:0;left:0;width:2px;height:100%;background:linear-gradient(180deg,var(--accent),rgba(212,149,106,.2))}
.impact-icon-wrapper{width:40px;height:40px;background:var(--accent-dim);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}

.charts-grid,.charts-section{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;margin-bottom:40px}
.chart-card.full-width{grid-column:1 / -1}
.chart-header{margin-bottom:24px}
.chart-title{font-size:15px;font-weight:500;color:var(--text);margin-bottom:6px;letter-spacing:-.1px}
.chart-subtitle{font-size:12px;color:var(--dim);line-height:1.5}
.chart-container{position:relative;height:300px;margin-bottom:20px}
.chart-empty-state{display:flex;align-items:center;justify-content:center;height:100%;color:var(--faint);font-size:13px;font-style:italic}

/* ── MISSIONS ── */
.missions-section,.challenges-section,.completed-missions{margin-bottom:40px}
.missions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.mission-card{cursor:pointer;position:relative;overflow:hidden}
.mission-card::before{
  content:'';position:absolute;top:0;left:0;width:2px;height:100%;
  background:linear-gradient(180deg,var(--accent),rgba(212,149,106,.2));
  transform:scaleY(0);transform-origin:top;transition:transform .3s;
}
.mission-card:hover::before{transform:scaleY(1)}
.mission-card:hover{border-color:rgba(212,149,106,.18);background:rgba(212,149,106,.03)}

.mission-type-badge{
  display:inline-block;padding:3px 10px;
  background:var(--purple-dim);border:1px solid var(--purple-border);
  border-radius:5px;font-size:9px;color:var(--purple);
  font-weight:600;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:16px;
}
.mission-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
.mission-icon{
  width:40px;height:40px;background:rgba(212,149,106,.08);border:1px solid rgba(212,149,106,.15);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
}
.mission-icon svg{width:20px;height:20px;stroke:var(--accent);fill:none;stroke-width:1.5}
.mission-icon svg path,.mission-icon svg rect,.mission-icon svg circle,.mission-icon svg polyline,.mission-icon svg line{
  fill:none;stroke:inherit;stroke-width:inherit;
}
.mission-points{font-size:13px;font-weight:600;color:var(--accent)}
.mission-title{font-size:16px;font-weight:500;color:var(--text);margin-bottom:8px;letter-spacing:-.2px}
.mission-description{font-size:13px;color:var(--dim);line-height:1.6;margin-bottom:16px}
.mission-footer{
  display:flex;justify-content:space-between;align-items:center;font-size:12px;
  padding-top:14px;border-top:1px solid rgba(107,127,168,.07);
}
.mission-impact{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--blue)}
.mission-value{font-size:12px;font-weight:500;color:var(--accent)}

/* ── CHALLENGES ── */
.challenges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.challenge-card{cursor:pointer;position:relative;overflow:hidden}
.challenge-card::before{
  content:'';position:absolute;top:0;left:0;width:2px;height:100%;
  background:linear-gradient(180deg,var(--blue),rgba(107,127,168,.2));
  transform:scaleY(0);transform-origin:top;transition:transform .25s;
}
.challenge-card:hover::before{transform:scaleY(1)}
.challenge-card:hover{border-color:rgba(107,127,168,.2);background:rgba(107,127,168,.04)}

.challenge-type-badge{
  display:inline-block;padding:3px 10px;
  background:var(--red-dim);border:1px solid var(--red-border);
  border-radius:5px;font-size:9px;color:var(--red);
  font-weight:600;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:12px;
}
.challenge-title{font-size:14px;font-weight:500;color:var(--text);margin-bottom:8px;line-height:1.4;letter-spacing:-.1px}
.challenge-description{font-size:12px;color:var(--dim);line-height:1.55;margin-bottom:14px}
.challenge-meta{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid rgba(107,127,168,.07)}
.challenge-points{font-size:12px;font-weight:600;color:var(--accent)}
.challenge-deadline{font-size:11px;color:var(--faint)}

/* Challenge detail modal */
.challenge-detail-badge{
  display:inline-block;padding:3px 10px;
  background:var(--red-dim);border:1px solid var(--red-border);
  border-radius:5px;font-size:9px;color:var(--red);
  font-weight:600;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:14px;
}
.challenge-detail-title{font-size:21px;font-weight:300;letter-spacing:-.5px;color:var(--text);margin-bottom:8px}
.challenge-detail-points{font-size:12px;font-weight:600;color:var(--accent);background:var(--accent-dim);border-radius:6px;padding:3px 10px;display:inline-block;margin-bottom:20px}
.challenge-detail-section{padding:14px 0;border-top:1px solid rgba(107,127,168,.08)}
.challenge-detail-label{font-size:9px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.challenge-detail-text{font-size:13px;color:var(--dim);line-height:1.7;margin:0}

.impact-metrics{display:flex;gap:32px}
.impact-metric-value{font-size:22px;font-weight:300;color:var(--accent);letter-spacing:-1px;line-height:1;margin-bottom:4px}
.impact-metric-label{font-size:9px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--faint)}

.related-mission-card{
  padding:14px 16px;border:1px solid rgba(107,127,168,.1);border-radius:10px;
  margin-top:8px;display:flex;gap:12px;align-items:flex-start;
}
.related-mission-icon{
  width:32px;height:32px;border-radius:8px;background:rgba(107,127,168,.08);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.related-mission-icon svg{width:16px;height:16px;stroke:var(--blue);fill:none;stroke-width:1.5}
.related-mission-info h4{font-size:13px;font-weight:500;color:var(--text);margin-bottom:3px}
.related-mission-info p{font-size:11px;color:var(--dim);margin:0}
.light-theme .related-mission-card{border-color:rgba(0,0,0,.08)}

/* ── JOURNEY / PROGRESS ── */
.journey-panel{
  background:rgba(18,16,28,.3);
}

.light-theme .journey-panel{
  background:#ffffff !important;
}
.journey-grid{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.journey-label{font-size:9px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--faint);margin-bottom:12px}
.altitude-display{font-size:clamp(48px,6vw,56px);font-weight:300;color:var(--accent);letter-spacing:-2px;line-height:1;margin-bottom:10px}

.progress-bar{height:3px;background:rgba(107,127,168,.12);border-radius:2px;overflow:hidden;margin-bottom:8px}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#a078c8);border-radius:2px;transition:width .6s ease}
.milestone-text{font-size:12px;color:var(--dim)}

.phase-row,.phase-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}
.phase-badge{
  padding:5px 12px;border:1px solid rgba(107,127,168,.12);border-radius:20px;
  font-size:10px;color:var(--faint);font-weight:500;letter-spacing:.5px;
  display:flex;align-items:center;gap:6px;
}
.phase-badge svg,.phase-badge-icon{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2;flex-shrink:0}
.phase-badge.completed,.phase-badge.done{border-color:rgba(107,127,168,.2);color:var(--blue)}
.phase-badge.active{border-color:rgba(212,149,106,.3);color:var(--accent);background:rgba(212,149,106,.06)}
.phase-badge.locked{opacity:.3}

/* Phase badge distinct done colors */
.phase-badge.completed[data-phase="liftoff"],.phase-badge.done[data-phase="liftoff"]{
  border-color:rgba(184,148,90,.25);color:#b8945a;background:rgba(184,148,90,.06);
}
.phase-badge.completed[data-phase="ascent"],.phase-badge.done[data-phase="ascent"]{
  border-color:rgba(167,127,168,.25);color:#a77fa8;background:rgba(167,127,168,.06);
}
.light-theme .phase-badge.completed[data-phase="liftoff"],.light-theme .phase-badge.done[data-phase="liftoff"]{
  border-color:rgba(160,110,40,.3);color:#a06e28;background:rgba(160,110,40,.06);
}
.light-theme .phase-badge.completed[data-phase="ascent"],.light-theme .phase-badge.done[data-phase="ascent"]{
  border-color:rgba(130,90,140,.3);color:#825a8c;background:rgba(130,90,140,.06);
}

.orbit-visual{width:120px;height:120px;position:relative;flex-shrink:0}
.orbit-ring{position:absolute;border:1px solid rgba(107,127,168,.15);border-radius:50%}
.orbit-ring-1{inset:0}
.orbit-ring-2{inset:15px;border-color:rgba(212,149,106,.12)}
.orbit-center{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:40px;height:40px;background:rgba(212,149,106,.1);
  border:1px solid rgba(212,149,106,.2);border-radius:50%;
  display:flex;align-items:center;justify-content:center;
}
.orbit-center svg{width:22px;height:22px;stroke:var(--accent);fill:none;stroke-width:1.5}

/* ── KPI CARDS ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-bottom:40px}
.kpi-card{background:var(--bg-card);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:16px;padding:24px;transition:all .3s}
.kpi-card:hover{border-color:rgba(212,149,106,.3)}
.kpi-label{font-size:10px;color:var(--faint);text-transform:uppercase;letter-spacing:1.8px;font-weight:600;margin-bottom:8px}
.kpi-value{font-size:28px;font-weight:300;color:var(--accent);letter-spacing:-1px;line-height:1;margin-bottom:4px}
.kpi-note{font-size:11px;color:var(--dim)}

/* ── ACCESS LIST ── */
.access-list{margin-bottom:72px}
.access-row{
  display:flex;align-items:center;gap:24px;padding:22px 24px;
  border:1px solid rgba(107,127,168,.07);border-radius:14px;
  text-decoration:none;position:relative;transition:all .25s;cursor:pointer;
  margin-bottom:8px;overflow:hidden;
}
.access-row:last-child{margin-bottom:0}
.access-row:hover{border-color:rgba(212,149,106,.2)}
.access-row:hover .access-row-title{color:var(--accent)}
.access-row:hover .access-row-arrow{color:var(--accent);transform:translateX(4px)}
.access-row::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(180deg,var(--accent),rgba(212,149,106,.2));
  transform:scaleY(0);transform-origin:top;transition:transform .3s cubic-bezier(.4,0,.2,1);
  border-radius:14px 0 0 14px;
}
.access-row:hover::before{transform:scaleY(1)}
.access-row-icon{width:32px;height:32px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.access-row-icon svg{width:18px;height:18px;stroke:var(--faint);fill:none;stroke-width:1.5;transition:stroke .25s}
.access-row:hover .access-row-icon svg{stroke:var(--accent)}
.access-row-body{flex:1;min-width:0}
.access-row-title{font-size:15px;font-weight:500;color:var(--text);margin-bottom:3px;letter-spacing:-.1px;transition:color .25s}
.access-row-desc{font-size:12px;color:var(--dim);line-height:1.5}
.access-row-meta{display:flex;align-items:center;gap:16px;flex-shrink:0}
.access-meta-item{text-align:right}
.access-meta-value{font-size:18px;font-weight:300;color:var(--accent);letter-spacing:-1px;line-height:1}
.access-meta-value.blue{color:var(--blue)}
.access-meta-label{font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-top:2px}
.access-row-arrow{font-size:16px;color:var(--faint);transition:all .25s;flex-shrink:0;margin-left:8px}
.light-theme .access-row{background:rgba(255,255,255,.92);border-color:rgba(0,0,0,.09)}
.light-theme .access-row:hover{border-color:rgba(212,149,106,.3)}

/* ── ACTIVITY ── */
.activity-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.activity-header-label{font-size:9px;font-weight:600;letter-spacing:2.2px;text-transform:uppercase;color:var(--faint)}
.activity-see-all{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--dim);text-decoration:none;transition:color .2s}
.activity-see-all:hover{color:var(--accent)}
.activity-list{display:flex;flex-direction:column;gap:0}
.activity-item{display:flex;align-items:center;gap:16px;padding:16px 0;border-bottom:1px solid rgba(107,127,168,.06);transition:opacity .2s}
.activity-item:first-child{border-top:1px solid rgba(107,127,168,.06)}
.activity-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.activity-dot.check{background:var(--success);box-shadow:0 0 6px rgba(110,200,213,.4)}
.activity-dot.star{background:var(--accent);box-shadow:0 0 6px rgba(212,149,106,.4)}
.activity-dot.milestone{background:var(--blue);box-shadow:0 0 6px rgba(107,127,168,.4)}
.activity-content{flex:1;min-width:0}
.activity-title{font-size:13px;font-weight:400;color:var(--text);margin-bottom:2px}
.activity-meta{font-size:11px;color:var(--faint)}
.activity-pts{font-size:11px;font-weight:600;color:var(--accent);white-space:nowrap;letter-spacing:.3px}

/* ── MULTIPLIERS ── */
.multipliers-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1px;
  background:rgba(107,127,168,.07);border:1px solid rgba(107,127,168,.07);border-radius:14px;overflow:hidden;
}
.light-theme .multipliers-grid{background:rgba(0,0,0,.05)}
.multiplier-card{background:var(--bg);padding:20px;transition:background .2s}
.light-theme .multiplier-card{background:rgba(255,255,255,.9)}
.multiplier-card:hover{background:rgba(18,16,28,.8)}
.light-theme .multiplier-card:hover{background:rgba(255,255,255,1)}
.multiplier-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px}
.multiplier-value{font-size:26px;font-weight:300;letter-spacing:-1px;color:var(--faint)}
.multiplier-card.active .multiplier-value{color:var(--accent)}
.multiplier-status{font-size:9px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.multiplier-card.active .multiplier-status{color:var(--accent)}
.multiplier-name{font-size:13px;font-weight:500;color:var(--dim);margin-bottom:4px}
.multiplier-card.active .multiplier-name{color:var(--text)}
.multiplier-criteria{font-size:11px;color:var(--faint);line-height:1.5;margin-bottom:8px}
.multiplier-hint{font-size:11px;color:var(--dim);margin-bottom:14px}
.multiplier-card.active .multiplier-hint{color:var(--accent)}
.multiplier-btn{
  background:none;border:1px solid rgba(107,127,168,.15);border-radius:6px;
  padding:5px 12px;font-family:'Sora',sans-serif;font-size:9px;font-weight:600;
  letter-spacing:1px;text-transform:uppercase;color:var(--faint);cursor:default;transition:all .2s;
}
.multiplier-btn.coming-soon{opacity:.6;cursor:not-allowed}

/* ── MODALS ── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px);
  z-index:500;display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
}
.modal-overlay.active{opacity:1;visibility:visible}
.modal-content{
  background:rgba(18,16,28,.97);backdrop-filter:blur(40px);
  border:1px solid rgba(255,255,255,.06);border-radius:16px;
  padding:32px;max-width:500px;width:90%;max-height:85vh;overflow-y:auto;position:relative;
  scrollbar-width:none;
}
.modal-content::-webkit-scrollbar{display:none}
.light-theme .modal-content{background:rgba(244,241,236,.99);border-color:rgba(0,0,0,.1);box-shadow:0 20px 60px rgba(0,0,0,.15)}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:var(--dim);transition:color .2s}
.modal-close:hover{color:var(--text)}

/* ── FORMS ── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:10px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.form-input,.form-select,.form-textarea{
  width:100%;padding:9px 13px;background:rgba(18,16,28,.6);
  border:1px solid rgba(107,127,168,.15);border-radius:8px;
  color:var(--text);font-size:13px;font-family:'Sora',sans-serif;transition:border-color .2s;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:rgba(212,149,106,.3)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--faint);font-size:12px}
.form-select option{background:#0c0a14}
.form-textarea{resize:vertical;min-height:80px}
.light-theme .form-input,.light-theme .form-select,.light-theme .form-textarea{background:rgba(255,255,255,.8);border-color:rgba(0,0,0,.1);color:var(--text)}
.light-theme .form-select option{background:#f0ede8}

.file-upload-area{border:1px dashed rgba(107,127,168,.2);border-radius:8px;padding:20px;text-align:center;cursor:pointer;transition:border-color .2s}
.file-upload-area:hover{border-color:rgba(212,149,106,.3)}
.file-upload-area p{font-size:12px;color:var(--dim);margin-top:8px}

.submit-button{
  width:100%;padding:11px;background:none;border:1px solid rgba(212,149,106,.3);
  border-radius:8px;color:var(--accent);font-family:'Sora',sans-serif;font-size:10px;
  font-weight:600;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:all .2s;margin-top:4px;
}
.submit-button:hover{background:rgba(212,149,106,.08)}

/* ── EMPTY STATE ── */
.empty-state{padding:20px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--faint);font-size:13px;text-align:center}

/* ── MISSIONS LIST (impact page) ── */
.missions-list{display:flex;flex-direction:column;gap:16px}
.mission-impact-item{display:flex;align-items:center;gap:20px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;border-left:2px solid var(--accent)}
.mission-icon-large{width:44px;height:44px;background:var(--accent-dim);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mission-impact-content{flex:1}
.mission-impact-title{font-size:15px;font-weight:500;color:var(--text);margin-bottom:6px;letter-spacing:-.1px}
.mission-impact-description{font-size:12px;color:var(--dim);line-height:1.6}
.mission-impact-metrics{display:flex;gap:12px;margin-top:10px;flex-wrap:wrap}
.impact-metric-tag{padding:4px 10px;background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:6px;font-size:11px;color:var(--accent);font-weight:600;letter-spacing:.3px}
.mission-date{font-size:11px;color:var(--faint);font-weight:500;white-space:nowrap;letter-spacing:.3px}

/* ── FILTERS ── */
.filters-bar{display:flex;gap:12px;align-items:center;margin-bottom:28px;flex-wrap:wrap}
.filter-select{padding:8px 14px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;color:var(--text);font-size:12px;font-weight:500;cursor:pointer;font-family:'Sora',sans-serif;transition:border-color .2s}
.filter-select:focus{outline:none;border-color:var(--accent)}

/* ── FOOTER ── */
footer{padding:40px clamp(24px,4vw,56px);text-align:center;position:relative;z-index:1}
footer p{font-size:12px;color:var(--faint);letter-spacing:.3px}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .stats-grid,.impact-stats-grid{grid-template-columns:repeat(2,1fr)}
  .charts-grid,.charts-section{grid-template-columns:1fr}
  .missions-grid{grid-template-columns:1fr}
  .challenges-grid{grid-template-columns:1fr}
  .journey-grid{grid-template-columns:1fr}
  .orbit-visual{display:none}
}
@media(max-width:760px){
  .main-wrapper{padding:calc(var(--nav-h) + 40px) 16px 60px}
  .page-title{font-size:32px}
  .hero-title{font-size:40px}
  .altitude-display{font-size:40px}
  .quick-stats{flex-direction:column;gap:16px}
  .hero-section{padding:28px}
  .multipliers-grid{grid-template-columns:1fr}
}
@media(max-width:640px){
  .nav-center{display:none}
  .access-row-meta{display:none}
  .stats-grid,.impact-stats-grid{grid-template-columns:1fr}
  .mission-impact-item{flex-direction:column;align-items:flex-start}
}

/* ════════════════════════════════════════════════════════════════════════════
   PHASE 5–7 ADDITIONS — Mission Accept/Decline, Hypothesis details, Outcomes
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Mission card status banner (visible on accepted / verified missions) ── */
.mission-status-banner{
  margin-top:14px;padding:8px 12px;border-radius:8px;
  font-size:11px;font-weight:600;letter-spacing:.4px;
  text-align:center;border:1px solid var(--border-color);
}
.mission-status-banner.mission-status-accepted,
.mission-status-banner.mission-status-in_progress{
  color:var(--blue);background:var(--blue-dim);border-color:rgba(107,127,168,.18);
}
.mission-status-banner.mission-status-declined{
  color:var(--faint);background:rgba(107,127,168,.06);border-color:rgba(107,127,168,.12);
}
.mission-status-banner.mission-status-verified_success{
  color:var(--success);background:rgba(110,200,213,.08);border-color:rgba(110,200,213,.22);
}
.mission-status-banner.mission-status-verified_partial{
  color:var(--accent);background:var(--accent-dim);border-color:var(--accent-border);
}
.mission-status-banner.mission-status-verified_failed{
  color:var(--danger);background:rgba(224,108,117,.06);border-color:rgba(224,108,117,.18);
}
.mission-status-banner.mission-status-verified_inconclusive{
  color:var(--faint);background:rgba(107,127,168,.05);border-color:rgba(107,127,168,.12);
}

/* Verified-success state: thicker accent bar */
.mission-card-verified_success::before{
  transform:scaleY(1) !important;
  background:linear-gradient(180deg,var(--success),rgba(110,200,213,.2)) !important;
}
.mission-card-verified_failed::before{
  transform:scaleY(1) !important;
  background:linear-gradient(180deg,var(--danger),rgba(224,108,117,.2)) !important;
}

/* ── Modal: Hypothesis grid ── */
.hypothesis-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:8px;
  padding:14px;background:rgba(212,149,106,.04);border-radius:10px;
  border:1px solid var(--accent-border);
}
.hypothesis-item{display:flex;flex-direction:column;gap:4px}
.hypothesis-key{
  font-size:9px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;
  color:var(--faint);
}
.hypothesis-val{
  font-size:14px;font-weight:500;color:var(--text);font-feature-settings:'tnum' 1;
}
.hypothesis-note{
  font-size:11px;color:var(--dim);line-height:1.5;margin-top:10px;font-style:italic;
}

/* ── Modal: Intervention steps list ── */
.intervention-steps{
  list-style:none;counter-reset:step;padding:0;margin:8px 0 0 0;
}
.intervention-steps li{
  position:relative;padding:10px 12px 10px 38px;font-size:13px;color:var(--dim);
  line-height:1.6;border-bottom:1px solid rgba(107,127,168,.06);
  counter-increment:step;
}
.intervention-steps li:last-child{border-bottom:none}
.intervention-steps li::before{
  content:counter(step);
  position:absolute;left:8px;top:10px;
  width:22px;height:22px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent-dim);color:var(--accent);
  font-size:10px;font-weight:600;font-family:'Sora',sans-serif;
  border:1px solid var(--accent-border);
}

/* ── Modal: Mission action row + decline picker ── */
.mission-modal-actions{
  display:flex;gap:10px;margin-top:18px;padding-top:18px;
  border-top:1px solid rgba(107,127,168,.08);
}
.btn-mission-accept,.btn-mission-decline{
  flex:1;padding:12px 18px;border-radius:10px;font-family:'Sora',sans-serif;
  font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;
}
.btn-mission-accept{
  border:none;background:linear-gradient(135deg,var(--accent),var(--blue));
  color:#0c0a14;letter-spacing:.2px;
}
.light-theme .btn-mission-accept{color:#fff}
.btn-mission-accept:hover:not(:disabled){filter:brightness(1.08)}
.btn-mission-accept:disabled{opacity:.6;cursor:not-allowed}
.btn-mission-decline{
  border:1px solid var(--border-color);background:none;color:var(--dim);
}
.btn-mission-decline:hover:not(:disabled){color:var(--text);border-color:rgba(107,127,168,.25)}
.btn-mission-decline:disabled{opacity:.6;cursor:not-allowed}

.mission-decline-picker{margin-top:14px;padding-top:14px;border-top:1px solid rgba(107,127,168,.08)}
.mission-decline-prompt{font-size:12px;color:var(--dim);margin-bottom:10px;line-height:1.5}
.decline-reason-grid{display:flex;flex-wrap:wrap;gap:6px}
.btn-decline-reason{
  padding:7px 12px;border-radius:8px;border:1px solid var(--border-color);background:none;
  color:var(--dim);font-family:'Sora',sans-serif;font-size:11px;font-weight:500;cursor:pointer;
  transition:all .15s;
}
.btn-decline-reason:hover:not(:disabled){
  color:var(--accent);border-color:var(--accent-border);background:var(--accent-dim);
}
.btn-decline-reason:disabled{opacity:.6;cursor:not-allowed}

/* Modal status banner (above all detail sections) */
.mission-modal-status-banner{
  margin-bottom:18px;padding:10px 14px;border-radius:8px;
  font-size:12px;font-weight:600;letter-spacing:.3px;text-align:center;
  border:1px solid var(--border-color);
}

/* ════════════════════════════════════════════════════════════════════════════
   OUTCOMES SECTION (rewards page) — Phase 6 verifier results feed
   ════════════════════════════════════════════════════════════════════════════ */
.outcomes-section{margin:0 0 32px 0}
.outcomes-summary{
  display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:24px;
}
.outcomes-stat{
  background:var(--bg-card);border:1px solid var(--border-color);
  border-radius:12px;padding:18px 16px;text-align:center;
  display:flex;flex-direction:column;gap:4px;
}
.light-theme .outcomes-stat{background:rgba(255,255,255,.92);border-color:rgba(0,0,0,.09)}
.outcomes-stat-num{font-size:28px;font-weight:300;letter-spacing:-1px;color:var(--text);line-height:1}
.outcomes-stat-label{
  font-size:9px;font-weight:600;letter-spacing:1.6px;text-transform:uppercase;color:var(--faint);
}
.outcomes-stat-ok .outcomes-stat-num{color:var(--success)}
.outcomes-stat-warn .outcomes-stat-num{color:var(--accent)}
.outcomes-stat-err .outcomes-stat-num{color:var(--danger)}
.outcomes-stat-muted .outcomes-stat-num{color:var(--faint)}
.outcomes-stat-bonus .outcomes-stat-num{color:var(--blue)}

.outcomes-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.outcome-item{
  display:flex;align-items:center;gap:14px;padding:14px 16px;
  background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;
}
.light-theme .outcome-item{background:rgba(255,255,255,.92);border-color:rgba(0,0,0,.09)}
.outcome-item.outcome-status-ok{border-left:3px solid var(--success)}
.outcome-item.outcome-status-warn{border-left:3px solid var(--accent)}
.outcome-item.outcome-status-err{border-left:3px solid var(--danger)}
.outcome-item.outcome-status-muted{border-left:3px solid var(--faint)}

.outcome-icon{
  width:32px;height:32px;border-radius:8px;background:var(--accent-dim);
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:600;color:var(--accent);flex-shrink:0;
}
.outcome-status-ok .outcome-icon{background:rgba(110,200,213,.1);color:var(--success)}
.outcome-status-warn .outcome-icon{background:var(--accent-dim);color:var(--accent)}
.outcome-status-err .outcome-icon{background:rgba(224,108,117,.1);color:var(--danger)}
.outcome-status-muted .outcome-icon{background:rgba(107,127,168,.08);color:var(--faint)}

.outcome-body{flex:1;min-width:0}
.outcome-status-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:4px}
.outcome-metric-line{font-size:11px;color:var(--dim);margin-bottom:6px;font-feature-settings:'tnum' 1}
.outcome-metric-arrow{margin:0 4px;color:var(--faint)}
.outcome-metric-target{color:var(--faint)}

.outcome-progress-bar{
  height:4px;background:rgba(107,127,168,.1);border-radius:2px;overflow:hidden;margin-bottom:6px;
}
.outcome-progress-fill{height:100%;border-radius:2px;transition:width .3s}
.outcome-progress-fill.fill-ok{background:linear-gradient(90deg,var(--success),rgba(110,200,213,.5))}
.outcome-progress-fill.fill-warn{background:linear-gradient(90deg,var(--accent),rgba(212,149,106,.4))}
.outcome-progress-fill.fill-err{background:linear-gradient(90deg,var(--danger),rgba(224,108,117,.4))}
.outcome-progress-fill.fill-muted{background:rgba(107,127,168,.3)}

.outcome-bonus-line{font-size:11px;font-weight:600;color:var(--blue);letter-spacing:.3px}

.outcomes-empty{
  font-size:13px;color:var(--faint);text-align:center;padding:32px 16px;
  background:var(--bg-card);border:1px dashed var(--border-color);border-radius:12px;
  font-style:italic;
}
.light-theme .outcomes-empty{background:rgba(255,255,255,.6)}

@media(max-width:760px){
  .hypothesis-grid{grid-template-columns:1fr}
  .outcomes-summary{grid-template-columns:repeat(3,1fr)}
  .mission-modal-actions{flex-direction:column}
}

/* ════════════════════════════════════════════════════════════════════════════
   PHASE 7C ADDITIONS — Challenge "Mark as done" + completion state
   ════════════════════════════════════════════════════════════════════════════ */

/* Card-level status banner (sits at the bottom of completed challenge cards) */
.challenge-card-status-banner{
  margin-top:14px;padding:7px 12px;border-radius:8px;
  font-size:11px;font-weight:600;letter-spacing:.4px;text-align:center;
  color:var(--success);
  background:rgba(110,200,213,.08);
  border:1px solid rgba(110,200,213,.22);
}
.challenge-card-completed{opacity:.92}
.challenge-card-completed .challenge-title{
  text-decoration:line-through;text-decoration-color:rgba(107,127,168,.3);
  text-decoration-thickness:1px;
}
.challenge-card-completed::before{
  transform:scaleY(1) !important;
  background:linear-gradient(180deg,var(--success),rgba(110,200,213,.2)) !important;
}

/* Modal-level completion banner (sits below the title/points) */
.challenge-status-banner{
  margin:12px 0 18px 0;padding:10px 14px;border-radius:8px;
  font-size:12px;font-weight:600;letter-spacing:.3px;text-align:center;
  color:var(--success);
  background:rgba(110,200,213,.08);
  border:1px solid rgba(110,200,213,.22);
}

/* Action row (Mark as done button) — same layout shape as mission actions */
.challenge-modal-actions{
  display:flex;gap:10px;margin-top:18px;padding-top:18px;
  border-top:1px solid rgba(107,127,168,.08);
}
.btn-challenge-done{
  flex:1;padding:12px 18px;border-radius:10px;
  font-family:'Sora',sans-serif;font-size:13px;font-weight:600;
  cursor:pointer;transition:all .2s;
  border:none;
  background:linear-gradient(135deg,var(--accent),var(--blue));
  color:#0c0a14;letter-spacing:.2px;
}
.light-theme .btn-challenge-done{color:#fff}
.btn-challenge-done:hover:not(:disabled){filter:brightness(1.08)}
.btn-challenge-done:disabled{opacity:.6;cursor:not-allowed}

/* Outcomes summary — separator that visually groups challenge stat with verifications */
.outcomes-summary .outcomes-stat-challenge .outcomes-stat-num{color:var(--accent)}

/* ════════════════════════════════════════════════════════════════════════════
   MODERN RAIL — Vertical, floating glass navigation
   Replaces the old .top-nav (its rules are kept above as harmless dead code).
   ════════════════════════════════════════════════════════════════════════════ */

/* ── Extra design tokens the rail needs (extend existing palette) ───────── */
:root{
  --bg-elevated:#0f1424;
  --muted:#6b7fa8;
  --border-strong:rgba(255,255,255,.14);
  --surface:rgba(255,255,255,.03);
  --surface-hover:rgba(255,255,255,.06);
  --accent-soft:rgba(212,149,106,.35);
  --rail-w:196px;
  --rail-w-collapsed:64px;
  --rail-gap:16px;
}
.light-theme{
  --bg-elevated:#ffffff;
  --muted:#8a92a8;
  --border-strong:rgba(26,29,38,.14);
  --surface:rgba(26,29,38,.02);
  --surface-hover:rgba(26,29,38,.05);
  --accent-soft:rgba(184,116,58,.25);
}

/* ── Body offset for the rail (replaces the old top-nav height offset) ─── */
/* Scoped via :has() so auth pages (login/register/onboarding/404) — which have
   no .modern-rail — stay full-width and properly centered. */
body{transition:padding-left .35s cubic-bezier(.4,0,.2,1),background .3s,color .3s}
body:has(.modern-rail){padding-left:calc(var(--rail-w) + var(--rail-gap) + var(--rail-gap))}
body:has(.modern-rail.collapsed){padding-left:calc(var(--rail-w-collapsed) + var(--rail-gap) + var(--rail-gap) + 16px)}

/* Main-wrapper used to add `nav-h` of top padding for the old top nav — no longer needed. */
.main-wrapper{padding-top:48px}

/* ── The floating rail itself ───────────────────────────────────────────── */
.modern-rail{
  position:fixed;top:var(--rail-gap);left:var(--rail-gap);bottom:var(--rail-gap);
  width:var(--rail-w);z-index:200;
  display:flex;flex-direction:column;
  padding:16px 12px;
  background:rgba(15,20,36,.72);
  backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);
  border:1px solid var(--border-color);border-radius:16px;
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset,0 20px 60px rgba(0,0,0,.35);
  transition:width .35s cubic-bezier(.4,0,.2,1);
  box-sizing:border-box;
}
.light-theme .modern-rail{
  background:rgba(255,255,255,.78);
  box-shadow:0 1px 0 rgba(255,255,255,.8) inset,0 20px 50px rgba(26,29,38,.08);
}
.modern-rail::before{
  content:"";position:absolute;inset:0;border-radius:16px;
  background:radial-gradient(ellipse 80% 50% at 50% 0%,var(--accent-dim) 0%,transparent 60%);
  opacity:.6;pointer-events:none;
}

/* ── Collapsed state ─────────────────────────────────────────────────────── */
.modern-rail.collapsed{width:var(--rail-w-collapsed);padding:16px 10px}
.modern-rail.collapsed .rail-link-text,
.modern-rail.collapsed .rail-link-kbd,
.modern-rail.collapsed .rail-dock-meta,
.modern-rail.collapsed .rail-dock-caret,
.modern-rail.collapsed .rail-fab-label{display:none !important}
/* Logo wordmark/mark visibility is handled by the dedicated brand block below */

.modern-rail.collapsed .rail-link{width:40px;height:40px;padding:0;margin:0 auto;justify-content:center;align-items:center;gap:0}
.modern-rail.collapsed .rail-link.active{padding:0;width:40px;height:40px}

.modern-rail.collapsed .rail-fab{width:40px;height:40px;padding:0;margin:0 auto 10px;border-radius:50%;justify-content:center;gap:0}

.modern-rail.collapsed .rail-utility-row{flex-direction:column;gap:4px;align-items:center}
.modern-rail.collapsed .rail-utility{width:40px;height:36px;flex:0 0 auto;padding:0;justify-content:center}

.modern-rail.collapsed .rail-brand{justify-content:center;padding:4px 0 16px;gap:0}

.modern-rail.collapsed .rail-dock-trigger{width:40px;height:40px;padding:0;margin:0 auto;border-radius:50%;justify-content:center;gap:0}
.modern-rail.collapsed .rail-dock{padding-top:12px}

/* ── Brand row ──────────────────────────────────────────────────────────── */
.modern-rail .rail-brand{display:flex;align-items:center;padding:4px 8px 18px;text-decoration:none;position:relative;z-index:2;overflow:hidden;color:var(--text);gap:0}

/* Sizing — must override .nav-brand img{width:148px;height:28px} from earlier */
.modern-rail .rail-brand img{display:block;flex:0 0 auto}
.modern-rail .rail-brand .rail-brand-logo{height:28px;width:auto}
.modern-rail .rail-brand .rail-brand-mark-only{height:32px;width:32px}

/* Visibility — all four logo images start hidden, then the correct one is enabled
   based on (collapsed state × theme). Specificity (0,4,0) reliably beats any other
   .logo-dark / .logo-light rule elsewhere in the file. */
.modern-rail .rail-brand .rail-brand-logo,
.modern-rail .rail-brand .rail-brand-mark-only{display:none !important}

/* EXPANDED: show the full wordmark (dark theme by default, light when .light-theme) */
.modern-rail:not(.collapsed) .rail-brand .rail-brand-logo.logo-dark{display:block !important}
body.light-theme .modern-rail:not(.collapsed) .rail-brand .rail-brand-logo.logo-dark{display:none !important}
body.light-theme .modern-rail:not(.collapsed) .rail-brand .rail-brand-logo.logo-light{display:block !important}

/* COLLAPSED: show only the mark, theme-aware */
.modern-rail.collapsed .rail-brand .rail-brand-mark-only.logo-dark{display:block !important}
body.light-theme .modern-rail.collapsed .rail-brand .rail-brand-mark-only.logo-dark{display:none !important}
body.light-theme .modern-rail.collapsed .rail-brand .rail-brand-mark-only.logo-light{display:block !important}

/* ── Edge collapse handle ───────────────────────────────────────────────── */
.rail-collapse-btn{
  position:absolute;top:20px;right:-10px;width:20px;height:20px;border-radius:50%;
  background:var(--bg-elevated);border:1px solid var(--border-strong);color:var(--dim);
  display:grid;place-items:center;cursor:pointer;z-index:5;opacity:0;
  transition:opacity .2s,color .2s,border-color .2s;
}
.modern-rail:hover .rail-collapse-btn{opacity:1}
.rail-collapse-btn:hover{color:var(--accent);border-color:var(--accent-soft)}
.rail-collapse-btn svg{width:10px;height:10px;transition:transform .35s}
.modern-rail.collapsed .rail-collapse-btn{opacity:1}
.modern-rail.collapsed .rail-collapse-btn svg{transform:rotate(180deg)}

/* ── Nav list ───────────────────────────────────────────────────────────── */
.rail-nav{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1px;position:relative;z-index:2}
.rail-link{
  display:flex;align-items:center;gap:12px;padding:10px 11px;border-radius:8px;
  text-decoration:none;color:var(--text);
  font-size:14px;font-weight:500;letter-spacing:-.1px;
  text-transform:none;        /* override the all-caps .nav-link rule */
  position:relative;transition:color .18s,background .18s;
}
.rail-link:hover{background:var(--surface-hover);color:var(--text)}
.rail-link svg{width:19px;height:19px;flex:0 0 19px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.rail-link-text{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity .2s .05s;letter-spacing:-.1px}

.rail-link.active{
  color:var(--text);background:var(--surface-hover);
  border:1px solid var(--border-color);padding:9px 10px;
}
.rail-link.active svg{color:var(--accent)}
/* Neutralize the old .nav-link.active::after underline if anyone re-uses .nav-link here */
.rail-link.active::after{display:none}

/* Tooltip when collapsed */
.rail-link::before{
  content:attr(data-tip);position:absolute;left:calc(100% + 14px);top:50%;
  transform:translateY(-50%) translateX(-4px);
  background:var(--bg-elevated);color:var(--text);
  padding:5px 9px;border-radius:6px;border:1px solid var(--border-strong);
  font-size:13px;white-space:nowrap;pointer-events:none;opacity:0;
  transition:opacity .15s,transform .15s;z-index:50;
  box-shadow:0 4px 16px rgba(0,0,0,.3);
}
.modern-rail.collapsed .rail-link:hover::before{opacity:1;transform:translateY(-50%) translateX(0)}

/* ── Spacer + Upload FAB ────────────────────────────────────────────────── */
.rail-spacer{flex:1;min-height:8px}
.rail-fab{
  display:flex;align-items:center;justify-content:center;gap:9px;
  width:100%;padding:13px 14px;margin-bottom:12px;
  border-radius:10px;border:1px solid var(--accent-soft);
  background:linear-gradient(135deg,var(--accent) 0%,#b87a52 100%);
  color:#1a1208;font-family:'Sora',sans-serif;
  font-size:14px;font-weight:600;letter-spacing:-.1px;
  cursor:pointer;position:relative;z-index:2;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 4px 14px rgba(212,149,106,.22),inset 0 1px 0 rgba(255,255,255,.25);
}
.light-theme .rail-fab{color:#fff;text-shadow:0 1px 1px rgba(80,40,10,.3)}
.rail-fab:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(212,149,106,.32),inset 0 1px 0 rgba(255,255,255,.3)}
.rail-fab:active{transform:translateY(0)}
.rail-fab svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2.2}

/* ── Utility row (theme + language) ─────────────────────────────────────── */
.rail-utility-row{display:flex;gap:4px;margin-bottom:10px;position:relative;z-index:2}
.modern-rail .rail-utility{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:10px;border-radius:8px;background:transparent;border:1px solid transparent;
  color:var(--text);cursor:pointer;font-family:'Sora',sans-serif;
  font-size:13px;font-weight:500;letter-spacing:0;
  transition:color .18s,background .18s,border-color .18s;
}
.modern-rail .rail-utility:hover{background:var(--surface-hover);border-color:var(--border-color);color:var(--text)}
.modern-rail .rail-utility svg{width:17px;height:17px}
.modern-rail .rail-utility .icon-sun{display:block}
.modern-rail .rail-utility .icon-moon{display:none}
.light-theme .modern-rail .rail-utility .icon-sun{display:none !important}
.light-theme .modern-rail .rail-utility .icon-moon{display:block !important}

/* ── Profile dock at the bottom ─────────────────────────────────────────── */
.modern-rail .rail-dock{
  position:relative;z-index:2;
  border-top:1px solid var(--border-color);padding-top:10px;
  /* Reset .user-profile rules (border-left, padding, cursor) which would interfere */
  border-left:none;padding-left:0;padding-right:0;cursor:auto;height:auto;
}
.rail-dock-trigger{
  display:flex;align-items:center;gap:10px;width:100%;padding:7px 8px;border-radius:9px;
  background:none;border:1px solid transparent;cursor:pointer;color:var(--text);
  font-family:'Sora',sans-serif;text-align:left;
  transition:background .18s,border-color .18s;
}
.rail-dock-trigger:hover{background:var(--surface-hover);border-color:var(--border-color)}
.modern-rail .rail-avatar{
  flex:0 0 32px;width:32px;height:32px;border-radius:8px;
  background:linear-gradient(135deg,#6b7fa8 0%,#a78bcf 100%);
  display:grid;place-items:center;
  font-size:12.5px;font-weight:600;color:#fff;letter-spacing:.3px;
  /* Override the round, accent-bordered .user-avatar look */
  border:none;
}
.rail-dock-meta{flex:1;min-width:0;transition:opacity .2s .05s}
.rail-dock-name{font-size:13.5px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2}
.rail-dock-status{font-size:12px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:5px}
.rail-dock-status::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--success);box-shadow:0 0 6px var(--success);
}
.rail-dock-caret{color:var(--muted)}
.rail-dock-caret svg{width:13px;height:13px;transition:transform .25s}
.rail-dock.open .rail-dock-caret svg{transform:rotate(180deg)}

/* Dropdown panel — opens above the trigger (since dock is at rail bottom).
   `right:auto + min-width` lets it grow wider than the 196px rail so long
   emails like first.last+suffix@gmail.com don't bleed off the panel edge. */
.modern-rail .rail-dock-panel{
  position:absolute;bottom:calc(100% + 8px);left:0;right:auto;top:auto;
  min-width:max(100%, 260px);max-width:calc(100vw - 32px);
  background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:12px;
  padding:5px;opacity:0;transform:translateY(6px);pointer-events:none;
  transition:opacity .2s,transform .2s;
  box-shadow:0 12px 32px rgba(0,0,0,.4);z-index:60;
  /* Reset old .user-dropdown defaults (visibility/min-width/etc.) */
  visibility:visible;
}
.light-theme .modern-rail .rail-dock-panel{background:var(--bg-elevated);box-shadow:0 12px 32px rgba(26,29,38,.15)}
.rail-dock.open .rail-dock-panel{opacity:1;transform:translateY(0);pointer-events:auto}
.modern-rail.collapsed .rail-dock-panel{left:calc(100% + 12px);right:auto;bottom:0;min-width:260px}

.rail-dock-header{padding:10px 11px 12px;border-bottom:1px solid var(--border-color);margin-bottom:5px;min-width:0}
.rail-dock-header-name{font-size:14px;font-weight:500;color:var(--text);overflow-wrap:break-word}
.rail-dock-header-email{font-size:12px;color:var(--muted);margin-top:3px;overflow-wrap:anywhere;word-break:break-word;line-height:1.4}
.rail-dock-item{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:7px;
  color:var(--text);text-decoration:none;font-size:13.5px;cursor:pointer;
  transition:background .15s;
}
.rail-dock-item:hover{background:var(--surface-hover);color:var(--text)}
.rail-dock-item svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8}

/* ── Mobile drawer ──────────────────────────────────────────────────────── */
.rail-mobile-toggle{
  display:none;position:fixed;top:14px;left:14px;z-index:300;
  width:38px;height:38px;border-radius:10px;
  background:var(--bg-elevated);border:1px solid var(--border-strong);
  color:var(--text);cursor:pointer;place-items:center;
}
.rail-mobile-toggle svg{width:16px;height:16px}
.rail-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);z-index:199}
.rail-backdrop.open{display:block}

@media (max-width:860px){
  body,body.rail-collapsed{padding-left:0}
  .modern-rail{transform:translateX(calc(-100% - 32px));transition:transform .3s cubic-bezier(.4,0,.2,1)}
  .modern-rail.mobile-open{transform:translateX(0)}
  /* On mobile the rail is always fully expanded — never icon-only */
  .modern-rail.collapsed{width:var(--rail-w);padding:16px 12px}
  .modern-rail.collapsed .rail-link-text,
  .modern-rail.collapsed .rail-link-kbd,
  .modern-rail.collapsed .rail-dock-meta,
  .modern-rail.collapsed .rail-dock-caret,
  .modern-rail.collapsed .rail-fab-label{display:revert !important}
  /* Force the full wordmark back on, hide the mark — for both themes */
  .modern-rail.collapsed .rail-brand .rail-brand-mark-only{display:none !important}
  .modern-rail.collapsed .rail-brand .rail-brand-logo.logo-dark{display:block !important}
  body.light-theme .modern-rail.collapsed .rail-brand .rail-brand-logo.logo-dark{display:none !important}
  body.light-theme .modern-rail.collapsed .rail-brand .rail-brand-logo.logo-light{display:block !important}
  .modern-rail.collapsed .rail-link,
  .modern-rail.collapsed .rail-link.active{width:auto;height:auto;padding:8px 10px;margin:0;justify-content:flex-start;gap:11px}
  .modern-rail.collapsed .rail-link.active{padding:7px 9px}
  .modern-rail.collapsed .rail-fab{width:100%;height:auto;padding:11px 14px;margin:0 0 12px;border-radius:10px;gap:8px}
  .modern-rail.collapsed .rail-utility-row{flex-direction:row;align-items:stretch}
  .modern-rail.collapsed .rail-utility{width:auto;height:auto;padding:8px}
  .modern-rail.collapsed .rail-brand{justify-content:flex-start;padding:4px 6px 18px;gap:9px}
  .modern-rail.collapsed .rail-dock-trigger{width:100%;height:auto;padding:7px 8px;margin:0;border-radius:9px;justify-content:flex-start;gap:10px}
  .rail-collapse-btn{display:none}
  .rail-mobile-toggle{display:grid}
}

/* ===== Guided onboarding tour ===== */
.astra-tour-overlay{position:fixed;inset:0;z-index:2000;display:none;pointer-events:auto}
.astra-tour-overlay.visible{display:block}
.astra-tour-spotlight{position:fixed;top:0;left:0;width:0;height:0;border-radius:14px;
  box-shadow:0 0 0 9999px rgba(8,6,14,.72),0 0 0 2px var(--accent-border),0 0 22px 4px rgba(212,149,106,.28) inset;
  transition:top .28s ease,left .28s ease,width .28s ease,height .28s ease;pointer-events:none}
.light-theme .astra-tour-spotlight{box-shadow:0 0 0 9999px rgba(20,18,26,.55),0 0 0 2px var(--accent-border),0 0 22px 4px rgba(184,116,58,.22) inset}
.astra-tour-overlay.no-anchor .astra-tour-spotlight{transition:none;box-shadow:0 0 0 9999px rgba(8,6,14,.72)}
.light-theme .astra-tour-overlay.no-anchor .astra-tour-spotlight{box-shadow:0 0 0 9999px rgba(20,18,26,.55)}
.astra-tour-pop{position:fixed;top:50%;left:50%;width:340px;max-width:calc(100vw - 32px);
  background:var(--bg-card);backdrop-filter:blur(22px);border:1px solid var(--border-color);
  border-radius:16px;padding:22px;pointer-events:auto;box-shadow:0 18px 48px rgba(0,0,0,.45);
  font-family:'Sora',sans-serif}
.light-theme .astra-tour-pop{background:rgba(255,255,255,.96)}
.astra-tour-counter{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:10px}
.astra-tour-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:-.2px}
.astra-tour-body{font-size:13px;line-height:1.65;color:var(--dim);margin-bottom:18px}
.astra-tour-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}
.astra-tour-nav-btns{display:flex;align-items:center;gap:8px}
.astra-tour-pop button{font-family:'Sora',sans-serif;cursor:pointer;border-radius:8px;font-weight:600;transition:all .2s}
.astra-tour-skip,.astra-tour-back{background:none;border:1px solid var(--border-color);color:var(--dim);font-size:12px;padding:8px 14px}
.astra-tour-skip:hover,.astra-tour-back:hover{color:var(--text);border-color:var(--accent-border)}
.astra-tour-next{background:linear-gradient(135deg,var(--accent),var(--blue));border:none;color:#0c0a14;font-size:12px;padding:9px 18px}
.light-theme .astra-tour-next{color:#fff}
.astra-tour-next:hover{filter:brightness(1.08)}
.astra-tour-optout{display:block;width:100%;margin-top:14px;background:none;border:none;color:var(--faint);font-size:11px;text-align:center;padding:2px}
.astra-tour-optout:hover{color:var(--dim);text-decoration:underline}

/* celebratory shooting stars on tour finish */
.astra-tour-stars{position:fixed;inset:0;z-index:2100;pointer-events:none;overflow:hidden;opacity:1;transition:opacity .7s ease}
.astra-tour-stars.fade{opacity:0}
.astra-tour-star{position:absolute;width:3px;height:3px;border-radius:50%;background:var(--accent);
  box-shadow:0 0 8px 2px rgba(212,149,106,.7);opacity:0;
  animation:astra-tour-shoot 1.5s cubic-bezier(.2,.6,.3,1) forwards}
.astra-tour-star::before{content:'';position:absolute;top:50%;right:2px;width:120px;height:1.5px;
  transform:translateY(-50%);transform-origin:right center;
  background:linear-gradient(90deg,transparent,rgba(212,149,106,.8))}
@keyframes astra-tour-shoot{
  0%{opacity:0;transform:translate(0,0) rotate(28deg) scale(.6)}
  12%{opacity:1}
  100%{opacity:0;transform:translate(360px,200px) rotate(28deg) scale(1)}
}
@media(prefers-reduced-motion:reduce){
  .astra-tour-spotlight{transition:none}
  .astra-tour-star{animation:none;display:none}
}
