:root{
  --teal-900:#064e4a;
  --teal-700:#0f766e;
  --teal-600:#14857c;
  --teal-100:#d2f0eb;
  --teal-50:#ecf8f5;
  --sand-50:#fbf8f1;
  --sand-100:#f4eee0;
  --ink-900:#0c2a27;
  --ink-700:#28433f;
  --ink-500:#6b7d7a;
  --ink-300:#a4b3b0;
  --line:#e3ece9;
  --gold:#d6a85f;
  --rose:#e5736f;

  --r-sm:8px;
  --r-md:14px;
  --r-lg:22px;
  --r-xl:32px;

  --shadow-1:0 4px 10px rgba(12,42,39,.04), 0 1px 2px rgba(12,42,39,.06);
  --shadow-2:0 18px 40px -18px rgba(12,42,39,.22), 0 6px 14px -6px rgba(12,42,39,.10);
  --shadow-3:0 35px 60px -30px rgba(12,42,39,.32);

  --ease-out:cubic-bezier(0.23,1,0.32,1);
  --ease-in-out:cubic-bezier(0.77,0,0.175,1);

  --font-en:'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-my:'Padauk','Pyidaungsu','Myanmar Text', var(--font-en);
  --font-serif:'Playfair Display', Georgia, serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-en);
  color:var(--ink-900);
  background:var(--sand-50);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
html[lang="my"] body{font-family:var(--font-my); line-height:1.85}
img{max-width:100%; display:block}
a{color:var(--teal-700); text-decoration:none}
a:hover{color:var(--teal-900)}

.container{
  width:100%;
  max-width:1180px;
  margin:0 auto;
  padding:0 22px;
}

/* HEADER ---------------------------------------------------------------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(251,248,241,.85);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .2s var(--ease-out), background .2s var(--ease-out);
}
.site-header.scrolled{
  background:rgba(251,248,241,.96);
  border-bottom-color:var(--line);
}
.nav-bar{
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; min-height:70px; padding:14px 22px;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{display:inline-flex}
.brand-text{display:flex; flex-direction:column; line-height:1.1}
.brand-name{font-weight:800; font-size:1.05rem; color:var(--ink-900)}
.brand-tag{font-size:.78rem; color:var(--ink-500)}
.primary-nav{display:flex; gap:30px}
.primary-nav a{
  color:var(--ink-700); font-weight:500; font-size:.97rem;
  position:relative; padding:6px 0;
}
.primary-nav a::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px;
  height:2px; background:var(--teal-700); transform:scaleX(0); transform-origin:left;
  transition:transform .22s var(--ease-out);
  border-radius:2px;
}
.primary-nav a:hover{color:var(--ink-900)}
.primary-nav a:hover::after{transform:scaleX(1)}
.nav-actions{display:flex; align-items:center; gap:10px}
.lang-toggle{
  border:1px solid var(--line); background:white; padding:7px 12px;
  border-radius:999px; font-weight:600; cursor:pointer; color:var(--ink-700);
  transition:transform .16s var(--ease-out), background .16s var(--ease-out), border-color .16s var(--ease-out);
}
.lang-toggle:hover{border-color:var(--teal-600); color:var(--teal-700)}
.lang-toggle:active{transform:scale(.97)}
.menu-toggle{display:none; background:none; border:0; padding:8px; cursor:pointer}
.menu-toggle span{display:block; width:22px; height:2px; background:var(--ink-900); margin:5px 0; transition:transform .25s var(--ease-out), opacity .25s var(--ease-out)}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:inherit; font-weight:600; font-size:.97rem;
  padding:11px 18px; border-radius:999px; border:1px solid transparent;
  cursor:pointer; transition:transform .18s var(--ease-out), background .18s var(--ease-out), color .18s var(--ease-out), box-shadow .18s var(--ease-out);
}
.btn:active{transform:scale(.97)}
.btn-primary{background:var(--teal-700); color:white; box-shadow:0 8px 20px -8px rgba(15,118,110,.6)}
.btn-primary:hover{background:var(--teal-900); color:white; box-shadow:0 12px 26px -10px rgba(15,118,110,.7)}
.btn-ghost{background:transparent; color:var(--ink-900); border-color:var(--ink-900)}
.btn-ghost:hover{background:var(--ink-900); color:white}
.btn-lg{padding:14px 22px; font-size:1rem}
.cta{padding:10px 16px}

/* HERO ----------------------------------------------------------------- */
.hero{
  position:relative; overflow:hidden;
  padding:80px 0 70px;
}
.hero-art{
  position:absolute; inset:0; z-index:0; opacity:.7;
  filter:saturate(.95) contrast(.98);
}
.hero-art img{width:100%; height:100%; object-fit:cover}
.hero-art-overlay{
  position:absolute; inset:0;
  background:
    radial-gradient(75% 80% at 0% 50%, rgba(251,248,241,.96) 0%, rgba(251,248,241,.82) 35%, rgba(251,248,241,.55) 65%, rgba(251,248,241,.25) 100%),
    linear-gradient(180deg, rgba(251,248,241,.7) 0%, rgba(251,248,241,.4) 50%, rgba(251,248,241,.92) 100%);
}
.hero-grid{
  position:relative; z-index:1;
  display:grid; grid-template-columns:1.45fr 1fr; gap:50px; align-items:end;
}
.eyebrow{
  display:inline-block; margin:0 0 14px;
  font-size:.78rem; letter-spacing:.18em; text-transform:uppercase;
  font-weight:700; color:var(--teal-700);
}
.eyebrow.center{display:block; text-align:center}
h1,h2,h3,h4{font-family:var(--font-serif); color:var(--ink-900); letter-spacing:-.01em; line-height:1.15; margin:0 0 .5em}
html[lang="my"] h1, html[lang="my"] h2, html[lang="my"] h3, html[lang="my"] h4{font-family:var(--font-my); letter-spacing:0; line-height:1.4}
h1{font-size:clamp(2.2rem, 4.6vw, 3.6rem)}
h2{font-size:clamp(1.7rem, 3.2vw, 2.4rem)}
h3{font-size:1.2rem}
.lede{font-size:1.08rem; color:var(--ink-700); max-width:38ch; margin:0 0 26px}
.hero-ctas{display:flex; flex-wrap:wrap; gap:12px; margin-bottom:36px}
.hero-bullets{list-style:none; padding:0; margin:0; display:grid; gap:14px}
.hero-bullets li{display:flex; flex-direction:column; gap:2px}
.hero-bullets strong{font-size:.95rem}
.hero-bullets span{font-size:.9rem; color:var(--ink-500)}

