/* ═══════════════════════════════════════════
   AI PORTFOLIO — PREMIUM CSS
   Aesthetic: Professional Corporate · Purple Dark
   Fonts: Playfair Display + Plus Jakarta Sans
   ═══════════════════════════════════════════ */

/* ── TOKENS ── */
:root {
  --bg:        #0E0D14;
  --bg-2:      #13121C;
  --bg-card:   #18172A;
  --bg-card-h: #1E1D30;
  --border:    rgba(255,255,255,0.08);
  --border-p:  rgba(139,92,246,0.35);

  --purple:    #8B5CF6;
  --purple-lt: #A78BFA;
  --purple-dk: #6D28D9;
  --purple-bg: rgba(139,92,246,0.08);

  --text:      #F1F0F7;
  --text-2:    #9B97B8;
  --text-3:    #5B5880;

  --success:   #10B981;
  --danger:    #EF4444;

  --r:         12px;
  --r-sm:      8px;
  --r-lg:      20px;

  --shadow:    0 4px 24px rgba(0,0,0,0.4);
  --shadow-p:  0 8px 32px rgba(139,92,246,0.2);

  --font-head: 'Playfair Display', Georgia, serif;
  --font-body: 'Plus Jakarta Sans', system-ui, sans-serif;

  --trans: 0.22s cubic-bezier(0.4,0,0.2,1);
}

[data-theme="light"] {
  --bg:        #F8F7FF;
  --bg-2:      #EFEDFF;
  --bg-card:   #FFFFFF;
  --bg-card-h: #F3F0FF;
  --border:    rgba(0,0,0,0.08);
  --border-p:  rgba(109,40,217,0.3);
  --text:      #1A1830;
  --text-2:    #4B4870;
  --text-3:    #8B88B0;
  --shadow:    0 4px 24px rgba(0,0,0,0.08);
  --shadow-p:  0 8px 32px rgba(109,40,217,0.12);
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  font-size: 16px;
  background: #07070f; /* consistent deep-space base — no patches */
}
body {
  background: transparent;
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ── STARS CANVAS ── */
#starsCanvas {
  position: fixed;
  inset: 0;
  width: 100%; height: 100%;
  z-index: 0;
  pointer-events: none;
}
[data-theme="light"] #starsCanvas { display: none; }

/* Sections — semi-transparent so stars show through uniformly */
.section     { background: rgba(7,7,15,0.80);  position: relative; z-index: 1; }
.section-alt { background: rgba(10,9,20,0.86);  position: relative; z-index: 1; }
[data-theme="light"] .section     { background: var(--bg);  position: relative; z-index: 1; }
[data-theme="light"] .section-alt { background: var(--bg-2); position: relative; z-index: 1; }

/* All fixed UI above canvas */
.navbar, .open-banner, .footer,
#fabResume, #priyaBtn, #priyaPanel { position: relative; z-index: 1; }
a { text-decoration: none; color: inherit; }
button { font-family: var(--font-body); border: none; background: none; cursor: pointer; }
input, textarea, select { font-family: var(--font-body); }
img { max-width: 100%; display: block; }

/* ── NAVBAR ── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 900;
  background: rgba(14,13,20,0.92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--border);
  transition: var(--trans);
}
[data-theme="light"] .navbar { background: rgba(248,247,255,0.92); }

.nav-inner {
  max-width: 1440px; margin: 0 auto;
  display: flex; align-items: center;
  padding: 0 24px; height: 64px; gap: 12px;
}

.nav-brand {
  display: flex; align-items: center; gap: 10px;
  flex-shrink: 0;
}
.brand-mark {
  width: 36px; height: 36px;
  background: var(--purple-dk);
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 700; color: #fff;
}
.brand-mark.sm { width: 28px; height: 28px; font-size: 11px; border-radius: 6px; }
.brand-name { font-weight: 600; font-size: 15px; }

.nav-menu {
  display: flex; gap: 1px;
  flex: 1; justify-content: center;
  flex-wrap: nowrap;
}
.nav-item {
  padding: 6px 9px;
  font-size: 13px; font-weight: 500;
  color: var(--text-2);
  border-radius: 6px;
  transition: var(--trans);
  white-space: nowrap;
}
.nav-item:hover { color: var(--text); background: var(--bg-card); }
.nav-item.active { color: var(--purple-lt); }

.nav-actions { display: flex; align-items: center; gap: 6px; flex-shrink: 0; }

.theme-toggle {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  color: var(--text-2);
  font-size: 15px;
  display: flex; align-items: center; justify-content: center;
  transition: var(--trans);
}
.theme-toggle:hover { border-color: var(--border-p); color: var(--purple-lt); }

.btn-outline-sm {
  padding: 7px 16px;
  border: 1px solid var(--border-p);
  color: var(--purple-lt);
  border-radius: 7px;
  font-size: 13px; font-weight: 600;
  transition: var(--trans);
}
.btn-outline-sm:hover { background: var(--purple-bg); }

.btn-admin-sm {
  padding: 7px 16px;
  background: var(--purple-dk);
  color: #fff;
  border-radius: 7px;
  font-size: 13px; font-weight: 600;
  transition: var(--trans);
}
.btn-admin-sm:hover { background: var(--purple); }

.hamburger {
  display: none; flex-direction: column; gap: 5px;
  width: 36px; height: 36px; align-items: center; justify-content: center;
}
.hamburger span {
  display: block; width: 20px; height: 2px;
  background: var(--text-2); border-radius: 2px; transition: var(--trans);
}

/* ── BUTTONS ── */
.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--purple);
  color: #fff;
  padding: 12px 28px;
  border-radius: 8px;
  font-weight: 600; font-size: 15px;
  border: none; cursor: pointer;
  transition: var(--trans);
}
.btn-primary:hover { background: var(--purple-lt); box-shadow: var(--shadow-p); }
.btn-primary.w-full { width: 100%; justify-content: center; }
.btn-secondary {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid var(--border-p);
  color: var(--purple-lt);
  padding: 12px 28px;
  border-radius: 8px;
  font-weight: 600; font-size: 15px;
  transition: var(--trans);
}
.btn-secondary:hover { background: var(--purple-bg); }
.btn-outline {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid var(--border);
  color: var(--text-2);
  padding: 10px 20px;
  border-radius: 8px;
  font-weight: 500; font-size: 14px;
  transition: var(--trans); cursor: pointer;
}
.btn-outline:hover { border-color: var(--border-p); color: var(--text); }

/* ── CONTAINER ── */
.container { max-width: 1200px; margin: 0 auto; padding: 0 40px; }

/* ── SECTION ── */
.section { padding: 100px 0; }
.section-alt { background: var(--bg-2); }

.section-label {
  display: inline-block;
  font-size: 11px; font-weight: 700;
  letter-spacing: 2.5px; text-transform: uppercase;
  color: var(--purple-lt);
  background: var(--purple-bg);
  border: 1px solid var(--border-p);
  padding: 5px 14px;
  border-radius: 100px;
  margin-bottom: 18px;
}
.section-title {
  font-family: var(--font-head);
  font-size: clamp(34px, 4vw, 54px);
  font-weight: 700;
  letter-spacing: -0.5px;
  line-height: 1.15;
  margin-bottom: 14px;
}
.section-title em {
  font-style: italic;
  color: var(--purple-lt);
}
.section-sub { color: var(--text-2); font-size: 16px; max-width: 560px; }
.section-intro {
  color: var(--text-3); font-size: 0.95rem;
  max-width: 580px; line-height: 1.7;
  margin-bottom: 32px;
}

.section-head {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 24px;
  margin-bottom: 48px; flex-wrap: wrap;
}
.section-head .section-title { margin-bottom: 0; }

/* ── HERO ── */
.hero {
  min-height: 100vh;
  display: flex; align-items: center;
  position: relative;
  padding: 120px 0 80px;
  overflow: hidden;
}
.hero-bg-gradient {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 60% at 75% 50%, rgba(109,40,217,0.12), transparent),
    radial-gradient(ellipse 40% 40% at 10% 80%, rgba(139,92,246,0.07), transparent);
  pointer-events: none;
}

.hero-container {
  max-width: 860px; margin: 0 auto; padding: 0 40px;
  display: flex; flex-direction: column;
  align-items: center; text-align: center;
}

.hero-left {
  width: 100%;
}

.availability-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.3);
  color: #10B981;
  padding: 7px 16px;
  border-radius: 100px;
  font-size: 13px; font-weight: 500;
  margin-bottom: 32px;
}
.avail-dot {
  width: 7px; height: 7px;
  background: #10B981;
  border-radius: 50%;
  animation: pulse-green 2s infinite;
}
@keyframes pulse-green {
  0%, 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.5); }
  50% { box-shadow: 0 0 0 6px rgba(16,185,129,0); }
}

.hero-heading {
  font-family: var(--font-head);
  font-size: clamp(42px, 5vw, 68px);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -1px;
  margin-bottom: 24px;
}
.heading-line { display: block; }
.heading-line.accent { color: var(--purple-lt); }

.hero-bio {
  font-size: 17px; color: var(--text-2);
  line-height: 1.75; margin-bottom: 40px; max-width: 520px;
}

.hero-cta { display: flex; gap: 16px; margin-bottom: 56px; flex-wrap: wrap; justify-content: center; }

.hero-metrics { display: flex; align-items: center; gap: 32px; justify-content: center; flex-wrap: wrap; }
.metric { text-align: center; }
.metric-val {
  font-family: var(--font-head);
  font-size: 36px; font-weight: 700;
  color: var(--text); display: block;
}
.metric-val::after { content: '+'; color: var(--purple-lt); font-size: 24px; }
.metric-lbl { font-size: 12px; color: var(--text-3); letter-spacing: 0.5px; }
.metric-sep { width: 1px; height: 48px; background: var(--border); }

/* ── Currently Building widget ── */
.hero-building {
  display: inline-flex; align-items: center; gap: 10px;
  background: rgba(139,92,246,0.07);
  border: 1px solid rgba(139,92,246,0.2);
  border-radius: 100px;
  padding: 8px 18px 8px 14px;
  margin-bottom: 36px;
  font-size: 13px;
  max-width: 100%;
  overflow: hidden;
}
.hb-pulse {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--purple-lt);
  flex-shrink: 0;
  animation: hbPulse 2s ease-in-out infinite;
}
@keyframes hbPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(139,92,246,0.5); }
  50%       { box-shadow: 0 0 0 5px rgba(139,92,246,0); }
}
.hb-label {
  color: var(--purple-lt); font-weight: 600; white-space: nowrap; flex-shrink: 0;
}
.hb-ticker {
  position: relative; overflow: hidden;
  height: 1.4em; flex: 1; min-width: 0;
}
.hb-item {
  display: block; color: var(--text-2);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  opacity: 0; transform: translateY(12px);
  transition: opacity 0.4s, transform 0.4s;
  position: absolute; top: 0; left: 0; right: 0;
}
.hb-item.active { opacity: 1; transform: translateY(0); }
.hb-item a { color: var(--text-2); text-decoration: none; }
.hb-item a:hover { color: var(--purple-lt); }

/* ── Hero profile photo ── */
.hero-photo-wrap {
  position: relative;
  display: inline-block;
  margin-bottom: 28px;
}
.hero-photo {
  width: 110px; height: 110px;
  border-radius: 50%;
  object-fit: cover;
  object-position: top;
  border: 3px solid rgba(139,92,246,0.55);
  box-shadow: 0 0 0 7px rgba(139,92,246,0.1), 0 12px 36px rgba(0,0,0,0.45);
  display: block;
  position: relative; z-index: 1;
}
.hero-photo-ring {
  position: absolute; inset: -8px;
  border-radius: 50%;
  border: 1.5px solid rgba(139,92,246,0.25);
  animation: heroPhotoRing 3s ease-in-out infinite;
}
@keyframes heroPhotoRing {
  0%, 100% { transform: scale(1); opacity: 0.6; }
  50%       { transform: scale(1.06); opacity: 0.25; }
}

/* PROFILE CARD */
.profile-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 0 0 24px;
  width: 100%;
  text-align: center;
  box-shadow: var(--shadow), 0 0 0 1px rgba(139,92,246,0.08);
  transition: var(--trans);
  overflow: hidden;
  position: relative;
}
.profile-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--purple-dk), var(--purple-lt), #06b6d4);
}
.profile-card:hover {
  border-color: rgba(139,92,246,0.45);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.15),
              0 12px 40px rgba(139,92,246,0.20),
              inset 0 1px 0 rgba(255,255,255,0.04);
  transform: translateY(-3px);
  transition: var(--trans);
}

/* Status bar */
.profile-status-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 20px;
  background: rgba(16,185,129,0.06);
  border-bottom: 1px solid rgba(16,185,129,0.12);
  font-size: 12px;
}
.profile-status-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 0 3px rgba(16,185,129,0.2);
  animation: pulse-green 2s infinite;
  flex-shrink: 0;
}
@keyframes pulse-green {
  0%,100% { box-shadow: 0 0 0 3px rgba(16,185,129,0.2); }
  50%      { box-shadow: 0 0 0 6px rgba(16,185,129,0.08); }
}
.profile-status-text { color: var(--success); font-weight: 600; flex: 1; }
.profile-location { color: var(--text-3); font-size: 11px; white-space: nowrap; }

/* Photo */
.profile-img-wrap {
  width: 120px; height: 120px;
  border-radius: 50%;
  margin: 24px auto 16px;
  border: 3px solid transparent;
  background: linear-gradient(var(--bg-card), var(--bg-card)) padding-box,
              linear-gradient(135deg, var(--purple-dk), var(--purple-lt), #06b6d4) border-box;
  overflow: hidden;
  position: relative;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 24px rgba(139,92,246,0.25);
}
.profile-img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  display: block;
}
.profile-placeholder {
  position: absolute; inset: 0;
  display: none;
  align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--purple-dk), var(--bg-2));
}
.profile-placeholder-initials {
  font-size: 36px; font-weight: 700;
  color: var(--purple-lt);
  font-family: var(--font-head);
}

/* Name & role */
.profile-info { padding: 0 20px; margin-bottom: 16px; }
.profile-info h3 { font-size: 19px; font-weight: 700; margin-bottom: 4px; }
.profile-role { font-size: 12px; color: var(--purple-lt); line-height: 1.5; }

/* Mini stats */
.profile-stats-row {
  display: flex; align-items: center; justify-content: center;
  gap: 0; margin: 0 20px 16px;
  background: var(--bg-2); border-radius: var(--r);
  border: 1px solid var(--border); overflow: hidden;
}
.profile-stat { flex: 1; padding: 10px 4px; text-align: center; }
.profile-stat-val { display: block; font-size: 18px; font-weight: 700; color: var(--purple-lt); line-height: 1; }
.profile-stat-lbl { display: block; font-size: 10px; color: var(--text-3); margin-top: 3px; letter-spacing: 0.3px; }
.profile-stat-sep { width: 1px; height: 36px; background: var(--border); flex-shrink: 0; }

/* Tags */
.profile-tags { display: flex; flex-wrap: wrap; gap: 5px; justify-content: center; margin: 0 20px 16px; }
.ptag {
  font-size: 10.5px;
  padding: 3px 9px;
  border-radius: 100px;
  background: var(--purple-bg);
  border: 1px solid var(--border-p);
  color: var(--purple-lt);
}

/* Links */
.profile-links { display: flex; gap: 8px; justify-content: center; padding: 0 20px; }
.profile-link {
  flex: 1; text-align: center;
  padding: 8px 4px;
  border: 1px solid var(--border);
  border-radius: 8px;
  font-size: 11.5px; font-weight: 600;
  color: var(--text-2); transition: var(--trans);
  text-decoration: none;
}
.profile-link:hover { border-color: var(--border-p); color: var(--purple-lt); background: var(--purple-bg); }

