/**
 * Hot House Design System v2.0
 * Architectural luxury — light-first, quiet gold + deep navy accents.
 * Aligns with Elementor Global Colors (Site Settings kit).
 * Use .hh-scope in Elementor HTML widgets; prefer Elementor globals in templates.
 */

:root {
  /* Base */
  --hh-black: #0c0c0e;
  --hh-graphite: #1a1a1d;
  --hh-slate: #2f3136;
  --hh-soft-gray: #6b6f76;

  /* Light surfaces */
  --hh-white: #f6f6f7;
  --hh-stone: #d9d6d1;
  --hh-sand: #ece8e1;

  /* Accents — warm hearth (footer-adjacent, not cold navy) */
  --hh-gold: #c4a574;
  --hh-bronze: #a88b5b;
  --hh-hearth: #040f1a;
  --hh-navy: #0a1219;
  --hh-midnight: #141c24;
  --hh-navy-hover: #1c2630;

  /* Heat layer — ember accent (Phase 4) */
  --hh-ember: #d8662a;
  --hh-ember-deep: #9e3e1f;
  --hh-fire-glow: rgba(216, 102, 42, 0.16);

  /* Semantic */
  --hh-text: var(--hh-black);
  --hh-text-muted: var(--hh-soft-gray);
  --hh-text-on-dark: var(--hh-white);
  --hh-bg: var(--hh-white);
  --hh-bg-alt: var(--hh-sand);
  --hh-border: rgba(12, 12, 14, 0.1);
  --hh-border-gold: rgba(200, 169, 106, 0.45);
  --hh-whatsapp: #25d366;

  /* Elementor bridge (when kit is synced) */
  --hh-e-primary: var(--e-global-color-primary, var(--hh-black));
  --hh-e-secondary: var(--e-global-color-secondary, var(--hh-graphite));
  --hh-e-text: var(--e-global-color-text, var(--hh-soft-gray));
  --hh-e-accent: var(--e-global-color-accent, var(--hh-gold));

  /* Typography */
  /* Single family site-wide (Heebo); serif alias kept for legacy class names */
  --hh-font-serif: "Heebo", "Assistant", "Noto Sans Hebrew", system-ui, sans-serif;
  --hh-font-sans: "Heebo", "Assistant", "Noto Sans Hebrew", system-ui, sans-serif;
  --hh-font-size-xs: clamp(0.75rem, 0.7rem + 0.15vw, 0.8125rem);
  --hh-font-size-sm: clamp(0.875rem, 0.82rem + 0.2vw, 0.9375rem);
  --hh-font-size-base: clamp(1rem, 0.95rem + 0.25vw, 1.0625rem);
  --hh-font-size-lg: clamp(1.125rem, 1.05rem + 0.35vw, 1.25rem);
  --hh-font-size-xl: clamp(1.375rem, 1.2rem + 0.6vw, 1.625rem);
  --hh-font-size-2xl: clamp(1.75rem, 1.5rem + 1vw, 2.25rem);
  --hh-font-size-3xl: clamp(2.25rem, 1.8rem + 1.6vw, 3rem);
  --hh-font-size-hero: clamp(2.5rem, 2rem + 2.2vw, 3.75rem);
  --hh-line-tight: 1.12;
  --hh-line-body: 1.7;
  --hh-letter-wide: 0.1em;

  /* Spacing */
  --hh-space-xs: 0.5rem;
  --hh-space-sm: 0.75rem;
  --hh-space-md: 1rem;
  --hh-space-lg: 1.5rem;
  --hh-space-xl: 2rem;
  --hh-space-2xl: 3rem;
  --hh-space-3xl: 4.5rem;
  --hh-space-4xl: 6rem;

  --hh-container: 72rem;
  --hh-radius-sm: 2px;
  --hh-radius-md: 6px;
  --hh-shadow-sm: 0 8px 32px rgba(12, 12, 14, 0.06);
  --hh-shadow-md: 0 16px 48px rgba(12, 12, 14, 0.1);
  --hh-transition: 0.25s ease;
}

