/* Marucha Clean - shared site styles */

html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', ui-sans-serif, system-ui, sans-serif;
  background: #F7F4EF;
  color: #1C1C1A;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ============================================================
   i18n VISIBILITY — hide the inactive language on the entire site
   ============================================================ */
/* Default (no data-lang set, or data-lang="en"): hide all ES spans */
body:not([data-lang="es"]) [data-i18n="es"] { display: none; }
/* When body is in Spanish mode, hide all EN spans */
body[data-lang="es"] [data-i18n="en"] { display: none; }
a { text-decoration: none; }
.font-display { font-family: 'Playfair Display', Georgia, serif; }

/* Buttons */
.btn-primary {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .75rem 1.5rem; border-radius: 2px;
  font-size: .875rem; font-weight: 600; letter-spacing: .01em;
  background: #2D6A4F; color: #F7F4EF; border: 1.5px solid #2D6A4F;
  transition: background .18s cubic-bezier(.2,.7,.2,1),
              border-color .18s cubic-bezier(.2,.7,.2,1),
              transform .18s cubic-bezier(.2,.7,.2,1),
              box-shadow .18s cubic-bezier(.2,.7,.2,1);
  white-space: nowrap; cursor: pointer;
}
.btn-primary:hover {
  background: #1B4332; border-color: #1B4332;
  transform: scale(1.015);
  box-shadow: 0 6px 22px rgba(201,168,76,.32), 0 0 0 1px rgba(201,168,76,.2);
}
.btn-primary:active {
  transform: scale(1);
  box-shadow: none;
}
.btn-ghost {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .75rem 1.5rem; border-radius: 2px;
  font-size: .875rem; font-weight: 600; letter-spacing: .01em;
  background: transparent; color: #1C1C1A; border: 1.5px solid #DDD9D1;
  transition: background .18s cubic-bezier(.2,.7,.2,1),
              border-color .18s cubic-bezier(.2,.7,.2,1),
              color .18s cubic-bezier(.2,.7,.2,1),
              transform .18s cubic-bezier(.2,.7,.2,1);
  white-space: nowrap; cursor: pointer;
}
.btn-ghost:hover {
  border-color: #2D6A4F; color: #2D6A4F;
  background: rgba(45,106,79,.05);
  transform: translateY(-1px);
}
.btn-ghost:active {
  transform: scale(.99);
}
.btn-ghost-light {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .75rem 1.5rem; border-radius: 2px;
  font-size: .875rem; font-weight: 600; letter-spacing: .01em;
  background: transparent; color: rgba(247,244,239,.85);
  border: 1.5px solid rgba(247,244,239,.25);
  transition: background .18s cubic-bezier(.2,.7,.2,1),
              border-color .18s cubic-bezier(.2,.7,.2,1),
              color .18s cubic-bezier(.2,.7,.2,1),
              transform .18s cubic-bezier(.2,.7,.2,1);
  white-space: nowrap;
}
.btn-ghost-light:hover {
  border-color: rgba(247,244,239,.6); color: #F7F4EF;
  background: rgba(247,244,239,.08); transform: translateY(-1px);
}

/* Section labels */
.section-label {
  font-size: .7rem; font-weight: 700; letter-spacing: .2em;
  text-transform: uppercase; color: #2D6A4F;
}
.rule-label { display: flex; align-items: center; gap: .75rem; margin-bottom: 1.25rem; }
.rule-label::before {
  content: ''; display: block; width: 2rem; height: 1.5px;
  background: #2D6A4F; flex-shrink: 0;
}

/* Container */
.container-mc {
  width: 100%; margin: 0 auto; padding: 0 1.25rem; max-width: 1280px;
}
@media (min-width: 640px) { .container-mc { padding: 0 1.5rem; } }
@media (min-width: 1024px) { .container-mc { padding: 0 2rem; } }

/* Ticker */
@keyframes ticker-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.ticker-track {
  animation: ticker-scroll 30s linear infinite;
  display: flex; gap: 2rem; white-space: nowrap; width: max-content;
}
.ticker-track:hover { animation-play-state: paused; }

/* Reveal on scroll */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity: 1; transform: none; }

/* Editorial frame — replaces stock photo blocks with typography-led composition.
   Use inside an aspect-ratio:4/3 wrapper (or similar) for image-replacement. */
