/* ============================================================
   Larkin Mortuary — "Quiet Heritage" shared design system
   Scoped to .lm-page / .lm-plan / .lm-home wrappers.
   Linked via navigator/_quiet_heritage_styles.html
   (extracted from the former inline <style> for caching / dedupe)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Open+Sans:wght@300;400;500;600&display=swap');

:is(.lm-page, .lm-plan, .lm-home) {
  --primary:       #2a3856;
  --primary-deep:  #1d2b3e;
  --accent:        #566c98;
  --accent-deep:   #43547c;
  --gold:          #C9A84C;
  --gold-soft:     #7e5c0c;
  --gold-bright:   #EDD9A3;
  --ink:           #2a3856;
  --text-dark:     #2f3743;
  --text-light:    #5a6575;
  --white:         #ffffff;
  --ivory:         #f7f4ef;
  --ivory-deep:    #efe9e0;
  --radius:        4px;
  --radius-lg:     8px;
  --shadow:        0 10px 30px rgba(29,43,62,.08);
  --shadow-hover:  0 22px 48px rgba(29,43,62,.16);
  --transition:    all 0.45s cubic-bezier(.22,.61,.36,1);
  --serif:         'Cormorant Garamond', Georgia, 'Times New Roman', serif;
  --sans:          'Open Sans', 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;

  font-family: var(--sans);
  color: var(--text-dark);
  line-height: 1.7;
  background: var(--ivory);
}

.lm-plan p { font-family: var(--sans); }

/* ---- Scroll-reveal system --------------------------------- */
:is(.lm-page, .lm-plan, .lm-home) .reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.9s cubic-bezier(.22,.61,.36,1),
              transform 0.9s cubic-bezier(.22,.61,.36,1);
  will-change: opacity, transform;
}
:is(.lm-page, .lm-plan, .lm-home) .reveal.is-visible { opacity: 1; transform: none; }
:is(.lm-page, .lm-plan, .lm-home) .reveal[data-delay="1"] { transition-delay: .12s; }
:is(.lm-page, .lm-plan, .lm-home) .reveal[data-delay="2"] { transition-delay: .24s; }
:is(.lm-page, .lm-plan, .lm-home) .reveal[data-delay="3"] { transition-delay: .36s; }
:is(.lm-page, .lm-plan, .lm-home) .reveal[data-delay="4"] { transition-delay: .48s; }

/* ---- Gold eyebrow label ----------------------------------- */
.lm-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  font-family: var(--sans);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold-soft);
  margin-bottom: 1rem;
}
.lm-eyebrow::before, .lm-eyebrow::after {
  content: '';
  width: 34px;
  height: 1px;
  background: var(--gold);
  opacity: .8;
}
.lm-eyebrow--light { color: var(--gold-bright); }
.lm-eyebrow--light::before, .lm-eyebrow--light::after { opacity: 1; }
.lm-eyebrow--start::before { display: none; }

