/*
Theme Name: Spain Directory Elementor Theme V2
Theme URI: https://example.com/
Author: OpenAI
Author URI: https://openai.com/
Description: Tema V2 estilo directorio premium, compatible con Elementor y preparado para integrar WP Adverts en home y páginas internas.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.8
Requires PHP: 7.4
Text Domain: spain-directory-elementor
*/

:root {
  --sd-bg: #ffffff;
  --sd-bg-soft: #fbfbfc;
  --sd-panel: #f6f7f9;
  --sd-text: #111111;
  --sd-muted: #666b75;
  --sd-border: #eceef2;
  --sd-chip: #f5f6f8;
  --sd-chip-hover: #ffe7ef;
  --sd-primary: #ff2960;
  --sd-primary-dark: #e61f54;
  --sd-primary-soft: #fff1f5;
  --sd-dark: #111214;
  --sd-dark-soft: #1d1f23;
  --sd-radius-sm: 12px;
  --sd-radius-md: 18px;
  --sd-radius-lg: 24px;
  --sd-radius-xl: 32px;
  --sd-shadow-sm: 0 8px 20px rgba(12, 18, 28, 0.06);
  --sd-shadow-md: 0 14px 40px rgba(12, 18, 28, 0.08);
  --sd-shadow-lg: 0 22px 60px rgba(12, 18, 28, 0.12);
  --sd-max-width: 1280px;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: Inter, Arial, sans-serif;
  color: var(--sd-text);
  background: var(--sd-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover {
  color: var(--sd-primary);
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.site-main {
  min-height: 60vh;
}

.sd-container {
  width: min(calc(100% - 28px), var(--sd-max-width));
  margin: 0 auto;
}

.sd-topbar {
  background: var(--sd-dark);
  color: #fff;
  font-size: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.sd-topbar__inner,
.sd-header__inner,
.sd-footer__upper,
.sd-subnav__inner,
.sd-hero__actions,
.sd-filter-links,
.sd-inline-links,
.sd-footer__columns {
  display: flex;
  align-items: center;
  gap: 14px;
}

.sd-topbar__inner,
.sd-subnav__inner {
  justify-content: space-between;
}

.sd-topbar__inner {
  min-height: 42px;
}

.sd-topbar__links,
.sd-topbar__actions,
.sd-chip-cloud,
.sd-footer__columns,
.sd-inline-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.sd-topbar a {
  opacity: .88;
}

.sd-topbar a:hover {
  opacity: 1;
  color: #fff;
}

.sd-header {
  position: sticky;
  top: 0;
  z-index: 90;
  background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(160%) blur(16px);
  border-bottom: 1px solid rgba(17,18,20,0.06);
}

.admin-bar .sd-header {
  top: 32px;
}

.sd-header__inner {
  min-height: 82px;
  justify-content: space-between;
}

.sd-header__brand {
  display: flex;
  align-items: center;
  gap: 14px;
}

.sd-logo,
.sd-header__brand .custom-logo-link {
  display: inline-flex;
  align-items: center;
}

.sd-logo {
  font-size: 30px;
  line-height: 1;
  font-weight: 800;
  letter-spacing: -0.05em;
}

.sd-logo-mark {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--sd-primary), #ff7ea2);
  box-shadow: 0 0 0 5px rgba(255,41,96,.08);
}

.sd-header__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.sd-pill,
.sd-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border-radius: 999px;
  border: 1px solid var(--sd-border);
  background: var(--sd-chip);
  color: var(--sd-text);
  font-size: 13px;
  font-weight: 600;
  transition: all .2s ease;
}

.sd-chip:hover,
.sd-pill:hover {
  background: var(--sd-chip-hover);
  border-color: #ffc0d0;
  color: var(--sd-text);
  transform: translateY(-1px);
}

.sd-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  transition: .2s ease;
  cursor: pointer;
}

.sd-btn--primary {
  background: var(--sd-primary);
  color: #fff;
  box-shadow: 0 10px 22px rgba(255, 41, 96, 0.22);
}

.sd-btn--primary:hover {
  background: var(--sd-primary-dark);
  color: #fff;
  transform: translateY(-1px);
}

.sd-btn--secondary {
  background: #fff;
  border-color: var(--sd-border);
  color: var(--sd-text);
}

.sd-btn--secondary:hover {
  background: #f8f9fb;
}

.sd-subnav {
  background: #fff;
  border-bottom: 1px solid var(--sd-border);
}

.sd-subnav__inner {
  min-height: 52px;
}

.sd-subnav__left,
.sd-subnav__right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.sd-hero {
  position: relative;
  overflow: hidden;
  padding: 36px 0 18px;
  background:
    radial-gradient(circle at top left, rgba(255,41,96,.10), transparent 32%),
    radial-gradient(circle at top right, rgba(255,126,162,.08), transparent 26%),
    linear-gradient(180deg, #ffffff 0%, #fcfcfd 100%);
}

.sd-hero__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, .9fr);
  gap: 22px;
  align-items: stretch;
}