/* ── DATETIME CARD ── */
.hero-right {
  display: flex; flex-direction: column; gap: 14px;
  align-items: stretch; width: 320px;
  align-self: center;
}
.datetime-card {
  width: 100%;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 20px;
  box-shadow: var(--shadow);
  position: relative; overflow: hidden;
}
.datetime-card::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, #06b6d4, var(--purple-lt), var(--purple-dk));
}
.dt-top {
  display: flex; align-items: baseline; gap: 8px;
  justify-content: center; margin-bottom: 4px;
}
.dt-clock {
  font-size: 36px; font-weight: 700; letter-spacing: 2px;
  font-family: 'Courier New', monospace;
  background: linear-gradient(135deg, var(--purple-lt), #06b6d4);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.dt-ampm {
  font-size: 13px; font-weight: 700;
  color: var(--text-3); letter-spacing: 1px;
}
.dt-date {
  text-align: center; font-size: 12px;
  color: var(--text-3); margin-bottom: 16px;
  letter-spacing: 0.3px;
}

/* Calendar */
.dt-cal-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.dt-cal-month {
  font-size: 13px; font-weight: 600; color: var(--text-2);
}
.dt-cal-nav {
  background: none; border: 1px solid var(--border);
  color: var(--text-3); width: 26px; height: 26px;
  border-radius: 6px; cursor: pointer; font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  transition: var(--trans); line-height: 1;
}
.dt-cal-nav:hover { border-color: var(--border-p); color: var(--purple-lt); }
.dt-cal-days-wrap { }
.dt-cal-dow {
  display: grid; grid-template-columns: repeat(7, 1fr);
  text-align: center; font-size: 10px;
  color: var(--text-3); letter-spacing: 0.5px;
  margin-bottom: 4px;
}
.dt-cal-dow span { text-align: center; }
.dt-cal-days {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}
.dt-cal-day, .dt-cal-empty {
  height: 26px; width: 26px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: var(--text-2);
  border-radius: 6px; cursor: default;
  transition: var(--trans);
}
.dt-cal-day:hover {
  background: var(--purple-bg); color: var(--purple-lt);
}
.dt-today {
  background: linear-gradient(135deg, var(--purple-dk), var(--purple));
  color: #fff !important; font-weight: 700;
  box-shadow: 0 2px 10px rgba(139,92,246,0.4);
}

/* ══════════════════════════════════════════════════
   PROJECTS SECTION — ULTRA PREMIUM
══════════════════════════════════════════════════ */

/* Section floating orbs */
/* ════════════════════════════════════════════
   PROJECTS SECTION — ULTRA PREMIUM
════════════════════════════════════════════ */
.proj-sec { position: relative; overflow: hidden; }
.proj-sec-bg { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.proj-sec-orb { position: absolute; border-radius: 50%; filter: blur(110px); }
.proj-sec-orb1 { width: 600px; height: 600px; background: radial-gradient(circle, #6366f1, transparent 70%);
  opacity: .05; top: -150px; right: -120px; animation: pOrb1 20s ease-in-out infinite; }
.proj-sec-orb2 { width: 420px; height: 420px; background: radial-gradient(circle, #a78bfa, transparent 70%);
  opacity: .045; bottom: -100px; left: -100px; animation: pOrb2 24s ease-in-out infinite; }
.proj-sec-orb3 { width: 300px; height: 300px; background: radial-gradient(circle, #06b6d4, transparent 70%);
  opacity: .035; top: 45%; left: 40%; animation: pOrb3 16s ease-in-out infinite; }
@keyframes pOrb1 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-50px,40px)} }
@keyframes pOrb2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(40px,-50px)} }
@keyframes pOrb3 { 0%,100%{transform:translate(-50%,-50%)} 50%{transform:translate(-44%,-44%)} }

/* ── Section header layout ── */
.proj-hd {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 32px;
  margin-bottom: 48px;
}
.proj-hd-left { flex: 1; }
.proj-hd-right { flex-shrink: 0; padding-bottom: 4px; }

.proj-sec-sub {
  font-size: 14px; color: var(--text-3); margin-top: 8px; line-height: 1.65;
  max-width: 480px;
}

/* ── Stat row ── */
.proj-stats-row {
  display: flex; align-items: center; gap: 16px; margin-top: 20px;
}
.proj-stat {
  display: flex; flex-direction: column; gap: 2px;
}
.proj-stat-num {
  font-size: 22px; font-weight: 800; line-height: 1;
  background: linear-gradient(135deg, #a78bfa, #818cf8);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-family: var(--font-head);
}
.proj-stat-lbl {
  font-size: 10px; font-weight: 600; letter-spacing: 0.6px; text-transform: uppercase;
  color: rgba(255,255,255,0.3);
}
.proj-stat-div {
  width: 1px; height: 32px;
  background: linear-gradient(to bottom, transparent, rgba(255,255,255,0.1), transparent);
}

/* ── Filter bar — segmented control ── */
.filter-bar {
  display: flex; gap: 2px;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 12px; padding: 4px;
  backdrop-filter: blur(16px);
}
.filter-btn {
  padding: 8px 16px; border-radius: 8px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.2px;
  color: rgba(255,255,255,0.4); cursor: pointer; border: none;
  background: transparent; transition: all 0.2s ease;
  font-family: var(--font-body);
}
.filter-btn:hover { color: rgba(255,255,255,0.65); background: rgba(255,255,255,0.04); }
.filter-btn.active {
  background: linear-gradient(135deg, rgba(109,40,217,0.55) 0%, rgba(99,102,241,0.45) 100%);
  color: #e9d5ff;
  box-shadow: 0 2px 12px rgba(109,40,217,0.3),
              inset 0 1px 0 rgba(255,255,255,0.12),
              inset 0 -1px 0 rgba(0,0,0,0.2);
}

/* ── Projects grid ── */
.projects-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 16px;
  align-items: start;
}

/* ══════════════════════════════════════
   PROJECT CARD — BASE
══════════════════════════════════════ */
.project-card {
  position: relative;
  display: flex; flex-direction: column;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.09);
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.25),
    0 2px 4px rgba(0,0,0,0.2),
    0 8px 24px rgba(0,0,0,0.18),
    inset 0 1px 0 rgba(255,255,255,0.06);
  transition: transform 0.38s cubic-bezier(0.23,1,0.32,1),
              box-shadow 0.38s cubic-bezier(0.23,1,0.32,1),
              border-color 0.38s ease,
              background 0.38s ease;
  overflow: hidden;
  isolation: isolate;
}

/* Subtle top-edge highlight — always on */
.project-card::before {
  content: '';
  position: absolute; top: 0; left: 10%; right: 10%; height: 1px; z-index: 3;
  background: linear-gradient(90deg, transparent, rgba(139,92,246,0.35), rgba(99,102,241,0.5), rgba(6,182,212,0.25), transparent);
  border-radius: 0 0 4px 4px;
  transition: opacity 0.35s;
  opacity: 0.7;
}

/* Shimmer sweep on hover */
.project-card::after {
  content: '';
  position: absolute; top: 0; left: -60%; width: 45%; height: 100%; z-index: 2;
  background: linear-gradient(105deg, transparent, rgba(255,255,255,0.025), transparent);
  transform: skewX(-15deg);
  transition: left 0s;
  pointer-events: none;
}
.project-card:hover::after {
  left: 130%;
  transition: left 0.55s ease;
}

.project-card:hover {
  transform: translateY(-7px);
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(139,92,246,0.22);
  box-shadow:
    0 0 0 1px rgba(139,92,246,0.12),
    0 4px 8px rgba(0,0,0,0.25),
    0 16px 40px rgba(99,102,241,0.14),
    0 32px 64px rgba(0,0,0,0.25),
    inset 0 1px 0 rgba(255,255,255,0.1),
    inset 0 -1px 0 rgba(139,92,246,0.06);
}
.project-card:hover::before {
  opacity: 1;
  background: linear-gradient(90deg, transparent, rgba(139,92,246,0.65), rgba(99,102,241,0.8), rgba(6,182,212,0.45), transparent);
}
.project-card.hidden { display: none; }

/* ══ FEATURED CARD ══ */
.card-featured {
  background: rgba(109, 40, 217, 0.07);
  backdrop-filter: blur(24px) saturate(1.5);
  -webkit-backdrop-filter: blur(24px) saturate(1.5);
  border-color: rgba(139,92,246,0.18);
  box-shadow:
    0 0 0 1px rgba(109,40,217,0.08),
    0 4px 16px rgba(0,0,0,0.22),
    0 20px 60px rgba(99,102,241,0.1),
    inset 0 1px 0 rgba(139,92,246,0.12);
}
.card-featured:hover {
  background: rgba(109, 40, 217, 0.11);
  border-color: rgba(139,92,246,0.3);
}

/* ── Card number watermark ── */
.card-num-bg {
  position: absolute; bottom: 10px; right: 14px; z-index: 0;
  font-size: 52px; font-weight: 900; line-height: 1; letter-spacing: -2px;
  color: transparent;
  background: linear-gradient(135deg, rgba(99,102,241,0.12), rgba(139,92,246,0.06));
  -webkit-background-clip: text; background-clip: text;
  pointer-events: none; user-select: none;
  font-family: var(--font-head);
  transition: background 0.35s;
}
.project-card:hover .card-num-bg {
  background: linear-gradient(135deg, rgba(139,92,246,0.2), rgba(6,182,212,0.1));
  -webkit-background-clip: text; background-clip: text;
}

/* ── Card inner ── */
.card-inner {
  padding: 18px 20px 12px;
  display: flex; flex-direction: column; gap: 10px; flex: 1;
  position: relative; z-index: 1;
  text-align: left;
}

.card-top {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
}

/* ── Icon ── */
.card-icon {
  font-size: 18px; line-height: 1;
  width: 40px; height: 40px; border-radius: 11px; flex-shrink: 0;
  background: linear-gradient(145deg, rgba(99,102,241,0.14) 0%, rgba(139,92,246,0.08) 100%);
  border: 1px solid rgba(99,102,241,0.18);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.04), 0 2px 8px rgba(99,102,241,0.1);
  transition: all 0.3s cubic-bezier(0.23,1,0.32,1);
}
.project-card:hover .card-icon {
  background: linear-gradient(145deg, rgba(139,92,246,0.24) 0%, rgba(99,102,241,0.14) 100%);
  border-color: rgba(139,92,246,0.3);
  box-shadow: 0 0 0 5px rgba(139,92,246,0.06), 0 6px 20px rgba(139,92,246,0.25);
  transform: scale(1.08) rotate(-4deg);
}

/* ── Featured badge ── */
.card-badge.featured {
  font-size: 9px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  padding: 4px 11px; border-radius: 100px; white-space: nowrap;
  background: rgba(109,40,217,0.18);
  border: 1px solid rgba(139,92,246,0.3);
  color: #c4b5fd;
  box-shadow: 0 0 12px rgba(139,92,246,0.1), inset 0 1px 0 rgba(255,255,255,0.06);
  font-family: var(--font-body);
}

/* ── Category tag (regular cards) ── */
.card-cat {
  font-size: 9.5px; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 100px; white-space: nowrap;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.32);
  font-family: var(--font-body);
}

/* ── Title ── */
.card-title {
  font-size: 14.5px; font-weight: 700; line-height: 1.3;
  color: rgba(255,255,255,0.9); letter-spacing: -0.1px;
  font-family: var(--font-body);
  text-align: left;
}
.card-featured .card-title {
  font-size: 15px; letter-spacing: -0.15px;
  color: #ede9fe;
}

/* ── Description ── */
.card-desc {
  font-size: 12px; color: rgba(255,255,255,0.48); line-height: 1.7; flex: 1; margin: 0;
  font-family: var(--font-body);
  text-align: left;
}

/* ── Stack chips ── */
.card-stack { display: flex; gap: 4px; flex-wrap: wrap; text-align: left; }
.card-stack span {
  font-size: 10px; font-weight: 600; padding: 2px 8px;
  border-radius: 6px;
  background: rgba(99,102,241,0.08);
  border: 1px solid rgba(99,102,241,0.15);
  color: rgba(165,180,252,0.8);
  transition: all 0.18s ease; letter-spacing: 0.1px;
  font-family: var(--font-body);
}
.card-stack span:hover {
  background: rgba(139,92,246,0.14);
  border-color: rgba(139,92,246,0.32);
  color: #c4b5fd; transform: translateY(-1px);
}

/* ── Card footer / CTAs ── */
.card-links {
  display: flex; gap: 5px; flex-wrap: wrap; align-items: center;
  padding: 10px 20px 14px;
  border-top: 1px solid rgba(255,255,255,0.05);
  position: relative; z-index: 1;
  text-align: left;
}
.card-link {
  font-size: 11px; font-weight: 600; letter-spacing: 0.1px;
  padding: 5px 11px; border-radius: 7px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.42);
  transition: all 0.2s ease;
  font-family: var(--font-body);
}
.card-link:hover {
  color: rgba(255,255,255,0.72);
  background: rgba(255,255,255,0.055);
  border-color: rgba(255,255,255,0.11);
  transform: translateY(-1px);
}
.card-link.primary {
  color: #c4b5fd;
  border-color: rgba(139,92,246,0.24);
  background: rgba(109,40,217,0.1);
}
.card-link.primary:hover {
  background: rgba(109,40,217,0.22);
  border-color: rgba(139,92,246,0.5);
  color: #ede9fe;
  box-shadow: 0 3px 14px rgba(139,92,246,0.22);
  transform: translateY(-2px);
}
.card-link.ai-ask {
  color: rgba(110,231,183,0.75);
  border-color: rgba(52,211,153,0.16);
  background: rgba(16,185,129,0.05);
}
.card-link.ai-ask:hover {
  background: rgba(16,185,129,0.11);
  border-color: rgba(52,211,153,0.38);
  color: #a7f3d0;
  box-shadow: 0 3px 12px rgba(16,185,129,0.12);
  transform: translateY(-2px);
}

/* ── SKILLS ── */
.skills-layout {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 32px;
}

.skill-group {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 28px;
}
.skill-group-title {
  font-size: 13px; font-weight: 700;
  letter-spacing: 0.5px; text-transform: uppercase;
  color: var(--text-3); margin-bottom: 24px;
}
.skill-bars { display: flex; flex-direction: column; gap: 18px; }
.skill-row {}
.skill-meta { display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 14px; font-weight: 500; }
.skill-pct { color: var(--purple-lt); font-weight: 600; font-size: 13px; }
.skill-track {
  height: 6px; background: var(--border);
  border-radius: 100px; overflow: hidden;
}
.skill-fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--purple-dk), var(--purple-lt));
  border-radius: 100px;
  transition: width 1.2s cubic-bezier(0.4,0,0.2,1);
}

.tech-cloud { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--r); padding: 28px; }
.tech-tags { display: flex; flex-wrap: wrap; gap: 10px; }
.tech-tag {
  padding: 7px 14px;
  background: var(--purple-bg);
  border: 1px solid var(--border-p);
  border-radius: 7px;
  font-size: 13px; font-weight: 500;
  color: var(--purple-lt);
  transition: var(--trans);
}
.tech-tag:hover { background: rgba(139,92,246,0.16); }

/* ── KNOWLEDGE HUB ── */
.knowledge-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.topic-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 24px;
  cursor: pointer; transition: var(--trans);
  position: relative; overflow: hidden;
}
.topic-card:hover {
  border-color: rgba(139,92,246,0.50);
  background: linear-gradient(145deg, #1c1a2e 0%, #191830 100%);
  transform: translateY(-5px) scale(1.01);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.15),
              0 8px 28px rgba(139,92,246,0.20),
              inset 0 1px 0 rgba(255,255,255,0.04);
}
.topic-card.expanded { border-color: var(--border-p); background: var(--bg-card-h); }

