/* =============================================================
   LoQ Google Reviews — Frontend Slider CSS
   ============================================================= */

/* ── Base widget ── */
.loq-gr-widget {
    width: auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    -webkit-font-smoothing: antialiased;
    box-sizing: border-box;
    /* Respeta los márgenes del sitio — mismo patrón que minicard_promo */
    margin: 0 16px var(--loq-space-5, 20px);
}

.loq-gr-widget *,
.loq-gr-widget *::before,
.loq-gr-widget *::after {
    box-sizing: inherit;
}

/* Desktop: centrado con max-width del tema */
@media (min-width: 1024px) {
    .loq-gr-widget {
        max-width: var(--loq-container, 1440px);
        margin-left: auto;
        margin-right: auto;
    }
}

/* Si el widget está dentro del bloque Shortcode del Category Builder,
   o en el wrapper de la PDP, el wrapper ya aplica los márgenes — evitar doble margin */
.loq-sc-block .loq-gr-widget,
.lqsp-google-reviews-pdp .loq-gr-widget {
    margin-left: 0;
    margin-right: 0;
}

/* ── Header ── */
.loq-gr-widget-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 12px;
    padding: 0 2px;
}

/* Modo título */
.loq-gr-header-titulo {
    margin-bottom: 14px;
}

.loq-gr-title-heading {
    font-size: 20px !important;
    font-weight: 600;
    color: var(--loq-text, #0f172a);
    line-height: 1.25;
    margin: 0;
    letter-spacing: -0.01em;
}

/* Botón centrado debajo del slider (modo título) */
.loq-gr-footer-link {
    display: flex;
    justify-content: center;
    margin-top: 16px;
}


.loq-gr-widget-brand {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.loq-gr-glyph {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

/* Texto compacto del header */
.loq-gr-header-compact {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 13px;
    color: #374151;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.loq-gr-header-star {
    color: #FBBC05;
    font-size: 14px;
    line-height: 1;
}

.loq-gr-header-compact strong {
    font-size: 13px;
    font-weight: 700;
    color: #0f172a;
}

.loq-gr-header-sep {
    color: #cbd5e1;
}

.loq-gr-header-count {
    font-size: 12px;
    color: #64748b;
}

/* Botón Ver en Google */
.loq-gr-widget-link {
    flex-shrink: 0;
    font-size: 12px;
    font-weight: 600;
    color: #4285F4;
    text-decoration: none;
    white-space: nowrap;
    border: 1px solid #c7d2fe;
    padding: 5px 10px;
    border-radius: 20px;
    transition: background 0.15s, color 0.15s;
}

.loq-gr-widget-link:hover {
    background: #4285F4;
    color: #fff !important;
    text-decoration: none;
    border-color: #4285F4;
}

/* Link en el Header (más sutil) */
.loq-gr-header-link {
    border: none !important;
    background: transparent !important;
    color: #64748b !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    padding: 0 !important;
    margin-left: auto;
}

.loq-gr-header-link:hover {
    color: #4285F4 !important;
    background: transparent !important;
    text-decoration: underline !important;
}

/* ── Slider container ── */
.loq-gr-slider-wrap {
    position: relative;
    display: flex;
    align-items: stretch;
    /* Cambiado de center para evitar saltos de altura */
    /* Fade suave en bordes izquierdo y derecho */
    -webkit-mask-image: linear-gradient(to right,
            transparent 0%,
            black 8%,
            black 92%,
            transparent 100%);
    mask-image: linear-gradient(to right,
            transparent 0%,
            black 8%,
            black 92%,
            transparent 100%);
}

/* Track outer: overflow:hidden amplificado con padding para que las sombras
   no se corten. El margin negativo compensa el espacio del padding.
   Técnica: padding = spread de la sombra → la zona de clip se expande. */
.loq-gr-track-outer {
    flex: 1;
    overflow: hidden;
    /* Simplificado: eliminamos los márgenes negativos excesivos que causaban inestabilidad vertical */
    padding: 12px 0;
    margin: 0;
}

.loq-gr-track {
    display: flex;
    transition: transform 0.42s cubic-bezier(0.4, 0, 0.2, 1);
    will-change: transform;
}

/* ── Slides ── */
.loq-gr-slide {
    flex: 0 0 100%;
    width: 100%;
    padding: 0 5px;
}

/* ── Nav buttons — ocultos (los dots + swipe son suficientes) ── */
.loq-gr-btn {
    display: none;
}

/* ── Dots ── */
.loq-gr-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 14px;
}

.loq-gr-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #cbd5e1;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: background 0.2s, transform 0.2s;
}

.loq-gr-dot.active {
    background: #6366f1;
    transform: scale(1.35);
}

/* =============================================================
   VARIANTE CARD (completa)
   ============================================================= */
.loq-gr-card .loq-gr-slide {
    padding: 0 5px;
}

.loq-gr-card-inner {
    background: #ffffff !important;
    border-radius: 18px;
    padding: 24px;
    min-height: 180px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    box-shadow: 0 4px 16px rgba(15, 23, 42, 0.06);
    border: 1px solid rgba(15, 23, 42, 0.05);
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.18s;
}

.loq-gr-card-inner:hover {
    box-shadow: var(--loq-shadow-card-hover, 4px 8px 24px rgba(0, 0, 0, 0.18));
    transform: translateY(-2px);
}

.loq-gr-card-top {
    display: flex;
    align-items: center;
    gap: 12px;
}

.loq-gr-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 2px solid #f1f5f9;
}

