*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { overflow-x: hidden; }

html, body {
  user-select: none;
  -webkit-user-select: none;
}

input, textarea, [contenteditable="true"], code, pre {
  user-select: text !important;
  -webkit-user-select: text !important;
}

:root {
  --bg:        #f4f4f9;
  --card:      #ffffff;
  --card-h:    #f8f8fc;
  --card2:     #eeeef4;
  --border:    rgba(0,0,0,0.07);
  --border-h:  rgba(0,0,0,0.12);
  --text:      #1a1a2e;
  --text-dim:  #4a4a6a;
  --muted:     #8888a8;

  --cyan:      #377bf2;
  --cyan-glow: rgba(55,123,242,0.15);
  --green:     #16a34a;
  --green-glow:rgba(22,163,74,0.15);
  --purple:    #7c3aed;
  --purple-glow:rgba(124,58,237,0.12);
  --amber:     #d97706;
  --pink:      #db2777;
  --pink-glow: rgba(219,39,119,0.12);

  --radius-sm: 12px;
  --radius-md: 16px;
  --radius-lg: 20px;
  --gap: clamp(10px, 1.5vw, 24px);
  --font: 'Lexend Deca', sans-serif;

  /* Fluid Typography */
  --fs-xs:   clamp(0.65rem, 0.6rem + 0.25vw, 0.8rem);
  --fs-sm:   clamp(0.8rem, 0.75rem + 0.25vw, 0.95rem);
  --fs-base: clamp(0.9rem, 0.85rem + 0.3vw, 1.1rem);
  --fs-md:   clamp(1.1rem, 1rem + 0.5vw, 1.4rem);
  --fs-lg:   clamp(1.4rem, 1.25rem + 0.8vw, 2rem);
  --fs-xl:   clamp(2rem, 1.7rem + 1.2vw, 3.2rem);
  --fs-display: clamp(2.5rem, 2rem + 2vw, 4.5rem);

  /* Fluid Spacing */
  --sp-sm: clamp(0.5rem, 0.4rem + 0.5vw, 1rem);
  --sp-md: clamp(1rem, 0.8rem + 1vw, 2rem);
  --sp-lg: clamp(2rem, 1.5rem + 2vw, 4rem);

  --header-offset: 40px;
}

/* ========== DARK THEME ========== */
[data-theme="dark"] {
  --bg:        #08080c;
  --card:      #0f0f15;
  --card-h:    #141420;
  --card2:     #181822;
  --border:    rgba(255,255,255,0.05);
  --border-h:  rgba(255,255,255,0.12);
  --text:      #e0e0ec;
  --text-dim:  #9a9ab8;
  --muted:     #8a8aa3;

  --cyan:      #377bf2;
  --cyan-glow: rgba(55,123,242,0.18);
  --green:     #4ade80;
  --green-glow:rgba(74,222,128,0.18);
  --purple:    #a78bfa;
  --purple-glow:rgba(167,139,250,0.15);
  --amber:     #fbbf24;
  --pink:      #f472b6;
  --pink-glow: rgba(244,114,182,0.15);
}

/* ========== CUSTOM CURSOR ========== */
.custom-cursor {
  position: fixed;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border: 2px solid var(--cyan);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  transition: width 0.2s, height 0.2s, background-color 0.2s;
}
.custom-cursor.hover {
  width: 40px;
  height: 40px;
  background-color: var(--cyan-glow);
}

/* ========== UIVERSE THEME SWITCH ========== */
.theme-switch {
  --toggle-size: 16px;
  --container-width: 4em;
  --container-height: 2em;
  --container-radius: 6.25em;
  --container-light-bg: #3D7EAE;
  --container-night-bg: #1D1F2C;
  --circle-container-diameter: 2.5em;
  --sun-moon-diameter: 1.6em;
  --sun-bg: #ECCA2F;
  --moon-bg: #C4C9D1;
  --spot-color: #959DB1;
  --circle-container-offset: calc((var(--circle-container-diameter) - var(--container-height)) / 2 * -1);
  --stars-color: #fff;
  --clouds-color: #F3FDFF;
  --back-clouds-color: #AACADF;
  --transition: .5s cubic-bezier(0, -0.02, 0.4, 1.25);
  --circle-transition: .3s cubic-bezier(0, -0.02, 0.35, 1.17);

  position: fixed;
  top: 1.5rem;
  right: 1.5rem;
  z-index: 1000;
  opacity: 0.7;
  transition: opacity 0.3s ease;
}

.theme-switch:hover {
  opacity: 1;
}

.theme-switch, .theme-switch *, .theme-switch *::before, .theme-switch *::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-size: var(--toggle-size);
}

.theme-switch__container {
  width: var(--container-width);
  height: var(--container-height);
  background-color: var(--container-light-bg); /* default light */
  border-radius: var(--container-radius);
  overflow: hidden;
  cursor: pointer;
  -webkit-box-shadow: 0em -0.062em 0.062em rgba(0, 0, 0, 0.25), 0em 0.062em 0.125em rgba(255, 255, 255, 0.94);
  box-shadow: 0em -0.062em 0.062em rgba(0, 0, 0, 0.25), 0em 0.062em 0.125em rgba(255, 255, 255, 0.94);
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
  position: relative;
}

[data-theme="dark"] .theme-switch__container {
  background-color: var(--container-night-bg);
}