/* -------------------------------------------------------------------------- */
/* Base — light default                                                       */
/* -------------------------------------------------------------------------- */

.hh-scope {
  font-family: var(--hh-font-sans);
  font-size: var(--hh-font-size-base);
  line-height: var(--hh-line-body);
  color: var(--hh-text);
  background: transparent;
}

.hh-scope h1,
.hh-scope h2,
.hh-scope h3,
.hh-scope h4,
.hh-scope .hh-h1,
.hh-scope .hh-h2,
.hh-scope .hh-h3 {
  font-family: var(--hh-font-serif);
  font-weight: 500;
  line-height: var(--hh-line-tight);
  color: var(--hh-black);
  margin: 0 0 var(--hh-space-md);
}

.hh-scope h1,
.hh-scope .hh-h1 { font-size: var(--hh-font-size-hero); }
.hh-scope h2,
.hh-scope .hh-h2 { font-size: var(--hh-font-size-3xl); }
.hh-scope h3,
.hh-scope .hh-h3 { font-size: var(--hh-font-size-2xl); }

.hh-scope p {
  margin: 0 0 var(--hh-space-md);
  color: var(--hh-text-muted);
}

.hh-scope .hh-eyebrow {
  display: block;
  font-family: var(--hh-font-sans);
  font-size: var(--hh-font-size-xs);
  font-weight: 600;
  letter-spacing: var(--hh-letter-wide);
  text-transform: uppercase;
  color: var(--hh-gold);
  margin-bottom: var(--hh-space-sm);
}

.hh-scope .hh-lead {
  font-size: var(--hh-font-size-lg);
  color: var(--hh-graphite);
  max-width: 40em;
}

.hh-scope a:not([class]) {
  color: var(--hh-navy);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color var(--hh-transition), border-color var(--hh-transition);
}

.hh-scope a:not([class]):hover {
  color: var(--hh-gold);
  border-bottom-color: var(--hh-gold);
}

/* Dark sections */
.hh-section--dark,
.hh-section--graphite,
.hh-scope.hh-section--dark {
  background: var(--hh-graphite);
  color: var(--hh-text-on-dark);
}

.hh-section--dark h1,
.hh-section--dark h2,
.hh-section--dark h3,
.hh-section--dark .hh-h1,
.hh-section--dark .hh-h2,
.hh-section--dark p,
.hh-section--dark .hh-lead {
  color: var(--hh-white);
}

.hh-section--dark p {
  color: rgba(246, 246, 247, 0.78);
}

.hh-section--light,
.hh-section--white {
  background: var(--hh-white);
}

.hh-section--sand {
  background: var(--hh-sand);
}

.hh-section--stone {
  background: var(--hh-stone);
}

.hh-container {
  width: min(100% - var(--hh-space-xl) * 2, var(--hh-container));
  margin-inline: auto;
}

/* -------------------------------------------------------------------------- */
/* Buttons — per brand UI spec                                                */
/* -------------------------------------------------------------------------- */

.hh-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--hh-space-xs);
  min-height: 3rem;
  padding: 0.75rem 1.75rem;
  font-family: var(--hh-font-sans);
  font-size: var(--hh-font-size-sm);
  font-weight: 500;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: var(--hh-radius-sm);
  cursor: pointer;
  transition: background var(--hh-transition), color var(--hh-transition), border-color var(--hh-transition), box-shadow var(--hh-transition);
}

.hh-btn:focus-visible {
  outline: 2px solid var(--hh-gold);
  outline-offset: 3px;
}

/* Primary: Jet Black → Navy hover */
.hh-btn--primary {
  background: var(--hh-black);
  color: var(--hh-white);
  border-color: var(--hh-black);
}

.hh-btn--primary:hover {
  background: var(--hh-navy);
  border-color: var(--hh-navy);
  color: var(--hh-white);
  box-shadow: var(--hh-shadow-sm);
}

