/* ================================================================
   RESPONSIVE BLOCKS — Centros Informáticos Ledesma
   Pegar cada bloque al FINAL del CSS indicado.
   Los media queries de header/navbar/footer/cookie ya existen
   en todos los archivos; aquí solo van los elementos únicos
   de cada página.
================================================================ */

/* ================================================================
   📄  main.css
   Elementos únicos: layout de 3 columnas, about, fotos tienda
================================================================ */

/* --- Tablet (≤ 992px) --- */
@media (max-width: 992px) {

  /* Layout principal: de 3 col a 2 col apilando sidebar izquierdo */
  .main-wrapper {
    grid-template-columns: 300px 1fr;
    gap: 14px;
  }

  /* Columna derecha ocupa todo el ancho */
  .right-col {
    grid-column: 1 / -1;
    flex-direction: row;
    flex-wrap: wrap;
    gap: 14px;
  }
  .right-col .sidebar-box { flex: 1 1 calc(50% - 7px); }

  /* About section: de 2 col a 1 col */
  .about-container {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  /* Fotos tienda */
  .fotos_tienda {
    flex-wrap: wrap;
    margin-right: 0;
    gap: 10px;
  }
  .foto-item { height: 180px; flex: 1 1 calc(50% - 10px); }

  /* Mapa: aspect ratio más alto para que se vea bien en sidebar */
  .map-container { padding-bottom: 50%; }

  .navbar .inner {
    height: auto;          /* elimina el corte vertical */
    min-height: 48px;
    flex-wrap: wrap;
    padding: 0;
    overflow: visible;
  }
 
  /* El botón CTA va en su propia fila, ancho completo */
  .nav-search-btn {
    width: 100%;
    margin-left: 0;
    border-left: none;
    border-top: 1px solid rgba(255,255,255,.08);
    justify-content: center;
    padding: 10px 16px;
    order: 10;             /* siempre último */
  }
 
  .nav-search-btn a {
    display: block;
    text-align: center;
    width: 100%;
  }
 
  /* Los links de nav se quedan en su fila y hacen wrap */
  .nav-links {
    flex: 1 1 auto;
    flex-wrap: wrap;
    height: auto;
  }
 
  .nav-links a {
    height: 44px;
    flex-shrink: 0;
  }

  .foto_perfil { height: 55%; }
}

/* --- Mobile grande (≤ 768px) --- */
@media (max-width: 768px) {

  .navbar .inner {
    height: auto;
    min-height: unset;
    overflow: visible;
  }
 
  .nav-cat-dropdown {
    width: 100%;
  }
 
  .nav-cat-btn {
    width: 100%;
    height: 48px;
    justify-content: flex-start;
  }
 
  /* El menú desplegable en móvil: ancho completo de la pantalla */
  .nav-cat-menu {
    position: fixed;        /* evita que desborde el contenedor relativo */
    left: 0;
    right: 0;
    width: 100vw;
    min-width: unset;
    border-radius: 0;
    top: auto;              /* el JS lo posiciona, aquí no importa */
    z-index: 1001;
  }
 
  .nav-links {
    flex-direction: column;
    width: 100%;
    height: auto;
  }
 
  .nav-links a {
    width: 100%;
    height: 44px;
    padding: 0 16px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    /* quita el ::after animado que puede causar overflow */
    overflow: hidden;
  }
 
  .nav-links a::after {
    display: none;
  }
 
  .nav-search-btn {
    width: 100%;
    margin-left: 0;
    padding: 12px 16px;
    order: 10;
    justify-content: center;
    border-top: 1px solid rgba(255,255,255,.1);
    border-left: none;
  }
 
  .nav-search-btn a {
    display: block;
    width: 100%;
    text-align: center;
    white-space: normal;      /* evita desbordamiento horizontal */
    word-break: break-word;
  }
  .foto_perfil { height: 55%; }
}


/* ================================================================
   📄  taller_sat.css
   Elementos únicos: hero banner, carruseles, photo-grid, srv-cards
================================================================ */

/* --- Tablet (≤ 992px) --- */
@media (max-width: 992px) {

  /* Hero banner */
  .hero-banner { height: 320px; }
  .hero-overlay { padding: 28px 32px; }
  .hero-text h2 { font-size: 36px; }
  .hero-text p  { font-size: 13.5px; max-width: 300px; }

  /* Servicios rápidos: 2 col */
  .services-row { grid-template-columns: repeat(2, 1fr); gap: 14px; }

  /* Carrusel */
  .carousel-slide { height: 380px; }

  /* Photo grid: 3 col se mantiene en tablet */
  .photo-grid { gap: 12px; }
  .photo-item { height: 180px; }

  /* Block title */
  .block-title h2 { font-size: 18px; }
}

/* --- Mobile grande (≤ 768px) --- */
@media (max-width: 768px) {

  /* Hero banner */
  .hero-banner { height: 240px; border-radius: 6px; margin-bottom: 24px; }
  .hero-overlay { padding: 20px 20px; }
  .hero-text h2 { font-size: 26px; letter-spacing: 0; }
  .hero-text p  { font-size: 12.5px; max-width: 100%; }
  .hero-badge   { font-size: 12px; padding: 8px 14px; margin-top: 12px; }

  /* Servicios rápidos: 2 col */
  .services-row { grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 24px; }
  .srv-card { padding: 16px 12px 14px; gap: 8px; }
  .srv-card-icon { width: 44px; height: 44px; font-size: 18px; }
  .srv-card h3 { font-size: 14px; }
  .srv-card p  { font-size: 11px; }

  /* Carrusel */
  .carousel-section { margin-bottom: 28px; }
  .carousel-slide { height: 240px; }
  .carousel-btn { width: 48px; }
  .slide-caption { padding: 24px 16px 14px; }
  .slide-caption strong { font-size: 15px; }
  .slide-caption p { font-size: 11.5px; }
  .carousel-counter { font-size: 11px; top: 10px; right: 10px; padding: 4px 8px; }

  /* Photo grid: 2 col */
  .photo-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; margin-bottom: 28px; }
  .photo-item { height: 150px; }

  /* Block title */
  .block-title { margin-bottom: 14px; }
  .block-title h2 { font-size: 16px; }
  .block-title-icon { font-size: 16px; }
}

