/*
Theme Name: JQ Theme
Author: Álvaro Parra Caro
Description: Basic theme for JQ Asesores
Version: 1.0
Text Domain: jq-theme
*/

/* ===================== FONTS ===================== */
@font-face {
  font-family: "Josefin Sans";
  src: local("Josefin Sans"),
       url("../fonts/Josefin_Sans/JosefinSans-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 700;        /* Rango variable habitual */
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Josefin Sans";
  src: local("Josefin Sans Italic"),
       url("../fonts/Josefin_Sans/JosefinSans-Italic-VariableFont_wght.ttf") format("truetype");
  font-weight: 100 700;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Kalam";
  src: local("Kalam Regular"),
       url("../fonts/Kalam/Kalam-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Kalam";
  src: url("../fonts/Kalam/Kalam-Light.ttf") format("truetype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Kalam";
  src: url("../fonts/Kalam/Kalam-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ===================== BASE ===================== */
body {
  margin: 0;
  font-family: 'Josefin Sans', sans-serif;
  line-height: 1.6;
  background: #fff;
  color: #222;
  
}

h1, h2 {
  font-size: 2rem;
  margin-bottom: 1rem;
}

p {
  margin-bottom: 1rem;
}

section {
  padding: 24px 8px;
  margin: 0 auto;
}

.container {
  max-width: 800px;
  margin: 0 auto;
  padding: 48px 24px;
}

.container-full {
  max-width: 100%;
  padding: 48px 24px;
}

@media screen and (min-width: 960px) {
  .container {
    max-width: 960px;
    padding:64px 48px;
  }
  .container-full{
    padding:64px 48px;
  }
}
/* ===================== Button reset ===================== */

button,
[type="button"],
[type="submit"],
[type="reset"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce .checkout-button,
.woocommerce .wc-proceed-to-checkout a.checkout-button {
  -webkit-appearance: none;
  appearance: none;
  background: none;
  border: 0;
  padding: 0;
  margin: 0;
  font: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  color: inherit;
  text-align: inherit;
  text-transform: none;
  box-shadow: none;
  border-radius: 0;
  cursor: pointer;
}

button::-moz-focus-inner {
  border: 0;
  padding: 0;
}

button:disabled,
[type="button"]:disabled,
[type="submit"]:disabled,
[type="reset"]:disabled {
  cursor: not-allowed;
  opacity: .6;
}

/* ===================== HEADER ===================== */
.site-header {
  padding: 1rem 0;
}

.container.header-container {
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}

.site-logo img {
  max-width: 150px;
}

.site-navigation-account {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap:2rem;
}

.site-navigation {
  display: flex;
  flex: 1;
  justify-content: center;
}

.nav-menu {
  display: flex;
  list-style: none;
  gap: 1rem;
  padding: 0;
  margin: 0;
}

.nav-menu a {
  text-decoration: none;
  color: #333;
}

.nav-menu a:hover,
.nav-menu a:focus {
  color: #f7941c;
}

.site-account {
  flex-shrink: 0;
}

.site-account a {
  text-decoration: none;
  color: #333;
}

.site-account a:hover,
.site-account a:focus {
  color: #f7941c;
}
/* ===================== SECCION 0 - INTRO ===================== */

.jqbiz-top {
  background-color: #eee;
  color: #333;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap:16px;
}
.jqbiz-top h1{
  font-size:21px;
  padding:0;
  margin:0;
}
.jqbiz-top p{
  font-size:18px;
  margin:0;
  padding:0;
}

/* ===================== SECCION 1 - HERO ===================== */

.jqbiz-hero {
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.jqbiz-hero .title {
  font-family: "Kalam", "Segoe Print", "Comic Sans MS";
  font-style: italic;
  font-weight: 700;
}

.subline {
  width: 160px;
}

.hero-media {
  width: 90%;
  position: relative;
  margin-top: 12px;
}

.hero-image {
  width: 100%;
  height: auto;
  position: relative;
  z-index:1;
}

.adornment {
  position: absolute;
  pointer-events: none;
}

.adornment.top {
  top: -16px;
  left: 50%;
  right: 50%;
  transform: translate(-50%, -50%);
  width: 120px;
}

.adornment.drops {
  top: -20px;
  left: -22px;
  width: 40px;
  height: 34px;
}

.hero-media::before {
  content: '';
  position: absolute;
  z-index: 0;
  width: clamp(120px, 24vw, 410px);
  height: clamp(120px, 24vw, 410px);
  background: #eeee;
  left: -32px;
  bottom: 21%;
  filter: drop-shadow(0 6px 12px rgba(0, 0, 0, .06));
  border-radius: 50%;
}

.hero-media::after {
  content: '';
  position: absolute;
  z-index: 0;
  width: clamp(110px, 18vw, 380px);
  height: clamp(110px, 18vw, 380px);
  background: #feebc2;
  right: 18px;
  top: -30px;
  filter: drop-shadow(0 6px 12px rgba(0, 0, 0, .06));
  border-radius: 50%;
}

.hero-cta {
  background-color: #f7941c;
  width:100%;
  max-width: 520px;
  color:#333;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap:24px;
  padding:16px 24px;
  margin-top:-8px;
}

.hero-cta-demo {
  display: flex;
  align-items: center;
}
.hero-cta-demo a {
  border:2px solid #333;
  background-color:#f7941c;
  color:#333;
  text-decoration: none;
  padding:12px 24px 7px 24px;
  margin:0;
  font-size:18px;
  font-weight: 700;
}

.hero-cta-demo a:hover,
.hero-cta-demo a:focus {
  background-color: #333;
  color: #f7941c;
  text-decoration:none;
}

.hero-cta-buy {
  display:flex;
  align-items: center;
  flex-direction: column;
  gap:12px;
  font-weight: 700;
}

.hero-cta-buy p {
  color:#333;
  font-size:18px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-align: left;
  line-height: 1.3;
  min-height: calc(2 * 1.3em);
  margin:0;
}

.hero-cta-buy button {
  background-color: #f3751d;
  color: #333;
  border: 2px solid #f3751d;
  padding: 12px 24px;
  cursor: pointer;
  font-size:18px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
}

.hero-cta-buy button:hover, 
.hero-cta-buy button:focus {
  background-color: #333;
  color: #f3751d;
  border-color:#333;
}

@media screen and (min-width: 768px) {
  .hero-media::before {
    left: -48px;
    bottom: 18%;
  }

  .hero-cta {
    max-width: 520px;
    gap:32px;
    padding:24px 32px;
  }

  .hero-cta-buy p {
    font-size:21px;
  }
  .hero-cta-buy {
    flex-direction: row;
    justify-content: space-between;
    gap:24px;
  }

}

@media screen and (min-width: 960px) {
  .subline {
    width: 240px;
  }
  .hero-media {
    width: 100%;
    margin-top: 24px;
  }
  .hero-media::before {
    left: -100px;
    bottom: 15%;
  }
  .hero-media::after {
    right: 21px;
    top: -50px;
  }
  .adornment.drops {
    top: -40px;
    left: -45px;
    width: 80px;
    height: 67px;
  }
}
/* ===================== SECTION 2: STORY ===================== */

.jqbiz-story {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap:24px;
  border-top:1px solid #a1a1a1;
}

.jqbiz-story > h2 {
  font-size:24px;
  font-weight: 700;
  padding:0;
  margin:0;
}

.jqbiz-story-block-container {
  display:flex; 
  flex-direction:column;
  gap:32px;
  align-items:stretch; 
}

.jqbiz-story-block {
  text-align:center;
  display: flex;
  align-items: center;
  gap:12px;
}

.jqbiz-story-block img {
  width: 100px;
  height: auto;
  margin: 0 auto;            
}

.jqbiz-story-block h3 {
  margin: 0;
  font-size: 21px;
}

.jqbiz-story-block p {
  margin: 0;
  font-size:14px;
}
.jqbiz-story-block p:nth-of-type(1) {
  font-weight: 300;
}

.jqbiz-story-block p:nth-of-type(2) {
  font-style:italic;
  font-weight:700;
}
@media screen and (min-width: 960px) {
  .jqbiz-story-block-container {
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    column-gap:24px;
    row-gap:8px;  
    align-items:start;
  }
}

@supports (grid-template-rows: subgrid) {
  .jqbiz-story-block-container {
    grid-template-rows: repeat(4, auto);
  }

  .jqbiz-story-block {
    display: grid;
    grid-template-rows: subgrid; /* hereda las 4 filas */
    grid-row: span 4;
    justify-items: center;
    text-align: center;
  }

  .jqbiz-story-block > img { grid-row: 1; }
  .jqbiz-story-block > h3 { grid-row: 2; }
  .jqbiz-story-block > p:nth-of-type(1) { grid-row: 3; }
  .jqbiz-story-block > p:nth-of-type(2) { grid-row: 4; }
}

/* ===================== SECTION 3: BENEFITS ===================== */
.jqbiz-benefits {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background-color: #F3F3F3;
  text-align: center;
}
.jqbiz-benefits > h2 {
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 8px 0;
  padding: 0;
}
.jqbiz-benefits > p {
  font-size:16px;
  margin:0 0 32px 0;
  padding:0;
}
.jqbiz-benefit-block-container {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

.jqbiz-benefit-block {
  display: block;
  text-align: center;
  gap: 12px;
}

.jqbiz-benefit-block img {
  max-width: 240px;
}

.jqbiz-benefit-block h3 {
  font-size: 1.5rem;
  margin: 0;
}

.jqbiz-benefit-block:nth-of-type(1)  h3{
  color:#f7941c;
}

.jqbiz-benefit-block:nth-of-type(2)  h3{
  color:#f3751d;
}

.jqbiz-benefit-block ul {
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: center;
}
.jqbiz-benefit-block ul li {
  padding: 8px 0;
  font-size: 14px;
}

@media (min-width: 960px) {
  .jqbiz-benefit-block-container {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 24px;
    row-gap: 12px;
    align-items: start;
  }
}

@supports (grid-template-rows: subgrid) {
  @media (min-width: 960px) {
    .jqbiz-benefit-block-container {
      grid-template-rows: auto auto auto 1fr;
      row-gap:12px;
    }
    .jqbiz-benefit-block {
      display: grid;
      grid-template-rows: subgrid;
      grid-row: span 4; 
      justify-items: center;
      text-align: center;
      row-gap: 12px;
    }
    .jqbiz-benefit-block > img { grid-row: 1; }
    .jqbiz-benefit-block > h3 { grid-row: 2; }
    .jqbiz-benefit-block > p { grid-row: 3; }
    .jqbiz-benefit-block > ul { grid-row: 4; }
  }
}
/* ===================== MINI CTA  ===================== */
.jqbiz-mini-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin-top: 32px;
}

.jqbiz-mini-cta a {
  border:2px solid #333;
  background-color:#333;
  color:#fff;
  text-decoration: none;
  padding:12px 24px 7px 24px;
  margin:0;
  font-size:16px;
  font-weight: 700;
}

.jqbiz-mini-cta a:hover,
.jqbiz-mini-cta a:focus {
  background-color: #fff;
  color: #333;
  text-decoration:none;
}

.jqbiz-mini-cta button {
  background-color: #fff;
  color: #333;
  border: 2px solid #333;
  padding: 12px 24px 7px 24px;
  cursor: pointer;
  font-size:16px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
}

.jqbiz-mini-cta button:hover, 
.jqbiz-mini-cta button:focus {
  background-color: #333;
  color: #fff;
  border-color:#333;
}

/* ===================== SECTION 4: POWER ===================== */
.jqbiz-power {
  display: flex;
  flex-direction: column;
  gap: 24px;
  text-align: center;
  border-top: 1px solid #e5e5e5;
}

.jqbiz-highlights {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 12px;
}

.jqbiz-highlights li {
  display: grid;
  grid-template-columns: 40px 1fr;
  align-items: center;
  gap: 8px;
  background: #fff;
  border: 1px solid #e9e9e9;
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: 0 6px 12px rgba(0,0,0,.04);
  text-align: left;
}

.jqbiz-highlights .hi-emoji {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 2px solid #333;
  font-size: 18px;
}

.jqbiz-highlights strong {
  font-size: 16px;
}

.jqbiz-highlights small {
  display: block;
  color: #666;
  font-size: 12px;
  margin-top: 2px;
}

.jqbiz-pill-list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  padding: 0;
  margin: 0;
}

.jqbiz-pill-list li {
  border: 1px solid #ddd;
  background: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
}

.jqbiz-quote {
  margin: 8px auto 0;
  max-width: 720px;
}

.jqbiz-quote blockquote {
  position: relative;
  margin: 0;
  padding: 16px 16px 16px 48px;
  background: #F8FBFD;
  border: 1px solid #e6eef2;
  border-radius: 12px;
  text-align: left;
}

.jqbiz-quote blockquote::before {
  content: "“";
  position: absolute;
  left: 14px;
  top: -8px;
  font-family: "Kalam", "Josefin Sans", sans-serif;
  font-size: 56px;
  line-height: 1;
  color: #f7941c;
}

.jqbiz-quote figcaption {
  font-size: 13px;
  color: #666;
  margin-top: 8px;
  text-align: right;
}

.jqbiz-note {
  font-size: 12px;
  color: #777;
  margin: -8px 0 0;
}


/* ===================== SECTION 5, 6 y 7 General ===================== */
/* Base de sección compartida */
.g4p-formation,
.g4p-communication,
.g4p-usa{
  position: relative;
  padding: clamp(2rem, 3vw, 4rem) 0;
  color: #111;
}

.g4p-formation h2,
.g4p-communication h2,
.g4p-usa h2{
  margin: 0 0 .75rem;
  line-height: 1.15;
}

.g4p-formation h2::after,
.g4p-communication h2::after,
.g4p-usa h2::after{
  content:"";
  display:block;
  width:64px; height:3px;
  background: #f7941c;
  border-radius: 2px;
  margin-top:.5rem;
}

/* Grids reutilizables */
.g4p-two-col{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap: 1.25rem;
}
.g4p-three-col{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(240px,1fr));
  gap: 1.25rem;
}

/* Tarjeta/panel reutilizable */
.g4p-panel{
  background: #fff;
  border:1px solid #e6e6e6;
  border-radius: 16px;
  padding: 1rem .95rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.g4p-panel:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,0,0,.08);
  border-color: #bad0c6; /* mezcla aproximada de #f7941c con #e6e6e6 al 20% */
}

/* Listas con icono personalizado (variantes: check y dash) */
.g4p-list{ list-style: none; padding:0; margin:.25rem 0 0; }
.g4p-list li{
  position:relative;
  padding-left: 1.4rem;
  margin:.35rem 0;
  color: #111;
}
.g4p-list--check li::before,
.g4p-list--dash  li::before{
  content:"";
  position:absolute; left:.15rem; top:.6em;
  width:.55rem; height:.55rem; border-radius:999px;
  background: #f7941c;
}
.g4p-list--dash li::before{
  width:.6rem; height:2px; top:.85em; border-radius:2px;
}

/* Nota/aclaración */
.g4p-note{
  font-size:.95rem;
  color: #666;
}

/* Links destacados dentro de tarjetas */
.g4p-panel a{
  text-decoration: underline;
  text-underline-offset: 2px;
}
/* ===================== SECTION 5: Formación y Tecnificación ===================== */
.g4p-formation{
  background: linear-gradient(0deg, #f8fbf9, #ffffff);
  border-top: 3px solid #f4751d; /* mezcla aprox. 45% de #f7941c con blanco */
}
.g4p-formation .g4p-two-col > div{
  background: #fff;
  border:1px solid #e6e6e6;
  border-radius: 16px;
  padding: 1rem .95rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.g4p-formation .g4p-two-col > div:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,0,0,.08);
  border-color: #bad0c6;
}
.g4p-formation h3{
  margin:.2rem 0 .5rem;
  font-weight: 700;
}
.g4p-formation ul{ margin:.25rem 0 0; }
.g4p-formation .g4p-two-col ul{
  list-style: none; padding:0; margin:.25rem 0 0;
}
.g4p-formation .g4p-two-col ul li{
  position:relative; padding-left:1.4rem; margin:.35rem 0; color:#111;
}
.g4p-formation .g4p-two-col ul li::before{
  content:""; position:absolute; left:.15rem; top:.6em;
  width:.55rem; height:.55rem; border-radius:999px; background:#f7941c;
}

/* Franja lateral decorativa */
.g4p-formation::before{
  content:"";
  position:absolute; inset: 0 auto 0 0;
  width:6px; border-radius: 0 6px 6px 0;
  background: linear-gradient(180deg, #f7941c, #075a33);
  opacity:.12;
}
/* ===================== SECTION 6: Comunicación, Marketing & Sponsoring ===================== */

.g4p-communication{
  background:#ffffff;
}
.g4p-communication .g4p-three-col > div{
  background: #fff;
  border:1px solid #e6e6e6;
  border-radius: 16px;
  padding: 1rem .95rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
  display:flex; flex-direction: column; gap:.35rem;
  min-height: 180px;
}
.g4p-communication .g4p-three-col > div:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,0,0,.08);
  border-color: #b6cec3; /* mezcla aprox. 22% #f7941c con #e6e6e6 */
}
.g4p-communication h3{
  margin:0 0 .25rem;
  display:inline-flex; align-items:center; gap:.5rem;
}
.g4p-communication h3::before{
  content:""; width:.6rem; height:.6rem; border-radius:999px;
  background: #f7941c;
  box-shadow: 0 0 0 6px #e2efe9; /* halo suave (≈12% de #f7941c con blanco) */
}
.g4p-communication p{ color: #666; }

/* ===================== SECTION 7: Carrera de fútbol en EEUU – Goals4Players4EEUU ===================== */
.g4p-usa{
  background: linear-gradient(135deg, #f7f9ff 0%, #ffffff 55%);
  border-top: 1px solid #e6e6e6;
}
.g4p-usa .g4p-two-col > div{
  background: #fff;
  border:1px solid #e6e6e6;
  border-radius: 16px;
  padding: 1rem .95rem;
  box-shadow: 0 4px 16px rgba(0,0,0,.06);
  transition: box-shadow .2s ease, transform .2s ease, border-color .2s ease;
}
.g4p-usa .g4p-two-col > div:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(0,0,0,.08);
  border-color: #bad0c6;
}
.g4p-usa h3{ margin:.15rem 0 .45rem; }
.g4p-usa .g4p-two-col ul{
  list-style:none; padding:0; margin:.25rem 0 0;
}
.g4p-usa .g4p-two-col ul li{
  position:relative; padding-left:1.4rem; margin:.35rem 0; color:#111;
}
.g4p-usa .g4p-two-col ul li::before{
  content:""; position:absolute; left:.15rem; top:.85em;
  width:.6rem; height:2px; border-radius:2px; background:#f7941c;
}

/* Cinta decorativa superior (sutil) */
.g4p-usa::before{
  content:"";
  position:absolute; left:0; right:0; top:0; height:8px;
  background: linear-gradient(90deg, #f7941c 0%, #85bca2 35%, #ffffff 60%, #85bca2 85%, #f7941c 100%);
  opacity:.12;
}

/* CTA dentro de la sección USA */
.g4p-usa .btn, .g4p-usa .jqbiz-btn{
  border-color: #f7941c;
}
.g4p-usa .btn:hover, .g4p-usa .jqbiz-btn:hover{
  filter: brightness(.98);
}

/* Responsive finos */
@media (max-width: 900px){
  .g4p-formation h2,
  .g4p-communication h2,
  .g4p-usa h2{
    margin-bottom: .5rem;
  }
  .g4p-formation::before{ width:4px; }
}

/* Accesibilidad: reduce motion */
@media (prefers-reduced-motion: reduce){
  .g4p-panel,
  .g4p-communication .g4p-three-col > div{
    transition: none;
  }
}

/* ===================== SECTION 8: FINAL CTA ===================== */
.jqbiz-final-cta {
  text-align: center;
  background: linear-gradient(180deg, #F8FBFD 0%, #F7FFF4 100%);
  border-top: 1px solid #e6e6e6;
}

.jqbiz-offer {
  background: #fff;
  border: 1px solid #eaeaea;
  border-radius: 16px;
  padding: 24px;
  max-width: 860px;
  margin: 12px auto 0;
  box-shadow: 0 10px 20px rgba(0,0,0,.04);
}

.jqbiz-ticks {
  list-style: none;
  padding: 0;
  margin: 0 0 8px 0;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  justify-content: center;
}

.jqbiz-ticks li {
  font-size: 14px;
}

.jqbiz-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  align-items: center;
  margin: 12px 0 8px;
}

.jqbiz-btn {
  border: 2px solid #333;
  background: #fff;
  color: #333;
  text-decoration: none;
  padding: 12px 24px 7px 24px;
  font-size: 16px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.jqbiz-btn--ghost:hover,
.jqbiz-btn--ghost:focus {
  background: #333;
  color: #fff;
}

.jqbiz-btn--primary {
  background: #f3751d;
  border-color: #f3751d;
  color: #333;
}

.jqbiz-btn--primary:hover,
.jqbiz-btn--primary:focus {
  background: #333;
  color: #f3751d;
  border-color: #333;
}

.jqbiz-legal {
  font-size: 12px;
  color: #666;
  margin: 4px 0 0;
}

.jqbiz-faqs {
  margin-top: 16px;
  text-align: left;
}

.jqbiz-faqs details {
  border: 1px solid #eaeaea;
  border-radius: 10px;
  padding: 10px 12px;
  background: #fff;
  margin: 8px 0;
}

.jqbiz-faqs summary {
  cursor: pointer;
  font-weight: 700;
  list-style: none;
}

.jqbiz-faqs summary::-webkit-details-marker { display: none; }

.jqbiz-faqs details[open] {
  background: #F9FBF9;
  border-color: #dfeadf;
}

.jqbiz-cta-foot {
  margin-top: 16px;
  font-size: 14px;
  color: #333;
}

@media (min-width: 960px) {
  .jqbiz-offer { padding: 32px; }
  .jqbiz-stat-num { font-size: 32px; }
}


/* ===================== FOOTER ===================== */
.site-footer {
  background: #111;               /* oscuro elegante */
  color: #eee;
  border-top: 4px solid #f7941c;  /* acento de marca */
}

.container.footer-container {
  display: grid;
  gap: 16px;
  align-items: center;
  text-align: center;
}

.footer-brand p {
  margin: 0;
}

.footer-brand strong {
  color: #f7941c;
}

/* Menú del pie: hereda .nav-menu base y lo adaptamos al fondo oscuro */
.site-footer .nav-menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 16px;
  padding: 0;
  margin: 0;
}

.site-footer .footer-nav a {
  color: #eee;
  text-decoration: none;
  padding: 4px 0;
  border-bottom: 2px solid transparent;
}

.site-footer .footer-nav a:hover,
.site-footer .footer-nav a:focus {
  color: #f7941c;
  border-bottom-color: #f7941c;
}

/* Accesibilidad: enfoque visible y helper "visually-hidden" */
.site-footer a:focus-visible {
  outline: 2px dashed #f3751d;
  outline-offset: 2px;
}

.visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* Layout en escritorio: texto a la izquierda, menú a la derecha */
@media (min-width: 960px) {
  .container.footer-container {
    grid-template-columns: 1fr auto;
    text-align: left;
  }
  .footer-nav .nav-menu { justify-content: flex-end; }
}


/*******************************************
*************** WOOCOMMERCE *****************
********************************************/

/* ===== Página genérica ===== */
.jqbiz-page__title { margin:0 0 8px 0; font-size:28px; }
.jqbiz-page__lead { margin:0; color:#555; }

/* ===== Grids ===== */
.jq-grid-2 { display:grid; gap:16px; }
@media (min-width:960px){ .jq-grid-2{ grid-template-columns: 1fr 360px; gap:24px; } }

.jq-grid-3 { display:grid; gap:16px; }
@media (min-width:960px){ .jq-grid-3{ grid-template-columns: repeat(3,1fr); gap:24px; } }

.jq-flex-column { display: flex; flex-direction: column; gap:24px; }

/* ===== Cards ===== */
.jq-card { background:#fff; border:1px solid #eaeaea; border-radius:16px; box-shadow:0 6px 12px rgba(0,0,0,.04); }
.jq-card__title { margin:0; padding:16px 18px; border-bottom:1px solid #eee; font-size:18px; }
.jq-card__body { padding:16px 18px; }
.jq-card__foot { padding:16px 18px; border-top:1px solid #eee; }

/* sticky sidebar */
.jq-sticky { position: sticky; top: 16px; }

/* ===== Notices ===== */
.jq-notice { padding:12px 14px; border-radius:12px; margin:8px 0; font-size:14px; }
.jq-notice--info { background:#F8FBFD; border:1px solid #e6eef2; }
.jq-notice--ok { background:#F7FFF4; border:1px solid #dfeadf; }
.jq-notice--warn { background:#fff7e6; border:1px solid #ffe4b5; }

/* ===== Tabla flexible (cart) ===== */
.jq-table { display: grid; gap:12px; }
.jq-row { display:grid; grid-template-columns: 72px 1fr auto; gap:12px;
  background:#fff; border:1px solid #e9e9e9; border-radius:14px; padding:12px; align-items:center; }
.jq-row__thumb { width:72px; height:72px; object-fit:cover; border-radius:10px; }
.jq-row__title { margin:0 0 4px 0; font-size:16px; }
.jq-row__meta { color:#666; }
.jq-row__qty { display:inline-flex; gap:8px; align-items:center; margin-top:6px; }
.jq-row__price { font-weight:700; white-space:nowrap; }
.jq-row__remove .link { text-decoration:underline; color:#333; }
@media (max-width: 480px) {
  .jq-row { grid-template-columns: 64px 1fr; }
  .jq-row__price, .jq-row__remove { grid-column: 2; }
}

/* ===== Totales ===== */
.jq-totals { display:grid; gap:8px; }
.jq-totals > div { display:flex; justify-content:space-between; align-items:center; }
.jq-totals__total { border-top:1px solid #eee; padding-top:8px; font-size:18px; }

/* ===== Formulario genérico ===== */
.jq-form .form-row, .jq-form .woocommerce-billing-fields__field,
.jq-form .woocommerce-shipping-fields__field { margin-bottom:12px; }
.jq-form label { display:block; margin-bottom:6px; font-weight:700; }
.jq-form input[type="text"], .jq-form input[type="email"], .jq-form input[type="tel"],
.jq-form input[type="number"], .jq-form select, .jq-form textarea {
  width:100%; padding:10px 12px; border:1px solid #ddd; border-radius:10px; background:#fff; font:inherit;
}
.jq-form .woocommerce-invalid input, .jq-form .woocommerce-invalid select { border-color:#e96d6d; }



/***** Ajustes mínimos para las nuevas secciones (reutiliza las clases jqbiz-*) *****/
.g4p-tagline { font-weight: 400; font-size: .8em; margin-left: .5rem; }
.g4p-two-col { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap: 1.25rem; }
.g4p-three-col { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 1.25rem; }

.g4p-players { margin-top: 2rem; }
.g4p-player-card { display: grid; grid-template-columns: 320px 1fr; gap: 1.25rem; align-items: start; background: #fff; border-radius: 16px; padding: 1rem; box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.g4p-player-card .g4p-player-media img { width: 100%; height: auto; border-radius: 12px; object-fit: cover; }
.g4p-player-body h3 { margin: 0 0 .25rem; }
.g4p-player-bio { margin: .5rem 0 1rem; }
.g4p-player-data { margin: 0 0 1rem; padding-left: 1rem; }
.g4p-player-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap: .75rem; margin-top: 1.5rem; }
.g4p-player-item { background: #fff; border-radius: 12px; padding: .75rem; text-align: center; box-shadow: 0 2px 10px rgba(0,0,0,.05); }
.g4p-player-item img { width: 100%; height: 160px; object-fit: cover; border-radius: 10px; margin-bottom: .5rem; }
.g4p-mini-link { font-size: .9rem; text-decoration: underline; }

.g4p-contact-form { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .75rem 1rem; margin-top: 1rem; }
.g4p-contact-form .g4p-form-row--full { grid-column: 1 / -1; }
.g4p-contact-form label { display: block; font-size: .95rem; margin-bottom: .25rem; }
.g4p-contact-form input[type="text"],
.g4p-contact-form input[type="email"],
.g4p-contact-form input[type="tel"],
.g4p-contact-form select,
.g4p-contact-form textarea { width: 100%; border: 1px solid #e6e6e6; border-radius: 10px; padding: .6rem .7rem; }
.g4p-consent { grid-column: 1 / -1; font-size: .9rem; }
.g4p-form-success { background: #e9f9f0; border: 1px solid #b7f0d0; color: #f7941c; padding: .6rem .8rem; border-radius: 10px; margin: 1rem 0; }
.g4p-form-error { background: #fdecea; border: 1px solid #f5c2c0; color: #7a0b0b; padding: .6rem .8rem; border-radius: 10px; margin: 1rem 0; }
.g4p-hp { display: none !important; }

.g4p-call-btn, .g4p-contact-btn { display: inline-block; padding: .85rem 1.1rem; border-radius: 999px; background: #111; color: #fff; }
.g4p-contact-btn { background: transparent; border: 1px solid #111; color: #111; margin-left: .5rem; }

@media (max-width: 900px) {
  .g4p-player-card { grid-template-columns: 1fr; }
}