.similar-comercios-section {
margin: 60px 0;
padding: 50px 0;
background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
border-radius: 24px;
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.04);
}
.similar-comercios-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
gap: 24px;
margin-top: 40px;
}
.similar-comercio-card {
background: white;
border-radius: 16px;
overflow: hidden;
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
border: 1px solid rgba(0, 0, 0, 0.05);
position: relative;
}
.similar-comercio-card:hover {
transform: translateY(-6px);
box-shadow: 0 12px 40px rgba(0, 0, 0, 0.12);
border-color: rgba(0, 90, 135, 0.15);
}
.similar-comercio-image {
height: 190px;
overflow: hidden;
position: relative;
}
.similar-comercio-image::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
right: 0;
height: 60px;
background: linear-gradient(to top, rgba(0, 0, 0, 0.15), transparent);
pointer-events: none;
opacity: 0;
transition: opacity 0.3s ease;
}
.similar-comercio-card:hover .similar-comercio-image::after {
opacity: 1;
}
.similar-comercio-thumb {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.similar-comercio-card:hover .similar-comercio-thumb {
transform: scale(1.08);
}
.similar-comercio-content {
padding: 22px;
}
.similar-comercio-category {
margin-bottom: 12px;
}
.category-badge {
display: inline-block;
padding: 4px 14px;
background: var(--directorio-primary-color);
color: #ffffff;
border-radius: 50px;
font-size: 11px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.8px;
border: 1px solid var(--directorio-primary-color);
pointer-events: none; }
.similar-comercio-title {
font-size: 18px;
font-weight: 700;
margin-bottom: 12px;
line-height: 1.3;
}
.similar-comercio-title a {
color: #111827;
transition: color 0.2s ease;
}
.similar-comercio-card:hover .similar-comercio-title a {
color: var(--directorio-primary-color);
}
.similar-comercio-meta {
display: flex;
flex-direction: column;
gap: 8px;
margin-bottom: 14px;
}
.similar-comercio-location {
display: flex;
align-items: center;
gap: 6px;
font-size: 13px;
color: #6b7280;
}
.similar-comercio-location i {
color: var(--directorio-primary-color);
font-size: 13px;
}
.similar-comercio-rating {
display: flex;
align-items: center;
gap: 6px;
}
.similar-comercio-rating .stars {
display: flex;
flex-direction: row !important;
color: #f59e0b;
font-size: 13px;
}
.similar-comercio-rating .rating-text {
font-size: 13px;
font-weight: 600;
color: #374151;
}
.similar-comercio-excerpt {
font-size: 13px;
color: #6b7280;
line-height: 1.5;
margin-bottom: 18px;
}
.similar-comercio-link {
display: inline-flex;
align-items: center;
gap: 8px;
font-size: 13px;
font-weight: 600;
color: var(--directorio-primary-color);
padding: 8px 0;
position: relative;
}
.similar-comercio-link::after {
content: '';
position: absolute;
bottom: 0;
left: 0;
width: 0;
height: 2px;
background: var(--directorio-primary-color);
transition: width 0.3s ease;
}
.similar-comercio-link:hover::after {
width: 100%;
}
.similar-comercio-link i {
font-size: 11px;
transition: transform 0.2s ease;
}
.similar-comercio-link:hover i {
transform: translateX(4px);
}
.section-footer {
text-align: center;
margin-top: 45px;
}
.view-all-link {
display: inline-flex;
align-items: center;
gap: 10px;
padding: 14px 28px;
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, #0077aa 100%);
color: white;
font-weight: 600;
border-radius: 12px;
box-shadow: 0 4px 12px rgba(0, 90, 135, 0.25);
transition: all 0.3s ease;
}
.view-all-link:hover {
transform: translateY(-2px);
box-shadow: 0 8px 24px rgba(0, 90, 135, 0.35);
color: white;
}
.view-all-link i {
transition: transform 0.2s ease;
}
.view-all-link:hover i {
transform: translateX(4px);
}
@media (max-width: 768px) {
.similar-comercios-section {
padding: 35px 0;
margin: 40px 0;
border-radius: 16px;
}
.similar-comercios-grid {
grid-template-columns: 1fr;
gap: 20px;
}
.similar-comercio-image {
height: 170px;
}
.similar-comercio-content {
padding: 18px;
}
} .comercio-visitas-contador {
display: inline-flex;
align-items: center;
gap: 8px;
background: linear-gradient(135deg, #ffebee 0%, #ffcdd2 100%);
padding: 8px 16px;
border-radius: 25px;
margin: 12px 0;
box-shadow: 0 2px 8px rgba(244, 67, 54, 0.15);
}
.comercio-visitas-contador i {
color: #e91e63;
font-size: 16px;
animation: heartbeat 1.5s ease-in-out infinite;
}
.comercio-visitas-contador .visitas-numero {
font-weight: 600;
color: #c2185b;
font-size: 14px;
}
.result-visits {
display: flex;
align-items: center;
gap: 6px;
color: #e91e63;
font-size: 13px;
font-weight: 500;
}
.result-visits i {
font-size: 14px;
animation: heartbeat 2s ease-in-out infinite;
}
@keyframes heartbeat {
0% {
transform: scale(1);
}
14% {
transform: scale(1.1);
}
28% {
transform: scale(1);
}
42% {
transform: scale(1.1);
}
70% {
transform: scale(1);
}
}
.average-rating-display {
display: flex;
align-items: center;
gap: 16px;
flex-wrap: wrap;
}
.visit-counter-inline {
display: inline-flex;
align-items: center;
gap: 6px;
color: #e91e63;
font-size: 14px;
font-weight: 500;
margin-left: 12px;
}
.visit-counter-inline i {
animation: heartbeat 1.5s ease-in-out infinite;
font-size: 16px;
}
.visit-counter-inline .visit-number {
font-weight: 600;
}
.result-actions {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 8px;
}  :root {
--directorio-primary-color: #005a87;
--directorio-secondary-color: #f0f8ff;
--directorio-accent-color: #005a87;
--directorio-text-color: #333;
--directorio-border-color: #ddd;
--directorio-white: #fff;
--directorio-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
}
body {
font-family: var(--directorio-font-family);
color: var(--directorio-text-color);
background-color: #f7f7f7;
line-height: 1.6;
}
a {
color: var(--directorio-accent-color);
text-decoration: none;
}
.container {
max-width: 1200px;
margin: 0 auto;
padding: 0 20px;
}  .top-bar {
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, var(--directorio-accent-color) 100%);
color: var(--directorio-white);
font-size: 13px;
padding: 8px 0;
position: relative;
z-index: 2001;
} @media (max-width: 991px) {
.top-bar {
display: flex;
align-items: center;
justify-content: center;
height: 35px;
padding: 0;
position: fixed;
top: 0;
left: 0;
right: 0;
width: 100%;
z-index: 2001;
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, var(--directorio-accent-color) 100%);
transition: transform 0.3s ease;
border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}
.top-bar-content {
justify-content: center;
padding: 0 10px;
}
.top-bar-left {
margin: 0;
position: static;
transform: none;
}
.top-bar-text-left {
position: static !important;
transform: none !important;
text-align: center;
font-size: 12px;
margin: 0;
padding: 0;
display: inline-flex;
align-items: center;
gap: 6px;
}
.top-bar-label {
display: inline !important;
font-size: 12px;
font-weight: 600;
}
.comercios-counter {
display: inline-block !important;
font-size: 16px;
padding: 2px 10px;
margin-left: 0;
}
.top-bar-right {
display: none !important;
} .site-header {
transform: translate3d(0, 35px, 0);
transition: transform 0.3s ease;
} .site-header.scrolled {
transform: translate3d(0, 0.1px, 0);
}
.site-header.scrolled .top-bar {
transform: translateY(-100%);
opacity: 0;
visibility: hidden;
}
.header-spacer {
height: 100px;
}
}
.top-bar-content {
display: flex;
justify-content: space-between;
align-items: center;
width: 100%;
max-width: 100%;
padding: 0 20px;
box-sizing: border-box;
}
.top-bar-left {
display: flex;
align-items: center;
gap: 8px;
}
.top-bar-text {
display: flex;
align-items: center;
gap: 6px;
font-weight: 500;
opacity: 0.95;
}
.top-bar-text-left {
margin-left: 0 !important;
color: #ffffff;
font-weight: 700;
font-size: 14px;
position: absolute;
left: 20px;
top: 50%;
transform: translateY(-50%);
}
.top-bar-text i {
font-size: 12px;
} .comercios-counter {
display: inline-block;
font-weight: 700;
font-size: 16px;
color: #ffffff;
background: rgba(255, 255, 255, 0.15);
padding: 2px 10px;
border-radius: 20px;
margin-left: 4px;
transition: all 0.3s ease;
min-width: 30px;
text-align: center;
}
.top-bar-text .fa-store {
font-size: 14px;
margin-right: 4px;
}
.top-bar-right {
display: flex;
align-items: center;
gap: 20px;
margin-left: auto;
justify-content: flex-end;
}
.top-bar-link {
color: var(--directorio-white);
text-decoration: none;
display: flex;
align-items: center;
gap: 6px;
font-weight: 500;
opacity: 0.9;
transition: opacity 0.2s ease;
font-size: 13px;
margin-left: auto; }
.top-bar-link:hover {
opacity: 1;
text-decoration: none;
}
.top-bar-link i {
font-size: 12px;
} .site-header::before { content: ''; position: absolute; top: -100px; left: 0; right: 0; height: 100px; background-color: var(--directorio-white); z-index: -1; }
.site-header {
position: fixed;
top: 0;
left: 0;
width: 100%;
z-index: 2000;
background-color: var(--directorio-white);
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08), 0 1px 2px rgba(0, 0, 0, 0.04);
transition: all 0.3s ease-in-out;
padding: 0;
height: 70px;
}
.site-header.has-top-bar { transform: translate3d(0, 35px, 0); }
.site-header.scrolled {
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
}
.site-header.scrolled.has-top-bar { transform: translate3d(0, 0.1px, 0); }
.header-main-wrapper {
display: flex;
justify-content: space-between; align-items: center;
width: 100%;
height: 100%;
gap: 20px;
padding-left: 0; margin-left: 0; } @media (min-width: 992px) {
.header-main-wrapper {
padding-left: 20px; padding-right: 20px; gap: 0; justify-content: flex-start; }
} @media (max-width: 991px) {
.header-main-wrapper {
padding-left: 20px; padding-right: 20px; }
} .site-branding {
flex-shrink: 0;
}
.brand-link {
display: flex;
align-items: center;
gap: 10px;
text-decoration: none;
transition: transform 0.2s ease;
}
.brand-link:hover {
transform: scale(1.02);
}
.brand-icon {
width: 40px;
height: 40px;
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, var(--directorio-accent-color) 100%);
border-radius: 10px;
display: flex;
align-items: center;
justify-content: center;
color: var(--directorio-white);
font-size: 18px;
box-shadow: 0 4px 12px rgba(0, 90, 135, 0.2);
flex-shrink: 0;
} .custom-logo-link {
display: flex;
align-items: center;
}
.custom-logo {
max-height: 50px;
width: auto;
max-width: 150px;
object-fit: contain;
} .site-branding:has(.custom-logo) .brand-tagline {
font-size: 11px;
color: #6b7280;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 2px; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
opacity: 0.7;
} .header-search-wrapper {
flex: 1;
max-width: 500px;
margin: 0 16px;
position: relative;
}
.header-search-dropdown {
position: absolute;
top: 100%;
left: 0;
right: 0;
background: white;
border-radius: 12px;
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
margin-top: 8px;
z-index: 9999;
max-height: 400px;
overflow-y: auto;
border: 1px solid #eee;
}
.dropdown-group {
padding: 8px 0;
border-bottom: 1px solid #f0f0f0;
}
.dropdown-group:last-child {
border-bottom: none;
}
.group-title {
padding: 4px 16px;
font-size: 11px;
font-weight: 700;
color: #9ca3af;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.dropdown-item {
display: block;
padding: 10px 16px;
font-size: 14px;
color: #374151;
transition: background 0.2s;
}
.dropdown-item:hover {
background: #f3f4f6;
color: var(--directorio-accent-color);
} .header-search-autocomplete-results {
position: absolute;
top: calc(100% + 10px);
left: 0;
right: 0;
background: #ffffff;
border-radius: 16px;
box-shadow: 0 15px 45px rgba(0, 0, 0, 0.12), 0 5px 15px rgba(0, 0, 0, 0.04);
border: 1px solid rgba(0, 0, 0, 0.06);
z-index: 10000;
overflow: hidden;
display: none;
animation: slideUpFade 0.3s ease-out;
}
@keyframes slideUpFade {
from {
opacity: 0;
transform: translateY(10px);
}
to {
opacity: 1;
transform: translate3d(0, 0.1px, 0);
}
}
.autocomplete-group-title {
padding: 16px 20px 8px 20px;
font-size: 11px;
font-weight: 800;
color: #9ca3af;
text-transform: uppercase;
letter-spacing: 1.5px;
background: #f9fafb;
}
.autocomplete-item {
display: flex;
align-items: center;
gap: 15px;
padding: 12px 20px;
cursor: pointer;
transition: all 0.2s ease;
border-bottom: 1px solid rgba(0, 0, 0, 0.02);
}
.autocomplete-item:last-child {
border-bottom: none;
}
.autocomplete-item i {
width: 32px;
height: 32px;
display: flex;
align-items: center;
justify-content: center;
background: #f3f4f6;
border-radius: 10px;
color: var(--directorio-primary-color);
font-size: 14px;
transition: all 0.2s ease;
}
.autocomplete-item .item-name {
font-size: 15px;
font-weight: 500;
color: #374151;
}
.autocomplete-item:hover,
.autocomplete-item.is-selected {
background: #f0f7ff;
}
.autocomplete-item:hover i,
.autocomplete-item.is-selected i {
background: var(--directorio-primary-color);
color: #ffffff;
transform: scale(1.1);
}
.autocomplete-footer {
padding: 15px 20px;
background: #ffffff;
border-top: 1px solid rgba(0, 0, 0, 0.05);
display: flex;
align-items: center;
justify-content: space-between;
font-size: 14px;
color: var(--directorio-primary-color);
cursor: pointer;
font-weight: 600;
}
.autocomplete-footer:hover {
background: #f8fbff;
}
.autocomplete-footer i {
font-size: 12px;
transition: transform 0.2s;
}
.autocomplete-footer:hover i {
transform: translateX(5px);
} @media (max-width: 991px) {
.header-search-autocomplete-results {
position: fixed;
top: 70px;
left: 10px;
right: 10px;
bottom: auto;
max-height: 80vh;
border-radius: 20px;
}
} @media (min-width: 992px) {
.header-search-wrapper {
margin: 0 32px; }
}
.header-search-form {
display: flex;
align-items: center;
background: #f3f4f6;
border-radius: 50px;
overflow: hidden;
border: 2px solid transparent;
transition: all 0.2s ease;
}
.header-search-form:focus-within {
background: var(--directorio-white);
border-color: var(--directorio-accent-color);
box-shadow: 0 0 0 3px rgba(0, 115, 170, 0.1);
}
.header-search-input {
flex: 1;
border: none;
background: transparent;
padding: 10px 30px;
font-size: 14px;
color: var(--directorio-text-color);
outline: none;
}
.header-search-input::placeholder {
color: #9ca3af;
}
.header-search-btn {
background: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
padding: 12px 16px;
cursor: pointer;
transition: background 0.2s ease;
display: flex;
align-items: center;
justify-content: center;
}
.header-search-btn:hover {
background: var(--directorio-primary-color);
} .header-actions {
display: flex;
align-items: center;
gap: 12px;
flex-shrink: 0; } @media (min-width: 992px) {
.header-actions {
position: static;
transform: none;
}
} @media (max-width: 991px) {
.header-actions {
position: absolute;
right: 20px;
top: 50%;
transform: translateY(-50%);
}
} .btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 10px 20px;
font-size: 14px;
font-weight: 600;
border-radius: 8px;
text-decoration: none;
border: none;
cursor: pointer;
transition: all 0.2s ease;
white-space: nowrap;
}
.btn-primary {
background: linear-gradient(135deg, var(--directorio-accent-color) 0%, var(--directorio-primary-color) 100%);
color: var(--directorio-white);
box-shadow: 0 4px 12px rgba(0, 115, 170, 0.25);
}
.btn-primary:hover {
transform: translateY(-2px);
box-shadow: 0 6px 20px rgba(0, 115, 170, 0.35);
color: var(--directorio-white);
}
.btn-block {
width: 100%;
}
.header-cta {
padding: 1px 10px; font-size: 12px; min-width: 36px; justify-content: center; height: 36px; }
.header-cta i {
font-size: 16px; }  @media (min-width: 992px) {
.header-right-side {
display: flex;
align-items: center;
gap: 16px;
position: absolute;
right: 25px;
top: 50%;
transform: translateY(-50%);
}
} .main-navigation {
display: flex;
align-items: center;
}
.primary-menu {
margin: 0;
padding: 0;
list-style: none;
display: flex;
gap: 8px;
}
.primary-menu li {
position: relative;
}
.primary-menu a {
display: block;
padding: 8px 16px;
color: var(--directorio-text-color);
text-decoration: none;
font-weight: 500;
font-size: 14px;
border-radius: 6px;
transition: all 0.2s ease;
position: relative;
}
.primary-menu a:hover {
color: var(--directorio-accent-color);
background: #f3f4f6;
}
.primary-menu a.current-menu-item,
.primary-menu a.current_page_item {
color: var(--directorio-accent-color);
background: rgba(0, 115, 170, 0.08);
} .primary-menu li.menu-item-has-children {
position: relative;
}
.primary-menu .sub-menu {
position: absolute;
top: 100%;
left: 0;
min-width: 200px;
background: var(--directorio-white);
border-radius: 8px;
box-shadow: 0 10px 40px rgba(0, 0, 0, 0.12);
padding: 8px 0;
opacity: 0;
visibility: hidden;
transform: translateY(10px);
transition: all 0.2s ease;
z-index: 2100;
flex-direction: column !important;
gap: 0;
}
.primary-menu li:hover .sub-menu {
opacity: 1;
visibility: visible;
transform: translate3d(0, 0.1px, 0);
}
.primary-menu .sub-menu a {
padding: 10px 20px;
font-size: 13px;
border-radius: 0;
}
.primary-menu .sub-menu a:hover {
background: #f3f4f6;
} .mobile-search-toggle {
background: transparent;
border: 1.5px solid rgba(0, 90, 135, 0.25);
color: var(--directorio-primary-color);
font-size: 17px;
cursor: pointer;
padding: 8px;
transition: all 0.25s ease;
border-radius: 12px;
width: 38px;
height: 38px;
display: none;
align-items: center;
justify-content: center;
position: relative;
}
.mobile-search-toggle:hover {
border-color: var(--directorio-primary-color);
background: rgba(0, 90, 135, 0.04);
color: var(--directorio-primary-color);
}
.mobile-search-toggle:active {
background: rgba(0, 90, 135, 0.08);
} .menu-toggle {
background: none;
border: none;
cursor: pointer;
padding: 8px;
display: none;
z-index: 2100;
}
.hamburger {
display: flex;
flex-direction: column;
gap: 5px;
width: 24px;
}
.hamburger-line {
display: block;
width: 100%;
height: 2.5px;
background: var(--directorio-primary-color);
border-radius: 3px;
transition: all 0.3s ease-in-out;
transform-origin: center;
}
.menu-toggle.is-active .hamburger-line:nth-child(1) {
transform: translateY(7.5px) rotate(45deg);
}
.menu-toggle.is-active .hamburger-line:nth-child(2) {
opacity: 0;
transform: translateX(-10px);
}
.menu-toggle.is-active .hamburger-line:nth-child(3) {
transform: translateY(-7.5px) rotate(-45deg);
} .header-spacer {
height: 105px;
} .mobile-nav-overlay {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.5);
opacity: 0;
visibility: hidden;
transition: all 0.3s ease;
z-index: 2099;
backdrop-filter: blur(4px);
}
.mobile-nav-overlay.is-active {
opacity: 1;
visibility: visible;
}
.mobile-navigation {
position: fixed;
top: 0;
right: -320px;
width: 320px;
max-width: 85%;
height: 100%;
background: var(--directorio-white);
display: flex;
flex-direction: column;
transition: right 0.3s ease;
z-index: 2100;
box-shadow: -4px 0 20px rgba(0, 0, 0, 0.1);
}
.mobile-nav-overlay.is-active .mobile-navigation {
right: 0;
}
.mobile-nav-header {
display: flex;
justify-content: space-between;
align-items: center;
padding: 20px;
border-bottom: 1px solid #e5e7eb;
}
.mobile-nav-title {
font-size: 18px;
font-weight: 700;
color: var(--directorio-primary-color);
}
.mobile-nav-close {
background: none;
border: none;
font-size: 24px;
color: #6b7280;
cursor: pointer;
padding: 4px;
transition: color 0.2s ease;
}
.mobile-nav-close:hover {
color: var(--directorio-primary-color);
}
.mobile-nav-search {
padding: 16px 20px;
border-bottom: 1px solid #e5e7eb;
}
.mobile-nav-search form {
display: flex;
background: #f3f4f6;
border-radius: 8px;
overflow: hidden;
}
.mobile-search-input {
flex: 1;
border: none;
background: transparent;
padding: 10px 12px;
font-size: 14px;
outline: none;
}
.mobile-nav-search button {
background: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
padding: 10px 14px;
cursor: pointer;
}
.mobile-nav-menu {
overflow-y: auto;
padding: 16px 0;
}
.mobile-menu {
margin: 0;
padding: 0;
list-style: none;
}
.mobile-menu li {
border-bottom: 1px solid #f3f4f6;
}
.mobile-menu a {
display: flex;
align-items: center;
gap: 12px;
padding: 14px 20px;
color: var(--directorio-text-color);
text-decoration: none;
font-weight: 500;
font-size: 16px;
transition: all 0.2s ease;
}
.mobile-menu a:hover {
color: var(--directorio-accent-color);
background: #f9fafb;
padding-left: 28px;
}
.mobile-menu .sub-menu {
padding-left: 20px;
}
.mobile-menu .sub-menu a {
font-size: 14px;
padding: 10px 20px;
}
.mobile-nav-user {
padding: 16px 20px;
border-top: 1px solid #e5e7eb;
border-bottom: 1px solid #e5e7eb;
display: flex;
flex-direction: column;
gap: 8px;
}
.mobile-user-link,
.mobile-login-link,
.mobile-register-link,
.mobile-logout-link {
display: flex;
align-items: center;
gap: 10px;
padding: 12px 16px;
border-radius: 8px;
text-decoration: none;
font-weight: 500;
font-size: 15px;
transition: all 0.2s ease;
}
.mobile-user-link {
color: var(--directorio-primary-color);
background: rgba(0, 90, 135, 0.08);
}
.mobile-user-link:hover {
background: rgba(0, 90, 135, 0.12);
}
.mobile-login-link {
color: var(--directorio-text-color);
background: #f3f4f6;
}
.mobile-login-link:hover {
background: #e5e7eb;
}
.mobile-register-link {
color: var(--directorio-accent-color);
background: rgba(0, 115, 170, 0.08);
}
.mobile-register-link:hover {
background: rgba(0, 115, 170, 0.12);
}
.mobile-logout-link {
color: #ef4444;
background: rgba(239, 68, 68, 0.08);
}
.mobile-logout-link:hover {
background: rgba(239, 68, 68, 0.12);
}
.mobile-nav-cta {
padding: 20px;
} .mobile-search-overlay {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: var(--directorio-white);
z-index: 2100;
opacity: 0;
visibility: hidden;
transition: all 0.3s ease;
display: flex;
align-items: center;
justify-content: center;
padding: 20px 15px;
box-sizing: border-box;
}
.mobile-search-overlay.is-active {
opacity: 1;
visibility: visible;
}
.mobile-search-container {
width: 100%;
max-width: 600px;
position: relative; display: flex;
align-items: center;
gap: 12px;
gap: 10px;
box-sizing: border-box;
}
.mobile-search-container form {
flex: 1;
display: flex;
background: #f3f4f6;
border-radius: 12px;
overflow: hidden;
min-width: 0; }
.mobile-search-full {
flex: 1;
min-width: 0; border: none;
background: transparent;
padding: 16px 20px;
font-size: 18px;
padding: 14px 16px;
font-size: 16px; outline: none;
}
.mobile-search-submit {
background: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
padding: 16px 24px;
padding: 14px 18px;
cursor: pointer;
font-size: 18px;
font-size: 16px;
}
.mobile-search-close {
background: none;
border: none;
font-size: 28px;
color: #6b7280;
cursor: pointer;
padding: 8px;
} @media (max-width: 991px) {
.mobile-search-container .header-search-dropdown {
top: 100%;
margin-top: 15px;
width: 100%;
box-sizing: border-box;
}
} @media (max-width: 991px) { .site-header.has-top-bar {
height: 65px;
}
.header-main-wrapper {
height: 65px;
padding: 0 20px; overflow: visible; }
.site-branding {
flex: 0 0 auto; min-width: 0; }
.brand-icon {
width: 36px;
height: 36px;
font-size: 16px;
}
.brand-name {
font-size: 17px;
margin-left: 0 !important; text-shadow: 0 0 15px rgba(0, 90, 135, 0.5), 0 0 25px rgba(0, 90, 135, 0.4), 0 0 35px rgba(0, 90, 135, 0.3), 0 0 45px rgba(0, 90, 135, 0.2);
filter: drop-shadow(0 0 12px rgba(0, 90, 135, 0.6));
position: relative;
z-index: 10;
display: block;
width: 100%;
}
.brand-tagline {
font-size: 10px;
} .main-navigation {
display: none !important;
} .mobile-search-toggle,
.menu-toggle {
display: flex !important;
min-width: 40px; min-height: 40px; align-items: center;
justify-content: center;
}
.header-cta .btn-text {
display: none;
}
.header-cta {
padding: 0px;
border-radius: 10px;
background: var(--directorio-accent-color);
color: var(--directorio-white);
flex: 0 0 auto; min-width: 40px; min-height: 40px; align-items: center;
justify-content: center;
}
.header-spacer {
height: 100px;
} .header-actions {
flex: 0 0 auto; gap: 8px; min-width: 0; } .mobile-search-toggle i,
.menu-toggle .hamburger {
font-size: 20px;
display: flex;
align-items: center;
justify-content: center;
}
}
@media (max-width: 480px) {
.brand-tagline {
display: none;
}
.header-actions {
gap: 8px;
}
.mobile-navigation {
width: 280px;
}
} .desktop-only {
display: flex;
}
.mobile-only {
display: none;
}
@media (max-width: 991px) {
.desktop-only {
display: none !important;
}
.mobile-only {
display: flex;
}
} @keyframes fadeIn {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
@keyframes slideInRight {
from {
transform: translateX(100%);
}
to {
transform: translateX(0);
}
}
@keyframes slideOutRight {
from {
transform: translateX(0);
}
to {
transform: translateX(100%);
}
} .site-footer {
background-color: #222;
color: var(--directorio-white);
padding: 40px 0;
text-align: center;
margin-top: 60px;
} .directory-hero {
background: linear-gradient(45deg, var(--directorio-primary-color), var(--directorio-accent-color));
color: var(--directorio-white);
padding: 80px 20px;
text-align: center;
}
.directory-hero h1 {
font-size: 48px;
margin-bottom: 20px;
}
.directory-hero p {
font-size: 18px;
margin-bottom: 30px;
}
.categories-section {
padding: 60px 0;
}
.section-title {
text-align: center;
font-size: 32px;
margin-bottom: 40px;
}
.category-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
gap: 20px;
}
.category-card {
background-color: var(--directorio-white);
border: 1px solid var(--directorio-border-color);
border-radius: 5px;
padding: 20px;
text-align: center;
text-decoration: none;
color: var(--directorio-text-color);
transition: transform 0.2s, box-shadow 0.2s;
}
.category-card:hover {
transform: translateY(-5px);
box-shadow: 0 10px 20px rgba(0, 0, 0, 0.05);
}
.category-card h3 {
margin: 0;
color: var(--directorio-primary-color);
} .listings-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
gap: 30px;
margin-top: 40px;
}
.listing-card {
background-color: var(--directorio-white);
border: 1px solid var(--directorio-border-color);
border-radius: 5px;
overflow: hidden;
color: var(--directorio-text-color);
display: flex;
flex-direction: column;
transition: transform 0.2s, box-shadow 0.2s;
}
.listing-card:hover {
transform: translateY(-5px);
box-shadow: 0 10px 20px rgba(0, 0, 0, 0.08);
}
.listing-card-image img {
width: 100%;
height: 200px;
object-fit: cover;
display: block;
}
.listing-card-content {
padding: 20px;
}
.listing-card-category {
display: inline-block;
background-color: var(--directorio-secondary-color);
color: var(--directorio-accent-color);
padding: 4px 8px;
border-radius: 4px;
font-size: 12px;
font-weight: bold;
margin-bottom: 10px;
text-transform: uppercase;
}
.listing-card-title {
margin: 0 0 10px;
font-size: 20px;
color: var(--directorio-primary-color);
}
.listing-card-address {
margin: 0;
font-size: 14px;
color: #666;
} .listing-main-content {
margin-bottom: 50px; }
.single-listing-thumbnail {
margin-bottom: 30px;
}
.single-listing-thumbnail img {
width: 100%;
height: auto;
border-radius: 5px;
} .listing-taxonomy-terms {
margin: 20px 0 30px 0;
display: flex;
flex-direction: column;
gap: 15px; }
.taxonomy-group {
margin-bottom: 0;
} .category-pills .terms {
display: flex;
flex-wrap: wrap;
gap: 10px;
}
.category-badge {
display: inline-block;
background-color: var(--directorio-white); color: var(--directorio-primary-color) !important;
padding: 6px 14px;
border-radius: 4px;
font-size: 13px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
text-decoration: none;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08); transition: all 0.2s ease;
border: 1px solid var(--directorio-primary-color); }
.category-badge:hover {
background-color: var(--directorio-primary-color); color: var(--directorio-white) !important;
border-color: var(--directorio-primary-color);
transform: translateY(-2px); box-shadow: 0 5px 10px rgba(0, 90, 135, 0.25); } .location-breadcrumb {
background-color: #f8f9fa; padding: 10px 15px 10px 0; border-radius: 6px;
border: 1px solid #e9ecef;
display: block;
width: 100%;
box-sizing: border-box;
margin-bottom: 15px; }
.location-breadcrumb .terms a {
color: #000000; font-weight: 700; font-size: 14px; text-decoration: none;
transition: color 0.2s ease;
}
.location-breadcrumb .terms a:hover {
color: var(--directorio-primary-color); text-decoration: none; }
@media (min-width: 768px) {
.location-breadcrumb .terms a {
font-size: 16px; }
}
.location-breadcrumb .breadcrumb-separator {
margin: 0 6px;
color: #000000; font-weight: bold;
font-size: 14px; }
@media (min-width: 768px) {
.location-breadcrumb .breadcrumb-separator {
font-size: 16px; }
}
.button.edit-listing-button {
display: inline-block;
margin-bottom: 20px;
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
padding: 8px 15px;
border-radius: 4px;
} .listing-carousel-wrapper {
position: relative;
margin-bottom: 30px;
padding: 15px; background-color: var(--directorio-white); border: 1px solid var(--directorio-border-color); max-width: 100%; margin: 0 0 30px 0; border-radius: 5px;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
overflow: visible; } .listing-top-grid {
display: grid;
grid-template-columns: 1fr;
gap: 30px;
margin-bottom: 30px;
}
@media (min-width: 992px) {
.listing-top-grid {
grid-template-columns: 2fr 1fr; align-items: start;
}
} .listing-sidebar-column {
min-width: 0;
max-width: 100%;
}
.listing-sidebar-placeholder {
background-color: var(--directorio-white);
border: 1px dashed var(--directorio-border-color);
padding: 20px;
border-radius: 5px;
color: #777;
text-align: center;
}
.listing-carousel .carousel-slide {
display: none; height: 250px; background-color: #f8fafc;
overflow: hidden;
border-radius: 3px;
}
@media (min-width: 768px) {
.listing-carousel .carousel-slide {
height: 450px; }
}
.listing-carousel .carousel-slide img {
width: 100%;
height: 100%; display: block;
object-fit: cover; border-radius: 3px;
}
.listing-carousel .carousel-slide video {
width: 100%;
height: 100%;
background-color: #000;
display: block;
border-radius: 5px;
object-fit: contain; }
.video-slide-container {
position: relative;
width: 100%;
height: 100%; background: #000;
border-radius: 5px;
overflow: hidden;
cursor: pointer;
}
.video-overlay-play {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
z-index: 10;
width: 80px;
height: 80px;
background: var(--directorio-accent-color);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: #fff;
font-size: 28px;
box-shadow: 0 0 20px rgba(0, 0, 0, 0.5);
transition: all 0.3s ease;
pointer-events: none;
}
.video-overlay-play i {
margin-left: 5px;
}
.video-slide-container:hover .video-overlay-play {
transform: translate(-50%, -50%) scale(1.1);
}
.video-slide-container.playing .video-overlay-play {
opacity: 0;
visibility: hidden;
} .video-custom-controls {
position: absolute;
bottom: 0;
left: 0;
width: 100%;
background: linear-gradient(transparent, rgba(0, 0, 0, 0.8));
padding: 10px 15px;
box-sizing: border-box;
opacity: 0;
transition: opacity 0.3s ease;
z-index: 15;
}
.video-slide-container:hover .video-custom-controls {
opacity: 1;
}
.video-progress {
width: 100%;
height: 5px;
background: rgba(255, 255, 255, 0.3);
border-radius: 5px;
margin-bottom: 10px;
cursor: pointer;
position: relative;
}
.video-progress-filled {
height: 100%;
background: var(--directorio-accent-color);
width: 0%;
border-radius: 5px;
transition: width 0.1s linear;
}
.video-controls-buttons {
display: flex;
align-items: center;
gap: 15px;
color: #fff;
}
.video-btn {
background: none;
border: none;
color: #fff;
cursor: pointer;
font-size: 16px;
padding: 5px;
transition: transform 0.2s;
}
.video-btn:hover {
transform: scale(1.2);
}
.video-time {
font-size: 13px;
font-weight: 500;
font-family: monospace;
}
.video-controls-right {
margin-left: auto;
display: flex;
gap: 10px;
}
.carousel-control {
position: absolute;
top: 50%;
transform: translateY(-50%);
background-color: rgba(0, 0, 0, 0.5);
color: var(--directorio-white);
border: none;
padding: 10px;
font-size: 24px;
cursor: pointer;
transition: background-color 0.2s;
z-index: 30; width: 50px;
height: 50px;
border-radius: 50%;
line-height: 1;
display: flex;
align-items: center;
justify-content: center;
font-size: 28px;
background-color: rgba(0, 0, 0, 0.7); box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}
.video-slide-container.playing .video-overlay-play {
opacity: 0;
visibility: hidden;
}
.carousel-control:hover {
background-color: rgba(0, 0, 0, 0.9);
transform: translateY(-50%) scale(1.1);
} .carousel-control.prev {
left: -25px;
}
.carousel-control.next {
right: -25px;
} @media (max-width: 1280px) {
.carousel-control.prev {
left: 5px;
}
.carousel-control.next {
right: 5px;
}
} .listing-carousel-thumbnails {
display: flex;
gap: 10px;
margin-top: 15px;
justify-content: center;
flex-wrap: wrap;
}
.carousel-thumbnail-item {
cursor: pointer;
border: 2px solid transparent;
transition: border-color 0.2s;
border-radius: 3px;
overflow: hidden;
width: 80px; height: 60px; }
.carousel-thumbnail-item img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
opacity: 0.6;
transition: opacity 0.2s;
}
.carousel-thumbnail-item:hover img,
.carousel-thumbnail-item.active img {
opacity: 1;
}
.carousel-thumbnail-item.active {
border-color: var(--directorio-accent-color);
}
.carousel-thumbnail-item.is-video {
position: relative;
}
.video-thumb-overlay {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
color: #fff;
font-size: 18px;
z-index: 2;
text-shadow: 0 0 4px rgba(0, 0, 0, 0.6);
pointer-events: none;
opacity: 0.8;
}
.video-placeholder {
width: 100%;
height: 100%;
background-color: #333;
display: flex;
align-items: center;
justify-content: center;
color: #999;
font-size: 20px;
}
.listing-meta-section {
background-color: var(--directorio-white);
border: 1px solid var(--directorio-border-color);
padding: 20px; border-radius: 5px;
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.03);
}
.sidebar-section-title {
margin-top: 0;
margin-bottom: 15px;
font-size: 20px;
color: var(--directorio-primary-color);
border-bottom: 2px solid var(--directorio-accent-color);
padding-bottom: 10px;
} .contact-details {
background: var(--directorio-white);
border-radius: 12px;
padding: 24px;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
border: 1px solid #e5e7eb;
}
.contact-details ul {
list-style: none;
padding: 0;
margin: 0;
}
.contact-details li {
display: flex;
align-items: center;
gap: 16px;
margin-bottom: 20px;
padding: 12px 16px;
background: #f9fafb;
border-radius: 10px;
border: 1px solid #e5e7eb;
transition: all 0.2s ease;
font-weight: 500;
font-size: 16px;
}
.contact-details li:hover {
background: #f3f4f6;
border-color: #d1d5db;
transform: translateY(-1px);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}
.contact-details li i {
font-family: "Font Awesome 5 Free";
font-size: 20px;
color: var(--directorio-accent-color);
width: 24px;
text-align: center;
flex-shrink: 0;
}
.contact-details li .phone-number {
font-weight: 600;
color: #111827;
letter-spacing: 0.5px;
}
.contact-details li a {
color: var(--directorio-accent-color);
text-decoration: none;
font-weight: 600;
transition: color 0.2s ease;
}
.contact-details li a:hover {
color: var(--directorio-primary-color);
text-decoration: underline;
} .social-links {
display: flex;
gap: 16px;
margin-top: 24px;
padding-top: 24px;
border-top: 1px solid #e5e7eb;
}
.social-link {
display: inline-flex;
align-items: center;
justify-content: center;
width: 48px;
height: 48px;
border-radius: 12px;
background-size: 55%;
background-repeat: no-repeat;
background-position: center;
transition: all 0.3s ease;
opacity: 0.9;
position: relative;
overflow: hidden;
}
.social-link::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(255, 255, 255, 0.1);
opacity: 0;
transition: opacity 0.3s ease;
}
.social-link:hover {
opacity: 1;
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
}
.social-link:hover::before {
opacity: 1;
}
.social-link.facebook {
background-color: #1877F2;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M22,12c0-5.52-4.48-10-10-10S2,6.48,2,12c0,4.84,3.44,8.87,8,9.8V15H8v-3h2V9.5C10,7.57,11.57,6,13.5,6H16v3h-1.5c-1.38,0-1.5,0.62-1.5,1.5V12h3l-0.5,3h-2.5v6.8C18.56,20.87,22,16.84,22,12z'/%3E%3C/svg%3E");
}
.social-link.instagram {
background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%);
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 2.163c3.204 0 3.584.012 4.85.07 3.252.148 4.771 1.691 4.919 4.919.058 1.265.069 1.645.069 4.849 0 3.205-.012 3.584-.069 4.849-.149 3.225-1.664 4.771-4.919 4.919-1.266.058-1.644.07-4.85.07-3.204 0-3.584-.012-4.85-.07-3.26-.149-4.771-1.699-4.919-4.92-.058-1.265-.07-1.644-.07-4.849 0-3.204.013-3.583.07-4.849.149-3.227 1.664-4.771 4.919-4.919 1.266-.057 1.645-.069 4.85-.069zm0-2.163c-3.259 0-3.667.014-4.947.072-4.358.2-6.78 2.618-6.98 6.98-.059 1.281-.073 1.689-.073 4.948 0 3.259.014 3.668.072 4.948.2 4.358 2.618 6.78 6.98 6.98 1.281.058 1.689.072 4.948.072 3.259 0 3.668-.014 4.948-.072 4.354-.2 6.782-2.618 6.979-6.98.059-1.28.073-1.689.073-4.948 0-3.259-.014-3.667-.072-4.947-.196-4.354-2.617-6.78-6.979-6.98-1.281-.059-1.69-.073-4.949-.073zm0 5.838c-3.403 0-6.162 2.759-6.162 6.162s2.759 6.163 6.162 6.163 6.162-2.759 6.162-6.163c0-3.403-2.759-6.162-6.162-6.162zm0 10.162c-2.209 0-4-1.79-4-4 0-2.209 1.791-4 4-4s4 1.791 4 4c0 2.21-1.791 4-4 4zm6.406-11.845c-.796 0-1.441.645-1.441 1.44s.645 1.44 1.441 1.44c.795 0 1.439-.645 1.439-1.44s-.644-1.44-1.439-1.44z'/%3E%3C/svg%3E"),
radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%, #d6249f 60%, #285AEB 90%);
background-size: 55%, cover;
background-position: center, center;
background-repeat: no-repeat, no-repeat;
}
.social-link.whatsapp {
background-color: #25D366;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 01-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 01-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 012.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0012.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 005.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893a11.821 11.821 0 00-3.48-8.413z'/%3E%3C/svg%3E");
} .contact-details .sidebar-section-title {
font-size: 22px;
margin-bottom: 24px;
padding-bottom: 16px;
border-bottom: 2px solid var(--directorio-accent-color);
color: #111827;
font-weight: 700;
letter-spacing: -0.5px;
} @media (max-width: 768px) {
.contact-details {
padding: 20px;
}
.contact-details li {
padding: 10px 14px;
margin-bottom: 16px;
font-size: 15px;
}
.contact-details li i {
font-size: 18px;
}
.social-link {
width: 44px;
height: 44px;
}
.contact-details .sidebar-section-title {
font-size: 20px;
margin-bottom: 20px;
}
}
@media (max-width: 480px) {
.contact-details {
padding: 16px;
}
.contact-details li {
padding: 8px 12px;
margin-bottom: 12px;
font-size: 14px;
}
.contact-details li i {
font-size: 16px;
}
.social-link {
width: 40px;
height: 40px;
}
.social-links {
gap: 12px;
margin-top: 20px;
padding-top: 20px;
}
} .gh-widget {
font-family: var(--directorio-font-family);
background-color: var(--directorio-white);
border: 1px solid #e5e7eb;
border-radius: 16px;
overflow: hidden;
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
margin-bottom: 30px;
transition: all 0.3s ease;
}
.gh-widget:hover {
box-shadow: 0 12px 32px rgba(0, 0, 0, 0.1);
transform: translateY(-2px);
}
.gh-header {
padding: 24px 28px;
border-bottom: 1px solid #f3f4f6;
display: flex;
align-items: center;
justify-content: space-between;
background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
}
.gh-status-line {
display: flex;
align-items: center;
gap: 16px;
width: 100%;
}
.gh-clock-icon {
font-size: 24px;
color: var(--directorio-accent-color);
background: rgba(0, 90, 135, 0.1);
width: 48px;
height: 48px;
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
} .gh-status,
.closed-state {
font-size: 12px;
font-weight: 700;
padding: 8px 16px;
border-radius: 8px;
letter-spacing: 0.5px;
display: inline-flex;
align-items: center;
text-transform: uppercase;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
}
.gh-status.open {
background: linear-gradient(135deg, #10b981 0%, #059669 100%);
color: #ffffff;
border: none;
}
.gh-status.closed,
.closed-state {
background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
color: #ffffff;
border: none;
} .gh-status-text {
font-size: 16px;
font-weight: 600;
color: #111827;
flex-grow: 1;
}
.gh-status-text.closed {
color: #dc2626;
}
.gh-next-change {
margin-left: auto;
font-size: 13px;
color: #6b7280;
white-space: nowrap;
font-weight: 500;
background: rgba(255, 255, 255, 0.8);
padding: 6px 12px;
border-radius: 6px;
border: 1px solid #e5e7eb;
}
@media (max-width: 767px) {
.gh-next-change {
font-size: 11px;
padding: 4px 8px;
}
.gh-header {
padding: 20px;
flex-wrap: wrap;
gap: 12px;
}
.gh-status-line {
flex-wrap: wrap;
}
.gh-clock-icon {
width: 40px;
height: 40px;
font-size: 20px;
}
}
.gh-content {
padding: 20px 24px;
}
.gh-table {
width: 100%;
border-collapse: separate;
border-spacing: 0 8px;
}
.gh-table td {
padding: 14px 20px;
border: none;
color: #374151;
font-size: 14px;
transition: all 0.2s ease;
position: relative;
}
.gh-day {
font-weight: 600;
width: 40%;
color: #111827;
letter-spacing: 0.3px;
}
.gh-hours {
text-align: right;
color: #4b5563;
font-variant-numeric: tabular-nums;
font-weight: 500;
} .gh-table tr.is-today td {
background: linear-gradient(135deg, rgba(0, 90, 135, 0.08) 0%, rgba(0, 90, 135, 0.04) 100%);
color: var(--directorio-primary-color);
font-weight: 700;
position: relative;
}
.gh-table tr.is-today td::before {
content: '';
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
width: 4px;
height: 70%;
background: var(--directorio-accent-color);
border-radius: 0 4px 4px 0;
} .gh-table tr.is-today td:first-child {
border-top-left-radius: 10px;
border-bottom-left-radius: 10px;
color: var(--directorio-accent-color);
padding-left: 24px;
}
.gh-table tr.is-today td:last-child {
border-top-right-radius: 10px;
border-bottom-right-radius: 10px;
} .gh-table tr:not(.is-today):hover td {
background-color: #f9fafb;
transform: translateX(4px);
}
.gh-hours .gh-closed-text {
color: #dc2626;
font-weight: 600;
font-size: 13px;
background: rgba(239, 68, 68, 0.1);
padding: 4px 10px;
border-radius: 6px;
text-transform: uppercase;
display: inline-block;
}
.gh-hours .gh-unknown-text {
color: #9ca3af;
font-style: italic;
} @media (max-width: 640px) {
.gh-content {
padding: 16px 20px;
}
.gh-table td {
padding: 12px 8px;
font-size: 13px;
}
.gh-table tr.is-today td:first-child {
padding-left: 20px;
}
.gh-hours .gh-closed-text {
font-size: 12px;
padding: 3px 8px;
}
} .directorio-tabs-wrapper {
margin-top: 40px;
background-color: var(--directorio-white);
border-radius: 5px;
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
overflow: hidden;
}
.tabs-nav-wrapper {
position: relative;
}
.tabs-nav {
list-style: none;
padding: 0;
margin: 0;
display: flex;
background-color: #f1f1f1;
border-bottom: 1px solid #ddd;
overflow-x: auto; scrollbar-width: none; -ms-overflow-style: none; } .tabs-nav::-webkit-scrollbar {
display: none;
}
.tab-link {
padding: 15px 25px;
cursor: pointer;
font-weight: 600;
color: #666;
border-right: 1px solid #ddd;
transition: all 0.2s ease;
white-space: nowrap;
flex-shrink: 0;
}
.tab-link:hover {
background-color: #e9e9e9;
color: var(--directorio-primary-color);
}
.tab-link.current {
background-color: var(--directorio-white);
color: var(--directorio-primary-color);
border-bottom: 2px solid var(--directorio-white); margin-bottom: -1px; border-top: 3px solid var(--directorio-accent-color);
} .tabs-scroll-indicator {
position: absolute;
top: 0;
right: 0;
bottom: 0;
width: 50px;
background: linear-gradient(to left, #f1f1f1 40%, rgba(241, 241, 241, 0));
display: flex;
align-items: center;
justify-content: center;
pointer-events: none; opacity: 0;
transition: opacity 0.3s ease;
z-index: 5;
}
.tabs-scroll-indicator.visible {
opacity: 1;
}
.tabs-scroll-indicator span {
color: var(--directorio-primary-color);
font-size: 20px;
animation: bounceRight 1.5s infinite;
}
@keyframes bounceRight {
0%,
100% {
transform: translateX(0);
}
50% {
transform: translateX(5px);
}
}
.tab-content {
display: none;
padding: 30px;
animation: fadeIn 0.4s;
}
.tab-content.current {
display: block;
}
@keyframes fadeIn {
from {
opacity: 0;
transform: translateY(5px);
}
to {
opacity: 1;
transform: translate3d(0, 0.1px, 0);
}
} .form-section-horario {
background: #fdfdfd;
border: 1px solid var(--directorio-border-color);
padding: 15px;
border-radius: 4px;
margin-bottom: 20px;
}
.horario-input-row {
display: flex;
flex-direction: column;
margin-bottom: 15px;
padding-bottom: 15px;
border-bottom: 1px dashed #eee;
}
.horario-input-row:last-child {
border-bottom: none;
margin-bottom: 0;
padding-bottom: 0;
}
@media (min-width: 600px) {
.horario-input-row {
flex-direction: row;
align-items: center;
gap: 20px;
}
.day-label {
width: 100px;
font-weight: bold;
flex-shrink: 0;
}
}
.time-inputs {
display: flex;
flex-wrap: wrap;
gap: 15px;
align-items: center;
flex-grow: 1;
}
.time-group {
display: flex;
align-items: center;
gap: 5px;
}
.time-group input[type="time"] {
margin-bottom: 0 !important;
padding: 5px 10px !important;
width: auto !important;
}
.check-group input {
margin-right: 5px;
} .address-text {
font-size: 16px;
margin-bottom: 15px;
}
.map-wrapper {
position: relative;
margin-bottom: 15px;
overflow: hidden;
border-radius: 5px;
z-index: 2;
}
.map-container {
height: 600px; width: 100%;
background-color: #eee; }
.map-mobile-overlay {
display: flex;
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, 0.45);
z-index: 10000 !important;
cursor: pointer;
flex-direction: column;
justify-content: center;
align-items: center;
color: #fff;
}
.map-mobile-overlay span {
background-color: var(--directorio-accent-color);
padding: 12px 20px;
border-radius: 4px;
font-weight: bold;
box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
} #comercio-map:fullscreen {
width: 100vw;
height: 100vh;
z-index: 99999;
} .leaflet-popup-content-wrapper {
border-radius: 8px;
padding: 0; overflow: hidden;
box-shadow: 0 3px 14px rgba(0, 0, 0, 0.2);
}
.leaflet-popup-content {
margin: 0 !important; width: 260px !important; } .leaflet-container a.leaflet-popup-close-button {
color: #fff;
text-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
font-size: 22px;
padding: 8px 12px 0 0;
z-index: 10;
}
.leaflet-container a.leaflet-popup-close-button:hover {
color: #eee;
}
.leaflet-popup-content a {
font-weight: bold;
} .map-popup {
line-height: 1.5;
}
.map-popup-thumb {
width: 100%;
height: 130px; object-fit: cover; display: block;
}
.map-popup-content {
padding: 12px; }
.map-popup-title {
font-size: 16px; font-weight: 700;
margin-bottom: 6px;
line-height: 1.2;
}
.map-popup-title a {
color: var(--directorio-primary-color);
text-decoration: none;
}
.map-popup-category {
font-size: 12px; color: #666;
margin-bottom: 8px;
text-transform: uppercase;
letter-spacing: 0.5px;
font-weight: 600;
}
.map-popup-address {
font-size: 13px; color: #333;
margin-bottom: 12px;
padding: 5px;
}
.map-popup-actions {
display: flex;
gap: 8px;
margin-top: 12px; }
.map-popup-directions {
display: inline-block;
flex: 1;
background-color: var(--directorio-accent-color);
color: #ffffff !important; padding: 8px 5px;
border-radius: 4px;
font-size: 12px; font-weight: bold;
text-decoration: none;
text-align: center;
white-space: nowrap;
}
.map-popup-directions:hover {
color: #ffffff !important;
opacity: 0.9;
}
.map-popup-rating {
display: flex;
align-items: center;
gap: 5px;
margin-bottom: 8px;
}
.map-popup-rating .stars {
--star-size: 16px; }
.map-popup-rating .rating-text {
font-size: 12px;
color: #666;
} .map-emoji-icon {
background: none;
border: none;
} .custom-map-icon {
border-radius: 50%;
border: 2px solid var(--directorio-white);
box-shadow: 0 2px 5px rgba(0, 0, 0, 0.3);
} @media (max-width: 767px) {
.leaflet-popup-content {
width: 240px !important; }
.map-popup-thumb {
height: 110px; }
.map-popup-title {
font-size: 15px;
}
.map-popup-address {
font-size: 12px;
}
.map-popup-directions {
font-size: 11px;
}
.map-wrapper {
height: 350px; }
.map-container {
height: 100%;
}
.map-mobile-overlay {
display: flex;
}
} .leaflet-control-custom {
display: flex !important;
justify-content: center;
align-items: center;
cursor: pointer;
background-color: #fff; width: 30px;
height: 30px;
}
.leaflet-control-custom .geo-icon {
font-size: 20px;
line-height: 1;
width: 100%;
text-align: center;
} .button-show-similar {
width: 100%;
padding: 12px;
font-size: 15px;
font-weight: bold;
text-align: center;
cursor: pointer;
border: 1px solid var(--directorio-accent-color);
background-color: var(--directorio-white);
color: var(--directorio-accent-color);
border-radius: 4px;
transition: all 0.2s ease-in-out;
}
.button-show-similar:hover {
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
} .listing-tags-container {
margin-top: 30px;
padding-top: 20px;
border-top: 1px solid var(--directorio-border-color);
}
.tags-title {
font-weight: bold;
margin-right: 10px;
font-size: 16px;
}
.listing-tags-container a,
.tag-item {
display: inline-block;
background-color: #eee;
color: #555;
padding: 5px 12px;
margin: 0 5px 5px 0;
border-radius: 4px;
font-size: 14px;
text-decoration: none;
transition: all 0.2s;
}
.listing-tags-container a:hover {
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
} .listing-reviews-section {
margin-top: 40px;
padding-top: 40px;
border-top: 1px solid var(--directorio-border-color);
} .login-required-notice {
background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
border: 1px solid #bae6fd;
border-radius: 12px;
padding: 24px;
margin: 40px 0;
display: flex;
align-items: flex-start;
gap: 20px;
box-shadow: 0 4px 6px rgba(0, 90, 135, 0.05);
}
.login-notice-icon {
flex-shrink: 0;
width: 50px;
height: 50px;
background: var(--directorio-accent-color);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: var(--directorio-white);
font-size: 20px;
box-shadow: 0 4px 12px rgba(0, 90, 135, 0.3);
}
.login-notice-content {
flex: 1;
min-width: 0;
}
.login-notice-content h3 {
margin: 0 0 8px 0;
font-size: 18px;
font-weight: 700;
color: #111827;
line-height: 1.3;
}
.login-notice-content p {
margin: 0 0 16px 0;
color: #4b5563;
line-height: 1.5;
font-size: 14px;
}
.login-notice-actions {
display: flex;
flex-wrap: wrap;
gap: 12px;
}
.login-notice-actions .button {
padding: 10px 20px;
border-radius: 8px;
font-weight: 600;
text-decoration: none;
display: inline-flex;
align-items: center;
gap: 8px;
transition: all 0.2s ease;
font-size: 14px;
white-space: nowrap;
}
.login-notice-actions .login-btn {
background: var(--directorio-accent-color);
color: var(--directorio-white);
box-shadow: 0 2px 4px rgba(0, 90, 135, 0.2);
}
.login-notice-actions .login-btn:hover {
background: var(--directorio-primary-color);
transform: translateY(-1px);
box-shadow: 0 4px 8px rgba(0, 90, 135, 0.3);
}
.login-notice-actions .register-btn {
background: var(--directorio-white);
color: var(--directorio-accent-color);
border: 2px solid var(--directorio-accent-color);
}
.login-notice-actions .register-btn:hover {
background: var(--directorio-accent-color);
color: var(--directorio-white);
transform: translateY(-1px);
} @media (max-width: 768px) {
.login-required-notice {
padding: 20px;
gap: 16px;
flex-direction: column;
align-items: center;
text-align: center;
}
.login-notice-icon {
width: 44px;
height: 44px;
font-size: 18px;
}
.login-notice-content {
text-align: center;
}
.login-notice-content h3 {
font-size: 16px;
}
.login-notice-content p {
font-size: 13px;
}
.login-notice-actions {
justify-content: center;
}
.login-notice-actions .button {
padding: 10px 20px;
font-size: 14px;
min-width: 140px;
}
}
@media (max-width: 480px) {
.login-required-notice {
padding: 24px 20px;
gap: 16px;
margin: 30px 0;
}
.login-notice-icon {
width: 48px;
height: 48px;
font-size: 18px;
margin-bottom: 4px;
}
.login-notice-content h3 {
font-size: 16px;
margin-bottom: 8px;
padding: 0 10px;
}
.login-notice-content p {
font-size: 13px;
margin-bottom: 20px;
padding: 0 10px;
}
.login-notice-actions {
flex-direction: column;
gap: 12px;
width: 100%;
box-sizing: border-box;
padding: 0 10px;
}
.login-notice-actions .button {
justify-content: center;
width: 100%;
box-sizing: border-box;
padding: 12px 20px;
margin: 0;
}
} .logged-in-as {
display: flex;
align-items: center;
gap: 10px;
padding: 12px 16px;
background: #f9fafb;
border-radius: 8px;
margin-bottom: 20px;
font-size: 14px;
color: #374151;
}
.logged-in-as .avatar {
border-radius: 50%;
}
.logged-in-as a {
color: var(--directorio-accent-color);
text-decoration: none;
font-weight: 500;
}
.logged-in-as a:hover {
text-decoration: underline;
}
#respond {
background: var(--directorio-white);
border: 1px solid #e5e7eb;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.05);
padding: 30px;
border-radius: 12px;
}
#reply-title {
font-size: 22px;
margin-top: 0;
padding-bottom: 15px;
border-bottom: 2px solid var(--directorio-accent-color);
margin-bottom: 25px;
font-weight: 700;
color: #111827;
}
#respond label {
display: block;
margin-bottom: 8px;
font-weight: 600;
color: #374151;
}
#respond input[type="text"],
#respond input[type="email"],
#respond textarea {
width: 100%;
padding: 14px 2px;
border: 1px solid #d1d5db;
border-radius: 8px;
margin-bottom: 15px;
font-size: 15px;
transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
#respond input[type="text"]:focus,
#respond input[type="email"]:focus,
#respond textarea:focus {
outline: none;
border-color: var(--directorio-accent-color);
box-shadow: 0 0 0 3px rgba(0, 90, 135, 0.1);
}
#respond .form-submit .submit {
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
padding: 14px 32px;
font-size: 16px;
font-weight: 600;
border-radius: 8px;
cursor: pointer;
transition: all 0.2s ease;
box-shadow: 0 2px 4px rgba(0, 90, 135, 0.2);
}
#respond .form-submit .submit:hover {
background-color: var(--directorio-primary-color);
transform: translateY(-1px);
box-shadow: 0 4px 8px rgba(0, 90, 135, 0.3);
} .page-header {
margin-bottom: 40px;
border-bottom: 1px solid var(--directorio-border-color);
padding-bottom: 20px;
}
.page-title {
font-size: 36px;
}
.post-card {
background: var(--directorio-white);
border: 1px solid var(--directorio-border-color);
border-radius: 5px;
margin-bottom: 40px;
padding: 30px;
}
.entry-title {
margin-top: 0;
margin-bottom: 20px;
}
.entry-title a {
text-decoration: none;
color: var(--directorio-primary-color);
}
.post-thumbnail img {
width: 100%;
height: auto;
border-radius: 5px;
margin-bottom: 20px;
}
.entry-content p {
line-height: 1.7;
}
.entry-content a {
color: var(--directorio-primary-color);
} .single .entry-title,
.page .entry-title {
font-size: 42px;
} .single-listing-article .entry-title {
font-size: 26px; font-weight: 800; color: #1a202c; padding: 5px;
line-height: 1.1; letter-spacing: -1px; margin-bottom: 10px;
}
@media (min-width: 768px) {
.single-listing-article .entry-title {
font-size: 38px; }
}
.single .entry-content,
.page .entry-content {
max-width: 1500px; } .directory-search-form {
max-width: 600px;
margin: 0 auto;
display: flex;
border-radius: 5px;
overflow: hidden;
box-shadow: 0 5px 15px rgba(0, 0, 0, 0.1);
}
.directory-search-form .search-field {
width: 100%;
padding: 15px 20px;
font-size: 16px;
border: none;
outline: none;
}
.directory-search-form .search-submit {
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
padding: 0 30px;
cursor: pointer;
font-size: 16px;
font-weight: bold;
} .advanced-search-form {
max-width: 800px;
margin: 0 auto;
background: var(--directorio-white);
border-radius: 12px;
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
overflow: hidden;
}
.search-main-row {
display: flex;
gap: 10px;
padding: 20px;
border-bottom: 1px solid #f0f0f0;
}
.search-input-group {
flex: 1;
}
.search-label {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 8px;
font-size: 14px;
font-weight: 600;
color: #555;
}
.search-label i {
color: var(--directorio-accent-color);
}
.search-field {
width: 100%;
padding: 14px 16px;
font-size: 16px;
border: 2px solid #e0e0e0;
border-radius: 8px;
outline: none;
transition: border-color 0.3s ease;
}
.search-field:focus {
border-color: var(--directorio-accent-color);
}
.search-submit-btn {
display: flex;
align-items: center;
gap: 8px;
padding: 14px 24px;
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
border-radius: 8px;
font-size: 16px;
font-weight: 600;
cursor: pointer;
transition: background-color 0.3s ease;
white-space: nowrap;
}
.search-submit-btn:hover {
background-color: #004a70;
}
.search-filters-toggle {
padding: 0 20px 20px;
text-align: center;
}
.filters-toggle-btn {
display: inline-flex;
align-items: center;
gap: 8px;
padding: 10px 16px;
background: transparent;
color: var(--directorio-accent-color);
border: 2px solid var(--directorio-accent-color);
border-radius: 6px;
font-size: 14px;
font-weight: 600;
cursor: pointer;
transition: all 0.3s ease;
}
.filters-toggle-btn:hover {
background: var(--directorio-accent-color);
color: var(--directorio-white);
}
.search-filters-container {
padding: 0 20px;
max-height: 0;
overflow: hidden;
transition: max-height 0.5s ease, padding 0.5s ease;
}
.search-filters-container.active {
padding: 20px;
max-height: 1000px;
}
.filters-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 24px;
margin-bottom: 24px;
}
.filter-group {
display: flex;
flex-direction: column;
}
.filter-label {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 8px;
font-size: 14px;
font-weight: 600;
color: #555;
}
.filter-label i {
color: var(--directorio-accent-color);
}
.filter-select {
width: 100%;
padding: 12px 16px;
font-size: 15px;
border: 2px solid #e0e0e0;
border-radius: 8px;
background-color: var(--directorio-white);
outline: none;
transition: border-color 0.3s ease;
cursor: pointer;
}
.filter-select:focus {
border-color: var(--directorio-accent-color);
}
.rating-filter {
margin-top: 4px;
}
.rating-stars-select {
display: flex;
flex-direction: column;
gap: 8px;
}
.rating-option {
display: flex;
align-items: center;
}
.rating-option input[type="radio"] {
display: none;
}
.rating-option label {
display: flex;
align-items: center;
gap: 10px;
padding: 8px 12px;
border-radius: 6px;
cursor: pointer;
transition: background-color 0.2s ease;
flex: 1;
}
.rating-option label:hover {
background-color: #f5f5f5;
}
.rating-option input[type="radio"]:checked+label {
background-color: rgba(0, 90, 135, 0.1);
border: 1px solid var(--directorio-accent-color);
}
.stars-display {
display: flex;
gap: 2px;
}
.star {
color: #ddd;
font-size: 16px;
}
.star.filled {
color: #ffc107;
}
.rating-text {
font-size: 14px;
color: #555;
}
.filters-actions {
display: flex;
justify-content: flex-end;
gap: 12px;
margin-bottom: 24px;
}
.filter-btn {
display: flex;
align-items: center;
gap: 8px;
padding: 10px 20px;
border: none;
border-radius: 6px;
font-size: 14px;
font-weight: 600;
cursor: pointer;
transition: all 0.3s ease;
}
.clear-filters {
background: #f5f5f5;
color: #666;
}
.clear-filters:hover {
background: #e0e0e0;
}
.apply-filters {
background: var(--directorio-accent-color);
color: var(--directorio-white);
}
.apply-filters:hover {
background: #004a70;
}
.search-tips {
background: #f8f9fa;
border-radius: 8px;
padding: 16px;
border-left: 4px solid var(--directorio-accent-color);
}
.tip-header {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 12px;
color: var(--directorio-accent-color);
font-size: 15px;
}
.tip-list {
margin: 0;
padding-left: 20px;
}
.tip-list li {
margin-bottom: 6px;
font-size: 14px;
color: #666;
line-height: 1.5;
} @media (max-width: 768px) {
.search-main-row {
flex-direction: column;
gap: 12px;
}
.search-submit-btn {
justify-content: center;
}
.filters-grid {
grid-template-columns: 1fr;
gap: 20px;
}
.filters-actions {
flex-direction: column;
}
.filter-btn {
justify-content: center;
}
}
@media (max-width: 480px) {
.search-main-row {
padding: 16px;
}
.search-filters-container.active {
padding: 16px;
}
.filter-select {
padding: 10px 14px;
}
.rating-option label {
padding: 6px 10px;
}
} .form-field.term-icon-wrap .button {
vertical-align: middle;
margin-left: 10px;
}
.form-field.term-icon-wrap .icon-preview-wrapper {
width: 64px;
height: 64px;
border: 1px dashed #ddd;
display: inline-block;
vertical-align: middle;
background-color: #f7f7f7;
border-radius: 4px;
padding: 2px;
}
.form-field.term-icon-wrap .icon-preview {
width: 100%;
height: 100%;
} .directorio-form-wrapper {
max-width: 600px;
margin: 40px auto;
padding: 30px;
background: var(--directorio-white);
border: 1px solid var(--directorio-border-color);
border-radius: 5px;
box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}
.directorio-form-wrapper h3 {
margin-top: 0;
color: var(--directorio-primary-color);
}
.directorio-form-wrapper label {
display: block;
font-weight: bold;
margin-bottom: 8px;
}
.directorio-form-wrapper input[type="text"],
.directorio-form-wrapper input[type="email"],
.directorio-form-wrapper textarea {
width: 100%;
padding: 12px;
border: 1px solid var(--directorio-border-color);
border-radius: 4px;
margin-bottom: 15px;
}
.directorio-form-wrapper .button {
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
padding: 12px 30px;
font-size: 16px;
border-radius: 4px;
cursor: pointer;
transition: background-color 0.2s;
}
.directorio-form-wrapper .button:hover {
background-color: var(--directorio-primary-color);
} .directorio-message {
padding: 15px;
margin-bottom: 20px;
border-radius: 4px;
border: 1px solid;
}
.directorio-message.success {
background-color: #d4edda;
border-color: #c3e6cb;
color: #155724;
}
.directorio-message.error {
background-color: #f8d7da;
border-color: #f5c6cb;
color: #721c24;
} .directorio-private-key-notice {
border: 2px dashed var(--directorio-accent-color);
background-color: var(--directorio-secondary-color);
padding: 20px;
margin: 40px auto;
max-width: 600px;
text-align: center;
}
.directorio-private-key-notice .private-key {
background-color: var(--directorio-white);
padding: 15px;
border: 1px solid var(--directorio-border-color);
word-break: break-all;
font-family: monospace;
font-size: 16px;
margin-bottom: 20px;
} .directorio-dashboard {
background: var(--directorio-white);
border: 1px solid var(--directorio-border-color);
padding: 30px;
margin-top: 30px;
border-radius: 5px;
}
.directorio-dashboard h2 {
margin-top: 0;
}
.directorio-dashboard-actions {
margin: 20px 0;
display: flex;
gap: 15px;
align-items: center;
}
.directorio-dashboard-actions .button {
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
padding: 10px 20px;
border-radius: 4px;
text-decoration: none;
}
.directorio-dashboard-list {
list-style: none;
padding: 0;
margin-top: 20px;
}
.directorio-dashboard-list-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 15px;
border-bottom: 1px solid var(--directorio-border-color);
}
.directorio-dashboard-list-item:last-child {
border-bottom: none;
}
.directorio-dashboard-list-item .item-title {
font-weight: bold;
}
.directorio-dashboard-list-item .item-actions a {
margin: 0 5px;
}
.directorio-dashboard-list-item .item-actions a.delete {
color: #a00;
}
.directorio-form-wrapper .form-footer-link {
margin-top: 20px;
text-align: center;
font-size: 14px;
} .recovery-phrase-notice {
border-color: #ffc107;
margin-top: 20px;
}
.recovery-phrase-notice .recovery-phrase {
color: #856404;
background-color: #fff3cd;
border-color: #ffeeba;
font-size: 18px;
letter-spacing: 1px;
} .recovery-phrase-inputs {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 15px;
margin-bottom: 20px;
}
@media (min-width: 768px) {
.recovery-phrase-inputs {
grid-template-columns: repeat(3, 1fr);
}
}
.recovery-phrase-inputs .word-input {
display: flex;
align-items: center;
}
.recovery-phrase-inputs .word-input label {
font-weight: normal;
margin-bottom: 0;
margin-right: 10px;
color: #666;
}
.recovery-phrase-inputs .word-input input {
margin-bottom: 0;
}  .average-rating-display {
display: flex;
align-items: center;
gap: 10px;
margin: 10px 0 20px;
}
.average-rating-display .rating-text {
font-size: 15px;
color: #555;
} .stars {
--star-size: 24px;
--star-color: #ccc;
--star-background: #3483fa;
display: inline-block;
font-size: var(--star-size);
font-family: Times; line-height: 1;
}
.stars::before {
content: '\2605\2605\2605\2605\2605';
letter-spacing: 3px;
background: linear-gradient(90deg, var(--star-background) calc(var(--rating) / 5 * 100%), var(--star-color) calc(var(--rating) / 5 * 100%));
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
} .listing-reviews-section .comment-list {
list-style: none;
padding: 0;
margin: 40px 0;
}
.review-item {
display: flex;
gap: 20px;
background: var(--directorio-white);
border: 1px solid #e5e7eb;
border-radius: 12px;
padding: 24px;
margin-bottom: 20px;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
transition: all 0.2s ease;
}
.review-item:hover {
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
transform: translateY(-1px);
}
.review-author {
flex-shrink: 0;
}
.review-author .avatar {
border-radius: 50%;
border: 2px solid #e5e7eb;
transition: border-color 0.2s ease;
}
.review-item:hover .review-author .avatar {
border-color: var(--directorio-accent-color);
}
.review-content-main {
flex-grow: 1;
}
.review-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 8px;
flex-wrap: wrap;
gap: 12px;
}
.review-header .fn {
font-size: 18px;
font-weight: 700;
color: #111827;
letter-spacing: 0.2px;
}
.review-header .review-rating .stars {
--star-size: 20px;
}
.comment-metadata {
font-size: 13px;
color: #6b7280;
margin-bottom: 16px;
}
.comment-content {
line-height: 1.7;
color: #374151;
}
.comment-awaiting-moderation {
background: #fef3c7;
border: 1px solid #f59e0b;
padding: 12px;
border-radius: 8px;
margin: 12px 0;
font-size: 14px;
color: #92400e;
font-weight: 500;
} .review-actions {
margin-top: 16px;
display: flex;
gap: 10px;
}
.review-actions button {
background: #f3f4f6;
border: 1px solid #d1d5db;
padding: 8px 14px;
font-size: 13px;
border-radius: 8px;
cursor: pointer;
font-weight: 600;
transition: all 0.2s ease;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.review-actions button:hover {
background: #e5e7eb;
transform: translateY(-1px);
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}
.review-actions button.delete-review-btn {
color: #ef4444;
border-color: #fecaca;
background: #fef2f2;
}
.review-actions button.delete-review-btn:hover {
background: #fee2e2;
color: #b91c1c;
} .comment-form-rating {
margin-bottom: 20px;
}
.comment-form-rating>label {
display: block;
margin-bottom: 10px;
font-weight: 600;
color: #374151;
}
.rating-stars {
display: inline-flex;
flex-direction: row-reverse; justify-content: flex-end; border: none;
font-size: 0; }
.rating-stars input {
display: none;
}
.rating-stars label {
font-size: 30px;
color: #ccc;
cursor: pointer;
display: inline-block !important; width: auto;
font-weight: normal; margin-bottom: 0; transition: all 0.2s ease;
padding: 0 2px;
}
.rating-stars label::before {
content: '\2605';
} .rating-stars label:hover,
.rating-stars label.hover,
.rating-stars label:hover~label,
.rating-stars label.hover~label,
.rating-stars input:checked+label,
.rating-stars input:checked~label {
color: #3483fa !important; transform: scale(1.1);
} .comment-form-rating .rating-stars,
.review-edit-form .rating-stars {
flex-direction: row-reverse !important;
} .review-edit-form {
margin-top: 15px;
}
.review-edit-form textarea {
width: 100%;
min-height: 120px;
padding: 14px 16px;
border: 1px solid #d1d5db;
border-radius: 8px;
display: block;
font-size: 15px;
transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.review-edit-form textarea:focus {
outline: none;
border-color: var(--directorio-accent-color);
box-shadow: 0 0 0 3px rgba(0, 90, 135, 0.1);
}
.review-edit-form .comment-form-rating {
margin-top: 10px;
}
.review-edit-actions {
margin-top: 15px;
display: flex;
align-items: center;
gap: 10px;
}
.review-edit-actions .spinner {
background: url(//directoriolatinoamerica.com/wp-admin/images/spinner.gif) no-repeat;
background-size: 20px 20px;
display: inline-block;
opacity: 0;
width: 20px;
height: 20px;
margin: 0 5px 0 0;
vertical-align: middle;
transition: opacity .25s;
}
.review-edit-actions .spinner.is-active {
opacity: 1;
}
.edit-form-message {
margin-top: 10px;
padding: 10px;
border-radius: 4px;
display: none;
}
.edit-form-message.error {
background-color: #f8d7da;
border: 1px solid #f5c6cb;
color: #721c24;
}
.review-edit-actions .cancel-edit-btn {
background-color: #f3f4f6;
border: 1px solid #d1d5db;
color: #374151;
text-decoration: none;
cursor: pointer;
font-weight: 600;
padding: 10px 20px;
border-radius: 4px;
transition: all 0.2s ease;
font-size: 14px;
}
.review-edit-actions .cancel-edit-btn:hover {
background-color: #e5e7eb;
color: #111827;
border-color: #9ca3af;
transform: translateY(-1px);
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}
.review-edit-actions .save-review-btn {
background-color: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
padding: 10px 20px;
border-radius: 4px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s ease;
text-decoration: none;
display: inline-block;
}
.review-edit-actions .save-review-btn:hover {
background-color: #004a70;
transform: translateY(-1px);
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
.review-edit-actions .save-review-btn:active {
transform: translate3d(0, 0.1px, 0);
box-shadow: none;
}
.review-edit-actions .save-review-btn:disabled {
background-color: #ccc;
cursor: not-allowed;
transform: none;
box-shadow: none;
} @media (max-width: 768px) { .review-item {
flex-direction: column;
gap: 15px;
padding: 20px;
}
.review-author {
display: flex;
align-items: center;
gap: 15px;
}
.review-author .avatar {
width: 50px;
height: 50px;
}
.review-header {
flex-direction: column;
align-items: flex-start;
gap: 8px;
}
.review-header .fn {
font-size: 16px;
}
.review-header .review-rating .stars {
--star-size: 18px;
} .review-actions {
flex-wrap: wrap;
gap: 8px;
}
.review-actions button {
padding: 10px 16px;
font-size: 14px;
flex: 1;
min-width: 120px;
text-align: center;
} #respond {
padding: 20px;
}
#reply-title {
font-size: 18px;
} .review-edit-form textarea {
min-height: 100px;
padding: 12px;
font-size: 14px;
}
.review-edit-actions {
flex-direction: column;
gap: 12px;
align-items: stretch;
}
.review-edit-actions .save-review-btn,
.review-edit-actions .cancel-edit-btn {
width: 100%;
text-align: center;
padding: 12px;
font-size: 15px;
} .review-edit-actions .cancel-edit-btn {
background-color: #f5f5f5;
border: 1px solid #ddd;
color: #555;
text-decoration: none;
font-weight: 600;
}
.review-edit-actions .cancel-edit-btn:hover {
background-color: #e5e5e5;
color: #333;
} .rating-stars label {
font-size: 24px;
}
.comment-form-rating>label {
font-size: 14px;
}
}
@media (max-width: 480px) { .review-item {
padding: 16px;
}
.review-actions button {
min-width: 100px;
font-size: 13px;
padding: 8px 12px;
}
.review-edit-form textarea {
min-height: 80px;
}
.rating-stars label {
font-size: 20px;
} .review-edit-actions .save-review-btn,
.review-edit-actions .cancel-edit-btn {
padding: 14px;
font-size: 16px;
}
} .similar-comercios-section {
margin: 60px 0;
padding: 40px 0;
background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
border-radius: 20px;
}
.section-header {
text-align: center;
margin-bottom: 40px;
}
.section-title {
font-size: 32px;
font-weight: 800;
color: #111827;
margin-bottom: 12px;
letter-spacing: -0.5px;
} .real-time-search-container {
margin: 40px auto;
padding: 0 20px;
max-width: 1400px;
}
.search-layout {
display: grid;
grid-template-columns: 260px 1fr;
gap: 20px;
align-items: start;
} .search-sidebar {
background: var(--directorio-white);
border-radius: 12px;
padding: 16px;
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
position: sticky;
top: 90px;
height: auto;
overflow-y: visible;
}
.sidebar-header {
margin-bottom: 15px;
padding-bottom: 10px;
border-bottom: 1px solid #e5e7eb;
}
.sidebar-header h2 {
font-size: 16px;
font-weight: 600;
color: #111827;
margin: 0;
display: flex;
align-items: center;
gap: 8px;
}
.sidebar-header h2 i {
color: var(--directorio-accent-color);
font-size: 14px;
}
.sidebar-subtitle {
font-size: 12px;
color: #6b7280;
margin: 4px 0 0 0;
} .filter-section {
margin-bottom: 1px;
padding-bottom: 1px;
border-bottom: 1px solid #f0f0f0;
}
.filter-section:last-child {
border-bottom: none;
margin-bottom: 0;
padding-bottom: 0;
} .rt-searchable-select-container {
position: relative;
width: 100%;
box-sizing: border-box;
z-index: 10;
}
.rt-searchable-select-container.is-open {
z-index: 1001; }
.rt-searchable-input {
width: 100% !important;
padding: 12px 40px 12px 16px !important;
border: 2px solid #e5e7eb !important;
border-radius: 10px !important;
background-color: #fff !important;
box-sizing: border-box !important;
font-size: 15px !important;
cursor: text;
transition: all 0.2s ease;
}
.rt-searchable-select-container i.toggle-icon {
position: absolute;
right: 15px;
top: 50%;
transform: translateY(-50%);
color: #6b7280;
pointer-events: none;
transition: transform 0.2s ease;
}
.rt-searchable-select-container.is-open i.toggle-icon {
transform: translateY(-50%) rotate(180deg);
}
.rt-searchable-list {
position: absolute;
top: 100%;
left: 0;
right: 0;
background: white;
border-radius: 10px;
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
margin-top: 5px;
max-height: 250px;
overflow-y: auto;
z-index: 999;
display: none;
padding: 5px 0;
border: 1px solid #e5e7eb;
box-sizing: border-box;
}
.rt-searchable-option {
padding: 10px 16px;
cursor: pointer;
font-size: 14px;
transition: background 0.2s;
}
.rt-searchable-option:hover,
.rt-searchable-option.selected {
background: #f3f4f6;
color: var(--directorio-accent-color);
}
.rt-searchable-option.hidden {
display: none;
}
.filter-section-title {
font-size: 14px;
font-weight: 600;
color: #374151;
margin: 0 0 12px 0;
display: flex;
align-items: center;
gap: 8px;
}
.filter-section-title i {
color: var(--directorio-accent-color);
font-size: 12px;
}
.filter-group {
margin-bottom: 12px;
}
.filter-label {
display: block;
font-size: 13px;
font-weight: 500;
color: #4b5563;
margin-bottom: 6px;
} .search-input-with-icon {
position: relative;
}
.search-input-with-icon i {
position: absolute;
left: 14px;
top: 50%;
transform: translateY(-50%);
color: #9ca3af;
font-size: 16px;
}
.rt-search-field {
width: 80%;
width: 100%; padding: 12px 1px 12px 42px;
font-size: 15px;
border: 2px solid #e5e7eb;
border-radius: 10px;
background: var(--directorio-white);
box-sizing: border-box;
transition: all 0.2s ease;
}
.rt-search-field:focus {
outline: none;
border-color: var(--directorio-accent-color);
box-shadow: 0 0 0 3px rgba(0, 90, 135, 0.1);
} .rt-filter-select {
width: 100%;
padding: 12px 16px;
font-size: 15px;
border: 2px solid #e5e7eb;
border-radius: 10px;
background: var(--directorio-white);
cursor: pointer;
transition: all 0.2s ease;
appearance: none;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%236b7280'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");
background-repeat: no-repeat;
background-position: right 12px center;
background-size: 20px;
}
.rt-filter-select:focus {
outline: none;
border-color: var(--directorio-accent-color);
box-shadow: 0 0 0 3px rgba(0, 90, 135, 0.1);
} .rating-filter-grid {
display: grid;
grid-template-columns: 1fr;
gap: 10px;
}
.rating-option-card {
position: relative;
}
.rating-option-card input[type="radio"] {
position: absolute;
opacity: 0;
width: 0;
height: 0;
}
.rating-option-card label {
display: flex;
align-items: center;
gap: 12px;
padding: 12px 16px;
border: 2px solid #e5e7eb;
border-radius: 10px;
background: var(--directorio-white);
cursor: pointer;
transition: all 0.2s ease;
}
.rating-option-card:hover label {
border-color: #d1d5db;
background: #f9fafb;
}
.rating-option-card.active label {
border-color: var(--directorio-accent-color) !important;
background: rgba(0, 90, 135, 0.08) !important;
transform: scale(1.03) !important;
box-shadow: 0 0 0 4px rgba(0, 90, 135, 0.15) !important;
transition: all 100ms ease !important;
}
.rating-option-card input[type="radio"]:checked+label { }
.rating-stars {
display: flex;
flex-direction: row !important;
gap: 2px;
}
.rating-stars .star {
color: #e5e7eb;
font-size: 16px;
}
.rating-stars .star.filled {
color: #3483fa;
}
.rating-label {
font-size: 14px;
font-weight: 500;
color: #374151;
}
.rating-option-all {
display: flex;
align-items: center;
gap: 10px;
color: #6b7280;
}
.rating-option-all i {
font-size: 16px;
} .filter-actions {
display: flex;
gap: 12px;
margin-top: 24px;
}
.filter-action-btn {
flex: 1;
display: flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 12px 16px;
font-size: 14px;
font-weight: 600;
border: none;
border-radius: 10px;
cursor: pointer;
transition: all 0.2s ease;
}
.clear-all-filters {
background: #f3f4f6;
color: #6b7280;
}
.clear-all-filters:hover {
background: #e5e7eb;
color: #374151;
}
.apply-filters {
background: var(--directorio-accent-color);
color: var(--directorio-white);
}
.apply-filters:hover {
background: #004a70;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(0, 90, 135, 0.2);
} .search-tips {
margin-top: 24px;
padding: 16px;
background: #f8fafc;
border-radius: 10px;
border-left: 4px solid var(--directorio-accent-color);
}
.tips-header {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 12px;
font-size: 14px;
color: var(--directorio-accent-color);
font-weight: 600;
}
.tips-list {
margin: 0;
padding-left: 20px;
}
.tips-list li {
font-size: 13px;
color: #6b7280;
margin-bottom: 6px;
line-height: 1.5;
} .search-results {
background: var(--directorio-white);
border-radius: 16px;
padding: 24px;
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
.results-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 24px;
padding-bottom: 20px;
border-bottom: 2px solid #f0f0f0;
}
.results-title-section {
display: flex;
align-items: center;
gap: 16px;
}
.results-title-section h2 {
font-size: 20px;
font-weight: 700;
color: #111827;
margin: 0;
display: flex;
align-items: center;
gap: 10px;
}
.results-title-section h2 i {
color: var(--directorio-accent-color);
}
.results-count {
font-size: 14px;
font-weight: 600;
color: var(--directorio-accent-color);
background: rgba(0, 90, 135, 0.1);
padding: 6px 12px;
border-radius: 20px;
}
.results-controls {
display: flex;
align-items: center;
gap: 20px;
}
.sort-controls {
display: flex;
align-items: center;
gap: 10px;
}
.sort-controls label {
font-size: 14px;
font-weight: 500;
color: #6b7280;
}
.sort-select {
padding: 8px 12px;
font-size: 14px;
border: 2px solid #e5e7eb;
border-radius: 8px;
background: var(--directorio-white);
cursor: pointer;
transition: all 0.2s ease;
}
.sort-select:focus {
outline: none;
border-color: var(--directorio-accent-color);
}
.view-toggle {
display: flex;
gap: 8px;
}
.view-btn {
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
border: 2px solid #e5e7eb;
background: var(--directorio-white);
border-radius: 8px;
cursor: pointer;
transition: all 0.2s ease;
color: #6b7280;
}
.view-btn:hover {
border-color: #d1d5db;
background: #f9fafb;
}
.view-btn.active {
border-color: var(--directorio-accent-color);
background: rgba(0, 90, 135, 0.1);
color: var(--directorio-accent-color);
} .results-container {
min-height: 400px;
position: relative;
}
.loading-results {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
z-index: 10;
}
.loading-spinner {
font-size: 32px;
color: var(--directorio-accent-color);
margin-bottom: 16px;
}
.loading-results p {
font-size: 16px;
color: #6b7280;
font-weight: 500;
}
.no-results {
text-align: center;
padding: 60px 20px;
}
.no-results-icon {
font-size: 48px;
color: #d1d5db;
margin-bottom: 20px;
}
.no-results h3 {
font-size: 20px;
font-weight: 600;
color: #374151;
margin-bottom: 12px;
}
.no-results p {
font-size: 16px;
color: #6b7280;
margin-bottom: 24px;
}
.btn-clear-all {
padding: 12px 24px;
font-size: 14px;
font-weight: 600;
background: var(--directorio-accent-color);
color: var(--directorio-white);
border: none;
border-radius: 8px;
cursor: pointer;
transition: all 0.2s ease;
}
.btn-clear-all:hover {
background: #004a70;
transform: translateY(-1px);
} .results-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
gap: 16px;
}
.results-grid.list-view {
grid-template-columns: 1fr;
}
.result-card {
background: var(--directorio-white);
border: 1px solid #e5e7eb;
border-radius: 8px;
overflow: hidden;
transition: all 0.3s ease;
cursor: pointer;
position: relative;
display: block;
text-decoration: none;
color: inherit;
}
.result-card:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
border-color: var(--directorio-accent-color);
}
.result-card.list-view {
display: flex;
}
.result-image {
height: 140px;
overflow: hidden;
position: relative;
}
.result-card.list-view .result-image {
width: 160px;
height: auto;
flex-shrink: 0;
}
.result-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.5s ease;
}
.result-card:hover .result-image img {
transform: scale(1.05);
}
.result-content {
padding: 12px;
}
.result-category {
margin-bottom: 8px;
}
.category-tag {
display: inline-block;
padding: 4px 8px;
font-size: 10px;
font-weight: 700;
background: rgba(0, 90, 135, 0.1);
color: var(--directorio-accent-color);
border-radius: 4px;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.result-meta {
display: flex;
flex-direction: column;
gap: 8px;
}
.result-location {
display: flex;
align-items: center;
gap: 6px;
font-size: 12px;
color: #6b7280;
}
.result-location i {
color: var(--directorio-accent-color);
font-size: 12px;
}
.result-rating {
display: flex;
align-items: center;
gap: 6px;
}
.result-rating .stars {
display: flex;
flex-direction: row !important;
--star-size: 14px;
--star-background: var(--directorio-accent-color);
}
.rating-value {
font-size: 12px;
font-weight: 600;
color: var(--directorio-accent-color);
} .result-title {
font-size: 14px;
font-weight: 700;
color: #111827;
margin-bottom: 8px;
line-height: 1.3;
display: block;
}
.result-title a {
color: inherit;
text-decoration: none;
transition: color 0.2s ease;
}
.result-title a:hover {
color: var(--directorio-accent-color);
} .result-excerpt,
.result-distance {
display: none;
}
.result-actions {
display: flex;
align-items: center;
justify-content: space-between;
padding: 8px 0 0 0;
margin-top: 8px;
border-top: 1px solid #f0f0f0;
}
.result-actions .result-visits {
display: flex;
align-items: center;
gap: 4px;
color: #e91e63;
font-size: 12px;
font-weight: 500;
}
.result-actions .result-visits i {
font-size: 12px;
animation: heartbeat 2s ease-in-out infinite;
}
.result-rating-footer {
display: flex;
align-items: center;
gap: 6px;
}
.result-rating-footer .stars {
--star-size: 14px;
--star-background: #3483fa;
}
.result-rating-footer .rating-value {
font-size: 12px;
font-weight: 600;
color: #3483fa;
} .load-more-container {
text-align: center;
margin-top: 40px;
padding-top: 30px;
border-top: 1px solid #e5e7eb;
}
.btn-load-more {
display: inline-flex;
align-items: center;
gap: 10px;
padding: 14px 28px;
background: var(--directorio-white);
color: var(--directorio-accent-color);
border: 2px solid var(--directorio-accent-color);
border-radius: 10px;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: all 0.3s ease;
}
.btn-load-more:hover {
background: var(--directorio-accent-color);
color: var(--directorio-white);
transform: translateY(-2px);
box-shadow: 0 6px 20px rgba(0, 90, 135, 0.2);
}
.btn-load-more:disabled {
opacity: 0.5;
cursor: not-allowed;
transform: none;
}
.btn-load-more:disabled:hover {
background: var(--directorio-white);
color: var(--directorio-accent-color);
box-shadow: none;
} .mobile-top-search-bar {
display: none;
gap: 12px;
align-items: center;
margin-bottom: 16px;
padding: 0;
} .mobile-search-bar {
display: none;
}
.mobile-search-input-wrapper {
flex: 1;
position: relative;
}
.mobile-search-input-wrapper i {
position: absolute;
left: 16px;
top: 50%;
transform: translateY(-50%);
color: #9ca3af;
font-size: 18px;
}
#mobile-search-input {
width: 100%;
padding: 14px 16px 14px 48px;
background: white;
border: none;
border-radius: 50px;
font-size: 15px;
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}
#mobile-search-input:focus {
outline: none;
box-shadow: 0 4px 20px rgba(0, 90, 135, 0.25);
}
.btn-mobile-filters {
display: flex;
align-items: center;
justify-content: center;
gap: 6px;
padding: 12px;
background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
color: var(--directorio-accent-color);
border: 2px solid #e2e8f0;
border-radius: 12px;
width: 48px;
height: 48px;
font-size: 18px;
font-weight: 600;
cursor: pointer;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
position: relative;
flex-shrink: 0;
}
.btn-mobile-filters:hover,
.btn-mobile-filters:active {
background: var(--directorio-accent-color);
color: var(--directorio-white);
border-color: var(--directorio-accent-color);
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(0, 90, 135, 0.25);
}
.btn-mobile-filters:active {
transform: translate3d(0, 0.1px, 0);
box-shadow: 0 2px 6px rgba(0, 90, 135, 0.15);
}
.filter-count {
background: transparent;
color: inherit;
font-size: 15px;
font-weight: 700;
margin-left: 2px;
display: inline-block;
} .mobile-filters-overlay {
position: fixed;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.6);
z-index: 1000;
opacity: 0;
visibility: hidden;
transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
display: flex;
align-items: flex-end;
justify-content: center;
}
.mobile-filters-overlay.active {
opacity: 1;
visibility: visible;
}
.mobile-filters-overlay.active .mobile-filters-modal {
transform: translate3d(0, 0.1px, 0);
}
.mobile-filters-modal {
width: 100%;
max-height: 85vh;
background: var(--directorio-white);
border-radius: 20px 20px 0 0;
transform: translateY(100%);
transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
display: flex;
flex-direction: column;
box-shadow: 0 -10px 40px rgba(0, 0, 0, 0.15);
}
.mobile-filters-drag-indicator {
width: 40px;
height: 4px;
background: #d1d5db;
border-radius: 2px;
margin: 12px auto 8px auto;
}
.mobile-filters-header {
background: var(--directorio-white);
padding: 12px 16px 16px 16px;
display: flex;
justify-content: space-between;
align-items: center;
border-bottom: 1px solid #f3f4f6;
}
.mobile-filters-header h3 {
margin: 0;
font-size: 17px;
font-weight: 700;
color: #111827;
display: flex;
align-items: center;
gap: 8px;
}
.close-mobile-filters {
background: #f3f4f6;
border: none;
font-size: 20px;
color: #4b5563;
cursor: pointer;
width: 36px;
height: 36px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
transition: all 0.2s ease;
padding: 0;
}
.close-mobile-filters:hover {
background: #e5e7eb;
color: var(--directorio-accent-color);
transform: rotate(90deg);
}
.mobile-filters-content {
flex: 1;
background: var(--directorio-white);
overflow-y: auto;
padding: 16px;
-webkit-overflow-scrolling: touch;
}
.mobile-filters-content .filter-section {
margin-bottom: 16px;
}
.mobile-filters-content .filter-group {
margin-bottom: 0;
}
.mobile-filters-content .filter-label {
font-size: 14px;
margin-bottom: 8px;
}
.mobile-filters-content .rt-search-field,
.mobile-filters-content .rt-filter-select {
font-size: 15px;
min-height: 20px;
}
.mobile-filters-content .rating-filter-grid {
gap: 8px;
}
.mobile-filters-content .rating-option-card {
padding: 8px;
}
.mobile-filters-content .filter-actions {
position: sticky;
bottom: 0;
background: white;
padding: 12px 0 16px 0;
margin-top: 8px;
display: flex;
gap: 12px;
}
.mobile-filters-content .filter-action-btn {
flex: 1;
padding: 12px;
font-size: 15px;
} .mobile-filters-content .rt-search-field,
.mobile-filters-content .search-input-with-icon,
.mobile-filters-content .filter-group:has(#rt-search-name) {
display: none !important;
} .mobile-filters-content .filter-section,
.mobile-filters-content .filter-group {
display: block !important;
} @media (max-width: 1024px) {
.search-layout {
grid-template-columns: 220px 1fr;
gap: 20px;
}
.results-grid {
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}
}
@media (max-width: 768px) {
.search-layout {
grid-template-columns: 1fr;
gap: 0;
}
.search-sidebar {
display: none;
}
.mobile-top-search-bar {
display: flex;
}
.results-header {
flex-direction: column;
align-items: flex-start;
gap: 16px;
}
.results-controls {
width: 100%;
justify-content: space-between;
}
.results-grid {
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
}
.result-card.list-view {
flex-direction: column;
}
.result-card.list-view .result-image {
width: 100%;
height: 180px;
}
}
@media (max-width: 480px) {
.real-time-search-container {
padding: 0 16px;
}
.search-results {
padding: 20px;
}
.results-grid {
grid-template-columns: 1fr;
gap: 20px;
}
.results-title-section {
flex-direction: column;
align-items: flex-start;
gap: 8px;
}
.results-controls {
flex-direction: column;
align-items: stretch;
gap: 16px;
}
.sort-controls {
flex-direction: column;
align-items: flex-start;
}
.view-toggle {
align-self: flex-start;
}
.btn-mobile-filters {
padding: 12px 18px;
font-size: 14px;
}
} @keyframes fadeInUp {
from {
opacity: 0;
transform: translateY(20px);
}
to {
opacity: 1;
transform: translate3d(0, 0.1px, 0);
}
}
.result-card {
animation: fadeInUp 0.4s ease;
} .loading-results {
animation: pulse 1.5s infinite;
}
@keyframes pulse {
0% {
opacity: 0.6;
}
50% {
opacity: 1;
}
100% {
opacity: 0.6;
}
} .rt-search-field,
.rt-filter-select,
.filter-action-btn,
.view-btn,
.sort-select,
.btn-view-details,
.btn-load-more,
.btn-mobile-filters {
transition: all 0.2s ease;
} .rt-search-field:focus,
.rt-filter-select:focus,
.filter-action-btn:focus,
.view-btn:focus,
.sort-select:focus,
.btn-view-details:focus,
.btn-load-more:focus,
.btn-mobile-filters:focus {
outline: 2px solid var(--directorio-accent-color);
outline-offset: 2px;
} .rt-search-field.error,
.rt-filter-select.error {
border-color: #ef4444;
}
.error-message {
color: #ef4444;
font-size: 13px;
margin-top: 4px;
display: none;
}
.error-message.show {
display: block;
} .success-message {
color: #10b981;
font-size: 13px;
margin-top: 4px;
display: none;
}
.success-message.show {
display: block;
}
.section-subtitle {
font-size: 16px;
color: #6b7280;
max-width: 600px;
margin: 0 auto;
line-height: 1.6;
}
.similar-comercios-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(350px, 1fr));
gap: 30px;
margin-bottom: 40px;
}
.similar-comercio-card {
background: var(--directorio-white);
border-radius: 16px;
overflow: hidden;
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
transition: all 0.3s ease;
display: flex;
flex-direction: column;
height: 100%;
}
.similar-comercio-card:hover {
transform: translateY(-8px);
box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}
.similar-comercio-image {
height: 200px;
overflow: hidden;
position: relative;
}
.similar-comercio-thumb {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.5s ease;
}
.similar-comercio-card:hover .similar-comercio-thumb {
transform: scale(1.05);
}
.similar-comercio-placeholder {
width: 100%;
height: 100%;
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, var(--directorio-accent-color) 100%);
display: flex;
align-items: center;
justify-content: center;
color: var(--directorio-white);
font-size: 48px;
}
.similar-comercio-content {
padding: 24px;
flex-grow: 1;
display: flex;
flex-direction: column;
}
.similar-comercio-title {
font-size: 20px;
font-weight: 700;
color: #111827;
margin-bottom: 16px;
line-height: 1.3;
}
.similar-comercio-title a {
color: inherit;
line-height: 1.6;
margin-bottom: 20px;
flex-grow: 1;
}
.similar-comercio-link {
display: inline-flex;
align-items: center;
gap: 8px;
color: var(--directorio-accent-color);
font-weight: 600;
font-size: 14px;
text-decoration: none;
padding: 10px 0;
transition: all 0.2s ease;
align-self: flex-start;
}
.similar-comercio-link:hover {
color: var(--directorio-primary-color);
gap: 12px;
}
.similar-comercio-link i {
font-size: 12px;
transition: transform 0.2s ease;
}
.similar-comercio-link:hover i {
transform: translateX(4px);
}
.section-footer {
text-align: center;
padding-top: 30px;
border-top: 1px solid #e5e7eb;
} @media (max-width: 992px) {
.similar-comercios-grid {
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
gap: 24px;
}
.similar-comercio-section {
padding: 30px 0;
}
.section-title {
font-size: 28px;
}
}
@media (max-width: 768px) {
.similar-comercios-grid {
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 20px;
}
.similar-comercio-section {
margin: 40px 0;
padding: 30px 20px;
border-radius: 16px;
}
.section-title {
font-size: 24px;
}
.section-subtitle {
font-size: 14px;
}
.similar-comercio-content {
padding: 20px;
}
.similar-comercio-title {
font-size: 18px;
}
.view-all-link {
font-size: 14px;
padding: 12px 20px;
}
}
@media (max-width: 480px) {
.similar-comercios-grid {
grid-template-columns: 1fr;
gap: 20px;
}
.similar-comercio-section {
margin: 30px 0;
padding: 24px 16px;
border-radius: 12px;
}
.section-title {
font-size: 22px;
}
.similar-comercio-image {
height: 180px;
}
.similar-comercio-content {
padding: 16px;
}
.similar-comercio-title {
font-size: 17px;
}
.similar-comercio-excerpt {
font-size: 13px;
}
.view-all-link {
width: 75%;
justify-content: center;
}
} .archive-hero {
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, #003a5d 100%);
color: white;
padding: 60px 0;
margin-top: 70px; position: relative;
overflow: hidden;
}
.archive-hero::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background-image: radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.05) 0%, transparent 50%),
radial-gradient(circle at 80% 70%, rgba(255, 255, 255, 0.05) 0%, transparent 50%);
pointer-events: none;
}
.archive-hero-content {
max-width: 800px;
z-index: 1;
position: relative;
animation: fadeInUp 0.6s ease-out;
}
.breadcrumb-nav {
display: flex;
align-items: center;
gap: 8px;
font-size: 13px;
margin-bottom: 20px;
opacity: 0.8;
}
.breadcrumb-nav a {
color: white;
text-decoration: none;
}
.breadcrumb-nav a:hover {
text-decoration: underline;
}
.breadcrumb-nav .sep {
font-size: 10px;
}
.archive-title {
font-size: 40px;
font-weight: 800;
margin: 0 0 15px 0;
line-height: 1.2;
}
.archive-title span {
color: #ffd700; }
.archive-description {
font-size: 18px;
opacity: 0.9;
margin-bottom: 25px;
line-height: 1.6;
}
.archive-stats {
display: flex;
gap: 20px;
}
.stat-item {
display: inline-flex;
align-items: center;
gap: 8px;
background: rgba(255, 255, 255, 0.1);
padding: 8px 16px;
border-radius: 50px;
font-size: 14px;
backdrop-filter: blur(5px);
} .listings-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 24px;
margin-bottom: 40px;
}
.listing-card {
background: white;
border-radius: 16px;
overflow: hidden;
box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
height: 100%;
}
.listing-card:hover {
transform: translateY(-10px);
box-shadow: 0 12px 30px rgba(0, 0, 0, 0.1);
}
.listing-card-image {
position: relative;
height: 200px;
overflow: hidden;
}
.listing-card-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.5s ease;
}
.listing-card:hover .listing-card-image img {
transform: scale(1.1);
}
.listing-card-badge {
position: absolute;
top: 15px;
left: 15px;
background: var(--directorio-primary-color);
color: white;
padding: 5px 12px;
border-radius: 6px;
font-size: 11px;
font-weight: 700;
text-transform: uppercase;
box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}
.listing-card-content {
padding: 20px;
}
.listing-card-title {
font-size: 18px;
font-weight: 700;
margin: 0 0 10px 0;
color: #111;
}
.listing-card-address {
font-size: 14px;
color: #666;
margin-bottom: 15px;
display: flex;
align-items: flex-start;
gap: 5px;
}
.listing-card-footer {
border-top: 1px solid #eee;
padding-top: 15px;
margin-top: auto;
}
.view-detail {
color: var(--directorio-accent-color);
font-weight: 600;
font-size: 14px;
display: flex;
align-items: center;
gap: 5px;
}
.view-detail i {
transition: transform 0.2s ease;
}
.listing-card:hover .view-detail i {
transform: translateX(5px);
} .terms-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
gap: 20px;
}
.term-card {
background: white;
padding: 24px;
border-radius: 16px;
display: flex;
align-items: center;
gap: 15px;
text-decoration: none !important;
box-shadow: 0 2px 10px rgba(0, 0, 0, 0.03);
border: 1px solid #f0f0f0;
transition: all 0.3s ease;
}
.term-card:hover {
transform: scale(1.03);
border-color: var(--directorio-accent-color);
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);
}
.term-card-icon {
width: 54px;
height: 54px;
background: var(--directorio-secondary-color);
border-radius: 12px;
display: flex;
align-items: center;
justify-content: center;
color: var(--directorio-accent-color);
font-size: 20px;
flex-shrink: 0;
}
.term-card-icon img {
width: 32px;
height: 32px;
object-fit: contain;
}
.term-card-content {
flex: 1;
}
.term-card-title {
font-size: 16px;
font-weight: 700;
color: #111;
margin: 0 0 4px 0;
}
.term-card-count {
font-size: 13px;
color: #888;
margin: 0;
}
.term-card-arrow {
color: #ccc;
font-size: 12px;
transition: transform 0.2s ease;
}
.term-card:hover .term-card-arrow {
transform: translateX(3px);
color: var(--directorio-accent-color);
} .pagination-wrapper {
margin-top: 40px;
display: flex;
justify-content: center;
}
.pagination-wrapper .nav-links {
display: flex;
gap: 8px;
}
.pagination-wrapper .page-numbers {
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 8px;
background: white;
color: #555;
text-decoration: none;
font-weight: 600;
border: 1px solid #eee;
transition: all 0.2s ease;
}
.pagination-wrapper .page-numbers.current {
background: var(--directorio-primary-color);
color: white;
border-color: var(--directorio-primary-color);
}
.pagination-wrapper .page-numbers:hover:not(.current) {
background: #f0f0f0;
border-color: #ddd;
} .no-results-not-found {
text-align: center;
padding: 60px 20px;
background: #f9fafb;
border-radius: 20px;
margin: 40px 0;
}
.no-results-not-found i {
font-size: 60px;
color: #d1d5db;
margin-bottom: 20px;
}
.no-results-not-found h3 {
font-size: 24px;
margin-bottom: 10px;
}
.no-results-not-found p {
color: #6b7280;
margin-bottom: 30px;
} .category-header-flex {
display: flex;
align-items: center;
gap: 25px;
}
.category-hero-icon {
width: 80px;
height: 80px;
background: white;
border-radius: 20px;
padding: 15px;
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}
.category-hero-icon img {
width: 100%;
height: 100%;
object-fit: contain;
}
.py-5 {
padding-top: 3rem;
padding-bottom: 3rem;
}
@media (max-width: 768px) {
.archive-title {
font-size: 30px;
}
.archive-hero {
padding: 40px 0;
}
.category-header-flex {
flex-direction: column;
align-items: flex-start;
gap: 15px;
}
.category-hero-icon {
width: 60px;
height: 60px;
padding: 10px;
}
} .login-action-login,
.login-action-register,
.login-action-lostpassword {
background-color: #f7f7f7 !important;
}
#login {
width: 100% !important;
max-width: 450px !important;
padding: 40px !important;
background: #ffffff !important;
border-radius: 20px !important;
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05) !important;
margin-top: 50px !important;
}
.login form {
border: none !important;
box-shadow: none !important;
padding: 0 !important;
background: transparent !important;
}
.login label {
font-weight: 600 !important;
color: #374151 !important;
display: block !important;
margin-bottom: 8px !important;
}
.login .input {
border-radius: 10px !important;
border: 1px solid #ddd !important;
padding: 12px !important;
box-shadow: none !important;
width: 100% !important;
margin-bottom: 15px !important;
}
.login .button-primary {
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, #0077aa 100%) !important;
border: none !important;
border-radius: 10px !important;
padding: 12px 24px !important;
height: auto !important;
font-weight: 700 !important;
box-shadow: 0 4px 12px rgba(0, 90, 135, 0.2) !important;
width: 100% !important;
margin-top: 10px !important;
}
.login #nav,
.login #backtoblog {
text-align: center !important;
padding: 0 !important;
} .directorio-form-wrapper {
max-width: 600px !important;
margin: 60px auto !important;
padding: 40px !important;
background: #ffffff !important;
border: 1px solid rgba(0, 0, 0, 0.05) !important;
border-radius: 16px !important;
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08), 0 1px 3px rgba(0, 0, 0, 0.03) !important;
position: relative !important;
overflow: hidden !important;
}
.directorio-form-wrapper::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 6px;
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, #0077aa 100%);
}
.directorio-form-wrapper h3 {
margin-top: 0 !important;
color: #111827 !important;
font-size: 24px !important;
font-weight: 800 !important;
text-align: center !important;
margin-bottom: 15px !important;
}
.directorio-form-wrapper p {
color: #6b7280 !important;
font-size: 14px !important;
text-align: center !important;
margin-bottom: 25px !important;
line-height: 1.6 !important;
}
.directorio-form-wrapper label {
display: block !important;
font-weight: 600 !important;
margin-bottom: 8px !important;
color: #374151 !important;
font-size: 14px !important;
text-align: left !important;
}
.directorio-form-wrapper input[type="text"],
.directorio-form-wrapper input[type="email"],
.directorio-form-wrapper input[type="password"],
.directorio-form-wrapper textarea {
width: 100% !important;
padding: 14px 16px !important;
border: 1px solid #e5e7eb !important;
border-radius: 10px !important;
margin-bottom: 20px !important;
font-size: 15px !important;
background: #f9fafb !important;
color: #1f2937 !important;
transition: all 0.3s ease !important;
box-sizing: border-box !important;
}
.directorio-form-wrapper input:focus,
.directorio-form-wrapper textarea:focus {
outline: none !important;
border-color: var(--directorio-primary-color) !important;
background: #ffffff !important;
box-shadow: 0 0 0 4px rgba(0, 90, 135, 0.1) !important;
}
.directorio-form-wrapper .button,
.directorio-form-wrapper button[type="submit"] {
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, #0077aa 100%) !important;
color: var(--directorio-white) !important;
border: none !important;
padding: 14px 24px !important;
font-size: 16px !important;
font-weight: 700 !important;
border-radius: 10px !important;
cursor: pointer !important;
width: 100% !important;
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
box-shadow: 0 4px 12px rgba(0, 90, 135, 0.25) !important;
margin-top: 10px !important;
display: inline-block !important;
text-align: center !important;
text-decoration: none !important;
box-sizing: border-box;
}
.directorio-form-wrapper .button:hover,
.directorio-form-wrapper button[type="submit"]:hover {
transform: translateY(-2px) !important;
box-shadow: 0 8px 20px rgba(0, 90, 135, 0.35) !important;
color: white !important;
}
.directorio-form-wrapper .button:active,
.directorio-form-wrapper button[type="submit"]:active {
transform: translateY(0) !important;
}
.directorio-form-wrapper .form-footer-link {
margin-top: 25px !important;
text-align: center !important;
font-size: 14px !important;
color: #6b7280 !important;
}
.directorio-form-wrapper .form-footer-link a {
color: var(--directorio-primary-color) !important;
font-weight: 600 !important;
transition: color 0.2s !important;
text-decoration: none !important;
}
.directorio-form-wrapper .form-footer-link a:hover {
color: #004a70 !important;
text-decoration: underline !important;
} .directorio-message {
padding: 16px 20px !important;
margin-bottom: 24px !important;
border-radius: 12px !important;
border: 1px solid !important;
font-size: 15px !important;
font-weight: 500 !important;
text-align: center !important;
max-width: 480px !important;
margin-left: auto !important;
margin-right: auto !important;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}
.directorio-message.success {
background-color: #ecfdf5 !important;
border-color: #a7f3d0 !important;
color: #065f46 !important;
}
.directorio-message.error {
background-color: #fef2f2 !important;
border-color: #fecaca !important;
color: #991b1b !important;
} .directorio-private-key-notice {
border: 2px dashed rgba(0, 90, 135, 0.3) !important;
background-color: #f0f8ff !important;
padding: 24px !important;
margin: 30px auto !important;
max-width: 480px !important;
text-align: center !important;
border-radius: 16px !important;
}
.directorio-private-key-notice h3 {
color: var(--directorio-primary-color) !important;
margin-top: 0 !important;
font-size: 18px !important;
font-weight: 700 !important;
}
.directorio-private-key-notice p {
color: #4b5563 !important;
margin-bottom: 15px !important;
font-size: 14px;
}
.directorio-private-key-notice .private-key {
background-color: #ffffff !important;
padding: 16px !important;
border: 1px solid #e5e7eb !important;
border-radius: 8px !important;
word-break: break-all !important;
white-space: pre-wrap !important;
overflow-wrap: break-word !important;
font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace !important;
font-size: 15px !important;
color: #1f2937 !important;
box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.02) !important;
} .recovery-phrase-notice {
border-color: #fcd34d !important;
background-color: #fffbeb !important;
margin-top: 20px !important;
}
.recovery-phrase-notice h3 {
color: #b45309 !important;
}
.recovery-phrase-grid {
display: grid;
grid-template-columns: repeat(2, 1fr);
gap: 12px;
margin-top: 15px;
text-align: left;
}
@media (min-width: 480px) {
.recovery-phrase-grid {
grid-template-columns: repeat(3, 1fr);
}
}
@media (min-width: 768px) {
.recovery-phrase-grid {
grid-template-columns: repeat(4, 1fr);
}
}
.recovery-word-badge {
background: #ffffff;
border: 1px solid #fde68a;
padding: 10px 14px;
border-radius: 8px;
display: flex;
align-items: center;
gap: 8px;
box-shadow: 0 2px 4px rgba(217, 119, 6, 0.05);
}
.recovery-word-badge .word-number {
color: #d97706;
font-weight: 700;
font-size: 13px;
opacity: 0.8;
user-select: none;
}
.recovery-word-badge .word-text {
color: #92400e;
font-weight: 700;
font-size: 15px;
letter-spacing: 0.5px;
} body:has(.directorio-form-wrapper) {
display: flex;
flex-direction: column;
min-height: 100vh;
margin: 0;
}
#colophon {
margin-top: auto;
} body:has(.directorio-form-wrapper) .wp-block-post-title,
body:has(.directorio-form-wrapper) h1.entry-title,
body:has(.directorio-form-wrapper) .page-title,
body:has(.directorio-form-wrapper) header.entry-header {
display: none !important;
} .site-footer {
background-color: #ffffff;
font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
margin-top: auto;
} .footer-cta {
background: linear-gradient(135deg, var(--directorio-primary-color) 0%, #0077aa 100%);
padding: 50px 0;
color: #ffffff;
}
.footer-cta-inner {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
gap: 20px;
}
@media (min-width: 768px) {
.footer-cta-inner {
flex-direction: row;
justify-content: space-between;
text-align: left;
}
}
.cta-text h3 {
color: #ffffff;
margin: 0 0 10px 0;
font-size: 24px;
font-weight: 700;
}
.cta-text p {
margin: 0;
font-size: 16px;
opacity: 0.9;
max-width: 600px;
}
.cta-button {
background-color: #ffffff;
color: var(--directorio-primary-color);
padding: 14px 28px;
border-radius: 8px;
font-weight: 700;
text-decoration: none;
font-size: 16px;
transition: all 0.3s ease;
white-space: nowrap;
box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
}
.cta-button:hover {
transform: translateY(-2px);
box-shadow: 0 6px 15px rgba(0, 0, 0, 0.15);
color: #005a87;
} .footer-main {
padding: 60px 0 40px;
}
.footer-main-flex {
display: flex;
flex-direction: column;
gap: 40px;
}
@media (min-width: 768px) {
.footer-main-flex {
flex-direction: row;
justify-content: space-between;
gap: 60px;
}
}
.footer-brand {
max-width: 400px;
}
.footer-logo {
color: #111827;
font-size: 22px;
font-weight: 800;
margin: 0 0 15px 0;
letter-spacing: -0.5px;
}
.footer-desc {
line-height: 1.6;
margin-bottom: 25px;
font-size: 15px;
color: #6b7280;
}
.footer-social {
display: flex;
gap: 12px;
justify-content: center;
}
.footer-social a {
display: flex;
align-items: center;
justify-content: center;
width: 40px;
height: 40px;
background-color: #f3f4f6;
color: #4b5563;
border-radius: 8px;
transition: all 0.3s ease;
text-decoration: none;
font-size: 16px;
}
.footer-social a:hover {
background-color: var(--directorio-primary-color);
color: #ffffff;
transform: translateY(-3px);
box-shadow: 0 4px 10px rgba(0, 119, 170, 0.2);
}
.footer-links-group {
display: flex;
flex-direction: column;
gap: 40px;
width: 100%;
max-width: 500px;
}
@media (min-width: 480px) {
.footer-links-group {
flex-direction: row;
justify-content: space-between;
}
}
.footer-column h4 {
color: #111827;
font-size: 15px;
font-weight: 700;
margin: 0 0 20px 0;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.footer-column ul {
list-style: none;
padding: 0;
margin: 0;
}
.footer-column ul li {
margin-bottom: 12px;
}
.footer-column ul li a {
color: #6b7280;
text-decoration: none;
transition: color 0.2s ease;
font-size: 15px;
font-weight: 500;
}
.footer-column ul li a:hover {
color: var(--directorio-primary-color);
} .footer-bottom {
padding: 24px 0;
background-color: #f9fafb;
border-top: 1px solid #e5e7eb;
}
.footer-bottom-content {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
gap: 10px;
}
@media (min-width: 768px) {
.footer-bottom-content {
flex-direction: row;
justify-content: space-between;
text-align: left;
}
}
.footer-bottom-content p {
margin: 0;
}
.footer-bottom-content p:first-child {
font-size: 14px;
color: #6b7280;
font-weight: 500;
}
.footer-bottom-content .disclaimer {
font-size: 13px;
color: #9ca3af;
max-width: 500px;
} .floating-whatsapp {
position: fixed;
bottom: 30px;
right: 30px;
background-color: #25D366;
color: white;
width: 60px;
height: 60px;
border-radius: 50px;
display: flex;
align-items: center;
justify-content: center;
box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
z-index: 1000;
transition: all 0.3s ease;
text-decoration: none;
overflow: hidden;
}
.floating-whatsapp i {
font-size: 32px;
}
.floating-whatsapp span {
max-width: 0;
opacity: 0;
white-space: nowrap;
transition: all 0.3s ease;
font-weight: 700;
margin-left: 0;
}
.floating-whatsapp:hover {
width: auto;
padding: 0 25px;
border-radius: 30px;
transform: translateY(-5px);
}
.floating-whatsapp:hover span {
max-width: 150px;
opacity: 1;
margin-left: 10px;
}
@media (max-width: 768px) {
.floating-whatsapp {
bottom: 60px;
right: 20px;
width: 50px;
height: 50px;
}
.floating-whatsapp i {
font-size: 26px;
}
.floating-whatsapp:hover {
width: 50px;
padding: 0;
}
.floating-whatsapp:hover span {
display: none;
}
} .sidebar-ads-container {
margin-top: 30px;
padding-top: 25px;
border-top: 1px dashed #e2e8f0;
display: flex;
flex-direction: column;
align-items: center;
gap: 20px;
}
.sidebar-ad-widget {
width: 100%;
text-align: center;
}
.ad-widget-title {
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 1px;
color: #94a3b8;
margin-bottom: 12px;
text-align: center;
} .listing-sidebar-ads {
width: 100%;
max-width: 100%;
box-sizing: border-box;
display: flex;
flex-direction: column;
align-items: center;
gap: 15px;
background: #fff;
padding: 20px;
border-radius: 12px;
box-shadow: 0 4px 15px rgba(0,0,0,0.05);
overflow: hidden;
}
@media (max-width: 480px) {
.listing-sidebar-ads {
padding: 15px; }
}
.listing-sidebar-ads .sidebar-ad-widget {
width: 100%;
text-align: center;
} .listing-sidebar-ads img,
.sidebar-ad-widget img {
max-width: 100% !important;
height: auto !important;
display: block;
margin: 0 auto;
}
.listing-sidebar-placeholder {
background: #f8fafc;
border: 2px dashed #e2e8f0;
border-radius: 12px;
padding: 30px 20px;
text-align: center;
color: #94a3b8;
}
.listing-sidebar-placeholder h3 {
font-size: 1.1rem;
color: #64748b;
margin-bottom: 8px;
} .admin-bar .top-bar,
.admin-bar .site-header {
margin-top: 32px !important;
}
@media screen and (max-width: 782px) {
.admin-bar .top-bar,
.admin-bar .site-header {
margin-top: 46px !important;
}
} @keyframes ar-shimmer {
0%   { background-position: -200% center; }
100% { background-position: 200% center; }
}
@keyframes ar-pulse-glow {
0%, 100% { box-shadow: 0 0 0 0 rgba(245, 158, 11, 0.3); }
50%       { box-shadow: 0 0 0 8px rgba(245, 158, 11, 0); }
}
@keyframes ar-badge-in {
from { opacity: 0; transform: translateY(-6px); }
to   { opacity: 1; transform: translateY(0); }
}
.admin-review-card {
position: relative;
border-radius: 16px;
overflow: hidden;
margin-bottom: 28px;
background: linear-gradient(135deg, #1a1a2e 0%, #16213e 50%, #0f3460 100%);
border: 1px solid rgba(245, 158, 11, 0.25);
box-shadow:
0 4px 24px rgba(0, 0, 0, 0.35),
0 0 0 1px rgba(245, 158, 11, 0.08),
inset 0 1px 0 rgba(255, 255, 255, 0.05);
animation: ar-badge-in 0.5s ease both;
} .admin-review-card::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
height: 3px;
background: linear-gradient(90deg, #f59e0b, #fbbf24, #f59e0b, #fbbf24);
background-size: 200% auto;
animation: ar-shimmer 3s linear infinite;
} .admin-review-card::after {
content: '';
position: absolute;
top: 3px;
left: 0;
width: 200px;
height: 200px;
background: radial-gradient(ellipse at top left, rgba(245, 158, 11, 0.08) 0%, transparent 60%);
pointer-events: none;
} .ar-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 14px 20px 12px;
border-bottom: 1px solid rgba(245, 158, 11, 0.12);
} .ar-badge {
display: inline-flex;
align-items: center;
gap: 7px;
background: linear-gradient(135deg, rgba(245, 158, 11, 0.15) 0%, rgba(251, 191, 36, 0.08) 100%);
border: 1px solid rgba(245, 158, 11, 0.3);
border-radius: 50px;
padding: 5px 14px 5px 10px;
}
.ar-badge-icon {
color: #f59e0b;
font-size: 14px;
line-height: 1;
animation: ar-pulse-glow 2.5s ease-in-out infinite;
}
.ar-badge-text {
font-size: 11px;
font-weight: 700;
color: #fbbf24;
text-transform: uppercase;
letter-spacing: 0.8px;
} .ar-verified {
display: inline-flex;
align-items: center;
gap: 5px;
}
.ar-verified-icon {
display: inline-flex;
align-items: center;
justify-content: center;
width: 20px;
height: 20px;
background: linear-gradient(135deg, #10b981, #059669);
border-radius: 50%;
color: #fff;
font-size: 11px;
font-weight: 700;
flex-shrink: 0;
}
.ar-verified-text {
font-size: 11px;
font-weight: 600;
color: #6ee7b7;
letter-spacing: 0.3px;
} .ar-body {
display: flex;
gap: 16px;
padding: 18px 20px 20px;
align-items: flex-start;
} .ar-avatar {
flex-shrink: 0;
width: 48px;
height: 48px;
border-radius: 50%;
background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
display: flex;
align-items: center;
justify-content: center;
box-shadow: 0 4px 12px rgba(245, 158, 11, 0.35);
border: 2px solid rgba(245, 158, 11, 0.4);
}
.ar-avatar-icon {
font-size: 22px;
font-weight: 800;
color: #1a1a2e;
line-height: 1;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
} .ar-content {
flex: 1;
min-width: 0;
} .ar-stars {
display: flex;
gap: 2px;
margin-bottom: 10px;
}
.ar-star {
font-size: 18px;
line-height: 1;
}
.ar-star-filled {
color: #f59e0b;
text-shadow: 0 0 6px rgba(245, 158, 11, 0.5);
}
.ar-star-empty {
color: rgba(255, 255, 255, 0.15);
} .ar-text {
margin: 0 0 12px;
font-size: 15px;
line-height: 1.65;
color: #e2e8f0;
font-style: italic;
border: none;
padding: 0;
quotes: "\201C" "\201D";
position: relative;
}
.ar-text::before {
content: open-quote;
font-size: 48px;
line-height: 0;
vertical-align: -18px;
color: rgba(245, 158, 11, 0.3);
font-style: normal;
margin-right: 4px;
} .ar-author {
margin: 0;
font-size: 13px;
font-weight: 600;
color: #94a3b8;
letter-spacing: 0.3px;
} @media (max-width: 600px) {
.ar-body {
gap: 12px;
padding: 14px 16px 16px;
}
.ar-avatar {
width: 40px;
height: 40px;
}
.ar-avatar-icon {
font-size: 18px;
}
.ar-text {
font-size: 14px;
}
.ar-header {
padding: 12px 16px 10px;
flex-wrap: wrap;
gap: 8px;
}
.ar-badge-text {
font-size: 10px;
}
}