/* --- Mobile pequeño (≤ 480px) --- */
@media (max-width: 480px) {

  /* Hero: altura mínima */
  .hero-banner { height: 190px; }
  .hero-text h2 { font-size: 22px; }

  /* Servicios rápidos: 1 col */
  .services-row { grid-template-columns: 1fr; }

  /* Carrusel más bajo */
  .carousel-slide { height: 200px; }
  .carousel-btn { width: 36px; font-size: 13px; }
  .carousel-btn::before { width: 34px; height: 34px; }

  /* Dots más pequeños */
  .carousel-dot { width: 6px; height: 6px; }
  .carousel-dot.active { width: 18px; }

  /* Photo grid: 1 col */
  .photo-grid { grid-template-columns: 1fr; }
  .photo-item { height: 180px; }

  /* Lightbox */
  .lightbox img { max-width: 96vw; max-height: 80vh; }
  .lightbox-close { font-size: 24px; top: 12px; right: 14px; }
}


/* ================================================================
   📄  telecomunicaciones.css
   Elementos únicos: operators-container, operator-card, operator-logo
================================================================ */

/* --- Tablet (≤ 992px) --- */
@media (max-width: 992px) {

  .operators-container { padding: 32px 24px; }

  /* Cards más pequeñas */
  .operator-card { width: 170px; }
  .operator-logo { width: 160px; height: 160px; }

  /* Ajuste de tipografía interna de logos */
  .logo-digi .brand-text    { font-size: 52px; }
  .logo-masmovil .brand-text { font-size: 30px; }
  .logo-pepephone .pepe-line1,
  .logo-pepephone .pepe-line2 { font-size: 42px; }
  .logo-jazztel .brand-text { font-size: 42px; }
  .logo-lowi .brand-text    { font-size: 58px; }
}

/* --- Mobile grande (≤ 768px) --- */
@media (max-width: 768px) {

  .operators-container { padding: 24px 14px; margin-top: 14px; }
  .operators-grid { gap: 16px; }

  /* 2 tarjetas por fila */
  .operator-card { width: calc(50% - 8px); max-width: 200px; }
  .operator-logo { width: 100%; height: 130px; border-radius: 8px; }
  .operator-name { font-size: 14px; }

  /* Logo internals */
  .logo-digi .brand-text    { font-size: 42px; }
  .logo-masmovil .brand-text { font-size: 24px; }
  .logo-pepephone .pepe-line1,
  .logo-pepephone .pepe-line2 { font-size: 34px; }
  .logo-jazztel .brand-text { font-size: 34px; }
  .logo-lowi .brand-text    { font-size: 46px; }
  .logo-lowi .lowi-dot      { width: 14px; height: 14px; }
}

/* --- Mobile pequeño (≤ 480px) --- */
@media (max-width: 480px) {

  .operators-grid { gap: 10px; }
  .operator-card { width: calc(50% - 5px); }
  .operator-logo { height: 110px; }
  .operator-name { font-size: 13px; }

  .logo-digi .brand-text    { font-size: 34px; }
  .logo-masmovil .brand-text { font-size: 20px; }
  .logo-pepephone .pepe-line1,
  .logo-pepephone .pepe-line2 { font-size: 28px; }
  .logo-jazztel .brand-text { font-size: 28px; }
  .logo-lowi .brand-text    { font-size: 36px; }
}


/* ================================================================
   📄  formulario.css
   Elementos únicos: .main-wrapper centrado con form de max 500px
================================================================ */

/* --- Tablet (≤ 992px) --- */
@media (max-width: 992px) {

  .main-wrapper {
    padding: 0 16px;
    margin: 30px auto;
  }
  .main-wrapper form {
    max-width: 100%;
    padding: 32px 28px;
  }
}

