/*
 Theme Name:   PageBolt Child - AgTag USA
 Theme URI:    https://agtagusa.com
 Description:  AgTag USA child theme for PageBolt with custom homepage design system
 Author:       AgTag USA
 Author URI:   https://agtagusa.com
 Template:     pagebolt
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 Text Domain:  pagebolt-child
*/

/* =============================================
   AGTAG USA — DESIGN SYSTEM VARIABLES
   Ported from homepage mockup
   ============================================= */

:root {
  /* Greens */
  --green-dark:    #1E4D12;
  --green-mid:     #2D7A1A;
  --green-bright:  #4BAD2A;
  --green-light:   #EBF5E6;
  --green-pale:    #F4FAF1;

  /* Accent */
  --amber:         #D4830A;
  --amber-light:   #FEF3E2;

  /* Neutrals */
  --bg:            #FAFAF8;
  --surface:       #FFFFFF;
  --ink:           #181E14;
  --ink-mid:       #3A4635;
  --ink-muted:     #6B7A65;
  --ink-faint:     #A8B5A2;
  --border:        #DDE8D8;

  /* Radii */
  --radius-sm:     6px;
  --radius-md:     12px;
  --radius-lg:     20px;
  --radius-xl:     28px;

  /* Shadows */
  --shadow-sm:     0 1px 4px rgba(30,77,18,0.08);
  --shadow-md:     0 4px 20px rgba(30,77,18,0.10);
}

/* =============================================
   TYPOGRAPHY
   ============================================= */
body {
  font-family: 'DM Sans', sans-serif;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  background: var(--bg);
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Inter', sans-serif;
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--ink);
}

p {
  color: var(--ink-muted);
  line-height: 1.65;
}

/* =============================================
   GLOBAL UTILITY CLASSES
   ============================================= */
.ag-section-label {
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--green-mid);
  margin-bottom: 14px;
}

.ag-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--green-light);
  color: var(--green-dark);
  font-size: 13px;
  font-weight: 500;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 20px;
}
.ag-eyebrow::before {
  content: '';
  width: 6px;
  height: 6px;
  background: var(--green-bright);
  border-radius: 50%;
}

/* =============================================
   BUTTONS
   ============================================= */
.ag-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 500;
  padding: 13px 26px;
  border-radius: var(--radius-md);
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.18s ease;
  white-space: nowrap;
}
.ag-btn-primary {
  background: var(--green-dark);
  color: #fff;
  box-shadow: var(--shadow-sm);
}
.ag-btn-primary:hover {
  background: var(--green-mid);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
  color: #fff;
  text-decoration: none;
}
.ag-btn-secondary {
  background: transparent;
  color: var(--ink);
  border: 1.5px solid var(--border);
}
.ag-btn-secondary:hover {
  border-color: var(--ink-muted);
  background: var(--surface);
  text-decoration: none;
}
.ag-btn-lg {
  font-size: 17px;
  padding: 16px 32px;
  border-radius: var(--radius-lg);
}
.ag-btn-sm {
  font-size: 13px;
  padding: 9px 18px;
}


/* -----------------------------------------------
   BLOG POST CONTENT - fix invisible content
   Theme animation stuck at opacity:0 (paused)
   ----------------------------------------------- */
.single-post .uicore-post-content.uicore-animate {
  opacity: 1 !important;
  animation: none !important;
}

/* -----------------------------------------------
   RESOURCES PAGE - Modern Card Grid
   ----------------------------------------------- */

/* === INTRO SECTION === */
.ag-resources-intro {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 48px;
  padding: 0 24px;
}
.ag-resources-intro .ag-intro-badge {
  display: inline-block;
  background: var(--green-pale);
  color: var(--green-mid);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  padding: 6px 16px;
  border-radius: 100px;
  margin-bottom: 20px;
}
.ag-resources-intro h2 {
  font-family: 'Inter', sans-serif;
  font-size: 36px;
  font-weight: 800;
  color: var(--ink);
  line-height: 1.2;
  margin-bottom: 18px;
}
.ag-resources-intro p {
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink-muted);
  margin: 0;
}
.ag-resources-intro .ag-intro-highlight {
  color: var(--green-mid);
  font-weight: 600;
}