.topic-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.topic-icon-name { display: flex; align-items: center; gap: 10px; }
.topic-icon { font-size: 22px; }
.topic-name { font-size: 16px; font-weight: 700; }
.topic-arrow { color: var(--text-3); font-size: 12px; transition: transform 0.2s; }
.topic-card.expanded .topic-arrow { transform: rotate(90deg); color: var(--purple-lt); }

.topic-desc { font-size: 13px; color: var(--text-2); margin-bottom: 14px; }

.topic-bar { height: 3px; background: var(--border); border-radius: 100px; margin-bottom: 14px; overflow: hidden; }
.topic-bar-fill { height: 100%; background: linear-gradient(90deg, var(--purple-dk), var(--purple-lt)); width: 0; transition: width 1.2s ease; border-radius: 100px; }

.topic-links { display: flex; gap: 8px; }
.tlink {
  font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: 100px;
  background: var(--purple-bg); border: 1px solid var(--border-p);
  color: var(--purple-lt); transition: var(--trans);
}
.tlink:hover { background: rgba(139,92,246,0.2); }

.topic-expand {
  display: none; margin-top: 16px; padding-top: 16px;
  border-top: 1px solid var(--border);
}
.topic-card.expanded .topic-expand { display: block; }
.topic-expand h5 { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-3); margin-bottom: 8px; }
.topic-expand p, .topic-expand li { font-size: 13px; color: var(--text-2); line-height: 1.6; }
.topic-expand ul { padding-left: 16px; display: flex; flex-direction: column; gap: 4px; }

/* ── TIMELINE ── */
.timeline {
  position: relative; max-width: 800px;
  padding-left: 40px;
}
.timeline::before {
  content: '';
  position: absolute; left: 11px; top: 8px; bottom: 8px;
  width: 2px; background: var(--border);
}

.tl-item {
  position: relative; margin-bottom: 48px;
  opacity: 0; transform: translateX(-20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.tl-item.visible { opacity: 1; transform: translateX(0); }

/* Premium timeline items override the base tl-item */
.tl-pitem { transform: translateY(24px) !important; }
.tl-pitem.visible { transform: translateY(0) !important; }

.tl-dot {
  position: absolute; left: -35px; top: 6px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--purple);
  border: 2px solid var(--bg);
  box-shadow: 0 0 0 3px var(--border-p);
}

.tl-date {
  font-size: 12px; font-weight: 600; letter-spacing: 0.5px;
  color: var(--purple-lt); text-transform: uppercase;
  margin-bottom: 8px;
}

.tl-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 24px 28px;
  transition: var(--trans);
}
.tl-card:hover {
  border-color: rgba(139,92,246,0.50);
  background: linear-gradient(145deg, #1d1b30 0%, #191830 100%);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.15),
              0 6px 24px rgba(139,92,246,0.18),
              inset 0 1px 0 rgba(255,255,255,0.04);
  transform: translateY(-3px);
  transition: var(--trans);
}
.tl-card h4 { font-size: 17px; font-weight: 700; margin-bottom: 8px; }
.tl-card p { font-size: 14px; color: var(--text-2); line-height: 1.7; margin-bottom: 14px; }
.tl-tags { display: flex; gap: 8px; flex-wrap: wrap; }
.tl-tags span {
  font-size: 11px; padding: 3px 10px; border-radius: 100px;
  background: var(--purple-bg); border: 1px solid var(--border-p); color: var(--purple-lt);
}

/* ── CHATBOT ── */
.chat-shell {
  display: grid; grid-template-columns: 260px 1fr;
  border: 1px solid var(--border);
  border-radius: var(--r-lg); overflow: hidden;
  background: var(--bg-card);
  box-shadow: var(--shadow);
  max-height: 620px;
}

.chat-sidebar {
  border-right: 1px solid var(--border);
  padding: 20px 16px;
  display: flex; flex-direction: column; gap: 24px;
  overflow-y: auto; background: var(--bg-2);
}
.chat-sidebar::-webkit-scrollbar { width: 4px; }
.chat-sidebar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

.sidebar-section {}
.sidebar-label {
  font-size: 11px; font-weight: 700; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--text-3);
  margin-bottom: 10px;
  display: flex; align-items: center; justify-content: space-between;
}

.model-list { display: flex; flex-direction: column; gap: 4px; }
.model-opt {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px; border-radius: 8px;
  font-size: 13px; font-weight: 500; color: var(--text-2);
  transition: var(--trans); cursor: pointer; text-align: left;
  background: none; width: 100%;
}
.model-opt:hover { background: var(--bg-card); color: var(--text); }
.model-opt.active { background: var(--purple-bg); border: 1px solid var(--border-p); color: var(--purple-lt); }

.provider-badge {
  font-size: 9px; font-weight: 700; letter-spacing: 0.5px;
  padding: 2px 6px; border-radius: 4px; text-transform: uppercase;
}
.provider-badge.groq { background: rgba(6,182,212,0.15); color: #06B6D4; }
.provider-badge.openai { background: rgba(16,163,127,0.15); color: #10A37F; }
.model-speed { font-size: 11px; color: var(--text-3); margin-left: auto; }

.clear-hist {
  font-size: 11px; color: var(--text-3); cursor: pointer;
  background: none; border: none; transition: var(--trans); font-family: var(--font-body);
}
.clear-hist:hover { color: var(--danger); }

.history-list { display: flex; flex-direction: column; gap: 2px; }
.history-empty { font-size: 12px; color: var(--text-3); text-align: center; padding: 12px 0; }

.history-group-label {
  font-size: 10px; font-weight: 700; letter-spacing: 1.2px;
  text-transform: uppercase; color: var(--text-3);
  padding: 10px 6px 4px; margin-top: 4px;
}
.history-group-label:first-child { padding-top: 2px; margin-top: 0; }

/* History item — div container with main button + action buttons */
.history-item {
  display: flex; align-items: center;
  border-radius: 7px; transition: var(--trans);
  position: relative; overflow: hidden;
}
.history-item:hover { background: var(--bg-card); }
.history-item.active {
  background: rgba(124,58,237,0.12);
  border-left: 2px solid var(--purple-lt);
}
.history-item-main {
  flex: 1; min-width: 0;
  display: flex; align-items: center;
  padding: 7px 6px 7px 8px;
  background: none; border: none; cursor: pointer;
  font-size: 12.5px; color: var(--text-2);
  font-family: var(--font-body); text-align: left;
  transition: var(--trans);
}
.history-item:hover .history-item-main { color: var(--text); }
.history-item.active .history-item-main { color: var(--purple-lt); }
.history-item-text {
  flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
/* Action buttons (pin / rename / delete) — hidden until hover */
.history-item-actions {
  display: flex; align-items: center; gap: 1px;
  opacity: 0; transition: var(--trans);
  padding-right: 4px; flex-shrink: 0;
}
.history-item:hover .history-item-actions { opacity: 1; }
.hist-action-btn {
  background: none; border: none; cursor: pointer;
  padding: 3px 5px; border-radius: 4px;
  font-size: 12px; color: var(--text-3);
  transition: var(--trans); line-height: 1;
}
.hist-action-btn:hover { background: var(--bg-card-h); color: var(--text); }
.hist-action-btn.del-btn:hover { color: var(--danger); background: rgba(239,68,68,0.1); }
.hist-action-btn.pin-btn.pinned { color: var(--purple-lt); opacity: 1; }

.quick-btns { display: flex; flex-direction: column; gap: 6px; }
.quick-btns button {
  padding: 8px 12px; border-radius: 7px;
  font-size: 12px; color: var(--text-2);
  border: 1px solid var(--border);
  text-align: left; cursor: pointer; transition: var(--trans);
  background: none; font-family: var(--font-body);
}
.quick-btns button:hover { border-color: var(--border-p); color: var(--text); }

/* CHAT MAIN */
.chat-main { display: flex; flex-direction: column; min-height: 0; }

.chat-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  background: var(--bg-2);
}
.chat-status { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 600; color: var(--text-2); }
.status-indicator {
  width: 8px; height: 8px; border-radius: 50%;
  background: #10B981; animation: pulse-green 2s infinite;
}
.new-chat-btn {
  font-size: 12px; font-weight: 600;
  padding: 6px 14px; border-radius: 6px;
  border: 1px solid var(--border);
  color: var(--text-2); cursor: pointer; transition: var(--trans); font-family: var(--font-body);
}
.new-chat-btn:hover { border-color: var(--border-p); color: var(--purple-lt); }

.chat-messages {
  flex: 1; overflow-y: auto;
  padding: 24px 20px;
  display: flex; flex-direction: column; gap: 20px;
  scroll-behavior: smooth;
}
.chat-messages::-webkit-scrollbar { width: 4px; }
.chat-messages::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

.chat-msg { display: flex; gap: 12px; align-items: flex-start; animation: fadeUp 0.25s ease; }
.chat-msg.user { flex-direction: row-reverse; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }

.msg-avatar {
  width: 34px; height: 34px; border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; flex-shrink: 0;
}
.ai-avatar { background: linear-gradient(135deg, var(--purple-dk), var(--purple-lt)); color: #fff; }
.user-avatar { background: var(--bg-card); border: 1px solid var(--border); color: var(--text-2); }

.msg-body {
  max-width: 520px; padding: 14px 16px;
  border-radius: 4px 12px 12px 12px;
  font-size: 14px; line-height: 1.7;
}
.chat-msg.ai .msg-body {
  background: linear-gradient(135deg, rgba(22,20,42,0.95) 0%, rgba(18,16,36,0.95) 100%);
  border: 1px solid rgba(99,102,241,0.22);
  box-shadow: 0 2px 12px rgba(99,102,241,0.10),
              inset 0 1px 0 rgba(255,255,255,0.03);
}
.chat-msg.user .msg-body {
  background: linear-gradient(135deg, rgba(109,40,217,0.40) 0%, rgba(139,92,246,0.28) 100%);
  border: 1px solid rgba(139,92,246,0.38);
  border-radius: 12px 4px 12px 12px;
  box-shadow: 0 2px 14px rgba(139,92,246,0.16),
              inset 0 1px 0 rgba(255,255,255,0.05);
}
.msg-body p { margin: 0; }
.msg-body strong { color: var(--purple-lt); }

.typing-dots { display: flex; gap: 4px; padding: 4px 0; }
.typing-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--text-3); animation: bounce 1.2s infinite ease;
}
.typing-dot:nth-child(2) { animation-delay: 0.2s; }
.typing-dot:nth-child(3) { animation-delay: 0.4s; }
@keyframes bounce { 0%,100% { transform: translateY(0); opacity:.4; } 50% { transform: translateY(-4px); opacity:1; } }

.chat-input-row {
  display: flex; gap: 10px;
  padding: 16px 20px; border-top: 1px solid var(--border);
  background: var(--bg-2);
}
.chat-input {
  flex: 1; background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 9px; color: var(--text);
  padding: 12px 16px; font-size: 14px; outline: none; transition: var(--trans);
}
.chat-input:focus { border-color: var(--border-p); }
.chat-input::placeholder { color: var(--text-3); }
.chat-send-btn {
  background: var(--purple); color: #fff;
  padding: 12px 22px; border-radius: 9px;
  font-size: 14px; font-weight: 600; cursor: pointer;
  transition: var(--trans); font-family: var(--font-body);
}
.chat-send-btn:hover { background: var(--purple-lt); }
.chat-send-btn:disabled { opacity: 0.5; pointer-events: none; }

/* ── CONTACT ── */
/* ── LEGACY contact classes (kept for JS refs) ── */
.contact-layout { display: none; }
.contact-form   { display: none; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-field { display: flex; flex-direction: column; gap: 7px; }
.form-field label { font-size: 13px; font-weight: 600; color: var(--text-2); }
.form-field input, .form-field textarea {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text);
  padding: 12px 14px; font-size: 14px; outline: none; transition: var(--trans); resize: none;
}
.form-field input:focus, .form-field textarea:focus { border-color: var(--border-p); }
.form-status { font-size: 14px; text-align: center; padding: 10px; border-radius: 7px; display: none; }
.form-status.success { background: rgba(16,185,129,0.1); color: #10B981; border: 1px solid rgba(16,185,129,0.3); display: block; }
.form-status.error   { background: rgba(239,68,68,0.1); color: #EF4444; border: 1px solid rgba(239,68,68,0.3); display: block; }
.mt-24 { margin-top: 24px; display: inline-flex; }
.resume-dl-group { display: flex; gap: 12px; margin-top: 24px; flex-wrap: wrap; }

/* ═══════════════════════════════════════════
   ULTRA PREMIUM CONTACT SECTION
   ═══════════════════════════════════════════ */

.ct-header { text-align: center; margin-bottom: 64px; }
.ct-subtitle {
  font-size: 17px; color: var(--text-2); line-height: 1.75;
  max-width: 500px; margin: 12px auto 0;
}

.ct-layout {
  display: grid; grid-template-columns: 1fr 1.25fr;
  gap: 56px; align-items: start;
}

/* ── Availability badge ── */
.ct-avail {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 20px; border-radius: 100px;
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.22);
  margin-bottom: 32px;
  width: fit-content;
}
.ct-avail-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: #10B981;
  box-shadow: 0 0 0 3px rgba(16,185,129,0.25);
  animation: ctDotPulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes ctDotPulse {
  0%,100% { box-shadow: 0 0 0 3px rgba(16,185,129,0.25); }
  50%     { box-shadow: 0 0 0 6px rgba(16,185,129,0.08); }
}
.ct-avail-text { font-size: 13px; font-weight: 600; color: #34d399; }
.ct-avail-tag {
  font-size: 10px; font-weight: 700; letter-spacing: 1px;
  padding: 3px 10px; border-radius: 100px;
  background: rgba(16,185,129,0.15); color: #6ee7b7;
  text-transform: uppercase;
}

/* ── Contact cards ── */
.ct-cards { display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.ct-card {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 20px; border-radius: 16px;
  background: linear-gradient(135deg, rgba(18,16,36,0.95) 0%, rgba(14,12,28,0.95) 100%);
  border: 1px solid rgba(99,102,241,0.20);
  transition: all 0.26s cubic-bezier(0.4,0,0.2,1);
  position: relative; overflow: hidden;
  box-shadow: 0 4px 20px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.03);
}
.ct-card::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(99,102,241,0.06) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.25s;
}
.ct-card:hover {
  border-color: rgba(139,92,246,0.50);
  transform: translateX(6px);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.15),
              0 8px 28px rgba(139,92,246,0.18),
              inset 0 1px 0 rgba(255,255,255,0.05);
}
.ct-card:hover::before { opacity: 1; }
.ct-card-li:hover { border-color: rgba(10,102,194,0.55); }
.ct-card-gh:hover { border-color: rgba(200,200,200,0.35); }

.ct-card-icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: linear-gradient(145deg, rgba(99,102,241,0.20) 0%, rgba(139,92,246,0.12) 100%);
  border: 1px solid rgba(99,102,241,0.25);
  display: flex; align-items: center; justify-content: center;
  color: #a5b4fc; flex-shrink: 0;
  box-shadow: 0 2px 10px rgba(99,102,241,0.15), inset 0 1px 0 rgba(255,255,255,0.06);
  transition: all 0.22s;
}
.ct-card:hover .ct-card-icon {
  background: linear-gradient(145deg, rgba(139,92,246,0.30) 0%, rgba(99,102,241,0.20) 100%);
  box-shadow: 0 4px 16px rgba(139,92,246,0.25);
}
.ct-card-li .ct-card-icon  { color: #60a5fa; }
.ct-card-gh .ct-card-icon  { color: #e2e8f0; }

.ct-card-body { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.ct-card-label { font-size: 11px; font-weight: 700; letter-spacing: 0.8px; text-transform: uppercase; color: var(--text-3); }
.ct-card-value { font-size: 14px; font-weight: 500; color: var(--text); }

.ct-card-arrow {
  font-size: 18px; color: var(--text-3);
  transition: all 0.22s; flex-shrink: 0;
}
.ct-card:hover .ct-card-arrow { color: var(--purple-lt); transform: translateX(4px); }

/* ── Quick facts ── */
.ct-facts { display: flex; flex-direction: column; gap: 10px; }
.ct-fact {
  display: flex; align-items: center; gap: 12px;
  font-size: 14px; color: var(--text-2);
}
.ct-fact-icon { font-size: 16px; flex-shrink: 0; }

/* ── Form wrapper ── */
.ct-right { position: relative; }
.ct-form-wrap {
  position: relative;
  background: linear-gradient(160deg, #0f0d25 0%, #0c0a1e 55%, #09071a 100%);
  border: 1px solid rgba(99,102,241,0.25);
  border-radius: 24px;
  padding: 40px;
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(99,102,241,0.07),
              0 16px 56px rgba(0,0,0,0.55),
              inset 0 1px 0 rgba(139,92,246,0.08);
}
.ct-form-glow {
  position: absolute; pointer-events: none;
  top: -60px; right: -60px;
  width: 260px; height: 260px; border-radius: 50%;
  background: radial-gradient(circle, rgba(139,92,246,0.12) 0%, transparent 70%);
}
.ct-form-title {
  font-size: 18px; font-weight: 700; color: var(--text);
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid rgba(99,102,241,0.15);
  display: flex; align-items: center; gap: 10px;
}
.ct-form-title::before {
  content: '✉';
  width: 36px; height: 36px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(99,102,241,0.2), rgba(139,92,246,0.15));
  border: 1px solid rgba(99,102,241,0.28);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px;
  box-shadow: 0 2px 10px rgba(99,102,241,0.15);
}
.ct-form { display: flex; flex-direction: column; gap: 18px; }
.ct-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.ct-field { display: flex; flex-direction: column; gap: 7px; }
.ct-field label {
  font-size: 12px; font-weight: 700; letter-spacing: 0.5px;
  text-transform: uppercase; color: var(--text-3);
}
.ct-field input, .ct-field textarea {
  background: rgba(10,8,22,0.7);
  border: 1px solid rgba(99,102,241,0.20);
  border-radius: 12px; color: var(--text);
  padding: 13px 16px; font-size: 14px;
  outline: none; transition: all 0.22s; resize: none;
  font-family: var(--font-body);
  box-shadow: inset 0 2px 8px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.02);
}
.ct-field input:focus, .ct-field textarea:focus {
  border-color: rgba(139,92,246,0.55);
  background: rgba(14,10,28,0.85);
  box-shadow: 0 0 0 3px rgba(139,92,246,0.12),
              inset 0 2px 8px rgba(0,0,0,0.25);
}
.ct-field input::placeholder, .ct-field textarea::placeholder { color: var(--text-3); }

.ct-submit {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; padding: 16px 28px;
  border-radius: 14px; border: none; cursor: pointer;
  font-size: 15px; font-weight: 700; letter-spacing: 0.3px;
  font-family: var(--font-body); color: #fff;
  background: linear-gradient(135deg, #6d28d9 0%, #8b5cf6 50%, #7c3aed 100%);
  background-size: 200% auto;
  box-shadow: 0 4px 20px rgba(139,92,246,0.40), inset 0 1px 0 rgba(255,255,255,0.12);
  transition: all 0.28s cubic-bezier(0.4,0,0.2,1);
  position: relative; overflow: hidden;
}
.ct-submit::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,0.10) 50%, transparent 70%);
  transform: translateX(-100%) skewX(-12deg);
  transition: none;
}
.ct-submit:hover {
  background-position: right center;
  box-shadow: 0 6px 30px rgba(139,92,246,0.60), inset 0 1px 0 rgba(255,255,255,0.15);
  transform: translateY(-2px);
}
.ct-submit:hover::before { animation: shimmerSweep 0.65s ease forwards; }
.ct-submit-icon { font-size: 18px; transition: transform 0.22s; }
.ct-submit:hover .ct-submit-icon { transform: translateX(4px); }

