/*
 Theme Name:   GOICLEX Child
 Theme URI:    https://tudominio.com
 Description:  Child theme para Astra - GOICLEX Despacho Legal
 Author:       GOICLEX
 Template:     astra
 Version:      1.0.0
 Text Domain:  regina-child
*/

/* =========================================================
   Brand tokens
   ========================================================= */
:root {
  --color-brand-dark:   #122540;
  --color-brand-mid:    #1c3559;
  --color-brand-gold:   #d1902e;
  --color-brand-gold-deep:#b77722;
  --color-brand-light:  #f5ede1;
  --color-brand-ink:    #0d1a2d;
  --color-text:         #182434;
  --color-muted:        #5e6775;
  --color-border:       #d6c39f;
  --font-heading:       'Marcellus', Georgia, serif;
  --font-body:          'Source Sans 3', system-ui, sans-serif;
  --radius-card:        16px;
  --shadow-card:        0 8px 32px rgba(18, 37, 64, 0.12);
}

/* =========================================================
   Base typography
   ========================================================= */
body {
  font-family: var(--font-body);
  color: var(--color-text);
  background:
    radial-gradient(circle at top left, rgba(209, 144, 46, 0.12), transparent 22rem),
    linear-gradient(180deg, #fbf8f2 0%, #ffffff 26%, #f8f3ea 100%);
  background-color: #fff;
}

.ast-plain-container.ast-no-sidebar #primary,
.home.ast-plain-container.ast-no-sidebar #primary,
.site-content > .ast-container {
  margin-top: 10px !important;
  padding-top: 0 !important;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  color: var(--color-brand-dark);
  letter-spacing: 0.01em;
}

a {
  color: var(--color-brand-mid);
}
a:hover {
  color: var(--color-brand-gold);
}

/* =========================================================
   Navigation — Header Astra
   ========================================================= */

/* Barra completa del header */
.site-header,
.ast-primary-header-bar,
#masthead,
.main-header-bar {
  background:
    linear-gradient(135deg, rgba(209, 144, 46, 0.96) 0, rgba(209, 144, 46, 0.96) 8rem, transparent 8rem),
    linear-gradient(180deg, #132846 0%, #10233d 100%) !important;
  border-bottom: 1px solid rgba(209, 144, 46, 0.24);
  box-shadow: 0 14px 34px rgba(13, 26, 45, 0.18);
}

/* Zona de navegación (fondo unificado con el header) */
.main-header-bar-navigation,
.site-navigation,
.main-navigation,
#site-navigation,
.ast-nav-menu,
.main-header-menu {
  background: transparent !important;
}

/* Links del menú */
.main-header-menu .menu-item > a,
.main-header-menu .menu-item > .ast-menu-toggle,
.ast-nav-menu > .menu-item > a,
.main-navigation a {
  color: #ffffff !important;
  background: transparent !important;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.84rem;
}

/* Hover y elemento activo */
.main-header-menu .menu-item > a:hover,
.main-header-menu .current-menu-item > a,
.main-header-menu .current_page_item > a,
.ast-nav-menu > .menu-item > a:hover,
.ast-nav-menu > .current-menu-item > a {
  color: var(--color-brand-gold) !important;
  background: transparent !important;
  text-shadow: 0 0 18px rgba(209, 144, 46, 0.24);
}

/* Submenús desplegables */
.main-header-menu .sub-menu,
.ast-nav-menu .sub-menu {
  background-color: var(--color-brand-dark) !important;
  border-top: 2px solid var(--color-brand-gold);
}

.main-header-menu .sub-menu a,
.ast-nav-menu .sub-menu a {
  color: #ffffff !important;
}

.main-header-menu .sub-menu a:hover,
.ast-nav-menu .sub-menu a:hover {
  color: var(--color-brand-gold) !important;
  background-color: rgba(255,255,255,0.05) !important;
}

/* Título / logo del sitio */
.site-title a,
.site-branding a,
.ast-site-identity a {
  color: #ffffff !important;
}

.site-logo-img .custom-logo {
  max-height: 56px;
  width: auto;
  filter: drop-shadow(0 12px 24px rgba(0, 0, 0, 0.2));
}

.site-header .site-logo-img,
#masthead .site-logo-img,
.ast-mobile-header-wrap .site-logo-img {
  display: none !important;
}

.ast-site-title-wrap {
  display: flex;
  align-items: center;
}

.site-title {
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.ast-builder-grid-row,
.ast-builder-layout-element {
  min-height: 0 !important;
}

.ast-primary-header-bar {
  padding-top: 0.35rem !important;
  padding-bottom: 0.35rem !important;
}

.main-header-bar {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.site-branding {
  gap: 0.55rem;
}

.main-header-menu > .menu-item > a,
.ast-nav-menu > .menu-item > a {
  padding-top: 0.85rem !important;
  padding-bottom: 0.85rem !important;
}

/* Footer: ocultar "Powered by Astra" si queda algún rastro */
.ast-footer-copyright a[href*="wpastra.com"],
.ast-footer-copyright a[href*="wpastra.com"]::before,
.ast-footer-copyright a[href*="wpastra.com"]::after {
  display: none !important;
}
/* Ocultar el separador " | " antes del enlace de Astra */
.ast-footer-copyright p {
  font-size: 0.9rem;
}

/* =========================================================
   Buttons
   ========================================================= */
.wp-block-button__link,
.wp-block-button .wp-block-button__link,
button,
input[type="submit"],
.button,
.btn {
  background: linear-gradient(180deg, #df9d39 0%, var(--color-brand-gold) 100%);
  color: var(--color-brand-dark) !important;
  border-radius: 999px;
  font-weight: 700;
  border: none;
  padding: 0.75rem 1.75rem;
  box-shadow: 0 14px 28px rgba(209, 144, 46, 0.22);
  transition: background-color 150ms ease, transform 100ms ease, box-shadow 150ms ease;
  text-decoration: none;
}

button:hover,
input[type="submit"]:hover,
.button:hover,
.wp-block-button__link:hover {
  background: linear-gradient(180deg, #e5a84c 0%, var(--color-brand-gold-deep) 100%);
  transform: translateY(-2px);
  box-shadow: 0 20px 34px rgba(183, 119, 34, 0.26);
}

/* =========================================================
   Hero / Banner section
   ========================================================= */
.site-hero {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(209, 144, 46, 0.94) 0, rgba(209, 144, 46, 0.94) 9rem, transparent 9rem),
    radial-gradient(circle at 85% 20%, rgba(209, 144, 46, 0.18), transparent 18rem),
    linear-gradient(135deg, var(--color-brand-dark) 0%, var(--color-brand-ink) 100%);
  color: #fff;
  padding: 3.2rem 2rem 2.8rem;
  text-align: center;
  box-shadow: inset 0 -1px 0 rgba(209, 144, 46, 0.18);
}

.site-hero::before {
  content: "";
  position: absolute;
  right: -8rem;
  bottom: -7rem;
  width: 22rem;
  height: 22rem;
  border: 1px solid rgba(209, 144, 46, 0.24);
  border-radius: 50%;
  opacity: 0.9;
}

.site-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(209, 144, 46, 0.6), transparent);
}

.site-hero h1 {
  color: #fff;
  font-size: clamp(2rem, 5vw, 3.5rem);
  margin-bottom: 0.75rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.site-hero p {
  color: var(--color-brand-light);
  font-size: 1.2rem;
  max-width: 640px;
  margin: 0 auto 1.35rem;
}

/* =========================================================
   Cards (servicios / noticias)
   ========================================================= */
.card-servicio,
.card-noticia {
  position: relative;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, #fbf8f3 100%);
  border: 1px solid rgba(214, 195, 159, 0.9);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 2.75rem 2rem 2rem;
  transition: transform 200ms ease, box-shadow 200ms ease;
  overflow: hidden;
}

.card-servicio::before,
.card-noticia::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 5.5rem;
  height: 5.5rem;
  background: linear-gradient(135deg, rgba(209, 144, 46, 0.9) 0, rgba(209, 144, 46, 0.9) 50%, transparent 50%);
  opacity: 0.92;
}

.card-servicio:hover,
.card-noticia:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(18, 37, 64, 0.18);
}

.card-servicio h2,
.card-servicio h3,
.card-noticia h2,
.card-noticia h3 {
  font-size: 1.25rem;
  margin-bottom: 0.5rem;
  margin-top: 0;
  position: relative;
  z-index: 1;
  padding-left: 1.45rem;
  padding-top: 0.2rem;
}

.post-type-archive-servicio .container,
.post-type-archive-noticia .container {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 1rem;
}

.post-type-archive-servicio #primary.site-main,
.post-type-archive-servicio .site-main,
.post-type-archive-servicio #primary {
  padding-bottom: 0.5rem;
}

.post-type-archive-servicio .ast-container,
.post-type-archive-servicio .site-content > .ast-container {
  margin-top: 0 !important;
}

.post-type-archive-noticia #primary.site-main,
.post-type-archive-noticia .site-main,
.post-type-archive-noticia #primary {
  padding-bottom: 0.5rem;
}

