/*
Theme Name: Beaver Builder Child Theme
Theme URI: https://www.wpbeaverbuilder.com
Version: 2.0
Description: Guiderly child theme — customized for MarkoMedia LLC
Author: The Beaver Builder Team / MarkoMedia LLC
Author URI: https://guiderly.com
Template: bb-theme
*/

/*
  GUIDERLY — GLOBAL DESIGN SYSTEM
  Version: 2.0 — April 14, 2026
  Owner: MarkoMedia LLC
  All brand colors defined in :root below.
  Change a value once — updates everywhere.
*/

/* ============================================================
   1. DESIGN TOKENS — SINGLE SOURCE OF TRUTH
   ============================================================ */

:root {

  /* Brand colors */
  --g-brown-dark:       #3A2E1E;
  --g-brown-mid:        #7B5E3A;
  --g-brown-light:      #8B7340;
  --g-brown-border:     #C4B49A;
  --g-brown-hover:      #6A5030;

  /* Cream backgrounds */
  --g-cream-primary:    #F5F0E8;
  --g-cream-secondary:  #E8DFC8;
  --g-cream-white:      #FFFFFF;

  /* Text colors */
  --g-text-primary:     #2C2C2A;
  --g-text-secondary:   #5F5E5A;
  --g-text-tertiary:    #888780;

  /* Accent colors */
  --g-cobalt:           #1A56DB;
  --g-orange:           #E8600A;
  --g-olive:            #3B6D11;

  /* Typography */
  --g-font-serif:       Georgia, 'Times New Roman', serif;
  --g-font-sans:        Arial, Helvetica, sans-serif;

  /* Font sizes */
  --g-text-xs:          11px;
  --g-text-sm:          13px;
  --g-text-base:        15px;
  --g-text-md:          17px;
  --g-text-lg:          20px;
  --g-text-xl:          24px;
  --g-text-2xl:         30px;
  --g-text-3xl:         36px;
  --g-text-4xl:         48px;

  /* Line heights */
  --g-leading-tight:    1.25;
  --g-leading-snug:     1.4;
  --g-leading-normal:   1.6;
  --g-leading-relaxed:  1.75;

  /* Spacing */
  --g-space-xs:         4px;
  --g-space-sm:         8px;
  --g-space-md:         16px;
  --g-space-lg:         24px;
  --g-space-xl:         32px;
  --g-space-2xl:        48px;
  --g-space-3xl:        64px;

  /* Border radius */
  --g-radius-sm:        4px;
  --g-radius-md:        6px;
  --g-radius-lg:        10px;
  --g-radius-xl:        16px;
  --g-radius-pill:      100px;

  /* Max widths */
  --g-content-width:    720px;
  --g-narrow-width:     560px;

  /* Transitions */
  --g-transition:       0.15s ease;
}


/* ============================================================
   2. GLOBAL RESET & BASE
   ============================================================ */

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-base);
  color: var(--g-text-primary);
  background-color: var(--g-cream-primary);
  line-height: var(--g-leading-normal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}


/* ============================================================
   3. TYPOGRAPHY
   ============================================================ */

h1, h2, h3, h4, h5, h6 {
  font-family: var(--g-font-serif);
  font-weight: normal;
  color: var(--g-brown-dark);
  line-height: var(--g-leading-tight);
  margin-top: 0;
  margin-bottom: var(--g-space-md);
}

h1 { font-size: var(--g-text-3xl); }
h2 { font-size: var(--g-text-2xl); }
h3 { font-size: var(--g-text-lg); }
h4 { font-size: var(--g-text-base); font-weight: 600; font-family: var(--g-font-sans); }

p {
  margin-top: 0;
  margin-bottom: var(--g-space-md);
  line-height: var(--g-leading-relaxed);
}

.g-serif {
  font-family: var(--g-font-serif);
  font-size: var(--g-text-md);
  line-height: var(--g-leading-relaxed);
  color: var(--g-brown-dark);
}

.g-eyebrow,
.g-label {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--g-brown-light);
}

.g-section-label {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-xs);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--g-text-tertiary);
  margin-bottom: var(--g-space-md);
}