/* === CARD GRID === */
.bdt-post-card {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 32px !important;
  padding: 0 20px !important;
}
.bdt-post-card > div {
  padding: 0 !important;
  display: flex !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* Card container - equal height */
.bdt-post-card-item {
  background: var(--surface) !important;
  border-radius: var(--radius-lg) !important;
  overflow: hidden !important;
  box-shadow: 0 2px 12px rgba(30,77,18,0.06) !important;
  transition: transform 0.35s ease, box-shadow 0.35s ease !important;
  border: none !important;
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
}
.bdt-post-card-item::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 4px !important;
  background: linear-gradient(90deg, var(--green-mid), var(--green-bright)) !important;
  z-index: 2 !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
}
.bdt-post-card-item:hover::before {
  opacity: 1 !important;
}
.bdt-post-card-item:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 16px 40px rgba(30,77,18,0.12) !important;
}

/* Card image */
.bdt-post-card-thumb {
  display: block !important;
  overflow: hidden !important;
  aspect-ratio: 16 / 10 !important;
  position: relative !important;
  background: linear-gradient(135deg, #1B3A0A 0%, #2D7A1A 50%, #164012 100%) !important;
  flex-shrink: 0 !important;
}
.bdt-post-card-thumb::after {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(180deg, transparent 40%, rgba(27,30,26,0.5) 100%) !important;
  z-index: 1 !important;
  pointer-events: none !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease !important;
}
.bdt-post-card-item:hover .bdt-post-card-thumb::after {
  opacity: 1 !important;
}
.bdt-post-card-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  transition: transform 0.5s ease !important;
}
.bdt-post-card-item:hover .bdt-post-card-thumb img {
  transform: scale(1.08) !important;
}
.bdt-post-card-thumb img[src=""],
.bdt-post-card-thumb img:not([src*="uploads"]) {
  opacity: 0 !important;
}

/* Card content area */
.bdt-post-card-desc {
  padding: 28px 28px 32px !important;
  display: flex !important;
  flex-direction: column !important;
  flex-grow: 1 !important;
}

/* Category badge */
.bdt-post-card-meta {
  order: -1 !important;
  margin-bottom: 14px !important;
  gap: 8px !important;
}
.bdt-post-card-meta a {
  display: inline-block !important;
  background: var(--green-pale) !important;
  color: var(--green-mid) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  padding: 4px 12px !important;
  border-radius: 100px !important;
  text-decoration: none !important;
  transition: background 0.2s ease, color 0.2s ease !important;
}
.bdt-post-card-item:hover .bdt-post-card-meta a {
  background: var(--green-mid) !important;
  color: #fff !important;
}
.bdt-post-card-meta span:not(:has(a)) {
  font-size: 12px !important;
  color: var(--ink-faint) !important;
}

/* Post title */
.bdt-post-card-title {
  font-family: 'Inter', sans-serif !important;
  font-size: 21px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  color: var(--ink) !important;
  margin-bottom: 12px !important;
}
.bdt-post-card-title a {
  color: var(--ink) !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}
.bdt-post-card-item:hover .bdt-post-card-title a {
  color: var(--green-mid) !important;
}

/* Excerpt */
.bdt-post-card-excerpt {
  font-size: 15px !important;
  line-height: 1.65 !important;
  color: var(--ink-muted) !important;
  margin-bottom: 24px !important;
  flex-grow: 1 !important;
}

/* Read More link */
a.bdt-post-card-button {
  display: inline-flex !important;
  align-items: center !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--green-mid) !important;
  text-decoration: none !important;
  transition: all 0.25s ease !important;
  gap: 8px !important;
  padding: 10px 20px !important;
  background: var(--green-pale) !important;
  border-radius: var(--radius-md) !important;
  align-self: flex-start !important;
  margin-top: auto !important;
}
a.bdt-post-card-button::after {
  content: '\2192' !important;
  transition: transform 0.25s ease !important;
  font-size: 16px !important;
}
a.bdt-post-card-button:hover {
  background: var(--green-mid) !important;
  color: #fff !important;
}
a.bdt-post-card-button:hover::after {
  transform: translateX(4px) !important;
}

/* Responsive */
@media (max-width: 960px) {
  .bdt-post-card { grid-template-columns: repeat(2, 1fr) !important; gap: 24px !important; }
  .ag-resources-intro h2 { font-size: 28px; }
}
@media (max-width: 640px) {
  .bdt-post-card { grid-template-columns: 1fr !important; gap: 20px !important; }
  .bdt-post-card-desc { padding: 20px 20px 24px !important; }
  .bdt-post-card-title { font-size: 18px !important; }
  .ag-resources-intro h2 { font-size: 24px; }
  .ag-resources-intro p { font-size: 15px; }
}