.editorial-frame {
  position: relative;
  width: 100%;
  height: 100%;
  background:
    radial-gradient(circle at 80% 0%, rgba(201,168,76,.12), transparent 55%),
    linear-gradient(160deg, #0F3023 0%, #0D2B1F 60%, #1B4332 100%);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: clamp(24px, 5%, 48px);
  overflow: hidden;
  color: #F7F4EF;
}
.editorial-frame::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(201,168,76,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(201,168,76,.04) 1px, transparent 1px);
  background-size: 64px 64px;
  pointer-events: none;
  opacity: .5;
}
.editorial-frame-mono {
  position: absolute;
  right: -.08em;
  bottom: -.32em;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(14rem, 28vw, 22rem);
  line-height: 1;
  color: rgba(201,168,76,.10);
  letter-spacing: -.06em;
  pointer-events: none;
  user-select: none;
}
.editorial-frame-num {
  position: relative;
  z-index: 1;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(2.5rem, 5vw, 4rem);
  color: #C9A84C;
  letter-spacing: -.04em;
  line-height: 1;
}
.editorial-frame-rule {
  position: relative;
  z-index: 1;
  width: 48px;
  height: 2px;
  background: #C9A84C;
  margin-top: 18px;
}
.editorial-frame-body {
  position: relative;
  z-index: 1;
}
.editorial-frame-label {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(201,168,76,.85);
  margin-bottom: 12px;
}
.editorial-frame-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  letter-spacing: -.01em;
  line-height: 1.1;
  color: #F7F4EF;
  margin-bottom: 8px;
}
.editorial-frame-sub {
  font-family: 'DM Sans', sans-serif;
  font-style: italic;
  font-size: 14px;
  color: rgba(201,168,76,.9);
  letter-spacing: .005em;
}

/* Tier comparison grid (services.html) */
.compare-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
@media (min-width: 768px) {
  .compare-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }
}
.compare-col {
  position: relative;
  background: rgba(247,244,239,.04);
  border: 1px solid rgba(247,244,239,.08);
  border-radius: 12px;
  padding: 32px 28px 28px 28px;
  display: flex;
  flex-direction: column;
  color: rgba(247,244,239,.78);
  transition: background .35s cubic-bezier(.2,.7,.2,1),
              border-color .35s cubic-bezier(.2,.7,.2,1),
              transform .35s cubic-bezier(.2,.7,.2,1);
}
.compare-col:hover {
  background: rgba(247,244,239,.06);
  border-color: rgba(201,168,76,.35);
  transform: translateY(-3px);
}
.compare-col.is-featured {
  background: linear-gradient(160deg, rgba(201,168,76,.10) 0%, rgba(247,244,239,.04) 100%);
  border-color: rgba(201,168,76,.45);
}
.compare-col.is-featured:hover {
  border-color: rgba(201,168,76,.65);
}
.compare-badge {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  font-family: 'DM Sans', sans-serif;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: #0D2B1F;
  background: #C9A84C;
  padding: 5px 12px;
  border-radius: 999px;
  white-space: nowrap;
}
.compare-num {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(2.25rem, 4vw, 3rem);
  line-height: 1;
  color: #C9A84C;
  letter-spacing: -.04em;
  margin-bottom: 14px;
}
.compare-tier {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: 1.5rem;
  letter-spacing: -.01em;
  color: #F7F4EF;
  margin-bottom: 6px;
}
.compare-tag {
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-size: .95rem;
  color: rgba(201,168,76,.85);
  margin-bottom: 18px;
}
.compare-price {
  font-family: 'DM Sans', sans-serif;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(247,244,239,.55);
  margin-bottom: 4px;
}
.compare-price-num {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: 1.6rem;
  color: #F7F4EF;
  letter-spacing: -.01em;
  margin-bottom: 18px;
}
.compare-best {
  font-family: 'DM Sans', sans-serif;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(201,168,76,.75);
  margin-bottom: 10px;
}
.compare-features {
  list-style: none;
  padding: 0;
  margin: 0 0 22px 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.compare-features li {
  position: relative;
  padding-left: 22px;
  font-size: .9rem;
  line-height: 1.45;
  color: rgba(247,244,239,.85);
}
.compare-features li::before {
  content: '+';
  position: absolute;
  left: 0;
  top: 0;
  color: #C9A84C;
  font-weight: 600;
  font-family: 'Playfair Display', Georgia, serif;
}
.compare-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .7rem 1.2rem;
  border-radius: 2px;
  font-size: .82rem;
  font-weight: 600;
  letter-spacing: .01em;
  background: transparent;
  color: #F7F4EF;
  border: 1.5px solid rgba(247,244,239,.25);
  cursor: pointer;
  transition: all .22s cubic-bezier(.2,.7,.2,1);
  margin-top: auto;
}
.compare-cta:hover {
  border-color: #C9A84C;
  background: rgba(201,168,76,.08);
}
.compare-col.is-featured .compare-cta {
  background: #C9A84C;
  color: #0D2B1F;
  border-color: #C9A84C;
}
.compare-col.is-featured .compare-cta:hover {
  background: #D6B563;
  border-color: #D6B563;
}