blockquote,
.g-quote-text {
  font-family: var(--g-font-serif);
  font-style: italic;
  font-size: var(--g-text-md);
  color: var(--g-brown-dark);
  line-height: var(--g-leading-relaxed);
  margin: 0 0 var(--g-space-sm);
  padding: 0;
  border: none;
}

a {
  color: var(--g-brown-mid);
  text-decoration: none;
  transition: color var(--g-transition);
}

a:hover {
  color: var(--g-brown-hover);
  text-decoration: underline;
}

.g-prompt-text {
  font-family: var(--g-font-serif);
  font-style: italic;
  color: var(--g-brown-dark);
  font-size: var(--g-text-lg);
  line-height: var(--g-leading-relaxed);
}

@media (max-width: 600px) {
  h1 { font-size: var(--g-text-2xl); }
  h2 { font-size: var(--g-text-xl); }
}


/* ============================================================
   4. LAYOUT & CONTAINERS
   ============================================================ */

.g-container {
  max-width: var(--g-content-width);
  margin: 0 auto;
  padding: 0 var(--g-space-lg);
}

.g-container-narrow {
  max-width: var(--g-narrow-width);
  margin: 0 auto;
  padding: 0 var(--g-space-lg);
}

.g-section {
  padding: var(--g-space-2xl) 0;
}

.g-divider {
  border: none;
  border-top: 1px solid var(--g-cream-secondary);
  margin: var(--g-space-2xl) 0;
}

.g-center { text-align: center; }


/* ============================================================
   5. CARDS & SURFACES
   ============================================================ */

.g-card {
  background: var(--g-cream-white);
  border: 1px solid var(--g-cream-secondary);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-xl);
}

.g-card-cream {
  background: var(--g-cream-primary);
  border: 1px solid var(--g-cream-secondary);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-xl);
}

.g-card-featured {
  background: var(--g-cream-white);
  border: 2px solid var(--g-brown-mid);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-xl);
}

.g-card-quote {
  background: var(--g-cream-primary);
  border-left: 3px solid var(--g-brown-mid);
  border-radius: 0 var(--g-radius-md) var(--g-radius-md) 0;
  padding: var(--g-space-lg) var(--g-space-xl);
}

.g-card-notice {
  background: var(--g-cream-primary);
  border-left: 3px solid var(--g-brown-light);
  border-radius: 0 var(--g-radius-md) var(--g-radius-md) 0;
  padding: var(--g-space-md) var(--g-space-lg);
}

@media (max-width: 600px) {
  .g-card,
  .g-card-cream,
  .g-card-featured {
    padding: var(--g-space-lg) var(--g-space-md);
  }
}


/* ============================================================
   6. BUTTONS
   ============================================================ */

.g-btn {
  display: inline-block;
  padding: 13px 24px;
  border-radius: var(--g-radius-md);
  font-family: var(--g-font-sans);
  font-size: var(--g-text-base);
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition: background var(--g-transition), color var(--g-transition), border-color var(--g-transition);
  letter-spacing: 0.02em;
  line-height: 1;
  -webkit-appearance: none;
}

.g-btn-block {
  display: block;
  width: 100%;
}

.g-btn-primary {
  background: var(--g-brown-mid);
  color: var(--g-cream-primary) !important;
  border: 2px solid var(--g-brown-mid);
}
.g-btn-primary:hover {
  background: var(--g-brown-hover);
  border-color: var(--g-brown-hover);
  color: var(--g-cream-primary) !important;
  text-decoration: none;
}

.g-btn-secondary {
  background: transparent;
  color: var(--g-brown-dark) !important;
  border: 1.5px solid var(--g-brown-border);
}
.g-btn-secondary:hover {
  background: var(--g-cream-primary);
  border-color: var(--g-brown-mid);
  color: var(--g-brown-dark) !important;
  text-decoration: none;
}

.g-btn-ghost {
  background: transparent;
  color: var(--g-cream-primary) !important;
  border: 1.5px solid var(--g-cream-primary);
}
.g-btn-ghost:hover {
  background: rgba(245, 240, 232, 0.15);
  color: var(--g-cream-primary) !important;
  text-decoration: none;
}

