/* Aproch.html */
body {
        font-family: "Newsreader", serif;
      }
      .letter-spacing-widest {
        letter-spacing: 0.3em;
      }
      .hero-overlay {
        background: linear-gradient(
          to bottom,
          rgba(10, 10, 10, 0.4) 0%,
          rgba(10, 10, 10, 0.8) 100%
        );
      }
      .approach-hero-media {
        filter: none;
      }
      .approach-hero-panel {
        background: transparent;
        border: none;
        box-shadow: none;
      }

      .approach-philosophy {
        padding-top: clamp(5rem, 10vw, 8rem);
        padding-bottom: clamp(5rem, 10vw, 8rem);
      }

      .approach-philosophy-grid {
        display: grid;
        grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
        gap: clamp(2.5rem, 7vw, 6rem);
        align-items: center;
      }

      .approach-philosophy-copy {
        max-width: 40rem;
      }

      .approach-feature-list {
        display: grid;
        gap: 2rem;
      }

      .approach-feature {
        display: grid;
        grid-template-columns: 4rem minmax(0, 1fr);
        gap: 1.5rem;
        align-items: start;
      }

      .approach-feature-icon {
        width: 4rem;
        height: 4rem;
        border-radius: 999px;
        border: 1px solid rgba(163, 0, 0, 0.22);
        display: flex;
        align-items: center;
        justify-content: center;
        color: #b30a0a;
        background: rgba(163, 0, 0, 0.04);
        transition: all 0.35s ease;
      }

      .approach-feature:hover .approach-feature-icon {
        color: #ffffff;
        background: #a30000;
        border-color: rgba(163, 0, 0, 0.95);
      }

      .approach-feature-icon svg {
        width: 1.65rem;
        height: 1.65rem;
        stroke: currentColor;
      }

      .approach-philosophy-media {
        position: relative;
        padding: 1rem;
      }

      .approach-philosophy-image {
        position: relative;
        width: 100%;
        min-height: 560px;
        border-radius: 0.375rem;
        object-fit: cover;
        object-position: center;
        filter: grayscale(0.25);
      }

      @media (max-width: 1023px) {
        .approach-philosophy-grid {
          grid-template-columns: 1fr;
        }

        .approach-philosophy-copy {
          max-width: none;
        }

        .approach-philosophy-media {
          order: -1;
          padding: 0;
        }

        .approach-philosophy-image {
          min-height: 420px;
        }
      }

      @media (max-width: 640px) {
        .approach-hero {
          height: 100svh !important;
          min-height: 100svh;
          padding-top: 7rem;
          padding-bottom: 2.5rem;
          align-items: center;
        }

        .approach-hero-media {
          height: 100%;
          object-position: center;
        }

        .approach-hero-panel {
          padding: 1.5rem 1.25rem;
          border-radius: 1.5rem;
          backdrop-filter: blur(14px);
          -webkit-backdrop-filter: blur(14px);
        }

        .approach-hero-kicker {
          margin-bottom: 1rem !important;
          font-size: 0.62rem !important;
          letter-spacing: 0.28em !important;
        }

        .approach-hero-title {
          font-size: clamp(3rem, 15vw, 4.6rem) !important;
          line-height: 0.94 !important;
          margin-bottom: 1rem !important;
        }

        .approach-hero-copy {
          font-size: 1rem !important;
          line-height: 1.7 !important;
          color: rgba(255, 255, 255, 0.92) !important;
          margin-bottom: 1.5rem !important;
        }

        .approach-hero-actions {
          gap: 0.85rem !important;
        }

        .approach-hero-actions a {
          width: 100%;
          padding: 0.95rem 1.25rem !important;
          font-size: 0.76rem !important;
          letter-spacing: 0.22em !important;
        }

        .approach-philosophy {
          padding-left: 1.25rem;
          padding-right: 1.25rem;
        }

        .approach-philosophy-grid {
          gap: 2rem;
        }

        .approach-philosophy-copy h3 {
          font-size: clamp(2.5rem, 10vw, 3.6rem) !important;
          line-height: 1.06 !important;
          margin-bottom: 1.25rem !important;
        }

        .approach-philosophy-copy p {
          font-size: 1rem !important;
          line-height: 1.8 !important;
        }

        .approach-feature {
          grid-template-columns: 3.5rem minmax(0, 1fr);
          gap: 1rem;
        }

        .approach-feature-icon {
          width: 3.5rem;
          height: 3.5rem;
        }

        .approach-feature h4 {
          font-size: 1.85rem !important;
          margin-bottom: 0.5rem !important;
        }

        .approach-philosophy-image {
          min-height: 320px;
        }
      }
      body.tm-warm-theme {
        background: #f5f1eb !important;
        color: #3f3b34 !important;
      }
      body.tm-warm-theme #navbar .brand-wordmark {
        color: #7d6b5d !important;
        background: transparent !important;
        background-color: transparent !important;
      }
      body.tm-warm-theme #navbar {
        background: rgba(251, 249, 246, 0.82) !important;
        border-color: rgba(158, 137, 118, 0.18) !important;
        box-shadow: 0 10px 30px rgba(158, 137, 118, 0.08);
      }
      body.tm-warm-theme #navbar.navbar-scrolled {
        background: rgba(251, 249, 246, 0.94) !important;
        border-color: rgba(158, 137, 118, 0.24) !important;
        box-shadow: 0 14px 34px rgba(158, 137, 118, 0.12) !important;
      }
      body.tm-warm-theme #navbar a:not(.brand-lockup):not(.book-now-btn) {
        color: #716a61 !important;
      }
      body.tm-warm-theme #navbar a:not(.brand-lockup):not(.book-now-btn):hover {
        color: #7d6b5d !important;
      }
      body.tm-warm-theme #line1,
      body.tm-warm-theme #line2 {
        background-color: #3f3b34 !important;
      }
      body.tm-warm-theme .hero-overlay {
        background: linear-gradient(
          to bottom,
          rgba(63, 59, 52, 0.12) 0%,
          rgba(63, 59, 52, 0.46) 100%
        );
      }
      body.tm-warm-theme .approach-hero-media {
        filter: none;
      }
      body.tm-warm-theme .approach-hero-panel {
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
      }
      body.tm-warm-theme .approach-hero-copy {
        color: #4c463f !important;
      }
      body.tm-warm-theme .brand-wordmark {
        font-family: "Newsreader", serif !important;
        color: #7d6b5d !important;
        opacity: 1 !important;
        background: transparent !important;
        background-color: transparent !important;
      }
      body.tm-warm-theme section {
        color: #3f3b34;
      }
      body.tm-warm-theme .text-white,
      body.tm-warm-theme .text-stone-200,
      body.tm-warm-theme .text-stone-300,
      body.tm-warm-theme h1,
      body.tm-warm-theme h2,
      body.tm-warm-theme h3,
      body.tm-warm-theme h4 {
        color: #3f3b34 !important;
      }
      body.tm-warm-theme .text-stone-400,
      body.tm-warm-theme .text-stone-500,
      body.tm-warm-theme .text-slate-400,
      body.tm-warm-theme .text-slate-500 {
        color: #716a61 !important;
      }
      body.tm-warm-theme .text-primary {
        color: #9e8976 !important;
      }
      body.tm-warm-theme .border-primary\/30,
      body.tm-warm-theme .border-primary\/20,
      body.tm-warm-theme .border-white\/20,
      body.tm-warm-theme .border-white\/10,
      body.tm-warm-theme .border-white\/5 {
        border-color: rgba(158, 137, 118, 0.18) !important;
      }
      body.tm-warm-theme .bg-stone-950,
      body.tm-warm-theme .bg-charcoal {
        background: #f5f1eb !important;
      }
      body.tm-warm-theme .bg-white\/5 {
        background: rgba(255, 255, 255, 0.55) !important;
      }
      body.tm-warm-theme .hover\:bg-white\/5:hover {
        background: rgba(158, 137, 118, 0.08) !important;
      }
      body.tm-warm-theme .hover\:bg-primary\/5:hover {
        background: rgba(158, 137, 118, 0.08) !important;
      }
      body.tm-warm-theme .bg-primary {
        background: #9e8976 !important;
      }
      body.tm-warm-theme #navbar .book-now-btn,
      body.tm-warm-theme .mobile-contact-link {
        background: #9e8976 !important;
        border-color: #9e8976 !important;
        color: #fff !important;
      }
      body.tm-warm-theme #navbar .book-now-btn:hover,
      body.tm-warm-theme .mobile-contact-link:hover {
        background: #7d6b5d !important;
        color: #fff !important;
      }
      body.tm-warm-theme .hover\:bg-primary\/80:hover {
        background: #7d6b5d !important;
      }
      body.tm-warm-theme a.bg-primary,
      body.tm-warm-theme a.bg-primary.text-white {
        color: #fff !important;
      }
      body.tm-warm-theme .approach-feature-icon {
        border-color: rgba(158, 137, 118, 0.22);
        color: #9e8976;
        background: rgba(158, 137, 118, 0.06);
      }
      body.tm-warm-theme .approach-feature:hover .approach-feature-icon {
        color: #fff;
        background: #9e8976;
        border-color: rgba(158, 137, 118, 0.9);
      }
      body.tm-warm-theme .approach-philosophy-image {
        filter: none;
      }
      body.tm-warm-theme .approach-modalities-grid {
        background: rgba(125, 107, 93, 0.22) !important;
        border-color: rgba(125, 107, 93, 0.42) !important;
      }
      body.tm-warm-theme .approach-modality-card {
        background: #f5f1eb !important;
        box-shadow: inset 0 0 0 1px rgba(125, 107, 93, 0.34);
        overflow: hidden;
      }
      .approach-modality-icon {
        width: 3rem;
        height: 3rem;
        display: flex;
        align-items: center;
        justify-content: flex-start;
      }
      .approach-modality-svg {
        width: 2.6rem;
        height: 2.6rem;
        display: block;
      }
      .approach-modality-card .material-symbols-outlined {
        display: block;
        line-height: 1;
      }
      body.tm-warm-theme .approach-quote-panel {
        border-color: rgba(92, 76, 64, 0.46) !important;
      }
      body.tm-warm-theme .approach-quote-panel p {
        color: #fff !important;
      }
      body.tm-warm-theme #navbar .brand-wordmark.brand-wordmark,
      body.tm-warm-theme #navbar .brand-wordmark {
        background: transparent !important;
        background-color: transparent !important;
        color: #7d6b5d !important;
        box-shadow: none !important;
      }
          /* shared-navbar-footer */
      body.tm-warm-theme {
        background: #f5f1eb;
        color: #3f3b34;
      }
      body.tm-warm-theme #navbar {
        background: rgba(251, 249, 246, 0.82) !important;
        border-color: rgba(158, 137, 118, 0.18) !important;
        box-shadow: 0 10px 30px rgba(158, 137, 118, 0.08);
      }
      body.tm-warm-theme #navbar .brand-wordmark,
      body.tm-warm-theme #line1,
      body.tm-warm-theme #line2 {
        color: #3f3b34 !important;
        background-color: #3f3b34 !important;
      }
      body.tm-warm-theme #navbar .book-now-btn {
        background: #9e8976 !important;
        color: #fff !important;
      }
      body.tm-warm-theme #navbar .book-now-btn:hover {
        background: #7d6b5d !important;
      }
      body.tm-warm-theme .brand-lockup {
        gap: 0.9rem;
        min-width: 0;
      }
      body.tm-warm-theme .brand-mark-wrap {
        width: 2.75rem;
        height: 2.75rem;
        overflow: hidden;
        flex-shrink: 0;
        border-radius: 9999px;
        background: transparent;
        border: none;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        padding-left: 0;
      }
      body.tm-warm-theme .brand-mark {
        height: 2.3rem !important;
        width: auto;
        max-width: none !important;
      }
      body.tm-warm-theme .brand-wordmark {
        color: #7d6b5d !important;
        display: inline-block;
        opacity: 1 !important;
        text-shadow: none;
        line-height: 1;
        letter-spacing: 0.18em;
        font-size: 1rem !important;
        font-weight: 700;
        white-space: nowrap;
        background: transparent !important;
      }
      body.tm-warm-theme #mobileMenu {
        background: rgba(245, 241, 232, 0.96) !important;
      }
      body.tm-warm-theme #mobileMenu a {
        color: #3f3b34 !important;
      }
      body.tm-warm-theme #mobileMenu a:hover {
        color: #9e8976 !important;
      }
      body.tm-warm-theme #mobileMenu .mobile-contact-link {
        background: #9e8976 !important;
        border-color: #9e8976 !important;
        color: #fff !important;
      }