.sd-hero__content,
.sd-hero__panel {
  border: 1px solid var(--sd-border);
  border-radius: 28px;
  background: rgba(255,255,255,.92);
  box-shadow: var(--sd-shadow-sm);
}

.sd-hero__content {
  padding: 30px;
}

.sd-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--sd-primary-soft);
  color: var(--sd-primary);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.sd-hero__title {
  margin: 0 0 12px;
  font-size: clamp(38px, 5vw, 68px);
  line-height: .94;
  font-weight: 800;
  letter-spacing: -0.06em;
}

.sd-hero__subtitle {
  max-width: 760px;
  margin: 0;
  color: var(--sd-muted);
  font-size: 16px;
  line-height: 1.7;
}

.sd-hero__actions {
  margin-top: 24px;
  flex-wrap: wrap;
}

.sd-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 22px;
}

.sd-stat {
  padding: 14px 16px;
  background: var(--sd-bg-soft);
  border: 1px solid var(--sd-border);
  border-radius: 18px;
}

.sd-stat__num {
  display: block;
  margin-bottom: 6px;
  font-size: 24px;
  line-height: 1;
  font-weight: 800;
}

.sd-stat__label {
  color: var(--sd-muted);
  font-size: 13px;
}

.sd-hero__panel {
  padding: 20px;
}

.sd-panel-title {
  margin: 0 0 12px;
  font-size: 16px;
  font-weight: 800;
}

.sd-filter-bar {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.sd-filter-field label {
  display: block;
  margin: 0 0 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--sd-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.sd-filter-bar input,
.sd-filter-bar select {
  width: 100%;
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid var(--sd-border);
  border-radius: 14px;
  background: #fff;
  font-size: 14px;
  color: var(--sd-text);
}

.sd-filter-note {
  margin-top: 12px;
  color: var(--sd-muted);
  font-size: 13px;
  line-height: 1.6;
}

.sd-filter-links {
  margin-top: 12px;
  flex-wrap: wrap;
}

.sd-section {
  padding: 18px 0 8px;
}

.sd-section--spacious {
  padding: 34px 0 14px;
}

.sd-section__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.sd-section__eyebrow {
  display: inline-block;
  margin-bottom: 8px;
  color: var(--sd-primary);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.sd-section__title {
  margin: 0;
  font-size: clamp(24px, 3vw, 34px);
  letter-spacing: -0.04em;
  line-height: 1;
}

.sd-section__desc {
  margin: 8px 0 0;
  color: var(--sd-muted);
  font-size: 15px;
  line-height: 1.6;
}

.sd-chip-cloud {
  margin-top: 8px;
}

.sd-grid,
.sd-directory-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.sd-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--sd-border);
  border-radius: 24px;
  background: #fff;
  box-shadow: var(--sd-shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.sd-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sd-shadow-md);
  border-color: #e4d8dd;
}

.sd-card__media {
  position: relative;
  aspect-ratio: 3 / 4;
  background:
    linear-gradient(180deg, rgba(17,18,20,0.04) 0%, rgba(17,18,20,0.12) 100%),
    radial-gradient(circle at top, rgba(255,41,96,.14), transparent 48%),
    linear-gradient(135deg, #faf0f3 0%, #f1f4f7 100%);
}

.sd-card__badge-wrap {
  position: absolute;
  top: 14px;
  left: 14px;
  z-index: 2;
}

.sd-card__floating {
  position: absolute;
  right: 14px;
  bottom: 14px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(10px);
  font-size: 12px;
  font-weight: 700;
}

.sd-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .05em;
}

.sd-badge--new {
  background: var(--sd-dark);
  color: #fff;
}

.sd-badge--vip {
  background: var(--sd-primary);
  color: #fff;
}

.sd-badge--top {
  background: #111;
  color: #fff;
}

.sd-badge--video {
  background: #fff;
  color: var(--sd-text);
  border: 1px solid var(--sd-border);
}

.sd-card__body {
  padding: 16px;
}

.sd-card__name {
  margin: 0 0 8px;
  font-size: 18px;
  letter-spacing: -.03em;
}

.sd-card__meta {
  color: var(--sd-muted);
  font-size: 14px;
}

.sd-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
}

