/**
 * NicheCreator PRO - Frontend Styles
 * MERGED: Estilos originales del theme + estilos del plugin
 *
 * @package NicheCreator_Pro
 */

/* ═══════════════════════════════════════════════════════════════════════════
   General / Auxiliares
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-hidden {
	display: none !important;
}

.primary-sidebar .nc-map-card div,
.primary-sidebar .nc-map-modal div {
    margin-bottom: 0 !important;
}

:where(.wp-block-columns.is-layout-flex) {
    gap: 1.5em;
}

/* Ocultar párrafos vacíos dentro de fichas (WordPress/Gutenberg los genera) */
.nc-ficha-completa p:empty,
.wp-block-columns.nc-ficha-completa p:empty,
#nc-fichas-container p:empty {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Ocultar H2 "Sobre..." cuando el shortcode de descripción está vacío
   El marcador .ncpro-desc-empty se inyecta cuando no hay descripción */
h2.wp-block-heading:has(+ .ncpro-desc-empty),
h2.wp-block-heading:has(+ p:empty + .ncpro-desc-empty),
h2.wp-block-heading:has(+ div:empty + .ncpro-desc-empty) {
    display: none !important;
}

/* Forzar layout flex en fichas filtradas (que pierden clases de Gutenberg) */
.wp-block-columns.nc-ficha-completa {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 1.5em;
    align-items: flex-start !important;
}

/* Menú "Para empresas" */
#menu li.menu-item-para-empresas {
    order: -1;
}

@media (min-width: 1050px) {
    #menu li.menu-item-para-empresas > ul {
        width: 18rem !important;
        max-width: 18rem !important;
        min-width: 18rem !important;
    }
    #menu li.menu-item-para-empresas > ul > li {
        width: 100% !important;
    }
    #menu>ul>li.menu-item-para-empresas:first-child {
        margin-right: .5rem !important;
    }
    #menu>ul>li.menu-item-para-empresas:first-child > a .menu-svg {
        padding-left: 0 !important;
    }

    /* Botones auth: no heredar fondo/padding del theme, mantener tamaño compacto */
    #menu>ul>li.ncpro-menu-auth-wrapper {
        background: transparent !important;
        padding: 0 !important;
        margin: 0 0 0 0.75rem !important;
        display: inline-flex;
        align-items: center;
        gap: 0.5rem;
    }
    #menu>ul>li.ncpro-menu-auth-wrapper > a {
        padding: 6px 14px !important;
        background: transparent;
    }
    #menu>ul>li.ncpro-menu-auth-wrapper > a.ncpro-menu-btn-solid {
        background: #d91020 !important;
        border-color: #d91020 !important;
    }
    #menu>ul>li.ncpro-menu-auth-wrapper > a.ncpro-menu-btn-outline {
        border: 1px solid rgba(255,255,255,0.6) !important;
    }
}

.ncpro-auth-buttons {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
}

/* Botones de auth en header (Login/Register/Mi cuenta) */
.ncpro-menu-auth-buttons {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-left: auto;
}
.ncpro-menu-auth-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 16px;
    border-radius: 3px;
    background: rgba(255,255,255,.2) !important;
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    text-decoration: none;
    white-space: nowrap;
    transition: background 0.15s, color 0.15s;
    position: relative;
}
.ncpro-menu-auth-badge {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 9px;
    height: 9px;
    background: #ef4444;
    border: 2px solid #fff;
    border-radius: 50%;
    box-shadow: 0 0 0 2px rgba(0,0,0,0.08);
}
#menu>ul a {
font-size: 15px !important;
}
.ncpro-menu-auth-btn:hover {
    background: rgba(255,255,255,.3) !important;
}
.ncpro-menu-auth-btn:active {
    background: rgba(255,255,255,.5) !important;
}
@media (max-width: 768px) {
    .ncpro-menu-auth-buttons {
        flex-direction: column;
          margin-top: 2rem !important;
    }
 .ncpro-menu-auth-buttons a  {
    background: #fff !important;

    }

    .ncpro-claim-sidebar-card {
    	margin-bottom: 4rem !important;
    }
}

.ncpro-menu-btn {
    border-radius: 3px;
    border: 1px solid rgba(255,255,255,0.6);
    padding: 6px 14px;
    font-size: 13px;
    letter-spacing: 0.02em;
    text-transform: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.ncpro-menu-btn-outline {
    background: transparent;
    color: #fff;
}

.ncpro-menu-btn-solid {
    background: #d91020;
    color: #fff;
    border-color: #d91020;
}

.ncpro-menu-btn:hover {
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}

@media (max-width: 1049px) {
    .ncpro-auth-buttons {
        display: none;
    }

    .nc-cluster-parent .content-thin .tm-cta-negocio {
    	display: none;
    }
    
}

.wp-block-columns.nc-ficha-completa > .wp-block-column {
    flex-grow: 0;
    flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Enlazado Circular
   ═══════════════════════════════════════════════════════════════════════════ */

.enlazado-circ{
	margin-top:24px;
	margin: 0 auto;
	padding: 1rem 0 !important;
	max-width: calc(1140px - 2rem);
	padding-top: 52px !important;
	margin-top: 32px !important;
	border-top: 1px solid rgba(240, 240, 240, 1);
	border-color: rgba(240, 240, 240, 1);
}
.enlazado-circ .enlazado-circ-title{display:block;font-weight:600;margin-bottom:12px;font-size: 24px;margin-bottom: 2rem !important;}

/* Grilla: 5 por fila (responsive) */
.enlazado-circ .enlazado-circ-grid{
	display:grid;gap:20px;grid-template-columns:repeat(5,minmax(0,1fr))
}
@media (max-width:1200px){.enlazado-circ .enlazado-circ-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width:900px){ .enlazado-circ .enlazado-circ-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:640px){ .enlazado-circ .enlazado-circ-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}

/* Tarjeta */
.enlazado-circ .enlazado-circ-card{display:block;text-decoration:none;color:inherit;overflow:hidden;}
.enlazado-circ .enlazado-circ-card:hover .enlazado-circ-name { 
	text-decoration: underline;
}
/* Foto grande */
.enlazado-circ .enlazado-circ-photo{aspect-ratio:4/3;background:#f5f6f8;position:relative}
.enlazado-circ .enlazado-circ-photo img{width:100%;height:100%;object-fit:cover;display:block; border-radius: 4px !important}

/* Info */
.enlazado-circ .enlazado-circ-info{padding:10px 20px 10px 0px}
.enlazado-circ .enlazado-circ-name{font-weight:700;margin-bottom:6px;font-size:16px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ===== Rating EXACTO al que pasaste ===== */
.enlazado-circ .rating-div{display:inline-flex;align-items:flex-start;gap:4px; flex-direction: column;}
.enlazado-circ .rating-box{display:inline-flex;align-items:center;height:20px}

.enlazado-circ .rating-text {
	margin-left: 0 !important;
}

/* Cuadritos con estrella blanca embebida */
.enlazado-circ .rating-box .sq{
	width:18px;height:18px;border-radius:4px;display:inline-block;margin-right:4px;
	background-repeat:no-repeat, no-repeat;
	background-position:center, center;
	background-size:12px 12px, 100% 100% !important;
}

/* Texto a la derecha */
.enlazado-circ .rating-text .rating-n{font-weight:700;margin-right:6px}
.enlazado-circ .rating-text .rating-n2{color:#666;font-size:.92em}

/* ───────────── Carrusel en móviles ───────────── */
@media (max-width: 480px) {
	.enlazado-circ .enlazado-circ-title{font-size: 20px;margin-bottom: 1.5rem !important;}

	.enlazado-circ {
		margin-top: -2rem !important;
		margin-bottom: 2rem !important;
	}
	.enlazado-circ .enlazado-circ-grid {
		display: flex;
		overflow-x: auto;
		gap: 16px;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		padding: 0 8px;
	}
	.enlazado-circ .enlazado-circ-card {
		flex: 0 0 70%;
		scroll-snap-align: start;
	}

	/* Ocultar scrollbar */
	.enlazado-circ .enlazado-circ-grid::-webkit-scrollbar {
		display: none;
	}
	.enlazado-circ .enlazado-circ-grid {
		-ms-overflow-style: none;
		scrollbar-width: none;
	}
	
	.nc-ficha-completa .rating-div .rating-text{
		margin-left:0 !important;
		margin-top:.25rem !important;
	}
}

/* ═══════════════════════════════════════════════════════════════════════════
   Mapa - Cards y Modal
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-map-card div {
    margin-bottom: 0 !important;
}

.leaflet-pane {
	margin-bottom:0 !important;
}

/* Neutralizar márgenes heredados */
.nc-desktop-map-wrap,
.nc-desktop-map-wrap > div,
#nc-map-card-dk,
#nc-map-card,
.nc-map-modal,
.nc-map-modal > div,
.nc-map-modal .nc-map-modal-body,
.nc-map-modal .nc-map-actions,
.nc-rating-row,
.nc-card-body { margin-bottom:0 !important; }

/* Ocultar mapa embebido en móviles */
@media (max-width: 768px), (pointer:coarse) {
	.nc-desktop-map-wrap{ display:none !important; }
}

/* Guard táctil desktop */
.nc-map-guard{
	position:absolute;inset:0;z-index:600;cursor:pointer;
	background:rgba(255,255,255,.0);
	display:flex;align-items:center;justify-content:center;
	font:600 14px/1.2 'Open Sans', Arial, sans-serif;color:#444;
}
.nc-map-guard::after{
	content:'Toca para activar el mapa';
	background:#fff;padding:.5rem 1rem;border:1px solid #ccc;
	border-radius:6px;box-shadow:0 2px 6px rgba(0,0,0,.15);
}
@media (pointer:fine){.nc-map-guard{display:none!important;}}

/* Modal móvil */
.nc-map-modal[hidden]{display:none;}
.nc-map-modal{
	position:fixed; left:0; right:0; bottom:0;
	top: var(--nc-offset-top, 60px);
	height: calc(100dvh - var(--nc-offset-top, 60px));
	z-index: 9990; background:#fff; overflow:hidden;
	display:grid; grid-template-rows:auto 1fr auto;
}
.nc-map-modal-header{
	display:flex; align-items:center; gap:2rem;
	padding:.65rem 1rem; border-bottom:1px solid #eee;
}
.nc-modal-titles{display:flex; flex-direction:column; gap:.2rem; min-width:0; margin-bottom:0 !important;}
#nc-modal-h1{ margin:0; font:700 15px/1.2 system-ui,'Open Sans', Arial; color:#111; }
#nc-modal-sub{ margin:0; font:400 12px/1.35 system-ui,'Open Sans', Arial; color:#666; }
.nc-map-close{
	margin-left:auto; border:0; background:#f4f4f4; border-radius:6px;
	padding:.35rem .6rem; cursor:pointer; font-weight:700;
}
.nc-map-modal-body{position:relative; min-height:0;}
#nc-map-modal-map{ position:absolute !important; inset:0 !important; width:100% !important; height:100% !important; }

/* Mensaje de mapa vacío (sin resultados) */
.nc-map-empty-msg {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 1000;
	background: linear-gradient(135deg, #fffbeb 0%, #fef3c7 100%);
	border: 1px solid #fcd34d;
	border-radius: 12px;
	padding: 24px 32px;
	text-align: center;
	box-shadow: 0 4px 20px rgba(0,0,0,0.15);
	max-width: 280px;
}

.nc-map-empty-icon {
	font-size: 40px;
	margin-bottom: 8px;
}

.nc-map-empty-text {
	font-size: 15px;
	font-weight: 600;
	color: #92400e;
	margin-bottom: 6px;
}

.nc-map-empty-hint {
	font-size: 13px;
	color: #a16207;
}

/* "Buscar en esta zona" */
.nc-map-requery{
	position:absolute; left:50%; transform:translateX(-50%);
	top:20px; z-index:3500; border:0; border-radius:3px;
	padding:.55rem .9rem; font-weight:700; cursor:pointer;
	background:#111; color:#fff; box-shadow:0 6px 16px rgba(0,0,0,.2);
	box-shadow: 0 2px 10px 0 rgba(0, 0, 0, .12);
	background-color: #fff;
	font-size: 13px;
	font-weight: 700;
	color: #666;
	text-align: center;
}
.nc-map-requery[hidden]{display:none;}

/* Tarjetas */
.nc-map-card{
	background:#fff;border-radius:4px;
	box-shadow:0 8px 20px rgba(0,0,0,.18);
	z-index:1200;
	margin-bottom:0 !important;
}

/* Contenido clickeable (DESKTOP) */
.nc-card-link{
	display:flex; flex-direction:column; gap:.6rem;
	padding:.6rem; text-decoration:none; color:inherit; width:100%;
}

/* MÓVIL - Tarjeta del mapa */
#nc-map-card{
	position:absolute;
	bottom:1rem;
	left:1rem;
	right:1rem;
	margin-bottom:0 !important;
	padding:12px;
	gap:10px;
	display:none; /* Oculta por defecto, JS la muestra */
}
#nc-map-card[style*="display: flex"],
#nc-map-card[style*="display:flex"] {
	flex-direction:row !important;
	align-items:flex-start !important;
}
#nc-map-card img,
#nc-map-card .nc-card-img-mobile {
	width:84px !important;
	min-width:84px !important;
	max-width:84px !important;
	height:60px !important;
	object-fit:cover !important;
	border-radius:6px !important;
	border:1px solid #eee !important;
	flex-shrink:0 !important;
	margin:0 !important;
}
#nc-map-card .nc-card-body {
	min-width:0;
	display:flex;
	flex-direction:column;
	gap:.25rem;
	flex:1;
}
#nc-map-card .nc-card-title {
	font-weight:700;
	font-size:14px;
	line-height:1.15;
	margin:0;
}
#nc-map-card .nc-card-title a {
	color:#111;
	text-decoration:none;
}
#nc-map-card .nc-meta {
	color:#555;
	font-size:12px;
}

/* DESKTOP: FIXED */
#nc-map-card-dk{
	position:fixed; left:0; top:0; pointer-events:auto;
	width:240px; max-width:calc(100% - 24px);
	will-change: transform, left, top;
	margin-bottom:0 !important;
	z-index:2147483647;
}

#nc-card-stars,
.nc-meta {
	margin-bottom:0 !important;
	font-weight:normal !important;
}
#nc-card-stars {
	margin-top:.25rem !important;
	margin-bottom:.25rem !important;
}

/* BAJO‑IZQUIERDA (default) */
#nc-map-card-dk.orient-below{ transform: translate(calc(-100% + 12px), 12px); }
/* ARRIBA‑IZQUIERDA */
#nc-map-card-dk.orient-above{ transform: translate(calc(-100% + 14px), calc(-100% - 46px)); }

