/* ============================================================================
   GOLD N DIAMONDS TAMPA — "Gilded Precision" Design System
   Maps the Google Stitch design tokens to CSS custom properties and a set of
   utility classes you can apply to Elementor widgets via their "CSS Classes"
   field (Advanced tab). Nothing here forces a layout — it only supplies brand
   colors, type, spacing and component looks so Elementor stays fully editable.
   ============================================================================ */

:root {
  /* ---- Brand colors (from DESIGN.md) ---- */
  --gnd-gold:            #C9A84C; /* primary interactive gold (buttons, hovers) */
  --gnd-gold-accessible: #856B24; /* gold for text-on-white (passes 4.5:1)      */
  --gnd-gold-dark:       #755b00; /* primary / surface-tint                      */
  --gnd-navy:            #1A1A2E; /* trust bar / institutional dark              */
  --gnd-charcoal:        #1b1c1c; /* default text (never pure black)             */
  --gnd-slate:           #4d4637; /* secondary text                              */
  --gnd-gray:            #666666; /* nav links                                   */
  --gnd-gray-light:      #888888; /* utility / meta text                         */
  --gnd-white:           #ffffff;
  --gnd-surface:         #fbf9f8; /* page background                             */
  --gnd-offwhite:        #F9F9F9; /* section alternation                         */
  --gnd-section-gray:    #F0F0F0; /* footer link band                            */
  --gnd-border:          #E0E0E0; /* inputs / grids                              */
  --gnd-border-soft:     #E5E5E5; /* hairline dividers                           */
  --gnd-error:           #ba1a1a;

  /* ---- Typography ---- */
  --gnd-font-display: "Playfair Display", Georgia, "Times New Roman", serif;
  --gnd-font-body:    "DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --gnd-fs-display:   48px;
  --gnd-fs-display-m: 32px;
  --gnd-fs-h-lg:      32px;
  --gnd-fs-h-md:      24px;
  --gnd-fs-body-lg:   18px;
  --gnd-fs-body:      16px;
  --gnd-fs-label:     12px;
  --gnd-fs-nav:       14px;

  /* ---- Spacing scale ---- */
  --gnd-xs: 4px;
  --gnd-sm: 8px;
  --gnd-md: 16px;
  --gnd-lg: 24px;
  --gnd-xl: 40px;
  --gnd-section: 80px;

  /* ---- Shape & elevation ---- */
  --gnd-radius: 4px;
  --gnd-radius-lg: 8px;
  --gnd-shadow-whisper: 0px 4px 20px rgba(0, 0, 0, 0.05);

  /* ---- Layout ---- */
  --gnd-container: 1200px;
}

/* ----------------------------------------------------------------------------
   Base typography. Hello Elementor is intentionally minimal, so we set sane,
   on-brand defaults. Elementor's Global Kit (set in the editor) will still win
   where you explicitly style a widget, which is what we want.
   ---------------------------------------------------------------------------- */
body {
  font-family: var(--gnd-font-body);
  font-size: var(--gnd-fs-body);
  line-height: 1.6;
  color: var(--gnd-charcoal);
  background-color: var(--gnd-white);
}

h1, h2, h3, h4, h5, h6,
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--gnd-font-display);
  color: var(--gnd-charcoal);
  font-weight: 600;
  line-height: 1.3;
}

/* Editorial display style for hero H1s — add class "gnd-display" to a Heading widget */
.gnd-display {
  font-size: var(--gnd-fs-display);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
}
@media (max-width: 767px) {
  .gnd-display { font-size: var(--gnd-fs-display-m); }
}

/* label-caps: small uppercase kicker above headings — class "gnd-kicker" */
.gnd-kicker {
  font-family: var(--gnd-font-body);
  font-size: var(--gnd-fs-label);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gnd-gold-accessible);
}

/* ----------------------------------------------------------------------------
   Buttons — apply these classes to Elementor Button widgets (Advanced > CSS
   Classes) OR rely on the Global Kit button settings documented in the guide.
   ---------------------------------------------------------------------------- */
.gnd-btn,
.gnd-btn-primary .elementor-button,
a.gnd-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--gnd-sm);
  font-family: var(--gnd-font-body);
  font-weight: 700;
  font-size: var(--gnd-fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 14px 28px;
  border-radius: var(--gnd-radius);
  background-color: var(--gnd-gold);
  color: var(--gnd-white);
  border: 1px solid var(--gnd-gold);
  text-decoration: none;
  transition: background-color .2s ease, color .2s ease;
}
.gnd-btn-primary .elementor-button:hover,
a.gnd-btn-primary:hover,
.gnd-btn:hover {
  background-color: var(--gnd-gold-dark);
  border-color: var(--gnd-gold-dark);
  color: var(--gnd-white);
}