.sd-card__status {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--sd-bg-soft);
  border: 1px solid var(--sd-border);
  color: var(--sd-muted);
  font-size: 12px;
  font-weight: 700;
}

.sd-card--vip,
.sd-card--top {
  background: linear-gradient(180deg, #fff 0%, #fff9fb 100%);
}

.sd-card--hero {
  border-radius: 28px;
}

.sd-directory-wrap {
  padding: 18px;
  border: 1px solid var(--sd-border);
  border-radius: 28px;
  background: linear-gradient(180deg, #fff 0%, #fcfcfd 100%);
  box-shadow: var(--sd-shadow-sm);
}

.sd-directory-note {
  margin-top: 12px;
  color: var(--sd-muted);
  font-size: 13px;
}

.sd-shortcode-wrap {
  padding: 18px;
  border: 1px dashed #d9dee7;
  border-radius: 18px;
  background: #fafbfc;
}

.sd-shortcode-wrap code {
  display: inline-block;
  margin-top: 8px;
  padding: 8px 10px;
  border-radius: 10px;
  background: #fff;
  border: 1px solid var(--sd-border);
}

.sd-seo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}

.sd-seo-card {
  display: block;
  padding: 22px;
  border: 1px solid var(--sd-border);
  border-radius: 22px;
  background: #fff;
  transition: transform .2s ease, box-shadow .2s ease;
}

.sd-seo-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sd-shadow-sm);
}

.sd-seo-card__title {
  margin: 0 0 10px;
  font-size: 18px;
  letter-spacing: -.03em;
}

.sd-seo-card__text {
  margin: 0;
  color: var(--sd-muted);
  font-size: 14px;
  line-height: 1.7;
}

.sd-footer {
  margin-top: 48px;
  background: var(--sd-dark);
  color: rgba(255,255,255,.88);
}

.sd-footer__upper {
  align-items: start;
  justify-content: space-between;
  padding: 34px 0;
}

.sd-footer__columns {
  align-items: start;
  gap: 36px;
}

.sd-footer__title {
  margin: 0 0 12px;
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: #fff;
}

.sd-footer__links {
  display: grid;
  gap: 8px;
  font-size: 14px;
}

.sd-footer__bottom {
  padding: 16px 0 28px;
  border-top: 1px solid rgba(255,255,255,.08);
  color: rgba(255,255,255,.66);
  font-size: 13px;
}

/* WordPress content */
.entry-content,
.page-content,
.post-content {
  line-height: 1.8;
}

/* WP Adverts generic styling */
.adverts-list,
.adverts-list-container,
.adverts-items-container,
.adverts-loop,
.adverts-grid,
ul.adverts-list,
ul.adverts-items {
  list-style: none;
  margin: 0;
  padding: 0;
}

.adverts-list,
.adverts-items,
.adverts-grid,
.adverts-loop {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 18px;
}

