/* =============================================
   pages.css — All Page Layouts & Components v5.0
   ============================================= */

/* === Layout Shell === */
main {
  max-width:var(--max-w);
  margin:0 auto;
  padding:clamp(2.5rem,6vw,5rem) var(--col-gap) clamp(4rem,10vw,8rem);
}

/* === Section Header === */
.section-head { margin-bottom:clamp(2rem,5vw,3.5rem); }
.section-head .eyebrow {
  display:inline-flex; align-items:center;
  font-size:0.72rem; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase;
  color:var(--accent); margin-bottom:0.9rem;
}
.section-head .eyebrow::before {
  content:''; display:inline-block;
  width:1.8rem; height:1.5px;
  background:var(--accent); border-radius:2px;
  margin-right:0.65rem; flex-shrink:0;
}
.section-head h2 { margin-bottom:0.5rem; }
.section-head .subtitle { font-size:1.05rem; color:var(--ink-3); margin-top:0.25rem; }
.section-head p.body-text {
  font-size:0.975rem; color:var(--ink-2); line-height:1.75;
  max-width:65ch; margin-top:0.75rem;
}
.divider {
  height:1px;
  background:linear-gradient(90deg,var(--accent) 0%,var(--border) 60%);
  margin-top:1.5rem; border-radius:2px;
}

/* ================================================
   PAGE: INDEX / HERO
   ================================================ */
.page-hero {
  display:flex; flex-direction:column; justify-content:center;
  min-height:calc(100svh - var(--nav-h));
  padding-top:0; padding-bottom:0;
}

.hero-kicker {
  display:inline-flex; align-items:center; gap:0.6rem;
  font-size:0.75rem; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase;
  color:var(--accent); margin-bottom:1.5rem;
  opacity:0; animation:slideUp 0.6s var(--ease-out) 0.1s both;
}
.hero-kicker::before {
  content:''; display:inline-block;
  width:2rem; height:1.5px; background:var(--accent); border-radius:2px;
}
.hero-kicker::after {
  content:''; display:inline-block;
  width:6px; height:6px; border-radius:50%; background:var(--accent);
}

.hero-name {
  font-family:var(--font-display);
  font-size:clamp(3rem,8vw,5.5rem);
  font-weight:300; line-height:1.05; letter-spacing:-0.02em;
  color:var(--ink); margin-bottom:0.1em;
  opacity:0; animation:slideUp 0.7s var(--ease-out) 0.2s both;
}
.hero-name em { font-style:italic; color:var(--accent); }

.hero-role {
  font-size:clamp(1rem,2.5vw,1.3rem); color:var(--ink-3);
  font-weight:300; letter-spacing:0.02em;
  margin-bottom:2rem; min-height:1.9rem;
  opacity:0; animation:slideUp 0.7s var(--ease-out) 0.35s both;
}

/* Award strip on hero */
.hero-award-strip {
  display:flex; flex-wrap:wrap; gap:0.5rem;
  margin-bottom:2rem;
  opacity:0; animation:slideUp 0.7s var(--ease-out) 0.42s both;
}

.hero-cta-row {
  display:flex; flex-wrap:wrap; gap:1rem; align-items:center;
  opacity:0; animation:slideUp 0.7s var(--ease-out) 0.5s both;
}

.btn-primary {
  display:inline-flex; align-items:center; gap:0.5rem;
  background:var(--accent); color:#fff!important;
  padding:0.75rem 1.6rem; border-radius:var(--r-pill);
  font-size:0.875rem; font-weight:500; font-family:var(--font-body);
  border:none; cursor:pointer;
  transition:background var(--t-fast),transform var(--t-med) var(--ease-spring),box-shadow var(--t-med);
  box-shadow:var(--shadow-accent);
}
.btn-primary:hover { background:var(--accent-2); transform:translateY(-2px); box-shadow:0 12px 36px var(--accent-glow); }
.btn-primary:active { transform:scale(0.97); }
.btn-primary svg { width:14px; height:14px; }