.post-type-archive-noticia .ast-container,
.post-type-archive-noticia .site-content > .ast-container {
  margin-top: 0 !important;
}

.post-type-archive-servicio .card-servicio {
  padding: 2rem 1.25rem 1.2rem;
  min-height: 100%;
}

.post-type-archive-servicio .card-servicio h2,
.post-type-archive-servicio .card-servicio h3 {
  font-size: 0.96rem;
  line-height: 1.25;
  margin-bottom: 0.7rem;
  padding-left: 1.7rem;
  padding-right: 0.35rem;
  padding-top: 0.55rem;
  min-height: 3.7rem;
}

.post-type-archive-servicio .card-servicio .card-excerpt {
  font-size: 0.88rem;
  line-height: 1.6;
}

.post-type-archive-servicio .card-servicio .card-excerpt p {
  margin-bottom: 0;
}

.post-type-archive-servicio .servicios-grid {
  align-items: stretch;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
}

.post-type-archive-servicio .card-servicio .button {
  margin-top: auto;
  padding: 0.58rem 1.05rem;
  font-size: 0.82rem;
}

@media (min-width: 1280px) {
  .post-type-archive-servicio .servicios-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 1024px) and (max-width: 1279px) {
  .post-type-archive-servicio .servicios-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  .post-type-archive-servicio .servicios-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 767px) {
  .post-type-archive-servicio .servicios-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr)) !important;
  }
}

