/*
Theme Name: Astra Child
Template: astra
Description: PadelGuide child theme - custom design system
*/

/* ============================================================
   GOOGLE FONTS
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Instrument+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap');

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  --pg-bg:           #f7f6f2;
  --pg-white:        #ffffff;
  --pg-black:        #111111;
  --pg-accent:       #1e6ba8;
  --pg-accent-dark:  #185d92;
  --pg-accent-light: #e8f2f9;
  --pg-red:          #d63b1f;
  --pg-red-light:    #fdf0ee;
  --pg-border:       #e2e0da;
  --pg-border-dark:  #c8c5bc;
  --pg-text:         #1a1a1a;
  --pg-text-mid:     #555550;
  --pg-text-muted:   #8a8880;
  --pg-shadow-sm:    0 1px 4px rgba(0,0,0,0.06), 0 1px 2px rgba(0,0,0,0.04);
  --pg-shadow-md:    0 4px 16px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --pg-shadow-lg:    0 12px 40px rgba(0,0,0,0.10), 0 4px 8px rgba(0,0,0,0.05);
  --pg-radius:       10px;
  --pg-radius-sm:    6px;
}

/* ============================================================
   GLOBAL RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  background: var(--pg-bg);
}

body {
  font-family: 'Instrument Sans', sans-serif !important;
  background: var(--pg-bg) !important;
  color: var(--pg-text) !important;
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6,
.entry-title,
.page-title,
.site-title {
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 2px !important;
  line-height: 1.05 !important;
  color: var(--pg-black) !important;
  font-weight: 400 !important;
}

h1 { font-size: clamp(36px, 5vw, 56px) !important; }
h2 { font-size: clamp(28px, 4vw, 40px) !important; }
h3 { font-size: clamp(22px, 3vw, 30px) !important; }
h4 { font-size: 22px !important; }
h5 { font-size: 18px !important; }

/* Entry titles on archive pages */
.entry-title a {
  font-family: 'Bebas Neue', sans-serif !important;
  letter-spacing: 1.5px !important;
  color: var(--pg-black) !important;
  text-decoration: none !important;
  font-size: clamp(20px, 2.5vw, 26px) !important;
  line-height: 1.1 !important;
  transition: color 0.18s !important;
}

.entry-title a:hover {
  color: var(--pg-accent) !important;
}

/* Body text */
p, li, td, th, blockquote, figcaption {
  font-family: 'Instrument Sans', sans-serif !important;
  color: var(--pg-text-mid);
  line-height: 1.7;
}

/* Article body paragraphs */
.entry-content p {
  font-size: 16px;
  color: var(--pg-text-mid);
  margin-bottom: 1.5em;
}

/* Links */
a {
  color: var(--pg-accent);
  text-decoration: none;
  transition: color 0.18s;
}

a:hover { color: var(--pg-accent-dark); }

/* ============================================================
   HEADER & NAVIGATION
   ============================================================ */
.site-header,
#masthead,
.ast-primary-header-bar,
header.site-header {
  background: var(--pg-white) !important;
  border-bottom: 1px solid var(--pg-border) !important;
  box-shadow: var(--pg-shadow-sm) !important;
  padding: 0 !important;
}

/* Header inner */
.ast-primary-header-bar .ast-builder-grid-row,
.site-header .ast-container {
  padding: 0 40px !important;
  min-height: 68px !important;
  align-items: center !important;
}

/* Logo */
.ast-site-identity,
.site-branding {
  padding: 12px 0 !important;
}

.site-title a,
.ast-site-title a {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 28px !important;
  letter-spacing: 3px !important;
  color: var(--pg-black) !important;
  text-decoration: none !important;
}

/* Nav links */
.main-navigation a,
.ast-primary-nav > ul > li > a,
#site-navigation a,
.main-header-menu > .menu-item > a {
  font-family: 'Instrument Sans', sans-serif !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  letter-spacing: 0.3px !important;
  color: var(--pg-text-mid) !important;
  text-decoration: none !important;
  padding: 8px 14px !important;
  border-radius: var(--pg-radius-sm) !important;
  transition: all 0.18s !important;
}

.main-navigation a:hover,
.ast-primary-nav > ul > li > a:hover,
.main-header-menu > .menu-item > a:hover {
  color: var(--pg-black) !important;
  background: var(--pg-bg) !important;
}

/* Active nav item */
.main-navigation .current-menu-item > a,
.ast-primary-nav > ul > .current-menu-item > a,
.main-header-menu > .current-menu-item > a {
  color: var(--pg-accent) !important;
  background: var(--pg-accent-light) !important;
}

/* ============================================================
   PAGE LAYOUT
   ============================================================ */