/* Shared icon stroke language */
.mc-icon {
  stroke-width: 1.4;
  stroke-linecap: round;
  stroke-linejoin: round;
  vector-effect: non-scaling-stroke;
}

/* Sparkle / brand mark accents */
.brand-sparkle {
  position: relative;
  display: inline-block;
  width: 12px;
  height: 12px;
}
.brand-sparkle::before,
.brand-sparkle::after {
  content: '';
  position: absolute;
  background: #C9A84C;
}
.brand-sparkle::before {
  top: 50%;
  left: 0;
  right: 0;
  height: 1px;
  transform: translateY(-50%);
}
.brand-sparkle::after {
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
}
.brand-sparkle.is-diamond::before,
.brand-sparkle.is-diamond::after {
  transform-origin: center;
}
.brand-sparkle.is-diamond::before {
  transform: translateY(-50%) rotate(45deg);
}
.brand-sparkle.is-diamond::after {
  transform: translateX(-50%) rotate(45deg);
}
.sparkle-rule {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  margin: 24px 0;
  color: rgba(201,168,76,.5);
}
.sparkle-rule::before,
.sparkle-rule::after {
  content: '';
  flex: 1;
  max-width: 60px;
  height: 1px;
  background: rgba(201,168,76,.3);
}

/* ============================================================
   LANG SWITCH PILL (toggle)
   ============================================================ */
.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 1px;
  padding: 2px;
  border-radius: 999px;
  background: rgba(45,106,79,.08);
  border: 1px solid rgba(45,106,79,.18);
}
.lang-switch button {
  appearance: none;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #6B6B68;
  padding: 4px 10px;
  border-radius: 999px;
  transition: background .18s ease, color .18s ease;
}
.lang-switch button.is-active,
body[data-lang="en"] .lang-switch [data-lang-toggle="en"],
body[data-lang="es"] .lang-switch [data-lang-toggle="es"] {
  background: #2D6A4F !important;
  background-color: #2D6A4F !important;
  color: #F7F4EF !important;
}
.lang-switch button:not(.is-active):hover {
  color: #2D6A4F;
}
.lang-switch button:focus-visible {
  outline: 2px solid #C9A84C;
  outline-offset: 2px;
}

/* Legacy bilingual rules (kept as defensive fallback;
   primary rule is at top of file anchored to body[data-lang]) */
[data-i18n="es"] { display: none; }
body[data-lang="es"] [data-i18n="en"] { display: none; }
body[data-lang="es"] [data-i18n="es"] { display: inline; }
[data-i18n-block="es"] { display: none; }
body[data-lang="es"] [data-i18n-block="en"] { display: none; }
body[data-lang="es"] [data-i18n-block="es"] { display: block; }

/* Reveal-on-scroll */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
.reveal.in {
  opacity: 1;
  transform: none;
}

/* Page transitions */
body {
  transition: opacity .28s cubic-bezier(.2,.7,.2,1);
}
body.is-leaving {
  opacity: 0;
}
body.is-loading {
  opacity: 0;
}
body.is-ready {
  opacity: 1;
}

/* Navbar scroll state */
#nav {
  transition: padding .22s cubic-bezier(.2,.7,.2,1),
              background .22s ease,
              border-color .22s ease,
              box-shadow .22s ease;
}
#nav.is-scrolled {
  background: rgba(247,244,239,.97);
  border-bottom: 1px solid #DDD9D1;
  box-shadow: 0 1px 20px rgba(28,28,26,.05);
}
#nav.is-scrolled .nav-inner {
  padding-top: 4px;
  padding-bottom: 4px;
}

/* FAQ accordion */
.faq-item {
  border-bottom: 1px solid #DDD9D1;
}
.faq-q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 0;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: 1.1rem;
  letter-spacing: -.005em;
  color: #1C1C1A;
  transition: color .18s ease;
}
.faq-q:hover {
  color: #2D6A4F;
}
.faq-q::after {
  content: '+';
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #DDD9D1;
  border-radius: 999px;
  color: #2D6A4F;
  font-size: 1.1rem;
  font-weight: 400;
  transition: transform .25s cubic-bezier(.2,.7,.2,1), background .2s ease, border-color .2s ease;
}
.faq-item.open .faq-q::after {
  content: '-';
  background: #2D6A4F;
  border-color: #2D6A4F;
  color: #F7F4EF;
  transform: rotate(180deg);
}
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s cubic-bezier(.2,.7,.2,1);
  font-family: 'DM Sans', sans-serif;
  color: #6B6B68;
  line-height: 1.65;
}
.faq-item.open .faq-a {
  max-height: 600px;
  padding-bottom: 22px;
}