.post-type-archive-servicio .navigation.pagination,
.post-type-archive-noticia .navigation.pagination {
  display: none;
}

/* =========================================================
   Contact section
   ========================================================= */
.contacto-info {
  background: linear-gradient(180deg, #faf3e8 0%, var(--color-brand-light) 100%);
  border-radius: var(--radius-card);
  padding: 2rem;
  margin-bottom: 2rem;
  border: 1px solid rgba(209, 144, 46, 0.22);
}

.contacto-info a {
  color: var(--color-brand-dark);
  font-weight: 600;
}

/* =========================================================
   Contact Form 7 overrides
   ========================================================= */
.wpcf7-form label {
  display: block;
  font-weight: 600;
  margin-bottom: 0.35rem;
  color: var(--color-brand-dark);
}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea {
  width: 100%;
  border: 1.5px solid var(--color-border);
  border-radius: 8px;
  padding: 0.65rem 0.9rem;
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--color-text);
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 8px 18px rgba(18, 37, 64, 0.06);
  transition: border-color 150ms ease;
  box-sizing: border-box;
}

.wpcf7-form input:focus,
.wpcf7-form select:focus,
.wpcf7-form textarea:focus {
  border-color: var(--color-brand-mid);
  outline: none;
  box-shadow: 0 0 0 4px rgba(28, 53, 89, 0.08);
}

.wpcf7-form .cf7-field-group {
  margin-bottom: 1.25rem;
}

