/*
Theme Name: Salient Child Theme
Description: This is a custom child theme for Salient
Theme URI:   https://themeforest.net/item/salient-responsive-multipurpose-theme/4363266
Author: ThemeNectar
Author URI:  https://themeforest.net/user/themenectar
Template: salient
Version: 1.0
*/

:root {
    --blanco: #FFFFFF;
    --negro: #000000;
    --principal: #3696f3;
}

.blanco {
    color: #FFFFFF !important;
}

.negro {
    color: #000000 !important;
}

.principal {
    color: #3696f3 !important;
}

.text-balanced {
    text-wrap: balance !important;
}

/* Util para centrar en vertical elementos que se muestran en columnas */
.flex-center .vc_column-inner {
    display: flex;
    justify-content: center;
}

/*Imagenes en full width container se adapten en altas resoluciones*/
.img-with-animation {
    width: 100%;
}

.current-menu-item a {
    font-weight: 700 !important;
}

.off-canvas-menu-container li li a {
    font-size: 18px !important;
}

/*SCROLLBAR*/
body {
    &::-webkit-scrollbar {
        width: 10px;
    }

    &::-webkit-scrollbar-track {
        box-shadow: transparent;
        background-color: var(--blanco);
    }

    &::-webkit-scrollbar-thumb {
        background: var(--principal);
        /* border-radius: 5px; */
    }
}

/*FORMULARIOS*/
.wpcf7-form-control-wrap {
    position: relative;
}

.wpcf7-form-control-wrap textarea {
    resize: none !important;
}

.wpcf7-quiz-label {
    position: absolute;
    left: 1%;
    top: 20%;
    border-right: 1pt solid #000;
    padding-right: 5px;
}

.invalid .wpcf7-quiz-label {
    top: 10%;
}

.wpcf7-form-control.wpcf7-quiz {
    padding-left: 70px;
}

.grecaptcha-badge {
    visibility: hidden;
}

/* .meta-category,
.blog-recent .post-header .meta,
.blog-recent .article-content-wrap .excerpt {
    display: none !important;
} */

/* FOOTER */
.rrss-footer {
    display: flex;
    gap: 15px;
    flex-flow: row nowrap;
    justify-content: flex-start;
    align-items: center;
}

.rrss-footer .rrss-footer--img {
    width: 50px !important;
}

.links-footer {
    display: flex;
    flex-flow: column nowrap;
    gap: 10px;
}

.links-footer a {
    color: var(--blanco);
}

.search-footer {
    display: flex;
    background-color: var(--blanco-footer);
    margin-bottom: 20px;
}

.search-footer .input-search {
    color: var(--blanco) !important;
    border-radius: 0 !important;
    background-color: transparent !important;
    border-width: 0 !important;
}

.search-footer .input-search:hover,
.search-footer .input-search:focus {
    box-shadow: none !important;
    border: none !important;
}

.search-footer .btn-search {
    width: 30px;
    transition: transform 0.45s;
    background-color: transparent !important;
}

.search-footer .btn-search:hover,
.search-footer .btn-search:focus {
    -webkit-transform: translateY(-3px);
    -moz-transform: translateY(-3px);
    -ms-transform: translateY(-3px);
    transform: translateY(-3px);
}

#footer-outer {
    border-top: 2px solid #00b2ce;
}

#footer-outer #copyright {
    padding: 10px 0 !important;
    border-top: 2px solid #00b2ce !important;
}

#footer-outer #copyright p {
    font-size: 16px;
}

#footer-outer #copyright .col.span_5 {
    max-width: 100% !important;
}

#footer-outer #footer-widgets .container .row {
    padding: 20px 0 !important;
}

#footer-outer #footer-widgets .container .row .widget {
    margin-bottom: 0 !important;
}

#footer-outer #footer-widgets .container .row .widget .aligncenter {
    text-align: center;
    margin: 0 !important;
}

.mec-container {
    min-height: 100vh;
}

.mec-credit-url {
    display: none !important;
}

.menu-item.wpml-ls-item .sub-menu {
    width: 50px !important;
    padding: 10px !important;
}

