/* ===========================
   Live Leife – Universal CSS
   Palette: Gold | Ivory | Ink
   Fonts: Cormorant Garamond + Inter
   =========================== */

   :root {
    --leife-gold: #C6AD6A;      /* From logo */
    --leife-ink: #211f24;
    --leife-soft-ink: #6e6a73;
    --leife-shell: #f7f4ee;
    --leife-card: #ffffff;
    --leife-border-soft: #e6e0d2;
  
    --leife-radius-xl: 32px;
    --leife-radius-lg: 24px;
    --leife-radius-pill: 999px;
  
    --leife-shadow-soft: 0 28px 70px rgba(19, 12, 3, 0.16);
    --leife-shadow-light: 0 16px 40px rgba(19, 12, 3, 0.08);
  
    --leife-transition: 0.25s ease;
  }
  
  /* Reset-ish */
  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }
  
  html,
  body {
    margin: 0;
    padding: 0;
  }
  
  body.leife-body {
    font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background: radial-gradient(circle at top left, #fdf9f1 0%, var(--leife-shell) 40%, #ffffff 100%);
    color: var(--leife-ink);
    -webkit-font-smoothing: antialiased;
  }
  
  /* Typography */
  
  h1, h2, h3, h4 {
    font-family: "Cormorant Garamond", "Garamond", "Times New Roman", serif;
    font-weight: 600;
    letter-spacing: 0.01em;
  }
  
  p {
    font-size: 0.98rem;
    line-height: 1.7;
    color: var(--leife-soft-ink);
  }
  
  /* Layout helpers */
  
  .leife-container {
    width: min(1120px, 100% - 3rem);
    margin-inline: auto;
  }
  
  .leife-section {
    padding: 4.5rem 0;
  }
  
  .leife-section-soft {
    background: #fbf8f3;
  }
  
  /* Header */
  
  .leife-header {
    position: sticky;
    top: 0;
    z-index: 40;
    backdrop-filter: blur(18px);
    background: rgba(255, 255, 255, 0.92);
    border-bottom: 1px solid rgba(198, 173, 106, 0.12);
  }
  
  .leife-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: 0.75rem;
  }
  
  .leife-logo-img {
    height: 46px;
    display: block;
  }
  
  .leife-nav {
    display: flex;
    align-items: center;
    gap: 1.75rem;
    font-size: 0.9rem;
  }
  
  .leife-nav a {
    text-decoration: none;
    color: var(--leife-soft-ink);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-weight: 500;
    font-size: 0.78rem;
  }
  
  .leife-nav a:hover {
    color: var(--leife-ink);
  }
  
  .leife-nav-cta {
    padding: 0.6rem 1.4rem;
    border-radius: var(--leife-radius-pill);
    border: 1px solid rgba(198, 173, 106, 0.7);
    color: var(--leife-ink);
    background: linear-gradient(135deg, #fffaf1 0%, #f6ebd4 60%, #fefcf7 100%);
    box-shadow: 0 10px 24px rgba(198, 173, 106, 0.25);
  }
  
  /* Hero */
  
  .leife-hero {
    padding: 4.5rem 0 3.5rem;
  }
  
  .leife-hero-card {
    background: var(--leife-card);
    border-radius: var(--leife-radius-xl);
    box-shadow: var(--leife-shadow-soft);
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    gap: 0;
    overflow: hidden;
  }
  
  .leife-hero-copy {
    padding: 3.5rem 3.25rem;
  }
  
  .leife-eyebrow {
    font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--leife-gold);
    margin-bottom: 0.8rem;
  }
  
  .leife-hero-title {
    font-size: clamp(2.6rem, 3vw + 1.6rem, 3.3rem);
    line-height: 1.1;
    color: var(--leife-ink);
    margin-bottom: 1.05rem;
  }
  
  .leife-hero-lead {
    font-size: 1rem;
    max-width: 34rem;
    color: var(--leife-soft-ink);
    margin-bottom: 1.75rem;
  }
  
  .leife-hero-cta {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.95rem 1.9rem;
    border-radius: var(--leife-radius-pill);
    text-decoration: none;
    border: none;
    background: linear-gradient(135deg, #f3d9a5 0%, var(--leife-gold) 45%, #af8f4e 100%);
    color: #201c14;
    font-weight: 600;
    font-size: 0.9rem;
    letter-spacing: 0.09em;
    text-transform: uppercase;
    box-shadow: 0 14px 30px rgba(112, 87, 30, 0.4);
    transform: translateY(0);
    transition: transform var(--leife-transition), box-shadow var(--leife-transition), filter var(--leife-transition);
  }
  
  .leife-hero-cta:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 46px rgba(112, 87, 30, 0.55);
    filter: brightness(1.03);
  }
  
  .leife-hero-cta-arrow {
    font-size: 1rem;
  }
  
  .leife-hero-subcopy {
    margin-top: 1.3rem;
    font-size: 0.9rem;
    max-width: 28rem;
  }
  
  /* Hero media */
  
  .leife-hero-media {
    position: relative;
    background: radial-gradient(circle at top, #fef9ee 0%, #f4ece0 48%, #fdfaf5 100%);
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 2.25rem 2.25rem 2.75rem;
  }
  
  .leife-hero-img {
    width: 100%;
    max-width: 420px;
    border-radius: 28px;
    object-fit: cover;
    box-shadow: var(--leife-shadow-light);
  }
  
  /* Section headers */
  
  .leife-section-header {
    max-width: 640px;
    margin-inline: auto;
    text-align: center;
    margin-bottom: 2.5rem;
  }
  
  .leife-section-header h2 {
    font-size: 2.1rem;
    margin-bottom: 0.6rem;
  }
  
  .leife-section-lead {
    font-size: 0.98rem;
    color: var(--leife-soft-ink);
  }
  
  /* Grid */
  
  .leife-grid {
    display: grid;
    gap: 1.8rem;
  }
  
  .leife-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  
  @media (max-width: 900px) {
    .leife-grid-3 {
      grid-template-columns: 1fr;
    }
  }
  
  /* Cards */
  
  .leife-card {
    background: #ffffff;
    border-radius: 20px;
    padding: 1.8rem 1.7rem 1.9rem;
    border: 1px solid rgba(230, 224, 210, 0.9);
    box-shadow: 0 10px 26px rgba(31, 18, 5, 0.06);
  }
  
  .leife-card h3 {
    font-size: 1.3rem;
    margin-bottom: 0.4rem;
  }
  
  /* Steps */
  
  .leife-steps {
    align-items: stretch;
  }
  
  .leife-step {
    background: linear-gradient(145deg, #fffdf8 0%, #f7efe0 55%, #fefaf2 100%);
    border-radius: 22px;
    padding: 1.9rem 1.8rem 2rem;
    border: 1px solid rgba(198, 173, 106, 0.32);
    box-shadow: 0 16px 40px rgba(150, 120, 55, 0.18);
  }
  
  .leife-step-number {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: rgba(198, 173, 106, 0.12);
    color: var(--leife-gold);
    font-size: 0.85rem;
    margin-bottom: 0.65rem;
    font-weight: 600;
  }
  
  /* Assurance strip */
  
  .leife-assurance {
    padding: 2.4rem 0;
    background: #1b191e;
    color: #fdfaf4;
  }
  
  .leife-assurance-inner {
    text-align: center;
    font-size: 0.92rem;
  }
  
  .leife-assurance strong {
    color: #f6e3b7;
  }
  
  /* Contact */
  
 /* CONTACT LAYOUT */

.leife-contact {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 3rem;
  align-items: flex-start;
  margin-top: 2rem;
}

.leife-contact-form {
  background: #ffffff;
  border-radius: 22px;
  padding: 2rem 2rem 2.2rem;
  box-shadow: 0 14px 38px rgba(23, 16, 6, 0.12);
  border: 1px solid rgba(230, 224, 210, 0.9);
}

.leife-contact-intro {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--leife-soft-ink);
  margin-bottom: 1.2rem;
}

.leife-contact-copy h2 {
  margin-top: 0.4rem;
  font-family: "Cormorant Garamond", serif;
  font-size: 1.5rem;
}

.leife-contact-copy p {
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--leife-soft-ink);
  margin-top: 0.6rem;
}

