/*
Theme Name:   The Tech Sherpa Child
Theme URI:    https://thetechsherpa.com
Description:  Child theme for The Tech Sherpa MSP website, based on Kadence.
Author:       The Tech Sherpa
Template:     kadence
Version:      1.0.0
License:      GNU General Public License v2 or later
Text Domain:  tech-sherpa-child
*/

/* ============================================================
   TECH SHERPA DESIGN SYSTEM
   Brand Colors:
     Primary Green     #1D9E75
     Dark Green        #0F6E56
     Deep Green        #085041
     Light Green BG    #F4FBF8
     Light Green Mint  #E1F5EE
     Mint Accent       #9FE1CB
   Neutrals:
     Text Primary      #1a1a1a
     Text Secondary    #555550
     Text Muted        #888780
     Border Light      rgba(0,0,0,0.10)
     Surface           #F9F9F7
     White             #FFFFFF
   ============================================================ */

/* ============================================================
   1. CSS CUSTOM PROPERTIES
   ============================================================ */
:root {
  --ts-green-dark:    #085041;
  --ts-green-mid:     #0F6E56;
  --ts-green:         #1D9E75;
  --ts-green-light:   #5DCAA5;
  --ts-green-mint:    #9FE1CB;
  --ts-green-pale:    #E1F5EE;
  --ts-green-bg:      #F4FBF8;

  --ts-text:          #1a1a1a;
  --ts-text-secondary:#4a4a46;
  --ts-text-muted:    #888780;
  --ts-border:        rgba(0, 0, 0, 0.10);
  --ts-border-medium: rgba(0, 0, 0, 0.18);
  --ts-surface:       #F9F9F7;
  --ts-white:         #FFFFFF;

  --ts-radius-sm:     6px;
  --ts-radius:        10px;
  --ts-radius-lg:     14px;
  --ts-radius-xl:     20px;

  --ts-shadow-card:   0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
  --ts-shadow-hover:  0 4px 12px rgba(0,0,0,0.10);

  --ts-font:          'Inter', 'Helvetica Neue', Arial, sans-serif;
  --ts-transition:    all 0.2s ease;
}

/* ============================================================
   2. BASE & TYPOGRAPHY
   ============================================================ */
body {
  font-family: var(--ts-font);
  color: var(--ts-text);
  background-color: var(--ts-white);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--ts-font);
  font-weight: 500;
  line-height: 1.25;
  color: var(--ts-text);
}

h1 { font-size: clamp(28px, 4vw, 42px); }
h2 { font-size: clamp(22px, 3vw, 32px); }
h3 { font-size: clamp(17px, 2vw, 20px); }
h4 { font-size: 17px; }

p {
  font-size: 16px;
  line-height: 1.7;
  color: var(--ts-text-secondary);
}

a {
  color: var(--ts-green-mid);
  text-decoration: none;
  transition: var(--ts-transition);
}

a:hover {
  color: var(--ts-green-dark);
}

/* ============================================================
   3. NAVIGATION
   ============================================================ */
.site-header,
.kadence-sticky-header,
header.site-header {
  background-color: var(--ts-white) !important;
  border-bottom: 1px solid var(--ts-border);
  box-shadow: none !important;
}

/* Logo text */
.site-title,
.site-title a {
  font-family: var(--ts-font);
  font-weight: 600;
  font-size: 18px;
  color: var(--ts-text) !important;
  letter-spacing: -0.01em;
}

/* Nav links */
.main-navigation a,
.kadence-navigation a,
#site-navigation a {
  font-size: 14px;
  font-weight: 400;
  color: var(--ts-text-secondary) !important;
  padding: 6px 12px !important;
  border-radius: var(--ts-radius-sm);
  transition: var(--ts-transition);
}

.main-navigation a:hover,
.kadence-navigation a:hover,
#site-navigation a:hover {
  color: var(--ts-green) !important;
  background-color: var(--ts-green-pale) !important;
}

.main-navigation .current-menu-item > a,
.kadence-navigation .current-menu-item > a {
  color: var(--ts-green-mid) !important;
  font-weight: 500;
}

