/* ============================================================
   LeadGen Pro — global.css
   All theme component styles. Edit colors via CSS variables
   at the top of this file to reskin the entire theme.
   ============================================================ */

/* ── DESIGN TOKENS ──────────────────────────────────────────
   Change these to rebrand the site. That's it.
   ────────────────────────────────────────────────────────── */
:root {
  --lgp-primary:       #1B4FD8;
  --lgp-primary-dark:  #1540B0;
  --lgp-primary-light: #EEF3FD;
  --lgp-accent:        #059669;
  --lgp-accent-dark:   #047857;
  --lgp-dark:          #111827;
  --lgp-dark-70:       #374151;
  --lgp-muted:         #6B7280;
  --lgp-border:        #E5E7EB;
  --lgp-surface:       #F9FAFB;
  --lgp-white:         #FFFFFF;
  --lgp-gold:          #D97706;

  --lgp-radius-sm:  4px;
  --lgp-radius:     8px;
  --lgp-radius-lg:  12px;
  --lgp-radius-xl:  16px;
  --lgp-radius-2xl: 24px;

  --lgp-shadow-sm: 0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.04);
  --lgp-shadow:    0 4px 12px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --lgp-shadow-lg: 0 8px 24px rgba(0,0,0,0.10), 0 4px 8px rgba(0,0,0,0.04);

  --lgp-transition: 0.18s ease;
}

/* ── BASE RESET ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--lgp-dark);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

/* ── TYPOGRAPHY ─────────────────────────────────────────── */
h1, h2 {
  font-family: Georgia, 'Times New Roman', serif;
  font-weight: 400;
  line-height: 1.15;
  color: var(--lgp-dark);
}

h3, h4, h5, h6 {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  line-height: 1.3;
  color: var(--lgp-dark);
}

p { color: var(--lgp-dark-70); line-height: 1.75; }

a { color: var(--lgp-primary); transition: color var(--lgp-transition); }
a:hover { color: var(--lgp-primary-dark); }

/* ── HEADER ─────────────────────────────────────────────── */
.lgp-header-wrap {
  background: var(--lgp-white);
  border-bottom: 1px solid var(--lgp-border);
  position: sticky;
  top: 0;
  z-index: 100;
}

.lgp-topbar {
  background: var(--lgp-primary);
  padding: 0.5rem 1.5rem;
  text-align: center;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.9);
  font-weight: 500;
  letter-spacing: 0.01em;
}

.lgp-topbar a {
  color: #fff;
  font-weight: 700;
  text-decoration: none;
}

.lgp-topbar a:hover { text-decoration: underline; }

.wp-block-site-title a {
  font-family: 'Inter', sans-serif !important;
  font-weight: 700 !important;
  font-size: 1.25rem !important;
  color: var(--lgp-dark) !important;
  text-decoration: none !important;
  letter-spacing: -0.02em;
}

.wp-block-navigation a {
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: 0.9rem;
  color: var(--lgp-dark-70) !important;
  text-decoration: none !important;
  transition: color var(--lgp-transition);
}

.wp-block-navigation a:hover {
  color: var(--lgp-primary) !important;
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.wp-block-button__link {
  font-family: 'Inter', sans-serif !important;
  font-weight: 600 !important;
  transition: all var(--lgp-transition) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center;
  gap: 0.375rem;
}

/* Primary button */
.wp-block-button.is-style-primary .wp-block-button__link,
.wp-block-button:not([class*="is-style"]) .wp-block-button__link {
  background-color: var(--lgp-primary) !important;
  color: var(--lgp-white) !important;
  border: 2px solid var(--lgp-primary) !important;
  border-radius: var(--lgp-radius) !important;
  padding: 0.8rem 1.75rem !important;
}

.wp-block-button.is-style-primary .wp-block-button__link:hover,
.wp-block-button:not([class*="is-style"]) .wp-block-button__link:hover {
  background-color: var(--lgp-primary-dark) !important;
  border-color: var(--lgp-primary-dark) !important;
  transform: translateY(-1px);
  box-shadow: var(--lgp-shadow);
}

/* CTA / accent button */
.wp-block-button.is-style-cta .wp-block-button__link {
  background-color: var(--lgp-accent) !important;
  color: var(--lgp-white) !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 0.9rem 2.25rem !important;
  font-size: 1rem !important;
  box-shadow: 0 4px 14px rgba(5,150,105,0.30) !important;
}

.wp-block-button.is-style-cta .wp-block-button__link:hover {
  background-color: var(--lgp-accent-dark) !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(5,150,105,0.40) !important;
}

/* Ghost / outline button */
.wp-block-button.is-style-outline .wp-block-button__link {
  background: transparent !important;
  color: var(--lgp-primary) !important;
  border: 2px solid var(--lgp-primary) !important;
  border-radius: var(--lgp-radius) !important;
  padding: 0.8rem 1.75rem !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
  background: var(--lgp-primary) !important;
  color: var(--lgp-white) !important;
}

/* Ghost white (for dark backgrounds) */
.wp-block-button.is-style-ghost-white .wp-block-button__link {
  background: transparent !important;
  color: var(--lgp-white) !important;
  border: 2px solid rgba(255,255,255,0.55) !important;
  border-radius: var(--lgp-radius) !important;
  padding: 0.8rem 1.75rem !important;
}

.wp-block-button.is-style-ghost-white .wp-block-button__link:hover {
  background: rgba(255,255,255,0.12) !important;
  border-color: rgba(255,255,255,0.8) !important;
}

/* ── HERO SECTION ────────────────────────────────────────── */
.lgp-hero {
  background: linear-gradient(135deg, #0f1d3a 0%, var(--lgp-primary) 100%);
  padding: 5rem 1.5rem !important;
  position: relative;
  overflow: hidden;
}

.lgp-hero::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(255,255,255,0.04) 0%, transparent 60%);
  pointer-events: none;
}