.g-btn-olive {
  background: var(--g-olive);
  color: var(--g-cream-white) !important;
  border: 2px solid var(--g-olive);
}
.g-btn-olive:hover {
  background: #27500A;
  border-color: #27500A;
  color: var(--g-cream-white) !important;
  text-decoration: none;
}


/* ============================================================
   7. BADGES & PILLS
   ============================================================ */

.g-badge {
  display: inline-block;
  font-family: var(--g-font-sans);
  font-size: var(--g-text-xs);
  font-weight: 600;
  letter-spacing: 0.06em;
  padding: 4px 12px;
  border-radius: var(--g-radius-pill);
  background: var(--g-cream-primary);
  color: var(--g-brown-mid);
  border: 1px solid var(--g-cream-secondary);
}

.g-badge-gold {
  background: var(--g-brown-light);
  color: var(--g-cream-primary);
  border: none;
}

.g-badge-olive {
  background: var(--g-olive);
  color: var(--g-cream-white);
  border: none;
}


/* ============================================================
   8. FORMS
   ============================================================ */

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="password"],
input[type="search"],
textarea,
select {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid var(--g-brown-border);
  border-radius: var(--g-radius-md);
  background: var(--g-cream-white);
  font-family: var(--g-font-sans);
  font-size: var(--g-text-base);
  color: var(--g-text-primary);
  line-height: var(--g-leading-normal);
  transition: border-color var(--g-transition), box-shadow var(--g-transition);
  -webkit-appearance: none;
  box-shadow: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
textarea:focus,
select:focus {
  border-color: var(--g-brown-mid);
  outline: none;
  box-shadow: 0 0 0 3px rgba(123, 94, 58, 0.12);
}

textarea {
  min-height: 140px;
  resize: vertical;
}

label {
  display: block;
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  font-weight: 600;
  color: var(--g-brown-dark);
  margin-bottom: 6px;
  letter-spacing: 0.02em;
}

input[type="submit"],
button[type="submit"] {
  width: 100%;
  padding: 14px 20px;
  border-radius: var(--g-radius-md);
  background: var(--g-brown-mid);
  color: var(--g-cream-primary);
  font-family: var(--g-font-sans);
  font-size: var(--g-text-base);
  font-weight: 600;
  border: none;
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background var(--g-transition);
  -webkit-appearance: none;
}

input[type="submit"]:hover,
button[type="submit"]:hover {
  background: var(--g-brown-hover);
}


/* ============================================================
   9. GRAVITY FORMS — GLOBAL OVERRIDES
   ============================================================ */

.gform_wrapper {
  margin: 0 !important;
}

.gform_wrapper .gform_body {
  padding: 0 !important;
}

.gform_wrapper input[type="text"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="password"],
.gform_wrapper textarea {
  padding: 12px 16px !important;
  border: 1.5px solid var(--g-brown-border) !important;
  border-radius: var(--g-radius-md) !important;
  background: var(--g-cream-white) !important;
  font-family: var(--g-font-sans) !important;
  font-size: var(--g-text-base) !important;
  color: var(--g-text-primary) !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
}

.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper textarea:focus {
  border-color: var(--g-brown-mid) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(123, 94, 58, 0.12) !important;
}

.gform_wrapper .gfield_label {
  font-family: var(--g-font-sans) !important;
  font-size: var(--g-text-sm) !important;
  font-weight: 600 !important;
  color: var(--g-brown-dark) !important;
  margin-bottom: 6px !important;
}

.gform_wrapper .gfield {
  margin-bottom: var(--g-space-md) !important;
  padding: 0 !important;
}

.gform_wrapper .gform_footer,
.gform_wrapper .gform_page_footer {
  padding: 8px 0 0 !important;
  margin: 0 !important;
  border: none !important;
}

.gform_wrapper input[type="submit"],
.gform_wrapper .gform_button {
  width: 100% !important;
  padding: 14px 20px !important;
  border-radius: var(--g-radius-md) !important;
  background: var(--g-brown-mid) !important;
  color: var(--g-cream-primary) !important;
  font-family: var(--g-font-sans) !important;
  font-size: var(--g-text-base) !important;
  font-weight: 600 !important;
  border: none !important;
  cursor: pointer !important;
  -webkit-appearance: none !important;
  transition: background var(--g-transition) !important;
}

.gform_wrapper input[type="submit"]:hover,
.gform_wrapper .gform_button:hover {
  background: var(--g-brown-hover) !important;
}

.gform_wrapper .validation_error {
  background: #FAECE7 !important;
  border: 1px solid #D85A30 !important;
  border-radius: var(--g-radius-md) !important;
  color: #712B13 !important;
  font-family: var(--g-font-sans) !important;
  font-size: var(--g-text-sm) !important;
  padding: 10px 16px !important;
  margin-bottom: var(--g-space-md) !important;
}

.gform_wrapper .gfield_error input,
.gform_wrapper .gfield_error textarea {
  border-color: #D85A30 !important;
}

.gform_wrapper .gfield_description.validation_message {
  color: #993C1D !important;
  font-family: var(--g-font-sans) !important;
  font-size: 12px !important;
}

.gform_confirmation_message {
  background: var(--g-cream-primary) !important;
  border: 1px solid var(--g-brown-mid) !important;
  border-radius: var(--g-radius-lg) !important;
  padding: var(--g-space-lg) var(--g-space-xl) !important;
  font-family: var(--g-font-sans) !important;
  font-size: var(--g-text-base) !important;
  color: var(--g-brown-dark) !important;
  text-align: center !important;
  line-height: var(--g-leading-normal) !important;
}

.gform_wrapper .gfield_required {
  color: var(--g-brown-mid) !important;
}

.gform_wrapper ul.gform_fields {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}


/* ============================================================
   10. BEAVER BUILDER — GLOBAL OVERRIDES
   ============================================================ */

.fl-builder .fl-button,
.fl-builder .fl-button-wrap a {
  background: var(--g-brown-mid) !important;
  color: var(--g-cream-primary) !important;
  border-radius: var(--g-radius-md) !important;
  font-family: var(--g-font-sans) !important;
  font-weight: 600 !important;
  border: none !important;
  transition: background var(--g-transition) !important;
}

.fl-builder .fl-button:hover,
.fl-builder .fl-button-wrap a:hover {
  background: var(--g-brown-hover) !important;
  color: var(--g-cream-primary) !important;
}

.fl-builder .fl-module-heading h1,
.fl-builder .fl-module-heading h2,
.fl-builder .fl-module-heading h3,
.fl-builder .fl-module-heading h4 {
  font-family: var(--g-font-serif) !important;
  color: var(--g-brown-dark) !important;
  font-weight: normal !important;
}

.fl-builder .fl-module-rich-text p,
.fl-builder .fl-module-rich-text li {
  font-family: var(--g-font-sans) !important;
  color: var(--g-text-secondary) !important;
  line-height: var(--g-leading-relaxed) !important;
}

.fl-builder .fl-row-content-wrap {
  background-color: var(--g-cream-primary);
}

.fl-builder .fl-module {
  margin-bottom: var(--g-space-md);
}


/* ============================================================
   11. NAVIGATION
   ============================================================ */

.site-header a,
.main-navigation a {
  font-family: var(--g-font-sans);
  color: var(--g-brown-dark);
  font-size: var(--g-text-base);
  text-decoration: none;
  transition: color var(--g-transition);
}

.site-header a:hover,
.main-navigation a:hover {
  color: var(--g-brown-mid);
  text-decoration: none;
}

.g-nav-dropdown {
  background: var(--g-cream-white);
  border: 1px solid var(--g-cream-secondary);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-sm) 0;
  min-width: 200px;
}