/* Categorías home */
.categoria-riu {
    position: relative;
    min-height: 400px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    overflow: hidden;
    box-shadow: rgba(0, 0, 0, 0.04) 0 1px 0, rgba(0, 0, 0, 0.05) 0 2px 7px, rgba(0, 0, 0, 0.06) 0 12px 22px;
    text-decoration: none;
}

.categoria-riu__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 2.5s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.6s ease !important;
    z-index: 1;
}

.categoria-riu__bg::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    transition: background 0.3s ease;
    z-index: 2;
}

.categoria-riu__content {
    position: relative;
    z-index: 3;
    text-align: center;
    padding: 20px;
}

.categoria-riu__content h3 {
    color: var(--blanco);
    margin-bottom: 0 !important;
}

.categoria-riu:hover .categoria-riu__bg {
    transform: scale(1.1);
}

.categoria-riu:hover .categoria-riu__bg::after {
    background: rgba(0, 0, 0, 0.5);
}

/* Categorías NEW home */
.categoria-new-riu {
    position: relative;
    min-height: 400px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    /* border-radius: 10px; */
    box-shadow: 0 0 12px 2px #888;
    overflow: hidden;
    /* box-shadow: rgba(0, 0, 0, 0.04) 0 1px 0, rgba(0, 0, 0, 0.05) 0 2px 7px, rgba(0, 0, 0, 0.06) 0 12px 22px; */
    text-decoration: none;
}

.categoria-new-riu__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 2.5s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.6s ease !important;
    z-index: 1;
}

/* .categoria-new-riu__bg::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    transition: background 0.3s ease;
    z-index: 2;
} */

.categoria-new-riu__content {
    position: relative;
    z-index: 3;
    text-align: center;
    padding: 20px;
}

.categoria-new-riu__content h2 {
    color: var(--negro);
    margin-bottom: 0 !important;
}

.categoria-new-riu:hover .categoria-new-riu__bg {
    transform: scale(1.1);
}

.categoria-new-riu:hover .categoria-new-riu__bg::after {
    background: rgba(0, 0, 0, 0.5);
}

/* Home Button */
.cta-home {
    display: flex;
    justify-content: flex-start;
    margin: 10px 0 !important;
}

.cta-home__link {
    display: flex;
    align-items: flex-end;
    gap: 10px;
    text-decoration: none;
    color: var(--blanco);
    background-color: var(--principal);
    padding: 5px 20px;
    border-radius: 10px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
    transition: background-color 0.3s ease, transform 0.3s ease;
}

.cta-home__link:hover {
    color: var(--blanco);
    transform: scale(1.025) translateY(-2px);
}

.cta-home__arrow {
    font-size: 18px;
}

.cta-home__icon {
    font-size: 16px;
    padding: 1px 8px;
    border-radius: 200px;
    background-color: rgba(0, 0, 0, 0.3);
}

/* HOME */
.right-events {
    max-height: 910px;
    overflow-y: auto;
}

/* .right-events .mec-event-detail, */
.right-events .mec-event-footer,
.right-events .event-color {
    display: none !important;
}

.right-events .mec-wrap .row,
.right-events .mec-event-image img,
.right-events .mec-event-date,
.right-events .mec-skin-grid-container,
.right-events .mec-event-title {
    margin: 0 !important;
}

.right-events .mec-event-image img {
    max-height: 120px !important;
    width: 100% !important;
    object-fit: cover;
    object-position: center;
}

.right-events::-webkit-scrollbar {
    width: 6px;
}

.right-events::-webkit-scrollbar-track {
    box-shadow: transparent;
    background-color: #eee;
}

.right-events .mec-event-date {
    background-color: #6ad8f8 !important;
}

.right-events .mec-event-title {
    font-weight: 600 !important;
    color: var(--negro);
    font-family: Roboto;
}

.right-events .mec-event-title,
.right-events .mec-grid-event-location {
    padding: 5px 10px;
    padding-bottom: 5px !important;
}

.right-events::-webkit-scrollbar-thumb {
    background: var(--principal);
}

.right-events .mec-event-article {
    margin-bottom: 0;
}

.right-events .mec-event-content {
    padding: 0 !important;
}

.home .top-highlight {
    font-size: 2rem;
}