.btn-ghost {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.75rem 1.4rem; border-radius:var(--r-pill);
  border:1px solid var(--border-2);
  font-size:0.875rem; font-weight:500; color:var(--ink-2);
  background:transparent; cursor:pointer; font-family:var(--font-body);
  transition:border-color var(--t-fast),color var(--t-fast),background var(--t-fast),transform var(--t-med) var(--ease-spring);
}
.btn-ghost:hover { border-color:var(--border-3); color:var(--accent); background:var(--accent-3); transform:translateY(-2px); }

.hero-scroll-hint {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:0.4rem;
  opacity:0; animation:fadeIn 1s var(--ease-out) 1.2s both;
}
.scroll-label { font-size:0.7rem; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-4); }
.scroll-line {
  width:1px; height:2.5rem;
  background:linear-gradient(180deg,var(--accent) 0%,transparent 100%);
  border-radius:2px; animation:scrollPulse 2s ease-in-out 1.5s infinite;
}
@keyframes scrollPulse {
  0%,100%{opacity:0.4;transform:scaleY(1)}
  50%{opacity:1;transform:scaleY(0.7)}
}

.hero-meta {
  display:flex; flex-wrap:wrap; gap:1.25rem;
  margin-top:2.5rem; padding-top:2rem;
  border-top:1px solid var(--border);
  opacity:0; animation:slideUp 0.7s var(--ease-out) 0.65s both;
}
.hero-meta-item {
  display:flex; align-items:center; gap:0.5rem;
  font-size:0.875rem; color:var(--ink-3);
}
.hero-meta-item a { color:var(--accent); }
.hero-meta-item a:hover { color:var(--accent-2); }

@keyframes slideUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }

/* ================================================
   PAGE: OVERVIEW
   ================================================ */
.overview-hero {
  display:flex; gap:2.5rem; align-items:flex-start;
  padding-bottom:3rem; margin-bottom:3rem;
  border-bottom:1px solid var(--border);
}
.avatar-wrap { flex-shrink:0; position:relative; }
.avatar-ring {
  width:100px; height:100px; border-radius:50%;
  background:var(--accent-3); border:2px solid var(--border-3);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:2.2rem;
  color:var(--accent); overflow:hidden;
  transition:box-shadow var(--t-med),transform var(--t-med) var(--ease-spring);
}
.avatar-ring img { width:100%; height:100%; object-fit:cover; }
.avatar-ring:hover { box-shadow:0 0 0 4px var(--accent-3),var(--shadow-accent); transform:scale(1.04); }
.status-dot {
  position:absolute; bottom:5px; right:5px;
  width:13px; height:13px; border-radius:50%;
  background:#22c55e; border:2.5px solid var(--bg);
}

.overview-info h2 { font-size:clamp(1.5rem,3vw,2rem); margin-bottom:0.3rem; }
.overview-role { font-size:0.95rem; color:var(--ink-3); margin-bottom:0.75rem; }

/* Award strip in overview */
.overview-awards { display:flex; flex-wrap:wrap; gap:0.4rem; margin-bottom:1rem; }

.pill-row { display:flex; flex-wrap:wrap; gap:0.5rem; }
.pill {
  display:inline-flex; align-items:center; gap:0.35rem;
  font-size:0.78rem; font-weight:500;
  padding:0.3rem 0.9rem;
  border:1px solid var(--border-2); border-radius:var(--r-pill);
  color:var(--ink-2); background:var(--bg-subtle);
  transition:all var(--t-med) var(--ease-out);
}
a.pill { cursor:pointer; }
a.pill:hover { border-color:var(--border-3); color:var(--accent); background:var(--accent-3); transform:translateY(-2px); box-shadow:var(--shadow-sm); }

.overview-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.overview-card {
  background:var(--bg-raised); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:1.5rem;
  transition:box-shadow var(--t-med),border-color var(--t-med),transform var(--t-med) var(--ease-out);
}
.overview-card:hover { box-shadow:var(--shadow-md); border-color:var(--border-3); transform:translateY(-3px); }
.card-label {
  font-size:0.72rem; font-weight:600; letter-spacing:0.1em;
  text-transform:uppercase; color:var(--accent); margin-bottom:0.8rem;
}
.overview-card ul { padding-left:0; }
.overview-card li { font-size:0.9rem; color:var(--ink-2); padding:0.2rem 0; }
.overview-card p  { font-size:0.9rem; color:var(--ink-2); line-height:1.7; margin:0; }