.hero-card{
  background:white; border-radius:var(--r-lg);
  padding:24px; box-shadow:var(--shadow-2);
  border:1px solid var(--line);
  position:relative;
}
.hero-photo{margin:-24px -24px 18px; border-radius:var(--r-lg) var(--r-lg) 0 0; overflow:hidden; aspect-ratio:5/3; background:var(--teal-50)}
.hero-photo img{width:100%; height:100%; object-fit:cover; display:block}
.hero-card h3{margin:0 0 6px; font-family:var(--font-en); font-size:.85rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-700)}
.hours-now{margin:0 0 14px; font-size:1.05rem; font-weight:700; color:var(--ink-900); display:flex; align-items:center; gap:8px}
.hours-now::before{content:''; width:10px; height:10px; border-radius:50%; background:var(--ink-300); flex:0 0 auto}
.hours-now.open{color:var(--teal-700)}
.hours-now.open::before{background:#22c55e; box-shadow:0 0 0 4px rgba(34,197,94,.18)}
.hours-now.closed{color:var(--ink-700)}
.hours-now.closed::before{background:var(--rose); box-shadow:0 0 0 4px rgba(229,115,111,.16)}
.hours-list{list-style:none; padding:0; margin:0 0 16px; display:grid; gap:10px}
.hours-list li{display:flex; justify-content:space-between; font-size:.92rem; color:var(--ink-700); padding:8px 0; border-bottom:1px dashed var(--line)}
.hours-list li:last-child{border-bottom:0}
.card-link{display:inline-flex; align-items:center; gap:8px; font-weight:600; color:var(--teal-700)}

/* TRUST BAND ----------------------------------------------------------- */
.trust-band{
  background:var(--ink-900); color:white;
  padding:30px 0;
}
.trust-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:20px;
  text-align:center;
}
.trust-grid div{display:flex; flex-direction:column; gap:4px}
.trust-grid strong{font-family:var(--font-serif); font-size:2rem; color:var(--gold)}
.trust-grid span{font-size:.85rem; color:rgba(255,255,255,.7)}

