/*
 * DV Digital - Responsive CSS
 */

@media screen and (max-width: 1024px) {
  .section {
    padding: 60px 0;
  }

  /* Force Mobile Nav early for iPad Air (820px and up to 1024px) */
  .nav-links {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    width: 280px !important;
    height: 100vh !important;
    background-color: var(--bg-color) !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    padding-top: 100px !important;
    gap: 20px !important;
    transform: translateX(100%) !important;
    transition: transform 0.4s ease !important;
    z-index: 1100 !important;
    box-shadow: -10px 0 30px rgba(0,0,0,0.1) !important;
    display: flex !important;
  }

  .nav-links.active {
    transform: translateX(0) !important;
  }

  .mobile-toggle {
    display: block !important;
    z-index: 1200 !important;
    background: var(--btn-bg) !important;
    color: var(--btn-text) !important;
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 4px !important;
  }

  .header-actions {
    display: none !important;
  }

  .nav-links .header-actions {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    padding: 20px 40px !important;
    margin-top: 40px !important;
    gap: 16px !important;
    align-items: center !important;
  }

  .nav-links .header-actions .btn {
    width: 100% !important;
    text-align: center !important;
  }

  .hero-bg {
    min-height: 900px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: flex-start !important;
    background-image: url('../../banner/webp/tablet-modo-escuro.webp') !important;
    background-position: center top !important;
    padding: 0 40px !important;
    text-align: left !important;
  }

  .hero-content {
    width: 100% !important;
    max-width: 500px !important;
    margin: 0 !important;
    text-align: left !important;
    z-index: 5 !important;
  }

  .hero-title {
    font-size: 2.75rem !important;
    line-height: 1.1 !important;
    margin-bottom: 24px !important;
  }

  .hero-description {
    font-size: 1.2rem !important;
    line-height: 1.4 !important;
    margin-bottom: 40px !important;
  }

  .hero-btns {
    justify-content: center !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 12px !important;
  }

  .hero-btns .btn {
    width: 100% !important;
    max-width: 320px !important;
  }

  .hero-bg::before {
    background: linear-gradient(0deg, rgba(0,0,0,1) 0%, rgba(0,0,0,0.7) 40%, rgba(0,0,0,0) 80%) !important;
    width: 100% !important;
  }

  [data-theme="light"] .hero-bg::before {
    background: linear-gradient(0deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0.7) 40%, rgba(255,255,255,0) 80%) !important;
  }

  [data-theme="light"] .hero-bg {
    background-image: url('../../banner/webp/tablet-modo-claro.webp') !important;
  }
}

@media screen and (max-width: 768px) {
  .hero-bg {
    min-height: 850px !important;
    background-image: url('../../banner/webp/mobile-modo-escuro.webp') !important;
    justify-content: flex-start !important;
    padding-top: 450px !important;
    padding-bottom: 60px !important;
  }

  .hero-content {
    padding-bottom: 0 !important;
    margin-bottom: 40px !important;
  }

  .hero-title {
    font-size: 1.85rem !important;
  }

  .portfolio-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  .portfolio-visual {
    min-height: 246px !important;
    padding: 42px 88px 34px 18px !important;
  }

  .portfolio-url-badge {
    top: 3px !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 auto !important;
    width: max-content !important;
  }

  .portfolio-browser {
    width: 100% !important;
  }

  .portfolio-browser-bar {
    min-height: 44px !important;
    padding: 0 16px !important;
  }

  .portfolio-browser-dots {
    left: 16px !important;
  }

  .portfolio-browser-screen {
    padding: 2px !important;
  }

  .portfolio-mobile-screen {
    border-radius: 8px 8px 18px 18px !important;
  }

  .portfolio-mobile-frame {
    right: 16px !important;
    bottom: 24px !important;
    width: clamp(84px, 24%, 108px) !important;
    padding: 3px !important;
    border-radius: 20px !important;
  }

  .portfolio-desktop-shot {
    width: 100% !important;
    max-height: none !important;
  }

  .portfolio-mobile-notch {
    height: 10px !important;
    margin-bottom: 6px !important;
  }

  .portfolio-content {
    padding: 24px 20px 20px !important;
  }

  .portfolio-heading {
    flex-direction: column !important;
    gap: 12px !important;
  }

  .portfolio-card--portrait .portfolio-visual {
    min-height: 326px !important;
    padding-right: 72px !important;
  }

  .portfolio-card--portrait .portfolio-browser {
    max-width: min(82%, 304px) !important;
  }

  .portfolio-card--portrait .portfolio-mobile-frame {
    width: clamp(70px, 18%, 86px) !important;
    right: 10px !important;
    bottom: 12px !important;
  }

  .portfolio-card--portrait .portfolio-browser-bar {
    min-height: 50px !important;
  }

  [data-theme="light"] .hero-bg {
    background-image: url('../../banner/webp/mobile-modo-claro.webp') !important;
  }
}

@media (max-width: 480px) {
  h1 {
    font-size: 2.5rem;
  }

  h2 {
    font-size: 2rem;
  }

  .btn {
    width: 100%;
  }

  .portfolio-browser-label {
    font-size: 0.58rem !important;
    letter-spacing: 0.04em !important;
  }

  .portfolio-desktop-shot {
    width: 100% !important;
  }

  .portfolio-mobile-frame {
    width: clamp(70px, 22%, 86px) !important;
    right: 12px !important;
    bottom: 20px !important;
    padding: 2px !important;
  }

  .portfolio-mobile-screen {
    border-radius: 6px 6px 18px 18px !important;
  }

  .portfolio-visual {
    min-height: 210px !important;
    padding: 38px 68px 28px 14px !important;
  }

  .portfolio-url-badge {
    top: 5px !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 auto !important;
    width: max-content !important;
    font-size: 0.55rem !important;
    padding: 4px 10px !important;
  }

  .portfolio-browser-bar {
    min-height: 40px !important;
    padding: 0 12px !important;
  }

  .portfolio-browser-dots {
    left: 12px !important;
  }

  .portfolio-browser-screen {
    padding: 2px !important;
  }

  .portfolio-card--portrait .portfolio-visual {
    min-height: 286px !important;
    padding-right: 58px !important;
  }

  .portfolio-card--portrait .portfolio-browser {
    max-width: min(82%, 258px) !important;
  }

  .portfolio-card--portrait .portfolio-browser-bar {
    min-height: 46px !important;
  }

  .portfolio-card--portrait .portfolio-mobile-frame {
    width: clamp(62px, 18%, 72px) !important;
    right: 8px !important;
    bottom: 10px !important;
  }

  .portfolio-title {
    font-size: 1.2rem !important;
  }

  .portfolio-description {
    font-size: 0.92rem !important;
  }
}