.lgp-hero .wp-block-cover__inner-container { position: relative; z-index: 1; }
.lgp-hero .wp-block-heading,
.lgp-hero h1 { color: #fff !important; }
.lgp-hero p { color: rgba(255,255,255,0.82) !important; }

/* ── FORM CARD ───────────────────────────────────────────── */
.lgp-form-card {
  background: var(--lgp-white);
  border-radius: var(--lgp-radius-xl) !important;
  padding: 2.25rem !important;
  box-shadow: var(--lgp-shadow-lg) !important;
  border: 1px solid var(--lgp-border) !important;
}

.lgp-form-card h2, .lgp-form-card h3 { color: var(--lgp-dark) !important; }
.lgp-form-card .lgp-form-sub { color: var(--lgp-muted); font-size: 0.9rem; margin-bottom: 1.5rem; }

.lgp-form-placeholder {
  background: var(--lgp-surface) !important;
  border: 2px dashed var(--lgp-border) !important;
  border-radius: var(--lgp-radius) !important;
  padding: 2.5rem 1.5rem !important;
  text-align: center;
  color: var(--lgp-muted);
  font-size: 0.9rem;
}

/* ── TRUST / LOGO BAR ────────────────────────────────────── */
.lgp-trust-bar {
  background: var(--lgp-surface) !important;
  border-top: 1px solid var(--lgp-border) !important;
  border-bottom: 1px solid var(--lgp-border) !important;
  padding: 1.5rem !important;
  text-align: center;
}

.lgp-trust-label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--lgp-muted) !important;
  margin-bottom: 1rem !important;
}

/* ── SECTION UTILITIES ───────────────────────────────────── */
.lgp-section      { padding: 5rem 1.5rem !important; }
.lgp-section-sm   { padding: 3rem 1.5rem !important; }
.lgp-section-dark {
  background: linear-gradient(135deg, #0f1d3a 0%, var(--lgp-primary) 100%) !important;
}
.lgp-section-dark h2,
.lgp-section-dark h3,
.lgp-section-dark p { color: var(--lgp-white) !important; }
.lgp-section-dark p { color: rgba(255,255,255,0.75) !important; }

.lgp-surface-bg { background: var(--lgp-surface) !important; }

/* ── BADGE / PILL ────────────────────────────────────────── */
.lgp-badge {
  display: inline-block;
  background: var(--lgp-primary-light);
  color: var(--lgp-primary);
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  padding: 0.3rem 0.85rem;
  border-radius: 50px;
  margin-bottom: 0.875rem;
}

.lgp-badge-white {
  background: rgba(255,255,255,0.15);
  color: #fff;
}

/* ── FEATURE / BENEFIT CARDS ─────────────────────────────── */
.lgp-card {
  background: var(--lgp-white) !important;
  border: 1px solid var(--lgp-border) !important;
  border-radius: var(--lgp-radius-lg) !important;
  padding: 2rem !important;
  transition: all var(--lgp-transition);
  height: 100%;
}

.lgp-card:hover {
  box-shadow: var(--lgp-shadow) !important;
  transform: translateY(-3px);
  border-color: #c7d7fa !important;
}

.lgp-card-icon {
  width: 52px;
  height: 52px;
  background: var(--lgp-primary-light);
  border-radius: var(--lgp-radius);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.375rem;
  margin-bottom: 1.25rem;
}

/* ── CHECK LIST ──────────────────────────────────────────── */
.lgp-checklist {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.lgp-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 0.4rem 0;
  color: var(--lgp-dark-70);
  font-size: 0.95rem;
}

.lgp-checklist li::before {
  content: '';
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--lgp-accent);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='white' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round' d='M2 6l3 3 5-5'/%3E%3C/svg%3E");
  background-size: 12px;
  background-repeat: no-repeat;
  background-position: center;
  margin-top: 2px;
}

/* ── STATS ROW ───────────────────────────────────────────── */
.lgp-stat-num {
  font-family: Georgia, serif;
  font-size: 2.75rem;
  font-weight: 400;
  color: var(--lgp-white);
  line-height: 1;
  display: block;
}