.site-content,
#content,
.ast-container {
  background: var(--pg-bg) !important;
}

/* Main content max width */
.ast-page-builder-template .site-content,
.site-content .ast-container {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 0 40px !important;
}

/* ============================================================
   ARTICLE CARDS (Homepage / Archive)
   ============================================================ */
.ast-article-post,
.ast-article-inner-wrap,
article.type-post,
.post-thumbnail + .ast-blog-single-element {
  background: var(--pg-white) !important;
  border: 1px solid var(--pg-border) !important;
  border-radius: var(--pg-radius) !important;
  box-shadow: var(--pg-shadow-sm) !important;
  overflow: hidden !important;
  transition: box-shadow 0.22s, transform 0.22s, border-color 0.22s !important;
}

.ast-article-post:hover,
article.type-post:hover {
  box-shadow: var(--pg-shadow-md) !important;
  transform: translateY(-3px) !important;
  border-color: var(--pg-accent) !important;
}

/* Card image */
.ast-article-post .post-thumbnail,
article.type-post .post-thumbnail {
  overflow: hidden !important;
  border-radius: var(--pg-radius) var(--pg-radius) 0 0 !important;
}

.ast-article-post .post-thumbnail img,
article.type-post .post-thumbnail img {
  width: 100% !important;
  height: 220px !important;
  object-fit: cover !important;
  transition: transform 0.4s ease !important;
  display: block !important;
}

.ast-article-post:hover .post-thumbnail img,
article.type-post:hover .post-thumbnail img {
  transform: scale(1.03) !important;
}

/* Card body padding */
.ast-article-post .ast-blog-single-element,
.ast-article-post .entry-content-wrap,
article.type-post .entry-header,
article.type-post .entry-content {
  padding: 20px 22px !important;
}

/* Category labels */
.ast-article-post .entry-meta .category-style-simple a,
.ast-article-post .ast-terms-wrap a,
.entry-meta .cat-links a,
.cat-links a,
.ast-terms-wrap a {
  font-family: 'Instrument Sans', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--pg-accent) !important;
  background: var(--pg-accent-light) !important;
  padding: 3px 9px !important;
  border-radius: 4px !important;
  text-decoration: none !important;
  border: 1px solid transparent !important;
  transition: all 0.15s !important;
}

.cat-links a:hover,
.ast-terms-wrap a:hover {
  border-color: var(--pg-accent) !important;
  background: var(--pg-accent-light) !important;
}

/* Meta info (author, date) */
.entry-meta,
.posted-on,
.byline,
.ast-article-post .entry-meta {
  font-size: 12px !important;
  color: var(--pg-text-muted) !important;
  font-family: 'Instrument Sans', sans-serif !important;
  font-weight: 500 !important;
}

.entry-meta a {
  color: var(--pg-text-muted) !important;
}

.entry-meta a:hover {
  color: var(--pg-accent) !important;
}

/* Excerpt */
.entry-summary p,
.ast-article-post .entry-summary {
  font-size: 14px !important;
  color: var(--pg-text-mid) !important;
  line-height: 1.6 !important;
  margin: 8px 0 0 !important;
}

/* Read more link */
.read-more a,
.ast-read-more-container a,
.more-link {
  display: inline-block !important;
  font-family: 'Instrument Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.5px !important;
  color: var(--pg-accent) !important;
  text-decoration: none !important;
  margin-top: 12px !important;
  padding: 7px 14px !important;
  background: var(--pg-accent-light) !important;
  border-radius: var(--pg-radius-sm) !important;
  border: 1px solid transparent !important;
  transition: all 0.15s !important;
}

.read-more a:hover,
.more-link:hover {
  background: var(--pg-accent) !important;
  color: var(--pg-white) !important;
}

/* ============================================================
   SINGLE ARTICLE PAGE
   ============================================================ */
.single .site-content,
.single #content {
  background: var(--pg-bg) !important;
}

.single article.type-post {
  background: var(--pg-white) !important;
  border-radius: var(--pg-radius) !important;
  box-shadow: var(--pg-shadow-sm) !important;
  border: 1px solid var(--pg-border) !important;
  padding: 48px !important;
  max-width: 820px !important;
  margin: 40px auto !important;
}

/* Article featured image */
.single .post-thumbnail img {
  width: 100% !important;
  height: auto !important;
  border-radius: var(--pg-radius) !important;
  margin-bottom: 32px !important;
}

/* Article title */
.single .entry-title {
  font-size: clamp(32px, 4vw, 48px) !important;
  margin-bottom: 16px !important;
  line-height: 1.05 !important;
}

/* Article content headings */
.entry-content h2 {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 28px !important;
  letter-spacing: 1.5px !important;
  color: var(--pg-black) !important;
  margin: 40px 0 16px !important;
  padding-bottom: 10px !important;
  border-bottom: 2px solid var(--pg-border) !important;
}

