/*
Theme Name:   Seattle In-Home Massage
Theme URI:    https://seattleinhomemassage.com
Description:  Hello Elementor child theme for seattleinhomemassage.com — concierge luxury massage. Ruby/garnet/cream palette.
Author:       Heavy Metta LLC
Author URI:   https://heavymetta.rocks
Template:     hello-elementor
Version:      1.0.0
Text Domain:  sihm-theme
*/

/* ============================================================
   SIHM — BRAND CSS CUSTOM PROPERTIES
   Ruby · Garnet · Cream — Premium Concierge
   ============================================================ */

:root {
  /* ── Ruby Palette ── */
  --sihm-ruby:         #8B1A2A;
  --sihm-ruby-deep:    #5E0E1A;
  --sihm-ruby-glow:    #B02035;
  --sihm-garnet:       #6B2737;
  --sihm-coral:        #C96B5A;
  --sihm-coral-soft:   #E8A898;

  /* ── Neutrals ── */
  --sihm-dark:         #160C0E;
  --sihm-near-black:   #1F1115;
  --sihm-slate:        #5A4448;
  --sihm-grey:         #9A8888;
  --sihm-champagne:    #EDE4D8;
  --sihm-cream:        #F8F3EE;
  --sihm-off-white:    #FBF8F5;

  /* ── Typography ── */
  --sihm-font-heading: 'Cormorant Garamond', serif;
  --sihm-font-body:    'Jost', sans-serif;

  /* ── Spacing ── */
  --sihm-radius: 0px;
}

/* ============================================================
   GLOBAL BASE
   ============================================================ */

body {
  font-family: var(--sihm-font-body);
  background-color: var(--sihm-off-white);
  color: var(--sihm-dark);
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--sihm-font-heading);
  font-weight: 600;
  line-height: 1.15;
}

a {
  color: var(--sihm-ruby);
  transition: color 0.2s ease;
}

a:hover {
  color: var(--sihm-ruby-glow);
}

/* ============================================================
   ELEMENTOR OVERRIDES
   ============================================================ */

.elementor-widget-heading .elementor-heading-title {
  font-family: var(--sihm-font-heading);
}

.elementor-button {
  font-family: var(--sihm-font-body);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 0;
  transition: all 0.2s ease;
}

/* ============================================================
   SIHM UTILITY CLASSES
   ============================================================ */

.bg-sihm-dark      { background-color: var(--sihm-dark); }
.bg-sihm-ruby      { background-color: var(--sihm-ruby); }
.bg-sihm-garnet    { background-color: var(--sihm-garnet); }
.bg-sihm-cream     { background-color: var(--sihm-cream); }
.bg-sihm-champagne { background-color: var(--sihm-champagne); }

.text-sihm-ruby    { color: var(--sihm-ruby-glow); }
.text-sihm-coral   { color: var(--sihm-coral); }
.text-sihm-cream   { color: var(--sihm-cream); }
.text-sihm-grey    { color: var(--sihm-grey); }

/* Section label kicker */
.sihm-label {
  font-family: var(--sihm-font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--sihm-coral);
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 0.8rem;
}

.sihm-label::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--sihm-coral);
  flex-shrink: 0;
}

/* Tier badge */
.sihm-tier {
  display: inline-block;
  font-family: var(--sihm-font-body);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  padding: 0.3rem 0.8rem;
  border: 1px solid currentColor;
}

.sihm-tier-coral  { color: var(--sihm-coral); }
.sihm-tier-garnet { color: var(--sihm-garnet); background: rgba(107,39,55,0.06); }
.sihm-tier-ruby   { color: var(--sihm-cream); background: var(--sihm-ruby); }

/* ============================================================
   NAVIGATION
   ============================================================ */

.site-header,
.elementor-location-header {
  background: var(--sihm-dark);
  border-bottom: 2px solid var(--sihm-ruby);
}

.elementor-nav-menu a {
  font-family: var(--sihm-font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--sihm-cream);
}

.elementor-nav-menu a:hover {
  color: var(--sihm-coral-soft);
}

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer,
.elementor-location-footer {
  background: var(--sihm-dark);
  border-top: 2px solid var(--sihm-ruby);
  padding: 2.5rem;
}

.hm-footer-family {
  font-family: var(--sihm-font-body);
  font-size: 0.68rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--sihm-grey);
  text-align: center;
}

.hm-footer-family a {
  color: var(--sihm-coral);
  text-decoration: none;
  margin: 0 0.5rem;
  transition: color 0.2s;
}

.hm-footer-family a:hover { color: var(--sihm-cream); }

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 768px) {
  h1 { font-size: 2.4rem; }
  h2 { font-size: 1.8rem; }
}