/* Fields */

.leife-form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.leife-form-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

.leife-form-field label {
  font-size: 0.8rem;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--leife-soft-ink);
  font-weight: 500;
}

.leife-form-field input,
.leife-form-field select,
.leife-form-field textarea {
  border-radius: 12px;
  border: 1px solid var(--leife-border-soft);
  padding: 0.7rem 0.9rem;
  font-family: inherit;
  font-size: 0.92rem;
  color: var(--leife-ink);
  background: #fcfbf7;
  outline: none;
  transition: border-color var(--leife-transition), box-shadow var(--leife-transition), background var(--leife-transition);
}

.leife-form-field textarea {
  resize: vertical;
  min-height: 120px;
}

.leife-form-field input:focus,
.leife-form-field select:focus,
.leife-form-field textarea:focus {
  border-color: var(--leife-gold);
  box-shadow: 0 0 0 1px rgba(198, 173, 106, 0.5);
  background: #ffffff;
}

/* Radio pill styling */

.leife-radio-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.leife-radio-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  border: 1px solid var(--leife-border-soft);
  background: #fcfbf7;
  font-size: 0.86rem;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.leife-radio-pill:hover {
  background: #f6f1e6;
  border-color: rgba(193, 169, 115, 0.7);
  box-shadow: 0 6px 14px rgba(27, 20, 8, 0.08);
}