.hh-btn--primary::after {
  content: "←";
  margin-inline-start: 0.35rem;
  color: var(--hh-gold);
  font-size: 0.9em;
}

/* Secondary: outline gold */
.hh-btn--secondary {
  background: transparent;
  color: var(--hh-graphite);
  border-color: var(--hh-gold);
}

.hh-btn--secondary:hover {
  background: var(--hh-white);
  color: var(--hh-navy);
  border-color: var(--hh-navy);
}

.hh-btn--navy {
  background: var(--hh-navy);
  color: var(--hh-white);
  border-color: var(--hh-navy);
}

.hh-btn--navy:hover {
  background: var(--hh-midnight);
  color: var(--hh-white);
}

.hh-btn--whatsapp {
  background: var(--hh-whatsapp);
  color: #fff;
  border: none;
}

.hh-btn--whatsapp:hover {
  filter: brightness(1.05);
  color: #fff;
}

.hh-btn--lg { min-height: 3.25rem; padding-inline: 2rem; }
.hh-btn--block { width: 100%; }

/* -------------------------------------------------------------------------- */
/* Badges                                                                     */
/* -------------------------------------------------------------------------- */

.hh-badge-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--hh-space-xs);
  margin-bottom: var(--hh-space-md);
}

.hh-badge {
  display: inline-flex;
  padding: 0.2rem 0.7rem;
  font-size: var(--hh-font-size-xs);
  font-weight: 600;
  letter-spacing: 0.03em;
  border-radius: 999px;
  border: 1px solid var(--hh-border);
  background: var(--hh-white);
  color: var(--hh-soft-gray);
}

a.hh-badge {
  text-decoration: none;
  color: inherit;
}

a.hh-badge:hover .hh-badge__label {
  color: var(--hh-navy);
}

.hh-badge--fuel { border-color: var(--hh-border-gold); color: var(--hh-graphite); }
.hh-badge--brand { background: var(--hh-sand); color: var(--hh-black); }
.hh-badge--quote { background: rgba(16, 35, 59, 0.08); border-color: rgba(16, 35, 59, 0.2); color: var(--hh-navy); }
.hh-badge--technician { background: rgba(16, 35, 59, 0.12); color: var(--hh-navy); }
.hh-badge--install { color: var(--hh-soft-gray); }

/* -------------------------------------------------------------------------- */
/* Cards                                                                      */
/* -------------------------------------------------------------------------- */

.hh-card {
  display: flex;
  flex-direction: column;
  background: var(--hh-white);
  border: 1px solid var(--hh-border);
  border-radius: var(--hh-radius-md);
  overflow: hidden;
  box-shadow: var(--hh-shadow-sm);
  transition: box-shadow var(--hh-transition), border-color var(--hh-transition);
}

.hh-card:hover {
  border-color: var(--hh-border-gold);
  box-shadow: var(--hh-shadow-md);
}

.hh-card__media {
  aspect-ratio: 1 / 1;
  background: var(--hh-white);
  overflow: hidden;
}

.hh-card__media img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.hh-card__body {
  padding: var(--hh-space-lg);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--hh-space-sm);
}

.hh-card__title {
  font-family: var(--hh-font-serif);
  font-size: var(--hh-font-size-xl);
  margin: 0;
  color: var(--hh-black);
}

.hh-card__title a {
  color: inherit;
  text-decoration: none;
}

.hh-card__title a:hover { color: var(--hh-navy); }

.hh-card__meta {
  font-size: var(--hh-font-size-sm);
  color: var(--hh-soft-gray);
}

.hh-card__actions { margin-top: auto; padding-top: var(--hh-space-md); }

.hh-card--product .hh-card__media { aspect-ratio: 4 / 5; }

.hh-card--service {
  background: var(--hh-sand);
  border: none;
}

.hh-card--technician {
  border-inline-start: 3px solid var(--hh-navy);
}

.hh-card-grid {
  display: grid;
  gap: var(--hh-space-lg);
  grid-template-columns: repeat(auto-fill, minmax(min(100%, 15rem), 1fr));
}