/* Cuando la card está DEBAJO del pin → flecha hacia ARRIBA */
#nc-map-card-dk.orient-below::after {
	content: "";
	position: absolute;
	top: -8px;
	right: -8px;
	transform: translateX(-50%);
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-bottom: 10px solid #fff;
	filter: drop-shadow(0 8px 20px rgba(0,0,0,.18));
}

/* Cuando la card está ARRIBA del pin → flecha hacia ABAJO */
#nc-map-card-dk.orient-above::after {
	content: "";
	position: absolute;
	bottom: -8px;
	right: -6px;
	transform: translateX(-50%);
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-top: 10px solid #fff;
	filter: drop-shadow(0 8px 20px rgba(0,0,0,.18));
}

/* Visual de la card desktop */
#nc-map-card-dk img{
	display:block;
	width:100%;
	height:120px;
	object-fit:cover;
	border-radius:3px;
	border:1px solid #eee;
	margin:0;
}

.nc-card-body{ display:flex; flex-direction:column; gap:.35rem; }
.nc-card-title{ font-weight:700; font-size:15px; line-height:1.2; margin:0; }

.nc-rating-row{ display:flex; align-items:center; gap:0rem; }

/* Móvil: toda la card es clickeable */
#nc-map-card{ cursor: pointer; }

.nc-card-link {
	text-decoration:none !important;
}

.nc-card-link:hover .nc-card-title {
	text-decoration:underline !important;
}
.nc-card-body .rating-text{ font-size:12px; color:rgba(107,109,111,1); }

/* Estrellas cuadradas */
.nc-map-card .rating-box{display:inline-flex;gap:4px;align-items:center;line-height:1;}

.nc-map-card .rating-box .sq{ width:18px;height:18px;background-size:12px,100% 100% !important }

@media (max-width:480px){
	.nc-map-card .rating-box .sq{ width:16px;height:16px;background-size:12px,100% 100% !important }
}