.leife-radio-pill input[type="radio"] {
  margin: 0;
  accent-color: var(--leife-gold);
}

/* Submit button alignment */

.leife-contact-submit {
  width: 100%;
  justify-content: center;
  margin-top: 0.4rem;
}

.leife-contact-note {
  margin-top: 0.8rem;
  font-size: 0.78rem;
  color: var(--leife-soft-ink);
}

/* Responsive */

@media (max-width: 900px) {
  .leife-contact {
    grid-template-columns: 1fr;
    gap: 2rem;
  }

  .leife-form-row {
    grid-template-columns: 1fr;
  }
}

  
  /* Footer */
  
  .leife-footer {
    background: #151318;
    color: #f8f4ea;
    padding: 2.5rem 0 2rem;
  }
  
  .leife-footer-inner {
    text-align: center;
  }
  
  .leife-footer-brand {
    font-family: "Cormorant Garamond", "Garamond", serif;
    font-size: 1.4rem;
    margin-bottom: 0.4rem;
  }
  
  .leife-footer-links {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1.4rem;
    margin-bottom: 0.9rem;
  }
  
  .leife-footer-links a {
    text-decoration: none;
    color: #d3cabc;
    font-size: 0.8rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
  }
  
  .leife-footer-links a:hover {
    color: #f6e3b7;
  }
  
  .leife-footer-meta {
    font-size: 0.78rem;
    color: #9f9588;
  }
  
  /* Responsiveness */
  
  @media (max-width: 900px) {
    .leife-hero {
      padding-top: 3.5rem;
    }
  
    .leife-hero-card {
      grid-template-columns: 1fr;
    }
  
    .leife-hero-copy {
      padding: 2.6rem 2.1rem 2.3rem;
    }
  
    .leife-hero-media {
      padding: 1.8rem 2rem 2.2rem;
    }
  
    .leife-contact {
      grid-template-columns: 1fr;
    }
  
    .leife-nav {
      display: none; /* keep desktop-first; mobile nav can be added later */
    }
  }
  /* Radio pill styling reintroduced */
.leife-radio-group {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.leife-radio-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  border: 1px solid var(--leife-border-soft);
  background: #fcfbf7;
  font-size: 0.86rem;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}

.leife-radio-pill:hover {
  background: #f6f1e6;
  border-color: rgba(193, 169, 115, 0.7);
  box-shadow: 0 6px 14px rgba(27, 20, 8, 0.08);
}

.leife-radio-pill input[type="radio"] {
  margin: 0;
  accent-color: var(--leife-gold);
}

  @media (max-width: 600px) {
    .leife-container {
      width: min(100% - 2rem, 100%);
    }
  
    .leife-hero-copy {
      padding-inline: 1.6rem;
    }
  
    .leife-section {
      padding: 3.2rem 0;
    }
  
    .leife-form-row {
      grid-template-columns: 1fr;
    }
  }
  /* ===== Philosophy Page Tweaks ===== */

.leife-philo-hero .leife-hero-card {
    margin-top: 1.2rem;
  }
  
  /* 2-column grid helper */
  .leife-grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  
  @media (max-width: 900px) {
    .leife-grid-2 {
      grid-template-columns: 1fr;
    }
  }
  
  /* Philosophy cards variations */
  .leife-philo-columns .leife-card {
    min-height: 100%;
  }
  
  .leife-card-contrast {
    background: #151318;
    color: #f6eee0;
    border-color: rgba(246, 238, 224, 0.4);
  }
  
  .leife-card-contrast h3 {
    color: #f6e3b7;
  }
  
  .leife-card-contrast p,
  .leife-card-contrast li {
    color: #e7dfd2;
  }
  
  .leife-card-muted {
    background: #fbf8f3;
  }
  
  /* Lists inside cards */
  .leife-list {
    list-style: none;
    padding-left: 0;
    margin: 0.4rem 0 0;
  }
  
  .leife-list li {
    font-size: 0.94rem;
    color: var(--leife-soft-ink);
    margin-bottom: 0.45rem;
  }
  
  .leife-card-contrast .leife-list li {
    color: #e7dfd2;
  }
  
  /* Closing CTA alignment */
  .leife-philo-close {
    text-align: center;
  }
  
  .leife-philo-cta-wrap {
    margin-top: 1.5rem;
  }
  /* ===== Services Page – Archetypes ===== */

