/* ============================================
   pages.css — Page-specific styles
   ============================================ */

/* ============== HERO (index.html) ============== */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-top: 120px;
  padding-bottom: 60px;
  position: relative;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 60px;
  align-items: center;
}
.hero-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 50px;
  font-size: 0.85rem;
  color: var(--text-2);
  margin-bottom: 28px;
  backdrop-filter: blur(10px);
}
.hero-tag .dot {
  width: 8px; height: 8px;
  background: #22c55e;
  border-radius: 50%;
  animation: statusPulse 2s ease-in-out infinite;
}
.hero-title {
  font-size: clamp(2.4rem, 5.2vw, 4.2rem);
  margin-bottom: 18px;
}
.hero-title .typewrap {
  display: inline-block;
  color: var(--primary);
  min-width: 1ch;
}
.hero-sub {
  font-size: 1.05rem;
  color: var(--text-2);
  margin-bottom: 16px;
  max-width: 520px;
}
.hero-sub .pill {
  display: inline-block;
  padding: 2px 0;
  border-bottom: 1px dashed var(--glass-border);
}
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 28px; }

/* Hero visual / mascot area */
.hero-visual {
  position: relative;
  height: 480px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.mascot-wrap {
  position: relative;
  width: 320px;
  height: 380px;
}
.mascot-svg { width: 100%; height: 100%; }
.orbit-wrapper {
  position: absolute;
  inset: -40px;
  pointer-events: none;
}
.orbit-badge {
  position: absolute;
  top: 50%; left: 50%;
  width: 130px;
  margin-left: -65px;
  margin-top: -22px;
  pointer-events: auto;
  transform-origin: center;
}
/* Place each badge on a circle radius */
.orbit-badge.b1 { transform: rotate(0deg)   translateY(-200px) rotate(0deg); }
.orbit-badge.b2 { transform: rotate(90deg)  translateY(-200px) rotate(-90deg); }
.orbit-badge.b3 { transform: rotate(180deg) translateY(-200px) rotate(-180deg); }
.orbit-badge.b4 { transform: rotate(270deg) translateY(-200px) rotate(-270deg); }
.orbit-badge-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  background: var(--glass-strong);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid var(--glass-border);
  border-radius: 50px;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text);
  white-space: nowrap;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3);
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.orbit-badge-inner:hover {
  border-color: var(--primary);
  box-shadow: 0 0 20px rgba(0, 245, 255, 0.3);
}

/* Decorative glow blob behind mascot */
.mascot-wrap::before {
  content: '';
  position: absolute;
  inset: 10% 5%;
  background: radial-gradient(circle, rgba(0,245,255,0.18) 0%, transparent 65%);
  filter: blur(30px);
  z-index: -1;
  animation: bgShift 12s ease-in-out infinite;
}

/* ============== STATS / COUNTERS ============== */
.stats {
  padding: 60px 0;
  border-top: 1px solid var(--glass-border);
  border-bottom: 1px solid var(--glass-border);
  background: var(--section-stats-bg);
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  text-align: center;
}
.stat-num {
  font-family: var(--font-head);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 800;
  background: var(--gradient);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  display: block;
  line-height: 1;
}
.stat-label { color: var(--text-2); margin-top: 6px; font-size: 0.95rem; }

/* ============== ABOUT ============== */
.about-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 60px;
  align-items: center;
}
.about-text h2 { margin-bottom: 18px; }
.about-text p { margin-bottom: 16px; font-size: 1.02rem; }

.about-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-top: 28px;
}
.about-col h4 {
  font-family: var(--font-body);
  font-size: 0.85rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 12px;
}
.about-col ul { list-style: none; }
.about-col li {
  padding: 8px 0;
  border-bottom: 1px dashed var(--glass-border);
  color: var(--text-2);
  font-size: 0.95rem;
}
.about-col li:last-child { border-bottom: none; }