/* -------------------------------------------------------------------------- */
/* Sections                                                                   */
/* -------------------------------------------------------------------------- */

.hh-section { padding-block: var(--hh-space-3xl); }

.hh-hero {
  position: relative;
  min-height: clamp(24rem, 55vh, 36rem);
  display: flex;
  align-items: flex-end;
  padding-block: var(--hh-space-4xl);
  background: var(--hh-graphite);
  overflow: hidden;
}

.hh-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0.55;
}

.hh-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(26, 26, 29, 0.2) 0%, rgba(12, 12, 14, 0.85) 100%);
}

.hh-hero__content {
  position: relative;
  z-index: 1;
  width: min(100% - var(--hh-space-xl) * 2, var(--hh-container));
  margin-inline: auto;
  color: var(--hh-white);
}

.hh-hero__title {
  font-size: var(--hh-font-size-hero);
  color: var(--hh-white);
  max-width: 16ch;
}

.hh-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--hh-space-md);
  margin-top: var(--hh-space-xl);
}

.hh-split {
  display: grid;
  gap: var(--hh-space-2xl);
  align-items: center;
}

@media (min-width: 48rem) {
  .hh-split { grid-template-columns: 1fr 1fr; }
}

.hh-split__media {
  border-radius: var(--hh-radius-md);
  overflow: hidden;
  border: 1px solid var(--hh-border);
}

.hh-trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--hh-space-2xl);
  padding: var(--hh-space-xl);
  background: var(--hh-white);
  border-block: 1px solid var(--hh-border);
}

.hh-trust__value {
  font-family: var(--hh-font-serif);
  font-size: var(--hh-font-size-2xl);
  color: var(--hh-navy);
  display: block;
}

.hh-trust__label {
  font-size: var(--hh-font-size-sm);
  color: var(--hh-soft-gray);
}

.hh-faq__item { border-bottom: 1px solid var(--hh-border); }

.hh-faq__question {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--hh-space-lg) 0;
  background: none;
  border: none;
  font-family: var(--hh-font-serif);
  font-size: var(--hh-font-size-lg);
  color: var(--hh-black);
  cursor: pointer;
  text-align: start;
}

.hh-faq__question::after {
  content: "+";
  color: var(--hh-gold);
  font-family: var(--hh-font-sans);
}

.hh-faq__item.is-open .hh-faq__question::after { transform: rotate(45deg); }

.hh-faq__answer {
  display: none;
  padding-bottom: var(--hh-space-lg);
  color: var(--hh-soft-gray);
}

.hh-faq__item.is-open .hh-faq__answer { display: block; }

/* -------------------------------------------------------------------------- */
/* Forms                                                                      */
/* -------------------------------------------------------------------------- */

.hh-form {
  display: flex;
  flex-direction: column;
  gap: var(--hh-space-lg);
  max-width: 28rem;
}

.hh-label {
  font-size: var(--hh-font-size-sm);
  font-weight: 500;
  color: var(--hh-graphite);
}

.hh-input,
.hh-textarea,
.hh-select {
  width: 100%;
  min-height: 3rem;
  padding: 0.75rem 1rem;
  font-family: var(--hh-font-sans);
  font-size: var(--hh-font-size-base);
  color: var(--hh-black);
  background: var(--hh-white);
  border: 1px solid var(--hh-border);
  border-radius: var(--hh-radius-sm);
  transition: border-color var(--hh-transition), box-shadow var(--hh-transition);
}

.hh-input:focus,
.hh-textarea:focus {
  outline: none;
  border-color: var(--hh-navy);
  box-shadow: 0 0 0 3px rgba(16, 35, 59, 0.12);
}

.hh-form--whatsapp {
  padding: var(--hh-space-xl);
  background: var(--hh-sand);
  border-radius: var(--hh-radius-md);
}

.hh-product-cta-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--hh-space-sm);
  margin-top: var(--hh-space-lg);
}