.leife-services-hero {
    padding-top: 3.8rem;
  }
  
  .leife-services-hero-card {
    margin-top: 0.8rem;
  }
  
  .leife-services-hero-media {
    align-items: center;
  }
  
  /* Plans / archetype cards */
  
  .leife-plan-grid {
    align-items: stretch;
  }
  
  .leife-plan {
    background: #ffffff;
    border-radius: 24px;
    padding: 2.1rem 1.9rem 2.2rem;
    border: 1px solid rgba(230, 224, 210, 0.9);
    box-shadow: 0 16px 36px rgba(23, 16, 6, 0.08);
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
  }
  
  .leife-plan-highlight {
    background: linear-gradient(150deg, #fffaf1 0%, #f6ebd4 50%, #fefbf6 100%);
    border-color: rgba(198, 173, 106, 0.55);
    box-shadow: 0 22px 48px rgba(130, 105, 52, 0.3);
  }
  
  .leife-plan-tag {
    font-size: 0.78rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--leife-gold);
    font-weight: 500;
  }
  
  .leife-plan-title {
    font-size: 1.7rem;
    margin-bottom: 0.1rem;
  }
  
  .leife-plan-intro {
    font-size: 0.96rem;
  }
  
  .leife-plan-list {
    list-style: none;
    padding-left: 0;
    margin: 0.4rem 0 0.4rem;
  }
  
  .leife-plan-list li {
    position: relative;
    padding-left: 1.2rem;
    margin-bottom: 0.35rem;
    font-size: 0.93rem;
    color: var(--leife-soft-ink);
  }
  
  .leife-plan-list li::before {
    content: "•";
    position: absolute;
    left: 0;
    top: 0.05rem;
    color: var(--leife-gold);
    font-size: 0.9rem;
  }
  
  .leife-plan-suited {
    font-size: 0.9rem;
    margin-top: 0.3rem;
  }
  
  .leife-plan-cta {
    margin-top: auto;
    font-size: 0.86rem;
    text-decoration: none;
    letter-spacing: 0.11em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--leife-ink);
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
  }
  
  .leife-plan-cta::after {
    content: "↗";
    font-size: 0.9rem;
  }
  
  .leife-plan-cta-primary {
    color: #2b2416;
  }
  
  /* Comparison table */
  
  .leife-services-table {
    margin-top: 1.5rem;
    border-radius: 24px;
    overflow: hidden;
    border: 1px solid var(--leife-border-soft);
    background: #ffffff;
  }
  
  .leife-services-row {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) repeat(3, minmax(0, 1fr));
    border-top: 1px solid #efe7d8;
    font-size: 0.9rem;
  }
  
  .leife-services-row:first-of-type {
    border-top: none;
  }
  
  .leife-services-row > div {
    padding: 0.9rem 1.2rem;
  }
  
  .leife-services-row-head {
    background: #fbf6ec;
    font-weight: 600;
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--leife-soft-ink);
  }
  
  .leife-services-label {
    background: #fbf8f3;
    font-weight: 500;
  }
  
  /* Services FAQ / CTA */
  
  .leife-services-faq .leife-card {
    min-height: 100%;
  }
  
  .leife-services-cta {
    margin-top: 2rem;
    text-align: center;
  }
  
  /* Responsiveness for services */
  
  @media (max-width: 900px) {
    .leife-services-row {
      grid-template-columns: 1fr;
    }
  
    .leife-services-label {
      border-bottom: 1px solid #efe7d8;
    }
  }
  /* IMAGES UPDATE */
  /* ==========================
   HERO FIXES FOR LIVE LEIFE
   ========================== */

/* ---------------------------------------------------
   LIVE LEIFE — HERO IMAGE SIZE UPGRADE (MINIMAL)
   Keeps all previous styling, just improves proportion.
   --------------------------------------------------- */
