.elementor-14579 .elementor-element.elementor-element-d9254b1{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-14579 .elementor-element.elementor-element-16c180b.xpro-widget-bg-overlay:before{transition:background 0.3s;}/* Start custom CSS for html, class: .elementor-element-16c180b */*,
      *::before,
      *::after {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
      }
      html {
        scroll-behavior: smooth;
        -webkit-text-size-adjust: 100%;
      }

      /* ─────────────────────────────────────────────
   BRAND TOKENS
───────────────────────────────────────────── */
      :root {
        /* Foundation */
        --p: #f7f3ee;
        --pb: #e2dbd2;
        --w: #ffffff;
        /* Blue */
        --blue: #2166b9;
        --blue-d: #174d8a;
        --blue-l: #e8f0fb;
        --blue-m: #c4d6ef;
        /* Ink */
        --ink: #0e1a24;
        --ink-m: #2d3f50;
        --ink-s: #4a5e70;
        /* Accent */
        --gold: #9a6f28;
        /* WhatsApp */
        --wa: #1db954;
        --wa-d: #179c44;
        /* Radius */
        --r: 12px;
      }

      body {
        font-family: "DM Sans", sans-serif;
        background: var(--w);
        color: var(--ink-s);
        line-height: 1.7;
        font-size: 16px;
        -webkit-font-smoothing: antialiased;
      }

      /* ─────────────────────────────────────────────
   IMAGE PLACEHOLDERS
───────────────────────────────────────────── */
      .img-ph {
        background: var(--pb);
        position: relative;
        overflow: hidden;
        display: block;
      }
      .img-ph::after {
        content: "";
        position: absolute;
        inset: 0;
        background: linear-gradient(
          110deg,
          transparent 30%,
          rgba(255, 255, 255, 0.5) 50%,
          transparent 70%
        );
        background-size: 200% 100%;
        animation: shimmer 2s infinite;
      }
      @keyframes shimmer {
        0% {
          background-position: 200% 0;
        }
        100% {
          background-position: -200% 0;
        }
      }
      .ph-note {
        position: absolute;
        bottom: 10px;
        left: 12px;
        font-size: 10px;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: var(--ink-s);
        opacity: 0.4;
        z-index: 1;
        font-family: "DM Sans", sans-serif;
      }

      /* ─────────────────────────────────────────────
   NAV
───────────────────────────────────────────── */
      /*nav {*/
        /*position: sticky;*/
        /*top: 0;*/
        /*z-index: 100;*/
      /*  background: rgba(255, 255, 255, 0.96);*/
      /*  backdrop-filter: blur(12px);*/
      /*  border-bottom: 1px solid var(--pb);*/
      /*  height: 56px;*/
      /*  display: flex;*/
      /*  align-items: center;*/
      /*  justify-content: space-between;*/
      /*  padding: 0 20px;*/
      /*}*/
      /*.nb1 {*/
      /*  font-family: "DM Serif Display", serif;*/
      /*  font-size: 17px;*/
      /*  font-weight: 500;*/
      /*  color: var(--ink);*/
      /*}*/
      /*.nb2 {*/
      /*  font-size: 9.5px;*/
      /*  font-weight: 500;*/
      /*  letter-spacing: 2.5px;*/
      /*  text-transform: uppercase;*/
      /*  color: var(--blue);*/
      /*  display: block;*/
      /*  margin-top: 1px;*/
      /*}*/
     
      /* Nav CTA — minimum 44px tap target */
     
      /*.nav-cta {*/
      /*  background: var(--blue);*/
      /*  color: #fff;*/
      /*  font-size: 13px;*/
      /*  font-weight: 600;*/
      /*  padding: 0 18px;*/
      /*  height: 40px;*/
      /*  display: inline-flex;*/
      /*  align-items: center;*/
      /*  border-radius: 4px;*/
      /*  text-decoration: none;*/
      /*  letter-spacing: 0.3px;*/
      /*  white-space: nowrap;*/
      /*  min-height: 40px;*/
      /*}*/

      /* ─────────────────────────────────────────────
   HERO
   AUDIT FIX: H1 weight 300→600, stronger overlay,
   micro-copy added, sub opacity raised
───────────────────────────────────────────── */
      .hero {
        position: relative;
        height: 92svh;
        min-height: 560px;
        max-height: 800px;
        display: flex;
        flex-direction: column;
        justify-content: flex-end;
        overflow: hidden;
      }
      /* Hero background — replace div with real <img> */
      .hero-bg {
        position: absolute;
        inset: 0;
        background: linear-gradient(
          160deg,
          #c8bfb5 0%,
          #a89d93 40%,
          #8e8078 100%
        );
      }
      
      .hero-bg img{
        width:100%;
        height:100%;
        object-fit:cover;
        object-position:75% center;
        display:block;
      }
      
      
      /* Decorative blobs */
      .hero-blob {
        position: absolute;
        top: 6%;
        right: -6%;
        width: 52vw;
        max-width: 300px;
        height: 68%;
        border-radius: 42% 58% 52% 48%/48% 44% 56% 52%;
        background: rgba(255, 255, 255, 0.06);
        border: 1px solid rgba(255, 255, 255, 0.08);
      }
      .hero-blob2 {
        position: absolute;
        top: 22%;
        right: 10%;
        width: 35vw;
        max-width: 200px;
        height: 42%;
        border-radius: 52% 48% 58% 42%/44% 56% 44% 56%;
        background: rgba(255, 255, 255, 0.03);
      }
      /* Stronger overlay — AUDIT FIX: ensures H1 contrast on any photo */
      .hero-overlay {
        position: absolute;
        inset: 0;
        background: linear-gradient(
          to top,
          rgba(10, 18, 28, 0.92) 0%,
          rgba(10, 18, 28, 0.55) 40%,
          rgba(10, 18, 28, 0.15) 100%
        );
      }
      .hero-content {
        position: relative;
        z-index: 2;
        padding: 0 22px 48px;
      }
      /* Status pill */
      .hero-pill {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        background: rgba(255, 255, 255, 0.1);
        border: 1px solid rgba(255, 255, 255, 0.2);
        border-radius: 20px;
        padding: 5px 13px;
        margin-bottom: 20px;
      }
      .hero-dot {
        width: 7px;
        height: 7px;
        border-radius: 50%;
        background: var(--wa);
        flex-shrink: 0;
        animation: pulse 2s infinite;
      }
      @keyframes pulse {
        0%,
        100% {
          opacity: 1;
        }
        50% {
          opacity: 0.4;
        }
      }
      .hero-pill span {
        font-size: 10.5px;
        font-weight: 500;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.85);
      }
      /* H1 — AUDIT FIX: weight 300→600, higher contrast */
      .hero h1 {
        font-family: "DM Serif Display", serif;
        font-size: clamp(36px, 9vw, 56px);
        font-weight: 400;
        color: #ffffff;
        line-height: 1.1;
        letter-spacing: -0.3px;
        margin-bottom: 4px;
        text-shadow: 0 2px 16px rgba(0, 0, 0, 0.3);
      }
      .hero h1 em {
        font-style: italic;
        font-weight: 500;
        color: rgba(255, 255, 255, 0.9);
      }
      /* Clinic name sub-label under H1 */
      .hero h1 strong {
        display: block;
        font-family: "DM Sans", sans-serif;
        font-size: clamp(12px, 2.5vw, 14px);
        font-weight: 500;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.6);
        margin-top: 8px;
        text-shadow: none;
      }
      /* Gold rule */
      .hero-rule {
        width: 36px;
        height: 3px;
        background: var(--gold);
        margin: 20px 0 18px;
        border-radius: 2px;
      }
      /* Sub — AUDIT FIX: opacity raised from 0.68 → 0.82 */
      .hero-sub {
        font-size: 16px;
        font-weight: 300;
        color: rgba(255, 255, 255, 0.82);
        line-height: 1.75;
        margin-bottom: 8px;
        max-width: 400px;
      }
      .hero-sub b {
        font-weight: 500;
        color: #fff;
      }
      /* AUDIT FIX: Micro-copy trust line above CTA */
      .hero-micro {
        font-size: 12px;
        font-weight: 500;
        color: rgba(255, 255, 255, 0.55);
        letter-spacing: 0.5px;
        margin-bottom: 18px;
        display: flex;
        align-items: center;
        gap: 6px;
      }
      .hero-micro span {
        display: inline-flex;
        align-items: center;
        gap: 5px;
      }
      .hero-micro span::before {
        content: "★";
        color: var(--gold);
        font-size: 11px;
      }
      .hero-btns {
        display: flex;
        flex-direction: column;
        gap: 10px;
      }
      /* Primary CTA — AUDIT FIX: min-height 52px, stronger shadow for pop */
      .btn-wa-hero {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        background: var(--wa);
        color: #fff;
        font-size: 16px;
        font-weight: 600;
        padding: 0 28px;
        height: 52px;
        min-height: 52px;
        border-radius: 6px;
        text-decoration: none;
        letter-spacing: 0.3px;
        box-shadow: 0 4px 20px rgba(29, 185, 84, 0.5);
        transition:
          background 0.18s,
          transform 0.18s,
          box-shadow 0.18s;
      }
      .btn-wa-hero:hover {
        background: var(--wa-d);
        transform: translateY(-2px);
        box-shadow: 0 6px 24px rgba(29, 185, 84, 0.6);
      }
      /* Ghost CTA — AUDIT FIX: better contrast, visible border */
      .btn-ghost {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        background: rgba(255, 255, 255, 0.08);
        border: 1.5px solid rgba(255, 255, 255, 0.35);
        color: #fff;
        font-size: 14px;
        font-weight: 400;
        padding: 0 22px;
        height: 48px;
        min-height: 48px;
        border-radius: 6px;
        text-decoration: none;
        transition:
          background 0.18s,
          border-color 0.18s;
      }
      .btn-ghost:hover {
        background: rgba(255, 255, 255, 0.14);
        border-color: rgba(255, 255, 255, 0.55);
      }

      /* ─────────────────────────────────────────────
   TRUST STRIP
───────────────────────────────────────────── */
      .tstrip {
        background: var(--blue);
        display: flex;
        overflow-x: auto;
        scrollbar-width: none;
        padding: 13px 20px;
        gap: 0;
      }
      .tstrip::-webkit-scrollbar {
        display: none;
      }
      .ti {
        display: flex;
        align-items: center;
        gap: 8px;
        flex-shrink: 0;
        padding-right: 22px;
        margin-right: 22px;
        border-right: 1px solid rgba(255, 255, 255, 0.2);
      }
      .ti:last-child {
        border: none;
        padding: 0;
        margin: 0;
      }
      .ti span {
        font-size: 12px;
        font-weight: 500;
        color: #fff;
        white-space: nowrap;
      }

      /* ─────────────────────────────────────────────
   SECTION SHARED
───────────────────────────────────────────── */
      .sl {
        font-size: 10px;
        font-weight: 600;
        letter-spacing: 3px;
        text-transform: uppercase;
        color: var(--blue);
        margin-bottom: 10px;
      }
      .st {
        font-family: "DM Serif Display", serif;
        font-size: clamp(28px, 6vw, 36px);
        font-weight: 500;
        color: var(--ink);
        line-height: 1.15;
      }
      .st em {
        font-style: italic;
        font-weight: 400;
      }

      /* ─────────────────────────────────────────────
   TREATMENTS
   AUDIT FIX: card body font-size 12.5→16px,
   card links made proper tap targets 44px
───────────────────────────────────────────── */
      .tx-section {
        background: var(--p);
        padding: 72px 0 60px;
      }
      .sh {
        padding: 0 22px;
        margin-bottom: 32px;
      }
      .tx-row {
        display: flex;
        gap: 16px;
        padding: 4px 22px 16px;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
      }
      .tx-row::-webkit-scrollbar {
        display: none;
      }
      .tc {
        flex-shrink: 0;
        width: 270px;
        scroll-snap-align: start;
        background: var(--w);
        border: 1px solid var(--pb);
        border-radius: var(--r);
        overflow: hidden;
        transition:
          box-shadow 0.2s,
          transform 0.2s;
      }
      .tc:hover {
        box-shadow: 0 8px 28px rgba(33, 102, 185, 0.12);
        transform: translateY(-2px);
      }
      .tc-img {
        height: 175px;
        overflow:hidden;
      }
      
      .tc-img img{
        width:100%;
        height:100%;
        display:block;
        object-fit:cover;
        object-position:center;
        transform:scale(1);
        transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
        will-change:transform;
      }
    
      .tc:hover .tc-img img{
        transform:scale(1.06);
      }
      
      .tc-body {
        padding: 20px 18px 22px;
      }
      .tc-n {
        font-size: 10px;
        font-weight: 600;
        letter-spacing: 2px;
        text-transform: uppercase;
        color: var(--blue);
        margin-bottom: 8px;
      }
      .tc h2 {
        font-family: "DM Serif Display", serif;
        font-size: 20px;
        font-weight: 500;
        color: var(--ink);
        margin-bottom: 9px;
        line-height: 1.2;
      }
      /* AUDIT FIX: was 12.5px — now 15px (16px on desktop) */
      .tc p {
        font-size: 15px;
        color: var(--ink-s);
        line-height: 1.7;
        margin-bottom: 14px;
      }
      .tc-tags {
        display: flex;
        flex-wrap: wrap;
        gap: 6px;
      }
      .tg {
        font-size: 11px;
        padding: 4px 10px;
        border-radius: 20px;
        background: var(--blue-l);
        color: var(--blue-d);
        border: 1px solid var(--blue-m);
        font-weight: 500;
      }
      /* AUDIT FIX: tc-link → proper button tap target 44px */
      .tc-link {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        margin-top: 16px;
        background: var(--blue-l);
        color: var(--blue-d);
        font-size: 13px;
        font-weight: 600;
        padding: 0 16px;
        height: 40px;
        min-height: 40px;
        border-radius: 5px;
        text-decoration: none;
        letter-spacing: 0.3px;
        border: 1px solid var(--blue-m);
        transition:
          background 0.18s,
          color 0.18s;
      }
      .tc-link:hover {
        background: var(--blue);
        color: #fff;
        border-color: var(--blue);
      }
      /* Scroll dots */
      .sdots {
        display: flex;
        justify-content: center;
        gap: 6px;
        padding: 8px 0 0;
      }
      .sd {
        width: 6px;
        height: 6px;
        border-radius: 50%;
        background: var(--pb);
        transition:
          background 0.2s,
          width 0.2s;
      }
      .sd.on {
        background: var(--blue);
        width: 18px;
        border-radius: 3px;
      }

      /* ─────────────────────────────────────────────
   DOCTOR
───────────────────────────────────────────── */
      .doc {
        background: var(--w);
        padding: 72px 22px;
      }
      .doc-img {
        border-radius: var(--r);
        overflow: hidden;
        margin-bottom: 28px;
      }
      .doc-ph {
        height: 280px;
        background: linear-gradient(140deg, #ddd6ce, #c0b5ab);
        position: relative;
      }
      .doc-name {
        font-family: "DM Serif Display", serif;
        font-size: 32px;
        font-weight: 500;
        color: var(--ink);
        margin-bottom: 4px;
      }
      .doc-cred {
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: var(--blue);
        margin-bottom: 14px;
      }
      .doc-rule {
        width: 32px;
        height: 2px;
        background: var(--gold);
        margin-bottom: 18px;
      }
      /* AUDIT FIX: was 14.5px → 16px */
      .doc-bio {
        font-size: 16px;
        color: var(--ink-s);
        line-height: 1.85;
        margin-bottom: 24px;
      }
      .dstats {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 2px;
        border-radius: 10px;
        overflow: hidden;
        background: var(--pb);
        margin-bottom: 24px;
      }
      .ds {
        background: var(--p);
        padding: 16px 14px;
        text-align: center;
      }
      .ds-n {
        font-family: "DM Serif Display", serif;
        font-size: 30px;
        font-weight: 500;
        color: var(--blue-d);
        line-height: 1;
      }
      .ds-l {
        font-size: 12px;
        color: var(--ink-s);
        margin-top: 4px;
        line-height: 1.4;
      }
      /* WhatsApp button in doctor section */
      .btn-wa-doc {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 9px;
        background: var(--wa);
        color: #fff;
        font-size: 15px;
        font-weight: 500;
        height: 50px;
        min-height: 50px;
        border-radius: 6px;
        text-decoration: none;
        box-shadow: 0 4px 14px rgba(29, 185, 84, 0.3);
        transition: background 0.18s;
      }
      .btn-wa-doc:hover {
        background: var(--wa-d);
      }

      /* ─────────────────────────────────────────────
   WHY
   AUDIT FIX: body text 13px → 15px
───────────────────────────────────────────── */
      .why {
        background: var(--p);
        padding: 72px 22px;
      }
      .why-list {
        margin-top: 32px;
        display: flex;
        flex-direction: column;
        gap: 0;
      }
      .wi {
        display: flex;
        gap: 16px;
        padding: 22px 0;
        border-bottom: 1px solid var(--pb);
      }
      .wi:last-child {
        border: none;
      }
      .wi-icon {
        width: 40px;
        height: 40px;
        min-width: 40px;
        border-radius: 10px;
        background: var(--blue-l);
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        margin-top: 2px;
      }
      .wi h3 {
        font-family: "DM Serif Display", serif;
        font-size: 19px;
        font-weight: 500;
        color: var(--ink);
        margin-bottom: 5px;
      }
      /* AUDIT FIX: was 13px → 15px */
      .wi p {
        font-size: 15px;
        color: var(--ink-s);
        line-height: 1.75;
      }

      /* ─────────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────────── */
      .tms {
        background: var(--ink);
        padding: 72px 22px;
      }
      .tms .sl {
        color: rgba(255, 255, 255, 0.38);
      }
      .tms .st {
        color: #fff;
        margin-top: 10px;
      }
      .tm-list {
        margin-top: 28px;
        display: flex;
        flex-direction: column;
        gap: 14px;
      }
      .tm {
        background: rgba(255, 255, 255, 0.05);
        border: 1px solid rgba(255, 255, 255, 0.1);
        border-radius: var(--r);
        padding: 22px 20px;
      }
      .tm-stars {
        display: flex;
        gap: 3px;
        margin-bottom: 12px;
      }
      .tstar {
        width: 13px;
        height: 13px;
        background: var(--gold);
        clip-path: polygon(
          50% 0%,
          61% 35%,
          98% 35%,
          68% 57%,
          79% 91%,
          50% 70%,
          21% 91%,
          32% 57%,
          2% 35%,
          39% 35%
        );
        flex-shrink: 0;
      }
      .tm q {
        font-family: "DM Serif Display", serif;
        font-size: 17px;
        font-style: italic;
        font-weight: 400;
        color: rgba(255, 255, 255, 0.88);
        line-height: 1.7;
        display: block;
        margin-bottom: 16px;
        quotes: none;
      }
      .tm-who {
        font-size: 11.5px;
        font-weight: 500;
        letter-spacing: 1px;
        text-transform: uppercase;
        color: rgba(255, 255, 255, 0.35);
      }
      .tm-tx {
        font-size: 11px;
        color: var(--blue-m);
        margin-top: 4px;
        opacity: 0.75;
      }

      /* ─────────────────────────────────────────────
   AREAS
───────────────────────────────────────────── */
      .areas {
        background: var(--w);
        padding: 52px 22px;
        border-top: 1px solid var(--pb);
      }
      .area-chips {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        margin-top: 20px;
      }
      .ac {
        display: flex;
        align-items: center;
        gap: 6px;
        padding: 8px 16px;
        border: 1px solid var(--pb);
        border-radius: 20px;
        font-size: 13px;
        color: var(--ink-m);
        font-weight: 400;
      }
      .apin {
        width: 7px;
        height: 7px;
        border-radius: 50% 50% 50% 0;
        background: var(--blue);
        transform: rotate(-45deg);
        flex-shrink: 0;
      }

      /* ─────────────────────────────────────────────
   FAQ
───────────────────────────────────────────── */
      .faq {
        background: var(--p);
        padding: 72px 22px;
      }
      .faq-list {
        margin-top: 32px;
      }
      .fi {
        background: var(--w);
        border: 1px solid var(--pb);
        border-radius: 8px;
        margin-bottom: 10px;
        overflow: hidden;
      }
      /* AUDIT FIX: fq min-height 52px for tap target */
      .fq {
        display: flex;
        justify-content: space-between;
        align-items: center;
        gap: 12px;
        padding: 18px 20px;
        min-height: 52px;
        cursor: pointer;
        font-family: "DM Serif Display", serif;
        font-size: 18px;
        font-weight: 500;
        color: var(--ink);
        line-height: 1.3;
        user-select: none;
      }
      .fq:hover {
        background: var(--p);
      }
      .fc {
        width: 24px;
        height: 24px;
        min-width: 24px;
        border-radius: 50%;
        background: var(--blue-l);
        display: flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        transition:
          transform 0.25s,
          background 0.2s;
      }
      .fi.op .fc {
        transform: rotate(180deg);
        background: var(--blue);
      }
      .fi.op .fc svg path {
        stroke: #fff;
      }
      /* AUDIT FIX: answer font-size 13.5 → 15px */
      .fa {
        font-size: 15px;
        color: var(--ink-s);
        line-height: 1.8;
        max-height: 0;
        overflow: hidden;
        transition:
          max-height 0.35s ease,
          padding 0.25s;
        padding: 0 20px;
      }
      .fi.op .fa {
        max-height: 300px;
        padding: 0 20px 18px;
      }

      /* ─────────────────────────────────────────────
   BOOKING
───────────────────────────────────────────── */
      .book {
        background: var(--w);
        padding: 72px 22px;
      }
      .book-inner {
        display: block;
      }
      .book-side {
        display: none;
      }
      .book-card {
        background: var(--p);
        border: 1px solid var(--pb);
        border-radius: var(--r);
        padding: 28px 22px;
        max-width: 480px;
        margin: 0 auto;
      }
      .book-card h2 {
        font-family: "DM Serif Display", serif;
        font-size: 26px;
        font-weight: 500;
        color: var(--ink);
        margin-bottom: 4px;
      }
      .bsub {
        font-size: 14px;
        color: var(--ink-s);
        margin-bottom: 24px;
      }
      .fl {
        margin-bottom: 14px;
      }
      .fl label {
        display: block;
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 1.5px;
        text-transform: uppercase;
        color: var(--ink-s);
        margin-bottom: 6px;
      }
      /* AUDIT FIX: input min-height 48px for tap targets */
      .fl input,
      .fl select {
        width: 100%;
        background: var(--w);
        border: 1px solid var(--pb);
        border-radius: 6px;
        padding: 0 13px;
        height: 48px;
        min-height: 48px;
        font-family: "DM Sans", sans-serif;
        font-size: 15px;
        color: var(--ink);
        outline: none;
        transition:
          border-color 0.18s,
          box-shadow 0.18s;
        -webkit-appearance: none;
      }
      .fl textarea {
        width: 100%;
        background: var(--w);
        border: 1px solid var(--pb);
        border-radius: 6px;
        padding: 12px 13px;
        height: 80px;
        resize: none;
        font-family: "DM Sans", sans-serif;
        font-size: 15px;
        color: var(--ink);
        outline: none;
        transition:
          border-color 0.18s,
          box-shadow 0.18s;
      }
      .fl input:focus,
      .fl select:focus,
      .fl textarea:focus {
        border-color: var(--blue);
        box-shadow: 0 0 0 3px rgba(33, 102, 185, 0.12);
      }
      .fg2 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 12px;
      }
      /* AUDIT FIX: submit button height 52px */
      .btn-sub {
        width: 100%;
        background: var(--blue);
        color: #fff;
        font-family: "DM Sans", sans-serif;
        font-size: 15px;
        font-weight: 600;
        height: 52px;
        min-height: 52px;
        border: none;
        border-radius: 6px;
        cursor: pointer;
        letter-spacing: 0.3px;
        box-shadow: 0 4px 14px rgba(33, 102, 185, 0.3);
        transition:
          background 0.18s,
          box-shadow 0.18s;
      }
      .btn-sub:hover {
        background: var(--blue-d);
        box-shadow: 0 6px 18px rgba(33, 102, 185, 0.4);
      }
      .book-or {
        text-align: center;
        margin: 16px 0;
        font-size: 12px;
        color: var(--ink-s);
        position: relative;
      }
      .book-or::before,
      .book-or::after {
        content: "";
        position: absolute;
        top: 50%;
        width: 40%;
        height: 1px;
        background: var(--pb);
      }
      .book-or::before {
        left: 0;
      }
      .book-or::after {
        right: 0;
      }
      .btn-wa-b {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 9px;
        background: #f0faf4;
        border: 1px solid #b7e3ca;
        color: #1a6b3a;
        font-family: "DM Sans", sans-serif;
        font-size: 14px;
        font-weight: 500;
        height: 48px;
        min-height: 48px;
        border-radius: 6px;
        text-decoration: none;
        transition: background 0.18s;
      }
      .btn-wa-b:hover {
        background: #e0f5e9;
      }
      .prv {
        font-size: 11.5px;
        color: var(--ink-s);
        text-align: center;
        margin-top: 12px;
        opacity: 0.65;
      }

      /* ─────────────────────────────────────────────
   E-E-A-T
───────────────────────────────────────────── */
      .eeeat {
        background: var(--p);
        border-top: 1px solid var(--pb);
        padding: 32px 22px;
      }
      .eeeat p {
        font-size: 13px;
        color: var(--ink-s);
        line-height: 1.9;
      }
      .eeeat strong {
        color: var(--ink-m);
      }
      .disc {
        background: var(--ink);
        padding: 18px 22px;
        text-align: center;
      }
      .disc p {
        font-size: 11px;
        color: rgba(255, 255, 255, 0.25);
        line-height: 1.7;
      }

      /* ─────────────────────────────────────────────
   TABLET ≥ 768px
───────────────────────────────────────────── */
      @media (min-width: 768px) {
        body {
          padding-bottom: 0;
        }
        
        nav {
          height: 62px;
          padding: 0 40px;
        }
        .nb1 {
          font-size: 19px;
        }

        .hero {
          max-height: 880px;
        }
        .hero-content {
          padding: 0 52px 64px;
          max-width: 640px;
        }
        .hero h1 {
          font-size: clamp(44px, 5.5vw, 60px);
        }
        .hero-sub {
          font-size: 17px;
          max-width: 500px;
        }
        .hero-btns {
          flex-direction: row;
          gap: 12px;
          align-items: center;
        }
        .btn-wa-hero,
        .btn-ghost {
          width: auto;
        }

        .tstrip {
          justify-content: center;
          padding: 14px 40px;
        }

        .tx-section {
          padding: 88px 0 72px;
        }
        .sh {
          padding: 0 52px;
          margin-bottom: 36px;
        }
        .tx-row {
          display: grid;
          grid-template-columns: repeat(2, 1fr);
          gap: 22px;
          padding: 4px 52px 4px;
          overflow: visible;
          scroll-snap-type: none;
        }
        .tc {
          width: auto;
        }
        .tc p {
          font-size: 15px;
        }
        .sdots {
          display: none;
        }

        .doc {
          padding: 88px 52px;
        }
        .doc-inner {
          display: grid;
          grid-template-columns: 1fr 1fr;
          gap: 56px;
          align-items: start;
        }
        .doc-img {
          margin-bottom: 0;
        }
        .doc-ph {
          height: 380px;
        }

        .why {
          padding: 88px 52px;
        }
        .tms {
          padding: 88px 52px;
        }
        .tm-list {
          display: grid;
          grid-template-columns: repeat(3, 1fr);
          gap: 18px;
        }
        .areas {
          padding: 56px 52px;
        }
        .faq {
          padding: 88px 52px;
        }
        .faq-layout {
          display: grid;
          grid-template-columns: 1fr 2fr;
          gap: 60px;
          align-items: start;
        }
        .faq-sidebar {
          position: sticky;
          top: 80px;
        }
        .faq-list {
          margin-top: 0;
        }

        .book {
          padding: 88px 52px;
        }
        .book-card {
          max-width: 560px;
        }
        .eeeat {
          padding: 36px 52px;
        }
        .disc {
          padding: 18px 52px;
        }
      }

      /* ─────────────────────────────────────────────
   DESKTOP ≥ 1100px
───────────────────────────────────────────── */
      @media (min-width: 1100px) {
        nav {
          padding: 0 72px;
          height: 68px;
        }
        .nb1 {
          font-size: 21px;
        }

        .hero {
          max-height: 940px;
        }
        .hero-content {
          padding: 0 88px 80px;
          max-width: 720px;
        }
        .hero h1 {
          font-size: clamp(56px, 5vw, 72px);
        }
        .hero-sub {
          font-size: 18px;
          max-width: 560px;
        }

        .tx-section {
          padding: 100px 0 80px;
        }
        .sh {
          padding: 0 88px;
          margin-bottom: 44px;
        }
        .tx-row {
          grid-template-columns: repeat(3, 1fr);
          gap: 24px;
          padding: 4px 88px 4px;
        }
        .tc-img {
          height: 200px;
        }
        .tc p {
          font-size: 16px;
        }

        .doc {
          padding: 100px 88px;
        }
        .doc-inner {
          gap: 80px;
        }
        .doc-ph {
          height: 460px;
        }
        .doc-name {
          font-size: 40px;
        }
        .doc-bio {
          font-size: 17px;
        }

        .why {
          padding: 100px 88px;
        }
        .why-list {
          display: grid;
          grid-template-columns: repeat(3, 1fr);
          gap: 0;
        }
        .wi {
          flex-direction: column;
          gap: 14px;
          padding: 32px 28px;
          border-bottom: none;
          border-right: 1px solid var(--pb);
        }
        .wi:last-child {
          border-right: none;
        }
        .wi p {
          font-size: 15px;
        }

        .tms {
          padding: 100px 88px;
        }
        .areas {
          padding: 60px 88px;
        }
        .faq {
          padding: 100px 88px;
        }

        .book {
          padding: 100px 88px;
        }
        .book-inner {
          display: grid;
          grid-template-columns: 3fr 2fr;
          gap: 64px;
          align-items: start;
          max-width: 1040px;
          margin: 0 auto;
        }
        .book-card {
          max-width: 100%;
          margin: 0;
        }
        .book-side {
          display: block;
          padding-top: 8px;
        }
        .book-side h3 {
          font-family: "DM Serif Display", serif;
          font-size: 28px;
          font-weight: 500;
          color: var(--ink);
          margin-bottom: 14px;
        }
        .book-side-rule {
          width: 32px;
          height: 2px;
          background: var(--gold);
          margin-bottom: 20px;
        }
        .book-side p {
          font-size: 15px;
          color: var(--ink-s);
          line-height: 1.85;
          margin-bottom: 24px;
        }
        .book-contact-row {
          display: flex;
          flex-direction: column;
          gap: 14px;
        }
        .bcr {
          display: flex;
          align-items: center;
          gap: 10px;
          font-size: 14px;
          color: var(--ink-m);
          font-weight: 500;
        }
        .bcr-icon {
          width: 36px;
          height: 36px;
          border-radius: 8px;
          background: var(--blue-l);
          display: flex;
          align-items: center;
          justify-content: center;
          flex-shrink: 0;
        }
        .bcr a {
          color: var(--blue);
          text-decoration: none;
          font-weight: 500;
        }

        .eeeat {
          padding: 40px 88px;
        }
        .disc {
          padding: 20px 88px;
        }
      }/* End custom CSS */