.theme-switch__container::before {
  content: "";
  position: absolute;
  z-index: 1;
  inset: 0;
  -webkit-box-shadow: 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset, 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset;
  box-shadow: 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset, 0em 0.05em 0.187em rgba(0, 0, 0, 0.25) inset;
  border-radius: var(--container-radius)
}

.theme-switch__checkbox {
  display: none;
}

.theme-switch__circle-container {
  width: var(--circle-container-diameter);
  height: var(--circle-container-diameter);
  background-color: rgba(255, 255, 255, 0.1);
  position: absolute;
  left: calc(100% - var(--circle-container-offset) - var(--circle-container-diameter));
  top: var(--circle-container-offset);
  border-radius: var(--container-radius);
  -webkit-box-shadow: inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), 0 0 0 0.625em rgba(255, 255, 255, 0.1), 0 0 0 1.25em rgba(255, 255, 255, 0.1);
  box-shadow: inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), inset 0 0 0 3.375em rgba(255, 255, 255, 0.1), 0 0 0 0.625em rgba(255, 255, 255, 0.1), 0 0 0 1.25em rgba(255, 255, 255, 0.1);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-transition: var(--circle-transition);
  -o-transition: var(--circle-transition);
  transition: var(--circle-transition);
  pointer-events: none;
}

[data-theme="dark"] .theme-switch__circle-container {
  left: calc(100% - var(--circle-container-offset) - var(--circle-container-diameter));
}

.theme-switch__circle-container {
  left: var(--circle-container-offset);
}

[data-theme="light"] .theme-switch__circle-container:hover {
  left: calc(var(--circle-container-offset) + 0.187em);
}

.theme-switch__sun-moon-container {
  pointer-events: auto;
  position: relative;
  z-index: 2;
  width: var(--sun-moon-diameter);
  height: var(--sun-moon-diameter);
  margin: auto;
  border-radius: var(--container-radius);
  background-color: var(--sun-bg);
  -webkit-box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #a1872a inset;
  box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #a1872a inset;
  -webkit-filter: drop-shadow(0.062em 0.125em 0.125em rgba(0, 0, 0, 0.25)) drop-shadow(0em 0.062em 0.125em rgba(0, 0, 0, 0.25));
  filter: drop-shadow(0.062em 0.125em 0.125em rgba(0, 0, 0, 0.25)) drop-shadow(0em 0.062em 0.125em rgba(0, 0, 0, 0.25));
  overflow: hidden;
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
}

.theme-switch__moon {
  -webkit-transform: translate(0);
  -ms-transform: translate(0);
  transform: translate(0);
  width: 100%;
  height: 100%;
  background-color: var(--moon-bg);
  border-radius: inherit;
  -webkit-box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #969696 inset;
  box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #969696 inset;
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
  position: relative;
}

[data-theme="dark"] .theme-switch__moon {
  -webkit-transform: translate(0);
  -ms-transform: translate(0);
  transform: translate(0);
}

.theme-switch__moon {
  -webkit-transform: translateX(100%);
  -ms-transform: translateX(100%);
  transform: translateX(100%);
  width: 100%;
  height: 100%;
  background-color: var(--moon-bg);
  border-radius: inherit;
  -webkit-box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #969696 inset;
  box-shadow: 0.062em 0.062em 0.062em 0em rgba(254, 255, 239, 0.61) inset, 0em -0.062em 0.062em 0em #969696 inset;
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
  position: relative;
}

.theme-switch__spot {
  position: absolute;
  top: 0.75em;
  left: 0.312em;
  width: 0.75em;
  height: 0.75em;
  border-radius: var(--container-radius);
  background-color: var(--spot-color);
  -webkit-box-shadow: 0em 0.0312em 0.062em rgba(0, 0, 0, 0.25) inset;
  box-shadow: 0em 0.0312em 0.062em rgba(0, 0, 0, 0.25) inset;
}

.theme-switch__spot:nth-of-type(2) {
  width: 0.375em;
  height: 0.375em;
  top: 0.937em;
  left: 1.375em;
}

.theme-switch__spot:nth-last-of-type(3) {
  width: 0.25em;
  height: 0.25em;
  top: 0.312em;
  left: 0.812em;
}

.theme-switch__clouds {
  width: 1.25em;
  height: 1.25em;
  background-color: var(--clouds-color);
  border-radius: var(--container-radius);
  position: absolute;
  bottom: -4.062em;
  left: 0.312em;
  -webkit-box-shadow: 0.937em 0.312em var(--clouds-color), -0.312em -0.312em var(--back-clouds-color), 1.437em 0.375em var(--clouds-color), 0.5em -0.125em var(--back-clouds-color), 2.187em 0 var(--clouds-color), 1.25em -0.062em var(--back-clouds-color), 2.937em 0.312em var(--clouds-color), 2em -0.312em var(--back-clouds-color), 3.625em -0.062em var(--clouds-color), 2.625em 0em var(--back-clouds-color), 4.5em -0.312em var(--clouds-color), 3.375em -0.437em var(--back-clouds-color), 4.625em -1.75em 0 0.437em var(--clouds-color), 4em -0.625em var(--back-clouds-color), 4.125em -2.125em 0 0.437em var(--back-clouds-color);
  box-shadow: 0.937em 0.312em var(--clouds-color), -0.312em -0.312em var(--back-clouds-color), 1.437em 0.375em var(--clouds-color), 0.5em -0.125em var(--back-clouds-color), 2.187em 0 var(--clouds-color), 1.25em -0.062em var(--back-clouds-color), 2.937em 0.312em var(--clouds-color), 2em -0.312em var(--back-clouds-color), 3.625em -0.062em var(--clouds-color), 2.625em 0em var(--back-clouds-color), 4.5em -0.312em var(--clouds-color), 3.375em -0.437em var(--back-clouds-color), 4.625em -1.75em 0 0.437em var(--clouds-color), 4em -0.625em var(--back-clouds-color), 4.125em -2.125em 0 0.437em var(--back-clouds-color);
  -webkit-transition: 0.5s cubic-bezier(0, -0.02, 0.4, 1.25);
  -o-transition: 0.5s cubic-bezier(0, -0.02, 0.4, 1.25);
  transition: 0.5s cubic-bezier(0, -0.02, 0.4, 1.25);
}