@media (max-width:600px) {
  .overview-hero { flex-direction:column; gap:1.5rem; }
  .overview-grid { grid-template-columns:1fr; }
}

/* ================================================
   PAGE: ABOUT
   ================================================ */
.about-cards { display:flex; flex-direction:column; gap:1rem; }
.about-card {
  display:flex; gap:1.25rem; align-items:flex-start;
  background:var(--bg-raised); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:clamp(1.25rem,3vw,1.75rem);
  transition:box-shadow var(--t-med),border-color var(--t-med),transform var(--t-med) var(--ease-out);
}
.about-card:hover { box-shadow:var(--shadow-md); border-color:var(--border-3); transform:translateY(-3px); }
.about-card-icon {
  width:44px; height:44px; flex-shrink:0;
  border-radius:var(--r-md); background:var(--accent-3); border:1px solid var(--border-3);
  display:flex; align-items:center; justify-content:center; font-size:1.25rem;
  transition:transform var(--t-med) var(--ease-spring),background var(--t-fast);
}
.about-card:hover .about-card-icon { transform:rotate(-8deg) scale(1.15); background:var(--accent); }
.about-card-body h3 { font-size:1rem; margin-bottom:0.4rem; }
.about-card-body p  { font-size:0.9rem; color:var(--ink-3); margin:0; line-height:1.68; }
.about-card-body ul { padding-left:1rem; list-style:disc; }
.about-card-body li { font-size:0.9rem; color:var(--ink-3); margin-bottom:0.25rem; }

/* ================================================
   PAGE: ACHIEVEMENTS / AWARDS (new)
   ================================================ */
.achievements-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.25rem; margin-top:1rem;
}
.achievement-card {
  background:var(--bg-raised); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:1.5rem;
  position:relative; overflow:hidden;
  transition:box-shadow var(--t-med),border-color var(--t-med),transform var(--t-med) var(--ease-out);
}
.achievement-card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--gold),var(--accent));
}
.achievement-card:hover { box-shadow:var(--shadow-lg); border-color:rgba(184,134,11,0.3); transform:translateY(-4px); }
.achievement-card:hover .achievement-icon { transform:rotate(-8deg) scale(1.15); }
.achievement-icon {
  width:48px; height:48px; border-radius:var(--r-md);
  background:var(--gold-light); border:1px solid rgba(184,134,11,0.3);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; margin-bottom:1rem;
  transition:transform var(--t-med) var(--ease-spring);
}
.achievement-title { font-size:1rem; font-weight:600; color:var(--ink); margin-bottom:0.3rem; }
.achievement-org { font-size:0.78rem; font-weight:600; letter-spacing:0.06em; color:var(--gold); text-transform:uppercase; margin-bottom:0.5rem; }
.achievement-date { font-size:0.78rem; color:var(--ink-4); margin-bottom:0.75rem; }
.achievement-desc { font-size:0.875rem; color:var(--ink-3); line-height:1.65; margin:0; }

/* ================================================
   PAGE: EDUCATION
   ================================================ */