/* --- Mobile grande (≤ 768px) --- */
@media (max-width: 768px) {

  /* El bloque existente ya cubre form inputs/textarea/button.
     Solo añadimos ajuste del contenedor principal. */
  .main-wrapper {
    padding: 0 14px;
    margin: 16px auto;
    align-items: stretch;
  }
  .main-wrapper form {
    padding: 24px 16px;
    border-radius: 8px;
  }
}

/* --- Mobile pequeño (≤ 480px) --- */
@media (max-width: 480px) {

  .main-wrapper form {
    padding: 20px 14px;
    gap: 14px;
  }
  .main-wrapper label { font-size: 13px; }
  .main-wrapper button[type="submit"] { padding: 14px; font-size: 16px; }
}


/* ================================================================
   📄  condiciones_compra.css | cookies.css
       aviso_legal.css | politica_privacidad.css
   Elementos únicos: .main-wrapper (max-width 70%), .main_inner
   (El bloque existente cubre h1/h2/h3 y padding de .main_inner,
    pero no el max-width del contenedor principal ni el border-radius)
================================================================ */

/* --- Tablet (≤ 992px) --- */
@media (max-width: 992px) {

  .main-wrapper {
    max-width: 90%;
    margin: 24px auto;
    padding: 0 16px;
  }
  .main_inner {
    padding: 36px 28px;
    border-radius: 8px;
  }
}

/* --- Mobile grande (≤ 768px) --- */
@media (max-width: 768px) {

  .main-wrapper {
    max-width: 100%;
    margin: 12px auto;
    padding: 0;
  }
  .main_inner {
    padding: 24px 16px;
    border-radius: 0;
    box-shadow: none;
  }

  /* Listas con menos sangría */
  ul li { padding-left: 18px; }

  /* Títulos h2 inline-block que se desbordaban */
  h2 { display: block; }
}

/* --- Mobile pequeño (≤ 480px) --- */
@media (max-width: 480px) {

  .main_inner { padding: 18px 12px; }

  h1 { font-size: 26px; padding-bottom: 10px; margin-bottom: 20px; }
  h2 { font-size: 18px; }
  h3 { font-size: 15px; }

  .section-box  { padding: 12px; }
  .highlight    { padding: 12px 14px; }
  ul li { font-size: 13.5px; margin-bottom: 8px; }
}


/* ================================================================
   📄  plantilla.css
   Mismo layout de 3 columnas que main.css → mismas reglas
   (copiar el bloque de main.css aquí también)
================================================================ */

/* --- Tablet (≤ 992px) --- */
@media (max-width: 992px) {

  .main-wrapper {
    grid-template-columns: 1fr;
    gap: 14px;
    margin: 16px auto;
  }
}

/* --- Mobile grande (≤ 768px) --- */
@media (max-width: 768px) {

  .main-wrapper {
    grid-template-columns: 1fr;
    padding: 0 14px;
    margin: 10px auto;
  }
  .main_inner { padding: 20px 14px; border-radius: 6px; }
}

/* --- Mobile pequeño (≤ 480px) --- */
@media (max-width: 480px) {

  .main_inner { padding: 16px 12px; border-radius: 0; box-shadow: none; }
}


/* ================================================================
   📄  servicios.css
   El @media existente cubre .services-grid y .feature-strip,
   pero falta ajustar .page-wrapper y el hover de .service-icon-wrap
   en pantallas con altura reducida.
================================================================ */

/* --- Tablet (≤ 992px) --- */
@media (max-width: 992px) {

  .page-wrapper { padding: 0 16px; margin: 20px auto 36px; }
  .service-icon-wrap { height: 130px; }
  .service-icon { font-size: 44px; }
  .service-body { padding: 16px 16px 20px; }
  .service-title { font-size: 17px; }
}

/* --- Mobile grande (≤ 768px) --- */
@media (max-width: 768px) {

  .page-wrapper { padding: 0 14px; margin: 14px auto 28px; }

  /* Cards en horizontal (icono a la izquierda) */
  .service-card { flex-direction: row; align-items: flex-start; }
  .service-icon-wrap { height: 90px; min-width: 90px; flex: 0 0 90px; }
  .service-icon { font-size: 36px; }
  .service-body { padding: 14px 14px 14px 0; }
  .service-title { font-size: 15px; margin-bottom: 6px; }
  .service-desc  { font-size: 12.5px; }
  .service-link  { font-size: 12px; margin-top: 10px; }
}

/* --- Mobile pequeño (≤ 480px) --- */
@media (max-width: 480px) {

  /* Cards apiladas */
  .service-card { flex-direction: column; }
  .service-icon-wrap { height: 100px; min-width: auto; flex: none; width: 100%; }
  .service-icon { font-size: 40px; }
  .service-body { padding: 14px; }

  /* Feature strip a 1 col con items horizontales */
  .feature-strip { grid-template-columns: 1fr; }
  .feature-item {
    flex-direction: row;
    text-align: left;
    gap: 12px;
    padding: 14px;
    align-items: center;
  }
  .feature-item i { font-size: 24px; }
}