.g-nav-dropdown a {
  display: block;
  padding: 10px var(--g-space-lg);
  font-family: var(--g-font-sans);
  font-size: var(--g-text-base);
  color: var(--g-text-primary);
  text-decoration: none;
  transition: background var(--g-transition);
}

.g-nav-dropdown a:hover {
  background: var(--g-cream-primary);
  color: var(--g-brown-mid);
}

.g-nav-dropdown a.active {
  color: var(--g-brown-mid);
  font-weight: 600;
}


/* ============================================================
   12. PROGRESS BAR
   ============================================================ */

.g-progress-bar-wrap {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  color: var(--g-text-secondary);
}

.g-progress-bar-track {
  height: 4px;
  background: var(--g-cream-secondary);
  border-radius: var(--g-radius-pill);
  overflow: hidden;
  margin-top: 4px;
}

.g-progress-bar-fill {
  height: 100%;
  background: var(--g-brown-mid);
  border-radius: var(--g-radius-pill);
  transition: width 0.4s ease;
}


/* ============================================================
   13. WRITING PAGE
   ============================================================ */

.g-date-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--g-space-sm);
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  color: var(--g-text-secondary);
  background: var(--g-cream-primary);
  border: 1px solid var(--g-cream-secondary);
  border-radius: var(--g-radius-pill);
  padding: 6px 14px;
  cursor: pointer;
  transition: border-color var(--g-transition);
}