/* Tap pulse (mobile touch affordance) */
.is-tapped {
  opacity: .65;
  transform: scale(.98);
  transition: opacity .18s, transform .18s;
}

/* Focus visibility (a11y) */
.btn-primary:focus-visible,
.btn-ghost:focus-visible,
.btn-ghost-light:focus-visible {
  outline: 3px solid #C9A84C;
  outline-offset: 2px;
}

/* Social row */
.social-row {
  display: flex;
  align-items: center;
  gap: .65rem;
  flex-wrap: wrap;
}
.social-icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(247,244,239,.18);
  background: rgba(247,244,239,.04);
  color: rgba(247,244,239,.85);
  transition: all .2s ease;
}
.social-icon:hover {
  background: rgba(201,168,76,.15);
  border-color: rgba(201,168,76,.45);
  color: #C9A84C;
  transform: translateY(-1px);
}

/* Footer base */
.footer-mc {
  background: #0D2B1F;
  color: rgba(247,244,239,.78);
  padding: 64px 0 32px;
}
.footer-mc a {
  color: rgba(247,244,239,.78);
  transition: color .18s ease;
}
.footer-mc a:hover {
  color: #C9A84C;
}
.footer-mc h4 {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: .85rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(201,168,76,.85);
  margin-bottom: 18px;
}

/* Editorial frame interior text */
.editorial-frame-num {
  position: relative;
  z-index: 1;
  font-family: 'Playfair Display', Georgia, serif;
  font-style: italic;
  font-weight: 500;
  font-size: clamp(2.5rem, 5vw, 4rem);
  color: #C9A84C;
  letter-spacing: -.04em;
  line-height: 1;
}
.editorial-frame-rule {
  position: relative;
  z-index: 1;
  width: 48px;
  height: 2px;
  background: #C9A84C;
  margin-top: 18px;
}
.editorial-frame-body {
  position: relative;
  z-index: 1;
}
.editorial-frame-label {
  font-family: 'DM Sans', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(201,168,76,.85);
  margin-bottom: 12px;
}
.editorial-frame-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  letter-spacing: -.01em;
  line-height: 1.1;
  color: #F7F4EF;
  margin-bottom: 8px;
}
.editorial-frame-sub {
  font-family: 'DM Sans', sans-serif;
  font-style: italic;
  font-size: 14px;
  color: rgba(201,168,76,.9);
  letter-spacing: .005em;
}

/* Live availability widget */
.live-avail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 12px;
}

/* Pricing transparency table */
.pricing-table {
  width: 100%;
  border-collapse: collapse;
  font-family: 'DM Sans', sans-serif;
}
.pricing-table th,
.pricing-table td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid rgba(247,244,239,.12);
  color: rgba(247,244,239,.88);
}
.pricing-table th {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(201,168,76,.75);
  background: transparent;
}
.pricing-table td:last-child {
  text-align: right;
  font-weight: 600;
  color: #F7F4EF;
}

/* Sticky mobile CTA */
.sticky-cta {
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 40;
  display: none;
  padding: 12px 20px;
  border-radius: 999px;
  background: #2D6A4F;
  color: #F7F4EF;
  font-family: 'DM Sans', sans-serif;
  font-weight: 600;
  font-size: .85rem;
  letter-spacing: .01em;
  box-shadow: 0 12px 32px rgba(13,43,31,.28), 0 0 0 1px rgba(201,168,76,.25);
  text-decoration: none;
  transition: opacity .2s ease, transform .2s ease;
}
.sticky-cta.is-visible {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}
@media (min-width: 1024px) {
  .sticky-cta { display: none !important; }
}

/* Mobile safety: lang-switch sits compact next to hamburger */
@media (max-width: 1023px) {
  .mobile-nav-actions .lang-switch button {
    font-size: .62rem;
    padding: 3px 7px;
    letter-spacing: .08em;
  }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}

/* ============================================================
   TRUST STRIP — minimal credentials bar on dark forest background
   ============================================================ */
.trust-item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: rgba(247,244,239,.85);
  font-family: 'DM Sans', sans-serif;
}
@media (max-width: 639px) {
  .trust-item {
    flex-direction: column;
    gap: 6px;
    text-align: center;
  }
}
.trust-label {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(247,244,239,.92);
  line-height: 1.3;
}
.trust-item svg,
.trust-item .mc-icon {
  flex-shrink: 0;
}

