  :root {
    --gris_fondo: #f7f7f8;
    --gris_borde: #e6e6ea;
    --gris_texto: #555;
    --gris_icono: #8b8b94;
    --azul_btn: #1677ff;
    --azul_btn_hover: #125fd0;
    --verde: #1f9d55;
    --rojo: #ff3b3b;
    --amarillo: #ffc107;
    --negro: #111;
    --blanco: #fff;
    --radio: 18px;
    --sombra: 0 10px 25px rgba(16, 24, 40, .08);
  }


  .pagina_producto {
    max-width: 1400px;
    margin: auto;
    padding: 24px 16px;
    display: grid;
    gap: 24px;
    grid-template-columns: 1fr 1fr 0.8fr;
    /* ahora 3 columnas */
  }

  /* --- GALERÍA --- */
  .galeria_producto {
    background: var(--blanco);
    border: 1px solid var(--gris_borde);
    border-radius: var(--radio);
    padding: 16px;
    box-shadow: var(--sombra);
  }

  .visor {
    position: relative;
    border: 1px solid var(--gris_borde);
    border-radius: 16px;
    overflow: hidden;
    background: #fff;
    aspect-ratio: 1.2 / 1;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .visor img {
    width: 100%;
    height: 100%;
    object-fit: contain;
  }

  .control_flecha {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, .9);
    border: 1px solid var(--gris_borde);
    width: 40px;
    height: 40px;
    display: grid;
    place-items: center;
    border-radius: 50%;
    cursor: pointer;
    user-select: none;
    transition: .2s;
    box-shadow: var(--sombra);
  }

  .control_flecha:hover {
    background: #fff;
  }

  .control_prev {
    left: 12px;
  }

  .control_next {
    right: 12px;
  }

  .miniaturas {
    margin-top: 12px;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 10px;
  }

  .miniatura {
    border: 2px solid transparent;
    border-radius: 12px;
    overflow: hidden;
    background: #fff;
    aspect-ratio: 1/1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .miniatura img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .miniatura.activa {
    border-color: var(--azul_btn);
  }

  /* --- INFO --- */
  .info_producto {
    display: flex;
    flex-direction: column;
    gap: 16px;
  }

  .ruta_migas {
    color: var(--gris_icono);
    font-size: 13px;
  }

  .ruta_migas a {
    color: inherit;
    text-decoration: none;
  }

  .encabezado_producto {
    background: var(--blanco);
    border: 1px solid var(--gris_borde);
    border-radius: var(--radio);
    padding: 18px;
    box-shadow: var(--sombra);
  }

  .marca {
    font-weight: 700;
    letter-spacing: .4px;
    color: var(--gris_texto);
    font-size: 13px;
    text-transform: uppercase;
  }

  .titulo_producto {
    font-size: 22px;
    line-height: 1.25;
    margin: 6px 0 8px;
    font-weight: 700;
  }

  .calificacion {
    display: flex;
    align-items: center;
    gap: 8px;
    color: var(--gris_texto);
    font-size: 14px;
  }

  .estrellas {
    color: #f59e0b;
  }

  .precio_bloque {
    display: flex;
    align-items: flex-end;
    gap: 16px;
    margin-top: 8px;
  }

  .precio_actual {
    font-size: 16px;
    font-weight: 800;
    color: gray
  }

  .precio_antes {
    color: var(--gris_icono);
    text-decoration: line-through;
    font-size: 14px;
  }

  .descuento_badge {
    background: #ffe9ea;
    color: #d61f1f;
    border: 1px solid #ffd0d4;
    padding: 4px 8px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 700;
  }

  .cuenta_unidades {
    color: var(--gris_icono);
    font-size: 12px;
    margin-top: 6px;
  }

  .acciones_compra {
    display: flex;
    gap: 12px;
    align-items: center;
    margin-top: 12px;
  }

  .contador_cantidad {
    display: flex;
    align-items: center;
    border: 1px solid var(--gris_borde);
    border-radius: 12px;
    overflow: hidden;
  }

  .contador_cantidad button {
    width: 36px;
    height: 40px;
    background: #fff;
    border: 0;
    font-size: 18px;
    cursor: pointer;
  }

  .contador_cantidad input {
    width: 48px;
    height: 40px;
    border: 0;
    text-align: center;
    font-size: 16px;
  }

  .btn_agregar {
    flex: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    height: 44px;
    background: var(--azul_btn);
    color: #fff;
    border: 0;
    border-radius: 12px;
    padding: 0 18px;
    font-weight: 700;
    cursor: pointer;
    transition: .2s;
    box-shadow: 0 6px 14px rgba(22, 119, 255, .25);
  }

  .btn_agregar:hover {
    background: var(--azul_btn_hover);
  }

  .tarjetas_info {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }

  .tarjeta {
    background: #fff;
    border: 1px solid var(--gris_borde);
    border-radius: 14px;
    padding: 14px;
    box-shadow: var(--sombra);
    text-align: center;
    
  }

  .tarjeta small {
    display: block;
    color: var(--gris_texto);
    margin-top: 6px;
  }

  .vendedor_bloque {
    background: #fff;
    border: 1px solid var(--gris_borde);
    border-radius: var(--radio);
    padding: 14px;
    box-shadow: var(--sombra);
  }

  .vendedor_encabezado {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .vendedor_nombre {
    font-weight: 700;
  }

  .vendedor_estrellas {
    color: #f59e0b;
    font-size: 14px;
  }

  .enlace_vendedor {
    display: inline-block;
    margin-top: 8px;
    font-size: 14px;
    color: #1f6fd7;
    text-decoration: none;
  }

  .caracteristicas {
    background: #fff;
    border: 1px solid var(--gris_borde);
    border-radius: var(--radio);
    padding: 14px;
    box-shadow: var(--sombra);
  }

  .caracteristicas h3 {
    margin: 0 0 8px;
    font-size: 16px;
  }

  .lista_caracteristicas {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 8px;
  }

  .lista_caracteristicas li {
    display: flex;
    gap: 8px;
    color: var(--gris_texto);
  }

  .lista_caracteristicas li::before {
    content: "•";
    color: var(--gris_icono);
  }

  .galeria_producto .visor {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    /* Esto sube la imagen */
    margin-top: -20px;
    /* Ajusta según lo que necesites */
  }

  /* --- NUEVA SECCIÓN LATERAL --- */
  .extra_lateral {
    background: #fff;
    border: 1px solid var(--gris_borde);
    border-radius: var(--radio);
    padding: 16px;
    box-shadow: var(--sombra);
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
  }

  .extra_lateral img {
    
    border-radius: 12px;
    object-fit: cover;
  }

  .extra_lateral h3 {
    font-size: 18px;
    margin: 0;
    text-align: center;
  }

  /* --- RESPONSIVE --- */
  @media (max-width: 1024px) {
    .pagina_producto {
      grid-template-columns: 1fr;
    }

    .miniaturas {
      grid-template-columns: repeat(5, 1fr);
    }
  }

  @media (max-width: 640px) {
    .miniaturas {
      grid-template-columns: repeat(4, 1fr);
    }

    .titulo_producto {
      font-size: 20px;
    }

    .precio_actual {
      font-size: 24px;
    }

    .tarjetas_info {
      grid-template-columns: 1fr;
    }

    .acciones_compra {
      flex-direction: column;
      align-items: stretch;
    }

    .contador_cantidad {
      width: 100%;
      justify-content: space-between;
    }
  }

  .tarjeta_documento {
    width: 280px;
    border-radius: 15px;
    overflow: hidden;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);

    background: #fff;
    transition: transform 0.2s;
  }

  .tarjeta_documento:hover {
    transform: translateY(-5px);
  }

  /* Imagen superior */
  .contenedor_imagen_documento {
    position: relative;
    width: 100%;
    height: 160px;
    overflow: hidden;
  }

  .contenedor_imagen_documento img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  /* Etiqueta superior */
  .etiqueta_categoria {
    position: absolute;
    top: 10px;
    left: 10px;
    background: #e6f4f1;
    color: #008c7a;
    padding: 5px 12px;
    font-size: 12px;
    font-weight: bold;
    border-radius: 12px;
  }

  /* Contenido inferior */
  .contenido_documento {
    padding: 15px;
    text-align: center;
  }

  .titulo_documento {
    font-size: 15px;
    font-weight: bold;
    margin-bottom: 5px;
    color: #2c3e50;
  }

  .subtitulo_documento {
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 12px;
    color: #555;
  }

  .ficha-tecnica {
    max-width: 450px;
    border: 1px solid #ddd;
    border-radius: 6px;
 
    font-size: 14px;
    background: #fff;
    overflow: hidden;
  }

  .ficha-tecnica h3 {
    background: #f5f5f5;
    margin: 0;
    padding: 10px;
    font-size: 16px;
    border-bottom: 1px solid #ddd;
  }

  .ficha-tecnica ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .ficha-tecnica li {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 10px;
    border-bottom: 1px solid #eee;
  }

  .ficha-tecnica li span:first-child {
    font-weight: bold;
    color: #333;
    background: #fafafa;
    padding: 5px;
  }

  .ficha-tecnica li span:last-child {
    padding: 5px;
    text-align: right;
  }

  /* Botón descarga */
  .boton_descarga {
    display: inline-block;
    background: #2d2e83;
    color: #fff;
    padding: 8px 18px;
    border-radius: 20px;
    font-size: 14px;
    text-decoration: none;
    font-weight: bold;
    transition: background 0.3s;
  }

  .boton_descarga:hover {
    background: #1c1d5c;
  }