/* SECTIONS ------------------------------------------------------------- */
.section{padding:90px 0}
.section-soft{background:var(--teal-50)}
.section-lede{max-width:54ch; margin:0 auto 50px; color:var(--ink-700); text-align:center}
.center{text-align:center}

.two-col{
  display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;
}
.col-text p{color:var(--ink-700); font-size:1.02rem; margin:0 0 16px}
.about-tags{display:flex; flex-wrap:wrap; gap:8px; margin-top:24px}
.about-tags span{
  background:white; border:1px solid var(--line);
  border-radius:999px; padding:7px 14px; font-size:.85rem; color:var(--ink-700); font-weight:500;
}
.col-art{position:relative}
.art-stack{position:relative; min-height:420px}
.art-stack img{position:absolute; border-radius:var(--r-lg); box-shadow:var(--shadow-2)}
.art-a{width:78%; top:0; left:0; aspect-ratio:4/3; object-fit:cover}
.art-b{width:55%; bottom:0; right:0; aspect-ratio:4/5; object-fit:cover; border:6px solid var(--sand-50)}

/* SERVICES ------------------------------------------------------------- */
.services-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:22px;
}
.svc-card{
  background:white; border:1px solid var(--line);
  border-radius:var(--r-lg); padding:28px;
  transition:transform .25s var(--ease-out), box-shadow .25s var(--ease-out), border-color .25s var(--ease-out);
}
.svc-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-2); border-color:var(--teal-100)}
.svc-icon{
  width:48px; height:48px; border-radius:14px;
  display:grid; place-items:center; background:var(--teal-50); color:var(--teal-700);
  margin-bottom:18px;
}
.svc-icon svg{width:24px; height:24px}
.svc-card h3{font-family:var(--font-en); font-size:1.1rem; margin:0 0 6px}
.svc-card p{margin:0; color:var(--ink-700); font-size:.95rem}

/* DOCTORS -------------------------------------------------------------- */
.docs-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:36px;
}
.doc-card{
  background:white; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:26px; text-align:center; box-shadow:var(--shadow-1);
  transition:transform .25s var(--ease-out), box-shadow .25s var(--ease-out);
}
.doc-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-2)}
.doc-portrait{
  width:120px; height:120px; border-radius:50%; margin:0 auto 18px;
  display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, var(--teal-700) 0%, var(--teal-900) 100%);
  color:#fff; font-family:var(--font-serif); font-size:2.2rem; font-weight:600;
  letter-spacing:1px;
  box-shadow:0 0 0 6px var(--teal-50), inset 0 -8px 16px rgba(0,0,0,0.18);
}
.doc-portrait span{line-height:1; transform:translateY(2px)}
.doc-card h3{font-family:var(--font-serif); margin:0 0 6px}
.doc-role{font-size:.85rem; letter-spacing:.08em; text-transform:uppercase; color:var(--teal-700); font-weight:600; margin:0 0 12px}
.doc-bio{margin:0; color:var(--ink-700); font-size:.92rem}

/* GALLERY -------------------------------------------------------------- */
.gallery-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:14px; margin-top:36px;
}
.gallery-grid figure{margin:0; aspect-ratio:4/3; overflow:hidden; border-radius:var(--r-md); box-shadow:var(--shadow-1)}
.gallery-grid img{width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease-out)}
.gallery-grid figure:hover img{transform:scale(1.05)}

/* VISIT --------------------------------------------------------------- */
.visit-grid{
  display:grid; grid-template-columns:1.4fr 1fr; gap:30px; align-items:stretch; margin-top:36px;
}
.map-wrap{
  border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-2);
  background:white; border:1px solid var(--line); min-height:420px;
}
.map-wrap iframe{display:block; width:100%; height:100%; border:0}
.visit-info{
  background:white; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:28px; display:flex; flex-direction:column; gap:6px;
  box-shadow:var(--shadow-1);
}
.visit-info h3{font-family:var(--font-en); font-size:.82rem; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--teal-700); margin:14px 0 4px}
.visit-info h3:first-child{margin-top:0}
.visit-info p{margin:0; color:var(--ink-700); font-size:.95rem}
.visit-actions{display:flex; flex-wrap:wrap; gap:10px; margin-top:18px}