[data-theme="dark"] .theme-switch__clouds {
  bottom: -4.062em;
}

.theme-switch__clouds {
  bottom: -0.625em;
}

.theme-switch__stars-container {
  position: absolute;
  color: var(--stars-color);
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  left: 0.312em;
  width: 2.75em;
  height: auto;
  -webkit-transition: var(--transition);
  -o-transition: var(--transition);
  transition: var(--transition);
}

[data-theme="dark"] .theme-switch__stars-container {
  top: 50%;
}

.theme-switch__stars-container {
  top: -100%;
}

html {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 14px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.01em;
  scroll-behavior: smooth;
  transition: background 0.4s ease, color 0.4s ease;
}

body {
  min-height: 100vh;
  background:
    radial-gradient(ellipse 60% 50% at 5% 5%, rgba(55,123,242,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 55% 45% at 92% 88%, rgba(124,58,237,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 45% 35% at 50% 50%, rgba(22,163,74,0.03) 0%, transparent 65%),
    var(--bg);
  transition: background 0.4s ease;
}
[data-theme="dark"] body {
  background:
    radial-gradient(ellipse 60% 50% at 5% 5%, rgba(55,123,242,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 55% 45% at 92% 88%, rgba(167,139,250,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 45% 35% at 50% 50%, rgba(74,222,128,0.03) 0%, transparent 65%),
    radial-gradient(ellipse 30% 25% at 70% 20%, rgba(244,114,182,0.03) 0%, transparent 60%),
    var(--bg);
}

/* ========== LAYOUT ========== */
.page {
  max-width: 1240px;
  margin: 0 auto;
  padding: calc(var(--sp-lg) + var(--header-offset)) var(--sp-md) var(--sp-lg);
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: var(--sp-md);
  align-items: start;
  position: relative;
  z-index: 1;
}

.col { display: flex; flex-direction: column; gap: var(--gap); }
.col:last-child {
  grid-column: 1 / -1;
  margin-top: 1rem;
}

/* ========== CARD BASE ========== */
.card {
  background: rgba(15,15,21,0.7);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-md);
  position: relative;
  overflow: hidden;
  transition: background 0.4s ease, border-color 0.3s, transform 0.3s, box-shadow 0.3s, color 0.4s ease;
}
[data-theme="light"] .card {
  background: rgba(255,255,255,0.85);

}
.card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.35s;
  pointer-events: none;
}
.card:hover {
  border-color: var(--border-h);
}

.card-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 7px;
}
.card-title svg { width: 14px; height: 14px; opacity: 0.5; }

/* ========== PROFILE CARD ========== */
.profile-card {
  background: linear-gradient(145deg, rgba(20,20,30,0.9), rgba(12,12,18,0.95));
  border-color: rgba(255,255,255,0.08);

}
[data-theme="light"] .profile-card {
  background: linear-gradient(145deg, rgba(255,255,255,0.95), rgba(240,240,248,0.98));
  border-color: rgba(0,0,0,0.1);

}
[data-theme="light"] .profile-name { color: #1a1a2e; }
[data-theme="light"] .stat-num { color: #1a1a2e; }
[data-theme="light"] .proj-name { color: #1a1a2e; }
.profile-card::after {
  content: '';
  position: absolute;
  top: -40%; right: -30%;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(34,211,238,0.06) 0%, transparent 70%);
  pointer-events: none;
}

.profile-inner { display: flex; align-items: center; gap: 16px; margin-bottom: 1.1rem; }

.avatar-wrap {
  position: relative;
  flex-shrink: 0;
}
.avatar {
  width: 62px; height: 62px;
  border-radius: 50%;
  background: linear-gradient(135deg, #1a2a4a 0%, #2a1a4a 100%);
  border: 2px solid rgba(34,211,238,0.35);
  display: flex; align-items: center; justify-content: center;
  font-size: 26px;
  overflow: hidden;
  box-shadow: 0 0 0 5px rgba(34,211,238,0.08), 0 0 20px rgba(34,211,238,0.1);
  animation: avatar-ring-pulse 4s ease-in-out infinite;
}
[data-theme="light"] .avatar {
  background: linear-gradient(135deg, #e0f2fe 0%, #ede9fe 100%);
  border-color: rgba(8,145,178,0.4);
  box-shadow: 0 0 0 5px rgba(8,145,178,0.08), 0 0 20px rgba(8,145,178,0.06);
}
.avatar img { width:100%; height:100%; object-fit:cover; }
.avatar-status {
  position: absolute;
  bottom: 2px; right: 2px;
  width: 12px; height: 12px;
  background: var(--green);
  border-radius: 50%;
  border: 2.5px solid var(--bg);
  box-shadow: 0 0 8px var(--green);
}


.profile-name {
  font-size: var(--fs-md);
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.03em;
  line-height: 1.2;
}
.profile-handle {
  font-size: 12px;
  font-weight: 400;
  color: var(--muted);
  margin-top: 3px;
}

.profile-tagline {
  font-size: 12.5px;
  font-weight: 300;
  color: var(--text-dim);
  min-height: 20px;
  border-top: 1px solid rgba(255,255,255,0.06);
  padding-top: 0.85rem;
}
.tw-cursor {
  display: inline-block;
  width: 2px; height: 13px;
  background: var(--cyan);
  vertical-align: middle;
  margin-left: 2px;
  animation: blink 1s step-end infinite;
}

/* ========== CURRENTLY CARD ========== */
.currently-card {
  background: linear-gradient(135deg, rgba(34,211,238,0.06) 0%, rgba(15,15,21,0.8) 60%);
  border-color: rgba(34,211,238,0.15);
}
[data-theme="light"] .currently-card {
  background: linear-gradient(135deg, rgba(8,145,178,0.06) 0%, rgba(255,255,255,0.9) 60%);
  border-color: rgba(8,145,178,0.18);
}
[data-theme="light"] .current-role-name { color: #1a1a2e; }
.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cyan);
  background: rgba(34,211,238,0.08);
  border: 1px solid rgba(34,211,238,0.2);
  padding: 5px 12px;
  border-radius: 20px;
  margin-bottom: 0.85rem;
}
.status-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 6px var(--cyan);
  animation: pulse-dot 2s ease-in-out infinite;
}
.current-role-name {
  font-size: var(--fs-md);
  font-weight: 700;
  color: #fff;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
}
.current-role-desc {
  font-size: 12.5px;
  font-weight: 300;
  color: var(--text-dim);
  line-height: 1.8;
}

/* ========== JOURNEY & SKILLS (HORIZONTAL) ========== */
.journey-hz-section {
  width: 100%;
  margin-top: 0;
  /* Remove padding: 0 to inherit standard card padding */
}
.journey-hz-title {
  color: var(--text-dim);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 1.5rem;
  padding-left: 0;
}

.timeline-hz {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  width: 100%;
  margin: 0 auto 2.5rem auto;
}

.tl-hz-line {
  position: absolute;
  top: 4px; /* Adjusted for smaller dot */
  left: 10%;
  right: 10%;
  height: 2px;
  background: rgba(255, 255, 255, 0.1);
  z-index: 0;
}
.tl-hz-line::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  background: linear-gradient(90deg, var(--cyan), transparent);
}
[data-theme="light"] .tl-hz-line { background: rgba(0, 0, 0, 0.1); }
[data-theme="light"] .tl-hz-line::after { background: linear-gradient(90deg, var(--cyan), transparent); }

.tl-hz-item {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
}

.tl-hz-dot {
  width: 10px; /* Smaller dot */
  height: 10px;
  border-radius: 50%;
  background: #6b7280;
  margin-bottom: 1rem; /* Less space below dot */
  transition: all 0.3s;
  border: 2px solid var(--bg);
}

.tl-hz-item.active .tl-hz-dot {
  background: var(--cyan);
  box-shadow: 0 0 10px var(--cyan), 0 0 20px var(--cyan); /* Slightly smaller glow */
  border-color: var(--cyan);
}

.tl-hz-content {
  text-align: center;
}

.tl-hz-period {
  font-size: 10px; /* Smaller font */
  color: rgba(255,255,255,0.4);
  letter-spacing: 0.05em;
  margin-bottom: 4px; /* Tighter spacing */
  font-family: inherit;
  white-space: nowrap;
}
[data-theme="light"] .tl-hz-period { color: rgba(0,0,0,0.5); }

.tl-hz-role {
  font-size: 13px; /* Smaller font */
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
[data-theme="light"] .tl-hz-role { color: var(--text); }

.tl-hz-item.active .tl-hz-role {
  color: var(--cyan);
  text-shadow: 0 0 8px rgba(34, 211, 238, 0.3); /* Slightly smaller glow */
}

.journey-hz-skills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px; /* Tighter gap */
  justify-content: center;
  margin-top: 0.5rem;
}
.skill-pill {
  font-size: 11px; /* Smaller font */
  font-weight: 500;
  padding: 5px 14px; /* Less padding */
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.5);
  background: transparent;
  transition: all 0.3s ease;
  cursor: default;
}
[data-theme="light"] .skill-pill {
  border-color: rgba(0,0,0,0.08);
  color: rgba(0,0,0,0.6);
}
.skill-pill:hover {
  color: #fff;
  border-color: rgba(255,255,255,0.2);
  background: rgba(255,255,255,0.05);
}
[data-theme="light"] .skill-pill:hover {
  color: var(--text);
  border-color: rgba(0,0,0,0.15);
  background: rgba(0,0,0,0.05);
}

/* ========== SOCIAL GRID ========== */
.socials-card { padding: 1rem; }
.socials-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 7px;
}
.soc-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 10px 6px 9px;
  border-radius: var(--radius-sm);
  background: rgba(24,24,34,0.6);
  border: 1px solid var(--border);
  cursor: pointer;
  text-decoration: none;
  color: var(--muted);
  transition: all 0.25s;
  position: relative;
  overflow: hidden;
}
[data-theme="light"] .soc-btn {
  background: rgba(240,240,248,0.9);
}
.soc-btn::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--soc-color, rgba(255,255,255,0.04));
  opacity: 0;
  transition: opacity 0.25s;
}
.soc-btn:hover {
  border-color: var(--border-h);
  color: #fff;
  transform: translateY(-2px);
}
[data-theme="light"] .soc-btn:hover {
  color: var(--text);
  background: #fff;
}
.soc-btn:hover::after { opacity: 1; }
.soc-icon {
  width: 28px; height: 28px;
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px;
  background: var(--card);
  flex-shrink: 0;
}
.soc-label {
  font-size: 9.5px;
  font-weight: 500;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* ========== STATS ========== */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap);
}
.stat-card {
  background: rgba(20,20,30,0.5);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.03);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 1.25rem, 1.5rem) 0.5rem;
  text-align: center;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: default;
  position: relative;
  overflow: hidden;
}
.stat-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
  opacity: 0;
  transition: opacity 0.3s;
}
[data-theme="light"] .stat-card {
  background: #fff;
  border-color: rgba(0,0,0,0.04);
}
[data-theme="light"] .stat-card::after {
  background: linear-gradient(90deg, transparent, rgba(0,0,0,0.1), transparent);
}
.stat-card:hover {
  background: rgba(30,30,45,0.7);
  border-color: rgba(255,255,255,0.08);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}