/* CTA Button in nav */
.header-cta-button,
.menu-item.button a,
.nav-cta-button a {
  background-color: transparent !important;
  color: var(--ts-green-mid) !important;
  border: 1.5px solid var(--ts-green-mid) !important;
  border-radius: var(--ts-radius-sm) !important;
  padding: 8px 20px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  transition: var(--ts-transition) !important;
}

.header-cta-button:hover,
.menu-item.button a:hover {
  background-color: var(--ts-green) !important;
  color: var(--ts-white) !important;
  border-color: var(--ts-green) !important;
}

/* ============================================================
   4. BUTTONS
   ============================================================ */
.wp-block-button__link,
.button,
button[type="submit"],
input[type="submit"],
.kadence-button {
  font-family: var(--ts-font) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  border-radius: var(--ts-radius-sm) !important;
  padding: 12px 28px !important;
  transition: var(--ts-transition) !important;
  cursor: pointer !important;
}

/* Primary button */
.wp-block-button:not(.is-style-outline) .wp-block-button__link,
.button-primary,
.btn-primary,
.kadence-button.kb-btn-primary {
  background-color: var(--ts-green) !important;
  color: var(--ts-white) !important;
  border: none !important;
}

.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover,
.button-primary:hover,
.btn-primary:hover {
  background-color: var(--ts-green-mid) !important;
  transform: translateY(-1px);
}

/* Outline / secondary button */
.wp-block-button.is-style-outline .wp-block-button__link,
.button-secondary,
.btn-secondary {
  background-color: transparent !important;
  color: var(--ts-green-mid) !important;
  border: 1.5px solid var(--ts-green-mid) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover,
.button-secondary:hover {
  background-color: var(--ts-green-pale) !important;
}

/* ============================================================
   5. HERO SECTIONS
   ============================================================ */
.hero-section,
.wp-block-cover.hero-section,
.page-hero,
.site-hero {
  background-color: var(--ts-green-bg) !important;
  padding: 80px 24px 72px !important;
  text-align: center;
}

.hero-section h1,
.page-hero h1 {
  color: var(--ts-text);
  max-width: 680px;
  margin: 0 auto 16px;
}

.hero-section p,
.page-hero p {
  font-size: 17px;
  max-width: 540px;
  margin: 0 auto 32px;
  color: var(--ts-text-secondary);
}

/* Hero badge / pill */
.hero-badge,
.section-badge {
  display: inline-block;
  font-size: 12px;
  font-weight: 500;
  padding: 5px 14px;
  border-radius: 20px;
  background-color: var(--ts-green-mint);
  color: var(--ts-green-dark);
  margin-bottom: 16px;
  letter-spacing: 0.01em;
}

/* ============================================================
   6. TRUST BAR
   ============================================================ */
.trust-bar {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 40px;
  padding: 20px 24px;
  background-color: var(--ts-white);
  border-bottom: 1px solid var(--ts-border);
}

.trust-bar-item {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
  color: var(--ts-text-secondary);
}

.trust-bar-item .dashicons,
.trust-bar-item svg,
.trust-bar-item i {
  color: var(--ts-green);
  font-size: 16px;
}

/* ============================================================
   7. SECTION LAYOUT
   ============================================================ */
.ts-section {
  padding: 72px 24px;
}

.ts-section--alt {
  background-color: var(--ts-surface);
}

.ts-section--green {
  background-color: var(--ts-green-bg);
}

.ts-section--cta {
  background-color: var(--ts-green-bg);
  text-align: center;
  padding: 64px 24px;
}

.section-label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--ts-green-mid);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 8px;
}

.section-heading {
  margin-bottom: 10px;
}

.section-subtext {
  font-size: 16px;
  color: var(--ts-text-secondary);
  max-width: 520px;
  margin-bottom: 40px;
  line-height: 1.7;
}

/* ============================================================
   8. SERVICE CARDS
   ============================================================ */
.ts-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