/* Right decorative side */
.about-visual {
  position: relative;
  height: 460px;
  border-radius: var(--radius);
  background: var(--glass);
  border: 1px solid var(--glass-border);
  overflow: hidden;
  padding: 28px;
  backdrop-filter: blur(20px);
}
.code-block {
  font-family: 'Courier New', monospace;
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--text-2);
}
.code-block .c-key  { color: var(--code-key); }
.code-block .c-str  { color: var(--code-str); }
.code-block .c-num  { color: var(--code-num); }
.code-block .c-com  { color: var(--code-com); font-style: italic; }
.code-block .line {
  display: block;
  border-left: 2px solid transparent;
  padding-left: 10px;
  transition: border-color 0.2s ease, background-color 0.2s ease;
  border-radius: 4px;
}
.code-block .line:hover {
  border-color: var(--primary);
  background: var(--code-line-hover-bg);
}
.float-shape {
  position: absolute;
  border-radius: 50%;
  filter: blur(40px);
  opacity: 0.45;
}
.float-shape.s1 { width: 180px; height: 180px; background: var(--primary); top: -40px; right: -40px; animation: float 7s ease-in-out infinite; }
.float-shape.s2 { width: 140px; height: 140px; background: var(--secondary); bottom: -30px; left: -20px; animation: float 9s ease-in-out infinite reverse; }

/* Approach section */
.approach {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 70px;
}
.approach-card {
  padding: 30px;
  text-align: center;
}
.approach-icon {
  width: 64px; height: 64px;
  border-radius: 16px;
  margin: 0 auto 18px;
  display: flex; align-items: center; justify-content: center;
  background: var(--gradient-soft);
  border: 1px solid var(--glass-border);
  color: var(--primary);
  font-size: 1.6rem;
}
.approach-card h3 { font-size: 1.15rem; margin-bottom: 10px; }
.approach-card p  { font-size: 0.92rem; }

/* ============== SKILLS ============== */
.skills-section { padding: 80px 0 40px; }
.skills-section h3 { margin-bottom: 30px; display: flex; align-items: center; gap: 12px; }
.skills-section h3 .num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--gradient-soft);
  border: 1px solid var(--glass-border);
  font-size: 0.9rem;
  color: var(--primary);
}
.skills-section + .skills-section { padding-top: 30px; }

.skill-item { margin-bottom: 24px; }
.skill-head { display: flex; justify-content: space-between; margin-bottom: 8px; font-size: 0.95rem; }
.skill-head .pct { color: var(--primary); font-weight: 600; }
.skill-bar {
  height: 8px;
  background: var(--skill-bar-bg);
  border-radius: 10px;
  overflow: hidden;
  position: relative;
}
.skill-bar-fill {
  height: 100%;
  background: var(--gradient);
  border-radius: 10px;
  box-shadow: 0 0 12px rgba(0, 245, 255, 0.4);
}

.skills-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 50px;
}