.entry-content h3 {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 22px !important;
  letter-spacing: 1px !important;
  color: var(--pg-black) !important;
  margin: 32px 0 12px !important;
}

/* Blockquote */
.entry-content blockquote {
  border-left: 3px solid var(--pg-accent) !important;
  background: var(--pg-accent-light) !important;
  padding: 16px 20px !important;
  margin: 24px 0 !important;
  border-radius: 0 var(--pg-radius-sm) var(--pg-radius-sm) 0 !important;
}

.entry-content blockquote p {
  color: var(--pg-accent-dark) !important;
  font-style: italic !important;
  margin: 0 !important;
}

/* Tables */
.entry-content table {
  width: 100% !important;
  border-collapse: collapse !important;
  margin: 24px 0 !important;
  font-size: 14px !important;
  border-radius: var(--pg-radius-sm) !important;
  overflow: hidden !important;
  box-shadow: var(--pg-shadow-sm) !important;
}

.entry-content th {
  background: var(--pg-black) !important;
  color: var(--pg-white) !important;
  font-family: 'Instrument Sans', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 12px 16px !important;
  text-align: left !important;
}

.entry-content td {
  padding: 11px 16px !important;
  border-top: 1px solid var(--pg-border) !important;
  color: var(--pg-text-mid) !important;
  background: var(--pg-white) !important;
}

.entry-content tr:hover td {
  background: var(--pg-bg) !important;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.ast-button,
.button,
button,
input[type="submit"],
input[type="button"],
.wp-block-button__link {
  font-family: 'Instrument Sans', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 0.3px !important;
  background: var(--pg-black) !important;
  color: var(--pg-white) !important;
  border: none !important;
  border-radius: var(--pg-radius-sm) !important;
  padding: 11px 22px !important;
  cursor: pointer !important;
  transition: all 0.18s !important;
  text-decoration: none !important;
  display: inline-block !important;
}

.ast-button:hover,
.button:hover,
button:hover,
input[type="submit"]:hover {
  background: #333 !important;
  transform: translateY(-1px) !important;
}

/* Primary CTA button variant */
.pg-btn-primary {
  background: var(--pg-accent) !important;
  color: var(--pg-white) !important;
}

.pg-btn-primary:hover {
  background: var(--pg-accent-dark) !important;
}

/* ============================================================
   AFFILIATE BUY BUTTONS
   Used inside article content
   ============================================================ */
.pg-buy-wrap {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 24px 0;
  padding: 20px;
  background: var(--pg-bg);
  border: 1px solid var(--pg-border);
  border-radius: var(--pg-radius);
}

.pg-buy-btn {
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px !important;
  padding: 10px 16px !important;
  border-radius: var(--pg-radius-sm) !important;
  font-family: 'Instrument Sans', sans-serif !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: all 0.15s !important;
  border: none !important;
}

.pg-buy-btn .pg-store-name {
  font-size: 9px !important;
  font-weight: 700 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  opacity: 0.7 !important;
}

.pg-buy-btn .pg-price {
  font-size: 15px !important;
  font-weight: 700 !important;
}

.pg-buy-amazon {
  background: #ff9900 !important;
  color: #000 !important;
}

.pg-buy-amazon:hover { background: #e88a00 !important; }

.pg-buy-padelusa {
  background: var(--pg-accent) !important;
  color: var(--pg-white) !important;
}

.pg-buy-padelusa:hover { background: var(--pg-accent-dark) !important; }

.pg-buy-padelnuestro {
  background: transparent !important;
  border: 1.5px solid var(--pg-accent) !important;
  color: var(--pg-accent) !important;
}

.pg-buy-padelnuestro:hover {
  background: var(--pg-accent-light) !important;
}

/* ============================================================
   SIDEBAR
   ============================================================ */
.widget-area,
#secondary {
  background: transparent !important;
}

.widget {
  background: var(--pg-white) !important;
  border: 1px solid var(--pg-border) !important;
  border-radius: var(--pg-radius) !important;
  padding: 24px !important;
  margin-bottom: 24px !important;
  box-shadow: var(--pg-shadow-sm) !important;
}

.widget-title,
.widgettitle {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: 18px !important;
  letter-spacing: 2px !important;
  color: var(--pg-black) !important;
  margin-bottom: 16px !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid var(--pg-border) !important;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination,
.ast-pagination,
.page-links,
.nav-links {
  display: flex !important;
  gap: 6px !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 40px 0 !important;
  font-family: 'Instrument Sans', sans-serif !important;
}

.pagination .page-numbers,
.ast-pagination .page-numbers,
.nav-links .page-numbers {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 38px !important;
  height: 38px !important;
  border-radius: var(--pg-radius-sm) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  color: var(--pg-text-mid) !important;
  background: var(--pg-white) !important;
  border: 1px solid var(--pg-border) !important;
  text-decoration: none !important;
  transition: all 0.15s !important;
}

.pagination .page-numbers:hover,
.nav-links .page-numbers:hover {
  border-color: var(--pg-accent) !important;
  color: var(--pg-accent) !important;
  background: var(--pg-accent-light) !important;
}

.pagination .page-numbers.current,
.nav-links .page-numbers.current {
  background: var(--pg-black) !important;
  color: var(--pg-white) !important;
  border-color: var(--pg-black) !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer,
#colophon {
  background: var(--pg-black) !important;
  color: var(--pg-text-muted) !important;
  border-top: none !important;
  padding: 48px 40px 32px !important;
  margin-top: 60px !important;
}

.site-footer a {
  color: #888 !important;
  transition: color 0.15s !important;
}

.site-footer a:hover { color: var(--pg-white) !important; }

.site-footer .ast-footer-copyright {
  font-size: 13px !important;
  color: #666 !important;
  font-family: 'Instrument Sans', sans-serif !important;
}

/* ============================================================
   SEARCH
   ============================================================ */
.search-field,
input[type="search"],
input[type="text"],
input[type="email"],
textarea {
  font-family: 'Instrument Sans', sans-serif !important;
  background: var(--pg-white) !important;
  border: 1px solid var(--pg-border) !important;
  border-radius: var(--pg-radius-sm) !important;
  color: var(--pg-text) !important;
  padding: 10px 14px !important;
  font-size: 14px !important;
  transition: border-color 0.15s !important;
}

input[type="search"]:focus,
input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--pg-accent) !important;
  box-shadow: 0 0 0 3px rgba(30, 107, 168, 0.1) !important;
}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.ast-breadcrumbs,
.breadcrumb {
  font-size: 12px !important;
  font-family: 'Instrument Sans', sans-serif !important;
  color: var(--pg-text-muted) !important;
  padding: 12px 0 !important;
}

