/* ===== RESPONSIVE STYLES — Nettes Deutsch ===== */

/* ===== DESKTOP LARGE (>1440px) ===== */
@media (min-width: 1441px) {
  section {
    padding: 100px 80px;
  }
}

/* ===== TABLET (768px – 1024px) ===== */
@media (max-width: 1024px) {
  /* Navigation */
  #navbar {
    padding: 16px 32px;
  }

  /* Typography */
  :root {
    --size-hero: clamp(40px, 7vw, 72px);
    --size-h1: clamp(28px, 5vw, 48px);
    --size-h2: clamp(20px, 3vw, 32px);
  }

  /* Sections */
  section {
    padding: 60px 32px;
  }

  /* Grid layouts */
  .two-col,
  .alt-row {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .card-grid-4 {
    grid-template-columns: repeat(2, 1fr);
  }

  .card-grid-3 {
    grid-template-columns: repeat(2, 1fr);
  }

  /* Hero */
  .hero {
    min-height: auto;
    padding: 100px 32px 60px;
  }

  .hero-cards {
    flex-direction: column;
    align-items: center;
  }

  .hero-info-card {
    max-width: 100%;
  }

  /* Footer */
  .footer-main {
    grid-template-columns: 1fr 1fr;
    gap: 40px;
  }

  .footer-bottom {
    flex-direction: column;
    gap: 20px;
    text-align: center;
  }

  /* Photos */
  .section-photo {
    max-width: 480px;
    margin: 0 auto;
  }
}

/* ===== MOBILE (< 768px) ===== */
@media (max-width: 768px) {
  /* Navigation */
  #navbar {
    padding: 14px 20px;
  }

  .nav-links {
    display: none;
  }

  .nav-logo {
    font-size: 18px;
  }

  .nav-cta {
    padding: 12px 24px;
    font-size: 14px;
  }

  /* Typography */
  :root {
    --size-hero: clamp(36px, 9vw, 56px);
    --size-h1: clamp(26px, 6vw, 40px);
    --size-h2: clamp(18px, 4vw, 28px);
    --size-body: 15px;
    --size-small: 13px;
  }

  /* Sections */
  section {
    padding: 50px 20px;
  }

  /* Hero */
  .hero {
    min-height: 100vh;
    padding: 100px 20px 50px;
  }

  .hero-title {
    margin-bottom: 32px;
  }

  .hero-cards {
    gap: 16px;
    margin-bottom: 32px;
  }

  .hero-info-card {
    padding: 20px 24px;
    flex-direction: column;
    text-align: center;
  }

  .hero-info-card p {
    font-size: 15px;
  }

  .hero-btns {
    flex-direction: column;
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
  }

  .hero-btns .btn-red,
  .hero-btns .btn-white,
  .hero-btns .btn-ghost {
    width: 100%;
  }

  /* Buttons */
  .btn-red,
  .btn-white,
  .btn-ghost {
    padding: 14px 28px;
    font-size: 15px;
  }

  .btn-small {
    padding: 10px 20px;
    font-size: 13px;
  }

  /* Grid layouts */
  .two-col,
  .alt-row,
  .card-grid-2,
  .card-grid-3,
  .card-grid-4 {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  /* Cards */
  .card,
  .pricing-card,
  .faq-card,
  .alt-text-card {
    padding: 24px;
  }

  /* Photos */
  .section-photo {
    max-width: 100%;
    aspect-ratio: 4/5;
  }

  /* Social icons */
  .social-icons-row {
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
  }

  .social-icon-card {
    width: 56px;
    height: 56px;
    padding: 10px;
  }

  .social-icon-card img {
    width: 32px;
    height: 32px;
  }

  .social-icon-link {
    font-size: 12px;
  }

  /* Icon cards */
  .emoji-icon {
    width: 40px;
    height: 40px;
  }

  .icon-card {
    padding: 10px;
  }

  /* Icon lists */
  .icon-list-item {
    gap: 12px;
  }

  .mini-icon-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  /* Pricing cards */
  .pricing-price {
    font-size: 28px;
  }

  .pricing-card h4 {
    font-size: 18px;
  }

  /* Forms */
  form input,
  form textarea {
    padding: 12px 16px;
    font-size: 15px;
  }

  /* Footer */
  footer {
    padding: 40px 20px 24px;
  }

  .footer-main {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .footer-brand {
    font-size: 20px;
  }

  .footer-section h4 {
    font-size: 16px;
  }

  .footer-bottom {
    flex-direction: column;
    gap: 16px;
  }

  .footer-legal {
    flex-direction: column;
    gap: 12px;
    text-align: center;
  }

  .social-footer {
    justify-content: center;
  }

  /* Animations - reduce motion on mobile */
  .reveal,
  .reveal-left,
  .reveal-right {
    transform: translateY(20px);
  }

  .reveal-left,
  .reveal-right {
    transform: translateY(20px);
  }
}

/* ===== SMALL MOBILE (< 480px) ===== */
@media (max-width: 480px) {
  :root {
    --size-hero: clamp(32px, 10vw, 48px);
    --size-h1: clamp(24px, 7vw, 36px);
    --size-h2: clamp(16px, 5vw, 24px);
  }

  section {
    padding: 40px 16px;
  }

  .hero {
    padding: 90px 16px 40px;
  }

  .btn-red,
  .btn-white,
  .btn-ghost {
    padding: 12px 24px;
    font-size: 14px;
  }

  .card,
  .pricing-card,
  .faq-card,
  .alt-text-card {
    padding: 20px;
  }
}

/* ===== LANDSCAPE MOBILE ===== */
@media (max-height: 600px) and (orientation: landscape) {
  .hero {
    min-height: auto;
    padding: 80px 20px 40px;
  }

  section {
    padding: 40px 20px;
  }
}

/* ===== PRINT STYLES ===== */
@media print {
  #navbar,
  .hero-btns,
  .btn-red,
  .btn-white,
  .btn-ghost,
  form,
  footer {
    display: none;
  }

  section {
    page-break-inside: avoid;
  }
}