/* Tools */
.tools {
  margin-top: 80px;
  text-align: center;
}
.tools h3 { margin-bottom: 30px; }
.tools-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 720px;
  margin: 0 auto;
}
.tool-icon {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 20px 10px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  transition: all 0.3s ease;
  cursor: default;
}
.tool-icon:hover {
  border-color: var(--primary);
  transform: translateY(-4px);
  box-shadow: 0 0 20px rgba(0,245,255,0.25);
}
.tool-icon svg, .tool-icon img, .tool-icon .custom-tool-img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  flex-shrink: 0;
}
/* White outline + cyan glow for tools that need visibility on both modes */
.tool-icon .tool-glow {
  filter:
    drop-shadow(0 0 1.5px #ffffff)
    drop-shadow(0 0 3px rgba(0, 245, 255, 0.7))
    drop-shadow(0 0 6px rgba(0, 245, 255, 0.4));
  transition: filter 0.3s ease;
}
.tool-icon:hover .tool-glow {
  filter:
    drop-shadow(0 0 2px #ffffff)
    drop-shadow(0 0 5px rgba(0, 245, 255, 0.9))
    drop-shadow(0 0 10px rgba(0, 245, 255, 0.6));
}
.tool-icon .tool-img-wrap {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(0, 245, 255, 0.04);
  border: 1px solid rgba(0, 245, 255, 0.08);
}
.tool-icon span { font-size: 0.78rem; color: var(--text-2); }

/* ============== WORK ============== */
.filter-tabs {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-bottom: 50px;
  flex-wrap: wrap;
}
.filter-tab {
  padding: 10px 22px;
  background: var(--glass);
  border: 1px solid var(--glass-border);
  border-radius: 50px;
  font-size: 0.9rem;
  color: var(--text-2);
  transition: all 0.3s ease;
  cursor: pointer;
}
.filter-tab:hover { color: var(--text); border-color: rgba(0,245,255,0.3); }
.filter-tab.active {
  background: var(--gradient);
  color: #001018;
  border-color: transparent;
  font-weight: 600;
  box-shadow: 0 0 20px rgba(0,245,255,0.3);
}

.projects-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}
.project-card {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 0;
}
.project-thumb {
  height: 220px;
  position: relative;
  overflow: hidden;
}
/* Dev project thumb — dark dashboard mockup */
.project-thumb.dev {
  background:
    linear-gradient(135deg, #0d0d18 0%, #11142a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--glass-border);
}
.dev-mock {
  width: 80%; height: 80%;
  background: linear-gradient(160deg, rgba(0,245,255,0.06), rgba(79,110,247,0.04));
  border: 1px solid rgba(0,245,255,0.2);
  border-radius: 10px;
  padding: 14px;
  position: relative;
  overflow: hidden;
}
.dev-mock::before {
  content: '';
  position: absolute;
  top: 12px; left: 12px; right: 12px;
  height: 18px;
  background: rgba(255,255,255,0.05);
  border-radius: 4px;
  display: flex;
}
.dev-mock::after {
  content: '';
  position: absolute;
  top: 14px; left: 18px;
  width: 6px; height: 6px;
  background: #ff5f56;
  border-radius: 50%;
  box-shadow: 12px 0 0 #ffbd2e, 24px 0 0 #27c93f;
}
.dev-mock-bars {
  position: absolute;
  bottom: 14px; left: 14px; right: 14px;
  display: flex;
  gap: 8px;
  align-items: flex-end;
  height: 40%;
}
.dev-mock-bars div {
  flex: 1;
  background: var(--gradient);
  border-radius: 3px 3px 0 0;
  opacity: 0.7;
  box-shadow: 0 0 8px rgba(0,245,255,0.4);
}
.dev-mock-bars div:nth-child(1) { height: 40%; }
.dev-mock-bars div:nth-child(2) { height: 70%; }
.dev-mock-bars div:nth-child(3) { height: 55%; }
.dev-mock-bars div:nth-child(4) { height: 85%; }
.dev-mock-bars div:nth-child(5) { height: 65%; }
.dev-mock-bars div:nth-child(6) { height: 90%; }

/* Branding project thumb — warm gold/amber */
.project-thumb.brand {
  background:
    linear-gradient(135deg, #3a2710 0%, #1a0f08 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  border-bottom: 1px solid var(--glass-border);
}
/* Universal graphic-design canvas — looks like a Figma/Behance preview */
.brand-mock {
  width: 82%;
  height: 82%;
  background: linear-gradient(160deg, #fbf6ec 0%, #f0e6d2 100%);
  border-radius: 10px;
  padding: 14px;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
  overflow: hidden;
}
.brand-mock::before {
  content: '';
  position: absolute;
  top: -30px; right: -30px;
  width: 90px; height: 90px;
  background: radial-gradient(circle, rgba(255,140,60,0.45) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(10px);
  pointer-events: none;
}
.brand-mock::after {
  content: '';
  position: absolute;
  bottom: -25px; left: -25px;
  width: 70px; height: 70px;
  background: radial-gradient(circle, rgba(255,200,80,0.5) 0%, transparent 70%);
  border-radius: 50%;
  filter: blur(8px);
  pointer-events: none;
}

/* Top row: logo mark + brand name */
.bm-top {
  display: flex;
  align-items: center;
  gap: 10px;
  position: relative;
  z-index: 1;
}
.bm-logo-box {
  width: 34px;
  height: 34px;
  background: linear-gradient(135deg, #0f0f1a 0%, #2a2a3e 100%);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 3px 8px rgba(0,0,0,0.25);
}
.bm-logo-shape {
  width: 14px;
  height: 14px;
  background: linear-gradient(135deg, #ff5722 0%, #ffc107 100%);
  border-radius: 3px;
  transform: rotate(45deg);
  box-shadow: 0 0 8px rgba(255, 87, 34, 0.6);
}
.bm-brand-name {
  display: none;
}
.bm-lines {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
  justify-content: center;
}
.bm-line {
  height: 5px;
  background: rgba(15, 15, 26, 0.18);
  border-radius: 3px;
}
.bm-line-1 { width: 75%; }
.bm-line-2 { width: 50%; background: linear-gradient(90deg, rgba(255,87,34,0.45), rgba(255,193,7,0.4)); }
.bm-line-3 {
  width: 30%;
  background: rgba(15, 15, 26, 0.12);
  margin-top: 2px;
}

/* Color palette swatches */
.bm-palette {
  display: flex;
  gap: 5px;
  position: relative;
  z-index: 1;
}
.bm-swatch {
  flex: 1;
  height: 26px;
  border-radius: 4px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.12);
  transition: transform 0.3s ease;
}
.project-card:hover .bm-swatch:nth-child(1) { transform: translateY(-3px); }
.project-card:hover .bm-swatch:nth-child(2) { transform: translateY(-5px); }
.project-card:hover .bm-swatch:nth-child(3) { transform: translateY(-3px); }
.project-card:hover .bm-swatch:nth-child(4) { transform: translateY(-5px); }
.project-card:hover .bm-swatch:nth-child(5) { transform: translateY(-3px); }
.bm-swatch.s1 { background: #0f0f1a; }
.bm-swatch.s2 { background: #ff5722; }
.bm-swatch.s3 { background: #ffc107; }
.bm-swatch.s4 { background: #00bfa5; }
.bm-swatch.s5 { background: #e91e63; }

/* Typography sample */
.bm-typo {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding-top: 10px;
  border-top: 1px dashed rgba(15, 15, 26, 0.15);
  position: relative;
  z-index: 1;
}
.bm-aa {
  font-family: 'Georgia', serif;
  font-size: 1.7rem;
  font-weight: 900;
  color: #0f0f1a;
  line-height: 1;
}
.bm-bb {
  font-family: 'Helvetica', sans-serif;
  font-size: 0.65rem;
  color: rgba(15, 15, 26, 0.5);
  letter-spacing: 0.2em;
  font-weight: 600;
}

/* Old styles kept for backward compat (in case referenced elsewhere) */
.brand-mock .bm-circle {
  position: absolute;
  border-radius: 50%;
  filter: blur(50px);
  opacity: 0.55;
  display: none;
}
.brand-mock .bm-mono { display: none; }
.brand-mock .bm-bar { display: none; }

.project-body { padding: 26px; flex: 1; display: flex; flex-direction: column; }
.project-cat {
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 8px;
}
.project-title { font-size: 1.3rem; margin-bottom: 10px; font-family: var(--font-head); }
.project-desc { font-size: 0.92rem; margin-bottom: 16px; flex: 1; }
.tech-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 18px; }
.tech-tag {
  font-size: 0.72rem;
  padding: 4px 10px;
  background: rgba(0,245,255,0.08);
  border: 1px solid rgba(0,245,255,0.2);
  border-radius: 50px;
  color: var(--primary);
}
.project-links { display: flex; gap: 10px; flex-wrap: wrap; }
.project-links .btn { flex: 1; justify-content: center; min-width: 130px; }

.project-card.hidden { display: none; }

/* ============== CONTACT ============== */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 40px;
  align-items: start;
}
.contact-info {
  padding: 36px;
}
.contact-info h2 { margin-bottom: 14px; }
.contact-info > p { margin-bottom: 26px; }
.info-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--glass-border);
}
.info-row:last-of-type { border-bottom: none; }
.info-icon {
  width: 42px; height: 42px;
  border-radius: 12px;
  background: var(--gradient-soft);
  border: 1px solid var(--glass-border);
  display: flex; align-items: center; justify-content: center;
  color: var(--primary);
  flex-shrink: 0;
}
.info-row small { display: block; color: var(--text-3); font-size: 0.78rem; }
.info-row span, .info-row a { font-size: 0.95rem; color: var(--text); }
.info-row a:hover { color: var(--primary); }

.availability {
  display: flex; align-items: center; gap: 10px;
  margin: 24px 0;
  padding: 14px 18px;
  background: rgba(34, 197, 94, 0.08);
  border: 1px solid rgba(34, 197, 94, 0.25);
  border-radius: var(--radius-sm);
  font-size: 0.92rem;
}
.availability .status-dot {
  width: 10px; height: 10px;
  background: #22c55e;
  border-radius: 50%;
  flex-shrink: 0;
}

.social-icons { display: flex; gap: 12px; margin-top: 24px; align-items: center; }
.social-icons a {
  width: 56px; height: 56px;
  display: flex;
  align-items: center; justify-content: center;
  background: #0d0d0d;
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 18px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.4);
  transition: all 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
  flex-shrink: 0;
  overflow: hidden;
}
.social-icons a:hover {
  transform: translateY(-3px) scale(1.08);
  background: #1a1a1a;
  border-color: rgba(255,255,255,0.15);
}
.social-icons a:active {
  transform: scale(0.95);
}
.social-icons a[data-platform="github"]:hover {
  box-shadow: 0 4px 20px rgba(255,255,255,0.2);
}
.social-icons a[data-platform="fiverr"]:hover {
  box-shadow: 0 4px 20px rgba(29,191,115,0.4);
}
.social-icons a[data-platform="linkedin"]:hover {
  box-shadow: 0 4px 20px rgba(0,119,181,0.4);
}
.social-icons a[data-platform="behance"]:hover {
  box-shadow: 0 4px 20px rgba(23,105,255,0.4);
}
.social-icons svg {
  width: 26px; height: 26px;
  display: block;
  flex-shrink: 0;
  fill: #ffffff;
  text-rendering: geometricPrecision;
  shape-rendering: geometricPrecision;
  overflow: visible;
}

/* Contact form */
.contact-form { padding: 36px; }
.form-group { margin-bottom: 20px; }
.form-group label {
  display: block;
  font-size: 0.85rem;
  color: var(--text-2);
  margin-bottom: 8px;
  letter-spacing: 0.05em;
}
.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 14px 16px;
  background: var(--input-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 0.95rem;
  transition: all 0.3s ease;
  outline: none;
}
.form-group input::placeholder,
.form-group textarea::placeholder { color: var(--text-3); }
.form-group textarea { resize: vertical; min-height: 130px; }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--primary);
  background: var(--input-focus-bg);
  box-shadow: 0 0 0 3px var(--input-focus-shadow);
}
.form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg fill='var(--dropdown-arrow-color)' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/></svg>");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 18px;
  padding-right: 40px;
}
[data-theme="dark"] .form-group select {
  background-image: url("data:image/svg+xml;utf8,<svg fill='%2300f5ff' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/></svg>");
}
[data-theme="light"] .form-group select {
  background-image: url("data:image/svg+xml;utf8,<svg fill='%230098a8' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'><path d='M7 10l5 5 5-5z'/></svg>");
}
.form-group select option { background: var(--select-option-bg); color: var(--text); }
.form-submit { width: 100%; justify-content: center; }
.form-success {
  display: none;
  padding: 16px;
  background: rgba(34, 197, 94, 0.1);
  border: 1px solid rgba(34, 197, 94, 0.3);
  border-radius: var(--radius-sm);
  color: #4ade80;
  margin-top: 16px;
  text-align: center;
  font-size: 0.9rem;
}
.form-success.show { display: block; animation: fadeUp 0.5s ease; }

/* ============================================
   LIGHT THEME — page-specific overrides
   ============================================ */
[data-theme="light"] {

  /* Hero / mascot area */
  .hero-tag { background: rgba(255, 255, 255, 0.6); }
  .mascot-wrap::before { opacity: 0.7; }

  /* Section title tag underline accent */
  .section-title .tag { color: var(--primary); }

  /* Glass cards stronger contrast in light mode */
  .glass {
    background: var(--glass);
    box-shadow: 0 4px 20px var(--card-shadow);
  }

  /* Stats section — solid white-ish bg with subtle border */
  .stats { background: var(--section-stats-bg); }

  /* About columns dashed border uses glass-border which is darker in light */
  .about-col li { border-bottom: 1px dashed rgba(10, 10, 30, 0.12); }

  /* Code block — give it a soft container for legibility on light bg */
  .about-visual { background: rgba(255, 255, 255, 0.85); }
  .float-shape { opacity: 0.25; }

  /* Skill items head color */
  .skill-head { color: var(--text); }

  /* Tools grid items — more contrast in light mode */
  .tool-icon {
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 2px 8px var(--card-shadow);
  }

  /* Project cards — keep dark dev/branding mockups, but soften */
  .project-card { background: rgba(255, 255, 255, 0.85); }

  /* Tech tags — slightly more contrast on light */
  .tech-tag {
    background: var(--tag-bg);
    border-color: var(--tag-border);
  }

  /* Contact info row dividers */
  .info-row { border-bottom: 1px solid rgba(10, 10, 30, 0.1); }
  .availability {
    background: rgba(34, 197, 94, 0.12);
    border-color: rgba(34, 197, 94, 0.35);
  }

  /* Social icons / footer socials — premium dark UI stays consistent in light mode */
  .social-icons a,
  .footer-socials a {
    background: #0d0d0d;
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.4);
  }

  /* Footer */
  footer { background: var(--footer-bg); }
  .footer-bottom { border-top: 1px solid rgba(10, 10, 30, 0.1); }

  /* Orbit badge inner — lighter glass */
  .orbit-badge-inner {
    background: var(--orbit-bg);
    box-shadow: 0 4px 16px rgba(10, 10, 30, 0.1);
    color: var(--text);
  }

  /* Approach cards icons background */
  .approach-icon {
    background: var(--gradient-soft);
    border-color: var(--glass-border);
  }

  /* Form input — ensure placeholder & text contrast */
  .form-group label { color: var(--text-2); }
  .form-group input,
  .form-group select,
  .form-group textarea {
    box-shadow: 0 1px 3px var(--card-shadow);
  }

  /* GitHub button — needs more contrast in light mode */
  .btn-github {
    background: #0a0a0f;
    color: #fff;
    border-color: #0a0a0f;
  }

  /* Fiverr button stays green (brand color) */
  .btn-fiverr { color: #fff; }

  /* Approach card icon symbol colors */
  .approach-icon { color: var(--primary); }

  /* Custom mascot hood should stay dark in light mode (character design) */

  /* Type-caret color */
  .type-caret::after { color: var(--primary); }

  /* Form success on light bg — keep green text */
  .form-success {
    background: rgba(34, 197, 94, 0.12);
    border-color: rgba(34, 197, 94, 0.35);
    color: #16a34a;
  }

  /* Selection in light mode */
  ::selection { background: var(--primary); color: #fff; }
}

/* ============== RESPONSIVE ============== */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 40px; text-align: center; }
  .hero-tag { margin-inline: auto; }
  .hero-ctas { justify-content: center; }
  .hero-visual { height: 420px; }
  .about-grid { grid-template-columns: 1fr; }
  .about-visual { height: 380px; }
  .approach { grid-template-columns: 1fr; }
  .skills-grid { grid-template-columns: 1fr; gap: 30px; }
  .tools-grid { grid-template-columns: repeat(3, 1fr); }
  .projects-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr; gap: 30px; }
  .mascot-wrap { width: 280px; height: 340px; }
  .orbit-badge.b1 { transform: rotate(0deg)   translateY(-180px) rotate(0deg); }
  .orbit-badge.b2 { transform: rotate(90deg)  translateY(-180px) rotate(-90deg); }
  .orbit-badge.b3 { transform: rotate(180deg) translateY(-180px) rotate(-180deg); }
  .orbit-badge.b4 { transform: rotate(270deg) translateY(-180px) rotate(-270deg); }
  .orbit-badge { width: 110px; margin-left: -55px; }
}
@media (max-width: 560px) {
  .about-cols { grid-template-columns: 1fr; }
  .tools-grid { grid-template-columns: repeat(3, 1fr); gap: 14px; }
  .orbit-badge.b1 { transform: rotate(0deg)   translateY(-150px) rotate(0deg); }
  .orbit-badge.b2 { transform: rotate(90deg)  translateY(-150px) rotate(-90deg); }
  .orbit-badge.b3 { transform: rotate(180deg) translateY(-150px) rotate(-180deg); }
  .orbit-badge.b4 { transform: rotate(270deg) translateY(-150px) rotate(-270deg); }
  .orbit-badge { width: 100px; margin-left: -50px; font-size: 0.75rem; padding: 8px 10px; }
  .orbit-badge-inner { font-size: 0.75rem; padding: 8px 10px; }
  .hero-visual { height: 380px; }
  .mascot-wrap { width: 240px; height: 300px; }
}