@media (max-width: 767px) {
        body.tm-warm-theme .brand-wordmark {
          font-size: 0.82rem !important;
          letter-spacing: 0.12em;
        }
      }

/* Aproch.html */
body #mobileMenu,
      body #mobileMenu.hidden {
        display: none !important;
        transform: translateY(-100%) !important;
        visibility: hidden !important;
        pointer-events: none !important;
      }

      body.menu-open #mobileMenu {
        display: flex !important;
        transform: translateY(0) !important;
        visibility: visible !important;
        pointer-events: auto !important;
      }

/* Aproch.html */
@keyframes slideNavDown {
            0% {
              transform: translateY(-100%);
              opacity: 0;
            }
            100% {
              transform: translateY(0);
              opacity: 1;
            }
          }
              /* shared-navbar-footer */
      body.tm-warm-theme {
        background: #f5f1eb;
        color: #3f3b34;
      }
      body.tm-warm-theme #navbar {
        background: rgba(251, 249, 246, 0.82) !important;
        border-color: rgba(158, 137, 118, 0.18) !important;
        box-shadow: 0 10px 30px rgba(158, 137, 118, 0.08);
      }
      body.tm-warm-theme #navbar .brand-wordmark,
      body.tm-warm-theme #line1,
      body.tm-warm-theme #line2 {
        color: #3f3b34 !important;
        background-color: #3f3b34 !important;
      }
      body.tm-warm-theme #navbar .book-now-btn {
        background: #9e8976 !important;
        color: #fff !important;
      }
      body.tm-warm-theme #navbar .book-now-btn:hover {
        background: #7d6b5d !important;
      }
      body.tm-warm-theme .brand-lockup {
        gap: 0.9rem;
        min-width: 0;
      }
      body.tm-warm-theme .brand-mark-wrap {
        width: 2.75rem;
        height: 2.75rem;
        overflow: hidden;
        flex-shrink: 0;
        border-radius: 9999px;
        background: transparent;
        border: none;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        padding-left: 0;
      }
      body.tm-warm-theme .brand-mark {
        height: 2.3rem !important;
        width: auto;
        max-width: none !important;
      }
      body.tm-warm-theme .brand-wordmark {
        color: #7d6b5d !important;
        display: inline-block;
        opacity: 1 !important;
        text-shadow: none;
        line-height: 1;
        letter-spacing: 0.18em;
        font-size: 1rem !important;
        font-weight: 700;
        white-space: nowrap;
        background: transparent !important;
      }
      body.tm-warm-theme #mobileMenu {
        background: rgba(245, 241, 232, 0.96) !important;
      }
      body.tm-warm-theme #mobileMenu a {
        color: #3f3b34 !important;
      }
      body.tm-warm-theme #mobileMenu a:hover {
        color: #9e8976 !important;
      }
      body.tm-warm-theme #mobileMenu .mobile-contact-link {
        background: #9e8976 !important;
        border-color: #9e8976 !important;
        color: #fff !important;
      }
@media (max-width: 767px) {
        body.tm-warm-theme .brand-wordmark {
          font-size: 0.82rem !important;
          letter-spacing: 0.12em;
        }
      }