.wpcf7-form .cf7-rgpd {
  margin: 1rem 0;
  font-size: 0.9rem;
}

.wpcf7-form .h-captcha,
.wpcf7-form .hcaptcha {
  margin: 1rem 0 1.25rem;
}

/* =========================================================
   Footer
   ========================================================= */
.site-footer {
  position: relative;
  background:
    linear-gradient(135deg, rgba(209, 144, 46, 0.95) 0, rgba(209, 144, 46, 0.95) 7rem, transparent 7rem),
    linear-gradient(180deg, var(--color-brand-ink) 0%, var(--color-brand-dark) 100%);
  color: var(--color-brand-light);
  padding: 0.7rem 2rem;
  border-top: 0;
}

.site-below-footer-wrap {
  background: transparent !important;
  border-top: none;
  padding-top: 0;
  padding-bottom: 0;
  width: 100% !important;
  max-width: none !important;
}

.site-below-footer-wrap .ast-builder-grid-row-container-inner,
.site-below-footer-wrap .ast-builder-footer-grid-columns,
.site-below-footer-wrap .ast-builder-grid-row,
.site-below-footer-wrap .site-footer-section,
.site-below-footer-wrap .ast-builder-layout-element,
.site-below-footer-wrap .ast-footer-copyright {
  background: transparent !important;
  background-color: transparent !important;
  width: 100% !important;
  max-width: none !important;
  flex: 0 0 100% !important;
  justify-content: center !important;
  box-shadow: none !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

.site-footer a {
  color: var(--color-brand-gold);
}

.site-footer a:hover {
  color: #fff;
}

.ast-footer-copyright,
.ast-footer-copyright p {
  color: rgba(245, 237, 225, 0.92) !important;
  text-align: center;
  font-size: 0.88rem;
  line-height: 1.2;
  margin: 0 !important;
}

.site-footer .ast-footer-copyright {
  display: none;
}

.goiclex-footer-injected {
  width: 100%;
  display: flex;
  justify-content: center;
  padding-top: 0.1rem;
}

.goiclex-footer-signoff {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.2rem;
}

.goiclex-footer-signoff p {
  margin: 0 !important;
}

.goiclex-footer-signoff p:first-child {
  font-weight: 600;
  letter-spacing: 0.04em;
}

.goiclex-footer-signoff p:nth-child(2) a {
  color: var(--color-brand-gold) !important;
  text-decoration: none;
}

.goiclex-footer-signoff p:nth-child(2) a:hover {
  color: #fff !important;
}

.goiclex-footer-signoff p:last-child {
  color: rgba(209, 144, 46, 0.96) !important;
  font-style: italic;
}

.entry-content > .site-hero + div,
.entry-content > div[style*="background:#f5ede1"] {
  box-shadow: none;
}

.home .entry-header,
.home .entry-title {
  display: none !important;
}

.page-id-21 .entry-header,
.page-id-21 .entry-title {
  display: none !important;
}

.page-id-21 .entry-content > div > h1:first-child {
  display: none !important;
}

.page-id-22 .entry-header,
.page-id-22 .entry-title {
  display: none !important;
}

.page-id-22 .entry-content > div:first-child {
  padding-top: 1.4rem !important;
  padding-bottom: 1.6rem !important;
}

.page-id-22 .entry-content > div:first-child > h1:first-child {
  margin-bottom: 0.8rem;
}

.page-id-22 .entry-content > div:first-child > p {
  margin-bottom: 0;
}

.page-id-22 .entry-content .wpcf7 {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(214, 195, 159, 0.9);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  padding: 1.4rem;
}

.page-id-22 .entry-content > div:first-child > div > div:first-child {
  box-shadow: var(--shadow-card);
}

.page-id-22 .entry-content > div:first-child > div > div:first-child h3 {
  margin-bottom: 1rem;
}

.page-id-22 .entry-content > div:first-child > div > div:first-child p {
  margin-bottom: 0.8rem;
  line-height: 1.55;
}

.page-id-22 .entry-content > div:first-child > div > div:first-child p:nth-of-type(5) {
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(209, 144, 46, 0.28);
  border-radius: 14px;
  padding: 0.9rem 1rem;
  color: var(--color-brand-dark);
  font-weight: 600;
}

.page-id-22 .entry-content > div:first-child > div > div:first-child p:nth-of-type(5) strong {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-brand-mid);
}