.stat-card:hover::after { opacity: 1; }
[data-theme="light"] .stat-card:hover {
  background: #fbfbfd;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
}
.stat-num {
  font-size: 28px;
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: 1;
  color: #fff;
}
.stat-num sup {
  font-size: 0.85rem;
  font-weight: 600;
  vertical-align: super;
}
.stat-num.c-cyan sup { color: var(--cyan); }
.stat-num.c-green sup { color: var(--green); }
.stat-num.c-purple sup { color: var(--purple); }
.stat-lbl {
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 5px;
}



/* ========== ABOUT CARD ========== */
.about-card {
  background: linear-gradient(135deg, rgba(167,139,250,0.06) 0%, rgba(34,211,238,0.04) 100%);
  border-color: rgba(167,139,250,0.12);
}
[data-theme="light"] .about-card {
  background: linear-gradient(135deg, rgba(124,58,237,0.05) 0%, rgba(8,145,178,0.04) 100%);
  border-color: rgba(124,58,237,0.15);
}
[data-theme="light"] .about-text strong { color: #1a1a2e; }
.about-text {
  font-size: var(--fs-base);
  font-weight: 300;
  color: var(--text-dim);
  line-height: 1.85;
}
.about-text strong { color: var(--text); font-weight: 500; }

/* ========== PROJECTS COLUMN ========== */
.projects-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px;
  margin-bottom: 6px;
}
.projects-label {
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dim);
}
.projects-count {
  font-size: 10px;
  font-weight: 600;
  color: var(--cyan);
  background: rgba(34,211,238,0.08);
  border: 1px solid rgba(34,211,238,0.2);
  padding: 3px 10px;
  border-radius: 12px;
}
[data-theme="light"] .projects-count {
  color: var(--cyan);
  background: rgba(8,145,178,0.06);
  border-color: rgba(8,145,178,0.2);
}