.g-date-pill:hover {
  border-color: var(--g-brown-mid);
}

.g-writing-area {
  width: 100%;
  min-height: 200px;
  padding: var(--g-space-lg);
  border: 1.5px solid var(--g-cream-secondary);
  border-radius: var(--g-radius-lg);
  background: var(--g-cream-white);
  font-family: var(--g-font-serif);
  font-size: var(--g-text-md);
  color: var(--g-brown-dark);
  line-height: var(--g-leading-relaxed);
  resize: vertical;
  transition: border-color var(--g-transition), box-shadow var(--g-transition);
}

.g-writing-area:focus {
  border-color: var(--g-brown-mid);
  outline: none;
  box-shadow: 0 0 0 3px rgba(123, 94, 58, 0.08);
}

.g-muse-question {
  font-family: var(--g-font-serif);
  font-style: italic;
  font-size: var(--g-text-lg);
  color: var(--g-brown-dark);
  line-height: var(--g-leading-relaxed);
  padding: var(--g-space-lg) var(--g-space-xl);
  background: var(--g-cream-primary);
  border-left: 3px solid var(--g-brown-mid);
  border-radius: 0 var(--g-radius-md) var(--g-radius-md) 0;
  margin: var(--g-space-xl) 0;
}

.g-btn-muse {
  background: transparent;
  color: var(--g-brown-mid) !important;
  border: 1.5px solid var(--g-brown-mid);
  border-radius: var(--g-radius-md);
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  font-weight: 600;
  padding: 10px 20px;
  cursor: pointer;
  transition: background var(--g-transition), color var(--g-transition);
  letter-spacing: 0.02em;
}

.g-btn-muse:hover {
  background: var(--g-brown-mid);
  color: var(--g-cream-primary) !important;
}

.g-muse-limit {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  color: var(--g-text-tertiary);
  font-style: italic;
  text-align: center;
  padding: var(--g-space-md);
}

.g-quote-artwork {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--g-space-xl);
  align-items: center;
  margin-top: var(--g-space-2xl);
  padding-top: var(--g-space-2xl);
  border-top: 1px solid var(--g-cream-secondary);
}

@media (max-width: 600px) {
  .g-quote-artwork { grid-template-columns: 1fr; }
}


/* ============================================================
   14. MEMBERSHIP TIER CARDS
   ============================================================ */

.g-tier-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--g-space-md);
  margin: var(--g-space-xl) 0;
}

.g-tier-card {
  background: var(--g-cream-white);
  border: 1px solid var(--g-cream-secondary);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-xl) var(--g-space-lg);
  display: flex;
  flex-direction: column;
  position: relative;
}

.g-tier-card.g-tier-recommended {
  border: 2px solid var(--g-olive);
}

.g-recommended-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: var(--g-radius-pill);
  background: var(--g-olive);
  color: var(--g-cream-white);
  white-space: nowrap;
}

.g-tier-name {
  font-family: var(--g-font-serif);
  font-size: var(--g-text-lg);
  color: var(--g-brown-dark);
  margin-bottom: var(--g-space-sm);
}