@media (max-width: 900px) {
  .ct-layout { grid-template-columns: 1fr; gap: 36px; }
  .ct-form-grid { grid-template-columns: 1fr; }
  .ct-form-wrap { padding: 28px 22px; }
}

/* ── NAV CONNECT BUTTON ── */
.nav-connect-btn {
  background: linear-gradient(135deg, rgba(109,40,217,0.18) 0%, rgba(139,92,246,0.12) 100%);
  border: 1px solid rgba(139,92,246,0.40);
  border-radius: 20px;
  padding: 5px 16px !important;
  color: #c4b5fd !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 0.2px;
  position: relative; overflow: hidden;
  transition: all 0.24s cubic-bezier(0.4,0,0.2,1) !important;
  box-shadow: 0 2px 12px rgba(139,92,246,0.15), inset 0 1px 0 rgba(255,255,255,0.06);
}
.nav-connect-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(105deg, transparent 30%, rgba(255,255,255,0.08) 50%, transparent 70%);
  transform: translateX(-100%) skewX(-12deg);
}
.nav-connect-btn:hover {
  background: linear-gradient(135deg, rgba(139,92,246,0.35) 0%, rgba(109,40,217,0.28) 100%) !important;
  border-color: rgba(167,139,250,0.65) !important;
  color: #fff !important;
  box-shadow: 0 4px 20px rgba(139,92,246,0.35), inset 0 1px 0 rgba(255,255,255,0.10);
  transform: translateY(-1px);
}
.nav-connect-btn:hover::before { animation: shimmerSweep 0.55s ease forwards; }