/* ---- Section titles --------------------------------------- */
:is(.lm-page, .lm-plan, .lm-home) .lm-section-title {
  font-family: var(--serif);
  font-size: clamp(2rem, 4vw, 2.9rem);
  font-weight: 600;
  line-height: 1.12;
  color: var(--primary);
  text-align: center;
  margin-bottom: .6rem;
  letter-spacing: .005em;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-section-subtitle {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.2rem;
  color: var(--text-light);
  text-align: center;
  max-width: 680px;
  margin: 0 auto 3.5rem;
  line-height: 1.55;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-section { padding: 80px 0; }
:is(.lm-page, .lm-plan, .lm-home) .lm-section-alt { background: var(--white); }

/* ---- Gold horizontal divider ------------------------------ */
.lm-gold-rule {
  width: 64px;
  height: 1px;
  margin: .8rem auto 0;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  border: 0;
  opacity: .85;
}
.lm-gold-rule--left { margin-left: 0; }

/* ============================================================
   HERO
   ============================================================ */
.lm-plan-hero {
  position: relative;
  overflow: hidden;
  color: var(--white);
  text-align: center;
  min-height: clamp(460px, 70vh, 660px);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-deep);
}
.lm-plan-hero__bg {
  position: absolute;
  inset: -4%;
  background: url('https://storage.googleapis.com/www.larkinmortuary.com/static/images/cemetery_50_50.jpg') center/cover no-repeat;
  transform: scale(1.06);
  animation: lmpKenBurns 28s ease-in-out infinite alternate;
  z-index: 0;
}
.lm-plan-hero__veil {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(120% 90% at 50% 40%, rgba(29,43,62,.30) 0%, rgba(29,43,62,.62) 60%, rgba(29,43,62,.84) 100%),
    linear-gradient(180deg, rgba(29,43,62,.28) 0%, rgba(29,43,62,.48) 100%);
}
.lm-plan-hero__content {
  position: relative;
  z-index: 2;
  max-width: 860px;
  padding: clamp(3rem, 8vh, 6rem) 1.5rem;
}
.lm-plan-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  font-family: var(--sans);
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--gold-bright);
  margin-bottom: 1.2rem;
}
.lm-plan-hero__eyebrow::before, .lm-plan-hero__eyebrow::after {
  content: ''; width: 34px; height: 1px;
  background: var(--gold); opacity: .9;
}
.lm-plan-hero__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(2.6rem, 6vw, 4.4rem);
  line-height: 1.08;
  margin: 0 0 1.1rem;
  color: #fff;
  text-shadow: 0 2px 24px rgba(0,0,0,.38);
  letter-spacing: .005em;
}
.lm-plan-hero__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold-bright);
  text-shadow: 0 2px 6px rgba(10,18,32,.6);
}
.lm-plan-hero__subtitle {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(1.1rem, 2.4vw, 1.5rem);
  line-height: 1.5;
  color: rgba(255,255,255,.93);
  margin: 0 auto 2rem;
  max-width: 620px;
}
.lm-plan-hero__divider {
  width: 64px;
  height: 1px;
  margin: 0 auto 2rem;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  border: 0; opacity: .9;
}
.lm-plan-hero__buttons {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.lm-plan-scroll-cue {
  position: absolute;
  left: 50%; bottom: 1.4rem;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: rgba(255,255,255,.7);
}
.lm-plan-scroll-cue .cue-label { font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; margin-bottom: .25rem; }
.lm-plan-scroll-cue .cue-arrow { animation: lmpBounce 2.4s ease-in-out infinite; }

@keyframes lmpKenBurns {
  0%   { transform: scale(1.04) translate3d(0, 0, 0); }
  100% { transform: scale(1.12) translate3d(-1.5%, -2%, 0); }
}
@keyframes lmpBounce {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(7px); }
}