/* Service area ticker text — sits on dark band */
.ticker-track,
.ticker-item {
  color: rgba(247,244,239,.85);
  font-family: 'DM Sans', sans-serif;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .18em;
  text-transform: uppercase;
}

/* ============================================================
   QUOTE CARD — homepage Instant Quote card
   ============================================================ */
.mc-quote-card {
  background: #EDE9E1;
  border: 1px solid #DDD9D1;
  border-radius: 4px;
  padding: clamp(28px, 3.5vw, 44px);
  display: flex;
  flex-direction: column;
  gap: 28px;
  box-shadow: 0 1px 0 rgba(28,28,26,.02), 0 24px 48px -28px rgba(13,43,31,.12);
}
.qc-status {
  display: flex;
  align-items: center;
  gap: 10px;
}
.qc-dot {
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #2D6A4F;
  flex-shrink: 0;
}
.qc-dot::after {
  content: '';
  position: absolute;
  inset: -4px;
  border-radius: 50%;
  background: rgba(45,106,79,.25);
  animation: qc-pulse 2.2s ease-out infinite;
}
@keyframes qc-pulse {
  0%   { transform: scale(.6); opacity: .9; }
  70%  { transform: scale(1.6); opacity: 0; }
  100% { transform: scale(1.6); opacity: 0; }
}
.qc-status-label {
  font-family: 'DM Sans', sans-serif;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: #2D6A4F;
}
.qc-headline {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: clamp(1.35rem, 2.2vw, 1.7rem);
  letter-spacing: -.01em;
  line-height: 1.25;
  color: #1C1C1A;
  margin: 0;
}
.qc-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  width: 100%;
  padding: 1.05rem 1.5rem;
  border-radius: 2px;
  background: #2D6A4F;
  color: #F7F4EF;
  border: 1.5px solid #2D6A4F;
  font-family: 'DM Sans', sans-serif;
  font-size: .92rem;
  font-weight: 600;
  letter-spacing: .01em;
  cursor: pointer;
  transition: background .18s cubic-bezier(.2,.7,.2,1),
              border-color .18s cubic-bezier(.2,.7,.2,1),
              transform .18s cubic-bezier(.2,.7,.2,1),
              box-shadow .18s cubic-bezier(.2,.7,.2,1);
}
.qc-cta:hover {
  background: #1B4332;
  border-color: #1B4332;
  transform: translateY(-1px);
  box-shadow: 0 6px 22px rgba(201,168,76,.25), 0 0 0 1px rgba(201,168,76,.18);
}
.qc-divider {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  max-width: 160px;
  margin: 0 auto;
  width: 100%;
}
.qc-divider::before,
.qc-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(28,28,26,.15);
}
.qc-divider span {
  font-family: 'DM Sans', sans-serif;
  font-size: .6rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(28,28,26,.5);
}
.qc-whatsapp {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border-radius: 4px;
  background: transparent;
  border: 1px solid transparent;
  text-decoration: none;
  transition: background .18s ease, border-color .18s ease;
}
.qc-whatsapp:hover {
  background: rgba(45,106,79,.05);
  border-color: rgba(45,106,79,.18);
}
.qc-whatsapp-icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #F7F4EF;
  border: 1px solid #DDD9D1;
  flex-shrink: 0;
}
.qc-whatsapp-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.qc-whatsapp-label {
  font-family: 'DM Sans', sans-serif;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(28,28,26,.5);
}
.qc-whatsapp-number {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 600;
  font-size: 1rem;
  color: #1C1C1A;
  letter-spacing: -.005em;
  transition: color .18s ease;
}
.qc-whatsapp:hover .qc-whatsapp-number {
  color: #2D6A4F;
}

/* ============================================================
   BOX PADDING SYSTEM — consistent rhythm across cards/chips/tiles
   ============================================================ */
.mc-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(45,106,79,.06);
  border: 1px solid rgba(45,106,79,.15);
  font-family: 'DM Sans', sans-serif;
  font-size: .78rem;
  font-weight: 500;
  color: #2D6A4F;
}
.mc-card-sm {
  padding: clamp(20px, 2.5vw, 28px);
  border-radius: 4px;
  background: #FFFFFF;
  border: 1px solid #DDD9D1;
}
.mc-card-md {
  padding: clamp(28px, 3.5vw, 40px);
  border-radius: 4px;
  background: #FFFFFF;
  border: 1px solid #DDD9D1;
}
.mc-card-lg {
  padding: clamp(36px, 4.5vw, 56px);
  border-radius: 4px;
  background: #FFFFFF;
  border: 1px solid #DDD9D1;
}
