@media (max-width: 768px) {
  nav a {
    font-size: 15vw;
  }
  .fp-section {
    padding: 12vh 5vw;
  }
  .hero {
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
  }
  .hero-h1 {
    font-size: 10vw;
  }
  .badge-container {
    left: auto;
    right: 5%;
    bottom: 10%;
    transform: scale(0.8);
  }
  .about-container {
    display: flex;
    flex-direction: column;
    gap: 30px;
    justify-content: center;
  }
  .ethos h2 {
    font-size: 8vw;
    margin-bottom: 15px;
  }
  .data-art {
    flex-direction: row;
    gap: 20px;
    border-left: none;
    border-top: 1px solid #ddd;
    padding-left: 0;
    padding-top: 30px;
    align-items: flex-start;
  }
  .stat-number {
    font-size: 15vw;
  }
  .about-container {
    display: flex;
    flex-direction: column;
    gap: 30px;
    justify-content: center;
  }
  .data-art {
    display: flex;
    flex-direction: column;
    gap: 30px;
    justify-content: center;
  }
  .stat-block {
    display: flex;
    flex-direction: column;
    gap: 30px;
    justify-content: center;
  }
  .identity-block {
    display: flex;
    flex-direction: column;
    gap: 30px;
    justify-content: center;
  }
  /* Portfolio Mockup Responsiveness */
  .portfolio-mockup-wrapper {
    height: 300px;
  }
  .portfolio-mockup-wrapper .laptop-device {
    max-width: 280px;
    transform: translate(-5%, 8%) !important;
  }
  .portfolio-mockup-wrapper .mobile-device {
    width: 70px;
    height: 147px; /* 70 * (19/9) approx */
    right: 2%;
    bottom: 10%;
  }
  .portfolio-mockup-wrapper .mobile-device iframe {
    transform: scale(0.186); /* 70 / 375 */
  }
  .portfolio-mockup-wrapper .mockup-instruction {
    font-size: 0.7rem;
    letter-spacing: 2px;
    top: 15px;
  }
  /* --- Contact Section Responsiveness --- */
  .contact-section .section-title {
    margin-bottom: 20px;
    font-size: 10vw;
  }
  .contact-section .qrcode-wrapper {
    transform: scale(0.9);
  }
  .contact-section .contact-info-item {
    font-size: 1rem;
    margin-bottom: 15px;
  }
  /* --- Navigation Panel Responsiveness --- */
  .nav-menu {
    width: 100%;
    left: 0;
    bottom: 0;
    padding: 20px;
    border-radius: 20px 20px 0 0; /* Enhance top roundness for mobile drawer feel */
  }
  .nav-menu .nav-heading {
    font-size: 1.5rem;
  }
  .nav-menu .nav-desc {
    font-size: 0.8rem;
  }
  .nav-menu nav a {
    font-size: 1.3rem;
  }
}/*# sourceMappingURL=mobile.css.map */