/* Responsive — tablet and mobile adaptations */

/* ===== TABLET (768px - 1199px) ===== */
@media (max-width: 1199px) {
  h1 {
    font-size: var(--text-4xl);
  }

  h2 {
    font-size: var(--text-3xl);
  }

  .grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }

  .split {
    gap: var(--space-2xl);
  }

  .footer__inner {
    flex-wrap: wrap;
    gap: var(--space-2xl);
  }

  .profile {
    gap: var(--space-2xl);
  }

  .profile__avatar {
    width: 160px;
    height: 160px;
  }
}

/* ===== MOBILE (< 768px) ===== */
@media (max-width: 767px) {
  :root {
    --nav-height: 60px;
  }

  h1 {
    font-size: var(--text-3xl);
  }

  h2 {
    font-size: var(--text-2xl);
  }

  h3 {
    font-size: var(--text-xl);
  }

  .container {
    padding: 0 var(--space-md);
  }

  .section {
    padding: var(--space-3xl) 0;
  }

  /* Navbar mobile */
  .navbar__links {
    display: none;
    position: absolute;
    top: var(--nav-height);
    left: 0;
    right: 0;
    flex-direction: column;
    background: var(--glass-bg-heavy);
    backdrop-filter: var(--glass-blur-heavy);
    -webkit-backdrop-filter: var(--glass-blur-heavy);
    border-bottom: 1px solid var(--glass-border);
    padding: var(--space-lg);
    gap: var(--space-md);
  }

  .navbar__links.open {
    display: flex;
  }

  .navbar__toggle {
    display: flex;
  }

  /* Grid collapse */
  .grid-2,
  .grid-3 {
    grid-template-columns: 1fr;
  }

  .split {
    grid-template-columns: 1fr;
    gap: var(--space-2xl);
  }

  /* Profile stack */
  .profile {
    flex-direction: column;
    text-align: center;
  }

  .profile__avatar {
    width: 140px;
    height: 140px;
  }

  /* Experience stack */
  .experience {
    flex-direction: column;
  }

  /* Footer stack */
  .footer__inner {
    flex-direction: column;
    gap: var(--space-2xl);
  }

  .footer__bottom {
    flex-direction: column;
    gap: var(--space-md);
    text-align: center;
  }

  /* Hero banner responsive */
  .hero-banner {
    gap: var(--space-md);
    padding: var(--space-sm) var(--space-lg);
    max-width: 100%;
  }

  .hero-banner__text {
    font-size: var(--text-base);
  }

  .hero-banner__logo {
    height: 44px;
  }

  /* Navbar logo */
  .navbar__logo-svg {
    height: 22px;
  }

  /* Timeline */
  .timeline {
    padding-left: var(--space-xl);
  }
}