/* ---------------------------------------------
   LIVE LEIFE — HERO IMAGE SIZE CORRECTION
   Slightly smaller, perfectly proportioned
   --------------------------------------------- */

   .leife-hero-img {
    max-height: 320px !important;    /* reduced from 420px */
    width: 100%;
    height: auto !important;
    object-fit: cover;
    border-radius: 24px;
  }
  
  /* Slightly adjust spacing around image so it breathes */
  .leife-hero-media {
    padding: 1.5rem !important;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  /* Keep card height balanced */
  .leife-hero-card {
    min-height: 360px !important;   /* reduced for elegance */
  }
/* ---------------------------------------------------
   LIVE LEIFE — HERO IMAGE ENLARGEMENT (PERFECT BALANCE)
   --------------------------------------------------- */

   .leife-hero-card {
    grid-template-columns: 1fr 1.1fr !important; /* give more space to image */
  }
  
  /* Make image taller AND wider */
  .leife-hero-img {
    width: 100% !important;
    height: 100% !important;
    max-height: 245px !important;   /* increased */
    object-fit: cover !important;
    border-radius: 24px;
  }
  
  /* Reduce padding so the image occupies more space */
  .leife-hero-media {
    padding: 0.8rem 1.2rem !important;   /* reduced from 1.5–2rem */
    display: flex;
    justify-content: center;
    align-items: center;
  }
  
  /* Slightly increase card height to match new proportions */
  .leife-hero-card {
    min-height: 400px !important;
  }
/* ===== For Families Page ===== */

.leife-family-hero .leife-hero-card {
    margin-top: 1rem;
  }
  
  .leife-family-grid .leife-card,
  .leife-family-vignettes .leife-card {
    min-height: 100%;
  }
  
  .leife-card-soft {
    background: #fbf8f3;
    border-radius: 20px;
  }
  
  /* Active nav link styling */
  .leife-nav a.is-active {
    color: var(--leife-ink);
  }
  
  /* Slight tweak so hero on families page stays airy */
  .leife-family-hero {
    padding-top: 4rem;
  }
  /* ==============================
   CONTACT PAGE – LUXURY LAYOUT
   ============================== */

.leife-contact-hero {
    padding-top: 4rem;
    padding-bottom: 2.2rem;
  }
  
  .leife-contact-hero-card {
    background: #ffffff;
    border-radius: 28px;
    box-shadow: 0 32px 80px rgba(0, 0, 0, 0.08);
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
    overflow: hidden;
  }
  
  .leife-contact-hero-copy {
    padding: 3.2rem 3.2rem 3rem;
  }
  
  .leife-contact-hero-media {
    background: radial-gradient(circle at top, #fdf8ef 0%, #f5e9d6 45%, #f8f4ec 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 2.2rem;
  }
  
  .leife-contact-hero-img {
    width: 100%;
    max-width: 420px;
    max-height: 320px;
    object-fit: cover;
    border-radius: 24px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.22);
  }
  
  /* Phone callout */
  
  .leife-contact-callout {
    margin-top: 1.8rem;
    padding: 1.2rem 1.4rem;
    border-radius: 18px;
    background: #fbf6ec;
    border: 1px solid rgba(198, 173, 106, 0.4);
  }
  
  .leife-contact-callout-label {
    font-size: 0.78rem;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--leife-soft-ink);
    margin-bottom: 0.25rem;
  }
  
  .leife-contact-callout-main {
    font-family: "Cormorant Garamond", serif;
    font-size: 1.5rem;
    margin-bottom: 0.2rem;
  }
  
  .leife-contact-callout-main span {
    color: var(--leife-gold);
  }
  
  .leife-contact-callout-note {
    font-size: 0.82rem;
    color: var(--leife-soft-ink);
  }
  
  /* Page layout */
  
  .leife-contact-page {
    padding-top: 1.4rem;
    padding-bottom: 4rem;
  }
  
  .leife-contact-page-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
    gap: 2.5rem;
    align-items: flex-start;
  }
  
  /* Form tweaks for page version */
  
  .leife-contact-form-page {
    padding: 2.1rem 2.1rem 2.4rem;
  }
  
  .leife-consent {
    display: flex;
    align-items: flex-start;
    gap: 0.6rem;
    font-size: 0.8rem;
    margin-top: 0.4rem;
    margin-bottom: 1rem;
    color: var(--leife-soft-ink);
  }
  
  .leife-consent input[type="checkbox"] {
    margin-top: 0.2rem;
  }
  
  /* Side column */
  
  .leife-contact-side {
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
  }
  
  .leife-contact-side-block h2,
  .leife-contact-side-block h3 {
    font-size: 1.3rem;
    margin-bottom: 0.4rem;
  }
  
  .leife-contact-side-block p {
    font-size: 0.9rem;
    color: var(--leife-soft-ink);
  }
  
  /* Responsive */
  
  @media (max-width: 900px) {
    .leife-contact-hero-card {
      grid-template-columns: 1fr;
    }
  
    .leife-contact-hero-copy {
      padding: 2.5rem 2rem 1.9rem;
    }
  
    .leife-contact-hero-media {
      padding-inline: 2rem;
      padding-bottom: 2.3rem;
    }
  
    .leife-contact-page-layout {
      grid-template-columns: 1fr;
    }
  }
  
  @media (max-width: 600px) {
    .leife-contact-hero-copy {
      padding-inline: 1.6rem;
    }
  
    .leife-contact-form-page {
      padding-inline: 1.4rem;
    }
  }
  /* ==========================
   LEGAL / PRIVACY PAGES
   ========================== */