.nc-map-actions{ border-top:1px solid #eee; padding:.6rem .75rem; display:grid; grid-template-columns:1fr 1fr; gap:.6rem; }
.nc-map-btn{
	display:block; width:100%; text-align:center; border:0; border-radius:8px;
	padding:.7rem 1rem; cursor:pointer; font-weight:700;
	background:var(--ncpro-primary); color:#fff;
}
.nc-map-btn[disabled]{ background:#e5e7eb; color:#111; opacity:1; cursor:not-allowed; }

.nc-meta .nc-card-btn {
	-webkit-appearance: none;
	-moz-appearance: none;
	-ms-appearance: none;
	appearance: none;
	background-image: none;
	background-repeat: no-repeat;
	border: 0;
	cursor: pointer;
	margin: 0;
	align-items: center;
	border-radius: 3px;
	box-shadow: none;
	box-sizing: border-box;
	display: inline-flex;
	height: 34px;
	justify-content: center;
	padding-bottom: 6px;
	padding-left: 10px;
	padding-right: 10px;
	padding-top: 6px;
	position: relative;
	text-align: center;
	transition: all 0.8s;
	transition-property: background-image, background-color, background-position, background-size, border-color, box-shadow, opacity;
	user-select: none;
	vertical-align: middle;
	width: auto;
	background-color: rgba(0, 0, 0, 0);
	border: 1px solid rgba(200, 201, 202, 1);
	color: rgba(45, 46, 47, 1);
	font-size: 14px !important;
	font-weight: 600 !important;
	margin-top: .75rem !important;
}

.primary-sidebar .nc-meta div {
	margin-bottom: 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Contact Card
   ═══════════════════════════════════════════════════════════════════════════ */

.tm-contact-card{
	border:1px solid #e2e3e5;
	border-radius:6px;
	background:#fff;
	font-family:inherit;
	font-size:14px;
	line-height:1.35em;
	overflow:hidden;
	box-shadow:0 1px 2px rgba(0,0,0,.05);
	margin-top: 2.75rem !important;
}
.tm-contact-card .tm-row{
	display:flex;
	justify-content:space-between;
	align-items:center;
	padding:16px 1rem;
	border-top:1px solid #e2e3e5;
	text-decoration:none;
}
.tm-contact-card .tm-row:first-child {
	border-top:0;
}
.tm-contact-card .tm-row:last-child{border-bottom:none;}
.tm-contact-card .tm-row:hover{ text-decoration:underline;}
.tm-contact-card .tm-text{flex:1 1 auto;margin-right:12px; font-weight:600}

.tm-contact-card svg{
	stroke:#181818 !important;
}

.tm-dir {
	color:#767676 !important;
	display:inline-block;
	margin-top:.15rem;
	font-weight:600 !important;
}

.tm-text strong {
	font-weight:600;
}

.tm-row .tm-ico { flex: 0 0 20px; }

.tm-contact-card .tm-edit-btn {
	display:block;
	width:calc(100% - 2rem);
	border:1px solid #bababa;
	background:#fff;
	padding:10px;
	font-size:13px;
	cursor:pointer;
	text-align:center;
	color:#333 !important;
	font-size:15px;
	border-radius:3px;
	margin-top:2rem;
	font-weight:600;
	margin:1rem;
	display:none;
}
.tm-contact-card .tm-edit-btn:hover{background:#f0f2f4;}

/* Solo escritorio */
@media (max-width: 768px){ .tm-contact-card{ display:none } }

/* ═══════════════════════════════════════════════════════════════════════════
   Mobile Bar
   ═══════════════════════════════════════════════════════════════════════════ */

.tm-mobile-bar{
	display:flex;
	justify-content:space-around;
	padding:0 0 0 0;
	background:#fff;
	border-top:1px solid #eee;
	margin-bottom:-2rem;
	font-family:inherit;
	margin-top:1rem;
}

/* Sticky only on mobile (helps keep position in view) */
@media (max-width: 768px){
	.tm-mobile-bar--sticky{
		position: sticky;
		bottom: 0;
		z-index: 999;
		width: 100%;
		align-self: stretch;
		margin-top: 0;
		margin-bottom: 0;
	}
}
.tm-mobile-bar .tm-btn{
	flex:1 1 33.33%;
	text-align:center;
	text-decoration:none;
	color:#6b6b6b;
	font-size:12px;
	display:flex;
	flex-direction:column;
	align-items:center;
	gap:4px;
	line-height:1;
	padding:1rem 0
}
.tm-mobile-bar .tm-btn svg{
	width:24px;height:24px;
	stroke:#6b6b6b;
}
.the-content .tm-mobile-bar .tm-btn svg {
	stroke-width: 2 !important;
}
.tm-mobile-bar .tm-btn:active,
.tm-mobile-bar .tm-btn:hover{
	background:#f5f7fa;
}
.tm-mobile-bar .tm-btn {
	font-size:1	px !important;
	gap:5px !important;
}

/* Solo móvil */
@media (min-width: 769px){ .tm-mobile-bar { display:none } }

/* ═══════════════════════════════════════════════════════════════════════════
   Sticky Footer Mobile (tipo Yelp/Google Maps)
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-sticky-footer {
    display: none;
}

@media (max-width: 768px) {
    .nc-sticky-footer {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: #fff;
        border-top: 1px solid #e0e0e0;
        padding: 12px 12px;
        padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
        gap: 8px;
        z-index: 99999;
        transform: translateY(100%);
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        box-shadow: 0 -2px 10px rgba(0,0,0,0.1);
    }
    
    .nc-sticky-footer.visible {
        transform: translateY(0);
    }
    
    .nc-sticky-btn {
        flex: 1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 6px;
        padding: 10px 12px;
        border: 1px solid #d5d5d5;
        border-radius: 4px;
        background: #fff;
        color: #2d2e2f;
        text-decoration: none;
        font-size: 13px;
        font-weight: 600;
        transition: all 0.15s ease;
        white-space: nowrap;
    }
    
    .nc-sticky-btn:hover,
    .nc-sticky-btn:active {
        background: #f5f5f5;
        border-color: #bbb;
        text-decoration: none !important;
    }
    
    .nc-sticky-btn svg {
        flex-shrink: 0;
        stroke: #2d2e2f;
    }
    
    /* Botón primario (Llamar) - color dinámico */
    .nc-sticky-btn--primary {
        background: var(--ncpro-primary, #2d2e2f);
        border-color: var(--ncpro-primary, #2d2e2f);
        color: #fff;
    }
    
    .nc-sticky-btn--primary svg {
        stroke: #fff;
    }
    
    .nc-sticky-btn--primary:hover,
    .nc-sticky-btn--primary:active {
        background: var(--ncpro-primary-hover, #1a1a1a);
        border-color: var(--ncpro-primary-hover, #1a1a1a);
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Rating Stars
   ═══════════════════════════════════════════════════════════════════════════ */

.rating-div {
	display:flex;
}

.rating-box {
	position:relative;
	margin-right:.25rem;
	font-weight:bold !important;
}

/* estrellas rating */
.rating-box .sq{
    width:24px;height:24px;border-radius:4px;display:inline-block;
    background-size:16px;background-position:center;background-repeat:no-repeat;
}
.rating-box .sq.full,
.rating-box .full {
   background: var(--nc-star-color, #e61736) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M12 17.3 4.2 21l1.5-8.7L.3 8.7l8.8-1.3L12 0l2.9 7.4 8.8 1.3-6.4 6.3L19.8 21Z'/%3E%3C/svg%3E") no-repeat center/14px !important;
}
.rating-box .sq.half,
.rating-box .half {
   background: linear-gradient(to right, var(--nc-star-color, #e61736) 50%, #f1f1f1 50% 100%) !important;
   background-image:
      url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M12 17.3 4.2 21l1.5-8.7L.3 8.7l8.8-1.3L12 0l2.9 7.4 8.8 1.3-6.4 6.3L19.8 21Z'/%3E%3C/svg%3E"),
      linear-gradient(to right, var(--nc-star-color, #e61736) 50%, #f1f1f1 50% 100%) !important;
   background-repeat: no-repeat;
   background-position:center;
   background-size:14px,100% 100%;
}

/* estrella vacía */
.rating-box .empty{
    background:rgba(200, 201, 202, 0.58) !important;
    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23ffffff' d='M12 17.3 4.2 21l1.5-8.7L.3 8.7l8.8-1.3L12 0l2.9 7.4 8.8 1.3-6.4 6.3L19.8 21Z'/%3E%3C/svg%3E") !important;
    background-repeat:no-repeat !important;
    background-position:center !important;
    background-size:16px !important;
	color:#fff !important;
}

.rating-text{margin-left:6px;font:14px/22px 'Open Sans', Arial,sans-serif;color:#333;}
.rating-text small{font-size:12px;color:#666;}

.rating-n {
	font-weight:bold;
}

.rating-n2 {
	color:rgba(107, 109, 111, 1);
}

/* Icono de ayuda (?) para tooltip de ratings */
.nc-rating-help {
	position:relative;
	display:inline-flex;
	align-items:center;
	justify-content:center;
	width:16px;
	height:16px;
	margin-left:6px;
	cursor:help;
	vertical-align:middle;
}
.nc-rating-help-icon {
	display:flex;
	align-items:center;
	justify-content:center;
	width:16px;
	height:16px;
	border-radius:50%;
	background:rgba(240,240,240);
	color:#555;
	font-size:11px;
	font-weight:600;
	line-height:.9;
	transition:background 0.2s, color 0.2s;
}

.nc-rating-help-tooltip {
	position:absolute;
	bottom:calc(100% + 12px);
	left:0;
	transform:none;
	width:280px;
	max-width:90vw;
	padding:12px 14px;
	background:#2d2e2f;
	color:#fff;
	font-size:14px;
	font-weight:normal;
	line-height:1.5;
	border-radius:4px;
	opacity:0;
	visibility:hidden;
	transition:opacity 0.15s, visibility 0.15s;
	box-shadow:0 4px 12px rgba(0,0,0,0.25);
	pointer-events:none;
	z-index:9999;
	pointer-events:none;
	text-align:left;
}
/* Flecha del tooltip */
.nc-rating-help-tooltip::before {
	content:'';
	position:absolute;
	bottom:-6px;
	left:12px;
	width:12px;
	height:12px;
	background:#2d2e2f;
	transform:rotate(45deg);
}
/* Puente invisible para mantener hover */
.nc-rating-help-tooltip::after {
	content:'';
	position:absolute;
	bottom:-12px;
	left:0;
	width:100%;
	height:12px;
}
.nc-rating-help:hover .nc-rating-help-tooltip,
.nc-rating-help:focus .nc-rating-help-tooltip {
	opacity:1;
	visibility:visible;
	pointer-events:auto;
}
@media (max-width:600px) {
	.nc-rating-help-tooltip {
		width:250px;
		left:-10px;
		padding:10px 12px;
		font-size:13px;
	}
	.nc-rating-help-tooltip::before {
		left:16px;
	}
}

@media (max-width:768px) {
	.rating-div {
		flex-direction:column;
	}
	body.page-child:not(.page-parent) .rating-div {
		flex-direction:row !important;
	}
	body.page-child:not(.page-parent) .rating-text {
		margin-top:2px !important;
	}
}

body.page-child:not(.page-parent) .enlazado-circ .rating-div {
    display: inline-flex;
    align-items: flex-start;
    gap: 4px;
    flex-direction: column !important;
}

.page .nc-ficha-completa .rating-box .sq {
	height:20px;
	width:20px;
}

.page .nc-ficha-completa .rating-box .full,
.page .nc-ficha-completa .rating-box .empty,
.page .nc-ficha-completa .rating-box .half {
    background-size:13px,100% 100% !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   H2 Titles para shortcodes (descripción y valoraciones)
   ═══════════════════════════════════════════════════════════════════════════ */
.ncpro-desc-title,
.ncpro-rating-title {
    font-size: 1.25rem;
    font-weight: 600;
    color: #1f2937;
    margin: 0 0 0.75rem 0;
    line-height: 1.4;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Rating Block (Histograma)
   ═══════════════════════════════════════════════════════════════════════════ */
.rating-block{display:flex;gap:2rem;font-family:'Open Sans', system-ui,sans-serif;margin:1.5rem 0}
.rating-left{
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    align-items:flex-start;
    gap:.325rem;
	color:#767676;
	min-width:180px;
}
.rating-left strong{font-size:1.6rem;line-height:1}
.rating-left .sq {
	margin-right: 0rem;
}
.rating-right{flex:1;max-width:100%}
.rating-bar{display:flex;align-items:center;margin:0 0 14px 0;font-size:13px;color:#444}
.rating-bar .label{width:70px}
.rating-bar .track{flex:1;height:10px;background:#ececec;border-radius:8px;overflow:hidden}
.rating-bar .fill{display:block;height:100%;background:var(--col)}

.rating-title {
	font-weight:600 !important;
}


.rating-block .rating-box .sq
{
    width: 28px;
    height: 28px;
}



.rating-block .rating-box .sq.full,
.rating-block .rating-box .sq.half,
.rating-block .rating-box .sq.empty {
	    background-size: 16px, auto !important;

}
/* ═══════════════════════════════════════════════════════════════════════════
   Pill Buttons
   ═══════════════════════════════════════════════════════════════════════════ */

.niche-pill{
	display:inline-block;
	margin:0 14px 10px 0;
	padding:8px 16px;
	border:1px solid #c9c9c9;
	border-radius:999px;
	font-size:15px;
	line-height:1;
	color: rgba(45,46,47,1);
	text-decoration:none;
	transition:.15s;
	font-size:13px !important;
	font-weight:600 !important;
}

.niche-pill:hover{
	background:#eee;
	text-decoration:none;
}

.niche-pill:active{
	background:#ddd;
	text-decoration:none;
}

.niche-botones {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top:.5rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Ver más Toggle
   ═══════════════════════════════════════════════════════════════════════════ */

.vm-toggle {
	color: #1a73e8;
	cursor: pointer;
	text-decoration: none;
}

.vm-toggle:hover {
	text-decoration: underline;
}

.nc-ver-mas {
	line-height:1.4 !important;
	font-size:15px !important;
	font-weight:400 !important;
}
.nc-ver-mas span {
	font-size:14px !important;
	color:#666;
}

.nc-ver-mas strong {
	font-weight:400 !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Estado Abierto/Cerrado
   ═══════════════════════════════════════════════════════════════════════════ */

.estado-abierto {
	color: #1a936f;
	font-weight:600 !important;
}

.estado-cerrado {
    color: #d90429;
	font-weight:600 !important;
}

.nc-dir-estado,
.nc-horario{
	font-size:13px !important;
	margin-top:.5rem;
}
.nc-dir-estado {
    align-items:center;
    flex-wrap:wrap;
    gap:0 .35em;
	margin-top:.25rem !important;
    margin-bottom:.5rem;
}

.nc-dir-estado>span {
	align-items:center;
    gap:0 .15em;
	font-weight:600;
}

.nc-dir-estado svg {
	stroke:#000000;
	width:17px;
	position:absolute;
	height:17px;
	margin-top:2px;
}

.nc-dir-estado>span.span-dir {
	margin-left:1.25rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Badges
   ═══════════════════════════════════════════════════════════════════════════ */

.niche-badges{
	display:flex;
	flex-wrap:wrap;
	gap:.35rem;
	font-size:.85rem;
	margin-top:.25rem;
	margin-bottom:.75rem;
}

.niche-badges span {
    align-items: center;
    appearance: none;
    border: 0px;
    box-sizing: border-box;
    display: inline-flex;
    margin: 0px;
    outline: none;
    text-decoration: none;
    white-space: nowrap;
    --hover-bg-color: #e3e3e3;
    background-color: rgb(240, 240, 240);
    color: rgb(107, 109, 111);
    transition: background-color 0.2s;
    border-radius: 3px;
    gap: 4px;
    padding: 2px 4px;
    vertical-align: inherit;
    font-size: 12px;
    font-weight: 700;
    line-height: 16px;
    text-align: left;
	margin-right:.15rem;
	display:inline-block;
	text-transform: lowercase;
}
.niche-badges span::first-letter{
    text-transform: uppercase;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Paginador
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-pager{
	display:flex;
	align-items:center;
	justify-content:space-between;
	margin:40px 0;
}

.nc-pages a,
.nc-pages span{
	display:inline-block;
	padding:8px 14px;
	margin:0 4px;
	font:16px/1.1 'Open Sans', Arial,sans-serif;
	color:#555;
	text-decoration:none;
	border-radius:4px;
}

.nc-pages a:hover{background:#eee;}
.nc-pages a:active {background:#ddd;}

.nc-pages .current{
	background:var(--ncpro-primary);
	font-weight:bold;
	color:#fff;
}

/* flechas prev/next pequeñas */
.nc-pages a.prev,
.nc-pages a.next{
	font-size:18px;
	padding:8px 12px;
	color:#444;
}
.nc-pages a.prev:hover,
.nc-pages a.next:hover{background:#eee;}

.nc-pages a.prev:active,
.nc-pages a.next:active{background:#ddd;}

/* botón grande "Next Page" */
.nc-next-btn{
	display:inline-block;
	background:var(--ncpro-primary);
	color:#fff!important;
	font:16px/1.2 'Open Sans', Arial, sans-serif;
	padding:14px 65px;
	border-radius:4px;
	font-weight:600;
	text-decoration:none;
	transition:.2s;
}

/* fallback: si el filtro no añadió nc-next-btn */
.nc-next .next.page-numbers{
	display:inline-block;
	background:var(--ncpro-primary);
	color:#fff!important;
	font:16px/1.2 'Open Sans', Arial,sans-serif;
	padding:14px 65px;
	border-radius:4px;
	font-weight:600;
	text-decoration:none;
	transition:.2s;
}
.nc-next .next.page-numbers:hover,
#commentform input[type=submit]:hover{
	background:#283044;
	opacity:1 !important;
}
.nc-next .next.page-numbers:active,
#commentform input[type=submit]:active{
	background:#202636;

}

#commentform input[type=submit] {
	padding: 12px 30px !important;
	border-radius: 4px !important;
}
.nc-result-count {
    font-size: 14px;
    color: #767676;
    margin-bottom: 1.25rem;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Descripción Negocio
   ═══════════════════════════════════════════════════════════════════════════ */

p.desc-negocio {
	font-size:15px !important;
	margin-bottom: 1rem;
	line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Ficha Completa
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-ficha-completa {
	border-bottom:1px solid #ddd;
	padding:1rem 0;
	margin-bottom:1rem;
}

.nc-ficha-completa .wp-block-image img {
	border-radius:3px;
}

/* Thumbnail para fichas (imágenes externas de GMB) */
.nc-ficha-completa .wp-block-image img.nc-ficha-thumb,
.nc-ficha-completa .wp-block-image img:not([class*="wp-image-"]) {
	width: 100%;
	max-width: 250px;
	height: auto;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	border-radius: 8px;
}

@media screen and (max-width: 768px) {
  :where(.wp-block-columns.is-layout-flex) {
    gap: 1em;
  }

  .wp-block-columns.nc-ficha-completa.is-layout-flex {
    flex-wrap: nowrap !important;
    width: 100% !important;
  }

  .wp-block-columns.nc-ficha-completa.is-layout-flex > .wp-block-column:first-child {
    flex: 0 0 90px !important;
    max-width: 90px !important;
    min-width: 90px !important;
  }

  .wp-block-columns.nc-ficha-completa.is-layout-flex > .wp-block-column:first-child img {
    height: 90px;
    width: 90px;
    object-fit: cover;
  }

  .wp-block-columns.nc-ficha-completa.is-layout-flex > .wp-block-column:nth-child(2) {
    flex: 1 1 0 !important;
    min-width: 0 !important;
  }
}


.breadcrumb-trail {
	position: relative;
}
/* ═══════════════════════════════════════════════════════════════════════════
   Galería de Negocio (.nc-gallery) - Diseño moderno con lightbox
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-gallery {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
}

.nc-gallery img.nc-gallery-photo {
	
	    width: 100%;
    aspect-ratio: 1 / 1;
    height: auto;
    object-fit: cover;
    border-radius: 4px;
    cursor: pointer;
}

.nc-gallery img.nc-gallery-photo:hover {
	opacity: .87;
}


.nc-gallery a {
    line-height: 0 !important;
    margin-bottom: 0 !important;
}


@media (max-width: 1000px) {
    .nc-gallery {
        grid-template-columns: repeat(3, 1fr);
    }
}
@media (max-width: 767px) {
    .nc-gallery:not(.hero-gallery) {
        display: flex !important;
        gap: 8px !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scroll-snap-type: x mandatory !important;
        -webkit-overflow-scrolling: touch !important;
        padding-bottom: 8px !important;
    }
        .nc-gallery:not(.hero-gallery) img {
        flex: 0 0 auto !important;
        width: 40% !important;
        max-width: 280px !important;
        scroll-snap-align: start !important;
        overflow: hidden !important;
    }
}



/* Backward compatibility: .niche-gallery (usado en template premium) */
.niche-gallery {
	display: grid;
	gap: 10px;
	grid-template-columns: repeat(4, 1fr);
}

@media (max-width: 900px) {
	.niche-gallery {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 600px) {
	.niche-gallery {
		grid-template-columns: repeat(2, 1fr);
	}
}

.niche-gallery a {
	display: block;
	overflow: hidden;
	border-radius: 8px;
	line-height: 0 !important;
	margin-bottom: 0 !important;
}

.niche-gallery img {
	width: 100%;
	height: 140px;
	object-fit: cover;
	border-radius: 8px;
	transition: transform 0.2s ease;
}

.niche-gallery a:hover img {
	transform: scale(1.03);
}

@media (max-width: 600px) {
	.niche-gallery img {
		height: 100px;
	}
}

/* ===== Overlay ===== */
#ng-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:999999;display:none;font-family:"Segoe UI",Roboto,'Open Sans', Arial,sans-serif;color:#fff}
#ng-overlay.open{display:flex;align-items:center;justify-content:center}

/* Wrapper (margen 50 px) */
#ng-wrapper{width:calc(100vw - 100px);height:calc(100vh - 100px);max-width:1280px;display:flex;border-radius:6px;overflow:hidden;background:#000}
@media(max-width:800px){#ng-wrapper{flex-direction:column-reverse}}

/* ===== Visor ===== */
#ng-viewer{flex:3;position:relative;display:flex;align-items:center;justify-content:center;background:#000}
#ng-viewer img{max-height:80%;max-width:60%;object-fit:contain}

/* "Volver a fotos" */
#ng-back{
    all: unset;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 15px;
    position: absolute;
    top: 25px;
    left: 25px;
    z-index: 1002;
    background: rgba(0, 0, 0, .6);
    padding: 6px 10px;
    border-radius: 4px;
    background-color: rgba(255, 255, 255, 0.12);
    color: rgb(255, 255, 255);
	transition:all .2s;
}

#ng-back:hover {
    background-color: rgba(255, 255, 255, 0.22);
}

/* Áreas laterales completas */
.ng-side{position:absolute;top:0;bottom:0;width:120px;display:flex;align-items:center;justify-content:center;cursor:pointer}
#ng-prev-area{left:0}
#ng-next-area{right:0}
.ng-arrow{
	all:unset;
	width:40px;
	height:40px;
	border-radius:50%;
	background:rgba(255,255,255,.3);
	display:flex;
	align-items:center;
	justify-content:center;
	font-size:22px;
	line-height:8;
	color:#fff;
	transition:.2s;
	position:relative;
}
.ng-arrow span {
	margin-top:-4px;
}

.ng-side:hover .ng-arrow{background:rgba(255,255,255,.5)}
.ng-side:active .ng-arrow{background:rgba(255,255,255,.7)}

/* Panel info */
#ng-info{flex:0 0 360px;background:#fff;color:#000;padding:32px 40px 32px;overflow-y:auto}
#ng-pos{font-size:14px;color:#777;margin-bottom:6px}
#ng-title{font-size:18px;font-weight:600;margin-bottom:10px}
@media (max-width: 800px) {
    #ng-info {
        width: 100%;
        max-height: 90px;
        padding: 20px 20px 20px;
    }
}

/* Botón Cerrar flotante */
#ng-close{all:unset;cursor:pointer;position:absolute;top:15px;right:15px;font-size:20px;background:#000;padding:6px 10px;border-radius:4px;z-index:1002}
#ng-close:after{content:"✕"}
#ng-close::after {
    content: "\00d7" !important;
    font-size: 28px !important;
    color: #fff !important;
    line-height: 1 !important;
    display: inline-block !important;
}

@media (max-width: 800px) {
    #ng-wrapper {
        width: 100vw !important;
        height: 100vh !important;
        max-width: 100% !important;
        max-height: 100% !important;
        border-radius: 0 !important;
        flex-direction: column !important;
    }

    #ng-viewer {
        flex: 1 1 auto !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        position: relative !important;
        padding: 0 !important;
    }

    #ng-viewer img {
        max-width: 100% !important;
        max-height: 90vh !important;
        object-fit: contain !important;
    }

    /* Flechas más pequeñas y pegadas al borde */
    .ng-side {
        width: 50px !important;
    }
    .ng-arrow span {
        font-size: 2rem !important;
    }

    /* Info abajo de todo */
    #ng-info {
        width: 100% !important;
        background: rgba(0,0,0,0.7) !important;
        text-align: center !important;
        padding: 8px 0 !important;
        order: 2 !important;
    }

    #ng-pos, #ng-title {
        color: #fff !important;
        font-size: 14px !important;
        line-height: 1.4 !important;
    }

    /* Botón volver más integrado */
    #ng-back {
        position: absolute !important;
        top: 20px !important;
        left: 20px !important;
        z-index: 20 !important;
        padding: 6px 10px !important;
        font-size: 13px !important;
        background: rgba(255,255,255,.3)!important;
        color: #fff !important;
        border: none !important;
        border-radius: 4px !important;
    }

    /* Cerrar arriba a la derecha */
    #ng-close {
        top: 12px !important;
        right: 12px !important;
    }

	#ng-title {
		display:none !important;
	}
}

/* ═══════════════════════════════════════════════════════════════════════════
   Horarios
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-btn-horarios {
	align-items: center;
	appearance: none;
	border: 0px;
	box-sizing: border-box;
	display: inline-flex;
	margin: 0px;
	outline: none;
	text-decoration: none;
	white-space: nowrap;
	--hover-bg-color: #e3e3e3;
	background-color: rgb(240, 240, 240);
	color: #555;
	transition: background-color 0.2s;
	border-radius: 3px;
	gap: 4px;
	padding: 4px 6px;
	vertical-align: inherit;
	font-weight: 600;
	line-height: 16px;
	text-align: left;
	margin-left: 0rem;
	font-size: 14px;
}

.nc-estado {
	
margin-right: .4rem !important;}
.nc-btn-horarios:hover {
	text-decoration:none;
}

.nc-ficha-horarios {
	font-size:15px !important;
}

.nc-ficha-horarios tr {
	background:#fff !important;
}
.nc-ficha-horarios tr td:first-child {
	font-weight:600;
}

.nc-ficha-horarios.wp-block-table td {
	padding:0 !important;
	padding-bottom:.5rem !important;
}

@media screen and (max-width: 768px) {
	.nc-ficha-horarios tr td:first-child {
	    font-weight: 600;
	    padding-right: 2rem !important;
	}
}

/* ═══════════════════════════════════════════════════════════════════════════
   Amenities
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-amenities { margin:2rem 0; }
.nc-amen-title { font-size:1.25rem; margin-bottom:.75rem; }

.nc-amen-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:.5rem 1rem;
  list-style:none;
  margin:0;
  padding:0;
margin-bottom: 0 !important;
}

/* Desktop (≥ 640 px): 2 columnas */
@media (min-width:640px){
    .nc-amen-grid{
        grid-template-columns:repeat(2,1fr);
    }
}

.nc-amen-grid li{
  display:flex;
  align-items:center;
  font-size:.95rem;
  line-height:1.4;
  margin-bottom:8px !important;
}

.nc-flag,.nc-icon{
  width:18px;
  height:18px;
  margin-right:6px;
}

.nc-yes .nc-flag{ filter:hue-rotate(85deg) saturate(5); }
.nc-no  .nc-flag{ filter:hue-rotate(-45deg) saturate(4); }
.nc-no  { opacity:.55; }

.nc-amenities ul li {
	margin-left:0 !important;
	position:relative;
}

.nc-amen{
    display:flex;
    align-items:center;
    line-height:1.2;
}

.nc-amen svg{
    flex:0 0 auto;
    margin-right:.5rem;
}

.nc-amen-text{
    flex:1 1 auto;
    font-size:15px;
    white-space:normal;
}

.nc-amen-more{display:inline-flex;flex-direction:column;width:100% !important;margin-top:.5rem !important;}
.nc-amen-more > summary{order:2;cursor:pointer;margin-top:0 !important;font-weight:600;list-style:none;}
.nc-amen-more > summary::-webkit-details-marker{display:none}
.nc-amen-more .nc-amen-grid {
	margin-bottom:2rem !important;
}

.nc-amenities h3 {
	margin-bottom:1.25rem !important;
}

.nc-amen-grid svg {
	width:24px;
	height:24px;
}

.nc-amen-grid span {
	font-size:15px;
	padding-right:2rem;
}

.nc-amen-more span.more,
.nc-amen-more span.less {
    appearance: none;
    background-image: none;
    background-repeat: no-repeat;
    border: 0;
    cursor: pointer;
    margin: 0;
    align-items: center;
    border-radius: 4px;
    box-shadow: none;
    box-sizing: border-box;
    display: inline-flex;
    height: 44px;
    justify-content: center;
    padding: 10px 16px;
    position: relative;
    text-align: center;
    transition: all 0.8s;
    transition-property: background-image, background-color, background-position, background-size, border-color, box-shadow, opacity;
    user-select: none;
    vertical-align: middle;
    width: auto;
    background-color: rgba(0, 0, 0, 0);
    border: 1px solid rgba(200, 201, 202, 1);
    color: rgba(45, 46, 47, 1);
    font-size:14px !important;
}

.nc-amen-more span.more:hover,
.nc-amen-more span.less:hover {
    background-color: rgba(0, 0, 0, 0.05);
}
.nc-amen-more span.more:active,
.nc-amen-more span.less:active {
    background-color: rgba(0, 0, 0, 0.1);
}

/* Visibilidad: cerrado = .more visible, .less oculto */
.nc-amen-more > summary .less {
    display: none !important;
}
/* Visibilidad: abierto = .more oculto, .less visible */
.nc-amen-more[open] > summary .more {
    display: none !important;
}
.nc-amen-more[open] > summary .less {
    display: inline-flex !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Features / Tags
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-features { margin-top: 2rem; }
.nc-features-title { font-size: 1rem; margin: 1.25rem 0 .5rem; }
.nc-tags { display: flex; flex-wrap: wrap; gap: 6px; }

.nc-tag {
  background:#f2f2f2;
  border:1px solid #e0e0e0;
  border-radius:4px;
  padding:4px 10px;
  font-size:.85rem;
  line-height:1.4;
  white-space:nowrap;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Negocio Top
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-negocio-top {
	display:flex;
	flex-direction:column;
    align-items:flex-start;
	margin-top:.15rem;
    gap:.75rem;
}

.nc-negocio-top .nc-tipo {
    color: rgb(107, 109, 111);
    transition: background-color 0.2s;
    border-radius: 3px;
    gap: 4px;
    vertical-align: inherit;
    font-size: 15px;
    font-weight: 600;
    line-height: 16px;
    text-align: left;
    margin-right: .15rem;
    display: inline-block;
}

.nc-negocio-top div {
	font-size:16px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Popup / Leaflet
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-popup .leaflet-popup-content-wrapper{
	background:#ffffff;
	border-radius:12px;
	box-shadow:0 4px 14px rgba(0,0,0,.15);
	padding:8px 12px;
	display:flex;
    box-shadow: rgba(0, 0, 0, 0.16);
    background: rgb(255, 255, 255);
    border-radius: 4px;
    color: rgb(255, 255, 255);
    cursor: default;
    display: inline-block;
    padding: 18px 26px;
    position: relative;
    text-align: left;
    text-shadow: none;
    vertical-align: middle;
    white-space: normal;
}

.nc-popup .leaflet-popup-tip{
	background:var(--ncpro-primary);
	border:none;
}

.leaflet-container a.leaflet-popup-close-button {
	right:.25rem !important;
	top:.25rem !important;
}

.nc-popup-inner strong {
	font-family:'Poppins', sans-serif;
	font-size:16px !important;
}

.nc-popup .leaflet-popup-close-button{
	color:#444;
	top:6px;
	right:6px;
}

.nc-popup-inner,
.leaflet-popup-content {
	margin-bottom:0 !important;
}

.nc-popup .leaflet-popup-content-wrapper {
	margin-bottom:0 !important;
}

.nc-popup-inner strong{
	display:block;
	font-size:14px !important;
	color:#111;
	margin-bottom:2px;
}
.nc-popup-inner span{
	font-size:12px;
	color:#767676;
	display:none;
}
.leaflet-popup-content {
	margin: 0 !important;
}

.nc-popup .leaflet-popup-tip {
    background: #fff;
    border: none;
}

.leaflet-popup-content-wrapper, .leaflet-popup-tip {
    background: white;
    color: #333;
    box-shadow: 0 3px 14px rgba(0, 0, 0, 0.4);
}
.leaflet-popup-tip {
    width: 15px  !important;
    height: 15px !important;
    padding: 1px;
    margin: -10px auto 0;
    pointer-events: auto;
    transform: rotate(45deg);
}

/* ═══════════════════════════════════════════════════════════════════════════
   Alfabético / Municipios
   ═══════════════════════════════════════════════════════════════════════════ */

.tm-cta-sidebar .tm-cta-content {
 margin-bottom: 0 !important;
}


.tm-cta-sidebar  .tm-cta-negocio .more {
	width: 100% !important;
}
@media(max-width: 1050px)
{
	.tm-cta-sidebar  .tm-cta-negocio .more {
		display: none;
	}
}

.alpha-section{
  margin:2rem auto !important;
  max-width:1180px !important;
  padding:0 0px !important;
}


.alpha-h{
  margin:40px 0 16px !important;
  font-size:18px !important;
  font-weight:500 !important;
}

.muni-list{
    list-style:none;
    padding:0;
    margin:0 0 16px;
    columns:3 220px;
    column-gap:48px;
}

.muni-list li{
    display:inline-block;
    width:100%;
    padding-top:8px !important;
    margin:0  !important;
    break-inside:avoid-column;
}

.muni-list a{
  display:inline-block !important;
  font-size:17px !important;
  font-weight:500 !important;
  text-decoration:none !important;
}

.muni-list a:hover{
  text-decoration:underline !important;
}

.muni-count{
	margin-left:0px !important;
	color:#767676;
	font-size:14px;
}

@media(max-width:768px){
  .muni-list{ columns:2 160px !important; column-gap:32px !important; }
}
@media(max-width:480px){
  .alpha-h{ font-size:20px !important; margin:32px 0 12px !important; }
  .muni-list{ columns:1 !important; }
  .muni-list a{ font-size:16px !important; }
}

.tiles-grid {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
	gap: 0.75rem;
}

.tile {
	background: #f8f9fa;
	padding: 0.75rem 1rem;
	border-radius: 6px;
	text-align: center;
}

.tile a {
	color: #333;
	text-decoration: none;
	font-weight: 500;
}

.tile:hover {
	background: #e9ecef;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Comment Rating Stars (PLUGIN)
   ═══════════════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════════════
   Formulario de Reseñas - Layout completo (NC PRO)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Título del formulario */
.nc-review-form-title {
	font-size: 20px;
	font-weight: 700;
	color: #2d2e2f;
	margin: 0 0 20px 0;
}

.nc-review-form-title small {
	font-size: 14px;
	font-weight: 400;
	margin-left: 8px;
}

.nc-review-form-title small a {
	color: #6b6d6f;
	text-decoration: none;
}

.nc-review-form-title small a:hover {
	text-decoration: underline;
}

/* Layout flex del formulario */
#commentform {
	display: flex;
	flex-direction: column;
}


/* Orden: cookies después del textarea, fotos, luego submit */
#commentform .nc-form-field--cookies { order: 1; }
#commentform .nc-comment-photos-wrapper { order: 2; }
#commentform .form-submit { order: 3; margin-top: 20px; }

/* Ocultar notas innecesarias */
#commentform .comment-notes { display: none; }

/* Fix para ASAP theme - hacer transparente el wrapper */
#commentform .fields-wrap {
	display: contents;
}

/* Campos autor y email lado a lado usando CSS Grid */
#commentform {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 0;
}

/* Hacer que los campos autor y email ocupen una columna cada uno */
#commentform .nc-form-field--author {
	grid-column: 1;
	grid-row: auto;
}

#commentform .nc-form-field--email {
	grid-column: 2;
	grid-row: auto;
}

/* El resto de elementos ocupan el ancho completo */
#commentform .nc-comment-rating-wrapper,
#commentform .nc-comment-text-intro,
#commentform textarea,
#commentform .nc-form-field--cookies,
#commentform .nc-comment-photos-wrapper,
#commentform .form-submit,
#commentform .nc-logged-in-as,
#commentform .logged-in-as,
#commentform .comment-notes,
#commentform p:not(.form-submit) {
	grid-column: 1 / -1;
}

/* Estilos de los inputs */
#commentform .nc-form-field input[type="text"],
#commentform .nc-form-field input[type="email"] {
	width: 100% !important;
	max-width: none !important;
	padding: 12px 14px;
	border: 1px solid #d0d0d0;
	border-radius: 6px;
	font-size: 14px;
	transition: border-color 0.2s;
	box-sizing: border-box;
}

#commentform .nc-form-field input[type="text"]:focus,
#commentform .nc-form-field input[type="email"]:focus {
	outline: none;
	border-color: #2d2e2f;
}

@media (max-width: 600px) {
	#commentform {
		grid-template-columns: 1fr;
	}
	#commentform .nc-form-field--author,
	#commentform .nc-form-field--email {
		grid-column: 1;
	}
}

/* Cookies de ASAP */
#commentform .fields-wrap .comment-form-cookies-consent,
#commentform .comment-form-cookies-consent {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-size: 13px;
	color: #6b6d6f;
	margin-bottom: 16px;
}

/* Usuario logueado */
.nc-logged-in-as,
#commentform .logged-in-as {
	order: 0;
	margin-bottom: 16px;
	font-size: 13px;
	color: #6b6d6f;
}

.nc-logged-in-as a,
#commentform .logged-in-as a {
	color: #2d2e2f;
	text-decoration: none;
}

.nc-logged-in-as a:hover,
#commentform .logged-in-as a:hover {
	text-decoration: underline;
}

/* Campos del formulario */
.nc-form-field {
	margin-bottom: 16px;
}

.nc-form-field label {
	display: block;
	font-size: 14px;
	font-weight: 600;
	color: #2d2e2f;
	margin-bottom: 6px;
}

.nc-form-field label .required {
	color: #d32f2f;
}

.nc-form-field input[type="text"],
.nc-form-field input[type="email"] {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid #d0d0d0;
	border-radius: 6px;
	font-size: 14px;
	transition: border-color 0.2s;
	box-sizing: border-box;
}

.nc-form-field input[type="text"]:focus,
.nc-form-field input[type="email"]:focus {
	outline: none;
	border-color: #2d2e2f;
}

/* Checkbox de cookies - va después del textarea */
.nc-form-field--cookies {
	order: 1;
	margin-top: 16px;
}

.nc-form-field--cookies label {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	font-weight: 400;
	color: #6b6d6f;
	cursor: pointer;
	display: none;
}

.nc-form-field--cookies input[type="checkbox"] {
	margin-top: 2px;
	flex-shrink: 0;
}


/* Títulos de sección del formulario */
.nc-form-section-title {
	font-size: 16px;
	font-weight: 700;
	color: #2d2e2f;
	margin: 0 0 12px 0;
	line-height: 1.3;
	font-family: 'Poppins', sans-serif !important;
	display: block;
	width: 100%;
}
/* Texto de ayuda de sección */
.nc-form-section-hint {
	font-size: 14px;
	color: #6b6d6f;
	margin: 0 0 12px 0;
	line-height: 1.5;
}

/* Intro del textarea */
.nc-comment-text-intro {
	margin-bottom: 0;
}

.nc-comment-rating-wrapper {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0;
	margin-bottom: 24px;
}

/* Fila de estrellas + label en línea */
.nc-rating-row {
	display: flex;
	align-items: center;
	gap: 12px;
	flex-wrap: wrap;
}

#commentform input, #commentform textarea {
	margin-top: 0 !important;
}

.nc-rating-label {
	font-size: 14px;
	color: #6b6d6f;
	transition: color 0.2s;
}

.nc-comment-rating-wrapper label {
	font-weight: 600;
	color: #333;
	font-size: 15px;
}

/* Mensaje de "ya votaste" */
.nc-already-voted {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 16px 20px;
	background: #e8f4f0;
	border-radius: 3px;
	margin-bottom: 20px;
	padding-right: 36px !important;
	line-height: 1.5;
}

.nc-already-voted-icon {
	flex-shrink: 0;
	width: 40px;
	height: 40px;
	background: #1a936f;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}

.nc-already-voted-icon svg {
	width: 24px;
	height: 24px;
	stroke: #ffffff;
}

.nc-already-voted-content {
	flex: 1;
}


.nc-already-voted-content p {
	margin: 0 0 8px 0;
	font-size: 14px;
	color: #555;
}

.nc-already-voted-note {
	font-size: 12px !important;
	color: #777 !important;
	font-style: italic;
	margin-top: 8px !important;
}

/* Bloqueo completo del formulario de comentarios */
.nc-comment-blocked {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	padding: 40px 24px;
	background: linear-gradient(135deg, #e8f5e9 0%, #f1f8e9 100%);
	border: 2px solid #a5d6a7;
	border-radius: 16px;
	margin: 20px 0;
}

.nc-comment-blocked-icon {
	width: 80px;
	height: 80px;
	background: linear-gradient(135deg, #4caf50 0%, #66bb6a 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	margin-bottom: 20px;
	box-shadow: 0 4px 15px rgba(76, 175, 80, 0.4);
}

.nc-comment-blocked-icon svg {
	width: 40px;
	height: 40px;
}

.nc-comment-blocked-content h3 {
	margin: 0 0 12px 0;
	font-size: 22px;
	color: #2e7d32;
}

.nc-comment-blocked-content p {
	margin: 0 0 12px 0;
	font-size: 15px;
	color: #555;
	max-width: 400px;
}

.nc-comment-blocked-note {
	font-size: 13px !important;
	color: #777 !important;
	font-style: italic;
}

.nc-comment-blocked-btn {
	display: inline-block;
	margin-top: 16px;
	padding: 12px 24px;
	background: linear-gradient(135deg, #4caf50 0%, #66bb6a 100%);
	color: #fff !important;
	text-decoration: none !important;
	border-radius: 8px;
	font-weight: 600;
	transition: all 0.2s;
}

.nc-comment-blocked-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(76, 175, 80, 0.4);
}

.nc-rating-input {
	display: inline-flex;
	gap: 4px;
}

.nc-rating-input .star-input {
	width: 32px;
	height: 32px;
	border-radius: 4px;
	cursor: pointer;
	transition: transform 0.12s ease, background-color 0.12s ease;
	background-repeat: no-repeat;
	background-position: center;
	background-size: 22px 22px, 100% 100%;
	border: none;
	display: inline-block;
	/* Estado por defecto: estrella vacía visible */
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23ffffff' d='M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E"),
		linear-gradient(#e0e0e0, #e0e0e0);
		margin-right: 2px;
}

.nc-rating-input .star-input:hover,
.nc-rating-input .star-input.hovered,
.nc-rating-input .star-input.preview {
	transform: scale(1.1);
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23ffffff' d='M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E"),
		linear-gradient(var(--nc-star-color, #e61736), var(--nc-star-color, #e61736));
}

.nc-rating-input .star-input.selected {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23ffffff' d='M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E"),
		linear-gradient(var(--nc-star-color, #e61736), var(--nc-star-color, #e61736)) !important;
	transform: scale(1);
}

.nc-rating-input .star-input:focus {
	outline: 2px solid #7898eb;
	outline-offset: 2px;
}

.nc-rating-label {
	font-size: 14px;
	color: rgba(107,109,111,1);
	margin-left: 10px;
}

.nc-comment-rating-display {
	margin-bottom: 10px;
	margin-top: 1rem;
}

.nc-comment-rating-display .rating-box .sq {
margin-right: 3px;
}


/* ═══════════════════════════════════════════════════════════════════════════
   Photo Upload (Yelp Style) - PLUGIN
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-comment-photos-wrapper {
	margin-top: 0px;
}

.nc-comment-photos-wrapper > label {
	display: block;
	font-weight: 600;
	color: #333;
	font-size: 15px;
	margin-bottom: 12px;
}

.nc-photo-upload {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.nc-photo-dropzone {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 20px;
	border: 2px dashed rgba(200,201,202,1);
	border-radius: 8px;
	cursor: pointer;
	transition: border-color 0.2s, background 0.2s;
	text-align: center;
}

/* Dropzone grande estilo Yelp */
.nc-photo-dropzone--large {
	flex-direction: column;
	min-height: 140px;
	padding: 32px 24px;
	border-radius: 8px;
	background: #fff;
}

.nc-photo-dropzone--large .nc-photo-dropzone-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
}

.nc-photo-dropzone--large .nc-photo-dropzone-icon {
	width: 24px !important;
	height: 24px !important;
	min-width: 36px;
	max-width: 36px;
	color: #6b6d6f;
}

.nc-photo-dropzone--large .nc-photo-dropzone-text {
	font-size: 14px;
	color: #6b6d6f;
	text-align: center;
}


.nc-photo-dropzone-icon {
	width: 32px !important;
	height: 32px !important;
	min-width: 32px;
	max-width: 32px;
	color: #999;
	flex-shrink: 0;
}

.nc-photo-dropzone-text {
	font-size: 14px;
	color: #666;
}

.nc-photo-input {
	display: none;
}

.nc-photo-preview {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.nc-photo-preview-item {
	position: relative;
	width: 80px;
	height: 80px;
}

.nc-photo-preview-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 6px;
	border: 2px solid #eee;
}

.nc-photo-remove {
	position: absolute;
	top: -6px;
	right: -6px;
	width: 22px;
	height: 22px;
	background: #e61736;
	color: #fff;
	border: none;
	border-radius: 50%;
	font-size: 16px;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
}

.nc-photo-remove:hover {
	background: #c0132e;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Comment Votes (Yelp Style) - PLUGIN
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-comment-votes {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
	padding-top: 12px;
	border-top:none;
	margin-bottom: 2rem;
}

.rating-reviews-text {
	font-size: 15px !important;
}
.rating-reviews-text .rating-score {
	font-weight: 700;
	margin-right: 4px;
	color: #333;
}
.rating-reviews-text .rating-count {
	color: #666;
}
.nc-vote-btn {
  display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 6px 9px;
    border: 1px solid #f0f0f0;
    border-radius: 24px;
    background: #f0f0f0;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    color: rgba(45, 46, 47, 1);
    white-space: nowrap;
    transition: background-color 0.4s,border-color 0.4s,color 0.4s,clip-path 0.45s,transform 0.4s;
}
.nc-vote-icon {
	stroke:  rgba(45, 46, 47, 1);
}




.nc-vote-btn:hover {
      background: #d8d8d8;
    border-color: #d8d8d8;
    color: rgba(45, 46, 47, 1);
}


.nc-vote-btn:active {
      background: #c2c2c2;
    border-color: #c2c2c2;
    transform: scale(1.2) !important;
    color: rgba(45, 46, 47, 1);
}

.nc-vote-btn.voted {
border: 1px solid rgb(0, 118, 146);
    color: rgb(0, 118, 146);
    background: rgb(217, 246, 253);
}

.nc-vote-btn svg {
	width: 16px;
	height: 16px;
}

.nc-vote-count {
	font-weight: 600;
}

.nc-comment-photos {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 8px;
	margin: 16px 0;
	max-width: 400px;
}

.nc-comment-photos img.nc-comment-photo {
	width: 100%;
	height: 90px;
	object-fit: cover;
	border-radius: 6px;
	cursor: pointer;
	transition: transform 0.2s, box-shadow 0.2s;
}

.nc-comment-photos img.nc-comment-photo:hover {
	transform: scale(1.05);
	box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

@media (max-width: 480px) {
	.nc-comment-photos {
		grid-template-columns: repeat(3, 1fr);
		max-width: 100%;
	}
	
	.nc-comment-photos img.nc-comment-photo {
		height: 80px;
	}
}

/* Lightbox para fotos de reseñas */
.nc-lightbox {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.92);
	z-index: 99999;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s, visibility 0.3s;
}

.nc-lightbox.active {
	opacity: 1;
	visibility: visible;
}

.nc-lightbox-content {
	position: relative;
	max-width: 90vw;
	max-height: 90vh;
}

.nc-lightbox-content img {
	max-width: 90vw;
	max-height: 85vh;
	object-fit: contain;
	border-radius: 4px;
}

.nc-lightbox-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 44px;
	height: 44px;
	background: rgba(255,255,255,0.1);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s;
	z-index: 10;
}

.nc-lightbox-close:hover {
	background: rgba(255,255,255,0.2);
}

.nc-lightbox-close svg {
	width: 24px;
	height: 24px;
	stroke: #fff;
}

.nc-lightbox-nav {
	position: absolute;
	top: 0;
	bottom: 0;
	transform: none;
	width: 72px;
	background: rgba(255,255,255,0);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: background 0.2s;
}

.nc-lightbox-nav:hover {
	background: rgba(0,0,0,0.12);
}

.nc-lightbox-nav svg {
	width: 48px;
	height: 48px;
	stroke: #fff;
	background: rgba(0,0,0,0.4);
	border-radius: 999px;
	padding: 10px;
	stroke-width: 3 !important;
}

.nc-lightbox-prev {
	left: 1rem;
}

.nc-lightbox-next {
	right: 1rem;
}

.nc-lightbox-counter {
	position: absolute;
	bottom: 16px;
	left: 50%;
	transform: translateX(-50%);
	color: #fff;
	font-size: 14px;
	background: rgba(0,0,0,0.5);
	padding: 6px 12px;
	border-radius: 20px;
}

/* Lightbox Mobile: botones de navegación abajo */
@media (max-width: 600px) {
	.nc-lightbox-content {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		max-height: 70vh;
	}
	
	.nc-lightbox-content img {
		max-width: 100vw;
		max-height: 60vh;
	}
	
	/* Contenedor para botones de navegación en móvil */
	.nc-lightbox-nav {
		position: fixed;
		top: auto;
		bottom: 80px;
		transform: none;
		width: 56px;
		height: 56px;
		background: rgba(255,255,255,0.15);
		border: 1px solid rgba(255,255,255,0.2);
	}
	
	.nc-lightbox-prev {
		left: calc(50% - 70px);
	}
	
	.nc-lightbox-next {
		right: calc(50% - 70px);
	}
	
	.nc-lightbox-nav:active {
		background: rgba(255,255,255,0.3);
	}
	
	.nc-lightbox-counter {
		bottom: 30px;
	}
	
	.nc-lightbox-close {
		top: 12px;
		right: 12px;
	}
}

/* ═══════════════════════════════════════════════════════════════════════════
   Misc / Legacy
   ═══════════════════════════════════════════════════════════════════════════ */

.page .the-content h2 {
    margin-top: 0 !important;
    margin-bottom: .5rem !important;
	padding-top:0 !important;
}

.page-child h1, .page-parent h1 {
    margin-bottom: 0 !important;
}
.page-child h1 + .the-content, .page-parent h1 + .the-content {
    margin-top: .5rem !important;
}

.page-child .the-content h2 {
	margin-top:3rem !important;
	margin-bottom:1.25rem !important;
	padding-top: 32px !important;
	margin-top: 32px !important;
	border-top: 1px solid rgba(240, 240, 240, 1);
	border-color: rgba(240, 240, 240, 1);
}

.page-child h1 {
	margin-bottom:0 !important;
}

.page-child h1 + .the-content {
	margin-top:.5rem !important;
}

.page-child .rating-div {
	margin-bottom:.5rem;
}

.page-child .the-content h3 {
    margin-top: 1.75rem !important;
}

.page-child .the-content .nc-ficha-completa h2 {
	border-top:0 !important;
	padding-top:0 !important;
	margin-top:0 !important;
	margin-bottom: .5rem !important;
}

.page-child .the-content .nc-ficha-completa h2:before, .page-child .the-content .nc-ficha-completa h2 span:before {
    margin-top: -0px;
    height: 0px;
}
.page-child .the-content .nc-ficha-completa h2 span:before, .page-child .the-content .nc-ficha-completa h2:before, .page-child .the-content .nc-ficha-completa h3 span:before, .page-child .the-content .nc-ficha-completa h3:before {
    display: block;
    content: "";
    margin-top: 0px;
    height:0px;
    visibility: hidden;
}

.page:not(.page-child) .the-content h2::before {
    margin-top: 0;
    height: 0;
}

.page:not(.page-child) .the-content h2 span::before {
    display: none;
    margin-top: 0;
    height: 0;
    visibility: hidden;
}

.page .primary-sidebar {
	margin-top:-1.8rem !important;
    padding-top: 0 !important;
}

.the-content h2 a {
	color:#181818;
}

.wp-block-table.is-style-stripes {
	border:none;
}

.nc-letter-toggle {
	background:var(--ncpro-primary) !important;
}
.nc-letter-toggle.is-active {
	background:#8c76a6 !important;
    color: #fff !important
}

.nc-letter-list {
	background:#f6f6f7 !important;
}

ul.nc-amen-grid:last-child {
    margin-bottom: 1.5rem !important;
}

@media (min-width: 1050px) {
    .sticky {
        top: 80px;
    }
    .page-parent .sticky {
        top: 62px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   GLOBAL - Estrellas con color dinámico desde admin
   Estas reglas tienen alta especificidad para sobreescribir cualquier otra
   ═══════════════════════════════════════════════════════════════════════════ */
.rating-box .sq.full,
.rating-div .sq.full,
.rating-block .sq.full,
.enlazado-circ .sq.full,
.nc-ficha-completa .sq.full,
span.sq.full {
    background: var(--nc-star-color, #e61736) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M12 17.3 4.2 21l1.5-8.7L.3 8.7l8.8-1.3L12 0l2.9 7.4 8.8 1.3-6.4 6.3L19.8 21Z'/%3E%3C/svg%3E") no-repeat center !important;
    background-size: 14px, auto !important;
}

.rating-box .sq.half,
.rating-div .sq.half,
.rating-block .sq.half,
.enlazado-circ .sq.half,
.nc-ficha-completa .sq.half,
span.sq.half {
    background: linear-gradient(to right, var(--nc-star-color, #e61736) 50%, #e0e0e0 50%) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='white' d='M12 17.3 4.2 21l1.5-8.7L.3 8.7l8.8-1.3L12 0l2.9 7.4 8.8 1.3-6.4 6.3L19.8 21Z'/%3E%3C/svg%3E"),
        linear-gradient(to right, var(--nc-star-color, #e61736) 50%, #e0e0e0 50%) !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: 14px, 100% 100% !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Marcador de ubicación del usuario en el mapa
   ═══════════════════════════════════════════════════════════════════════════ */
.nc-user-location-marker {
    background: transparent !important;
    border: none !important;
}

.nc-user-dot {
    width: 16px;
    height: 16px;
    background: #4285f4;
    border: 3px solid #fff;
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(0,0,0,0.3);
    animation: nc-user-pulse 2s infinite;
}

@keyframes nc-user-pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(66, 133, 244, 0.4);
    }
    70% {
        box-shadow: 0 0 0 15px rgba(66, 133, 244, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(66, 133, 244, 0);
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   Filtros Dinámicos - Barra tipo Yelp
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-filter-bar {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 16px 0;
    padding: 0px 0 16px 0;
}

.nc-filter-row {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}
.breadcrumb{
	position: relative;
}
.nc-filter-buttons {
    display: flex;
    flex-wrap: nowrap;
    gap: 10px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    /* Ocultar scrollbar pero mantener funcionalidad */
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE/Edge */
    position: relative;
}

.nc-filter-buttons::-webkit-scrollbar {
    display: none; /* Chrome/Safari/Opera */
}

.nc-filter-actions {
    display: flex;
    align-items: center;
}

.nc-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    border: 1px solid #f0f0f0;
    border-radius: 24px;
    background: #f0f0f0;
    cursor: pointer;
    font-size: 12px;
    font-weight: 600;
    color: rgba(45, 46, 47, 1);
    white-space: nowrap;
    transition: background-color 0.4s,border-color 0.4s,color 0.4s,clip-path 0.45s,transform 0.4s;
    line-height: 16px;
}

.nc-filter-btn:hover {
      background: #d8d8d8;
    border-color: #d8d8d8;
    color: rgba(45, 46, 47, 1);
}

.nc-filter-btn.active,
.nc-filter-btn[aria-pressed="true"] {
      border: 1px solid rgb(0, 118, 146);
      color: rgb(0, 118, 146);
    background: rgb(217, 246, 253);
}

.nc-filter-btn.active:hover,
.nc-filter-btn[aria-pressed="true"]:hover {
     background: rgb(182, 237, 247);

}

.nc-filter-icon {
    display: flex;
    align-items: center;
    justify-content: center;
}

.nc-filter-icon svg {
    width: 18px;
    height: 18px;
}

.nc-filter-label {
    font-weight: 600;
}

.nc-filter-count {
    background: rgba(0,0,0,0.08);
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 12px;
    font-weight: 600;
}

.nc-filter-btn.active .nc-filter-count,
.nc-filter-btn[aria-pressed="true"] .nc-filter-count {
    background: rgba(255,255,255,0.25);
}

/* Filtros deshabilitados (modo server - páginas con muchas fichas) */
.nc-filter-btn.nc-filter-disabled {
    opacity: 0.5;
    cursor: not-allowed;
    background: #f5f5f5;
    border-color: #e0e0e0;
    color: #999;
}

.nc-filter-btn.nc-filter-disabled:hover {
    background: #f5f5f5;
    border-color: #e0e0e0;
    color: #999;
}

.nc-filter-clear {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    border: 1px dashed #d0d0d0;
    border-radius: 24px;
    background: #fff;
    cursor: pointer;
    font-size: 12px;
    color: #888;
    font-weight: 600;
    transition: all .2s ease;
}

.nc-filter-clear:hover {
    border-color: #bbbbbb;
    color: #666;
    background: #fafafa;
}

/* Dropdown de ordenamiento estilo Yelp */
.nc-sort-dropdown {
    position: relative;
    margin-left: auto;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.nc-sort-label {
    font-size: 14px;
    color: #181818;
    font-weight: 400;
}

.nc-sort-trigger {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0;
    background: transparent;
    border: none !important;
    font-size: 14px;
    font-weight: 700;
    color: #181818;
    cursor: pointer;
    border-radius: 4px;
    transition: all 0.15s ease;
}

.nc-sort-trigger:hover {
   text-decoration: underline;
}

.nc-sort-dropdown.open .nc-sort-trigger {
    border-color: #666;
    background: #fff;
}

.nc-sort-arrow {
    transition: transform 0.2s ease;
    color: #181818;
    height: 14px;
    width: 14px;

margin-top: 1px;
     }

.nc-sort-dropdown.open .nc-sort-arrow {
    transform: rotate(180deg);
}

.nc-sort-menu {
    position: absolute;
    top: calc(100% + 4px);
    right: 0;
    min-width: 200px;
    background: #fff;
    border-radius: 4px;
    box-shadow: 0 4px 16px rgba(0,0,0,0.15), 0 0 0 0px rgba(0,0,0,0.05);
    padding: .75rem !important;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: all 0.2s ease;
    z-index: 1000;
}

.nc-sort-dropdown.open .nc-sort-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.nc-sort-option {
    display: block;
    width: 100%;
    padding: 10px 16px;
    text-align: left;
    background: transparent;
    border: none;
    font-size: 14px;
    color: #181818;
    cursor: pointer;
    transition: background 0.1s ease;
    border-radius: 3px;
}

.nc-sort-option:hover {
    background: #f5f5f5;
}

.nc-sort-option.active {
    background: #e8f4fc;
    color: #0073bb;
    font-weight: 600;
}

/* Ocultar "Cerca mío" en desktop - solo visible en mobile */
@media (min-width: 769px) {
    .nc-filter-btn[data-filter="nearby"] {
        display: none;
    }


    #commentform, .asap-box-design #comentarios, .content-home-text {
    	margin-bottom: 0 !important;
    }
}




@media (max-width: 768px) {

	    .nc-review-trigger {
    	margin: 1.5rem !important;
    }

    .nc-sort-dropdown {
        margin-left: 0;
        margin-top: 4px;
    }
    
    .nc-filter-bar {
        gap: 10px;
    }

    .nc-filter-row {
        flex-direction: column;
        align-items: stretch;
        gap: 10px;
    }

    .nc-filter-buttons {
        width: 100%;
        gap: 8px;
        padding-bottom: 4px;
    }
    
    .nc-filter-btn {
        flex-shrink: 0; /* Evita que se compriman */
    }

    .nc-sort-dropdown {
        width: 100%;
    }
    
    .nc-sort-menu {
        right: auto;
        left: 0;
    }
    
    .nc-filter-actions {
        width: 100%;
    }
}

/* Loading state */
.nc-loading {
    pointer-events: none;
    position: relative;
}

.nc-loading::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 40px;
    height: 40px;
    margin: -20px 0 0 -20px;
    border: 3px solid #e0e0e0;
    border-top-color: #7898eb;
    border-radius: 50%;
    animation: nc-spin 0.8s linear infinite;
}

@keyframes nc-spin {
    to { transform: rotate(360deg); }
}

/* Sin resultados */
.nc-no-results {
    text-align: center;
    padding: 48px 24px;
    background: #f8f9fa;
    border-radius: 8px;
    margin: 24px 0;
}

.nc-no-results p {
    margin: 8px 0;
    color: #666;
}

.nc-no-results a {
    color: #7898eb;
    text-decoration: none;
    font-weight: 500;
}

.nc-no-results a:hover {
    text-decoration: underline;
}

/* Sin resultados - Estilo Warning (amarillo) */
.nc-no-results--warning {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    text-align: left;
    padding: 24px;
    background: linear-gradient(135deg, #fef3c7 0%, #fef3c7 100%);
    border-radius: 4px;
    margin: 24px 0;
}

.nc-no-results--warning .nc-no-results-icon {
    font-size: 32px;
    line-height: 1;
    flex-shrink: 0;
}

.nc-no-results--warning .nc-no-results-content {
    flex: 1;
}

.nc-no-results--warning .nc-no-results-content strong {
    display: block;
    font-size: 16px;
    color: #92400e;
    margin-bottom: 6px;
}

.nc-no-results--warning .nc-no-results-content p {
    margin: 0 0 12px 0;
    color: #a16207;
    font-size: 14px;
    line-height: 1.5;
}

.nc-no-results--warning .nc-filter-clear-inline {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    background: #f59e0b;
    color: #fff;
    border: none;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.2s;
}

.nc-no-results--warning .nc-filter-clear-inline:hover {
    background: #d97706;
}

@media (max-width: 480px) {
    .nc-no-results--warning {
        flex-direction: column;
        text-align: center;
        gap: 12px;
    }
    
    .nc-no-results--warning .nc-no-results-icon {
        font-size: 40px;
    }
}

/* Contenedor de fichas para AJAX */
#nc-fichas-container {
    transition: opacity .2s ease;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Filtro "Cerca de mí" - Estilos especiales
   ═══════════════════════════════════════════════════════════════════════════ */

.nc-filter-btn--nearby {
    background: linear-gradient(135deg, #4285f4 0%, #34a853 100%);
    border-color: #4285f4;
    color: #fff;
}

.nc-filter-btn--nearby:hover {
    background: linear-gradient(135deg, #3b78e7 0%, #2d9649 100%);
    border-color: #3b78e7;
    color: #fff;
}

.nc-filter-btn--nearby.active,
.nc-filter-btn--nearby[aria-pressed="true"] {
    background: #34a853;
    border-color: #34a853;
    box-shadow: 0 2px 8px rgba(52,168,83,0.4);
}

.nc-filter-btn--nearby.loading {
    opacity: 0.7;
    pointer-events: none;
}

.nc-filter-btn--nearby.loading .nc-filter-icon {
    animation: nc-spin 1s linear infinite;
}

.nc-filter-distance {
    font-size: 12px;
    opacity: 0.9;
    margin-left: 4px;
}

/* Indicador de distancia en fichas */
.nc-distance-info {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 6px;
    padding: 4px 10px;
    background: linear-gradient(135deg, #ff6b6b 0%, #ee5a5a 100%);
    color: #fff;
    font-size: 12px;
    font-weight: 600;
    border-radius: 12px;
    animation: nc-distance-pulse 2s ease-in-out infinite;
}

.nc-distance-info svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

@keyframes nc-distance-pulse {
    0%, 100% { opacity: 1; }
    50% { opacity: 0.85; }
}

/* Toast de geolocalización */
.nc-geo-toast {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.15);
    padding: 16px 20px;
    display: flex;
    align-items: center;
    gap: 12px;
    max-width: 400px;
    z-index: 99999;
    opacity: 0;
    transition: all .3s ease;
}

.nc-geo-toast.visible {
    transform: translateX(-50%) translateY(0);
    opacity: 1;
}

.nc-geo-toast--error {
    border-left: 4px solid #ea4335;
}

.nc-geo-toast-icon {
    font-size: 24px;
    flex-shrink: 0;
}

.nc-geo-toast-msg {
    flex: 1;
    font-size: 14px;
    color: #333;
    line-height: 1.4;
}

.nc-geo-toast-close {
    background: none;
    border: none;
    font-size: 20px;
    color: #999;
    cursor: pointer;
    padding: 0 4px;
}

.nc-geo-toast-close:hover {
    color: #333;
}

/* Modal de ayuda para permisos de geolocalización */
.nc-geo-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 999999;
    opacity: 0;
    transition: opacity .3s ease;
    padding: 20px;
}

.nc-geo-modal-overlay.visible {
    opacity: 1;
}

.nc-geo-modal {
    background: #fff;
    border-radius: 16px;
    max-width: 480px;
    width: 100%;
    box-shadow: 0 20px 60px rgba(0,0,0,0.3);
    transform: translateY(20px);
    transition: transform .3s ease;
    overflow: hidden;
}

.nc-geo-modal-overlay.visible .nc-geo-modal {
    transform: translateY(0);
}

.nc-geo-modal-header {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 20px 24px;
    background: #f0f0f0;
    color: #fff;
}

.nc-geo-modal-icon {
    font-size: 28px;
}

.nc-geo-modal-header h3 {
    flex: 1;
    margin: 0;
    font-size: 18px;
    font-weight: 600;
}

.nc-geo-modal-close {
    background: rgba(255,255,255,0.2);
    border: none;
    color: #333;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: 20px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .2s;
}

.nc-geo-modal-close:hover {
    background: rgba(255,255,255,0.3);
}

.nc-geo-modal-body {
    padding: 24px;
}

.nc-geo-modal-body p {
    margin: 0 0 16px 0;
    color: #333;
    line-height: 1.5;
}

.nc-geo-modal-body ol {
    margin: 0 0 16px 0;
    padding-left: 20px;
    color: #333;
}

.nc-geo-modal-body ol li {
    margin-bottom: 8px;
    line-height: 1.4;
}

.nc-geo-modal-tip {
    background: #f0f7ff;
    padding: 12px 16px;
    border-radius: 4px;
    font-size: 13px;
    color: #333;
}

.nc-geo-modal-footer {
    display: flex;
    gap: 12px;
    padding: 16px 24px;
    background: #f9f9f9;
    border-top: 1px solid #eee;
}

.nc-geo-modal-btn {
    flex: 1;
    padding: 12px 20px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all .2s;
}

.nc-geo-modal-btn--secondary {
    background: #e0e0e0;
    color: #333;
}

.nc-geo-modal-btn--secondary:hover {
    background: #d0d0d0;
}

.nc-geo-modal-btn--primary {
    background: #e0e0e0;
    color: #fff;
}

.nc-geo-modal-btn--primary:hover {
    background: #d0d0d0;
}

/* Responsive filtros */
@media (max-width: 600px) {
    .nc-filter-bar {
        gap: 12px 8px;
        padding: 0;
    }
    .nc-filter-btn {
        padding: 8px 12px;
        font-size: 13px;
    }
    .nc-filter-count {
        display: none;
    }
    .nc-filter-btn.active .nc-filter-label,
    .nc-filter-btn[aria-pressed="true"] .nc-filter-label {
        display: inline;
    }
    .nc-filter-clear {
        padding: 8px 12px;
        font-size: 13px;
    }
    .nc-geo-toast {
        max-width: calc(100% - 40px);
        bottom: 10px;
    }
    .nc-sort-menu {
    	        left: 27% !important;    	       
    	                margin-top: 6px !important;
    }
}


#commentform input, #commentform textarea {
	border: 1px solid rgba(200,201,202,1);
    box-shadow: none;
    padding: 12px !important;
}
#commentform input::placeholder,
#commentform textarea::placeholder {
	font-size: 15px;
	line-height: 1.5;
}


/* Wrappers específicos del shortcode de rating */
			.nc-rating-wrapper{
				display:flex;
				flex-direction:column;
				gap:4px;
				margin-bottom: 5px;
			}
			.nc-claim-status-row{
				width:100%;
				display:block;
			}

			/* Tooltip para rating */
			.nc-rating-tooltip{
				position:relative;
				cursor:help;
			}
			.nc-rating-tooltip::after{
				content:attr(title);
				position:absolute;
				bottom:calc(100% + 8px);
				left:50%;
				transform:translateX(-50%);
				background:#333;
				color:#fff;
				padding:10px 14px;
				border-radius:6px;
				font-size:12px;
				line-height:1.4;
				white-space:normal;
				width:280px;
				max-width:90vw;
				text-align:center;
				opacity:0;
				visibility:hidden;
				transition:opacity .2s, visibility .2s;
				z-index:1000;
				box-shadow:0 4px 12px rgba(0,0,0,0.15);
				pointer-events:none;
			}
			.nc-rating-tooltip::before{
				content:'';
				position:absolute;
				bottom:calc(100% + 2px);
				left:50%;
				transform:translateX(-50%);
				border:6px solid transparent;
				border-top-color:#333;
				opacity:0;
				visibility:hidden;
				transition:opacity .2s, visibility .2s;
				z-index:1001;
			}
			.nc-rating-tooltip:hover::after,
			.nc-rating-tooltip:hover::before{
				opacity:1;
				visibility:visible;
			}
			@media (max-width:600px){
				.nc-rating-tooltip::after{
					bottom:auto;
					top:calc(100% + 8px);
					width:220px;
				}
				.nc-rating-tooltip::before{
					bottom:auto;
					top:calc(100% + 2px);
					border-top-color:transparent;
					border-bottom-color:#333;
				}
			}

			.wp-block-table.is-style-stripes 
		{
			border-bottom: 0 !important;
		}


@media (max-width: 768px) {
	    .breadcrumb {
	        display: flex;
	        overflow-x: auto;
	        -webkit-overflow-scrolling: touch;
	        padding-right: 40px;
	    }

	      .content-thin > .breadcrumb-trail:after {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        width: 40px;
        height: 100%;
        pointer-events: none;
        background: linear-gradient(to right, transparent, #fff);
    }
        .breadcrumb li {
        flex: 0 0 auto;
        white-space: nowrap;
    }

}



.area-comentarios #commentform #author,
.area-comentarios #commentform #email {
	width: 98% !important;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Review Modal (Estilo Yelp)
   ═══════════════════════════════════════════════════════════════════════════ */

/* Trigger inline */
/* Trigger inline */
.nc-review-trigger {
	background: #fff;
	border-radius: 4px;
	padding: 24px 24px 26px 24px;
	text-align: center;
	margin-bottom: 24px;
	grid-column: 1 / -1;
	margin-top: 2rem;
	margin-bottom: 2rem !important;
	background: rgba(200, 201, 202, 0.2) !important;
}

.nc-review-trigger-title {
	font-size: 19px;
	color: #2d2e2f;
	margin: 0 0 16px 0;
	font-family: 'Poppins', 'Open Sans', Arial, sans-serif;
	font-weight: 600;
}

.nc-review-trigger-title strong {
	font-weight: 600;
}

.nc-review-trigger-stars.rating-box {
	display: inline-flex !important;
	gap: 6px;
	margin-bottom: 8px;
	justify-content: center;
}

.nc-review-trigger-stars .sq.nc-trigger-star {
	width: 32px !important;
	height: 32px !important;
	cursor: pointer;
	transition: transform 0.15s ease;
	background-size: 20px, 100% 100% !important;
}



.nc-review-trigger-stars .sq.nc-trigger-star:hover {
	transform: scale(1.15);
}

.nc-review-trigger-stars .sq.nc-trigger-star.empty  { 
	    background: rgba(0, 0, 0, .25) !important;
    background-image:
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23ffffff' d='M12 17.3 4.2 21l1.5-8.7L.3 8.7l8.8-1.3L12 0l2.9 7.4 8.8 1.3-6.4 6.3L19.8 21Z'/%3E%3C/svg%3E") !important;
    background-repeat:no-repeat !important;
    background-position:center !important;
        background-repeat: no-repeat !important;
    background-position: center !important;
    color: #fff !important;
        background-size: 20px, 100% 100% !important;
}


.nc-review-trigger-hint {
	font-size: 14px;
	color: #464646;
	margin: 0;
	transition: color 0.2s ease;
}

.nc-review-trigger-hint.nc-hint-active {
	color: #1a1a1a;
	font-weight: 600;
}

/* Modal */
.nc-review-modal {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 20px;
}

.nc-review-modal-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
	backdrop-filter: blur(4px);
}

.nc-review-modal-container {
	position: relative;
	background: #fff;
	border-radius: 6px;
	width: 100%;
	max-width: 560px;
	max-height: 90vh;
	overflow-y: auto;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	animation: nc-modal-in 0.12s ease-out;
}

@keyframes nc-modal-in {
	from {
		opacity: 0;
		transform: scale(0.95) translateY(10px);
	}
	to {
		opacity: 1;
		transform: scale(1) translateY(0);
	}
}

.nc-review-modal-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 20px 24px;
}

.nc-review-modal-header h2 {
	font-size: 18px;
	font-weight: 600;
	margin: 0;
	color: #2d2e2f;
}

.nc-modal-close {
	background: none;
	border: none;
	padding: 8px;
	cursor: pointer;
	color: #666;
	border-radius: 50%;
	transition: background 0.15s, color 0.15s;
}

.nc-modal-close:hover {
	background: #f0f0f0;
	color: #333;
}

.nc-review-modal-body {
	padding: 24px;
}

.nc-modal-section {
	margin-bottom: 24px;
}

.nc-modal-section:last-child {
	margin-bottom: 0;
}

.nc-modal-label {
	display: block;
	font-size: 16px;
	font-weight: 600;
	color: #2d2e2f;
	margin-bottom: 10px;
	font-family: 'Poppins', 'Open Sans', sans-serif, 'Arial';
}

.nc-modal-bajada {
	font-size: 14px;
	color: #767676;
	margin-bottom: 12px !important;
	margin-top: -6px !important;
}
p.desc-negocio strong {
    font-weight: 400;
}

.nc-modal-label span {
	color: #cc0000;
}

/* Rating en modal */
.nc-modal-rating {
	text-align: center;
	padding: 16px 0;
	background: #f1f1f1;
	margin: -24px -24px 24px -24px;
	padding: 24px;
}


.nc-modal-stars.rating-box {
	display: inline-flex !important;
	gap: 8px;
	margin-bottom: 8px;
	justify-content: center;
}

.nc-modal-stars .sq.nc-modal-star {
	width: 36px !important;
	height: 36px !important;
	cursor: pointer;
	transition: transform 0.15s ease;
	background-size: 22px, 100% 100% !important;
}

.nc-modal-stars .sq.nc-modal-star:hover {
	transform: scale(1.1);
}

.nc-modal-rating-label {
	display: block;
	font-size: 14px;
	color: #666;
	margin-top: 8px;
	min-height: 20px;
	font-weight: 500;
}

/* Textarea */
.nc-review-modal-body textarea, 
.nc-review-modal-body #nc-modal-author{
	width: 100%;
	padding: 14px 16px;
	border: 1px solid rgba(200,201,202,1);
	border-radius: 4px;
	font-size: 15px;
	font-family: inherit;
	resize: vertical;
	transition: border-color 0.15s, box-shadow 0.15s;
}

.nc-review-modal-body textarea {
		min-height: 120px;
}


.nc-review-modal-body textarea:focus, 
.nc-review-modal-body #nc-modal-author:focus {
	outline: none;
	border-color: rgba(240,240,240,1);
	box-shadow: inset 0 0 0 1px rgba(0, 118, 146, 1);
}

.nc-review-modal-body textarea::placeholder,
.nc-review-modal-body #nc-modal-author::placeholder  {
	color: #666 !important;
}

/* Dropzone de fotos */
.nc-modal-dropzone {
	display: block;
	border: 2px dashed  rgba(200,201,202,1);
	border-radius: 4px;
	padding: 32px 16px;
	text-align: center;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s;
	font-size: 15px;
}

.nc-modal-dropzone:hover {
	border-color: #b4b4b5;
}

.nc-modal-dropzone-inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	color: #666;
}

.nc-modal-dropzone-inner svg {
	color: #666;
}

.nc-modal-photos-input {
	display: none;
}

.nc-modal-photos-preview {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin-top: 12px;
}

.nc-modal-photo-thumb {
	position: relative;
	width: 64px;
	height: 64px;
	border-radius: 8px;
	overflow: hidden;
}

.nc-modal-photo-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.nc-remove-photo {
	position: absolute;
	top: 2px;
	right: 2px;
	width: 20px;
	height: 20px;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	border: none;
	border-radius: 50%;
	font-size: 14px;
	line-height: 1;
	cursor: pointer;
}

/* Campos usuario */
.nc-modal-user-fields {
	background: #f9f9f9;
	border-radius: 12px;
	padding: 20px;
}

.nc-modal-field-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 12px;
}

.nc-modal-field label {
	display: block;
	font-size: 13px;
	font-weight: 500;
	color: #555;
	margin-bottom: 6px;
}

.nc-modal-field input {
	width: 100%;
	padding: 10px 12px;
	border: 1px solid #ddd;
	border-radius: 8px;
	font-size: 14px;
	font-family: inherit;
}

.nc-modal-field input:focus {
	outline: none;
	border-color: #e61736;
}

.nc-modal-cookies {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 13px;
	color: #666;
	cursor: pointer;
}

.nc-modal-cookies input {
	width: 16px;
	height: 16px;
}

/* Submit */
.nc-modal-submit {
	text-align: center;
	padding-top: 8px;
}

.nc-modal-submit-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
    background: var(--ncpro-primary) !important;
    color: var(--ncpro-btn-text, #fff) !important;
	border: none;
	padding: 14px 48px;
	font-size: 16px;
	font-weight: 600;
	border-radius: 4px;
	cursor: pointer;
	transition: background 0.15s, transform 0.15s;
}

.nc-modal-submit-btn:hover:not(:disabled) {
	background: #c41430;
}

.nc-modal-submit-btn:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

.nc-btn-loading {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.nc-spinner {
	animation: nc-spin 1s linear infinite;
}

@keyframes nc-spin {
	from { transform: rotate(0deg); }
	to { transform: rotate(360deg); }
}

/* Éxito al enviar reseña */
.nc-modal-success {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 48px 24px;
	min-height: 300px;
}

.nc-modal-success-icon {
	width: 80px;
	height: 80px;
	background: #22c55e;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
	animation: nc-success-pop 0.4s ease-out;
}

.nc-modal-success-icon svg {
	stroke: #fff;
	width: 48px;
	height: 48px;
}

.nc-modal-success h3 {
	font-size: 22px;
	font-weight: 700;
	color: #1a1a1a;
	margin: 0 0 8px 0;
}

.nc-modal-success p {
	font-size: 15px;
	color: #666;
	margin: 0;
}

@keyframes nc-success-pop {
	0% { transform: scale(0); opacity: 0; }
	50% { transform: scale(1.1); }
	100% { transform: scale(1); opacity: 1; }
}

/* Mensajes */
.nc-modal-message {
	text-align: center;
	padding: 12px 16px;
	border-radius: 8px;
	margin-top: 16px;
	font-size: 14px;
}

.nc-modal-message--success {
	background: #d4edda;
	color: #155724;
}

.nc-modal-message--error {
	background: #f8d7da;
	color: #721c24;
}

/* Already voted */
.nc-already-voted {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	background: #e8f4f0;
	border-radius: 6px;
	padding: 24px;
	margin-bottom: 0;
}

.nc-already-voted-icon {
	flex-shrink: 0;
	width: 36px;
	height: 36px;
	background: #1a936f;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

.nc-already-voted-icon svg {
	stroke: #fff;
	width: 24px;
	height: 24px;
	fill: none;
	stroke-width: 2;
}

/* Offset para scroll considerando header sticky */
#respond,
.comment-respond {
	scroll-margin-top: 80px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Mensaje de moderación de comentarios
   ═══════════════════════════════════════════════════════════════════════════ */

/* Ocultar el mensaje feo de WordPress por defecto */
.comment-awaiting-moderation,
em.comment-awaiting-moderation {
	display: none !important;
}

/* Nuestro mensaje de moderación mejorado */
.nc-moderation-notice {
	display: flex !important;
	align-items: center;
	gap: 12px;
	background: linear-gradient(135deg, #fef3c7 0%, #fef9c3 100%);
	border: 1px solid #f59e0b;
	border-radius: 10px;
	padding: 14px 18px;
	margin: 0 0 16px 0;
	font-size: 14px;
	color: #92400e;
	line-height: 1.5;
	font-weight: 500;
}

.nc-moderation-notice::before {
	content: "⏳";
	font-size: 20px;
	flex-shrink: 0;
}

/* Estilo para el comentario completo cuando está pendiente */
.comment.unapproved,
li.comment:has(.nc-moderation-notice),
#comment-572:has(.nc-moderation-notice),
.comment-body:has(.nc-moderation-notice) {
	opacity: 0.85;
	border-left: 4px solid #f59e0b !important;
	padding-left: 16px;
	background: linear-gradient(to right, rgba(254, 243, 199, 0.3), transparent 60%) !important;
	border-radius: 0 8px 8px 0;
}

/* OCULTAR botones de reacción (Útil, Gracias, etc.) en comentarios pendientes */
.comment.unapproved .nc-comment-votes,
li.comment:has(.nc-moderation-notice) .nc-comment-votes,
.comment-body:has(.nc-moderation-notice) .nc-comment-votes,
.nc-moderation-notice ~ .nc-comment-votes,
.nc-moderation-notice + * .nc-comment-votes {
	display: none !important;
}

/* También ocultar por data-approved si está disponible */
.comment[data-approved="0"] .nc-comment-votes {
	display: none !important;
}

.comment-respond > p {
	border:  none !important;
}

.nc-already-voted-content strong {
	display: block;
	font-size: 16px;
	color: #166534;
	margin-bottom: 6px;
}

.nc-already-voted-content p {
	font-size: 16px;
	color: #15803d;
	margin: 0;
}

/* Ocupa todo el ancho cuando está dentro de un grid */
.nc-already-voted {
	grid-column: 1 / -1;
}

/* Ocultar los campos del formulario cuando ya votó (pero NO el mensaje) */
#commentform:has(.nc-already-voted) > *:not(.nc-already-voted),
#commentform:has(.nc-already-voted) textarea,
#commentform:has(.nc-already-voted) .comment-form-comment,
#commentform:has(.nc-already-voted) .form-submit,
#commentform:has(.nc-already-voted) .comment-form-author,
#commentform:has(.nc-already-voted) .comment-form-email,
#commentform:has(.nc-already-voted) input:not([type="hidden"]),
#commentform:has(.nc-already-voted) label,
#commentform:has(.nc-already-voted) p:not(:has(.nc-already-voted)):not(.nc-already-voted *) {
	display: none !important;
}

/* Asegurar que el mensaje sea visible */
#commentform .nc-already-voted {
	display: flex !important;
}

/* Responsive */
@media (max-width: 600px) {
	.nc-review-modal {
		padding: 0;
		align-items: flex-end;
	}

	.nc-review-modal-container {
		max-width: 100%;
		max-height: 95vh;
		border-radius: 6px 6px 0 0;
		animation: nc-modal-in-mobile 0.15s ease-out;
	}

	@keyframes nc-modal-in-mobile {
		from {
			transform: translateY(100%);
		}
		to {
			transform: translateY(0);
		}
	}

	.nc-modal-field-row {
		grid-template-columns: 1fr;
	}

	.nc-review-trigger-stars .sq.nc-trigger-star {
		width: 28px !important;
		height: 28px !important;
		background-size: 18px, 100% 100% !important;
	}

	.nc-modal-stars .sq.nc-modal-star {
		width: 32px !important;
		height: 32px !important;
		background-size: 20px, 100% 100% !important;
	}
}

.nc-modal-photos {
    margin-top: -2px;
}

.search-header svg, .search-home svg, .search-responsive svg {
	    stroke: #fff !important;
}

.page-es-ficha h1 {
	font-size:34px !important;
}

.search-header button.s-btn {
    color: #fff !important;
}
:where(.wp-block-columns.is-layout-flex) {
    gap: 1.5em;
}


@media (max-width: 768px) {
    body.page-child:not(.page-parent) .rating-text {
        margin-top: 2px !important;
    }
    .page-es-ficha h1 {
	font-size:26px !important;
}

}

body.page-child:not(.page-parent) .enlazado-circ .rating-div {
    display: inline-flex
;
    align-items: flex-start;
    gap: 4px;
    flex-direction: column !important;
}
@media(min-width:1050px) {
	.solo-movil {
		display:none !important;
	}
}

.hero-florerias .hero-bg{
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  pointer-events: none; 
	  width: 100%;
  inset:0;                /* top:0; right:0; bottom:0; left:0; */

}



footer li a {
    opacity:.76 !important;
}
@media(min-width:1050px) {
footer .content-footer li {
    margin-bottom: .975rem !important;
}
	}

@media (max-width: 1050px) {
	
	.go-top {
		margin-top:3rem !important;
	}
	.home footer {
		margin-top:5rem !important;
	}
	.content-footer {
		padding-top:2rem !important;
				padding-bottom:4rem !important;

}

	.footer-links{
		display:flex;
		flex-wrap:wrap;             
		gap:.1em;                 
		list-style:none;
		padding:0;
		margin:0;
	}

	.footer-links li{
		display:inline;
		margin:0;
	}


	.footer-links li:first-child{
		flex-basis:100%;           
		margin-bottom:.5em;
	}



.footer-links li:nth-child(n+2)::after{
	content:"|";
	margin:0 .4em;
	opacity:.5;
}
	.footer-links li:last-child::after{
		content:none;
	}
	
	.content-footer li {
    margin-bottom: .325rem !important;
}

}


.solo-movil  a {
	display:flex;
	align-items:center;
}
.solo-movil  a span {
	font-size:14px;
	margin-left:4px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Mobile Adjustments - Rating Block, Breadcrumb, Filter Bar
   ═══════════════════════════════════════════════════════════════════════════ */

/* Rating block en móviles: una sola columna */
@media (max-width: 768px) {
    .rating-block {
        flex-direction: column;
        gap: 1.5rem;
        margin-top: 1.5rem;
    }
    .rating-left {
        min-width: 100%;
    }
}

/* Breadcrumb: ocultar scrollbar pero mantener scroll */
.breadcrumb {
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE/Edge */
}
.breadcrumb::-webkit-scrollbar {
    display: none; /* Chrome, Safari, Opera */
}

/* Filter bar en móviles: estructura vertical limpia */
@media (max-width: 768px) {
    .nc-filter-bar {
        flex-direction: column;
    }
    
    .nc-filter-actions {
        margin-top: 4px;
    }
    
    .nc-filter-clear {
        width: 100%;
        justify-content: center;
    }
}

/* ═══════════════════════════════════════════════════════════════════════════
   FAQ Styles (movido desde inline)
   ═══════════════════════════════════════════════════════════════════════════ */

.ncpro-faq-category { margin-bottom: 24px; }
.ncpro-faq-category:last-child { margin-bottom: 0; }
.ncpro-faq-list { background: #fff; border: 1px solid #e5e7eb; border-radius: 6px; overflow: hidden; }
.ncpro-faq-item { border-bottom: 1px solid #f3f4f6; }
.ncpro-faq-item:last-child { border-bottom: 0; }
.ncpro-faq-item.is-hidden { display: none; }
.ncpro-faq-toggle {
    width: 100%; 
    padding: 16px 20px; 
    background: none; 
    border: none; 
    cursor: pointer;
    display: flex; 
    align-items: center; 
    justify-content: space-between; 
    gap: 16px;
    text-align: left; 
    font-size: 16px; 
    font-weight: 500; 
    color: #1f2937;
    transition: background .15s;
}
.ncpro-faq-toggle:hover { background: #f9fafb; }
.ncpro-faq-chevron { flex-shrink: 0; color: #9ca3af; transition: transform .2s; }
.ncpro-faq-item.is-open .ncpro-faq-chevron { transform: rotate(180deg); }
.ncpro-faq-answer { 
    max-height: 0; 
    overflow: hidden; 
    transition: max-height .3s ease-out;
}
.ncpro-faq-item.is-open .ncpro-faq-answer { max-height: 800px; }
.ncpro-faq-answer-inner { 
    padding: 0 20px 20px 20px; 
    font-size: 14px; 
    line-height: 1.7; 
    color: #4b5563;
}
.ncpro-faq-answer-inner strong { color: #111827; }
.ncpro-faq-answer-inner ol, 
.ncpro-faq-answer-inner ul { margin: 12px 0; padding-left: 20px; }
.ncpro-faq-answer-inner li { margin-bottom: 4px; }
.ncpro-faq-answer-inner a { color: #0ea5e9; text-decoration: none; }
.ncpro-faq-answer-inner a:hover { text-decoration: underline; }
.ncpro-faq-answer-inner p { 
    font-size: 14px; 
    line-height: 1.7; 
    color: #4b5563;
    margin: 8px 0; 
}
.ncpro-faq-answer-inner table { font-size: 13px; }
.ncpro-faq-category.is-hidden { display: none; }
#ncpro-faq-search:focus { border-color: #0ea5e9; box-shadow: 0 0 0 3px rgba(14,165,233,.1); }

/* CF7: Cuando se envía exitosamente, ocultar form y solo mostrar mensaje */
.wpcf7-form.sent > *:not(.wpcf7-response-output) {
    display: none !important;
}
.wpcf7-form.sent .wpcf7-response-output {
    display: block !important;
    background: #d1fae5 !important;
    border: 1px solid #10b981 !important;
    color: #065f46 !important;
    padding: 20px 24px !important;
    border-radius: 8px !important;
    margin: 0 !important;
    font-size: 15px;
    text-align: center;
}

/* ═══════════════════════════════════════════════════════════════════════════
   Claim Status Badge (movido desde inline)
   ═══════════════════════════════════════════════════════════════════════════ */

.ncpro-claim-wrapper {
    display: inline-flex;
    align-items: center;
     flex-wrap: wrap;
}
.ncpro-claim-status {
    position: relative;
    display: flex;
}

.ncpro-claim-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-family: 'Open Sans', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
    letter-spacing: 0;
    cursor: pointer;
    transition: opacity 0.2s ease;
    background: transparent;
    border: none;
    padding: 0;
}

.ncpro-claim-badge svg {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.ncpro-claim-badge.claimed {
    color: rgb(26, 109, 195);
}

.ncpro-claim-badge.claimed svg {
    fill: rgb(26, 109, 195);
}

.ncpro-claim-badge.unclaimed {
    color: rgb(107, 109, 111);
}

.ncpro-claim-badge.unclaimed svg {
    stroke: rgb(107, 109, 111);
}

.ncpro-claim-tooltip {
    position: absolute;
    bottom: calc(100% + 12px);
    left: 0;
    transform: none;
    width: 320px;
    max-width: 90vw;
    padding: 12px 14px;
    background: #2d2e2f;
    color: #fff;
    font-size: 14px;
    font-weight: normal;
    line-height: 1.5;
    border-radius: 4px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.15s, visibility 0.15s;
    z-index: 9999;
    pointer-events: none;
    text-align: left;
    box-shadow: 0 4px 12px rgba(0,0,0,0.25);
}

.ncpro-claim-tooltip p {
	font-size: 14px !important;
}


.ncpro-claim-status:hover .ncpro-claim-tooltip,
.ncpro-claim-status:focus-within .ncpro-claim-tooltip {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.ncpro-claim-tooltip-content p {
    color: #fff;
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
}

.ncpro-claim-tooltip-arrow {
    position: absolute;
    bottom: -6px;
    left: 20px;
    width: 12px;
    height: 12px;
    background: #2d2e2f;
    transform: rotate(45deg);
    z-index: -1;
}

@media (max-width: 600px) {
    .ncpro-claim-tooltip {
        width: 280px;
        left: 50%;
        transform: translateX(-50%);
    }
    .ncpro-claim-tooltip-arrow {
        left: 50%;
        transform: translateX(-50%) rotate(45deg);
    }
}

#ncpro-gmb-preview-rating .sq {
    margin-right: 4px !important;
}

#ncpro-gmb-preview-rating .nc-rating-wrapper {
	margin-bottom: 0 !important;
}

.comment-body {
	margin-top: 3rem !important;
}

.preview-section-desc p {
	margin-bottom: 0 !important;
}

.tm-cta-negocio {
    border: 1px solid #ddd;
    padding: 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    flex-wrap: wrap;
    background: #fff;
    border-radius: 3px;
    margin-top: 60px;
    font-family: inherit;
    width: 100%;
    margin-bottom: 60px;
}

.tm-cta-content {
    flex-grow: 1;
    min-width: 200px;
}
.tm-cta-negocio .more {
    -webkit-appearance: none;
    -moz-appearance: none;
    -ms-appearance: none;
    appearance: none;
    background-image: none;
    background-repeat: no-repeat;
    border: 0;
    cursor: pointer;
    margin: 0;
    -webkit-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border-radius: 4px;
    box-shadow: none;
    box-sizing: border-box;
    display: -webkit-inline-box;
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
    height: 44px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    -webkit-justify-content: center;
    justify-content: center;
    margin: 0;
    padding-bottom: 10px;
    padding-left: 16px;
    padding-right: 16px;
    padding-top: 10px;
    position: relative;
    text-align: center;
    -webkit-transition: all 0.8s;
    transition: all 0.25s;
    transition-property: background-image, background-color, background-position, background-size, border-color, box-shadow, opacity;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    vertical-align: middle;
    width: auto;
    background-color: rgba(0, 0, 0, 0);
    border: 1px solid rgba(200, 201, 202, 1);
    color: rgba(45, 46, 47, 1);
    font-size: 14px !important;
    width: auto !important;
    font-weight: 600;
    white-space: nowrap;
    text-decoration: none !important;
}

.tm-cta-negocio .more:hover {
       background-color: rgba(0, 0, 0, 0.07);

}
.tm-cta-negocio .more:active {
          background-color: rgba(0, 0, 0, 0.1);

}


.tm-cta-content p {
    margin: 0;
    color: #555;
    font-size: 14px;
}

.tm-cta-content strong {
    display: block;
    font-size: 16px;
    margin-bottom: 4px;
    color: #282828;
}


.yb-mobile-title {display: none;}
.yb-tab[data-tab="promote"] {
    display: none !important;
}


@media (max-width: 960px) {
    .nc-main {
        border: none !important;
        padding: 0 !important;
    }
}

@media (min-width: 1050px) {
    #menu>ul {
        display: flex;
        align-items: center;
    }
    .ncpro-menu-auth-buttons {
    	margin-left: 1.5rem;
    }
}

@media (min-width: 1050px) {
    #menu>ul>li {
        background: transparent !important;
    }
     #menu>ul>li:hover {
        background: rgba(255,255,255,.15) !important;
    }
}

#menu > ul > li {
	transition: background-color 0.25s;
	font-weight: 600 !important;
}

@media (min-width: 1050px) {
    #menu>ul>li.menu-item-para-empresas:first-child {
        margin-right: .25rem !important;
    }
     #menu ul .menu-item-has-children a {
        padding-right: .25rem !important;
    }
}



@media (max-width: 1050px) {
    .article-full>.breadcrumb-trail, .content-loop>.breadcrumb-trail, .content-thin>.breadcrumb-trail {
        margin-bottom: .25rem !important;
    }
}

.rating-block {
    display: flex;
    gap: 2rem;
    font-family: system-ui, sans-serif;
    margin: 1rem 0;
}

.nc-ubi-horarios-direccion a {
    font-size: 16px !important;
    font-weight: 600;
    line-height: 1.5 !important;
    display: inline-block;
}
.ncs-phone {
    display: flex;
    justify-content: space-between;
}
.ncs-phone div a {
    font-size: 16px !important;
    font-weight: 600;
}





/* LUPA en header - junto a Mapa y Hamburguesa */
.ncpro-header-search-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	cursor: pointer;
	margin-top:-3px !important;
}
.ncpro-header-search-btn svg {
	transition: opacity 0.2s;
}
.ncpro-header-search-btn:hover svg {
	opacity: 0.7;
}

/* Overlay */
.ncpro-search-overlay {
	display: none;
	position: fixed;
	top: 60px;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0,0,0,0.7);
	z-index: 99998;
	opacity: 0;
	transition: opacity 0.3s;
}
.ncpro-search-overlay.active {
	display: block;
	opacity: 1;
}

/* Panel */
.ncpro-search-panel {
	display: none;
	position: fixed;
	top: 60px;
	left: 0;
	right: 0;
	background: #fff;
	z-index: 99999;
	padding: 16px;
	box-shadow: 0 4px 20px rgba(0,0,0,0.15);
	transform: translateY(-100%);
	opacity: 0;
	transition: transform 0.3s, opacity 0.3s;

}
.ncpro-search-panel.active {
	display: block;
	transform: translateY(0);
	opacity: 1;
}

/* Form */
.ncpro-search-form {
	display: flex;
	gap: 10px;
	align-items: center;
	max-width: 600px;
	margin: 0 auto;
}
.ncpro-search-input-wrap {
	flex: 1;
	display: flex;
	align-items: center;
	border-radius: 4px;
	padding: 0 12px;
	border: 1px solid #e0e0e0;
}
	
.ncpro-search-input-wrap:focus-within {
	border-color: var(--ncpro-primary, #d32323);
	box-shadow: 0 0 0 3px rgba(211,35,35,0.1);
}
.ncpro-search-input-wrap svg {
	color: #666;
	flex-shrink: 0;
	display:none;
}
.ncpro-search-input-wrap input {
	flex: 1;
	border: none;
	background: transparent;
	padding: 12px 8px;
	font-size: 16px;
	outline: none;
	
	}
#ncpro-search-close {
	background: none;
	border: none;
	padding: 4px;
	cursor: pointer;
	color: #666;
	display: flex;
}
#ncpro-search-close:hover {
	color: #333;
}
.ncpro-search-submit {
	background: var(--ncpro-primary, #d32323);
	color: #fff;
	border: none;
	padding: 12px 20px;
	border-radius: 4px;
	font-size: 15px;
	font-weight: 600;
	cursor: pointer;
}
.ncpro-search-submit:hover {
	background: var(--ncpro-primary-hover, #b91c1c);
}
	@media(min-width:1050px) {
		#ncpro-search-btn {
			display:none;
		}
	}

	#nc-fichas-container .rating-box {
	display:flex;
	gap:4px;
}

#nc-fichas-container  .rating-n2 {
	margin-left:5px;
	
}

#nc-fichas-container  .rating-div {
	margin-bottom:.25rem 
	!important;
	margin-top:.1rem !important;
}

body.page-parent:not(.page-child) .solo-movil {
   display:none !important;
}

.province-card:active {
	    background: #f6f6f7;
}
#commentform {
	margin-bottom: 0 !important;
}

.tm-contact-card svg {
	stroke-width:1.75 !important;
	stroke:#2a2a2a !important;
}


@media(max-width: 768px) {
.content-thin > .breadcrumb-trail::after  {
        content: "";
        position: absolute;
        top: 0px;
        right: 0px;
        width: 40px;
        height: 100%;
        pointer-events: none;
        background: linear-gradient(to right, transparent, rgb(255, 255, 255));
    }

    


}