.projects-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

/* Tabs Navigation */
.tabs-nav {
  display: flex;
  gap: 0;
  background: rgba(24, 24, 34, 0.4);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding: 4px;
  border-radius: var(--radius-md);
  align-self: flex-start;
  margin-bottom: 0.5rem;
  position: relative;
  border: 1px solid var(--border);
  overflow: hidden;
}

[data-theme="light"] .tabs-nav {
  background: rgba(255, 255, 255, 0.5);
  border-color: rgba(0, 0, 0, 0.05);
}

.tab-indicator {
  position: absolute;
  top: 4px;
  bottom: 4px;
  left: 4px;
  z-index: 0;
  background: var(--card);
  border-radius: calc(var(--radius-md) - 5px);
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

[data-theme="light"] .tab-indicator {
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.06);
}

.tab-btn {
  position: relative;
  z-index: 1;
  background: transparent;
  border: none;
  padding: 9px 20px;
  border-radius: calc(var(--radius-md) - 5px);
  font-family: var(--font);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted);
  cursor: pointer;
  transition: color 0.3s ease;
}

.tab-btn:hover {
  color: var(--text-dim);
}

.tab-btn.active {
  color: var(--cyan);
}

.proj-group {
  display: none;
  animation: fadeIn 0.2s ease forwards;
}

.proj-group.active {
  display: block;
}

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

.proj-category {
  font-size: var(--fs-md);
  font-weight: 600;
  letter-spacing: -0.01em;
  text-transform: none;
  color: var(--text);
  padding: 0 4px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.proj-section {
  background: rgba(12,12,18,0.2);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--sp-md);
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-sm);
}

[data-theme="light"] .proj-section {
  background: rgba(245,245,250,0.4);
}

/* Folder-style Sub-categories */
.proj-folder {
  margin-bottom: 24px;
  position: relative;
}

.proj-folder::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 0;
  width: 100px;
  height: 12px;
  background: var(--card2);
  border: 1px solid var(--border);
  border-bottom: none;
  border-radius: 12px 12px 0 0;
  z-index: 0;
}

[data-theme="light"] .proj-folder::before {
  background: rgba(240,240,248,0.8);
}

.proj-folder .proj-section {
  position: relative;
  z-index: 1;
  background: var(--card2);
  border-radius: 0 16px 16px 16px;
  margin-top: 12px;
}

