/* Roadmap de Ciberseguridad v3.0 - responsive.css */

/* ===================================================================
   RESPONSIVE MEDIA QUERIES — Mobile-First
   ===================================================================
   Breakpoints: sm: 576px, md: 768px, lg: 900px, xl: 1100px
   ===================================================================
   Base styles (no media query) = mobile defaults.
   Complexity added progressively at wider breakpoints.
   =================================================================== */

/* ===================================================================
   BASE — Mobile defaults (< 576px)
   =================================================================== */

/* -- Navbar -- */
.navbar {
  padding: 0 16px;
}

.navbar__links {
  display: none !important;
}

.navbar__cta {
  display: none !important;
}

.navbar__hamburger {
  display: -webkit-flex;
  display: flex;
}

/* -- Mobile Nav Overlay -- */
.mobile-nav {
  display: -webkit-flex;
  display: flex;
}

/* -- Hero -- */
.hero__title .hero__title-line--main {
  font-size: clamp(28px, 5vw, 56px);
}

.hero__title .hero__title-line--accent {
  font-size: clamp(32px, 7vw, 80px);
}

.hero__title .hero__title-line--sub {
  font-size: clamp(14px, 2.2vw, 24px);
}

.hero__stats {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  border-radius: 4px;
}

.hero__stat {
  min-width: 80px;
  padding: 10px 14px;
}

/* -- Content Grids — all single column on mobile -- */
.intro__inner {
  grid-template-columns: 1fr;
  gap: 32px;
}

.advisor__inner {
  grid-template-columns: 1fr;
}

.routes__grid {
  grid-template-columns: 1fr;
}

.teams__layout {
  grid-template-columns: 1fr;
}

.events__grid {
  grid-template-columns: 1fr;
}

.communities__grid {
  grid-template-columns: 1fr;
}

.sponsors__grid {
  grid-template-columns: 1fr;
}

/* -- Campaign / CiberSinOdio -- */
.campaign {
  padding: 32px 16px;
}

.campaign__inner {
  -webkit-flex-direction: column;
  flex-direction: column;
  text-align: center;
  gap: 16px;
}

.campaign__emoji {
  font-size: 36px;
}

.campaign__hashtag {
  font-size: 13px;
}

/* -- Footer -- */
.footer__domains {
  margin-bottom: 12px;
}

.footer__domains a {
  margin: 0 6px;
}


/* ===================================================================
   SM — Small devices (min-width: 576px)
   =================================================================== */
@media (min-width: 576px) {
  .hero__stat {
    min-width: 90px;
    padding: 12px 16px;
  }

  .campaign {
    padding: 36px 24px;
  }

  .campaign__inner {
    gap: 20px;
  }

  .footer__domains a {
    margin: 0 8px;
  }
}


/* ===================================================================
   MD — Medium devices / Tablets (min-width: 768px)
   =================================================================== */
@media (min-width: 768px) {
  /* Navbar */
  .navbar {
    padding: 0 36px;
  }

  /* Hero */
  .hero__stats {
    -webkit-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }

  .hero__stat {
    min-width: 90px;
    padding: 14px 20px;
  }

  /* Grids */
  .intro__inner {
    grid-template-columns: repeat(2, 1fr);
    gap: 48px;
  }

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

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

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

  /* Campaign */
  .campaign {
    padding: 44px 36px;
  }

  .campaign__inner {
    -webkit-flex-direction: row;
    flex-direction: row;
    text-align: left;
    gap: 24px;
  }

  .campaign__emoji {
    font-size: 42px;
  }

  .campaign__hashtag {
    font-size: 15px;
  }

  /* Footer */
  .footer__domains {
    margin-bottom: 16px;
  }

  .footer__domains a {
    margin: 0 10px;
  }
}


/* ===================================================================
   LG — Large devices / Small desktop (min-width: 900px)
   =================================================================== */
@media (min-width: 900px) {
  /* Navbar: show full navigation */
  .navbar__links {
    display: -webkit-flex !important;
    display: flex !important;
  }

  .navbar__cta {
    display: -webkit-inline-flex !important;
    display: inline-flex !important;
  }

  .navbar__hamburger {
    display: none;
  }

  /* Mobile nav: hide on desktop */
  .mobile-nav {
    display: none !important;
  }

  /* Grids */
  .advisor__inner {
    grid-template-columns: repeat(2, 1fr);
  }

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

  .teams__layout {
    grid-template-columns: 360px 1fr;
  }

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

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


/* ===================================================================
   XL — Extra large / Full desktop (min-width: 1100px)
   =================================================================== */
@media (min-width: 1100px) {
  .intro__inner {
    grid-template-columns: 1fr 1fr;
    gap: 56px;
  }

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


/* ===================================================================
   PREFERS REDUCED MOTION
   =================================================================== */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    -webkit-animation-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }

  .grid-bg {
    display: none;
  }

  .rv {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}


/* ===================================================================
   PRINT STYLES
   =================================================================== */
@media print {
  /* Hide non-essential visual elements */
  #cvs,
  .grid-bg,
  #cur,
  #cur2,
  .navbar,
  .mobile-nav,
  .navbar__hamburger,
  .hero__orb,
  .term-widget,
  body::after {
    display: none !important;
  }

  body {
    background: #fff;
    color: #111;
    cursor: auto;
  }

  .hero__title .hero__title-line--accent {
    -webkit-text-fill-color: #111;
    background: none;
  }

  .section-h2 {
    color: #111;
  }

  .section-sub {
    color: #333;
  }
}