.timeline { display:flex; flex-direction:column; gap:0; position:relative; padding-left:1.5rem; }
.timeline::before {
  content:''; position:absolute;
  left:0; top:12px; bottom:12px; width:1px;
  background:linear-gradient(180deg,var(--accent),var(--border));
}
.tl-item { position:relative; padding-left:1.75rem; padding-bottom:2.5rem; }
.tl-item:last-child { padding-bottom:0; }
.tl-dot {
  position:absolute; left:-1.65rem; top:10px;
  width:10px; height:10px; border-radius:50%;
  background:var(--accent); border:2px solid var(--bg);
  box-shadow:0 0 0 2px var(--accent);
  transition:transform var(--t-med) var(--ease-spring);
}
.tl-item:hover .tl-dot { transform:scale(1.4); }
.tl-card {
  background:var(--bg-raised); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:clamp(1.25rem,3vw,1.75rem);
  transition:box-shadow var(--t-med),border-color var(--t-med),transform var(--t-med) var(--ease-out);
}
.tl-card:hover { box-shadow:var(--shadow-md); border-color:var(--border-3); transform:translateX(4px); }
.tl-meta { display:flex; align-items:center; gap:0.75rem; flex-wrap:wrap; margin-bottom:0.75rem; }
.tl-date { font-size:0.78rem; color:var(--ink-4); }
.tl-badge {
  font-size:0.68rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase;
  padding:0.18rem 0.6rem; background:rgba(34,197,94,0.12);
  color:#15803d; border:1px solid rgba(34,197,94,0.3);
  border-radius:var(--r-pill);
}
[data-theme='dark'] .tl-badge { color:#4ade80; background:rgba(74,222,128,0.1); border-color:rgba(74,222,128,0.25); }
.tl-card h3 { font-size:1.1rem; margin-bottom:0.3rem; }
.tl-institution { font-size:0.85rem; color:var(--accent); margin-bottom:0.6rem; font-weight:500; }
.tl-card p { font-size:0.875rem; color:var(--ink-3); margin:0; line-height:1.65; }

/* ================================================
   PAGE: SKILLS
   ================================================ */
.skills-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:1.25rem;
}
.skill-card {
  background:var(--bg-raised); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:1.5rem;
  transition:box-shadow var(--t-med),border-color var(--t-med),transform var(--t-med) var(--ease-out);
}
.skill-card:hover { box-shadow:var(--shadow-lg); border-color:var(--border-3); transform:translateY(-5px); }
.skill-icon {
  width:44px; height:44px; border-radius:var(--r-md);
  background:var(--accent-3); border:1px solid var(--border-3);
  display:flex; align-items:center; justify-content:center;
  font-size:1.25rem; margin-bottom:1rem;
  transition:transform var(--t-med) var(--ease-spring),background var(--t-fast);
}
.skill-card:hover .skill-icon { transform:rotate(-8deg) scale(1.15); background:var(--accent); }
.skill-card h3 { font-size:1rem; margin-bottom:0.4rem; }
.skill-card p  { font-size:0.875rem; color:var(--ink-3); margin:0; line-height:1.65; }
.skill-tags { display:flex; flex-wrap:wrap; gap:0.35rem; margin-top:1rem; }
.skill-tag {
  font-size:0.72rem; font-weight:500; padding:0.2rem 0.65rem;
  background:var(--bg-subtle); border:1px solid var(--border);
  border-radius:var(--r-pill); color:var(--ink-3);
}

@media (max-width:540px) { .skills-grid{grid-template-columns:1fr} }

/* ================================================
   PAGE: PROJECTS
   ================================================ */