/* Secondary / outline button — class "gnd-btn-outline" */
.gnd-btn-outline .elementor-button,
a.gnd-btn-outline {
  background-color: transparent;
  color: var(--gnd-gold-accessible);
  border: 1px solid var(--gnd-gold);
  padding: 14px 28px;
  border-radius: var(--gnd-radius);
  font-weight: 700;
  font-size: var(--gnd-fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background-color .2s ease, color .2s ease;
}
.gnd-btn-outline .elementor-button:hover,
a.gnd-btn-outline:hover {
  background-color: var(--gnd-gold);
  color: var(--gnd-white);
}

/* ----------------------------------------------------------------------------
   Section helpers — apply to Elementor Section/Container widgets
   ---------------------------------------------------------------------------- */
.gnd-section { padding-top: var(--gnd-section); padding-bottom: var(--gnd-section); }
.gnd-bg-offwhite { background-color: var(--gnd-offwhite); }
.gnd-bg-surface  { background-color: var(--gnd-surface); }
.gnd-container   { max-width: var(--gnd-container); margin-inline: auto; }
.gnd-whisper     { box-shadow: var(--gnd-shadow-whisper); border-radius: var(--gnd-radius); }

/* Card hover lift for product/category cards — class "gnd-card" */
.gnd-card { transition: box-shadow .25s ease, transform .25s ease; border-radius: var(--gnd-radius); }
.gnd-card:hover { box-shadow: var(--gnd-shadow-whisper); transform: translateY(-2px); }

/* ----------------------------------------------------------------------------
   Component: Trust Bar (navy) — rendered by [gnd_trust_bar] shortcode
   ---------------------------------------------------------------------------- */
.gnd-trust-bar {
  background-color: var(--gnd-navy);
  color: #cfcfe0;
  text-align: center;
  padding: 14px var(--gnd-md);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.gnd-trust-bar span { color: #8a8aa3; margin: 0 10px; }

/* Component: Gold category tab bar — [gnd_category_bar] */
.gnd-category-bar {
  background-color: var(--gnd-gold);
  text-align: center;
  padding: 12px var(--gnd-md);
}
.gnd-category-bar a {
  color: var(--gnd-white);
  font-size: var(--gnd-fs-label);
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  margin: 0 14px;
  display: inline-block;
  border-bottom: 2px solid transparent;
  padding-bottom: 2px;
}
.gnd-category-bar a:hover,
.gnd-category-bar a[aria-current="page"] { border-bottom-color: var(--gnd-white); }

/* Component: Reviews bar — [gnd_reviews_bar] */
.gnd-reviews-bar {
  text-align: center;
  padding: var(--gnd-md);
  border-top: 1px solid var(--gnd-border-soft);
  border-bottom: 1px solid var(--gnd-border-soft);
  font-size: var(--gnd-fs-body);
}
.gnd-reviews-bar .gnd-stars { color: var(--gnd-gold); letter-spacing: 2px; }
.gnd-reviews-bar a { color: var(--gnd-gold-accessible); font-weight: 700; }

/* Component: Promise quote — [gnd_promise] */
.gnd-promise {
  max-width: 820px;
  margin-inline: auto;
  text-align: center;
  padding: var(--gnd-xl) var(--gnd-md);
}
.gnd-promise blockquote {
  font-family: var(--gnd-font-display);
  font-size: 22px;
  line-height: 1.5;
  color: var(--gnd-slate);
  margin: 0 0 var(--gnd-md);
  border: 0;
}
.gnd-promise cite {
  font-family: var(--gnd-font-body);
  font-size: var(--gnd-fs-label);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--gnd-gray-light);
  font-style: normal;
}

/* Component: Company contact block — [gnd_contact_block] */
.gnd-contact-block { text-align: center; padding: var(--gnd-xl) var(--gnd-md); }
.gnd-contact-block .gnd-circle {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--gnd-gold); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 24px; margin-bottom: var(--gnd-md);
}
.gnd-contact-block strong { display: block; font-family: var(--gnd-font-display); font-size: 20px; }

/* Component: How It Works steps — [gnd_how_it_works] */
.gnd-hiw { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gnd-xl); }
@media (max-width: 767px) { .gnd-hiw { grid-template-columns: 1fr; } }
.gnd-hiw .gnd-step { text-align: center; }
.gnd-hiw .gnd-step-num {
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid var(--gnd-gold);
  color: var(--gnd-gold-accessible);
  font-family: var(--gnd-font-display); font-size: 20px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--gnd-md);
}
.gnd-hiw .gnd-step h3 { font-size: var(--gnd-fs-h-md); margin: 0 0 var(--gnd-sm); }
.gnd-hiw .gnd-step p { color: var(--gnd-slate); margin: 0; }