.ast-breadcrumbs a,
.breadcrumb a {
  color: var(--pg-text-muted) !important;
}

.ast-breadcrumbs a:hover { color: var(--pg-accent) !important; }

/* ============================================================
   PAGE HERO (static pages)
   ============================================================ */
.ast-archive-description,
.page-header {
  background: var(--pg-white) !important;
  border-bottom: 1px solid var(--pg-border) !important;
  padding: 48px 40px !important;
  margin-bottom: 40px !important;
}

.ast-archive-description .ast-archive-title,
.page-header .page-title {
  font-family: 'Bebas Neue', sans-serif !important;
  font-size: clamp(36px, 5vw, 60px) !important;
  letter-spacing: 3px !important;
  color: var(--pg-black) !important;
}

/* ============================================================
   IFRAME PAGES (Rackets / Compare)
   Remove all WordPress padding/margin around the iframe
   ============================================================ */
.page-id-rackets .site-content,
.page-id-compare .site-content,
[class*="page-template-page"] .site-content {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
}

.entry-content iframe {
  display: block !important;
  border: none !important;
  width: 100% !important;
}

/* ============================================================
   AFFILIATE DISCLOSURE BOX
   ============================================================ */
.affiliate-disclosure,
.pg-disclosure {
  background: var(--pg-bg) !important;
  border: 1px solid var(--pg-border) !important;
  border-left: 3px solid var(--pg-accent) !important;
  border-radius: 0 var(--pg-radius-sm) var(--pg-radius-sm) 0 !important;
  padding: 12px 16px !important;
  font-size: 12px !important;
  color: var(--pg-text-muted) !important;
  margin: 0 0 32px !important;
  font-family: 'Instrument Sans', sans-serif !important;
}

/* ============================================================
   MOBILE
   ============================================================ */
@media (max-width: 768px) {
  .ast-primary-header-bar .ast-builder-grid-row,
  .site-header .ast-container {
    padding: 0 20px !important;
  }

  .single article.type-post {
    padding: 24px 20px !important;
    margin: 20px !important;
    border-radius: var(--pg-radius-sm) !important;
  }

  .ast-page-builder-template .site-content,
  .site-content .ast-container {
    padding: 0 20px !important;
  }

  .site-footer {
    padding: 40px 20px 24px !important;
  }
}

@media (max-width: 480px) {
  h1 { font-size: 32px !important; }
  h2 { font-size: 24px !important; }

  .ast-article-post .post-thumbnail img,
  article.type-post .post-thumbnail img {
    height: 180px !important;
  }
}