.ts-card-grid--2col {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.ts-service-card,
.wp-block-kadence-card,
.kb-card {
  background-color: var(--ts-white) !important;
  border: 1px solid var(--ts-border) !important;
  border-radius: var(--ts-radius-lg) !important;
  padding: 28px 24px !important;
  transition: var(--ts-transition) !important;
  box-shadow: var(--ts-shadow-card) !important;
}

.ts-service-card:hover {
  border-color: var(--ts-green-mint) !important;
  box-shadow: var(--ts-shadow-hover) !important;
  transform: translateY(-2px);
}

.ts-service-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--ts-radius-sm);
  background-color: var(--ts-green-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}

.ts-service-icon svg,
.ts-service-icon i,
.ts-service-icon .dashicons {
  color: var(--ts-green-mid);
  font-size: 20px;
  width: 20px;
  height: 20px;
}

.ts-service-card h3 {
  font-size: 17px;
  font-weight: 500;
  margin-bottom: 8px;
  color: var(--ts-text);
}

.ts-service-card p {
  font-size: 14px;
  color: var(--ts-text-secondary);
  line-height: 1.65;
  margin-bottom: 0;
}

.ts-service-includes {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--ts-border);
  font-size: 12px;
  color: var(--ts-text-muted);
  line-height: 1.6;
}

/* ============================================================
   9. ABOUT / STATS
   ============================================================ */
.ts-about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

@media (max-width: 768px) {
  .ts-about-grid { grid-template-columns: 1fr; }
}

.ts-about-image {
  background-color: var(--ts-green-pale);
  border-radius: var(--ts-radius-lg);
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.ts-about-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--ts-radius-lg);
}

.ts-stats {
  display: flex;
  gap: 32px;
  margin-top: 24px;
  flex-wrap: wrap;
}

.ts-stat {
  text-align: left;
}

.ts-stat-number {
  font-size: 28px;
  font-weight: 600;
  color: var(--ts-green-mid);
  line-height: 1;
}

.ts-stat-label {
  font-size: 13px;
  color: var(--ts-text-muted);
  margin-top: 4px;
}

/* ============================================================
   10. VALUES CARDS
   ============================================================ */
.ts-values-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 32px;
}

.ts-value-card {
  background-color: var(--ts-white);
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius-lg);
  padding: 28px 22px;
}

.ts-value-card h3 {
  font-size: 16px;
  font-weight: 500;
  margin-bottom: 8px;
}

.ts-value-card p {
  font-size: 14px;
  line-height: 1.65;
  color: var(--ts-text-secondary);
  margin: 0;
}

/* ============================================================
   11. CONTACT FORM
   ============================================================ */
.contact-wrapper {
  max-width: 560px;
  margin: 0 auto;
}

.wpcf7-form,
.wpforms-form,
.ts-contact-form {
  background-color: var(--ts-white);
  border: 1px solid var(--ts-border);
  border-radius: var(--ts-radius-lg);
  padding: 36px 32px;
  box-shadow: var(--ts-shadow-card);
}

.wpcf7-form label,
.wpforms-field-label,
.ts-contact-form label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: var(--ts-text-secondary);
  margin-bottom: 6px;
}

.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form select,
.wpcf7-form textarea,
.wpforms-field input,
.wpforms-field select,
.wpforms-field textarea,
.ts-contact-form input,
.ts-contact-form select,
.ts-contact-form textarea {
  width: 100%;
  font-family: var(--ts-font);
  font-size: 14px;
  color: var(--ts-text);
  background-color: var(--ts-surface);
  border: 1px solid var(--ts-border-medium);
  border-radius: var(--ts-radius-sm);
  padding: 10px 14px;
  transition: var(--ts-transition);
  appearance: none;
}

.wpcf7-form input:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus,
.wpforms-field input:focus,
.wpforms-field textarea:focus,
.ts-contact-form input:focus,
.ts-contact-form textarea:focus {
  outline: none;
  border-color: var(--ts-green);
  box-shadow: 0 0 0 3px rgba(29, 158, 117, 0.12);
  background-color: var(--ts-white);
}