.lgp-stat-label {
  font-size: 0.875rem;
  color: rgba(255,255,255,0.65);
  margin-top: 0.35rem;
}

/* ── PHONE CTA SIDEBAR BOX ───────────────────────────────── */
.lgp-phone-box {
  background: var(--lgp-primary) !important;
  border-radius: var(--lgp-radius-xl) !important;
  padding: 2rem 1.5rem !important;
  text-align: center;
}

.lgp-phone-box h3 { color: var(--lgp-white) !important; }
.lgp-phone-box p  { color: rgba(255,255,255,0.75) !important; }

.lgp-phone-number {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--lgp-white) !important;
  text-decoration: none;
  display: block;
  margin-top: 0.75rem;
}

.lgp-phone-number:hover { color: var(--lgp-gold) !important; }

/* ── PAGE HERO (inner pages) ─────────────────────────────── */
.lgp-page-hero {
  background: var(--lgp-primary-light) !important;
  padding: 3rem 1.5rem !important;
  border-bottom: 1px solid #d0e0fb;
}

.lgp-page-hero h1 { color: var(--lgp-dark) !important; font-size: 2.5rem !important; }
.lgp-page-hero p  { color: var(--lgp-muted) !important; font-size: 1.1rem !important; }

/* ── BLOG / ARCHIVE ──────────────────────────────────────── */
.lgp-post-card {
  background: var(--lgp-white) !important;
  border: 1px solid var(--lgp-border) !important;
  border-radius: var(--lgp-radius-lg) !important;
  overflow: hidden;
  transition: all var(--lgp-transition);
}

.lgp-post-card:hover {
  box-shadow: var(--lgp-shadow);
  transform: translateY(-3px);
}

.lgp-post-card .wp-block-post-featured-image img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

.lgp-post-card-body { padding: 1.5rem !important; }

.lgp-post-date {
  font-size: 0.78rem;
  color: var(--lgp-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 600;
}

/* ── LEGAL PAGES ─────────────────────────────────────────── */
.lgp-legal-body {
  max-width: 780px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}

.lgp-legal-body h1 { font-size: 2.25rem !important; margin-bottom: 0.4rem; }

.lgp-legal-date {
  font-size: 0.875rem;
  color: var(--lgp-muted);
  padding-bottom: 2rem;
  border-bottom: 1px solid var(--lgp-border);
  margin-bottom: 2.5rem;
}

.lgp-legal-body h2 {
  font-family: 'Inter', sans-serif !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
  color: var(--lgp-dark) !important;
}

.lgp-legal-body p, .lgp-legal-body li {
  font-size: 0.925rem;
  color: var(--lgp-dark-70);
  line-height: 1.8;
}

/* ── THANK YOU PAGE ──────────────────────────────────────── */
.lgp-thankyou {
  min-height: 65vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 4rem 1.5rem;
}

.lgp-check-circle {
  width: 80px;
  height: 80px;
  background: var(--lgp-accent);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.75rem;
  font-size: 2.25rem;
  color: white;
}

/* ── FOOTER ──────────────────────────────────────────────── */
.lgp-footer {
  background: #0f1623 !important;
  color: rgba(255,255,255,0.65);
  padding: 3.5rem 1.5rem 1.5rem !important;
}

.lgp-footer .wp-block-site-title a {
  color: var(--lgp-white) !important;
  font-size: 1.125rem !important;
}

.lgp-footer a {
  color: rgba(255,255,255,0.6) !important;
  text-decoration: none !important;
  font-size: 0.875rem !important;
  transition: color var(--lgp-transition);
}

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

.lgp-footer h4 {
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: rgba(255,255,255,0.85) !important;
  margin-bottom: 1rem !important;
}

.lgp-footer-legal {
  border-top: 1px solid rgba(255,255,255,0.08);
  padding-top: 1.5rem;
  margin-top: 2.5rem;
  font-size: 0.78rem;
  color: rgba(255,255,255,0.35);
  text-align: center;
}

.lgp-footer-legal a { font-size: 0.78rem !important; }

/* ── DIVIDER ─────────────────────────────────────────────── */
.lgp-divider {
  width: 40px;
  height: 3px;
  background: var(--lgp-primary);
  border-radius: 2px;
  margin: 1rem 0 1.5rem;
}

/* ── SECURITY BADGE ──────────────────────────────────────── */
.lgp-secure-note {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  justify-content: center;
  font-size: 0.78rem;
  color: var(--lgp-muted);
  margin-top: 1rem;
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .lgp-hero      { padding: 3.5rem 1.25rem !important; }
  .lgp-section   { padding: 3rem 1.25rem !important; }
  .lgp-section-sm { padding: 2rem 1.25rem !important; }
  .lgp-form-card { padding: 1.75rem 1.25rem !important; }
  .lgp-stat-num  { font-size: 2.25rem; }
  .lgp-page-hero { padding: 2rem 1.25rem !important; }
  .lgp-page-hero h1 { font-size: 2rem !important; }
}