/* ═══════════════════════════════════════
   PRIYA AI MEGA DROPDOWN
═══════════════════════════════════════ */
.nav-priya-toggle {
  display: flex; align-items: center; gap: 5px; cursor: pointer;
  background: linear-gradient(135deg,rgba(99,102,241,.15),rgba(236,72,153,.12));
  border: 1px solid rgba(99,102,241,.35); border-radius: 20px;
  padding: 5px 14px !important; font-weight: 600; user-select: none;
  transition: background .2s, border-color .2s, box-shadow .2s;
}
.nav-priya-toggle:hover,
.nav-priya-dd.open .nav-priya-toggle {
  background: linear-gradient(135deg,rgba(99,102,241,.28),rgba(236,72,153,.22));
  border-color: rgba(236,72,153,.5);
  box-shadow: 0 0 18px rgba(99,102,241,.25);
}
.nav-priya-spark { font-size: 11px; color: #a78bfa; animation: priyaSparkSpin 3s linear infinite; display: inline-block; }
@keyframes priyaSparkSpin { to { transform: rotate(360deg); } }
.nav-priya-chevron { font-size: 9px; opacity: .7; transition: transform .2s; }
.nav-priya-dd.open .nav-priya-chevron { transform: rotate(180deg); }

.nav-priya-mega {
  position: absolute; top: calc(100% + 14px); right: -20px;
  width: 580px; max-width: calc(100vw - 32px);
  background: rgba(7,7,20,.94); backdrop-filter: blur(24px) saturate(180%);
  border: 1px solid rgba(99,102,241,.25); border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 24px 64px rgba(0,0,0,.7), 0 0 0 1px rgba(99,102,241,.1);
  opacity: 0; pointer-events: none;
  transform: translateY(-8px) scale(.98);
  transition: opacity .22s ease, transform .22s ease;
  z-index: 400;
}
.nav-priya-dd:hover .nav-priya-mega,
.nav-priya-dd.open  .nav-priya-mega {
  opacity: 1; pointer-events: all; transform: translateY(0) scale(1);
}
.npm-glow-ring {
  position: absolute; inset: -1px; border-radius: 20px; pointer-events: none;
  background: conic-gradient(from 0deg, transparent 0%, #6366f1 20%, #ec4899 40%, #8b5cf6 60%, transparent 80%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; padding: 1px;
  animation: npmRingRotate 4s linear infinite; opacity: .45;
}
@keyframes npmRingRotate { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }
.npm-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid rgba(99,102,241,.12);
  background: linear-gradient(135deg,rgba(99,102,241,.07),rgba(236,72,153,.04));
}
.npm-header-left { display: flex; align-items: center; gap: 12px; }
.npm-logo-wrap {
  position: relative; width: 34px; height: 34px;
  display: flex; align-items: center; justify-content: center;
}
.npm-logo-pulse {
  position: absolute; inset: 0; border-radius: 50%;
  background: linear-gradient(135deg,#6366f1,#ec4899); opacity: .22;
  animation: npmLogoPulse 2s ease-in-out infinite;
}
@keyframes npmLogoPulse { 0%,100%{transform:scale(1);opacity:.22} 50%{transform:scale(1.35);opacity:.1} }
.npm-logo-icon {
  font-size: 15px; position: relative; z-index: 1;
  background: linear-gradient(135deg,#818cf8,#f472b6);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.npm-title {
  font-size: 14px; font-weight: 800; letter-spacing: 1.5px;
  background: linear-gradient(90deg,#93c5fd,#c084fc,#f472b6);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.npm-subtitle { font-size: 10px; color: #475569; margin-top: 1px; }
.npm-live-pill {
  display: flex; align-items: center; gap: 5px;
  background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.2);
  border-radius: 100px; padding: 3px 10px;
  font-size: 10px; font-weight: 600; color: #86efac;
}
.npm-live-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #22c55e;
  animation: npmDotPulse 1.5s ease-in-out infinite;
}
@keyframes npmDotPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.35;transform:scale(.65)} }
.npm-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 1px; background: rgba(99,102,241,.07); padding: 1px;
}
.npm-feat {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 13px 15px; cursor: pointer; position: relative; overflow: hidden;
  background: rgba(7,7,20,.72); transition: background .18s;
}
.npm-feat::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg,rgba(99,102,241,.08),rgba(236,72,153,.05));
  opacity: 0; transition: opacity .18s;
}
.npm-feat:hover { background: rgba(15,15,38,.88); }
.npm-feat:hover::before { opacity: 1; }
.npm-feat-icon-wrap {
  width: 32px; height: 32px; border-radius: 8px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; position: relative; z-index: 1;
  transition: transform .2s;
}
.npm-feat:hover .npm-feat-icon-wrap { transform: scale(1.12) rotate(-4deg); }
.npm-col-blue   { background:rgba(59,130,246,.14); border:1px solid rgba(59,130,246,.24); }
.npm-col-violet { background:rgba(139,92,246,.14); border:1px solid rgba(139,92,246,.24); }
.npm-col-green  { background:rgba(34,197,94,.11);  border:1px solid rgba(34,197,94,.22); }
.npm-col-amber  { background:rgba(245,158,11,.11); border:1px solid rgba(245,158,11,.22); }
.npm-col-pink   { background:rgba(236,72,153,.11); border:1px solid rgba(236,72,153,.22); }
.npm-col-cyan   { background:rgba(6,182,212,.11);  border:1px solid rgba(6,182,212,.22); }
.npm-feat-body  { flex:1; min-width:0; position:relative; z-index:1; }
.npm-feat-title { font-size:11.5px; font-weight:700; color:#e2e8f0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.npm-feat-desc  { font-size:10px; color:#44546a; margin-top:3px; line-height:1.45; }
.npm-feat:hover .npm-feat-desc { color:#64748b; }
.npm-badge {
  flex-shrink:0; font-size:9px; font-weight:700; padding:2px 7px; border-radius:100px;
  letter-spacing:.3px; display:flex; align-items:center; gap:4px;
  white-space:nowrap; position:relative; z-index:1; margin-top:2px; align-self:flex-start;
}
.npm-badge-purple { background:rgba(139,92,246,.14); border:1px solid rgba(139,92,246,.28); color:#c4b5fd; }
.npm-badge-indigo { background:rgba(99,102,241,.14);  border:1px solid rgba(99,102,241,.28); color:#a5b4fc; }
.npm-badge-live   { background:rgba(34,197,94,.09);   border:1px solid rgba(34,197,94,.24); color:#86efac; }
.npm-badge-dot    { width:5px; height:5px; border-radius:50%; background:#22c55e; animation:npmDotPulse 1.5s ease-in-out infinite; }
.npm-cta {
  padding: 13px 20px;
  border-top: 1px solid rgba(99,102,241,.1);
  background: linear-gradient(135deg,rgba(99,102,241,.04),rgba(236,72,153,.02));
}
.npm-cta-btn {
  width:100%; padding:9px 20px; border-radius:11px; border:none;
  background: linear-gradient(135deg,#6366f1 0%,#8b5cf6 50%,#ec4899 100%);
  color:#fff; font-size:12.5px; font-weight:700; letter-spacing:.3px; cursor:pointer;
  position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center; gap:8px;
  box-shadow: 0 4px 18px rgba(99,102,241,.38);
  transition: transform .2s, box-shadow .2s;
}
.npm-cta-btn:hover { transform:translateY(-1px); box-shadow:0 6px 28px rgba(99,102,241,.52); }
.npm-cta-shine {
  position:absolute; inset:0;
  background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.18) 50%,transparent 62%);
  animation: npmShine 2.5s ease-in-out infinite;
}
@keyframes npmShine { 0%{transform:translateX(-100%)} 55%,100%{transform:translateX(200%)} }

@media (max-width: 900px) {
  .nav-priya-mega { width: calc(100vw - 20px); right: -8px; }
  .npm-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .nav-priya-mega {
    position: static; transform: none !important; opacity: 1;
    pointer-events: none; display: none;
    border-radius: 12px; margin-top: 6px; width: 100%;
  }
  .nav-priya-dd.open .nav-priya-mega { display: block; pointer-events: all; }
  .npm-glow-ring { display: none; }
  .npm-grid { grid-template-columns: 1fr; }
}

/* ── NAV PRIYA LINK ── */
.nav-priya-link {
  background: linear-gradient(135deg, rgba(99,102,241,.15), rgba(236,72,153,.15));
  border: 1px solid rgba(99,102,241,.35);
  border-radius: 20px;
  padding: 4px 14px !important;
  color: #a78bfa !important;
  font-weight: 600;
  transition: background .2s, border-color .2s, color .2s;
}
.nav-priya-link:hover {
  background: linear-gradient(135deg, rgba(99,102,241,.3), rgba(236,72,153,.3));
  border-color: rgba(236,72,153,.5);
  color: #f9a8d4 !important;
}

/* ═══════════════════════════════════════
   PRIYA AI FEATURES SECTION (premium)
═══════════════════════════════════════ */
.priya-sec { position: relative; overflow: hidden; }
.priya-sec-bg { position: absolute; inset: 0; pointer-events: none; }
.priya-sec-orb {
  position: absolute; border-radius: 50%; filter: blur(90px); opacity: .18;
}
.priya-sec-orb1 { width: 500px; height: 500px; background: #6366f1; top: -120px; left: -100px; animation: psoMove1 12s ease-in-out infinite; }
.priya-sec-orb2 { width: 400px; height: 400px; background: #ec4899; bottom: -80px; right: -60px;  animation: psoMove2 15s ease-in-out infinite; }
.priya-sec-orb3 { width: 300px; height: 300px; background: #06b6d4; top: 40%;  left: 50%;        animation: psoMove3 10s ease-in-out infinite; }
@keyframes psoMove1 { 0%,100%{transform:translate(0,0)}   50%{transform:translate(40px,30px)} }
@keyframes psoMove2 { 0%,100%{transform:translate(0,0)}   50%{transform:translate(-30px,-40px)} }
@keyframes psoMove3 { 0%,100%{transform:translate(-50%,0)} 50%{transform:translate(-50%,20px)} }

/* Header logo */
.priya-sec-header {
  display: flex; align-items: center; gap: 24px; margin-bottom: 28px;
}
.priya-sec-logo-wrap {
  position: relative; width: 64px; height: 64px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.priya-sec-logo-ring {
  position: absolute; inset: 0; border-radius: 50%;
  background: conic-gradient(from 0deg, #6366f1, #8b5cf6, #ec4899, #6366f1);
  animation: pslRingRotate 4s linear infinite; opacity: .7;
  -webkit-mask: radial-gradient(farthest-side,transparent calc(100% - 2px),#fff 0);
  mask: radial-gradient(farthest-side,transparent calc(100% - 2px),#fff 0);
}
.priya-sec-logo-ring2 {
  position: absolute; inset: 5px; border-radius: 50%;
  background: linear-gradient(135deg,rgba(99,102,241,.15),rgba(236,72,153,.1));
  border: 1px solid rgba(99,102,241,.2);
}
@keyframes pslRingRotate { to { transform: rotate(360deg); } }
.priya-sec-logo-icon {
  position: relative; z-index: 1; font-size: 22px;
  background: linear-gradient(135deg,#818cf8,#f472b6);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

/* Status bar */
.priya-sec-statusbar {
  display: inline-flex; align-items: center; gap: 14px;
  background: rgba(99,102,241,.07); border: 1px solid rgba(99,102,241,.18);
  border-radius: 100px; padding: 7px 18px; margin-bottom: 40px;
  font-size: 12px; color: #64748b;
}
.priya-sec-stat { display: flex; align-items: center; gap: 6px; }
.priya-sec-stat-dot {
  width: 7px; height: 7px; border-radius: 50%; background: #22c55e;
  box-shadow: 0 0 8px #22c55e; animation: psDotPulse 1.8s ease-in-out infinite;
}
@keyframes psDotPulse { 0%,100%{opacity:1} 50%{opacity:.3} }
.priya-sec-divider { width: 1px; height: 14px; background: rgba(99,102,241,.2); }
.priya-sec-stat #priyaSecRepos { color: #a78bfa; font-weight: 700; }

/* Cards grid */
.priya-sec-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; margin-bottom: 44px;
}
.priya-sec-card {
  position: relative; overflow: hidden; cursor: pointer;
  background: linear-gradient(145deg, rgba(10,10,30,.7), rgba(15,15,40,.6));
  border: 1px solid rgba(99,102,241,.18); border-radius: 20px;
  padding: 24px 22px 20px;
  transition: transform .25s, border-color .25s, box-shadow .25s;
  backdrop-filter: blur(10px);
}
.priya-sec-card:hover {
  transform: translateY(-5px);
  border-color: rgba(99,102,241,.45);
  box-shadow: 0 16px 48px rgba(99,102,241,.18), 0 0 0 1px rgba(99,102,241,.1);
}
.priya-sc-glow {
  position: absolute; inset: 0; pointer-events: none; opacity: 0;
  background: radial-gradient(ellipse at 30% 0%, rgba(99,102,241,.15) 0%, transparent 65%);
  transition: opacity .25s;
}
.priya-sec-card:hover .priya-sc-glow { opacity: 1; }

/* Card top row */
.priya-sc-top { display: flex; align-items: flex-start; justify-content: space-between; margin-bottom: 14px; }
.priya-sc-icon {
  width: 44px; height: 44px; border-radius: 12px; font-size: 20px;
  display: flex; align-items: center; justify-content: center;
  transition: transform .2s;
}
.priya-sec-card:hover .priya-sc-icon { transform: scale(1.1) rotate(-4deg); }
.psci-blue   { background:rgba(59,130,246,.14);  border:1px solid rgba(59,130,246,.25); }
.psci-violet { background:rgba(139,92,246,.14);  border:1px solid rgba(139,92,246,.25); }
.psci-green  { background:rgba(34,197,94,.12);   border:1px solid rgba(34,197,94,.22); }
.psci-amber  { background:rgba(245,158,11,.12);  border:1px solid rgba(245,158,11,.22); }
.psci-pink   { background:rgba(236,72,153,.12);  border:1px solid rgba(236,72,153,.22); }
.psci-cyan   { background:rgba(6,182,212,.12);   border:1px solid rgba(6,182,212,.22); }

/* Badges */
.priya-sc-badge {
  font-size: 10px; font-weight: 700; padding: 3px 10px; border-radius: 100px;
  letter-spacing: .3px; display: flex; align-items: center; gap: 5px;
}
.psb-purple { background:rgba(139,92,246,.14); border:1px solid rgba(139,92,246,.28); color:#c4b5fd; }
.psb-indigo { background:rgba(99,102,241,.14);  border:1px solid rgba(99,102,241,.28); color:#a5b4fc; }
.psb-live   { background:rgba(34,197,94,.1);    border:1px solid rgba(34,197,94,.25); color:#86efac; }
.psb-dot    { width:6px; height:6px; border-radius:50%; background:#22c55e; animation:psDotPulse 1.5s ease-in-out infinite; }

/* Card text */
.priya-sc-title {
  font-size: 15px; font-weight: 700; color: #e2e8f0;
  margin: 0 0 8px; line-height: 1.3;
}
.priya-sc-desc {
  font-size: 13px; color: #475569; line-height: 1.6; margin: 0 0 16px;
}
.priya-sec-card:hover .priya-sc-desc { color: #64748b; }

/* Tech tags row */
.priya-sc-footer { display: flex; flex-wrap: wrap; gap: 5px; }
.priya-sc-tag {
  font-size: 10px; font-weight: 500; padding: 2px 8px; border-radius: 100px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  color: #475569; transition: color .18s, border-color .18s;
}
.priya-sec-card:hover .priya-sc-tag { color: #64748b; border-color: rgba(255,255,255,.12); }

/* CTA */
.priya-sec-cta { text-align: center; }
.priya-sec-cta-btn {
  position: relative; display: inline-flex; align-items: center; gap: 10px;
  background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #ec4899 100%);
  border: none; border-radius: 50px; padding: 15px 40px;
  font-size: 16px; font-weight: 700; color: #fff; cursor: pointer;
  overflow: hidden; transition: transform .2s, box-shadow .2s;
  box-shadow: 0 6px 28px rgba(99,102,241,.4);
}
.priya-sec-cta-btn:hover { transform: scale(1.04); box-shadow: 0 10px 40px rgba(99,102,241,.55); }
.priya-sec-cta-shine {
  position: absolute; inset: 0;
  background: linear-gradient(105deg,transparent 35%,rgba(255,255,255,.22) 50%,transparent 65%);
  animation: psCTAShine 2.8s ease-in-out infinite;
}
@keyframes psCTAShine { 0%{transform:translateX(-100%)} 55%,100%{transform:translateX(200%)} }
.priya-sec-cta-ring {
  position: absolute; inset: -2px; border-radius: 50px;
  background: conic-gradient(from 0deg,#6366f1,#ec4899,#06b6d4,#6366f1);
  opacity: 0; transition: opacity .2s; z-index: -1;
  animation: pslRingRotate 3s linear infinite;
}
.priya-sec-cta-btn:hover .priya-sec-cta-ring { opacity: .4; }
.priya-sec-cta-hint { margin-top: 14px; font-size: 13px; color: #334155; }
.priya-sec-cta-hint strong { color: #a78bfa; }

@media (max-width: 900px) { .priya-sec-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 580px) {
  .priya-sec-grid { grid-template-columns: 1fr; }
  .priya-sec-header { flex-direction: column; align-items: flex-start; gap: 16px; }
  .priya-sec-statusbar { flex-wrap: wrap; border-radius: 12px; }
}

/* ── FOOTER ── */
.footer {
  border-top: 1px solid var(--border);
  padding: 24px 40px;
}
.footer-inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 13px; color: var(--text-3);
}
.footer-brand { font-weight: 600; color: var(--text-2); }

/* ── SCROLL ANIMATIONS ── */
.reveal {
  opacity: 0; transform: translateY(20px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ── RESPONSIVE ── */
@media (max-width: 860px) {
  .projects-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .card-num-bg { font-size: 44px; }
  .knowledge-grid { grid-template-columns: repeat(2, 1fr); }
  .skills-layout { grid-template-columns: 1fr; }
  .proj-hd { flex-direction: column; align-items: flex-start; gap: 20px; }
}
@media (max-width: 1100px) {
  .skills-layout { grid-template-columns: 1fr; }
  .proj-hd { flex-direction: column; align-items: flex-start; gap: 20px; }
}
@media (max-width: 900px) {
  .hero-container { grid-template-columns: 1fr; gap: 40px; }
  .hero-right { width: 100%; max-width: 360px; margin: 0 auto; }
  .profile-card, .datetime-card { width: 100%; }
  .contact-layout { grid-template-columns: 1fr; gap: 40px; }
  .chat-shell { grid-template-columns: 1fr; max-height: none; }
  .chat-sidebar { display: none; }
}
@media (max-width: 1100px) {
  .brand-name { display: none; }
}
@media (max-width: 768px) {
  .nav-menu { display: none; }
  .hamburger { display: flex; }
  .nav-menu.open { display: flex; flex-direction: column; position: fixed; top: 64px; left: 0; right: 0; background: var(--bg-2); padding: 20px; border-bottom: 1px solid var(--border); gap: 4px; z-index: 899; }
  .container { padding: 0 20px; }
  .section { padding: 72px 0; }
  .hero-container { padding: 0 20px; }
  .projects-grid { grid-template-columns: 1fr !important; }
  .knowledge-grid { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .footer-inner { flex-direction: column; gap: 8px; text-align: center; }
}

/* ── CHAT LINKS (clickable links in AI responses) ── */
.chat-link {
  color: var(--purple-lt);
  text-decoration: none;
  font-weight: 600;
  border-bottom: 1px solid rgba(167,139,250,0.3);
  padding-bottom: 1px;
  transition: color 0.15s, border-color 0.15s;
}
.chat-link:hover {
  color: #fff;
  border-bottom-color: var(--purple-lt);
}

/* ══════════════════════════════════════════
   NAME CARD — ABOUT SECTION
══════════════════════════════════════════ */
.namecard-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: start;
  padding: 48px 0 16px;
}

/* ── Left panel ── */
.namecard-left {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 14px;
  background: linear-gradient(160deg, #120f28 0%, #0e0c22 55%, #0a0818 100%);
  border: 1px solid rgba(99,102,241,0.22);
  border-radius: 24px;
  padding: 52px 32px;
  position: sticky;
  top: 90px;
  box-shadow: 0 0 0 1px rgba(99,102,241,0.07),
              0 8px 40px rgba(0,0,0,0.50),
              inset 0 1px 0 rgba(139,92,246,0.07);
  transition: var(--trans);
}
.namecard-left:hover {
  border-color: rgba(139,92,246,0.35);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.12),
              0 12px 48px rgba(139,92,246,0.12),
              inset 0 1px 0 rgba(139,92,246,0.10);
}
.namecard-left .namecard-chat { width: 100%; }
.namecard-left .nc-chat-msgs  { max-height: 420px; min-height: 280px; }
.namecard-photo-ring {
  width: 130px; height: 130px;
  border-radius: 50%;
  padding: 3px;
  background: linear-gradient(135deg, var(--purple-dk), #ec4899);
  flex-shrink: 0;
}
.namecard-photo {
  width: 100%; height: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  border: 3px solid var(--bg-card);
}
.namecard-name {
  font-family: var(--font-head);
  font-size: 22px;
  font-weight: 700;
  color: var(--text);
  margin: 0;
  line-height: 1.2;
}
.namecard-role {
  font-size: 13px;
  font-weight: 500;
  color: var(--purple-lt);
  margin: 0;
  letter-spacing: 0.02em;
}
.namecard-meta {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  color: var(--text-2);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 14px 0;
  width: 100%;
}
.namecard-socials {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 4px;
}
.namecard-social-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 50px;
  font-size: 13px;
  font-weight: 600;
  background: var(--bg-card-h);
  border: 1px solid var(--border);
  color: var(--text-2);
  transition: var(--trans);
}
.namecard-social-btn:hover {
  border-color: var(--border-p);
  color: var(--text);
  background: var(--purple-bg);
}
.namecard-social-li:hover { color: #0a66c2; border-color: #0a66c2; }

/* ── Right panel ── */
.namecard-right {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.namecard-bio {
  font-size: 17px;
  color: var(--text-2);
  line-height: 1.75;
  padding: 24px 28px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-left: 4px solid var(--purple);
  border-radius: 16px;
}
.namecard-bio strong { color: var(--text); font-weight: 700; }

.namecard-caps {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.namecard-cap {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 22px 20px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  transition: var(--trans);
}
.namecard-cap:hover {
  border-color: rgba(139,92,246,0.5);
  background: linear-gradient(135deg, rgba(30,26,50,0.98) 0%, rgba(26,24,48,0.98) 100%);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.18),
              0 8px 28px rgba(139,92,246,0.20),
              inset 0 1px 0 rgba(255,255,255,0.05);
  transform: translateY(-5px) scale(1.015);
}
.namecard-cap-icon {
  font-size: 28px;
  line-height: 1;
  flex-shrink: 0;
  margin-top: 2px;
}
.namecard-cap-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 6px;
}
.namecard-cap-desc {
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.6;
}

/* ── Mini PRIYA chat in namecard ── */
/* ── Mini PRIYA Chat — Ultra Premium ── */
.namecard-chat {
  width: 100%;
  position: relative;
  background: #06040f;
  border: 1px solid transparent;
  border-radius: 20px;
  margin-top: 4px;
  overflow: hidden;
  box-shadow: 0 0 0 1px rgba(99,102,241,0.15),
              0 12px 48px rgba(0,0,0,0.70),
              0 0 80px rgba(99,102,241,0.06);
}

/* Animated conic border ring */
.nc-border-ring {
  position: absolute; inset: 0; border-radius: 20px; pointer-events: none; z-index: 0;
  background: conic-gradient(from 0deg, rgba(99,102,241,0.7), rgba(139,92,246,0.4), rgba(236,72,153,0.3), rgba(6,182,212,0.3), rgba(99,102,241,0.7));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding: 1px;
  animation: ncBorderSpin 5s linear infinite;
}
@keyframes ncBorderSpin { to { transform: rotate(360deg); } }

/* Floating orbs */
.nc-bg-orb {
  position: absolute; border-radius: 50%; pointer-events: none; z-index: 0;
}
.nc-bg-orb1 {
  width: 160px; height: 160px;
  top: -40px; left: -40px;
  background: radial-gradient(circle, rgba(99,102,241,0.22) 0%, transparent 70%);
  animation: ncOrb1 8s ease-in-out infinite;
}
.nc-bg-orb2 {
  width: 120px; height: 120px;
  bottom: 20px; right: -30px;
  background: radial-gradient(circle, rgba(139,92,246,0.18) 0%, transparent 70%);
  animation: ncOrb2 10s ease-in-out infinite;
}
.nc-bg-orb3 {
  width: 80px; height: 80px;
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  background: radial-gradient(circle, rgba(6,182,212,0.10) 0%, transparent 70%);
  animation: ncOrb3 6s ease-in-out infinite;
}
@keyframes ncOrb1 {
  0%,100% { transform: translate(0,0) scale(1); }
  33%     { transform: translate(20px,15px) scale(1.15); }
  66%     { transform: translate(-10px,25px) scale(0.9); }
}
@keyframes ncOrb2 {
  0%,100% { transform: translate(0,0) scale(1); }
  40%     { transform: translate(-18px,-12px) scale(1.2); }
  70%     { transform: translate(12px,-20px) scale(0.85); }
}
@keyframes ncOrb3 {
  0%,100% { opacity: 0.6; transform: translate(-50%,-50%) scale(1); }
  50%     { opacity: 1.0; transform: translate(-50%,-50%) scale(1.3); }
}

/* Subtle dot grid overlay */
.nc-bg-grid {
  position: absolute; inset: 0; pointer-events: none; z-index: 0;
  background-image: radial-gradient(circle, rgba(139,92,246,0.12) 1px, transparent 1px);
  background-size: 20px 20px;
  animation: ncGridDrift 20s linear infinite;
}
@keyframes ncGridDrift {
  0%   { background-position: 0 0; }
  100% { background-position: 40px 40px; }
}

/* All inner content above bg layers */
.nc-chat-header,
.nc-chat-msgs,
.nc-chat-input-row { position: relative; z-index: 1; }

.nc-chat-header {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px;
  background: linear-gradient(90deg, rgba(14,10,30,0.92) 0%, rgba(10,8,22,0.88) 100%);
  border-bottom: 1px solid rgba(99,102,241,0.18);
  backdrop-filter: blur(12px);
}

/* Animated gradient border on photo */
.nc-header-photo {
  width: 52px; height: 52px;
  min-width: 52px; min-height: 52px;
  border-radius: 50%;
  object-fit: cover; object-position: center;
  display: block; flex-shrink: 0;
  border: 2px solid transparent;
  background-clip: padding-box;
  box-shadow: 0 0 0 2px rgba(99,102,241,0.5),
              0 0 12px rgba(139,92,246,0.4);
  animation: ncPhotoPulse 3s ease-in-out infinite;
}
@keyframes ncPhotoPulse {
  0%,100% { box-shadow: 0 0 0 2px rgba(99,102,241,0.5), 0 0 12px rgba(139,92,246,0.4); }
  50%     { box-shadow: 0 0 0 2px rgba(139,92,246,0.8), 0 0 20px rgba(236,72,153,0.35); }
}

.nc-header-info { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.nc-header-name { font-size: 13px; font-weight: 700; color: var(--text); line-height: 1.2; }
.nc-header-tag  {
  font-size: 11px; font-weight: 500;
  background: linear-gradient(90deg, #a5b4fc, #c084fc);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}

.nc-chat-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: #4ade80;
  box-shadow: 0 0 0 3px rgba(74,222,128,0.2);
  animation: ncDotPulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes ncDotPulse {
  0%,100% { box-shadow: 0 0 0 3px rgba(74,222,128,0.2); }
  50%     { box-shadow: 0 0 0 6px rgba(74,222,128,0.06); }
}

.nc-chat-msgs {
  padding: 16px 14px;
  display: flex; flex-direction: column; gap: 10px;
  max-height: 224px; overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(99,102,241,0.3) transparent;
  background: transparent;
}
.nc-chat-msgs::-webkit-scrollbar { width: 3px; }
.nc-chat-msgs::-webkit-scrollbar-thumb { background: rgba(99,102,241,0.35); border-radius: 4px; }

.nc-msg {
  font-size: 14px; line-height: 1.6;
  padding: 10px 14px; border-radius: 14px;
  max-width: 92%; word-break: break-word;
  position: relative; animation: ncMsgPop 0.25s cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes ncMsgPop {
  from { opacity: 0; transform: scale(0.88) translateY(6px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}

.nc-bot {
  background: linear-gradient(135deg, rgba(30,24,62,0.80) 0%, rgba(20,16,48,0.70) 100%);
  border: 1px solid rgba(99,102,241,0.28);
  color: var(--text);
  border-bottom-left-radius: 3px;
  align-self: flex-start;
  box-shadow: 0 2px 12px rgba(99,102,241,0.14), inset 0 1px 0 rgba(255,255,255,0.05);
  backdrop-filter: blur(4px);
}
.nc-user {
  background: linear-gradient(135deg, rgba(109,40,217,0.55) 0%, rgba(139,92,246,0.38) 100%);
  border: 1px solid rgba(167,139,250,0.38);
  color: #f1f0f7;
  border-bottom-right-radius: 3px;
  align-self: flex-end; text-align: right;
  box-shadow: 0 2px 14px rgba(139,92,246,0.22), inset 0 1px 0 rgba(255,255,255,0.08);
  backdrop-filter: blur(4px);
}

.nc-typing {
  display: flex; gap: 5px; align-items: center;
  padding: 10px 14px;
  background: linear-gradient(135deg, rgba(30,24,62,0.75) 0%, rgba(20,16,48,0.65) 100%);
  border: 1px solid rgba(99,102,241,0.22);
  border-radius: 14px; border-bottom-left-radius: 3px;
  align-self: flex-start; backdrop-filter: blur(4px);
}
.nc-typing span {
  width: 7px; height: 7px; border-radius: 50%;
  background: linear-gradient(135deg, #818cf8, #c084fc);
  animation: ncDot 1.2s ease-in-out infinite;
  box-shadow: 0 0 6px rgba(129,140,248,0.5);
}
.nc-typing span:nth-child(2) { animation-delay: .22s; }
.nc-typing span:nth-child(3) { animation-delay: .44s; }
@keyframes ncDot {
  0%,80%,100% { transform: scale(0.5); opacity: 0.35; }
  40%         { transform: scale(1.1); opacity: 1; }
}

.nc-chat-input-row {
  display: flex;
  border-top: 1px solid rgba(99,102,241,0.15);
  background: linear-gradient(90deg, rgba(10,7,22,0.92) 0%, rgba(8,5,18,0.92) 100%);
  backdrop-filter: blur(12px);
}
.nc-input {
  flex: 1; background: transparent; border: none; outline: none;
  padding: 14px 16px; font-size: 14px; color: var(--text);
  font-family: var(--font-body);
}
.nc-input::placeholder { color: var(--text-3); }
.nc-send-btn {
  padding: 0 18px;
  background: linear-gradient(135deg, rgba(99,102,241,0.25) 0%, rgba(139,92,246,0.18) 100%);
  border: none; border-left: 1px solid rgba(99,102,241,0.18);
  color: #a5b4fc; font-size: 18px; cursor: pointer;
  transition: all .22s; position: relative; overflow: hidden;
}
.nc-send-btn::after {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(139,92,246,0.4), rgba(236,72,153,0.25));
  opacity: 0; transition: opacity .22s;
}
.nc-send-btn:hover { color: #fff; }
.nc-send-btn:hover::after { opacity: 1; }
.nc-send-btn span { position: relative; z-index: 1; }

/* ── Namecard prompt suggestion buttons ── */
.nc-prompts {
  display: flex; flex-direction: column; gap: 8px;
  padding: 4px 2px;
  animation: ncMsgPop 0.3s cubic-bezier(0.34,1.56,0.64,1) both;
}
.nc-prompt-btn {
  display: flex; align-items: center; gap: 8px;
  width: 100%; text-align: left;
  padding: 10px 14px; border-radius: 12px;
  font-size: 13px; font-weight: 500; color: #c4b5fd;
  font-family: var(--font-body);
  background: linear-gradient(135deg, rgba(30,24,62,0.70) 0%, rgba(20,16,48,0.55) 100%);
  border: 1px solid rgba(99,102,241,0.25);
  cursor: pointer;
  transition: all 0.22s cubic-bezier(0.4,0,0.2,1);
  box-shadow: 0 2px 10px rgba(99,102,241,0.08), inset 0 1px 0 rgba(255,255,255,0.04);
  position: relative; overflow: hidden;
}
.nc-prompt-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(139,92,246,0.12) 0%, transparent 60%);
  opacity: 0; transition: opacity 0.2s;
}
.nc-prompt-btn:hover {
  border-color: rgba(139,92,246,0.55);
  color: #e9d5ff;
  transform: translateX(4px);
  box-shadow: 0 4px 18px rgba(139,92,246,0.20), inset 0 1px 0 rgba(255,255,255,0.06);
}
.nc-prompt-btn:hover::before { opacity: 1; }

/* Responsive */
@media (max-width: 960px) {
  .namecard-wrap { grid-template-columns: 1fr; }
  .namecard-left { position: static; flex-direction: row; text-align: left; border-radius: 16px; padding: 24px; }
  .namecard-meta { flex-direction: row; gap: 16px; border-top: none; border-bottom: none; padding: 0; }
  .namecard-socials { justify-content: flex-start; }
}
@media (max-width: 640px) {
  .namecard-left { flex-direction: column; text-align: center; }
  .namecard-meta { flex-direction: column; }
  .namecard-caps { grid-template-columns: 1fr; }
}


/* ═══════════════════════════════════════════
   NEW FEATURES CSS
   ═══════════════════════════════════════════ */

/* ── OPEN-TO-WORK BANNER ── */
.open-banner {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 950;
  background: linear-gradient(90deg, var(--purple-dk), var(--purple));
  color: #fff;
  display: flex; align-items: center; justify-content: center; gap: 10px;
  height: 40px; padding: 0 48px 0 16px;
  font-size: 13px; font-weight: 500;
  max-height: 40px;
  transition: max-height 0.3s ease, opacity 0.3s ease;
  overflow: hidden;
}
.banner-dot {
  width: 8px; height: 8px;
  background: #4ade80;
  border-radius: 50%;
  box-shadow: 0 0 6px #4ade80;
  flex-shrink: 0;
  animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; } 50% { opacity: 0.4; }
}
.banner-dismiss {
  position: absolute; right: 16px;
  background: none; border: none; color: rgba(255,255,255,0.7);
  font-size: 14px; cursor: pointer; padding: 4px 8px;
  transition: color 0.2s;
}
.banner-dismiss:hover { color: #fff; }
body.has-banner .navbar { top: 40px; }
body.has-banner .hero { padding-top: 164px; }

/* ── FAB RESUME BUTTON ── */
.fab-resume {
  position: fixed; bottom: 32px; right: 32px;
  z-index: 800;
  background: var(--purple);
  color: #fff;
  padding: 12px 22px;
  border-radius: 50px;
  font-size: 14px; font-weight: 600;
  box-shadow: var(--shadow-p);
  opacity: 0;
  transform: translateY(20px);
  transition: var(--trans);
  pointer-events: none;
}
.fab-resume.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.fab-resume:hover { background: var(--purple-lt); transform: translateY(-2px); }

/* ── HERO OUTLINE BUTTON ── */
.btn-outline {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 12px 24px;
  border: 1px solid var(--border-p);
  border-radius: 8px;
  color: var(--purple-lt);
  font-size: 15px; font-weight: 600;
  transition: var(--trans);
}
.btn-outline:hover { background: rgba(139,92,246,0.1); }


/* ── GITHUB STATS BADGE ── */
.github-stats {
  font-size: 11px;
  color: var(--text-3);
  margin: 6px 0;
  min-height: 16px;
}
.gh-stars { color: var(--purple-lt); }

/* ── GITHUB ACTIVITY FEED ── */
.activity-feed {
  display: flex; flex-direction: column; gap: 10px;
  margin-top: 24px;
}
.activity-loading, .activity-empty {
  color: var(--text-3); font-size: 14px; padding: 20px 0;
}
.activity-item {
  display: flex; align-items: flex-start; gap: 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px;
  transition: var(--trans);
}
.activity-item:hover { border-color: var(--border-p); }
.act-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--purple);
  margin-top: 5px;
  flex-shrink: 0;
}
.act-content {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px;
  flex: 1; font-size: 13px;
}
.act-repo {
  color: var(--purple-lt); font-weight: 600;
}
.act-repo:hover { text-decoration: underline; }
.act-msg { color: var(--text-2); flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.act-date { color: var(--text-3); font-size: 11px; white-space: nowrap; }
.activity-more {
  display: inline-block;
  margin-top: 16px;
  color: var(--purple-lt);
  font-size: 13px;
  font-weight: 600;
}
.activity-more:hover { text-decoration: underline; }

/* ── SKILL BADGE GRID ── */
.skill-badge-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 48px;
}
.skill-badge {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-left: 3px solid var(--purple);
  border-radius: var(--r);
  cursor: default;
  transition: var(--trans);
  position: relative;
  overflow: hidden;
}
.skill-badge::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(139,92,246,0.06) 0%, transparent 60%);
  opacity: 0;
  transition: opacity 0.22s;
}
.skill-badge:hover {
  border-left-color: var(--purple-lt);
  border-color: rgba(139,92,246,0.45);
  background: linear-gradient(90deg, rgba(30,26,50,0.95) 0%, rgba(24,23,42,0.95) 100%);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.15),
              0 4px 20px rgba(139,92,246,0.18),
              inset 0 1px 0 rgba(255,255,255,0.04);
  transform: translateX(6px);
}
.skill-badge:hover::before { opacity: 1; }
.sb-icon {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
}
.sb-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  line-height: 1.3;
}

/* ── GITHUB CONTRIBUTION HEATMAP ── */
.gh-heatmap-wrap {
  margin-top: 24px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.gh-stats-row {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.gh-stat {
  font-size: 13px;
  color: var(--text-3);
}
.gh-stat strong {
  color: var(--text);
  font-weight: 700;
}
.gh-profile-link {
  margin-left: auto;
  font-size: 12px;
  color: var(--purple-lt);
  font-weight: 600;
  text-decoration: none;
}
.gh-profile-link:hover { text-decoration: underline; }
.gh-grid-wrap {
  display: flex;
  gap: 6px;
}
.gh-day-labels {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: 30px;
  margin-right: 10px;
}
.gh-day-label {
  height: 24px;
  font-size: 12px;
  color: var(--text-3);
  line-height: 24px;
  margin-bottom: 5px;
  white-space: nowrap;
}
.gh-main {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.gh-month-labels {
  display: grid;
  grid-template-columns: repeat(var(--week-count, 26), 29px);
  margin-bottom: 6px;
  height: 22px;
  padding-left: 62px;
}
.gh-month-lbl {
  font-size: 12px;
  color: var(--text-3);
  white-space: nowrap;
  overflow: visible;
  align-self: center;
  grid-row: 1;
}
.gh-weeks {
  display: flex;
  gap: 5px;
}
.gh-week {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.gh-cell {
  width: 24px;
  height: 24px;
  border-radius: 5px;
  cursor: default;
  transition: opacity 0.2s;
}
.gh-cell:hover { opacity: 0.75; }
.gh-cell.level-0 { background: var(--bg-card); border: 1px solid var(--border); }
.gh-cell.level-1 { background: #0e4429; border: none; }
.gh-cell.level-2 { background: #006d32; border: none; }
.gh-cell.level-3 { background: #26a641; border: none; }
.gh-cell.level-4 { background: #39d353; border: none; }
.gh-legend {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 16px;
  font-size: 12px;
  color: var(--text-3);
  justify-content: flex-end;
}
.gh-legend-cell {
  width: 24px;
  height: 24px;
  border-radius: 5px;
}

/* ── NAV DROPDOWN ── */
.nav-dropdown { position: relative; }
.nav-dropdown-toggle { cursor: pointer; display: flex; align-items: center; gap: 4px; user-select: none; }
.nav-dropdown-menu {
  position: absolute; top: calc(100% + 12px); left: 50%;
  transform: translateX(-50%) translateY(-6px);
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 14px; padding: 10px; box-shadow: 0 16px 48px rgba(0,0,0,0.45);
  opacity: 0; pointer-events: none; transition: opacity 0.18s, transform 0.18s; z-index: 300;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown.open  .nav-dropdown-menu { opacity: 1; pointer-events: all; transform: translateX(-50%) translateY(0); }

/* Wide 2-column layout */
.nav-dropdown-wide { display: flex; gap: 0; min-width: 400px; }
.nav-dd-col { flex: 1; display: flex; flex-direction: column; }
.nav-dd-col-divider { width: 1px; background: var(--border); margin: 0 8px; flex-shrink: 0; }
.nav-dd-group-label {
  font-size: 10px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1.5px; color: var(--text-3); padding: 6px 10px 4px;
}
.nav-dd-divider { height: 1px; background: var(--border); margin: 5px 8px; }

.nav-dropdown-item {
  display: flex; align-items: center; gap: 8px; padding: 7px 10px;
  color: var(--text-2); font-size: 13px; font-weight: 500;
  border-radius: 8px; text-decoration: none; transition: var(--trans); white-space: nowrap;
}
.nav-dropdown-item:hover { background: rgba(139,92,246,0.12); color: var(--purple-lt); }
.nav-dropdown-item.active { color: var(--purple-lt); font-weight: 700; }
.nav-dropdown-toggle.active { color: var(--purple-lt); }

@media (max-width: 768px) {
  .nav-dropdown-menu { position: static; transform: none !important; opacity: 1; pointer-events: all;
    box-shadow: none; background: transparent; border: none; padding: 0 0 0 14px; display: none; min-width: unset; }
  .nav-dropdown-wide { flex-direction: column; }
  .nav-dropdown.open .nav-dropdown-menu { display: flex; }
  .nav-dd-col-divider { display: none; }
  .nav-dd-group-label { padding: 8px 10px 2px; }
  .nav-dropdown-item { padding: 7px 10px; }
}

/* ── STREAMING CURSOR ── */
.chat-msg.streaming .stream-content::after {
  content: '▋';
  animation: blink-cursor 0.7s infinite;
  color: var(--purple-lt);
  font-size: 14px;
}
@keyframes blink-cursor { 50% { opacity: 0; } }

@media (max-width: 640px) {
  .skill-cards-grid { grid-template-columns: repeat(3, 1fr); gap: 10px; }
  .fab-resume { bottom: 20px; right: 20px; padding: 10px 16px; font-size: 13px; }
  .open-banner { font-size: 11px; }
  .banner-text { display: none; }
  .open-banner::after { content: "Open to AI/ML Roles · Available now"; }
  .gh-cell { width: 9px; height: 9px; }
}

/* ══════════════════════════════════════════
   AI LAB SECTION
══════════════════════════════════════════ */
.ailab-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) { .ailab-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .ailab-grid { grid-template-columns: 1fr; } }

.ailab-card {
  display: flex;
  flex-direction: column;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 22px;
  text-decoration: none;
  transition: var(--trans);
  position: relative;
  overflow: hidden;
}
.ailab-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: var(--card-accent, var(--accent));
  opacity: 0;
  transition: opacity 0.2s;
}
.ailab-card:hover {
  border-color: var(--card-accent, var(--accent));
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.25);
}
.ailab-card:hover::before { opacity: 1; }

.ailab-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}
.ailab-icon { font-size: 1.8rem; }

.ailab-badge {
  font-size: 0.65rem;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 20px;
  background: rgba(99,102,241,0.15);
  color: #818cf8;
  border: 1px solid rgba(99,102,241,0.25);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.ailab-badge.live-pulse {
  background: rgba(34,197,94,0.15);
  color: #86efac;
  border-color: rgba(34,197,94,0.25);
  position: relative;
}
.ailab-badge.live-pulse::before {
  content: '';
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #22c55e;
  margin-right: 5px;
  animation: pulse-dot 1.5s infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.4; transform: scale(0.8); }
}

.ailab-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 8px;
}
.ailab-desc {
  font-size: 0.82rem;
  color: var(--text-3);
  line-height: 1.6;
  flex: 1;
  margin-bottom: 14px;
}
.ailab-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
}
.ailab-tags span {
  font-size: 0.68rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  background: rgba(255,255,255,0.05);
  color: var(--text-3);
  border: 1px solid var(--border);
}
.ailab-cta {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--card-accent, var(--accent));
  margin-top: auto;
}

/* ══════════════════════════════════════════
   TECH CATEGORY CARDS
══════════════════════════════════════════ */
.tech-categories {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 32px;
}
@media (max-width: 640px) { .tech-categories { grid-template-columns: 1fr; } }

.tech-cat-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 20px;
  transition: var(--trans);
}
.tech-cat-card:hover {
  border-color: var(--border-p);
  transform: translateY(-2px);
}
.tech-cat-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}
.tech-cat-icon { font-size: 1.1rem; }
.tech-cat-title {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-2);
}

/* ══════════════════════════════════════════
   GITHUB ACTIVITY — FIXES & RECENT EVENTS
══════════════════════════════════════════ */
.activity-error {
  text-align: center;
  padding: 36px 20px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 14px;
}

.gh-recent-title {
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text-3);
  margin: 24px 0 12px;
}

.gh-recent-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.gh-recent-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  transition: var(--trans);
}
.gh-recent-item:hover { background: var(--bg-card); }

.gh-event-icon {
  font-size: 1rem;
  flex-shrink: 0;
  margin-top: 1px;
}

.gh-event-body {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.gh-event-text {
  font-size: 0.83rem;
  color: var(--text-2);
  line-height: 1.5;
  flex: 1;
}

.gh-event-time {
  font-size: 0.72rem;
  color: var(--text-3);
  white-space: nowrap;
  flex-shrink: 0;
}

@media (max-width: 560px) {
  .gh-event-body { flex-direction: column; gap: 2px; }
}

/* ═══════════════════════════════════════════════════
   GITHUB ACTIVITY SECTION — ULTRA PREMIUM
═══════════════════════════════════════════════════ */

/* Section background orbs */
/* ══════════════════════════════════════════
   GITHUB ACTIVITY — Redesigned
══════════════════════════════════════════ */
.act-section { position: relative; overflow: hidden; }
.act-sec-bg  { position: absolute; inset: 0; pointer-events: none; z-index: 0; }
.act-sec-orb { position: absolute; border-radius: 50%; filter: blur(100px); }
.act-sec-orb1 {
  width: 560px; height: 560px; background: #6366f1; opacity: .08;
  top: -160px; left: -100px; animation: actOrb1 16s ease-in-out infinite;
}
.act-sec-orb2 {
  width: 420px; height: 420px; background: #a78bfa; opacity: .07;
  bottom: -100px; right: -60px; animation: actOrb2 20s ease-in-out infinite;
}
.act-sec-orb3 {
  width: 300px; height: 300px; background: #06b6d4; opacity: .06;
  top: 50%; left: 55%; transform: translate(-50%,-50%);
  animation: actOrb3 13s ease-in-out infinite;
}
@keyframes actOrb1 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(40px,30px)} }
@keyframes actOrb2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-30px,-40px)} }
@keyframes actOrb3 { 0%,100%{transform:translate(-50%,-50%)} 50%{transform:translate(-50%,-40%)} }

/* ── Section header row ── */
.act-section-hd {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 16px;
  margin-bottom: 32px;
  position: relative; z-index: 1;
}
.act-section-sub {
  font-size: 14px; color: var(--text-3); margin-top: 6px; line-height: 1.6;
}
.act-gh-profile-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 20px; border-radius: 12px;
  background: rgba(99,102,241,0.1);
  border: 1px solid rgba(99,102,241,0.3);
  color: #a5b4fc; font-size: 13px; font-weight: 600;
  text-decoration: none; white-space: nowrap;
  transition: all 0.2s;
}
.act-gh-profile-btn:hover {
  background: rgba(99,102,241,0.2);
  border-color: rgba(99,102,241,0.6);
  color: #c7d2fe;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(99,102,241,0.2);
}
.act-ghbtn-arrow { font-size: 15px; transition: transform 0.2s; }
.act-gh-profile-btn:hover .act-ghbtn-arrow { transform: translate(2px,-2px); }

/* ── Hero stats strip ── */
.act-hero-strip {
  display: flex; align-items: stretch;
  background: rgba(10,10,30,0.6);
  backdrop-filter: blur(16px);
  border: 1px solid rgba(99,102,241,0.2);
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 24px;
  position: relative; z-index: 1;
}
.act-hero-strip::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, #6366f1, #a78bfa, #06b6d4, #a78bfa, #6366f1);
  background-size: 200% 100%;
  animation: actStripShine 4s linear infinite;
}
@keyframes actStripShine { 0%{background-position:0% 0%} 100%{background-position:200% 0%} }

.act-hs-item {
  flex: 1; display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: 4px;
  padding: 24px 16px;
  position: relative;
  transition: background 0.2s;
}
.act-hs-item:hover { background: rgba(99,102,241,0.07); }
.act-hs-streak { background: rgba(251,146,60,0.04); }
.act-hs-streak:hover { background: rgba(251,146,60,0.08); }

.act-hs-icon-wrap { font-size: 20px; line-height: 1; margin-bottom: 2px; }
.act-hs-val {
  font-size: 32px; font-weight: 900; line-height: 1;
  background: linear-gradient(135deg, #c4b5fd 0%, #818cf8 50%, #60a5fa 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: drop-shadow(0 0 8px rgba(139,92,246,.4));
}
.act-hs-streak .act-hs-val {
  background: linear-gradient(135deg, #fbbf24 0%, #f97316 100%);
  -webkit-background-clip: text; background-clip: text;
  filter: drop-shadow(0 0 8px rgba(251,146,60,.4));
}
.act-hs-lbl {
  font-size: 10px; color: var(--text-3);
  text-transform: uppercase; letter-spacing: 1px; font-weight: 600;
}
.act-hs-div {
  width: 1px; align-self: stretch; margin: 16px 0;
  background: linear-gradient(to bottom, transparent, rgba(139,92,246,.3), transparent);
}

/* ── Layout ── */
.activity-layout {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 20px;
  position: relative; z-index: 1;
}
@media (max-width: 900px) {
  .activity-layout { grid-template-columns: 1fr; }
  .act-section-hd { flex-direction: column; align-items: flex-start; }
  .act-hero-strip { flex-wrap: wrap; }
  .act-hs-item { min-width: 50%; }
}

/* ── Cards ── */
.act-heatmap-card,
.act-feed-card {
  position: relative;
  background: rgba(8,8,22,0.7);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(99,102,241,0.18);
  border-radius: 22px;
  padding: 28px;
  overflow: hidden;
  transition: border-color 0.3s, box-shadow 0.3s;
}
.act-heatmap-card:hover,
.act-feed-card:hover {
  border-color: rgba(99,102,241,0.35);
  box-shadow: 0 12px 40px rgba(99,102,241,0.12);
}
/* Inner glow */
.act-heatmap-card::after,
.act-feed-card::after {
  content: '';
  position: absolute; inset: 0; border-radius: 22px;
  background: radial-gradient(ellipse at 20% 0%, rgba(99,102,241,.07) 0%, transparent 60%);
  pointer-events: none;
}

/* Top accent line per card */
.act-card-accent-line {
  position: absolute; top: 0; left: 28px; right: 28px; height: 2px;
  background: linear-gradient(90deg, transparent, rgba(99,102,241,.7), rgba(167,139,250,.7), transparent);
  border-radius: 0 0 4px 4px;
}

/* Card header */
.act-card-hd {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px; position: relative; z-index: 1;
}
.act-card-hd-left { display: flex; flex-direction: column; gap: 4px; }
.act-card-title {
  font-size: 15px; font-weight: 700;
  background: linear-gradient(90deg, #f1f0f7 0%, #c4b5fd 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.act-card-sub { font-size: 11px; color: var(--text-3); font-weight: 500; }

/* Live pill */
.act-live-pill {
  display: flex; align-items: center; gap: 7px;
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.25);
  padding: 5px 13px; border-radius: 100px;
  font-size: 10.5px; font-weight: 700; color: #34d399;
  box-shadow: 0 0 12px rgba(16,185,129,0.1);
  position: relative; z-index: 1;
}
.act-live-dot {
  width: 7px; height: 7px; border-radius: 50%; background: #10B981;
  animation: actpulse 2s ease-in-out infinite;
}
@keyframes actpulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(16,185,129,0.5); }
  50%      { box-shadow: 0 0 0 5px rgba(16,185,129,0); }
}

/* ── Heatmap ── */
.act-heatmap-wrap {
  display: flex; gap: 6px;
  position: relative; z-index: 1;
  overflow: hidden;
}
.act-hm-days {
  display: flex; flex-direction: column;
  padding-top: 20px;   /* align with month labels height */
  flex-shrink: 0;
}
.act-hm-day {
  height: 17px;        /* 13px cell + 4px gap */
  display: flex; align-items: center;
  font-size: 9px; color: var(--text-3);
  font-weight: 500; letter-spacing: 0.3px;
  line-height: 1; width: 24px;
}
.act-hm-day:last-child { height: 13px; }

.act-hm-grid-wrap { flex: 1; overflow-x: auto; min-width: 0; }
.act-hm-grid-wrap::-webkit-scrollbar { height: 4px; }
.act-hm-grid-wrap::-webkit-scrollbar-track { background: rgba(255,255,255,.04); border-radius: 2px; }
.act-hm-grid-wrap::-webkit-scrollbar-thumb { background: rgba(139,92,246,.35); border-radius: 2px; }

.act-hm-months {
  display: flex; gap: 4px;
  margin-bottom: 4px; height: 16px; align-items: flex-end;
}
.act-hm-month-label {
  width: 13px; font-size: 9px; color: var(--text-3);
  font-weight: 600; white-space: nowrap; overflow: visible;
  letter-spacing: 0.3px; flex-shrink: 0;
}

.act-heatmap {
  display: flex; gap: 4px;
  position: relative;
}
.act-heatmap-col { display: flex; flex-direction: column; gap: 4px; }
.act-heatmap-cell {
  width: 13px; height: 13px; border-radius: 3px;
  flex-shrink: 0; cursor: default;
  transition: transform 0.12s, box-shadow 0.12s;
}
.act-heatmap-cell:hover { transform: scale(1.6); z-index: 2; }
.act-heatmap-loading { font-size: 12px; color: var(--text-3); padding: 32px 0; }

/* Contribution levels */
.act-c0 { background: rgba(255,255,255,0.05); }
.act-c1 { background: rgba(99,102,241,0.28); }
.act-c2 { background: rgba(99,102,241,0.55); }
.act-c3 { background: rgba(139,92,246,0.82); box-shadow: 0 0 3px rgba(139,92,246,.4); }
.act-c4 { background: #a78bfa; box-shadow: 0 0 7px rgba(167,139,250,.7), 0 0 14px rgba(167,139,250,.25); }
.act-heatmap-cell.act-c4:hover { box-shadow: 0 0 12px rgba(167,139,250,.9); }

/* Legend */
.act-heatmap-legend {
  display: flex; align-items: center; gap: 5px;
  margin-top: 12px; justify-content: flex-end;
  position: relative; z-index: 1;
}
.act-legend-label { font-size: 10px; color: var(--text-3); }
.act-legend-cell { width: 12px; height: 12px; border-radius: 3px; }

/* ── Feed ── */
.act-feed {
  display: flex; flex-direction: column; gap: 8px;
  min-height: 200px; position: relative; z-index: 1;
}
.act-feed-loading { font-size: 12px; color: var(--text-3); padding: 24px 0; }

.act-event {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 14px;
  background: rgba(99,102,241,0.05);
  border: 1px solid rgba(99,102,241,0.1);
  border-radius: 14px;
  position: relative;
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s, border-color 0.2s;
  overflow: hidden;
}
.act-event::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(to bottom, #6366f1, #a78bfa, #06b6d4);
}
.act-event:hover {
  transform: translateX(4px);
  box-shadow: 0 4px 24px rgba(99,102,241,0.18);
  border-color: rgba(99,102,241,0.28);
  background: rgba(99,102,241,0.1);
}
.act-event-icon {
  width: 34px; height: 34px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(99,102,241,0.2), rgba(139,92,246,0.25));
  border: 1px solid rgba(139,92,246,0.25);
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
}
.act-event-body { flex: 1; min-width: 0; }
.act-event-repo {
  font-size: 12.5px; font-weight: 700;
  background: linear-gradient(90deg, #f1f0f7, #c4b5fd);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.act-event-msg {
  font-size: 11px; color: var(--text-2); margin-top: 3px; line-height: 1.45;
  overflow: hidden; display: -webkit-box;
  -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.act-event-time {
  font-size: 10px; white-space: nowrap; flex-shrink: 0; margin-top: 2px;
  color: #818cf8; font-weight: 600;
  background: rgba(99,102,241,0.1);
  border: 1px solid rgba(99,102,241,0.18);
  padding: 2px 8px; border-radius: 100px;
}

/* View all */
.act-view-all {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 14px; padding: 9px 18px;
  font-size: 12px; font-weight: 600; color: #a5b4fc;
  background: rgba(99,102,241,0.08);
  border: 1px solid rgba(99,102,241,0.2);
  border-radius: 10px; text-decoration: none;
  transition: all 0.2s; position: relative; z-index: 1;
}
.act-view-all:hover {
  background: rgba(99,102,241,0.16);
  border-color: rgba(99,102,241,0.4);
  color: #c7d2fe; gap: 9px;
  box-shadow: 0 4px 16px rgba(99,102,241,0.15);
}

/* Profile card last-seen badge */
.profile-last-seen {
  font-size: 10.5px; font-weight: 600; color: #10B981;
  background: rgba(16,185,129,0.1); border: 1px solid rgba(16,185,129,0.2);
  padding: 2px 8px; border-radius: 100px;
}


/* ═══════════════════════════════════════════
   PREMIUM HOVER & SHIMMER SYSTEM
   ═══════════════════════════════════════════ */

/* Shimmer sweep keyframe — used on all premium cards */
@keyframes shimmerSweep {
  0%   { transform: translateX(-100%) skewX(-12deg); }
  100% { transform: translateX(220%)  skewX(-12deg); }
}

/* Apply shimmer sweep to capability cards, topic cards, tl-cards */
.namecard-cap, .topic-card, .tl-card, .skill-badge, .chat-welcome-card {
  overflow: hidden;
}
.namecard-cap::before,
.topic-card::before,
.tl-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 45%; height: 100%;
  background: linear-gradient(
    105deg,
    transparent 20%,
    rgba(255,255,255,0.04) 50%,
    transparent 80%
  );
  opacity: 0;
  transition: none;
  pointer-events: none;
  z-index: 2;
}
.namecard-cap:hover::before,
.topic-card:hover::before,
.tl-card:hover::before {
  opacity: 1;
  animation: shimmerSweep 0.65s ease forwards;
}

/* Ensure tl-card has position:relative for shimmer */
.tl-card { position: relative; }

/* Namecard bio hover */
.namecard-bio {
  transition: var(--trans);
}
.namecard-bio:hover {
  border-color: rgba(139,92,246,0.45);
  box-shadow: 0 4px 20px rgba(139,92,246,0.15),
              inset 0 1px 0 rgba(255,255,255,0.04);
  transform: translateY(-2px);
}

/* Namecard right panel premium look */
.namecard-right {
  background: linear-gradient(160deg, #0f0d22 0%, #0c0a1c 55%, #090718 100%);
  border: 1px solid rgba(99,102,241,0.18);
  border-radius: 24px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.45),
              inset 0 1px 0 rgba(139,92,246,0.06);
}

/* Skill group hover */
.skill-group {
  transition: var(--trans);
}
.skill-group:hover {
  border-color: rgba(139,92,246,0.35);
  box-shadow: 0 4px 20px rgba(139,92,246,0.12),
              inset 0 1px 0 rgba(255,255,255,0.03);
  transform: translateY(-2px);
}


/* ═══════════════════════════════════════════
   PREMIUM MY JOURNEY TIMELINE
   ═══════════════════════════════════════════ */

.section-sub {
  font-size: 16px; color: var(--text-2);
  max-width: 520px; margin: -8px 0 52px;
  line-height: 1.7;
}
.tl-premium {
  position: relative;
  display: flex; flex-direction: column; gap: 0;
  max-width: 960px; margin: 0 auto;
}
.tl-premium::before {
  content: '';
  position: absolute; left: 50%; top: 0; bottom: 0; width: 2px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, transparent 0%, rgba(99,102,241,0.7) 8%, rgba(139,92,246,0.8) 30%, rgba(99,102,241,0.7) 60%, rgba(139,92,246,0.6) 80%, transparent 100%);
  box-shadow: 0 0 12px rgba(139,92,246,0.4);
}
.tl-pitem {
  display: grid; grid-template-columns: 1fr 56px 1fr;
  align-items: center; gap: 0; margin-bottom: 40px;
  opacity: 0; transform: translateY(24px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.tl-pitem.visible { opacity: 1; transform: translateY(0); }
.tl-pitem-left .tl-pcard  { grid-column: 1; grid-row: 1; padding-right: 32px; }
.tl-pitem-left .tl-pnode  { grid-column: 2; grid-row: 1; justify-self: center; }
.tl-pitem-right .tl-pnode { grid-column: 2; grid-row: 1; justify-self: center; }
.tl-pitem-right .tl-pcard { grid-column: 3; grid-row: 1; padding-left: 32px; }

.tl-pnode {
  position: relative; width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  z-index: 2; flex-shrink: 0;
}
.tl-pnode-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 2px solid rgba(139,92,246,0.5);
  animation: tlRingPulse 2.8s ease-in-out infinite;
}
@keyframes tlRingPulse {
  0%,100% { transform: scale(1);    border-color: rgba(139,92,246,0.5); box-shadow: 0 0 0 0 rgba(139,92,246,0); }
  50%     { transform: scale(1.12); border-color: rgba(139,92,246,0.9); box-shadow: 0 0 16px 4px rgba(139,92,246,0.3); }
}
.tl-pnode-dot {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(145deg, #13102a, #1a1535);
  border: 1.5px solid rgba(139,92,246,0.45);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; position: relative; z-index: 1;
  box-shadow: 0 0 0 3px rgba(99,102,241,0.12), 0 0 20px rgba(139,92,246,0.25), inset 0 1px 0 rgba(255,255,255,0.08);
}
.tl-pcard {
  position: relative;
  background: linear-gradient(145deg, #111028 0%, #0e0d22 100%);
  border: 1px solid rgba(99,102,241,0.22); border-radius: 18px; overflow: hidden;
  transition: all 0.28s cubic-bezier(0.4,0,0.2,1);
  box-shadow: 0 4px 24px rgba(0,0,0,0.45), inset 0 1px 0 rgba(139,92,246,0.07);
}
.tl-pcard:hover {
  border-color: rgba(139,92,246,0.55); transform: translateY(-5px) scale(1.01);
  box-shadow: 0 0 0 1px rgba(139,92,246,0.18), 0 12px 40px rgba(139,92,246,0.22), inset 0 1px 0 rgba(255,255,255,0.06);
}
.tl-pcard:hover .tl-pcard-glow { opacity: 1; }
.tl-pcard-glow {
  position: absolute; inset: 0; border-radius: 18px; pointer-events: none;
  background: radial-gradient(ellipse 60% 50% at 20% 0%, rgba(139,92,246,0.12) 0%, transparent 70%);
  opacity: 0; transition: opacity 0.35s;
}
.tl-pcard-inner { padding: 26px 28px; position: relative; z-index: 1; }
.tl-pcard-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px; gap: 10px; flex-wrap: wrap;
}
.tl-ptype {
  font-size: 11px; font-weight: 700; letter-spacing: 0.5px;
  padding: 4px 12px; border-radius: 100px;
}
.tl-ptype-freelance { background: rgba(16,185,129,0.12); border: 1px solid rgba(16,185,129,0.30); color: #34d399; }
.tl-ptype-work      { background: rgba(99,102,241,0.12); border: 1px solid rgba(99,102,241,0.30); color: #a5b4fc; }
.tl-ptype-edu       { background: rgba(245,158,11,0.10); border: 1px solid rgba(245,158,11,0.28); color: #fbbf24; }
.tl-pyear { font-size: 12px; font-weight: 600; letter-spacing: 0.4px; color: var(--text-3); text-transform: uppercase; }
.tl-pcompany { font-size: 11.5px; font-weight: 600; color: var(--text-3); letter-spacing: 0.04em; text-transform: uppercase; margin-bottom: 4px; }
.tl-ptitle { font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 10px; line-height: 1.3; }
.tl-pdesc  { font-size: 14px; color: var(--text-2); line-height: 1.75; margin-bottom: 16px; }
.tl-ptags  { display: flex; gap: 6px; flex-wrap: wrap; }
.tl-ptags span {
  font-size: 11px; font-weight: 600; letter-spacing: 0.2px;
  padding: 4px 12px; border-radius: 100px;
  background: rgba(99,102,241,0.10); border: 1px solid rgba(99,102,241,0.25);
  color: var(--purple-lt); transition: all 0.18s;
}
.tl-ptags span:hover { background: rgba(139,92,246,0.22); border-color: rgba(139,92,246,0.50); transform: translateY(-1px); }

@media (max-width: 768px) {
  .tl-premium::before { left: 24px; }
  .tl-pitem, .tl-pitem-left, .tl-pitem-right { grid-template-columns: 48px 1fr; }
  .tl-pitem-left .tl-pnode, .tl-pitem-right .tl-pnode { grid-column: 1; grid-row: 1; justify-self: center; }
  .tl-pitem-left .tl-pcard, .tl-pitem-right .tl-pcard { grid-column: 2; grid-row: 1; padding-left: 16px; padding-right: 0; }
}


/* ═══════════════════════════════════════════
   PREMIUM PRIYA VOICE BUTTON
   ═══════════════════════════════════════════ */

.priya-logo-halo1 {
  position: absolute; inset: -20px; border-radius: 50%;
  background: conic-gradient(from 0deg, rgba(37,99,235,0), rgba(124,58,237,0.18), rgba(236,72,153,0.12), rgba(6,182,212,0.10), rgba(37,99,235,0));
  animation: priyaHalo1Spin 6s linear infinite;
}
@keyframes priyaHalo1Spin { to { transform: rotate(360deg); } }

.priya-logo-halo2 {
  position: absolute; inset: -10px; border-radius: 50%;
  border: 1px solid rgba(139,92,246,0.18);
  animation: priyaHalo2Pulse 3.5s ease-in-out infinite;
}
@keyframes priyaHalo2Pulse {
  0%,100% { transform: scale(1);    opacity: 0.5; }
  50%     { transform: scale(1.08); opacity: 1.0; }
}

.priya-logo-halo3 {
  position: absolute; inset: -28px; border-radius: 50%;
  border: 1px solid rgba(99,102,241,0.10);
  animation: priyaHalo3Pulse 4.5s ease-in-out infinite reverse;
}
@keyframes priyaHalo3Pulse {
  0%,100% { transform: scale(1);    opacity: 0.3; }
  50%     { transform: scale(1.06); opacity: 0.7; }
}

.priya-logo-spin-ring {
  animation: priyaSpinRing 2.2s linear infinite;
  background: conic-gradient(from 0deg, #2563EB 0%, #7C3AED 20%, #EC4899 40%, #06B6D4 60%, #10B981 80%, #2563EB 100%);
}
.priya-logo-spin-ring2 {
  position: absolute; inset: 4px; border-radius: 50%;
  background: conic-gradient(from 180deg, rgba(6,182,212,0.5) 0%, rgba(124,58,237,0.5) 33%, rgba(236,72,153,0.4) 66%, rgba(6,182,212,0.5) 100%);
  animation: priyaSpinRing 3.8s linear infinite reverse;
  -webkit-mask: radial-gradient(farthest-side, transparent calc(100% - 2px), #fff 0);
          mask: radial-gradient(farthest-side, transparent calc(100% - 2px), #fff 0);
}

.priya-logo-glow1 {
  inset: -10px;
  background: radial-gradient(circle, rgba(124,58,237,0.45) 0%, rgba(37,99,235,0.15) 50%, transparent 70%);
  animation: priyaGlowPulse 2s ease-in-out infinite;
}
.priya-logo-glow2 {
  inset: -18px;
  background: radial-gradient(circle, rgba(236,72,153,0.20) 0%, rgba(6,182,212,0.12) 40%, transparent 70%);
  animation: priyaGlowPulse 2.8s ease-in-out infinite reverse;
}

.priya-logo-orbit3 {
  position: absolute; width: 100%; height: 100%; border-radius: 50%;
  animation: priyaOrbit 4s linear infinite; animation-delay: -2s;
}
.priya-logo-orbit3::before {
  content: ''; position: absolute; right: 3px; top: 50%; transform: translateY(-50%);
  width: 4px; height: 4px; border-radius: 50%;
  background: #34d399; box-shadow: 0 0 8px #34d399, 0 0 14px rgba(52,211,153,0.5);
}

.priya-logo-core {
  background: linear-gradient(145deg, #0d1424, #162040, #0d1424);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.10), inset 0 -1px 0 rgba(0,0,0,0.3), 0 0 28px rgba(37,99,235,0.4), 0 0 50px rgba(124,58,237,0.15);
  animation: priyaCoreShimmer 4s ease-in-out infinite;
}
@keyframes priyaCoreShimmer {
  0%,100% { box-shadow: inset 0 1px 0 rgba(255,255,255,0.10), 0 0 28px rgba(37,99,235,0.4), 0 0 50px rgba(124,58,237,0.15); }
  50%     { box-shadow: inset 0 1px 0 rgba(255,255,255,0.14), 0 0 38px rgba(124,58,237,0.55), 0 0 65px rgba(236,72,153,0.18); }
}

.priya-logo-mic {
  font-size: 26px;
  animation: priyaMicFloat 2.5s ease-in-out infinite;
  filter: drop-shadow(0 0 6px rgba(99,102,241,0.7));
}
@keyframes priyaMicFloat {
  0%,100% { transform: translateY(0)   scale(1);    filter: drop-shadow(0 0 6px rgba(99,102,241,0.7)); }
  50%     { transform: translateY(-3px) scale(1.08); filter: drop-shadow(0 0 12px rgba(139,92,246,1.0)); }
}

.priya-logo-label {
  font-size: 10px; font-weight: 900; letter-spacing: 4px;
  background: linear-gradient(90deg,#60A5FA,#C084FC,#F472B6,#60A5FA);
  background-size: 200% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: priyaLabelShift 3s linear infinite; opacity: 0.95;
}
@keyframes priyaLabelShift {
  0%   { background-position: 0%   center; }
  100% { background-position: 200% center; }
}

.priya-wave-ring {
  position: absolute; inset: 0; border-radius: 50%;
  border: 1.5px solid rgba(139,92,246,0.55);
  animation: priyaWaveEmit 2.4s ease-out infinite;
  pointer-events: none;
}
.priya-wave-ring:nth-child(2) { animation-delay: 0.8s; }
.priya-wave-ring:nth-child(3) { animation-delay: 1.6s; }
@keyframes priyaWaveEmit {
  0%   { transform: scale(1);   opacity: 0.7; }
  100% { transform: scale(2.2); opacity: 0; }
}

#priyaBtn:hover .priya-logo-core {
  transform: scale(1.10);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.15), 0 0 48px rgba(124,58,237,0.7), 0 0 80px rgba(236,72,153,0.25);
}
#priyaBtn:hover .priya-logo-spin-ring { animation-duration: 1.2s; }
#priyaBtn:hover .priya-logo-halo1     { animation-duration: 2s; }