/* =========================================================
   Mobile menu
   ========================================================= */
.ast-mobile-popup-drawer .ast-mobile-header-wrap,
.ast-mobile-popup-content,
.ast-mobile-popup-content .ast-builder-menu-mobile,
.ast-mobile-popup-content .main-navigation,
.ast-mobile-popup-content #ast-hf-mobile-menu,
.ast-mobile-popup-content .main-header-menu,
.ast-mobile-header-content,
.ast-mobile-header-wrap .main-header-bar,
.ast-mobile-popup-overlay {
  background:
    linear-gradient(135deg, rgba(209, 144, 46, 0.96) 0, rgba(209, 144, 46, 0.96) 5.5rem, transparent 5.5rem),
    linear-gradient(180deg, #132846 0%, #10233d 100%) !important;
}

.ast-mobile-popup-content {
  border-top: 1px solid rgba(209, 144, 46, 0.24);
  box-shadow: 0 18px 40px rgba(13, 26, 45, 0.22);
}

.ast-mobile-popup-content .main-header-menu,
.ast-mobile-popup-content .goiclex-mobile-menu-sync {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.8rem 1rem 1.1rem;
}

.ast-mobile-popup-content .main-header-menu .menu-item > a,
.ast-mobile-popup-content .goiclex-mobile-menu-sync .menu-item > a,
.ast-mobile-popup-content .page_item > a {
  color: #fff !important;
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  padding: 0.9rem 0.95rem !important;
  border: 1px solid rgba(245, 237, 225, 0.1);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.03);
}

.ast-mobile-popup-content .main-header-menu .menu-item > a:hover,
.ast-mobile-popup-content .main-header-menu .current-menu-item > a,
.ast-mobile-popup-content .goiclex-mobile-menu-sync .menu-item > a:hover,
.ast-mobile-popup-content .goiclex-mobile-menu-sync .current-menu-item > a,
.ast-mobile-popup-content .page_item > a:hover,
.ast-mobile-popup-content .current-menu-item > a {
  color: var(--color-brand-gold) !important;
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(209, 144, 46, 0.34);
}

.ast-mobile-popup-content .sub-menu {
  margin-top: 0.45rem;
  padding-left: 0.4rem;
}

.ast-mobile-popup-content .menu-toggle-close,
.ast-mobile-popup-content .ast-mobile-menu-trigger-minimal,
.ast-mobile-header-wrap .menu-toggle {
  color: #fff !important;
}

/* =========================================================
   Floating WhatsApp button
   ========================================================= */
.whatsapp-float {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: 9999;
  background: #25d366;
  color: #fff;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 24px rgba(37, 211, 102, 0.45);
  text-decoration: none;
  transition: transform 160ms ease, box-shadow 160ms ease;
}

.whatsapp-float:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 32px rgba(37, 211, 102, 0.60);
  color: #fff;
}

.whatsapp-float svg {
  width: 32px;
  height: 32px;
  fill: #fff;
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 768px) {
  .site-logo-img .custom-logo {
    max-height: 46px;
  }

  .ast-primary-header-bar {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }

  .whatsapp-float {
    bottom: 18px;
    right: 18px;
    width: 52px;
    height: 52px;
  }

  .whatsapp-float svg {
    width: 26px;
    height: 26px;
  }

  .post-type-archive-servicio .container {
    padding: 0 0.85rem;
  }

  .post-type-archive-servicio .card-servicio {
    padding: 1.55rem 1rem 1rem;
  }

  .post-type-archive-servicio .card-servicio h2,
  .post-type-archive-servicio .card-servicio h3 {
    min-height: 0;
    padding-left: 1.45rem;
    padding-top: 0.45rem;
  }
}