/* ============================================================
   BUTTONS
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .lm-btn {
  background: var(--gold);
  color: #14213a;
  padding: 14px 30px;
  border-radius: var(--radius);
  text-decoration: none;
  font-family: var(--sans);
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  transition: var(--transition);
  border: 1.5px solid var(--gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  line-height: 1;
  box-shadow: 0 8px 22px rgba(201,168,76,.22);
  cursor: pointer;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-btn .material-icons {
  font-size: 1.15rem;
  display: inline-block;
  vertical-align: middle;
  margin-top: -1px;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-btn:hover {
  background: #d8b86f;
  border-color: #d8b86f;
  color: #14213a;
  transform: translateY(-3px);
  box-shadow: 0 14px 32px rgba(201,168,76,.34);
  text-decoration: none;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-btn:focus-visible {
  outline: 3px solid #fff;
  outline-offset: 3px;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-btn-outline {
  background: transparent;
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.75);
  box-shadow: none;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-btn-outline:hover {
  background: rgba(255,255,255,.12);
  border-color: #fff;
  color: #fff;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-btn-ink {
  background: var(--primary);
  border-color: var(--primary);
  color: #fff;
  box-shadow: 0 8px 22px rgba(42,56,86,.2);
}
:is(.lm-page, .lm-plan, .lm-home) .lm-btn-ink:hover {
  background: var(--primary-deep);
  border-color: var(--primary-deep);
  color: #fff;
}

/* ============================================================
   INTRO THREE-COLUMN SECTION
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .intro-section { background: var(--ivory); padding: 80px 0; }

/* Why Plan Ahead card */
:is(.lm-page, .lm-plan, .lm-home) .intro-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 2.4rem 2rem;
  box-shadow: var(--shadow);
  border: 1px solid var(--ivory-deep);
  border-top: 3px solid var(--gold);
  height: 100%;
  transition: var(--transition);
}
:is(.lm-page, .lm-plan, .lm-home) .intro-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}
:is(.lm-page, .lm-plan, .lm-home) .intro-card h2 {
  font-family: var(--serif);
  font-size: 1.85rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 1.25rem;
  line-height: 1.2;
}
:is(.lm-page, .lm-plan, .lm-home) .intro-card p {
  color: var(--text-dark);
  line-height: 1.8;
  font-size: 1rem;
  margin-bottom: 1.1rem;
}
:is(.lm-page, .lm-plan, .lm-home) .intro-card a {
  color: var(--accent-deep);
  text-decoration: underline;
  text-underline-offset: 2px;
  font-weight: 600;
  transition: var(--transition);
}
:is(.lm-page, .lm-plan, .lm-home) .intro-card a:hover { color: var(--primary); }