.wpcf7-form textarea,
.wpforms-field textarea {
  min-height: 120px;
  resize: vertical;
}

.wpcf7-submit,
.wpforms-submit,
.ts-contact-form [type="submit"] {
  width: 100%;
  background-color: var(--ts-green) !important;
  color: var(--ts-white) !important;
  border: none !important;
  border-radius: var(--ts-radius-sm) !important;
  padding: 13px 28px !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: var(--ts-transition) !important;
  margin-top: 8px;
}

.wpcf7-submit:hover,
.wpforms-submit:hover {
  background-color: var(--ts-green-mid) !important;
  transform: translateY(-1px);
}

.contact-note {
  text-align: center;
  font-size: 12px;
  color: var(--ts-text-muted);
  margin-top: 12px;
}

/* Form two-column layout */
.form-row-2col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 480px) {
  .form-row-2col { grid-template-columns: 1fr; }
}

/* ============================================================
   12. CONTACT INFO BLOCK
   ============================================================ */
.ts-contact-info {
  display: flex;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
  margin-top: 40px;
}

.ts-contact-info-item {
  text-align: center;
}

.ts-contact-info-item .ts-icon {
  font-size: 26px;
  color: var(--ts-green);
  margin-bottom: 8px;
}

.ts-contact-info-item strong {
  display: block;
  font-size: 15px;
  font-weight: 500;
  color: var(--ts-text);
  margin-bottom: 3px;
}

.ts-contact-info-item span {
  font-size: 13px;
  color: var(--ts-text-muted);
}

/* ============================================================
   13. FOOTER
   ============================================================ */
.site-footer,
.kadence-footer {
  background-color: var(--ts-text) !important;
  color: rgba(255,255,255,0.75) !important;
  padding: 48px 24px 28px !important;
}

.site-footer a,
.kadence-footer a {
  color: rgba(255,255,255,0.65) !important;
  font-size: 14px;
  transition: var(--ts-transition);
}

.site-footer a:hover,
.kadence-footer a:hover {
  color: var(--ts-green-mint) !important;
}

.footer-tagline {
  font-size: 14px;
  color: rgba(255,255,255,0.5);
  margin-top: 6px;
}

.footer-brand {
  font-size: 17px;
  font-weight: 600;
  color: var(--ts-white) !important;
}

.footer-divider {
  border-color: rgba(255,255,255,0.10);
  margin: 28px 0 20px;
}

.footer-copy {
  font-size: 12px;
  color: rgba(255,255,255,0.35);
}

/* ============================================================
   14. UTILITIES & HELPERS
   ============================================================ */
.text-center { text-align: center; }
.text-green  { color: var(--ts-green-mid); }

.mb-0  { margin-bottom: 0; }
.mb-8  { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }
.mb-40 { margin-bottom: 40px; }

.max-540 { max-width: 540px; margin-left: auto; margin-right: auto; }
.max-680 { max-width: 680px; margin-left: auto; margin-right: auto; }

/* ============================================================
   15. RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .ts-card-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 600px) {
  .ts-card-grid,
  .ts-values-grid,
  .ts-card-grid--2col {
    grid-template-columns: 1fr;
  }

  .hero-section,
  .page-hero {
    padding: 52px 20px 44px !important;
  }

  .ts-section { padding: 48px 20px; }

  .wpcf7-form,
  .ts-contact-form {
    padding: 24px 20px;
  }

  .ts-stats { gap: 20px; }

  .trust-bar { gap: 10px 24px; }
}

/* ============================================================
   16. KADENCE THEME OVERRIDES
   ============================================================ */

/* Remove Kadence default button radius if conflicting */
.kadence-button-wrap .kb-button {
  border-radius: var(--ts-radius-sm) !important;
}

/* Kadence row/column backgrounds */
.kb-row-layout-inner > .kt-inside-inner-col {
  background-color: transparent;
}

/* Kadence header */
.kadence-header .kadence-header-inner {
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}

/* Smooth scroll */
html {
  scroll-behavior: smooth;
}

/* ============================================================
   END OF STYLESHEET
   ============================================================ */