.g-tier-price {
  font-family: var(--g-font-serif);
  font-size: var(--g-text-2xl);
  color: var(--g-brown-dark);
  margin-bottom: var(--g-space-xs);
}

.g-tier-period {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  color: var(--g-text-tertiary);
  margin-bottom: var(--g-space-lg);
}

.g-tier-features {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--g-space-xl);
  flex: 1;
}

.g-tier-features li {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  color: var(--g-text-secondary);
  padding: 5px 0 5px 20px;
  position: relative;
  line-height: var(--g-leading-snug);
}

.g-tier-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 12px;
  height: 12px;
  border: 1.5px solid var(--g-brown-mid);
  border-radius: 50%;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2.5 6l2.5 2.5 5-5' stroke='%237B5E3A' stroke-width='1.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/11px no-repeat;
}

.g-tier-features li.g-not-included {
  color: #B4B2A9;
}

.g-tier-features li.g-not-included::before {
  border-color: #D3D1C7;
  background: none;
}


/* ============================================================
   15. FOOTER
   ============================================================ */

.site-footer,
.g-footer {
  background: var(--g-cobalt);
  color: rgba(245, 240, 232, 0.85);
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  padding: var(--g-space-2xl) 0;
}

.g-footer a {
  color: rgba(245, 240, 232, 0.7);
  text-decoration: none;
  transition: color var(--g-transition);
}

.g-footer a:hover {
  color: var(--g-cream-primary);
  text-decoration: none;
}

.g-footer-copy {
  color: rgba(245, 240, 232, 0.5);
  font-size: 12px;
  margin-top: var(--g-space-lg);
}


/* ============================================================
   16. UTILITY CLASSES
   ============================================================ */

.g-text-center   { text-align: center; }
.g-text-left     { text-align: left; }
.g-text-right    { text-align: right; }
.g-text-primary  { color: var(--g-text-primary); }
.g-text-secondary { color: var(--g-text-secondary); }
.g-text-tertiary { color: var(--g-text-tertiary); }
.g-text-brand    { color: var(--g-brown-mid); }

.g-mt-sm  { margin-top: var(--g-space-sm); }
.g-mt-md  { margin-top: var(--g-space-md); }
.g-mt-lg  { margin-top: var(--g-space-lg); }
.g-mt-xl  { margin-top: var(--g-space-xl); }
.g-mt-2xl { margin-top: var(--g-space-2xl); }

.g-mb-sm  { margin-bottom: var(--g-space-sm); }
.g-mb-md  { margin-bottom: var(--g-space-md); }
.g-mb-lg  { margin-bottom: var(--g-space-lg); }
.g-mb-xl  { margin-bottom: var(--g-space-xl); }
.g-mb-2xl { margin-bottom: var(--g-space-2xl); }

.g-hidden { display: none; }

.g-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}


/* ============================================================
   17. PAGE COMPONENTS — FREE, LEVELS & CHECKOUT PAGES
   ============================================================ */

.g-delivery-card {
  background: var(--g-cream-primary);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-xl);
  margin-bottom: var(--g-space-2xl);
  border: 1px solid var(--g-cream-secondary);
}

.g-delivery-item {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: var(--g-space-lg);
}

.g-delivery-item:last-child { margin-bottom: 0; }

.g-delivery-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--g-brown-mid);
  margin-top: 9px;
  flex-shrink: 0;
}

.g-delivery-title {
  font-family: var(--g-font-serif);
  font-size: var(--g-text-base);
  color: var(--g-brown-dark);
  margin-bottom: 5px;
  line-height: var(--g-leading-snug);
}

.g-delivery-desc {
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  color: var(--g-text-secondary);
  line-height: var(--g-leading-normal);
}

.g-quote-block {
  border-left: 3px solid var(--g-brown-mid);
  background: var(--g-cream-primary);
  padding: var(--g-space-lg) var(--g-space-xl);
  border-radius: 0 var(--g-radius-md) var(--g-radius-md) 0;
  margin-bottom: var(--g-space-2xl);
}

.g-quote-attr {
  font-family: var(--g-font-sans);
  font-size: 12px;
  color: var(--g-text-tertiary);
  margin-top: var(--g-space-sm);
}