/* CONTACT -------------------------------------------------------------- */
.contact-list{list-style:none; padding:0; margin:24px 0 0; display:grid; gap:18px}
.contact-list li{display:flex; gap:14px; align-items:flex-start}
.contact-list svg{color:var(--teal-700); flex:0 0 auto; margin-top:3px}
.contact-list strong{display:block; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; color:var(--teal-700); margin-bottom:2px}
.contact-list a{color:var(--ink-900); font-weight:500}
.contact-list a:hover{color:var(--teal-700)}

.contact-form{
  background:white; border:1px solid var(--line); border-radius:var(--r-lg);
  padding:32px; display:grid; gap:14px; box-shadow:var(--shadow-2);
}
.contact-form h3{font-family:var(--font-serif); margin:0 0 8px}
.contact-form label{display:flex; flex-direction:column; gap:6px; font-weight:500; font-size:.9rem; color:var(--ink-700)}
.contact-form input, .contact-form select, .contact-form textarea{
  font:inherit;
  padding:12px 14px; border-radius:var(--r-sm);
  border:1px solid var(--line); background:var(--sand-50);
  color:var(--ink-900);
  transition:border-color .18s var(--ease-out), background .18s var(--ease-out), box-shadow .18s var(--ease-out);
}
.contact-form input:focus, .contact-form select:focus, .contact-form textarea:focus{
  outline:none; border-color:var(--teal-600); background:white;
  box-shadow:0 0 0 4px var(--teal-50);
}
.contact-form textarea{resize:vertical}
.form-hint{font-size:.82rem; color:var(--ink-500); margin:0}

/* FOOTER --------------------------------------------------------------- */
.site-footer{
  background:var(--ink-900); color:rgba(255,255,255,.78);
  padding:60px 0 30px; margin-top:40px;
}
.site-footer .brand-name{color:white}
.site-footer .brand-tag{color:rgba(255,255,255,.5)}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px}
.site-footer h4{color:white; font-family:var(--font-en); font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; margin:0 0 14px}
.site-footer p, .site-footer li{font-size:.92rem}
.site-footer a{color:rgba(255,255,255,.85)}
.site-footer a:hover{color:white}
.footer-links{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.footer-bottom{margin-top:36px; padding-top:20px; border-top:1px solid rgba(255,255,255,.12); font-size:.82rem; color:rgba(255,255,255,.55)}

/* TOAST ---------------------------------------------------------------- */
.toast{
  position:fixed; left:50%; bottom:24px; transform:translateX(-50%) translateY(20px);
  background:var(--ink-900); color:white;
  padding:14px 18px; border-radius:var(--r-md);
  box-shadow:var(--shadow-3);
  opacity:0; pointer-events:none;
  transition:opacity .22s var(--ease-out), transform .22s var(--ease-out);
  z-index:90; font-size:.92rem; font-weight:500;
}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}

/* REVEAL --------------------------------------------------------------- */
@media (prefers-reduced-motion: no-preference){
  .reveal{opacity:0; transform:translateY(18px); transition:opacity .55s var(--ease-out), transform .55s var(--ease-out)}
  .reveal.in{opacity:1; transform:translateY(0)}
}

/* RESPONSIVE ----------------------------------------------------------- */
@media (max-width: 980px){
  .visit-grid{grid-template-columns:1fr}
  .map-wrap{min-height:340px}
  .map-wrap iframe{height:340px}
  .hero{padding:60px 0 50px}
  .hero-grid{grid-template-columns:1fr; gap:30px}
  .hero-card{order:-1; align-self:start}
  .two-col{grid-template-columns:1fr; gap:40px}
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .docs-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr; gap:30px}
  .trust-grid{grid-template-columns:repeat(2,1fr); gap:30px}
  .trust-grid strong{font-size:1.6rem}
}
@media (max-width: 720px){
  .primary-nav{
    position:fixed; inset:70px 0 0 0;
    background:var(--sand-50);
    flex-direction:column; gap:0; padding:30px 22px;
    transform:translateY(-110%); transition:transform .3s var(--ease-out);
    border-top:1px solid var(--line);
    z-index:48;
  }
  .primary-nav.open{transform:translateY(0)}
  .primary-nav a{padding:16px 0; border-bottom:1px solid var(--line); font-size:1.1rem}
  .menu-toggle{display:block}
  .cta{display:none}
  .section{padding:60px 0}
  .services-grid{grid-template-columns:1fr}
  .docs-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr}
  .brand-tag{display:none}
  h1{font-size:2.1rem}
  .lede{font-size:1rem}
  .art-stack{min-height:340px}
}