.advert-item,
.adverts-item,
.adverts-single,
.adverts-grid > li,
.adverts-list > li,
.adverts-items > li {
  overflow: hidden;
  border: 1px solid var(--sd-border);
  border-radius: 22px;
  background: #fff;
  box-shadow: var(--sd-shadow-sm);
  transition: transform .2s ease, box-shadow .2s ease;
}

.advert-item:hover,
.adverts-item:hover,
.adverts-single:hover,
.adverts-grid > li:hover,
.adverts-list > li:hover,
.adverts-items > li:hover {
  transform: translateY(-2px);
  box-shadow: var(--sd-shadow-md);
}

.advert-item a,
.adverts-item a,
.adverts-grid > li a,
.adverts-list > li a,
.adverts-items > li a {
  color: inherit;
  text-decoration: none;
}

.advert-item img,
.adverts-item img,
.adverts-grid > li img,
.adverts-list > li img,
.adverts-items > li img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  background: #f4f6f8;
}

.advert-item .title,
.advert-item h3,
.advert-item h2,
.adverts-item .title,
.adverts-item h3,
.adverts-grid > li h3,
.adverts-list > li h3,
.adverts-items > li h3 {
  margin: 14px 14px 8px;
  font-size: 17px;
  line-height: 1.2;
  letter-spacing: -.03em;
}

.advert-item .price,
.adverts-item .price,
.advert-item .location,
.adverts-item .location,
.advert-item .adverts-field,
.adverts-item .adverts-field,
.adverts-grid > li .price,
.adverts-grid > li .location,
.adverts-list > li .price,
.adverts-list > li .location,
.adverts-items > li .price,
.adverts-items > li .location {
  margin: 0 14px 14px;
  color: var(--sd-muted);
  font-size: 13px;
}

.adverts-pagination,
.paging-navigation,
.navigation.pagination {
  margin-top: 18px;
}

.adverts-pagination a,
.adverts-pagination span,
.navigation.pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  min-height: 40px;
  margin-right: 6px;
  border-radius: 999px;
  border: 1px solid var(--sd-border);
  background: #fff;
}

/* Elementor basics */
.elementor-section.elementor-section-boxed > .elementor-container,
.elementor-container,
.elementor-widget-wrap {
  position: relative;
}

@media (max-width: 1024px) {
  .sd-grid,
  .sd-directory-list,
  .adverts-list,
  .adverts-items,
  .adverts-grid,
  .adverts-loop,
  .sd-seo-grid {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }

  .sd-hero__grid {
    grid-template-columns: 1fr;
  }

  .sd-header__inner,
  .sd-footer__upper,
  .sd-section__head,
  .sd-subnav__inner {
    align-items: start;
    flex-direction: column;
  }
}

@media (max-width: 782px) {
  .admin-bar .sd-header {
    top: 46px;
  }
}

@media (max-width: 767px) {
  .sd-container {
    width: min(calc(100% - 20px), var(--sd-max-width));
  }

  .sd-hero {
    padding-top: 20px;
  }

  .sd-hero__content,
  .sd-hero__panel,
  .sd-directory-wrap,
  .sd-seo-card,
  .sd-card,
  .advert-item,
  .adverts-item,
  .adverts-grid > li,
  .adverts-list > li,
  .adverts-items > li {
    border-radius: 18px;
  }

  .sd-grid,
  .sd-directory-list,
  .adverts-list,
  .adverts-items,
  .adverts-grid,
  .adverts-loop,
  .sd-seo-grid,
  .sd-hero__stats {
    grid-template-columns: 1fr;
  }

  .sd-logo {
    font-size: 24px;
  }

  .sd-hero__content {
    padding: 22px;
  }

  .sd-topbar__inner,
  .sd-topbar__links,
  .sd-topbar__actions,
  .sd-header__meta,
  .sd-subnav__left,
  .sd-subnav__right,
  .sd-chip-cloud,
  .sd-footer__columns,
  .sd-card__footer {
    gap: 8px;
  }

  .sd-footer__upper {
    padding: 28px 0;
  }
}