.loq-gr-card-author {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.loq-gr-card-author strong {
    font-size: 13px;
    font-weight: 700;
    color: #0f172a;
    line-height: 1.3;
}

.loq-gr-rel-date {
    font-size: 11px;
    color: #94a3b8;
}

.loq-gr-card-stars {
    display: flex;
    gap: 2px;
}

.loq-gr-card-stars .loq-gr-star-svg {
    width: 15px;
    height: 15px;
}

.loq-gr-card-text {
    flex: 1;
}

.loq-gr-card-text .loq-gr-text-short,
.loq-gr-card-text .loq-gr-text-full {
    font-size: 13px;
    color: #374151;
    line-height: 1.65;
    display: -webkit-box;
    -webkit-line-clamp: 5;
    line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.loq-gr-card-text .loq-gr-text-full {
    -webkit-line-clamp: unset;
    line-clamp: unset;
}

.loq-gr-expand {
    background: none;
    border: none;
    color: #6366f1;
    font-size: 11px;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
    margin-left: 4px;
    display: inline;
}

.loq-gr-card-link {
    font-size: 11px;
    color: #94a3b8;
    text-decoration: none;
    font-weight: 500;
    margin-top: auto;
}

.loq-gr-card-link:hover {
    color: #6366f1;
}

/* Desktop: 3 visible */
@media (min-width: 768px) {
    .loq-gr-card .loq-gr-slide {
        flex-basis: 33.333%;
        width: 33.333%;
    }
}

/* =============================================================
   VARIANTE MINICARD (compacta)
   ============================================================= */
.loq-gr-minicard .loq-gr-slide {
    padding: 0 4px;
}

.loq-gr-minicard-inner {
    background: #ffffff !important;
    border-radius: 18px;
    padding: 16px 20px;
    display: flex;
    align-items: flex-start;
    gap: 12px;
    box-shadow: 0 4px 16px rgba(15, 23, 42, 0.06);
    border: 1px solid rgba(15, 23, 42, 0.05);
    overflow: hidden;
    transition: box-shadow 0.2s, transform 0.18s;
    margin-bottom: 15px;
}

.loq-gr-minicard-inner:hover {
    box-shadow: var(--loq-shadow-card-hover, 4px 8px 24px rgba(0, 0, 0, 0.18));
    transform: translateY(-2px);
}

.loq-gr-mini-avatar {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
    border: 1.5px solid #f1f5f9;
}

.loq-gr-minicard-body {
    flex: 1;
    min-width: 0;
}

.loq-gr-minicard-top {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 4px;
}

.loq-gr-minicard-top strong {
    font-size: 11px;
    font-weight: 700;
    color: #0f172a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 80px;
}

.loq-gr-mini-date {
    font-size: 9px;
    color: #94a3b8;
    white-space: nowrap;
}

.loq-gr-mini-stars {
    display: flex;
    gap: 1.5px;
    flex-shrink: 0;
    margin-left: auto;
}

.loq-gr-mini-stars .loq-gr-star-svg {
    width: 10px;
    height: 10px;
}

.loq-gr-minicard-text {
    font-size: 11px;
    color: #64748b;
    line-height: 1.5;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.loq-gr-minicard-text.loq-gr-text-full {
    -webkit-line-clamp: unset;
    line-clamp: unset;
    display: block;
    /* Volvemos a block normal para que fluya todo el texto */
    overflow: visible;
}

/* Desktop: 5 visible */
@media (min-width: 768px) {
    .loq-gr-minicard .loq-gr-slide {
        flex-basis: 20%;
        width: 20%;
    }

    .loq-gr-minicard .loq-gr-btn {
        display: none;
    }
}

/* =============================================================
   LAYOUT: LIST (Grid estático)
   ============================================================= */
.loq-gr-layout-list .loq-gr-list-view {
    display: grid;
    grid-template-columns: 1fr;
    gap: 16px;
    padding: 4px;
}

@media (min-width: 640px) {
    .loq-gr-layout-list .loq-gr-list-view {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .loq-gr-layout-list .loq-gr-list-view {
        grid-template-columns: repeat(3, 1fr);
    }

    /* Si es minicard, podemos poner 4 o más */
    .loq-gr-style-minicard.loq-gr-layout-list .loq-gr-list-view {
        grid-template-columns: repeat(4, 1fr);
    }
}

.loq-gr-layout-list .loq-gr-list-item {
    width: 100%;
    opacity: 1;
    /* Por defecto visible para los que no están ocultos */
    transform: none;
    transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1),
        transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.loq-gr-layout-list .loq-gr-list-item.loq-gr-item-hidden {
    opacity: 0;
    transform: translateY(15px);
}

.loq-gr-layout-list .loq-gr-list-item.is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* ── Load More Button ── */
.loq-gr-load-more-wrap {
    text-align: center;
    margin-top: 100px;
    margin-bottom: 10px;
    width: 100%;
}

.loq-gr-load-more {
    background: #ffffff;
    border: 1.5px solid #e2e8f0;
    color: #0f172a;
    font-size: 13px;
    font-weight: 700;
    padding: 11px 32px;
    border-radius: 99px;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 4px 12px rgba(15, 23, 42, 0.04);
}

.loq-gr-load-more:hover {
    background: #f8fafc;
    border-color: #cbd5e1;
    transform: translateY(-2px);
    box-shadow: 0 8px 16px rgba(15, 23, 42, 0.08);
}

.loq-gr-load-more:active {
    transform: scale(0.96);
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.05);
}

/* Ajustes mínimos para que las cards no tengan margin-bottom extra en la lista */
.loq-gr-layout-list .loq-gr-minicard-inner,
.loq-gr-layout-list .loq-gr-card-inner {
    margin-bottom: 0;
}