.home .nectar-highlighted-text {
    font-size: 2.5rem;
}

.home .nectar-highlighted-text b {
    font-family: Poppins !important;
}

.home div[data-id="hlight-comercios"],
.home div[data-id="hlight-eventos"],
.home div[data-id="hlight-patrimonio"],
.home div[data-id="hlight-noticias"] {
    display: flex;
    justify-content: center;
}

.home div[data-id="hlight-comercios"] p,
.home div[data-id="hlight-eventos"] p,
.home div[data-id="hlight-patrimonio"] p,
.home div[data-id="hlight-noticias"] p {
    width: fit-content;
    position: relative;
}

/* .home div[data-id="hlight-comercios"] p:before {
    content: '';
    display: inline-block;
    width: 75px;
    height: 75px;
    background-image: url('/wp-content/uploads/2025/01/comercios_left.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    bottom: -5px;
    position: absolute;
    left: -60px;
    z-index: -1;
} */

.home div[data-id="hlight-comercios"] p:before {
    content: '';
    display: inline-block;
    width: 155px;
    height: 75px;
    background-image: url('/wp-content/uploads/2025/01/puente_left.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    bottom: -20px;
    position: absolute;
    left: -155px;
    z-index: -1;
}

.home div[data-id="hlight-comercios"] p:after {
    content: '';
    display: inline-block;
    width: 75px;
    height: 75px;
    /* background-image: url('/wp-content/uploads/2025/01/comercios_right.webp'); */
    background-image: url('/wp-content/uploads/2025/01/comercios_left.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    right: -60px;
    bottom: -5px;
    z-index: -1;
}

.home div[data-id="hlight-eventos"]:after {
    content: '';
    display: inline-block;
    width: 150px;
    height: 150px;
    background-image: url('/wp-content/uploads/2025/01/eventos_right.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    right: -12px;
    top: -46px;
    z-index: -1;
}


/* .home div[data-id="hlight-patrimonio"] p:before {
    content: '';
    display: inline-block;
    width: 155px;
    height: 75px;
    background-image: url('/wp-content/uploads/2025/01/puente_left.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    bottom: -20px;
    position: absolute;
    left: -155px;
    z-index: -1;
}

.home div[data-id="hlight-patrimonio"] p:after {
    content: '';
    display: inline-block;
    width: 151px;
    height: 75px;
    background-image: url('/wp-content/uploads/2025/01/puente_right.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    right: -150px;
    bottom: -20px;
    z-index: -1;
} */

.home div[data-id="hlight-noticias"] p:before {
    content: '';
    display: inline-block;
    width: 350px;
    height: 150px;
    background-image: url('/wp-content/uploads/2025/01/noticias_left.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    bottom: -40px;
    position: absolute;
    left: -375px;
    z-index: -1;
}

.home div[data-id="hlight-noticias"] p:after {
    content: '';
    display: inline-block;
    width: 350px;
    height: 150px;
    background-image: url('/wp-content/uploads/2025/01/noticias_right.webp');
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    right: -375px;
    bottom: -40px;
    z-index: -1;
}

/* MEDIA QUERY */
@media only screen and (max-width: 690px) {
    .categoria-riu {
        min-height: 200px;
    }

    .home .top-highlight,
    .home .nectar-highlighted-text {
        font-size: 1.5rem;
        font-family: Poppins;
    }

    .home .nectar-highlighted-text {
        font-size: 1.75rem;
    }

    .home div[data-id="hlight-comercios"] p:before,
    .home div[data-id="hlight-comercios"] p:after {
        width: 40px;
        height: 40px;
        bottom: -2px;
    }

    .home div[data-id="hlight-comercios"] p:before {
        left: -25px;
    }

    .home div[data-id="hlight-comercios"] p:after {
        right: -25px;
    }

    .home div[data-id="hlight-eventos"]:after {
        width: 100px;
        height: 100px;
        top: -22px;
        right: 0;
    }
}

@media only screen and (min-width: 690px) and (max-width: 1080px) {
    .right-events {
        max-height: 880px;
    }

    .home div[data-id="hlight-eventos"]:after {
        width: 115px;
        height: 115px;
        top: -38px;
        right: -25px;
    }
}

@media only screen and (min-width: 1000px) {
    .container {
        padding: 0 40px;
    }

    .right-events .mec-event-title {
        line-height: 20px !important;
    }
}

@media only screen and (min-width: 690px) and (max-width: 1000px) {
    .vc_row-fluid[data-column-margin="60px"] .wpb_column:not(.child_column) {
        padding: 0 10px !important;
    }

    .home .top-highlight {
        font-size: 1.75rem;
    }

    .home .nectar-highlighted-text {
        font-size: 2rem;
    }

    .home div[data-id="hlight-comercios"] p:before,
    .home div[data-id="hlight-comercios"] p:after {
        width: 50px;
        height: 50px;
    }

    .home div[data-id="hlight-comercios"] p:before {
        left: -40px;
    }

    .home div[data-id="hlight-comercios"] p:after {
        right: -40px;
    }
}

@media only screen and (max-width: 1000px) {

    .right-events .mec-event-image,
    .right-events .mec-event-image img {
        width: 100% !important;
        margin: 0 !important;
    }

    .right-events .mec-event-image img {
        max-width: 125px !important;
    }

    .right-events .mec-event-title,
    .right-events .mec-color-hover,
    .right-events .mec-color-hover img,
    .right-events .mec-event-article {
        margin: 0 !important;
    }

    .right-events .mec-event-article {
        padding: 0 !important;
        margin-bottom: 10px !important;
    }

    .container-wrap {
        padding-bottom: 0 !important;
        overflow: hidden !important;
    }
}

.popup {
    justify-content: center;
    align-items: center;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.4);
    cursor: auto;
    display: none;
}

.popup .popup__container {
    display: flex;
    flex-flow: column nowrap;
    gap: 5px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 8px;
    padding: 20px;
    width: 80%;
    max-width: 700px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.popup .popup__close {
    position: absolute;
    color: #3a3a38;
    align-self: flex-end;
    font-size: 28px;
    font-weight: bold;
    padding: 5px 10px 0 0;
    cursor: pointer;
}

.popup .popup__close:hover {
    color: #aaa;
}

.popup .popup__content {
    display: flex;
    flex-flow: column nowrap;
    justify-content: center;
    align-items: center;
}

.popup .popup__content canvas {
    width: 100%;
    max-width: 400px;
    height: auto;
}

/* NUEVOS CAMBIOS MENU */

#header-outer:not([data-format=left-header]) #top>.container>.row nav>ul {
    align-items: flex-end;
    padding-bottom: 40px;
}

/*  ESTILOS CAROUSEL SHORTCODE OFERTAS */

/* ===== Paleta base ===== */
:root{
  --of-accent:#2596be; --of-ink:#1f2937; --of-ink-2:#6b7280;
  --of-line:#e5e7eb; --of-card:#fff; --of-chip:#f3f4f6;
}

/* Wrapper + estados (evita FOUC) */
.ofertas-slider{ margin-block:20px; }
.ofertas-slider .f-carousel{ opacity:0; overflow-y:hidden; transition:opacity .2s ease; }
.ofertas-slider .f-carousel.is-ready,
.ofertas-slider.use-fallback .f-carousel{ opacity:1; }

/* 3 visibles SIEMPRE (carousel y fallback) */
.ofertas-slider .f-carousel__slide{ width:33.3333% !important; padding:4px; }
.ofertas-slider.use-fallback .f-carousel{
  display:flex !important; overflow-x:auto; -webkit-overflow-scrolling:touch; scroll-snap-type:x mandatory; gap:8px; padding:2px;
}
.ofertas-slider.use-fallback .f-carousel__slide{
  flex:0 0 33.3333% !important; max-width:33.3333% !important; scroll-snap-align:start;
}

/* Navegación: flechas fuera para no tapar tarjetas */
.ofertas-slider .f-carousel__nav{ pointer-events:none; }
.ofertas-slider .f-carousel__nav .f-button{
  pointer-events:auto; position:absolute; top:50%; transform:translateY(-50%);
  z-index:5; background:#fff; color:#2596be; border:1px solid #e5e7eb;
  box-shadow:0 6px 16px rgba(0,0,0,.12); width:36px; height:36px; border-radius:999px;
}
.ofertas-slider .f-carousel__nav .f-button.is-prev{ left:-18px; }
.ofertas-slider .f-carousel__nav .f-button.is-next{ right:-18px; }
.ofertas-slider .f-carousel__nav .f-button svg{ stroke: currentColor; }

/* ===== Tarjeta compacta tipo restaurante ===== */
.ofr-compact{
  display:grid; grid-template-columns:160px 1fr; gap:10px;
  background:var(--of-card); border:1px solid var(--of-line); border-radius:12px; overflow:hidden;
  box-shadow:0 4px 12px rgba(0,0,0,.05);
  min-height:176px !important; height:176px !important;
}
.ofr-thumb{ position:relative; display:block; overflow:hidden; border-right:1px solid var(--of-line); height:100% !important; }
.ofr-thumb img{ width:100% !important; height:100% !important; object-fit:cover !important; object-position:center !important; display:block; }
.ofr-badge{
  position:absolute; top:8px; left:8px; background:var(--of-accent); color:#fff;
  font-weight:700; font-size:11px; padding:4px 8px; border-radius:999px; box-shadow:0 4px 10px rgba(37,150,190,.25);
}
/* Fallback logo: encaja sin “desbordar visualmente” */
.ofr-thumb img[src*="logo-marketplace-huelva_negro.webp"]{
  object-fit:contain !important; background:#fff !important; padding:12px !important;
}

.ofr-body{
  display:grid !important; grid-template-rows:auto auto 1fr auto; gap:6px;
  padding:10px 12px 10px 8px; height:100% !important; overflow:hidden; color:var(--of-ink);
}
.ofr-title{ margin:0; font-size:.96rem; line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ofr-link{ color:var(--of-ink); text-decoration:none; border-bottom:1px solid transparent; transition:color .15s,border-color .15s; }
.ofr-link:hover{ color:var(--of-accent); border-color:var(--of-accent); }

.ofr-meta{ display:flex; align-items:center; gap:6px; overflow:hidden; white-space:nowrap; }
.chip{ white-space:nowrap; font-size:.76rem; padding:3px 8px; border-radius:999px; font-weight:700; background:#e6f5fb; color:#0b4860; border:1px solid #cbeaf5; }
.chip--muted{ background:var(--of-chip); color:#4b5563; border-color:#e5e7eb; font-weight:600; }

.ofr-desc{
  grid-row:3; margin:0; color:var(--of-ink-2); font-size:.86rem; line-height:1.25;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
  min-height:calc(1.25em * 2); /* reserva alto de 2 líneas aunque el texto sea corto */
}
/* Espaciador si no hay extracto, para mantener botón abajo */
.ofr-body::after{ content:""; display:block; grid-row:3; min-height:calc(1.25em * 2); }
.ofr-body:has(.ofr-desc)::after{ display:none; }

.ofr-cta{
  grid-row:4; align-self:end; justify-self:start;
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 10px; border-radius:999px; font-weight:700; font-size:.88rem;
  text-decoration:none; border:1px solid var(--of-accent);
  background:var(--of-accent); color:#fff;
  box-shadow:0 6px 16px rgba(37,150,190,.28);
  transition:transform .15s, box-shadow .15s, background .15s, color .15s, border-color .15s;
}
.ofr-cta:hover{
  background:#fff; color:var(--of-accent); border-color:var(--of-accent);
  transform:translateY(-1px); box-shadow:0 10px 24px rgba(37,150,190,.20);
}
.ofr-cta .cta-ic{ transform:translateX(0); transition:transform .15s; }
.ofr-cta:hover .cta-ic{ transform:translateX(2px); }

@media (max-width:640px){
  .ofertas-slider .f-carousel__slide,
  .ofertas-slider.use-fallback .f-carousel__slide{ width:50% !important; flex-basis:50% !important; max-width:50% !important; }
}
@media (max-width:420px){
  .ofertas-slider .f-carousel__slide,
  .ofertas-slider.use-fallback .f-carousel__slide{ width:100% !important; flex-basis:100% !important; max-width:100% !important; }
}


/* ESTILOS MODAL PARA SLIDER EMPRESA */

.oferta-modal{ display:grid; grid-template-columns: 300px 1fr; gap:16px; max-width: 900px; }
.oferta-modal__media img{ width:100%; height:100%; object-fit:cover; border-radius:8px; }
.oferta-modal__body{ display:flex; flex-direction:column; gap:10px; }
.oferta-modal__title{ margin:0; font-size:1.25rem; }
.oferta-modal__meta{ display:flex; flex-wrap:wrap; gap:6px; }
.oferta-modal__desc{ margin:0; color:#4b5563; }
.oferta-modal__cta{ margin-top:auto; }
@media (max-width:700px){
  .oferta-modal{ grid-template-columns: 1fr; }
  .oferta-modal__media img{ aspect-ratio: 16/9; }
}

/* ====== Overlay Fancybox v5 (más oscuro, visible el sitio detrás) ====== */
.fancybox__backdrop {
  background: rgba(0, 0, 0, .6) !important;
}

/* ====== Contenedor del modal de ofertas (scoped por clase que añadimos en JS) ====== */
.fancybox__content.oferta-fb{
  background: #fff;
  border-radius: 14px;
  padding: 16px;
  max-width: 720px;     /* tamaño máximo del modal */
  width: min(92vw, 720px);
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
}

/* Quita el borde por defecto si lo hubiera */
.fancybox__content.oferta-fb .fancybox__toolbar,
.fancybox__content.oferta-fb .fancybox__slide {
  border: 0;
}

/* Layout interno del modal (tu HTML ya viene dentro de .oferta-modal) */
.oferta-modal{
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 16px;
}

.oferta-modal__media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px;
  /* si la imagen es el logo fallback, que no “desborde visualmente” */
}
.oferta-modal__media img[src*="logo-marketplace-huelva_negro.webp"]{
  object-fit: contain;
  background: #fff;
  padding: 12px;
}

.oferta-modal__body{
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 10px;
  min-height: 0; /* evita overflow en grid */
}

.oferta-modal__title{
  margin: 0;
  font-size: 1.2rem;
  line-height: 1.25;
  color: #1f2937;
}

.oferta-modal__meta{
  display: flex; flex-wrap: wrap; gap: 6px;
}

.oferta-modal__desc{
  margin: 0; color: #4b5563; line-height: 1.45;
  display: -webkit-box; -webkit-line-clamp: 6; -webkit-box-orient: vertical; overflow: hidden;
}

/* Botón dentro del modal: SIEMPRE blanco de texto (por si el tema pisa estilos) */
.oferta-modal__cta{
  align-self: end;
}
.oferta-modal__cta [data-go-empresa]{
  appearance: none;
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid #2596be !important;
  background: #2596be !important;
  color: #fff !important;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 8px 18px rgba(37,150,190,.25);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.oferta-modal__cta [data-go-empresa]:hover{
  background: #fff !important;
  color: #2596be !important;
  box-shadow: 0 12px 28px rgba(37,150,190,.32);
  transform: translateY(-1px);
}

/* Chips reutilizan tus estilos existentes; por si acaso: */
.oferta-modal .chip{
  white-space: nowrap;
  font-size: .82rem;
  padding: 4px 9px;
  border-radius: 999px;
  background: #e6f5fb; color: #0b4860; border: 1px solid #cbeaf5;
}
.oferta-modal .chip--muted{
  background: #f3f4f6; color: #4b5563; border-color: #e5e7eb;
}

/* Responsive: modal más estrecho y imagen apilada en móvil */
@media (max-width: 700px){
  .fancybox__content.oferta-fb{
    width: min(96vw, 640px);
    padding: 14px;
  }
  .oferta-modal{
    grid-template-columns: 1fr;
  }
  .oferta-modal__media img{
    aspect-ratio: 16/9;
  }
}

.s-oferta-modal {
    color: #FFFFFF !important;
}

/* ===== Modal ofertas más GRANDE ===== */

/* Contenedor Fancybox del modal de oferta */
.fancybox__content.oferta-fb{
  /* más ancho y alto utilizable */
  max-width: 980px;                 /* antes 640px */
  width: min(96vw, 980px);
  max-height: 88vh;                 /* usar casi toda la altura de la ventana */
  padding: 20px;                    /* un pelín más de padding */
  overflow: hidden;                 /* controlamos scroll dentro del cuerpo */
}

/* Layout interno más holgado */
.oferta-modal{
  display: grid;
  grid-template-columns: 360px 1fr; /* imagen más grande a la izquierda */
  gap: 18px;
  min-height: 0;                    /* necesario para que el grid pueda scroll dentro */
}

/* Columna imagen: ocupa toda su columna y escala bien */
.oferta-modal__media img{
  width: 100%;
  height: 100%;
  max-height: calc(88vh - 40px);    /* alto del modal - paddings aprox */
  object-fit: cover;
  border-radius: 12px;
}

/* Si es el logo fallback, encájalo sin recortar */
.oferta-modal__media img[src*="logo-marketplace-huelva_negro.webp"]{
  object-fit: contain;
  background: #fff;
  padding: 14px;
}

/* Columna derecha: título/fechas/desc con scroll si sobra */
.oferta-modal__body{
  display: grid;
  grid-template-rows: auto auto 1fr; /* título, fechas, contenido flexible */
  gap: 12px;
  min-height: 0;
  overflow: auto;                    /* scroll vertical si es necesario */
  padding-right: 6px;                /* un pelín de aire para que no tape la scrollbar */
}

/* Tipos un poco mayores para que “llene” mejor el espacio */
.oferta-modal__title{
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.25;
  color: #1f2937;
}

.oferta-modal__fechas{
  font-weight: 700;
  color: #2596be;
  font-size: 1rem;
}

/* La descripción puede crecer más líneas antes de truncar */
.oferta-modal__desc{
  margin: 0;
  color: #4b5563;
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 10;           /* antes 6; muestra más texto en modales grandes */
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Responsivo: en pantallas medianas aún grande pero cómodo */
@media (max-width: 1100px){
  .fancybox__content.oferta-fb{
    max-width: 900px;
    width: min(96vw, 900px);
  }
  .oferta-modal{
    grid-template-columns: 320px 1fr;
  }
}

/* Móvil: apila, mantén el modal grande dentro de lo razonable */
@media (max-width: 700px){
  .fancybox__content.oferta-fb{
    width: min(98vw, 640px);
    max-width: 98vw;
    max-height: 90vh;
    padding: 16px;
  }
  .oferta-modal{
    grid-template-columns: 1fr;   /* imagen arriba, texto abajo */
    gap: 12px;
  }
  .oferta-modal__media img{
    aspect-ratio: 16/9;           /* imagen más ancha que alta en móvil */
    max-height: none;
  }
  .oferta-modal__desc{
    -webkit-line-clamp: 8;        /* un poco menos en móvil */
  }
}

/* Modal de ofertas: tamaño grande forzado */
html body .fancybox__content.oferta-fb{
  max-width: 980px !important;
  width: min(96vw, 980px) !important;
  max-height: 88vh !important;
  padding: 20px !important;
  overflow: hidden !important;
}

/* Layout interno (si ya lo tenías, puedes mantenerlo; lo dejo por si faltaba) */
html body .oferta-modal{
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 18px;
  min-height: 0;
}
html body .oferta-modal__media img{
  width: 100%;
  height: 100%;
  max-height: calc(88vh - 40px);
  object-fit: cover;
  border-radius: 12px;
}
html body .oferta-modal__media img[src*="logo-marketplace-huelva_negro.webp"]{
  object-fit: contain;
  background: #fff;
  padding: 14px;
}
html body .oferta-modal__body{
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 12px;
  min-height: 0;
  overflow: auto;
  padding-right: 6px;
}
html body .oferta-modal__title{
  margin: 0;
  font-size: 1.35rem;
  line-height: 1.25;
  color: #1f2937;
}
html body .oferta-modal__fechas{
  font-weight: 700;
  color: #2596be;
  font-size: 1rem;
}
html body .oferta-modal__desc{
  margin: 0;
  color: #4b5563;
  line-height: 1.55;
  display: -webkit-box;
  -webkit-line-clamp: 10;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