.leife-legal-hero {
    padding-top: 4rem;
    padding-bottom: 1.6rem;
  }
  
  .leife-legal-hero-card {
    max-width: 860px;
    margin: 0 auto;
    background: #ffffff;
    border-radius: 24px;
    padding: 2.4rem 2.6rem 2.2rem;
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.06);
  }
  
  .leife-legal-body {
    padding-top: 0.6rem;
    padding-bottom: 4rem;
  }
  
  .leife-legal {
    max-width: 860px;
    margin: 0 auto;
  }
  
  .leife-legal-card {
    background: #ffffff;
    border-radius: 24px;
    padding: 2.4rem 2.6rem 2.8rem;
    border: 1px solid rgba(230, 224, 210, 0.9);
  }
  
  .leife-legal-updated {
    font-size: 0.82rem;
    color: var(--leife-soft-ink);
    margin-bottom: 1rem;
  }
  
  .leife-legal-card h2 {
    font-size: 1.4rem;
    margin-top: 1.8rem;
    margin-bottom: 0.4rem;
  }
  
  .leife-legal-card h3 {
    font-size: 1.05rem;
    margin-top: 1.2rem;
    margin-bottom: 0.3rem;
  }
  
  .leife-legal-card p {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--leife-soft-ink);
  }
  
  .leife-legal-card ul {
    margin: 0.4rem 0 0.8rem 1.2rem;
    padding-left: 0.4rem;
  }
  
  .leife-legal-card li {
    font-size: 0.93rem;
    line-height: 1.6;
    color: var(--leife-soft-ink);
    margin-bottom: 0.25rem;
  }
  
  .leife-legal-highlight {
    background: #fbf6ec;
    border-radius: 16px;
    padding: 0.9rem 1.1rem;
    margin: 0.6rem 0 0.4rem;
    font-size: 0.93rem;
  }
  
  .leife-legal-card a {
    color: var(--leife-gold);
    text-decoration: none;
  }
  
  .leife-legal-card a:hover {
    text-decoration: underline;
  }
  
  @media (max-width: 768px) {
    .leife-legal-hero-card,
    .leife-legal-card {
      padding-inline: 1.6rem;
    }
  }
  /* ==========================
   JOURNAL PAGE STYLES
   ========================== */

.leife-journal-hero {
    padding-top: 4rem;
    padding-bottom: 1rem;
  }
  
  .leife-journal-hero-card {
    max-width: 840px;
    margin: 0 auto;
    background: #ffffff;
    border-radius: 26px;
    padding: 2.6rem 2.7rem 2.4rem;
    box-shadow: 0 30px 70px rgba(0,0,0,0.06);
  }
  
  .leife-journal-grid-section {
    padding-top: 1.6rem;
    padding-bottom: 4rem;
  }
  
  .leife-journal-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(290px, 1fr));
    gap: 2.2rem;
  }
  
  .leife-journal-card {
    background: #ffffff;
    border-radius: 24px;
    padding: 1.4rem 1.4rem 1.8rem;
    box-shadow: 0 22px 55px rgba(0,0,0,0.07);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  
  .leife-journal-img-wrap img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: 18px;
  }
  
  .leife-journal-title {
    font-family: "Cormorant Garamond", serif;
    font-size: 1.45rem;
    margin-top: 1rem;
    margin-bottom: 0.4rem;
    line-height: 1.3;
    color: var(--leife-ink);
  }
  
  .leife-journal-excerpt {
    font-size: 0.92rem;
    line-height: 1.65;
    color: var(--leife-soft-ink);
    margin-bottom: 1rem;
  }
  
  .leife-journal-read {
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--leife-gold);
    text-decoration: none;
    margin-top: auto;
  }
  
  .leife-journal-read:hover {
    text-decoration: underline;
  }
  
  /* Mobile */
  @media (max-width: 600px) {
    .leife-journal-hero-card {
      padding-inline: 1.6rem;
    }
  }
  /* ==========================
   FEATURED ARTICLE
   ========================== */

.leife-featured-article-section {
  padding-top: 1rem;
  padding-bottom: 2rem;
}

.leife-featured-article-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  background: #ffffff;
  border-radius: 28px;
  box-shadow: 0 35px 80px rgba(0,0,0,0.08);
  overflow: hidden;
}

.leife-featured-article-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  min-height: 320px;
}

.leife-featured-article-content {
  padding: 2.6rem 2.8rem;
}

.leife-featured-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 2rem;
  line-height: 1.27;
  margin-top: 0.4rem;
  margin-bottom: 1rem;
}

.leife-featured-excerpt {
  font-size: 1rem;
  line-height: 1.7;
  color: var(--leife-soft-ink);
  margin-bottom: 1.3rem;
}

.leife-featured-read {
  font-size: 1rem;
  color: var(--leife-gold);
  text-decoration: none;
  font-weight: 500;
}

.leife-featured-read:hover {
  text-decoration: underline;
}