.proj-card {
  background: rgba(20,20,30,0.4);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,0.03);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  display: flex;
  align-items: center;
  gap: 14px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  text-decoration: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
[data-theme="light"] .proj-card {
  background: #fff;
  border-color: rgba(0,0,0,0.04);
  box-shadow: 0 1px 3px rgba(0,0,0,0.02);
}
.proj-card::before {
  content: '';
  position: absolute;
  left: 0; top: 20%; bottom: 20%;
  width: 3px;
  background: var(--proj-accent, var(--cyan));
  opacity: 0;
  transition: opacity 0.3s, top 0.3s, bottom 0.3s;
  border-radius: 0 3px 3px 0;
}
.proj-card:hover {
  border-color: rgba(255,255,255,0.1);
  background: rgba(26,26,38,0.7);
  transform: translateY(-3px);
  box-shadow: 0 8px 16px rgba(0,0,0,0.2);
}
[data-theme="light"] .proj-card:hover {
  background: #fcfcfd;
  box-shadow: 0 8px 16px rgba(0,0,0,0.05);
}
.proj-card:hover::before {
  opacity: 1;
  top: 0;
  bottom: 0;
}

.proj-icon {
  width: 52px; height: 52px;
  border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  flex-shrink: 0;
  padding: 8px;
  transition: border-color 0.25s, transform 0.2s;
}
[data-theme="light"] .proj-icon {
  background: rgba(240,240,248,0.9);
}
.proj-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: 4px;
}
.proj-card:hover .proj-icon {
  border-color: var(--border-h);
  transform: scale(1.06);
}

.proj-info { flex: 1; min-width: 0; }
.proj-name {
  font-size: 13.5px;
  font-weight: 600;
  color: #fff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 3px;
  transition: color 0.3s;
}
.proj-desc {
  font-size: 11px;
  font-weight: 300;
  color: var(--muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
  line-height: 1.4;
}
.proj-type {
  font-size: 10px;
  font-weight: 500;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 5px;
}
.proj-type-badge {
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--proj-accent, var(--cyan));
  flex-shrink: 0;
}

.proj-btn {
  flex-shrink: 0;
  font-family: var(--font);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.03em;
  padding: 5px 13px;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.18s;
  border: 1px solid;
  white-space: nowrap;
}
.proj-btn.c {
  color: var(--cyan);
  border-color: rgba(34,211,238,0.25);
  background: rgba(34,211,238,0.08);
}
.proj-btn.c:hover { background: rgba(34,211,238,0.18); border-color: var(--cyan); }
.proj-btn.g {
  color: var(--green);
  border-color: rgba(74,222,128,0.25);
  background: rgba(74,222,128,0.08);
}
.proj-btn.g:hover { background: rgba(74,222,128,0.18); border-color: var(--green); }
.proj-btn.p {
  color: var(--purple);
  border-color: rgba(192,132,252,0.25);
  background: rgba(192,132,252,0.08);
}
.proj-btn.p:hover { background: rgba(192,132,252,0.18); border-color: var(--purple); }
.proj-btn.pk {
  color: var(--pink);
  border-color: rgba(244,114,182,0.25);
  background: rgba(244,114,182,0.08);
}
.proj-btn.pk:hover { background: rgba(244,114,182,0.18); border-color: var(--pink); }

/* ========== ANIMATIONS ========== */
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
@keyframes pulse-dot { 0%,100%{box-shadow:0 0 5px var(--cyan)} 50%{box-shadow:0 0 12px var(--cyan), 0 0 24px rgba(34,211,238,0.3)} }
@keyframes avatar-ring-pulse {
  0%,100% { box-shadow: 0 0 0 5px rgba(34,211,238,0.08), 0 0 20px rgba(34,211,238,0.1); }
  50%     { box-shadow: 0 0 0 7px rgba(34,211,238,0.12), 0 0 30px rgba(34,211,238,0.15); }
}
@keyframes fadeSlideUp {
  from { opacity:0; transform: translateY(18px); }
  to   { opacity:1; transform: translateY(0); }
}

.col:nth-child(1) { animation: fadeSlideUp 0.55s 0.05s both; }
.col:nth-child(2) { animation: fadeSlideUp 0.55s 0.18s both; }
.col:nth-child(3) { animation: fadeSlideUp 0.55s 0.3s both; }

/* stagger cards within columns */
.col .card:nth-child(1) { animation: fadeSlideUp 0.45s 0.1s both; }
.col .card:nth-child(2) { animation: fadeSlideUp 0.45s 0.2s both; }
.col .card:nth-child(3) { animation: fadeSlideUp 0.45s 0.3s both; }
.col .card:nth-child(4) { animation: fadeSlideUp 0.45s 0.4s both; }

.proj-card { animation: fadeSlideUp 0.4s both; }

/* ========== RESPONSIVE ========== */
/* ========== RESPONSIVE ========== */
@media (max-width: 1200px) {
  .page { padding-top: calc(var(--sp-lg) + var(--header-offset)); }
  .theme-switch { top: 1.5rem; right: 1.5rem; scale: 0.9; }
}

@media (max-width: 1100px) {
  .page { 
    grid-template-columns: 1fr 1fr; 
    gap: 1.5rem; 
    padding: 6rem 2rem 4rem;
  }
  .col:last-child { grid-column: 1 / -1; margin-top: 0; }
  .projects-list { 
    display: flex;
    flex-direction: column;
    gap: 1.5rem; 
  }
}