.projects-list { display:flex; flex-direction:column; gap:1rem; margin-top:2.5rem; }
.project-card {
  background:var(--bg-raised); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:clamp(1.25rem,3vw,1.75rem);
  display:grid; grid-template-columns:1fr auto; gap:1.25rem; align-items:start;
  transition:box-shadow var(--t-med),border-color var(--t-med),transform var(--t-med) var(--ease-out);
}
.project-card:hover { box-shadow:var(--shadow-lg); border-color:var(--border-3); transform:translateY(-4px); }
.project-tag {
  display:inline-flex; align-items:center;
  font-size:0.7rem; font-weight:600; letter-spacing:0.08em; text-transform:uppercase;
  color:var(--accent); background:var(--accent-3); border:1px solid var(--border-3);
  padding:0.2rem 0.7rem; border-radius:var(--r-pill); margin-bottom:0.65rem;
  transition:background var(--t-fast),color var(--t-fast),transform var(--t-med) var(--ease-spring);
}
.project-card:hover .project-tag { background:var(--accent); color:#fff; transform:scale(1.04); }
.project-card h3 { font-size:1.1rem; margin-bottom:0.5rem; }
.project-card p  { font-size:0.9rem; color:var(--ink-3); margin:0; line-height:1.65; }
.project-arrow {
  width:36px; height:36px; border-radius:50%;
  background:var(--bg-subtle); border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--ink-4); font-size:0.9rem; margin-top:0.3rem; flex-shrink:0;
  transition:background var(--t-fast),color var(--t-fast),transform var(--t-med) var(--ease-spring),border-color var(--t-fast);
}
.project-card:hover .project-arrow { background:var(--accent); border-color:var(--accent); color:#fff; transform:translate(2px,-2px) scale(1.08); }

/* ================================================
   PAGE: CONTACT
   ================================================ */
.contact-layout {
  display:grid; grid-template-columns:1fr 1.15fr;
  gap:2.5rem; margin-top:2.5rem; align-items:start;
}
.contact-channels { display:flex; flex-direction:column; gap:0.6rem; }
.contact-channel {
  display:flex; align-items:center; gap:1rem;
  padding:0.9rem 1.1rem; background:var(--bg-raised);
  border:1px solid var(--border); border-radius:var(--r-md);
  text-decoration:none!important; color:inherit!important;
  transition:border-color var(--t-fast),box-shadow var(--t-med),transform var(--t-med) var(--ease-out);
}
.contact-channel:hover { border-color:var(--border-3); box-shadow:var(--shadow-md); transform:translateX(6px); }
.channel-icon {
  width:38px; height:38px; border-radius:var(--r-sm);
  background:var(--accent-3); border:1px solid var(--border-3);
  display:flex; align-items:center; justify-content:center;
  font-size:0.95rem; flex-shrink:0; color:var(--accent); font-weight:700;
  transition:background var(--t-fast),color var(--t-fast),transform var(--t-med) var(--ease-spring);
}
.contact-channel:hover .channel-icon { background:var(--accent); color:#fff; transform:scale(1.1) rotate(-6deg); }
.channel-label { font-size:0.72rem; color:var(--ink-4); display:block; margin-bottom:0.1rem; }
.channel-value { font-size:0.9rem; font-weight:500; color:var(--accent); display:block; }

/* Contact Form */
.contact-form-wrap {
  background:var(--bg-raised); border:1px solid var(--border);
  border-radius:var(--r-xl); padding:clamp(1.5rem,4vw,2rem);
}
.form-title {
  font-size:1.05rem; font-weight:600; color:var(--ink);
  margin-bottom:1.5rem; padding-bottom:1rem; border-bottom:1px solid var(--border);
}
.form-group { display:flex; flex-direction:column; gap:0.35rem; margin-bottom:1.1rem; }
.form-group label { font-size:0.78rem; font-weight:600; letter-spacing:0.04em; color:var(--ink-3); text-transform:uppercase; }
.form-group input,
.form-group textarea {
  width:100%; padding:0.65rem 0.95rem;
  background:var(--bg-subtle); border:1px solid var(--border-2);
  border-radius:var(--r-sm); font-size:0.95rem;
  font-family:var(--font-body); color:var(--ink);
  transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-fast);
  outline:none; resize:vertical;
}
.form-group input::placeholder,.form-group textarea::placeholder { color:var(--ink-4); }
.form-group input:focus,.form-group textarea:focus { border-color:var(--accent); background:var(--bg-raised); box-shadow:0 0 0 3px var(--accent-glow); }
.form-group input.err,.form-group textarea.err { border-color:#ef4444; }
.form-group input.ok, .form-group textarea.ok  { border-color:#22c55e; }
.field-err { font-size:0.78rem; color:#ef4444; margin-top:0.2rem; }
.char-row { display:flex; justify-content:flex-end; font-size:0.72rem; color:var(--ink-4); margin-top:0.25rem; transition:color var(--t-fast); }
.char-row.warn{color:var(--accent)} .char-row.over{color:#ef4444}
.form-group textarea { min-height:130px; }
.form-footer { display:flex; align-items:center; justify-content:space-between; gap:1rem; flex-wrap:wrap; margin-top:0.5rem; }

.btn-send {
  display:inline-flex; align-items:center; gap:0.5rem;
  background:var(--accent); color:#fff;
  border:none; cursor:pointer;
  padding:0.72rem 1.6rem; border-radius:var(--r-pill);
  font-size:0.875rem; font-weight:500; font-family:var(--font-body);
  transition:background var(--t-fast),transform var(--t-med) var(--ease-spring),box-shadow var(--t-med);
  box-shadow:var(--shadow-accent);
}
.btn-send:hover{background:var(--accent-2);transform:translateY(-2px)}
.btn-send:active{transform:scale(0.97)}
.btn-send:disabled{opacity:0.6;cursor:not-allowed;transform:none}

.form-msg { font-size:0.875rem; padding:0.55rem 0.9rem; border-radius:var(--r-sm); font-weight:500; display:none; transition:all var(--t-med); }
.form-msg.show{display:block}
.form-msg.success{background:rgba(34,197,94,0.1);color:#15803d;border:1px solid rgba(34,197,94,0.25)}
.form-msg.error  {background:rgba(239,68,68,0.1);color:#dc2626;border:1px solid rgba(239,68,68,0.25)}

@media (max-width:650px) { .contact-layout{grid-template-columns:1fr} }

/* ================================================
   FOOTER
   ================================================ */
footer {
  border-top:1px solid var(--border);
  padding:2rem var(--col-gap);
  text-align:center;
  font-size:0.82rem; color:var(--ink-4); letter-spacing:0.02em;
}
.footer-inner { max-width:var(--max-w); margin:0 auto; }
.footer-links { display:flex; justify-content:center; gap:1.25rem; flex-wrap:wrap; margin-bottom:0.75rem; }
.footer-links a { font-size:0.82rem; color:var(--ink-4); transition:color var(--t-fast); }
.footer-links a:hover { color:var(--accent); }
.footer-social { display:flex; justify-content:center; gap:0.75rem; margin-bottom:0.75rem; }
.footer-social a {
  width:34px; height:34px; border-radius:50%;
  background:var(--bg-subtle); border:1px solid var(--border-2);
  display:flex; align-items:center; justify-content:center;
  font-size:0.85rem; color:var(--ink-3);
  transition:background var(--t-fast),color var(--t-fast),border-color var(--t-fast),transform var(--t-med) var(--ease-spring);
}
.footer-social a:hover { background:var(--accent); color:#fff; border-color:var(--accent); transform:translateY(-2px); }

/* ================================================
   404 PAGE
   ================================================ */
.page-404 {
  min-height:calc(100svh - var(--nav-h) - 80px);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; gap:1rem;
}
.error-num {
  font-family:var(--font-display);
  font-size:clamp(6rem,20vw,12rem); font-weight:300;
  color:var(--accent-3); line-height:1;
  -webkit-text-stroke:1px var(--border-3); letter-spacing:-0.04em;
}

/* ================================================
   SECTION FOCUS / PRESENTATION MODE
   ================================================ */
.focus-section {
  transition:opacity var(--t-med) var(--ease-in-out),transform var(--t-med) var(--ease-out);
}
body.focus-mode .focus-section { opacity:0.18; transform:scale(0.985); pointer-events:none; }
body.focus-mode .focus-section.active-focus { opacity:1!important; transform:none!important; pointer-events:auto; }

/* Progress bar */
#page-progress {
  position:fixed; top:var(--nav-h); left:0; height:2px;
  background:var(--accent); z-index:500;
  transition:width 0.15s linear;
  border-radius:0 2px 2px 0;
  box-shadow:0 0 8px var(--accent-glow);
}

/* Section nav dots */
#section-dots {
  position:fixed; right:1.25rem; top:50%; transform:translateY(-50%);
  display:flex; flex-direction:column; gap:0.6rem; z-index:300;
}
#section-dots .dot {
  width:8px; height:8px; border-radius:50%;
  background:var(--border-2); border:1px solid var(--border-2);
  cursor:pointer; transition:all var(--t-med) var(--ease-out);
}
#section-dots .dot.active { background:var(--accent); border-color:var(--accent); transform:scale(1.35); box-shadow:0 0 8px var(--accent-glow); }
#section-dots .dot:hover  { background:var(--accent-2); border-color:var(--accent-2); }

@media (max-width:700px) { #section-dots{display:none} }