/* Responsive */
@media (max-width: 900px) {
  .leife-featured-article-card {
    grid-template-columns: 1fr;
  }

  .leife-featured-article-image img {
    height: 260px;
  }

  .leife-featured-article-content {
    padding: 2rem 1.6rem;
  }
}
/* ==========================
   JOURNAL ARTICLE PAGES – UPGRADED
   ========================== */

   .leife-article-hero {
    padding-top: 3.5rem;
    padding-bottom: 1.4rem;
  }
  
  /* White hero card */
  .leife-article-hero-card {
    background: #ffffff;
    border-radius: 28px;
    box-shadow: 0 30px 70px rgba(0,0,0,0.07);
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.2fr);
    gap: 2.4rem;
    align-items: center;
    padding: 2.2rem 2.4rem;
  }
  
  .leife-article-hero-image img {
    width: 100%;
    border-radius: 22px;
    object-fit: cover;
    max-height: 340px;
    box-shadow: 0 18px 45px rgba(0,0,0,0.18);
  }
  
  .leife-article-hero-text {
    max-width: 600px;
  }
  
  .leife-article-title {
    font-family: "Cormorant Garamond", serif;
    font-size: 2.2rem;
    line-height: 1.25;
    margin-top: 0.4rem;
    margin-bottom: 0.7rem;
  }
  
  .leife-article-intro {
    font-size: 1rem;
    line-height: 1.7;
    color: var(--leife-soft-ink);
  }
  
  /* Body card */
  
  .leife-article-body-section {
    padding-top: 0.6rem;
    padding-bottom: 3rem;
  }
  
  .leife-article-body-card {
    background: #ffffff;
    border-radius: 24px;
    box-shadow: 0 26px 60px rgba(0,0,0,0.06);
    padding: 2.2rem 2.4rem 2.6rem;
  }
  
  .leife-article-body {
    max-width: 760px;
    margin: 0 auto;
  }
  
  .leife-article-body article p {
    font-size: 0.98rem;
    line-height: 1.8;
    color: var(--leife-soft-ink);
    margin-bottom: 0.9rem;
  }
  
  .leife-article-body article h2 {
    font-size: 1.3rem;
    margin-top: 1.7rem;
    margin-bottom: 0.5rem;
  }
  
  .leife-article-body article ul {
    margin: 0.4rem 0 0.9rem 1.2rem;
  }
  
  .leife-article-body article li {
    font-size: 0.95rem;
    line-height: 1.7;
    color: var(--leife-soft-ink);
    margin-bottom: 0.25rem;
  }
  
  /* Pull quote */
  
  .leife-article-quote {
    margin: 1.4rem 0;
    padding: 1.1rem 1.3rem;
    border-left: 3px solid var(--leife-gold);
    background: #fbf6ec;
    border-radius: 0 18px 18px 0;
    font-size: 0.96rem;
    line-height: 1.8;
    color: var(--leife-soft-ink);
    font-style: italic;
  }
  
  /* Related section stays as before */
  .leife-related-section {
    padding-top: 0.4rem;
    padding-bottom: 3.2rem;
  }
  
  .leife-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
    gap: 1.7rem;
  }
  
  .leife-journal-card-compact {
    padding: 1rem 1rem 1.4rem;
    box-shadow: 0 14px 40px rgba(0,0,0,0.06);
  }
  
  /* Responsive */
  
  @media (max-width: 900px) {
    .leife-article-hero-card {
      grid-template-columns: 1fr;
      padding: 1.9rem 1.8rem;
    }
  
    .leife-article-hero-image img {
      max-height: 260px;
    }
  }
  
  @media (max-width: 600px) {
    .leife-article-body-card {
      padding-inline: 1.6rem;
    }
  }
  /* Article Break Card */
.leife-article-break-card {
  background: #ffffff;
  border: 1px solid #ececec;
  border-radius: 22px;
  padding: 2rem 2.2rem;
  margin: 2.8rem 0;
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.06);
}

.leife-article-break-card p {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.3rem !important;
  line-height: 1.5;
  color:#af8f4e !important;
  /* color:  var(--leife-ink); */
  text-align: center;
}
/* =========================================
   LIVE LEIFE – SERVICES PAGE LAYOUT
   ========================================= */

/* Hero section */
.leife-services-hero {
  padding-top: 3.5rem;
  padding-bottom: 2.5rem;
}

.leife-services-hero-card {
  background: #ffffff;
  border-radius: 28px;
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.08);
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 2.4rem;
  align-items: center;
  padding: 2.4rem 2.6rem;
}

.leife-services-hero-text {
  max-width: 620px;
}

.leife-services-hero-image img {
  width: 100%;
  height: 100%;
  max-height: 360px;
  border-radius: 22px;
  object-fit: cover;
  box-shadow: 0 22px 55px rgba(0, 0, 0, 0.16);
}