@media (max-width: 1024px) {
  /* Horizontal Timeline to Vertical on Tablet */
  .timeline-hz { 
    flex-direction: column; 
    align-items: flex-start; 
    gap: 1.5rem; 
    padding-left: 20px;
  }
  .tl-hz-line { 
    width: 2px; 
    height: 100%; 
    left: 4px; 
    top: 0; 
    right: auto;
  }
  .tl-hz-line::after { width: 100%; height: 50%; }
  .tl-hz-item { 
    flex-direction: row; 
    gap: 20px; 
    align-items: center; 
    width: 100%; 
    justify-content: flex-start;
  }
  .tl-hz-dot { margin-bottom: 0; flex-shrink: 0; }
  .tl-hz-content { text-align: left; }
  .tl-hz-role { font-size: 14px; }
}

@media (max-width: 900px) {
  .page { grid-template-columns: 1fr; }
  .projects-list { display: flex; flex-direction: column; }
}

@media (max-width: 768px) {
  .page { padding: calc(var(--sp-lg) + var(--header-offset)) 1.25rem 3rem; }
  .socials-grid { grid-template-columns: repeat(3, 1fr); gap: 10px; }
  .stats-grid { grid-template-columns: repeat(3, 1fr); gap: 10px; }
}

@media (max-width: 640px) {
  .projects-list { display: flex; flex-direction: column; }
  .socials-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 480px) {
  .profile-inner { flex-direction: column; text-align: center; gap: 10px; }
  .avatar-status { right: 5px; bottom: 5px; }
  .socials-grid { grid-template-columns: repeat(3, 1fr); }
  .stats-grid { grid-template-columns: 1fr; }
  .stat-card { padding: 1.5rem; }
  .tab-btn { padding: 8px 12px; font-size: 10px; }
  
  .proj-card { 
    flex-direction: column; 
    text-align: center; 
    align-items: center; 
    gap: 12px;
    padding: 20px 15px;
  }
  .proj-info { width: 100%; }
  .proj-name { white-space: normal; overflow: visible; }
  .proj-desc { 
    white-space: normal; 
    overflow: hidden; 
    display: -webkit-box; 
    -webkit-line-clamp: 2; 
    line-clamp: 2; 
    -webkit-box-orient: vertical; 
    margin-bottom: 10px; 
  }
  .proj-type { justify-content: center; margin-bottom: 10px; }
  .proj-btn { align-self: stretch; text-align: center; }
}

/* ========== TOOL RESPONSIVENESS ========== */

/* Hide custom cursor on touch devices (tablet & mobile) */
@media (max-width: 1024px), (hover: none) {
  .custom-cursor { display: none !important; }
}

/* Hide theme toggle on tablet & mobile */
@media (max-width: 1024px) {
  .theme-switch { display: none !important; }
}

/* --- Tablet (≤950px) --- */
@media (max-width: 950px) {
  .calculator-grid, .tool-grid, .settings-grid { 
    grid-template-columns: 1fr !important; 
    gap: var(--sp-md) !important; 
  }
  .dashboard-grid { 
    grid-template-columns: 1fr !important; 
  }
  .calc-card, .tool-card { padding: var(--sp-md) !important; }
}

/* --- Tablet & Small Desktop (≤768px) --- */
@media (max-width: 768px) {
  /* Tool page containers (have inline display:block) */
  .page[style*="display: block"],
  .page[style*="display:block"] {
    padding: calc(var(--sp-lg) + var(--header-offset)) 1rem 3rem !important;
    max-width: 100% !important;
  }

  /* Fluid tool page titles (override inline font-size) */
  .page h1,
  .page [style*="font-size: 3rem"],
  .page [style*="font-size: 2.5rem"],
  .page [style*="font-size:3rem"],
  .page [style*="font-size:2.5rem"] {
    font-size: clamp(1.4rem, 5vw, 2.2rem) !important;
  }

  /* Calculator grids to single column */
  .calculator-grid {
    grid-template-columns: 1fr !important;
  }

  /* Dashboard grid (image-resizer etc.) */
  .dashboard-grid {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }

  /* Feature and FAQ grids */
  .features-grid,
  .faq-grid {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }

  /* Card padding reduction */
  .page .card[style*="padding: 3rem"],
  .page .card[style*="padding:3rem"],
  .page .card[style*="padding: 2.5rem"],
  .page .card[style*="padding:2.5rem"] {
    padding: 1.5rem 1rem !important;
  }

  /* Password display */
  .password-display {
    flex-wrap: wrap !important;
    gap: 10px !important;
    padding: 1rem !important;
  }
  .password-display input {
    font-size: 1rem !important;
    min-width: 0 !important;
    width: 100% !important;
  }
  .display-actions {
    width: 100% !important;
    justify-content: center !important;
  }

  /* Strength bars */
  .strength-bar {
    width: 40px !important;
  }

  /* Chart container */
  .chart-container {
    height: 220px !important;
    padding: 0.75rem !important;
  }

  /* Stats and details grids */
  .stats-grid,
  .details-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.75rem !important;
  }

  /* Editing toolbar wrap */
  .editing-toolbar {
    flex-wrap: wrap !important;
    gap: 8px !important;
  }

  /* Preview container height */
  .preview-container {
    min-height: 250px !important;
  }

  /* Options grid */
  .options-grid {
    grid-template-columns: 1fr !important;
  }

  /* Presets grid */
  .presets-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Converter preview boxes */
  .preview-container[id] {
    flex-direction: column !important;
  }
  .preview-box {
    min-width: unset !important;
    width: 100% !important;
  }

  /* Toolbar for signature pad */
  .toolbar {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Prevent overflow in result boxes */
  .result-box,
  .result-box.main {
    overflow: hidden !important;
    word-break: break-word !important;
  }
  .result-value {
    word-break: break-all !important;
    overflow-wrap: break-word !important;
    font-size: clamp(1.2rem, 4vw, 2rem) !important;
  }
  .result-label {
    font-size: 0.7rem !important;
  }

  /* Chart overflow */
  .chart-container {
    overflow: hidden !important;
  }
  .chart-container canvas {
    max-width: 100% !important;
  }

  /* General overflow protection for tool containers */
  .tool-container,
  .calc-card,
  .card {
    overflow: hidden !important;
  }
}