.g-guarantee {
  background: var(--g-cream-primary);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-xl);
  margin-bottom: var(--g-space-2xl);
  text-align: center;
  border: 1px solid var(--g-cream-secondary);
}

.g-guarantee h3 {
  font-family: var(--g-font-serif);
  font-size: var(--g-text-lg);
  font-weight: normal;
  color: var(--g-brown-dark);
  margin-bottom: var(--g-space-sm);
}

.g-guarantee p {
  font-family: var(--g-font-sans);
  font-size: 14px;
  color: var(--g-text-secondary);
  line-height: var(--g-leading-relaxed);
  max-width: 480px;
  margin: 0 auto;
}

.g-faq-item {
  border-bottom: 1px solid var(--g-cream-secondary);
  padding: var(--g-space-lg) 0;
}

.g-faq-item:first-child {
  border-top: 1px solid var(--g-cream-secondary);
}

.g-faq-q {
  font-family: var(--g-font-serif);
  font-size: var(--g-text-base);
  color: var(--g-brown-dark);
  margin-bottom: var(--g-space-sm);
}

.g-faq-a {
  font-family: var(--g-font-sans);
  font-size: 14px;
  color: var(--g-text-secondary);
  line-height: var(--g-leading-relaxed);
}

.g-form-section {
  background: var(--g-cream-primary);
  border-radius: var(--g-radius-lg);
  padding: var(--g-space-xl) var(--g-space-2xl);
  margin-bottom: var(--g-space-2xl);
  border: 1px solid var(--g-cream-secondary);
}

.g-form-heading {
  font-family: var(--g-font-serif);
  font-size: var(--g-text-xl);
  font-weight: normal;
  color: var(--g-brown-dark);
  text-align: center;
  margin-bottom: var(--g-space-sm);
}

.g-form-subheading {
  font-family: var(--g-font-sans);
  font-size: 14px;
  color: var(--g-text-secondary);
  text-align: center;
  line-height: var(--g-leading-normal);
  margin-bottom: var(--g-space-xl);
}

.g-footer-note {
  text-align: center;
  font-family: var(--g-font-sans);
  font-size: var(--g-text-sm);
  color: var(--g-text-tertiary);
  line-height: var(--g-leading-relaxed);
  padding-top: var(--g-space-2xl);
  border-top: 1px solid var(--g-cream-secondary);
  margin-top: var(--g-space-md);
}

@media (max-width: 600px) {
  .g-form-section {
    padding: var(--g-space-lg) var(--g-space-md);
  }
}

/* PMPro checkout page — Guiderly overrides */

/* Fix the olive/green borders on discount and login boxes */
#pmpro_form .pmpro_message,
#pmpro_form .pmpro-has-discount-code,
.pmpro_checkout .pmpro_message,
div.pmpro_checkout_box,
#pmpro_discount_code_area,
.pmpro_level-discount-code-area {
  border-color: #C4B49A !important;
  border-radius: 6px !important;
}

/* Form input fields on checkout */
#pmpro_form input[type="text"],
#pmpro_form input[type="email"],
#pmpro_form input[type="password"],
#pmpro_form input[type="tel"] {
  border: 1.5px solid #C4B49A !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 15px !important;
  color: #2C2C2A !important;
  background: #FFFFFF !important;
}

#pmpro_form input[type="text"]:focus,
#pmpro_form input[type="email"]:focus,
#pmpro_form input[type="password"]:focus {
  border-color: #7B5E3A !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(123, 94, 58, 0.12) !important;
}

/* Submit button */
#pmpro_form input[type="submit"],
#pmpro_form .pmpro_btn {
  background: #7B5E3A !important;
  color: #F5F0E8 !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 13px 24px !important;
  font-family: Arial, Helvetica, sans-serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
}

#pmpro_form input[type="submit"]:hover,
#pmpro_form .pmpro_btn:hover {
  background: #6A5030 !important;
}

/* Checkout box headings */
.pmpro_checkout h3,
.pmpro_checkout h2 {
  font-family: Georgia, 'Times New Roman', serif !important;
  font-weight: normal !important;
  color: #3A2E1E !important;
}