/* Services grid */

.leife-services-grid-section {
  padding-top: 1.5rem;
  padding-bottom: 3.2rem;
}

.leife-services-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
}

/* Individual service card */

.leife-service-card {
  background: #ffffff;
  border-radius: 24px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.06);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  height: 100%;
}

.leife-service-image-wrap img {
  width: 100%;
  height: 210px;
  object-fit: cover;
  display: block;
}

.leife-service-content {
  padding: 1.7rem 1.8rem 1.9rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  height: 100%;
}

.leife-service-eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--leife-soft-ink);
}

.leife-service-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.5rem;
  margin-bottom: 0.2rem;
}

.leife-service-intro {
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--leife-soft-ink);
}

.leife-service-list {
  margin: 0.2rem 0 0.6rem 1.1rem;
  padding: 0;
}

.leife-service-list li {
  font-size: 0.9rem;
  line-height: 1.6;
  color: var(--leife-soft-ink);
  margin-bottom: 0.25rem;
}

.leife-service-note {
  font-size: 0.9rem;
  line-height: 1.6;
  color: var(--leife-soft-ink);
  margin-top: 0.1rem;
  margin-bottom: 1rem;
}

/* Buttons (if not already defined) */

.leife-button-secondary,
.leife-button-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1.4rem;
  border-radius: 999px;
  font-size: 0.9rem;
  border: 1px solid transparent;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease,
    box-shadow 0.2s ease, transform 0.15s ease;
}

.leife-button-primary {
  background: var(--leife-ink);
  color: #ffffff;
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.18);
}

.leife-button-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.22);
}

.leife-button-secondary {
  background: #ffffff;
  color: var(--leife-ink);
  border-color: rgba(15, 15, 20, 0.12);
}

.leife-button-secondary:hover {
  background: #f8f6f2;
  transform: translateY(-1px);
}

/* Philosophy strip */

.leife-services-philosophy {
  padding-top: 0.5rem;
  padding-bottom: 2.8rem;
}

.leife-services-philosophy-card {
  background: #fbf7f0;
  border-radius: 28px;
  padding: 2.3rem 2.4rem;
  box-shadow: 0 20px 55px rgba(0, 0, 0, 0.04);
  text-align: left;
}

.leife-services-philosophy-card h2 {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.8rem;
  margin-bottom: 0.6rem;
}

.leife-services-philosophy-card p {
  font-size: 0.96rem;
  line-height: 1.8;
  color: var(--leife-soft-ink);
}

/* Steps section */

.leife-services-how-section {
  padding-top: 1.2rem;
  padding-bottom: 3.2rem;
}

.leife-services-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.6rem;
}

.leife-step-card {
  background: #ffffff;
  border-radius: 22px;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.05);
  padding: 1.7rem 1.6rem;
}

.leife-step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 999px;
  border: 1px solid rgba(0, 0, 0, 0.1);
  font-size: 0.78rem;
  margin-bottom: 0.7rem;
}

.leife-step-card h3 {
  font-size: 1.05rem;
  margin-bottom: 0.4rem;
}

.leife-step-card p {
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--leife-soft-ink);
}

/* CTA section */

.leife-services-cta-section {
  padding-top: 0.5rem;
  padding-bottom: 3rem;
}

.leife-services-cta-card {
  background: #ffffff;
  border-radius: 26px;
  box-shadow: 0 26px 70px rgba(0, 0, 0, 0.07);
  padding: 2.3rem 2.4rem;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 1.8rem;
  align-items: center;
}

.leife-services-cta-text h2 {
  font-family: "Cormorant Garamond", serif;
  font-size: 1.8rem;
  margin-bottom: 0.6rem;
}

.leife-services-cta-text p {
  font-size: 0.95rem;
  line-height: 1.8;
  color: var(--leife-soft-ink);
}

.leife-services-cta-actions {
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
  align-items: flex-start;
}

.leife-services-cta-note {
  font-size: 0.9rem;
  color: var(--leife-soft-ink);
}

/* Responsive adjustments */

@media (max-width: 1000px) {
  .leife-services-hero-card {
    grid-template-columns: 1fr;
  }

  .leife-services-cta-card {
    grid-template-columns: 1fr;
  }

  .leife-services-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .leife-services-steps-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .leife-services-hero-card {
    padding: 2rem 1.6rem;
  }

  .leife-services-cta-card {
    padding: 2rem 1.6rem;
  }

  .leife-service-content {
    padding-inline: 1.4rem;
  }

  .leife-services-grid {
    grid-template-columns: 1fr;
  }

  .leife-services-steps-grid {
    grid-template-columns: 1fr;
  }
}