/* Form card */
:is(.lm-page, .lm-plan, .lm-home) .form-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 2.4rem 2rem;
  box-shadow: var(--shadow);
  border: 1px solid var(--ivory-deep);
  border-top: 3px solid var(--primary);
  height: 100%;
  transition: var(--transition);
}
:is(.lm-page, .lm-plan, .lm-home) .form-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}
:is(.lm-page, .lm-plan, .lm-home) .form-card h2 {
  font-family: var(--serif);
  font-size: 1.85rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: .4rem;
  line-height: 1.2;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .form-instructions {
  font-size: .9rem;
  color: var(--text-light);
  margin-bottom: 1.4rem;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .form-control {
  border: 1.5px solid var(--ivory-deep);
  border-radius: var(--radius);
  padding: 11px 14px;
  font-size: .97rem;
  font-family: var(--sans);
  background: var(--ivory);
  color: var(--text-dark);
  transition: border-color .3s, box-shadow .3s;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .form-control:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.18);
  background: var(--white);
  outline: none;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .form-control::placeholder { color: #9aa3af; }
:is(.lm-page, .lm-plan, .lm-home) .form-card .form-check-input {
  width: 1.15rem;
  height: 1.15rem;
  margin-top: .18rem;
  border-color: #c8d0da;
  cursor: pointer;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .form-check-input:checked {
  background-color: var(--primary);
  border-color: var(--primary);
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .form-check-label {
  font-size: .93rem;
  color: var(--text-dark);
  font-weight: 500;
  margin-left: .4rem;
  cursor: pointer;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .interests-label {
  font-family: var(--sans);
  font-weight: 600;
  font-size: .88rem;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: .85rem;
  display: block;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .lm-submit-btn {
  background: var(--gold);
  color: #14213a;
  border: none;
  padding: 14px 20px;
  border-radius: var(--radius);
  font-family: var(--sans);
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  transition: var(--transition);
  cursor: pointer;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: 0 8px 22px rgba(201,168,76,.22);
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .lm-submit-btn .material-icons { font-size: 1.1rem; }
:is(.lm-page, .lm-plan, .lm-home) .form-card .lm-submit-btn:hover {
  background: #d8b86f;
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(201,168,76,.32);
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .lm-submit-btn:focus-visible {
  outline: 3px solid var(--primary);
  outline-offset: 3px;
}
:is(.lm-page, .lm-plan, .lm-home) .form-card .consent-note {
  font-size: .78rem;
  color: var(--text-light);
  margin-top: .85rem;
  text-align: center;
}

/* Planner card */
:is(.lm-page, .lm-plan, .lm-home) .planner-card {
  background: linear-gradient(155deg, var(--primary-deep) 0%, var(--primary) 55%, #324468 100%);
  border-radius: var(--radius-lg);
  padding: 2.4rem 2rem;
  box-shadow: 0 18px 50px rgba(29,43,62,.22);
  border: 1px solid rgba(201,168,76,.22);
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  transition: var(--transition);
}
:is(.lm-page, .lm-plan, .lm-home) .planner-card::before {
  content: '';
  position: absolute;
  top: -40%; right: -10%;
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(201,168,76,.15), transparent 70%);
  pointer-events: none;
}
:is(.lm-page, .lm-plan, .lm-home) .planner-card:hover {
  box-shadow: 0 28px 60px rgba(29,43,62,.30);
  transform: translateY(-4px);
}
:is(.lm-page, .lm-plan, .lm-home) .planner-card h2 {
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 500;
  color: #fff;
  margin-bottom: 1.4rem;
  line-height: 1.3;
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .planner-photo {
  width: 170px;
  height: 170px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid rgba(201,168,76,.65);
  box-shadow: 0 10px 30px rgba(0,0,0,.28);
  margin-bottom: 1.4rem;
  display: block;
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .planner-desc {
  font-size: 1rem;
  line-height: 1.75;
  color: rgba(255,255,255,.88);
  margin-bottom: 1.6rem;
  font-family: var(--sans);
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .planner-meeting {
  font-family: var(--serif);
  font-style: italic;
  font-size: 1.05rem;
  color: rgba(255,255,255,.72);
  line-height: 1.6;
  margin-bottom: 1.8rem;
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .planner-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  width: 100%;
  padding: 14px 20px;
  background: var(--gold);
  color: #14213a;
  border-radius: var(--radius);
  text-decoration: none;
  font-family: var(--sans);
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .05em;
  text-transform: uppercase;
  box-shadow: 0 8px 22px rgba(201,168,76,.28);
  transition: var(--transition);
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .planner-cta .material-icons { font-size: 1.15rem; }
:is(.lm-page, .lm-plan, .lm-home) .planner-cta:hover {
  background: #d8b86f;
  color: #14213a;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 14px 32px rgba(201,168,76,.36);
}

/* ============================================================
   BENEFITS SECTION
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .benefits-section { background: var(--white); padding: 80px 0; }
:is(.lm-page, .lm-plan, .lm-home) .benefit-card {
  background: var(--ivory);
  border-radius: var(--radius-lg);
  padding: 2.2rem 1.8rem;
  box-shadow: var(--shadow);
  border: 1px solid var(--ivory-deep);
  border-top: 3px solid var(--gold);
  text-align: center;
  transition: var(--transition);
  height: 100%;
}
:is(.lm-page, .lm-plan, .lm-home) .benefit-card:hover {
  transform: translateY(-8px);
  box-shadow: var(--shadow-hover);
}
:is(.lm-page, .lm-plan, .lm-home) .benefit-icon {
  font-size: 2.7rem;
  color: var(--accent);
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 3.5rem;
  transition: var(--transition);
}
:is(.lm-page, .lm-plan, .lm-home) .benefit-card:hover .benefit-icon { color: var(--primary); transform: translateY(-3px); }
:is(.lm-page, .lm-plan, .lm-home) .benefit-title {
  font-family: var(--serif);
  font-size: 1.45rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: .8rem;
  line-height: 1.2;
}
:is(.lm-page, .lm-plan, .lm-home) .benefit-desc {
  color: var(--text-light);
  line-height: 1.75;
  font-size: .97rem;
}

/* ============================================================
   STEPS SECTION
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .steps-section { background: var(--ivory); padding: 80px 0; }
:is(.lm-page, .lm-plan, .lm-home) .step-card {
  text-align: center;
  padding: 1.5rem 1rem;
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .step-num {
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: var(--gold);
  color: #14213a;
  font-family: var(--serif);
  font-size: 1.35rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.1rem;
  box-shadow: 0 6px 18px rgba(201,168,76,.28);
}
:is(.lm-page, .lm-plan, .lm-home) .step-title {
  font-family: var(--serif);
  font-size: 1.3rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: .6rem;
  line-height: 1.2;
}
:is(.lm-page, .lm-plan, .lm-home) .step-desc {
  color: var(--text-light);
  font-size: .95rem;
  line-height: 1.7;
}

/* ============================================================
   SERVICES GRID
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .services-section { background: var(--white); padding: 80px 0; }
:is(.lm-page, .lm-plan, .lm-home) .service-type-card {
  background: var(--ivory);
  border: 1px solid var(--ivory-deep);
  border-radius: var(--radius-lg);
  padding: 1.8rem 1.6rem;
  box-shadow: var(--shadow);
  transition: var(--transition);
  height: 100%;
}
:is(.lm-page, .lm-plan, .lm-home) .service-type-card:hover {
  border-color: var(--gold);
  box-shadow: var(--shadow-hover);
  transform: translateY(-5px);
}
:is(.lm-page, .lm-plan, .lm-home) .service-type-card h3 {
  font-family: var(--serif);
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: .75rem;
  line-height: 1.2;
}
:is(.lm-page, .lm-plan, .lm-home) .service-type-card p {
  color: var(--text-light);
  font-size: .95rem;
  line-height: 1.7;
  margin: 0;
}

/* ============================================================
   LOCATIONS + WHY LARKIN
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .details-section { background: var(--ivory); padding: 80px 0; }
:is(.lm-page, .lm-plan, .lm-home) .detail-block {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 2.2rem 2rem;
  box-shadow: var(--shadow);
  border: 1px solid var(--ivory-deep);
  height: 100%;
}
:is(.lm-page, .lm-plan, .lm-home) .detail-block h3 {
  font-family: var(--serif);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: 1rem;
  line-height: 1.2;
}
:is(.lm-page, .lm-plan, .lm-home) .detail-block h4 {
  font-family: var(--sans);
  font-size: .88rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent-deep);
  margin: 1.4rem 0 .75rem;
}
:is(.lm-page, .lm-plan, .lm-home) .detail-block p {
  color: var(--text-light);
  line-height: 1.75;
  font-size: .97rem;
  margin-bottom: .85rem;
}
:is(.lm-page, .lm-plan, .lm-home) .detail-block ul {
  list-style: none;
  padding: 0;
  margin: 0 0 .85rem;
}
:is(.lm-page, .lm-plan, .lm-home) .detail-block ul li {
  padding: .3rem 0;
  color: var(--text-light);
  font-size: .93rem;
  border-bottom: 1px solid var(--ivory-deep);
  display: flex;
  align-items: center;
  gap: .5rem;
}
:is(.lm-page, .lm-plan, .lm-home) .detail-block ul li:last-child { border-bottom: none; }
:is(.lm-page, .lm-plan, .lm-home) .detail-block ul li::before {
  content: '';
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
}
:is(.lm-page, .lm-plan, .lm-home) .detail-block strong { color: var(--text-dark); font-weight: 600; }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .faq-section { background: var(--white); padding: 80px 0; }
:is(.lm-page, .lm-plan, .lm-home) .faq-list { margin: 2rem 0; }
:is(.lm-page, .lm-plan, .lm-home) .faq-item { border-bottom: 1px solid var(--ivory-deep); }
:is(.lm-page, .lm-plan, .lm-home) .faq-item:first-child { border-top: 1px solid var(--ivory-deep); }
:is(.lm-page, .lm-plan, .lm-home) .faq-question {
  display: block;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  font-family: var(--serif);
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--primary);
  padding: 1.25rem 2.5rem 1.25rem 0;
  cursor: pointer;
  position: relative;
  transition: color .3s;
}
:is(.lm-page, .lm-plan, .lm-home) .faq-question:hover { color: var(--gold-soft); }
:is(.lm-page, .lm-plan, .lm-home) .faq-question:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: 3px;
}
:is(.lm-page, .lm-plan, .lm-home) .faq-question::after {
  content: '+';
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  font-size: 1.5rem;
  font-weight: 300;
  color: var(--gold);
  font-family: var(--sans);
}
:is(.lm-page, .lm-plan, .lm-home) .faq-item.active .faq-question::after { content: '−'; }
:is(.lm-page, .lm-plan, .lm-home) .faq-answer {
  display: none;
  padding: 0 0 1.25rem;
  color: var(--text-light);
  line-height: 1.75;
  font-size: .97rem;
}
:is(.lm-page, .lm-plan, .lm-home) .faq-item.active .faq-answer { display: block; }

/* ============================================================
   RELATED SERVICES
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .related-section { background: var(--ivory); padding: 60px 0; }
:is(.lm-page, .lm-plan, .lm-home) .related-chips {
  display: flex;
  flex-wrap: wrap;
  gap: .85rem;
  justify-content: center;
  margin-top: 2rem;
}
:is(.lm-page, .lm-plan, .lm-home) .related-chip {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .75rem 1.3rem;
  background: var(--white);
  color: var(--primary);
  border-radius: var(--radius);
  text-decoration: none;
  font-family: var(--sans);
  font-weight: 600;
  font-size: .88rem;
  letter-spacing: .03em;
  transition: var(--transition);
  border: 1px solid var(--ivory-deep);
  box-shadow: 0 4px 12px rgba(42,57,86,.06);
}
:is(.lm-page, .lm-plan, .lm-home) .related-chip .material-icons { font-size: 1.1rem; }
:is(.lm-page, .lm-plan, .lm-home) .related-chip:hover {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
  box-shadow: var(--shadow-hover);
  text-decoration: none;
  transform: translateY(-3px);
}

/* ============================================================
   BOTTOM CTA SECTION
   ============================================================ */
:is(.lm-page, .lm-plan, .lm-home) .bottom-cta {
  background: var(--white);
  padding: 80px 0;
}
:is(.lm-page, .lm-plan, .lm-home) .bottom-cta__inner {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--primary-deep) 0%, var(--primary) 60%, #324468 100%);
  border-radius: var(--radius-lg);
  padding: clamp(2.2rem, 5vw, 3.5rem);
  color: var(--white);
  box-shadow: 0 22px 50px rgba(29,43,62,.22);
  border: 1px solid rgba(201,168,76,.22);
  text-align: center;
}
:is(.lm-page, .lm-plan, .lm-home) .bottom-cta__inner::before {
  content: '';
  position: absolute;
  top: -40%; right: -8%;
  width: 340px; height: 340px;
  background: radial-gradient(circle, rgba(201,168,76,.18), transparent 70%);
  pointer-events: none;
}
:is(.lm-page, .lm-plan, .lm-home) .bottom-cta__title {
  font-family: var(--serif);
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 500;
  font-style: italic;
  color: #fff;
  margin-bottom: .75rem;
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .bottom-cta__sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,.85);
  margin-bottom: 2rem;
  font-family: var(--sans);
  position: relative;
}
:is(.lm-page, .lm-plan, .lm-home) .bottom-cta__buttons {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
  position: relative;
}

/* ============================================================
   LOADING POPUP
   ============================================================ */
.lm-plan-popup {
  position: fixed;
  inset: 0;
  background: rgba(29,43,62,.6);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  opacity: 0;
  visibility: hidden;
  transition: opacity .35s ease, visibility .35s ease;
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}
.lm-plan-popup.show { opacity: 1; visibility: visible; }
.lm-plan-popup__box {
  background: var(--white);
  padding: 2.5rem 2rem;
  border-radius: var(--radius-lg);
  text-align: center;
  max-width: 380px;
  width: 90%;
  box-shadow: var(--shadow-hover);
  border-top: 3px solid var(--gold);
}
.lm-plan-popup__box h3 {
  font-family: var(--serif);
  color: var(--primary);
  font-size: 1.4rem;
  margin-top: 1rem;
}
.lm-plan-spinner {
  width: 44px; height: 44px;
  border: 3px solid var(--ivory-deep);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: lmpSpin .8s linear infinite;
  margin: 0 auto;
}
@keyframes lmpSpin { to { transform: rotate(360deg); } }


/* ---- Article / resource layout ----------------------------- */
:is(.lm-page, .lm-plan, .lm-home) .lm-article-wrap {
  max-width: 820px;
  margin: 0 auto;
  padding: 0 1rem;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-prose {
  font-size: 1.05rem;
  line-height: 1.85;
  color: var(--text-dark);
}
:is(.lm-page, .lm-plan, .lm-home) .lm-prose h2 {
  font-family: var(--serif);
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--primary);
  margin: 2.5rem 0 1rem;
  line-height: 1.2;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-prose h3 {
  font-family: var(--serif);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--primary);
  margin: 2rem 0 .75rem;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-prose p { margin-bottom: 1.1rem; }
:is(.lm-page, .lm-plan, .lm-home) .lm-prose ul,
:is(.lm-page, .lm-plan, .lm-home) .lm-prose ol {
  margin-bottom: 1.25rem;
  padding-left: 1.4rem;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-prose a {
  color: var(--accent-deep);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 2px;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-prose a:hover { color: var(--primary); }

/* ---- Inline links in resource body copy -------------------- */
/* Bare links in .content-text / .content-list otherwise inherit
   Bootstrap's default link blue (#0d6efd), which only clears 4.5:1
   on pure white and fails (4.1:1) on the ivory page ground. Pin them
   to the brand link color so they pass WCAG AA on any surface. */
:is(.lm-page, .lm-plan, .lm-home) .content-text a,
:is(.lm-page, .lm-plan, .lm-home) .content-list a {
  color: var(--accent-deep);
  text-underline-offset: 2px;
}
:is(.lm-page, .lm-plan, .lm-home) .content-text a:hover,
:is(.lm-page, .lm-plan, .lm-home) .content-list a:hover { color: var(--primary); }

/* ---- Location hub cards ------------------------------------ */
:is(.lm-page, .lm-plan, .lm-home) .lm-loc-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 1.8rem;
  box-shadow: var(--shadow);
  border: 1px solid var(--ivory-deep);
  border-top: 3px solid var(--gold);
  height: 100%;
  transition: var(--transition);
}
:is(.lm-page, .lm-plan, .lm-home) .lm-loc-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
}
:is(.lm-page, .lm-plan, .lm-home) .lm-loc-card h3 {
  font-family: var(--serif);
  font-size: 1.45rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: .5rem;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-loc-card p {
  color: var(--text-light);
  font-size: .95rem;
  margin-bottom: .75rem;
}

/* ---- Contact / generic form card ------------------------- */
:is(.lm-page, .lm-plan, .lm-home) .lm-form-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 2.4rem 2rem;
  box-shadow: var(--shadow);
  border: 1px solid var(--ivory-deep);
  border-top: 3px solid var(--gold);
}
:is(.lm-page, .lm-plan, .lm-home) .lm-form-card .form-label {
  font-weight: 600;
  color: var(--text-dark);
  font-size: .95rem;
  margin-bottom: .4rem;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-form-card .form-control {
  border: 1.5px solid var(--ivory-deep);
  border-radius: var(--radius);
  padding: 11px 14px;
  font-size: .97rem;
  font-family: var(--sans);
  background: var(--ivory);
  color: var(--text-dark);
  transition: border-color .3s, box-shadow .3s;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-form-card .form-control:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,168,76,.18);
  background: var(--white);
  outline: none;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-form-card .form-control.error {
  border-color: #c0392b;
  box-shadow: 0 0 0 3px rgba(192,57,43,.15);
}
:is(.lm-page, .lm-plan, .lm-home) .lm-alert {
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  margin-bottom: 1.25rem;
  font-size: .95rem;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-alert-danger {
  background: #fdf0ef;
  color: #7a2018;
  border: 1px solid #e8c4c0;
}

/* ---- Event cards ----------------------------------------- */
:is(.lm-page, .lm-plan, .lm-home) .lm-event-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid var(--ivory-deep);
  transition: var(--transition);
  height: 100%;
  display: flex;
  flex-direction: column;
}
:is(.lm-page, .lm-plan, .lm-home) .lm-event-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-hover);
}
:is(.lm-page, .lm-plan, .lm-home) .lm-event-card__body { padding: 1.5rem; flex: 1; }
:is(.lm-page, .lm-plan, .lm-home) .lm-event-card__title {
  font-family: var(--serif);
  font-size: 1.35rem;
  font-weight: 600;
  color: var(--primary);
  margin-bottom: .5rem;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 991.98px) {
  :is(.lm-page, .lm-plan, .lm-home) .lm-section,
  :is(.lm-page, .lm-plan, .lm-home) .intro-section,
  :is(.lm-page, .lm-plan, .lm-home) .benefits-section,
  :is(.lm-page, .lm-plan, .lm-home) .steps-section,
  :is(.lm-page, .lm-plan, .lm-home) .services-section,
  :is(.lm-page, .lm-plan, .lm-home) .details-section,
  :is(.lm-page, .lm-plan, .lm-home) .faq-section,
  :is(.lm-page, .lm-plan, .lm-home) .related-section,
  :is(.lm-page, .lm-plan, .lm-home) .bottom-cta { padding: 60px 0; }
}
@media (max-width: 767.98px) {
  .lm-plan-hero__title { font-size: 2.4rem; }
  .lm-plan-hero__buttons { flex-direction: column; align-items: stretch; }
  :is(.lm-page, .lm-plan, .lm-home) .lm-btn { width: 100%; max-width: 320px; margin-inline: auto; }
  :is(.lm-page, .lm-plan, .lm-home) .bottom-cta__buttons { flex-direction: column; align-items: center; }
  :is(.lm-page, .lm-plan, .lm-home) .bottom-cta__buttons .lm-btn { width: 100%; max-width: 320px; }
}

/* ============================================================
   REDUCED MOTION (WCAG 2.3.3 / 2.2.2)
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  :is(.lm-page, .lm-plan, .lm-home) .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .lm-plan-hero__bg { animation: none !important; transform: scale(1.04); }
  .lm-plan-scroll-cue .cue-arrow { animation: none !important; }
  .lm-plan-spinner { animation: none !important; }
  :is(.lm-page, .lm-plan, .lm-home) .intro-card,
  :is(.lm-page, .lm-plan, .lm-home) .form-card,
  :is(.lm-page, .lm-plan, .lm-home) .planner-card,
  :is(.lm-page, .lm-plan, .lm-home) .benefit-card,
  :is(.lm-page, .lm-plan, .lm-home) .service-type-card,
  :is(.lm-page, .lm-plan, .lm-home) .related-chip,
  :is(.lm-page, .lm-plan, .lm-home) .lm-btn { transition: none !important; }
}