/* --- Mobile (≤640px) --- */
@media (max-width: 640px) {
  .results-summary, .details-grid, .details-list, .features-grid, .options-group, .info-grid { 
    grid-template-columns: 1fr !important; 
    gap: 1rem;
  }
  .instructions-list { grid-template-columns: 1fr !important; gap: 1.5rem; }
  
  .button-group, .tool-controls { flex-direction: column !important; gap: 10px !important; }
  .main-btn, .secondary-btn, .btn { width: 100% !important; flex: none !important; }
  .tabs { flex-wrap: wrap !important; }
  .tab { font-size: 11px !important; padding: 10px !important; }
  
  .page h1 { font-size: var(--fs-xl) !important; }
  .page .card { padding: var(--sp-md) !important; }
  .ip-display { font-size: var(--fs-display) !important; }
  .cp-preview-box { height: 200px !important; }

  /* Stats grid to single column on small phones */
  .stats-grid {
    grid-template-columns: 1fr !important;
  }

  /* Info content benefits grid */
  .info-content [style*="grid-template-columns"] {
    grid-template-columns: 1fr !important;
  }

  /* Toast repositioning for mobile */
  .toast {
    left: 1rem !important;
    right: 1rem !important;
    bottom: 1rem !important;
    text-align: center !important;
  }

  /* Textarea touch-friendly */
  textarea {
    min-height: 150px !important;
    font-size: 16px !important; /* Prevents iOS zoom on focus */
  }
}

/* --- Small Phone (≤480px) --- */
@media (max-width: 480px) {
  .page[style*="display: block"],
  .page[style*="display:block"] {
    padding: 1.5rem 0.75rem 2rem !important;
  }

  .input-field-wrapper, .input-value-wrapper { width: 100% !important; }
  .result-value { font-size: var(--fs-lg) !important; }

  /* Further reduce card padding */
  .calc-card {
    padding: 1rem !important;
  }

  /* Detail cards */
  .detail-card {
    padding: 0.75rem !important;
  }
  .detail-value {
    font-size: 0.95rem !important;
  }

  /* Chart even smaller */
  .chart-container {
    height: 180px !important;
  }

  /* Feature cards compact */
  .feature-card {
    padding: 1.5rem 1rem !important;
  }

  /* Toolbar to single column on very small */
  .toolbar {
    grid-template-columns: 1fr !important;
  }

  /* Control section padding */
  .control-section {
    padding: 1rem !important;
  }

  /* Download button */
  .download-btn {
    padding: 1rem !important;
    font-size: 12px !important;
  }

  .page h1 {
    font-size: clamp(1.2rem, 6vw, 1.8rem) !important;
  }

  /* Converter preview */
  .preview-content {
    min-height: 150px !important;
  }
}

/* ========== HEADER NAV ========== */
.site-header {
  position: fixed;
  top: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2000;
  width: fit-content;
  padding: 0.8rem 1.5rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 50px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);
  transition: all 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.site-header:hover {
  transform: translateX(-50%) translateY(-2px);
  box-shadow: 0 15px 50px rgba(0, 0, 0, 0.15);
  border-color: var(--cyan);
}

.nav-menu {
  display: flex;
  gap: 1.2rem;
  list-style: none;
  align-items: center;
}

.nav-link {
  color: var(--text-dim);
  text-decoration: none;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  transition: all 0.2s;
  padding: 6px 14px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  gap: 6px;
}

.nav-link i {
    font-size: 14px;
}

.nav-link:hover,
.nav-link.active {
  color: var(--cyan);
  background: var(--cyan-glow);
}

@media (max-width: 768px) {
  .site-header {
    top: auto;
    bottom: 1.5rem;
    padding: 0.5rem 0.8rem;
    max-width: 95%;
  }
  .nav-menu {
    gap: 0.3rem;
  }
  .nav-link {
    font-size: 9px;
    padding: 5px 8px;
    gap: 3px;
  }
  .nav-link i {
    font-size: 11px;
  }
}

/* ========== BACKGROUND CANVAS ========== */
#bg-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 0;
  pointer-events: none;
}

/* ========== FOOTER ========== */
.site-footer {
  text-align: center;
  padding: 1rem 1.5rem 2.5rem;
  font-size: 11px;
  color: var(--muted);
  font-weight: 500;
  position: relative;
  z-index: 1;
}
.site-footer p { margin-bottom: 4px; }
.site-footer .highlight {
  color: var(--text-dim);
  font-weight: 700;
  transition: color 0.3s;
}
.site-footer:hover .highlight { color: var(--cyan); }
.site-footer .vibe {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0.6;
}
