/* ============================================================
   IRIS THEME — Global CSS
   ============================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

/* === BREADCRUMB === */
.iris-bc{max-width:1200px;margin:0 auto;padding:16px 24px;font-size:13px;color:var(--muted,#888)}
.iris-bc-list{list-style:none;display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin:0;padding:0}
.iris-bc-item{display:inline-flex;align-items:center;gap:6px}
.iris-bc-item a{color:var(--orchid,#8a4d9d);text-decoration:none;transition:color .2s}
.iris-bc-item a:hover{color:var(--plum,#6b3a7d)}
.iris-bc-item span[aria-current]{color:var(--plum,#6b3a7d);font-weight:500}
.iris-bc-sep{color:var(--muted,#888);font-size:14px;line-height:1}
@media (max-width:600px){
  .iris-bc{padding:12px 16px;font-size:12px}
}

:root{
  --plum:#6B3A7D;--orchid:#9B6BB0;--lavender:#C4A1D4;--blush:#E8B4C8;
  --rose:#F2C6D0;--petal:#FAE0E4;--cream:#FFF5F7;--snow:#FFFAFC;
  --deep:#2D1B3D;--text:#4A3258;--muted:#8B7399;
  --hd:'Playfair Display','Noto Serif TC',serif;
  --bd:'Outfit','Noto Serif TC',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --ease2:cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{font-family:var(--bd);color:var(--text);background:var(--snow);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
button{border:none;cursor:pointer;font-family:inherit;background:none}
img{display:block;max-width:100%}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-thumb{background:var(--lavender);border-radius:3px}

/* === NAV === */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:68px;display:flex;align-items:center;justify-content:space-between;padding:0 48px;background:rgba(245,240,250,.95);backdrop-filter:blur(20px);border-bottom:1px solid rgba(180,140,200,.15);transition:all .4s var(--ease2)}
.nav.scrolled{background:rgba(240,235,248,.92);backdrop-filter:blur(28px);box-shadow:0 4px 30px rgba(107,58,125,.06)}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none}
.nav-logo{font-family:var(--hd);font-size:26px;font-weight:600;color:var(--plum);letter-spacing:2px}
.nav-sub{font-size:10px;letter-spacing:2.5px;color:var(--muted);text-transform:uppercase;margin-top:-2px}
.nav-mid{display:flex;gap:32px}
.nav-mid a{font-size:13.5px;font-weight:600;color:var(--deep);transition:color .3s;letter-spacing:.3px;position:relative}
.nav-mid a::after{content:'';position:absolute;bottom:-4px;left:0;right:0;height:2px;background:var(--orchid);border-radius:1px;transform:scaleX(0);transition:transform .3s var(--ease2)}
.nav-mid a:hover,.nav-mid a.active{color:var(--plum)}
.nav-mid a:hover::after,.nav-mid a.active::after{transform:scaleX(1)}
.nav-r{display:flex;align-items:center;gap:14px}
.lang-wrap{display:flex;border-radius:50px;overflow:hidden;background:rgba(155,107,176,.05);border:1px solid rgba(155,107,176,.08)}
.lang-btn{padding:5px 14px;font-size:11px;font-weight:500;color:var(--muted);transition:all .3s;cursor:pointer;background:none;border:none;font-family:var(--bd)}
.lang-btn.on{background:var(--orchid);color:#fff}
.nav-book{padding:8px 22px;border-radius:50px;font-size:12px;font-weight:600;background:var(--plum);color:#fff;transition:all .3s var(--ease2);cursor:pointer}
.nav-book:hover{background:var(--orchid);transform:translateY(-1px)}
.mob-menu{display:none;font-size:22px;color:var(--plum)}

/* === MARQUEE === */
.mq{padding:14px 0;overflow:hidden;background:linear-gradient(90deg,var(--plum),var(--orchid),var(--blush),var(--orchid),var(--plum));background-size:200%;animation:mqBg 6s linear infinite}
@keyframes mqBg{0%{background-position:0%}100%{background-position:200%}}
.mq-inner{display:flex;animation:mqScroll 28s linear infinite;white-space:nowrap}
@keyframes mqScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.mq-i{padding:0 30px;font-size:12px;font-weight:500;color:rgba(255,255,255,.88);letter-spacing:1px;display:inline-flex;align-items:center;gap:10px}
.mq-dot{width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,.35)}

/* === SECTION BASE === */
.sec{padding:96px 48px;position:relative}
.sec-tag{font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--orchid);margin-bottom:10px}
.sec-h{font-family:var(--hd);font-size:40px;font-weight:600;color:var(--deep);line-height:1.15;margin-bottom:12px}
.sec-p{font-size:14px;line-height:1.7;color:var(--muted);max-width:480px;margin-bottom:40px}

/* === HERO === */
.hero{height:88vh;max-height:780px;display:flex;align-items:stretch;position:relative;overflow:hidden;background:var(--snow)}
.hero-left{flex:0 0 48%;display:flex;flex-direction:column;justify-content:center;padding:0 56px;position:relative;z-index:2}
.hero-right{flex:1;position:relative;overflow:hidden}
.hero-right img{width:100%;height:100%;object-fit:cover;object-position:center 20%;display:block}
.hero-right::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,var(--snow) 0%,transparent 30%),linear-gradient(180deg,transparent 60%,rgba(45,27,61,.12) 100%)}
.hero-pill{display:inline-flex;align-items:center;gap:8px;padding:7px 18px;border-radius:50px;background:rgba(255,255,255,.65);backdrop-filter:blur(12px);border:1px solid rgba(200,160,212,.15);font-size:12px;font-weight:500;color:var(--orchid);margin-bottom:18px;width:fit-content}
.hero-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--orchid);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}
.hero h1{font-family:var(--hd);font-size:44px;font-weight:600;line-height:1.15;color:var(--deep);margin-bottom:12px}
.hero h1 i{font-style:italic;background:linear-gradient(135deg,var(--orchid),var(--blush));-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.hero-p{font-size:14px;line-height:1.8;color:var(--muted);margin-bottom:24px;max-width:360px}
.hero-btns{display:flex;gap:12px;margin-bottom:28px;flex-wrap:wrap}
.btn-p{padding:13px 32px;border-radius:50px;font-size:13px;font-weight:600;background:linear-gradient(135deg,var(--plum),var(--orchid));color:#fff;box-shadow:0 8px 28px rgba(107,58,125,.22);transition:all .4s var(--ease);cursor:pointer;border:none;font-family:var(--bd)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(107,58,125,.32)}
.btn-o{padding:13px 32px;border-radius:50px;font-size:13px;font-weight:500;background:rgba(255,255,255,.55);backdrop-filter:blur(10px);border:1.5px solid rgba(200,160,212,.25);color:var(--plum);transition:all .3s var(--ease);cursor:pointer;font-family:var(--bd)}
.btn-o:hover{background:rgba(155,107,176,.08);border-color:var(--lavender)}
.hero-nums{display:flex;gap:24px;flex-wrap:wrap}
.hero-n{position:relative;padding-left:12px}
.hero-n::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:2px;background:linear-gradient(180deg,var(--orchid),var(--blush));border-radius:1px}
.hero-nv{font-family:var(--hd);font-size:22px;font-weight:600;color:var(--plum)}
.hero-nl{font-size:10px;color:var(--muted);margin-top:1px;letter-spacing:.5px}

/* === TREATMENT CARDS === */
.treat-sec{background:var(--cream)}
.treat-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:36px;flex-wrap:wrap;gap:16px}
.treat-filters{display:flex;gap:6px;flex-wrap:wrap}
.tf{padding:6px 16px;border-radius:50px;font-size:12px;font-weight:500;color:var(--muted);background:rgba(255,255,255,.6);border:1px solid rgba(200,160,212,.12);transition:all .3s;cursor:pointer;font-family:var(--bd)}
.tf.on,.tf:hover{background:var(--orchid);color:#fff;border-color:var(--orchid)}
.treat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tc{background:#fff;border-radius:18px;overflow:hidden;border:1px solid rgba(200,160,212,.08);transition:all .5s var(--ease);cursor:pointer;text-decoration:none;display:block;color:inherit}
.tc:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(107,58,125,.08)}
.tc-img{height:200px;position:relative;overflow:hidden}
.tc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.tc:hover .tc-img img{transform:scale(1.05)}
.tc-badge{position:absolute;top:10px;left:10px;padding:4px 10px;border-radius:12px;font-size:10px;font-weight:600;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);color:var(--plum)}
.tc-body{padding:16px 18px}
.tc-cat{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--orchid);margin-bottom:6px}
.tc-name{font-family:var(--hd);font-size:17px;font-weight:600;color:var(--deep);margin-bottom:6px;line-height:1.3}
.tc-desc{font-size:12px;line-height:1.6;color:var(--muted);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tc-foot{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid rgba(200,160,212,.08)}
.tc-price{font-family:var(--hd);font-size:15px;font-weight:600;color:var(--plum)}
.tc-price small{font-weight:400;color:var(--muted);font-family:var(--bd);font-size:11px}
.tc-rate{font-size:11px;color:var(--orchid);display:flex;align-items:center;gap:3px}

/* === DOCTOR CARDS === */
.doc-sec{background:var(--snow)}
.doc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.dc{background:#fff;border-radius:18px;overflow:hidden;border:1px solid rgba(200,160,212,.08);transition:all .5s var(--ease);cursor:pointer;text-decoration:none;display:block;color:inherit}
.dc:hover{transform:translateY(-5px);box-shadow:0 14px 40px rgba(107,58,125,.07)}
.dc-img{height:220px;position:relative;overflow:hidden}
.dc-img img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .6s var(--ease)}
.dc:hover .dc-img img{transform:scale(1.04)}
.dc-vbadge{position:absolute;top:10px;left:10px;padding:3px 10px;border-radius:10px;font-size:10px;font-weight:600;background:rgba(255,255,255,.85);backdrop-filter:blur(6px);color:var(--orchid)}
.dc-body{padding:16px 18px}
.dc-name{font-family:var(--hd);font-size:18px;font-weight:600;color:var(--deep);margin-bottom:4px}
.dc-title{font-size:11px;color:var(--muted);line-height:1.5;margin-bottom:10px}
.dc-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:12px}
.dc-tag{padding:3px 8px;border-radius:8px;font-size:10px;font-weight:500;background:rgba(155,107,176,.07);color:var(--orchid)}
.dc-row{display:flex;gap:16px;padding-top:10px;border-top:1px solid rgba(200,160,212,.06)}
.dc-rv{font-family:var(--hd);font-size:14px;font-weight:600;color:var(--plum)}
.dc-rl{font-size:10px;color:var(--muted)}
.dc-actions{display:flex;gap:8px;padding-top:12px}
.dc-btn-consult{display:inline-flex;align-items:center;justify-content:center;flex:1;padding:8px 0;border-radius:50px;font-size:11px;font-weight:600;background:linear-gradient(135deg,var(--blush),var(--lavender));color:var(--plum);transition:all .3s var(--ease);cursor:pointer;font-family:var(--bd);border:none;text-decoration:none}
.dc-btn-consult:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(107,58,125,.2)}
.dc-btn-detail{display:inline-flex;align-items:center;justify-content:center;flex:1;padding:8px 0;border-radius:50px;font-size:11px;font-weight:600;background:transparent;color:var(--orchid);border:1.5px solid var(--lavender);transition:all .3s var(--ease);cursor:pointer;font-family:var(--bd);text-decoration:none}
.dc-btn-detail:hover{background:var(--petal);border-color:var(--orchid)}

/* === STORY BANNER === */
.story{display:flex;align-items:stretch;background:var(--deep);overflow:hidden;height:220px}
.story-bg{width:320px;flex-shrink:0;position:relative;overflow:hidden}
.story-bg img{width:100%;height:100%;object-fit:cover}
.story-txt{flex:1;display:flex;flex-direction:column;justify-content:center;padding:28px 40px}
.story-lbl{font-size:10px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--blush);margin-bottom:10px}
.story-q{font-family:var(--hd);font-size:18px;font-style:italic;font-weight:400;line-height:1.6;color:rgba(255,255,255,.9);margin-bottom:14px}
.story-who{font-size:12px;font-weight:600;color:var(--rose)}
.story-detail{font-size:11px;color:rgba(255,255,255,.45);margin-top:2px}

/* === CLINIC CARDS === */
.cli-sec{background:var(--cream)}
.cli-filters{display:flex;gap:6px;margin-bottom:28px;flex-wrap:wrap}
.cfl{padding:6px 16px;border-radius:50px;font-size:12px;font-weight:500;color:var(--muted);background:rgba(255,255,255,.6);border:1px solid rgba(200,160,212,.12);transition:all .3s;cursor:pointer;font-family:var(--bd);border-style:solid}
.cfl.on,.cfl:hover{background:var(--orchid);color:#fff;border-color:var(--orchid)}
.cli-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.cc{display:flex;background:#fff;border-radius:18px;overflow:hidden;border:1px solid rgba(200,160,212,.08);transition:all .5s var(--ease);height:200px;text-decoration:none;color:inherit}
.cc:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(107,58,125,.07)}
.cc-img{width:240px;flex-shrink:0;position:relative;overflow:hidden}
.cc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.cc:hover .cc-img img{transform:scale(1.04)}
.cc-badges{position:absolute;top:10px;left:10px;display:flex;gap:4px;z-index:2;flex-wrap:wrap}
.cc-bdg{padding:3px 8px;border-radius:8px;font-size:9px;font-weight:600;backdrop-filter:blur(6px)}
.cc-bdg.v{background:rgba(255,255,255,.85);color:var(--orchid)}
.cc-bdg.a{background:rgba(107,58,125,.75);color:#fff}
.cc-body{flex:1;padding:18px 20px;display:flex;flex-direction:column;justify-content:center}
.cc-name{font-family:var(--hd);font-size:18px;font-weight:600;color:var(--deep);margin-bottom:2px}
.cc-en{font-size:11px;color:var(--muted);margin-bottom:8px}
.cc-addr{font-size:11px;color:var(--muted);margin-bottom:8px}
.cc-tags{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:10px}
.cc-tag{padding:2px 8px;border-radius:8px;font-size:10px;font-weight:500;background:rgba(155,107,176,.06);color:var(--orchid)}
.cc-foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;gap:8px}
.cc-rate{font-size:12px;font-weight:600;color:var(--plum);display:flex;align-items:center;gap:3px}
.cc-btn{padding:6px 16px;border-radius:50px;font-size:11px;font-weight:600;background:var(--plum);color:#fff;transition:all .3s var(--ease);cursor:pointer;border:none;font-family:var(--bd)}
.cc-btn:hover{background:var(--orchid)}
.cc-btn-consult{padding:6px 16px;border-radius:50px;font-size:11px;font-weight:600;background:linear-gradient(135deg,var(--blush),var(--lavender));color:var(--plum);border:none;cursor:pointer;transition:all .3s var(--ease);font-family:var(--bd)}
.cc-btn-consult:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(107,58,125,.2)}

/* === REVIEWS === */
.rev-sec{background:var(--snow);overflow:hidden}
.rev-track-wrap{position:relative;margin:0 -48px;padding:0 48px}
.rev-track{display:flex;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:8px 0 20px;scrollbar-width:none}
.rev-track::-webkit-scrollbar{display:none}
.rc{flex:0 0 340px;scroll-snap-align:start;background:#fff;border-radius:20px;overflow:hidden;border:1px solid rgba(200,160,212,.08);transition:all .4s var(--ease);cursor:pointer}
.rc:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(107,58,125,.08)}
.rc-top{background:linear-gradient(135deg,var(--petal),rgba(196,161,212,.15));padding:24px 24px 18px;position:relative}
.rc-top::after{content:'❝';position:absolute;top:12px;right:20px;font-size:48px;color:rgba(155,107,176,.1);font-family:serif;line-height:1}
.rc-stars{color:var(--orchid);font-size:11px;letter-spacing:2px;margin-bottom:10px}
.rc-text{font-size:13px;line-height:1.75;color:var(--text)}
.rc-bot{padding:16px 24px;display:flex;align-items:center;gap:10px}
.rc-ava{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--orchid),var(--blush));display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;font-weight:600;flex-shrink:0}
.rc-name{font-size:13px;font-weight:600;color:var(--deep)}
.rc-info{font-size:10px;color:var(--muted);margin-top:1px}
.rc-proj{margin-left:auto;padding:4px 10px;border-radius:8px;font-size:10px;font-weight:500;background:rgba(155,107,176,.06);color:var(--orchid);white-space:nowrap}

/* === FAQ === */
.faq-sec{background:var(--cream)}
.faq-lay{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.faq-left{position:sticky;top:100px}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid rgba(200,160,212,.1)}
.faq-q{display:flex;justify-content:space-between;align-items:center;width:100%;padding:18px 0;text-align:left;font-size:14px;font-weight:500;color:var(--deep);transition:color .3s;cursor:pointer;background:none;border:none;font-family:var(--bd)}
.faq-q:hover{color:var(--orchid)}
.faq-ic{font-size:16px;color:var(--orchid);transition:transform .3s var(--ease);flex-shrink:0;margin-left:10px}
.faq-item.open .faq-ic{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.open .faq-a{max-height:180px}
.faq-a p{font-size:13px;line-height:1.7;color:var(--muted);padding-bottom:16px}
.faq-contact{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;background:linear-gradient(135deg,var(--plum),var(--orchid));color:#fff;border-radius:50px;font-size:13px;font-weight:500;letter-spacing:.3px;transition:transform .3s,box-shadow .3s;cursor:pointer;border:none;font-family:var(--bd)}
.faq-contact:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(107,58,125,.3)}

/* === CTA SECTION === */
.cta-sec{padding:96px 48px;text-align:center;background:var(--deep);position:relative;overflow:hidden}
.cta-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 50% 70% at 50% 50%,rgba(155,107,176,.2),transparent)}
.cta-in{position:relative;z-index:2}
.cta-in .sec-h{color:#fff;margin-bottom:14px}
.cta-p{font-size:15px;color:rgba(255,255,255,.55);max-width:440px;margin:0 auto 32px;line-height:1.7}
.cta-big{display:inline-block;padding:16px 48px;border-radius:50px;background:linear-gradient(135deg,var(--orchid),var(--blush));color:#fff;font-size:15px;font-weight:600;transition:all .4s var(--ease);box-shadow:0 8px 28px rgba(155,107,176,.3);cursor:pointer;border:none;font-family:var(--bd)}
.cta-big:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(155,107,176,.45)}

/* === PAGE HEADER === */
.page-hdr{margin-top:68px;padding:72px 48px 52px;background:linear-gradient(135deg,var(--blush) 0%,var(--petal) 50%,var(--cream) 100%);text-align:center;position:relative;overflow:hidden}
.page-hdr::before{content:'';position:absolute;top:-50%;right:-10%;width:500px;height:500px;border-radius:50%;background:rgba(155,107,176,.04);pointer-events:none}
.page-hdr::after{content:'';position:absolute;bottom:-30%;left:-5%;width:350px;height:350px;border-radius:50%;background:rgba(155,107,176,.03);pointer-events:none}
.page-hdr .inner{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.page-hdr h1{font-family:var(--hd);font-size:42px;font-weight:600;color:var(--plum);margin-bottom:10px}
.page-hdr h1 em{font-style:italic;color:var(--orchid)}
.page-hdr p{font-size:15px;color:var(--orchid);max-width:560px;margin:0 auto;line-height:1.7;opacity:.85}

/* === FILTER BAR === */
.filter-bar{padding:24px 48px;background:var(--cream);border-bottom:1px solid rgba(200,160,212,.1);position:sticky;top:68px;z-index:50;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.cat-tabs{display:flex;gap:6px;flex-wrap:wrap}
.cat-tab{padding:7px 18px;border-radius:50px;font-size:12px;font-weight:500;color:var(--muted);background:rgba(255,255,255,.7);border:1px solid rgba(200,160,212,.12);transition:all .3s;cursor:pointer;font-family:var(--bd)}
.cat-tab.on,.cat-tab:hover{background:var(--orchid);color:#fff;border-color:var(--orchid)}
.search-box{display:flex;align-items:center;gap:8px;padding:7px 18px;border-radius:50px;background:#fff;border:1px solid rgba(200,160,212,.15);min-width:220px}
.search-box input{border:none;outline:none;font-family:var(--bd);font-size:13px;color:var(--text);background:transparent;width:100%}
.search-box input::placeholder{color:var(--lavender)}

/* === ARTICLE CARDS === */
.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:48px}
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1200px;margin:0 auto}
.art-card{background:#fff;border-radius:18px;overflow:hidden;border:1px solid rgba(200,160,212,.08);transition:all .5s var(--ease);cursor:pointer;text-decoration:none;display:block;color:inherit}
.art-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(107,58,125,.1)}
.art-thumb{height:160px;position:relative;overflow:hidden}
.art-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.art-card:hover .art-thumb img{transform:scale(1.05)}
.art-tag{position:absolute;top:10px;left:10px;padding:4px 12px;border-radius:12px;font-size:10px;font-weight:600;backdrop-filter:blur(6px)}
.art-tag.plum{background:rgba(107,58,125,.85);color:#fff}
.art-tag.green{background:rgba(37,211,102,.85);color:#fff}
.art-tag.blush{background:rgba(232,180,200,.92);color:var(--deep)}
.art-tag.rose{background:rgba(242,198,208,.92);color:var(--plum)}
.art-body{padding:18px 20px}
.art-title{font-family:var(--hd);font-size:17px;font-weight:600;color:var(--deep);margin-bottom:8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.art-excerpt{font-size:12.5px;line-height:1.7;color:var(--muted);margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.art-foot{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid rgba(200,160,212,.08)}
.art-author{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.art-ava{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--orchid),var(--blush));display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;font-weight:600}
.art-aname{font-size:11.5px;font-weight:600;color:var(--deep);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.art-date{font-size:10px;color:var(--muted);margin-top:1px}
.art-stats{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:8px}
.art-stat{font-size:10.5px;color:var(--muted);display:flex;align-items:center;gap:3px;white-space:nowrap}
.art-stat svg{width:12px;height:12px;stroke:var(--lavender);fill:none;stroke-width:2;flex-shrink:0}

/* Article pagination */
.art-pagination{display:flex;justify-content:center;gap:6px;padding:30px 48px 0;flex-wrap:wrap}
.art-pagination .page-numbers{min-width:36px;height:36px;border-radius:10px;font-size:13px;font-weight:500;color:var(--muted);background:#fff;border:1px solid rgba(200,160,212,.12);display:inline-flex;align-items:center;justify-content:center;padding:0 10px;transition:all .3s;cursor:pointer;text-decoration:none}
.art-pagination .page-numbers:hover{background:var(--petal);color:var(--plum);border-color:var(--lavender)}
.art-pagination .page-numbers.current{background:var(--orchid);color:#fff;border-color:var(--orchid)}
.art-pagination .page-numbers.dots{background:none;border:none;cursor:default}
.art-pagination .page-numbers.dots:hover{background:none;color:var(--muted)}

/* === ARTICLE SINGLE === */
/* === SINGLE ARTICLE — clean blog typography === */
.reading-bar{position:fixed;top:68px;left:0;height:2px;background:var(--orchid);z-index:999;width:0;transition:width .05s}

.article-header{max-width:720px;margin:0 auto;padding:120px 24px 40px}
.article-header .breadcrumb{font-size:13px;color:var(--muted);margin-bottom:20px}
.article-header .breadcrumb a{color:var(--orchid)}
.article-header .article-cat{display:inline-block;font-size:12px;color:var(--orchid);font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:14px;padding:0;background:none}
.article-header .article-title{font-family:var(--hd);font-size:36px;color:var(--deep);line-height:1.35;margin-bottom:20px;font-weight:700}
.article-header .article-meta{display:flex;align-items:center;gap:14px;font-size:13.5px;color:var(--muted);flex-wrap:wrap;padding-bottom:24px;border-bottom:1px solid #f0e6ef}
.article-header .meta-sep{color:var(--lavender)}
.author-chip{display:flex;align-items:center;gap:8px}
.author-chip .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--orchid),var(--blush));display:flex;align-items:center;justify-content:center;font-size:13px;color:#fff;font-weight:600;flex-shrink:0}
.author-chip .name{color:var(--deep);font-weight:600}

.cover-img{max-width:720px;margin:32px auto;padding:0 24px}
.cover-img img{width:100%;border-radius:10px;aspect-ratio:16/9;object-fit:cover;display:block}

.article-content{max-width:720px;margin:0 auto;padding:0 24px 60px;font-size:16.5px;line-height:2;color:#3d2a4a}
.article-content h2{font-family:var(--hd);font-size:26px;color:var(--deep);margin:52px 0 18px;font-weight:700;line-height:1.35;border:none;padding:0}
.article-content h3{font-size:19px;color:var(--plum);margin:36px 0 12px;font-weight:600}
.article-content p{margin-bottom:22px}
.article-content ul,.article-content ol{margin:12px 0 24px 22px}
.article-content li{margin-bottom:8px;line-height:1.85}
.article-content strong{color:var(--deep)}
.article-content blockquote{margin:28px 0;padding:18px 24px;border-left:3px solid var(--lavender);background:#faf6fc;border-radius:0 8px 8px 0;font-style:italic;color:var(--plum);line-height:1.8}
.article-content img{width:100%;border-radius:8px;margin:24px 0}
.article-content hr{border:none;height:1px;background:#ece3ed;margin:48px 0}

.article-content .callout{margin:28px 0;padding:18px 22px;border-radius:10px;background:var(--cream);border:1px solid var(--rose);font-size:15px;line-height:1.75}
.article-content .callout .callout-label{font-weight:700;color:var(--plum);margin-bottom:6px}
.article-content .callout p{margin-bottom:6px}
.article-content .checklist{list-style:none;margin-left:0!important}
.article-content .checklist li{padding-left:28px;position:relative}
.article-content .checklist li::before{content:'☑';position:absolute;left:0;color:var(--orchid)}

.article-tags{max-width:720px;margin:0 auto;padding:0 24px 32px;display:flex;gap:8px;flex-wrap:wrap}
.article-tags .tag{background:#f5eef8;color:var(--plum);padding:5px 14px;border-radius:20px;font-size:12.5px;font-weight:500;text-decoration:none;transition:background .2s}
.article-tags .tag:hover{background:var(--petal)}

.section-divider{max-width:720px;margin:0 auto;padding:0 24px}
.section-divider hr{border:none;height:1px;background:#ece3ed}

.author-box{max-width:720px;margin:32px auto 48px;padding:0 24px}
.author-box-inner{display:flex;gap:18px;align-items:flex-start;padding:24px;border:1px solid #ece3ed;border-radius:12px;background:#fff}
.author-box .ab-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--orchid),var(--blush));display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;font-weight:600;flex-shrink:0}
.author-box h4{color:var(--deep);font-size:15.5px;margin-bottom:4px;font-weight:600}
.author-box p{font-size:13.5px;color:var(--muted);line-height:1.6;margin:0}

.related{max-width:720px;margin:40px auto 60px;padding:0 24px}
.related h3{font-size:18px;color:var(--deep);margin-bottom:20px;font-weight:700;font-family:var(--hd)}
.related-list{display:flex;flex-direction:column;gap:8px}
.related-item{display:flex;gap:16px;padding:14px 0;border-bottom:1px solid #f5eef8;text-decoration:none;color:inherit;transition:background .2s,padding .2s,margin .2s;border-radius:0}
.related-item:hover{background:#faf6fc;margin:0 -8px;padding:14px 8px;border-radius:8px;border-bottom-color:transparent}
.related-item:last-child{border-bottom:none}
.related-item img{width:120px;height:80px;object-fit:cover;border-radius:8px;flex-shrink:0;display:block}
.related-item .ri-body{flex:1;min-width:0}
.related-item .ri-cat{font-size:11px;color:var(--orchid);font-weight:600;margin-bottom:4px;letter-spacing:.5px}
.related-item .ri-title{font-size:15px;color:var(--deep);font-weight:600;line-height:1.4;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.related-item .ri-meta{font-size:12px;color:var(--muted)}

.share-bar{position:fixed;left:max(calc(50% - 420px),24px);top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:10px;z-index:100}
.share-btn{width:42px;height:42px;border-radius:50%;background:#f5eef8;display:flex;align-items:center;justify-content:center;font-size:16px;cursor:pointer;border:none;color:var(--plum);transition:background .2s,transform .2s}
.share-btn:hover{background:var(--lavender);color:#fff;transform:scale(1.1)}

.back-top{position:fixed;bottom:32px;right:32px;width:44px;height:44px;border-radius:50%;background:var(--orchid);color:#fff;display:none;align-items:center;justify-content:center;font-size:18px;cursor:pointer;border:none;box-shadow:0 4px 16px rgba(107,58,125,.2);transition:transform .2s;z-index:100}
.back-top.show{display:flex}
.back-top:hover{transform:scale(1.1)}

@media(max-width:1100px){
  .share-bar{display:none}
}
@media(max-width:768px){
  .article-header{padding:100px 20px 32px}
  .article-header .article-title{font-size:26px}
  .article-content,.cover-img,.article-tags,.author-box,.related,.section-divider{padding-left:20px;padding-right:20px}
  .related-item img{width:90px;height:60px}
  .back-top{bottom:20px;right:20px}
}
.author-ava{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,var(--orchid),var(--blush));display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;flex-shrink:0}
.author-name{font-family:var(--hd);font-size:16px;font-weight:600;color:var(--deep);margin-bottom:4px}
.author-bio{font-size:13px;color:var(--muted);line-height:1.6}

/* === FOOTER === */
.foot{background:var(--deep);color:rgba(255,255,255,.45);padding:0 48px 28px;border-top:1px solid rgba(255,255,255,.05)}
.foot-in{display:flex;justify-content:space-between;align-items:center;padding-top:20px;flex-wrap:wrap;gap:16px}
.foot-logo{font-family:var(--hd);font-size:16px;color:rgba(255,255,255,.7);letter-spacing:1px}
.foot-links{display:flex;gap:20px;flex-wrap:wrap}
.foot-links a{font-size:11px;color:rgba(255,255,255,.35);transition:color .3s}
.foot-links a:hover{color:var(--blush)}
.foot-copy{font-size:10px}

/* === MODAL === */
.modal-bg{position:fixed;inset:0;z-index:9999;background:rgba(45,27,61,.4);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;opacity:0;transition:opacity .3s}
.modal-bg.show{display:flex;opacity:1}
.modal-box{background:#fff;border-radius:22px;width:380px;max-width:92vw;padding:32px;position:relative;box-shadow:0 24px 64px rgba(45,27,61,.18);transform:translateY(16px);transition:transform .3s var(--ease)}
.modal-bg.show .modal-box{transform:translateY(0)}
.modal-x{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:rgba(200,160,212,.08);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--muted);transition:all .3s;cursor:pointer;border:none;font-family:var(--bd)}
.modal-x:hover{background:rgba(200,160,212,.16);color:var(--plum)}
.modal-h{font-family:var(--hd);font-size:22px;font-weight:600;color:var(--deep);text-align:center;margin-bottom:4px}
.modal-sub{text-align:center;font-size:12px;color:var(--muted);margin-bottom:20px}
.ch-list{display:flex;flex-direction:column;gap:8px}
.ch{display:flex;align-items:center;gap:10px;padding:11px 16px;border-radius:12px;font-size:13px;font-weight:600;color:#fff;transition:all .3s var(--ease);text-decoration:none}
.ch:hover{transform:translateX(4px);box-shadow:0 4px 14px rgba(0,0,0,.1)}
.ch .ic{font-size:18px}
.ch .nt{margin-left:auto;font-size:10px;opacity:.7;font-weight:400}
.ch.wa{background:#25d366}
.ch.li{background:#06c755}
.ch.wc{background:#07c160}
.ch.kk{background:#fee500;color:#3c1e1e}

/* === TOAST === */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(70px);padding:10px 22px;border-radius:12px;background:var(--deep);color:#fff;font-size:12px;font-weight:500;box-shadow:0 6px 20px rgba(45,27,61,.18);z-index:10000;transition:transform .4s var(--ease);white-space:nowrap}
.toast.show{transform:translateX(-50%) translateY(0)}

/* === SCROLL REVEAL === */
.rv{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.rv.vis{opacity:1;transform:translateY(0)}

/* === RESPONSIVE === */
@media(max-width:1100px){
  .hero{flex-direction:column;height:auto;max-height:none}
  .hero-left{flex:none;padding:100px 40px 40px;text-align:center}
  .hero-pill,.hero-p{margin-left:auto;margin-right:auto}
  .hero-btns,.hero-nums{justify-content:center}
  .hero-right{height:300px;width:100%}
  .treat-grid,.articles-grid,.art-grid{grid-template-columns:repeat(2,1fr)}
  .art-pagination{padding:24px 24px 0}
  .doc-grid{grid-template-columns:repeat(2,1fr)}
  .cli-grid{grid-template-columns:1fr}
  .cc{height:auto}
  .faq-lay{grid-template-columns:1fr;gap:28px}
  .faq-left{position:static}
  .story{height:auto}
  .story-bg{width:240px}
}
@media(max-width:768px){
  .nav{padding:0 20px}
  .nav-mid{display:none}
  .mob-menu{display:block}
  .hero-left{padding:80px 24px 32px}
  .hero h1{font-size:34px}
  .hero-right{height:220px}
  .sec{padding:64px 20px}
  .sec-h{font-size:30px}
  .treat-grid,.articles-grid,.doc-grid,.art-grid{grid-template-columns:1fr}
  .filter-bar{padding:16px 20px}
  .cc{flex-direction:column;height:auto}
  .cc-img{width:100%;height:180px}
  .story{flex-direction:column;height:auto}
  .story-bg{width:100%;height:160px}
  .cta-sec{padding:64px 20px}
  .foot-in{flex-direction:column;gap:12px;text-align:center}
}

/* === TREATMENT ARCHIVE – ZIGZAG ROWS === */
.treat-cat-tabs{max-width:1200px;margin:0 auto;padding:32px 48px 0;display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.cat-btn{padding:10px 24px;border-radius:50px;font-size:13px;font-weight:500;color:var(--muted);background:rgba(155,107,176,.06);border:1.5px solid rgba(155,107,176,.1);transition:all .3s var(--ease);cursor:pointer;font-family:var(--bd)}
.cat-btn:hover{border-color:var(--orchid);color:var(--orchid);background:rgba(155,107,176,.1)}
.cat-btn.on{background:var(--orchid);color:#fff;border-color:var(--orchid);box-shadow:0 4px 16px rgba(155,107,176,.25)}
.results-bar{max-width:1200px;margin:0 auto;padding:20px 48px 0;text-align:center}
.results-count{font-size:13px;color:var(--muted)}
.results-count span{font-weight:700;color:var(--orchid)}
.treat-list{max-width:1200px;margin:0 auto;padding:32px 48px 80px;display:flex;flex-direction:column;gap:36px}
.treat-row{display:flex;align-items:stretch;border-radius:20px;overflow:hidden;background:#fff;box-shadow:0 4px 24px rgba(107,58,125,.06);transition:opacity .6s var(--ease),transform .6s var(--ease),box-shadow .5s var(--ease);cursor:pointer;min-height:320px;text-decoration:none;color:inherit}
.treat-row:hover{box-shadow:0 16px 56px rgba(107,58,125,.14);transform:translateY(-4px)}
.treat-row.reverse{flex-direction:row-reverse}
.treat-img{flex:0 0 45%;position:relative;overflow:hidden;min-height:320px}
.treat-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.treat-row:hover .treat-img img{transform:scale(1.06)}
.treat-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(107,58,125,.15) 0%,rgba(45,27,61,.05) 100%);pointer-events:none}
.treat-img .pop-badge{position:absolute;top:16px;left:16px;z-index:2;padding:6px 14px;border-radius:50px;font-size:11px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--orchid),var(--plum));backdrop-filter:blur(8px);display:inline-flex;align-items:center;gap:4px}
.treat-row.reverse .treat-img .pop-badge{left:auto;right:16px}
.treat-body{flex:1;padding:36px 40px;display:flex;flex-direction:column;justify-content:center}
.treat-body .treat-cat{display:inline-block;padding:4px 14px;border-radius:50px;font-size:11px;font-weight:600;background:var(--petal);color:var(--plum);margin-bottom:12px;width:fit-content}
.treat-body .treat-name{font-family:var(--hd);font-size:26px;font-weight:600;color:var(--deep);margin-bottom:16px;line-height:1.3}
.treat-body .treat-desc{font-size:13.5px;color:var(--muted);line-height:1.7;margin-bottom:20px}
.treat-meta{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:20px}
.meta-item{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text)}
.meta-icon{width:32px;height:32px;border-radius:10px;background:var(--petal);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.meta-label{font-size:10px;color:var(--muted);display:block;line-height:1.4}
.meta-val{font-weight:600;color:var(--deep);font-size:13px}
.treat-price{display:flex;align-items:baseline;gap:8px;margin-bottom:20px}
.price-label{font-size:11px;color:var(--muted)}
.price-val{font-family:var(--hd);font-size:22px;font-weight:600;color:var(--plum)}
.price-hkd{font-size:13px;color:var(--orchid);font-weight:500}
a.treat-row .treat-cta{display:inline-flex;align-items:center;gap:8px;padding:12px 28px;border-radius:50px;font-size:13px;font-weight:600;background:linear-gradient(135deg,var(--orchid),var(--plum));color:#fff;transition:all .3s var(--ease);width:fit-content;pointer-events:none}
.no-results{text-align:center;padding:80px 20px}
.no-results .nr-emoji{font-size:48px;margin-bottom:16px}
.no-results p{font-size:14px;color:var(--muted)}

/* === DOCTOR ARCHIVE === */
.doc-hdr-stats{display:flex;gap:32px;margin-top:24px;justify-content:center;flex-wrap:wrap}
.doc-hdr-stat{text-align:center}
.doc-hdr-stat .stat-num{font-family:var(--hd);font-size:28px;font-weight:700;color:var(--plum)}
.doc-hdr-stat .stat-lbl{font-size:11px;color:var(--orchid);margin-top:2px}
.doc-search-bar{margin-top:28px;display:flex;justify-content:center}
.doc-search-bar input{width:400px;max-width:90%;padding:14px 24px;border-radius:50px;border:1.5px solid rgba(155,107,176,.15);font-size:13px;font-family:var(--bd);color:var(--text);background:#fff;outline:none;transition:border-color .3s}
.doc-search-bar input:focus{border-color:var(--orchid)}
.doc-search-bar input::placeholder{color:var(--lavender)}
.doc-filter-bar{max-width:1000px;margin:0 auto;padding:28px 48px 0;display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.doc-fbtn{padding:7px 18px;border-radius:50px;font-size:12px;font-weight:500;color:var(--muted);background:rgba(155,107,176,.06);border:1px solid rgba(155,107,176,.1);transition:all .3s var(--ease);cursor:pointer;font-family:var(--bd)}
.doc-fbtn:hover{border-color:var(--orchid);color:var(--orchid)}
.doc-fbtn.on{background:var(--orchid);color:#fff;border-color:var(--orchid)}
.doc-list{max-width:1000px;margin:0 auto;padding:24px 48px 80px;display:flex;flex-direction:column;gap:20px}
.doc-card{display:flex;align-items:center;gap:24px;padding:24px 28px;border-radius:18px;background:#fff;border:1px solid rgba(155,107,176,.06);transition:all .4s var(--ease);position:relative;overflow:hidden;text-decoration:none;color:inherit}
.doc-card:nth-child(even){background:var(--cream)}
.doc-card:hover{box-shadow:0 12px 40px rgba(107,58,125,.1);transform:translateY(-2px);border-color:rgba(155,107,176,.12)}
.doc-avatar{flex-shrink:0;width:100px;height:100px;border-radius:50%;overflow:hidden;position:relative;box-shadow:0 4px 16px rgba(107,58,125,.12)}
.doc-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.doc-avatar::after{content:'';position:absolute;inset:-3px;border-radius:50%;border:2px solid rgba(155,107,176,.15);transition:border-color .3s;pointer-events:none}
.doc-card:hover .doc-avatar::after{border-color:var(--orchid)}
.doc-avatar-ph{width:100%;height:100%;background:linear-gradient(135deg,var(--orchid),var(--plum));display:flex;align-items:center;justify-content:center;font-family:var(--hd);font-size:32px;font-weight:600;color:#fff}
.doc-info{flex:1;min-width:0}
.doc-name{font-family:var(--hd);font-size:20px;font-weight:600;color:var(--deep);margin-bottom:2px}
.doc-name-en{font-size:12px;color:var(--muted);font-weight:300;margin-bottom:8px;letter-spacing:.3px}
.doc-cred{font-size:11.5px;color:var(--orchid);margin-bottom:10px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.doc-cred .dot{width:3px;height:3px;border-radius:50%;background:var(--lavender);display:inline-block;flex-shrink:0}
.doc-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.doc-tag{padding:4px 12px;border-radius:50px;font-size:10.5px;font-weight:500;background:var(--petal);color:var(--plum)}
.doc-tag.exp{background:rgba(155,107,176,.08);color:var(--orchid)}
.doc-hospital{font-size:12px;color:var(--muted);margin-bottom:6px}
.doc-hospital::before{content:'🏥 '}
.doc-stats{display:flex;gap:16px;margin-bottom:6px}
.doc-stat{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--muted)}
.doc-stat .val{font-weight:700;color:var(--orchid)}
.doc-stat .icon{font-size:12px}
.doc-quote{font-size:11.5px;color:var(--muted);font-style:italic;padding-left:10px;border-left:2px solid var(--lavender);line-height:1.5;margin-top:4px}
.doc-action{flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:10px}
.doc-rating{display:flex;flex-direction:column;align-items:center;gap:2px}
.doc-rating .score{font-family:var(--hd);font-size:22px;font-weight:600;color:var(--plum)}
.doc-rating .stars{color:#f5a623;font-size:11px;letter-spacing:1px}
.doc-rating .cnt{font-size:10px;color:var(--muted)}
a.doc-card .doc-book{padding:10px 28px;border-radius:50px;font-size:12px;font-weight:600;background:linear-gradient(135deg,var(--orchid),var(--plum));color:#fff;transition:all .3s var(--ease);white-space:nowrap;pointer-events:none}

/* TREATMENT ARCHIVE – RESPONSIVE */
@media(max-width:1024px){
  .treat-list{padding:24px 24px 80px}
  .treat-body{padding:28px 24px}
  .treat-body .treat-name{font-size:22px}
  .treat-cat-tabs,.results-bar{padding-left:24px;padding-right:24px}
}
@media(max-width:768px){
  .treat-list{padding:20px 20px 60px;gap:24px}
  .treat-row,.treat-row.reverse{flex-direction:column!important}
  .treat-img{flex:0 0 auto;min-height:220px;max-height:240px}
  .treat-body{padding:24px 20px}
  .treat-body .treat-name{font-size:20px}
  .treat-meta{gap:12px}
  .price-val{font-size:18px}
  .treat-img .pop-badge{left:12px!important;right:auto!important;top:12px}
  .treat-cat-tabs{padding:20px 20px 0;gap:8px}
  .cat-btn{padding:8px 16px;font-size:12px}
  .results-bar{padding-left:20px;padding-right:20px}
}
@media(max-width:768px){
  .doc-list{padding:20px 20px 60px}
  .doc-filter-bar{padding:20px 20px 0}
  .doc-card{flex-direction:column;text-align:center;gap:16px;padding:24px 20px}
  .doc-tags{justify-content:center}
  .doc-cred{justify-content:center}
  .doc-hospital{display:flex;justify-content:center;align-items:center}
  .doc-stats{justify-content:center}
  .doc-action{flex-direction:row;gap:16px}
  .doc-avatar{width:80px;height:80px}
  .doc-avatar-ph{font-size:26px}
}

/* ===========================================================
   CLINIC ARCHIVE (整形醫院列表頁) — clarc-* namespace
   =========================================================== */
.clarc-hdr{margin-top:68px;padding:72px 48px 52px;background:linear-gradient(135deg,var(--blush) 0%,var(--petal) 50%,var(--cream) 100%);position:relative;overflow:hidden}
.clarc-hdr::before{content:'';position:absolute;top:-50%;right:-10%;width:500px;height:500px;border-radius:50%;background:rgba(155,107,176,.04);pointer-events:none}
.clarc-hdr::after{content:'';position:absolute;bottom:-30%;left:-5%;width:350px;height:350px;border-radius:50%;background:rgba(155,107,176,.03);pointer-events:none}
.clarc-hdr-in{max-width:1200px;margin:0 auto;position:relative;z-index:1}
.clarc-hdr h1{font-family:var(--hd);font-size:42px;font-weight:600;color:var(--plum);margin-bottom:10px;line-height:1.2}
.clarc-hdr h1 i{font-style:italic;color:var(--orchid)}
.clarc-hdr p{font-size:15px;color:var(--orchid);max-width:560px;line-height:1.7;opacity:.85}
.clarc-stats{display:flex;gap:32px;margin-top:28px}
.clarc-stat{text-align:center}
.clarc-stat .n{font-family:var(--hd);font-size:32px;font-weight:600;color:var(--plum);line-height:1}
.clarc-stat .l{font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:.5px}

.clarc-filter{max-width:1200px;margin:0 auto;padding:28px 48px 0;display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.clarc-fgrp{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.clarc-flbl{font-size:12px;font-weight:600;color:var(--muted);margin-right:4px}
.clarc-fbtn{padding:7px 18px;border-radius:50px;font-size:12px;font-weight:500;color:var(--muted);background:rgba(155,107,176,.06);border:1px solid rgba(155,107,176,.1);transition:all .3s var(--ease);cursor:pointer;font-family:var(--bd)}
.clarc-fbtn:hover{border-color:var(--orchid);color:var(--orchid)}
.clarc-fbtn.on{background:var(--orchid);color:#fff;border-color:var(--orchid)}

.clarc-results{max-width:1200px;margin:0 auto;padding:20px 48px 0;font-size:13px;color:var(--muted)}
.clarc-results span{font-weight:700;color:var(--orchid)}

.clarc-grid{max-width:1200px;margin:0 auto;padding:24px 48px 80px;display:grid;grid-template-columns:repeat(2,1fr);gap:28px;perspective:1200px}

.clarc-card{position:relative;border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 4px 24px rgba(107,58,125,.06);transition:transform .5s var(--ease),box-shadow .5s var(--ease);transform-style:preserve-3d;cursor:pointer;display:block;color:inherit;text-decoration:none}
.clarc-card:hover{box-shadow:0 20px 60px rgba(107,58,125,.15)}

.clarc-img{height:220px;position:relative;overflow:hidden}
.clarc-img .bg,.clarc-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);display:block}
.clarc-card:hover .clarc-img .bg,.clarc-card:hover .clarc-img img{transform:scale(1.05)}
.clarc-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(45,27,61,.55) 100%);pointer-events:none}

.clarc-overlay{position:absolute;bottom:0;left:0;right:0;padding:18px 20px;z-index:2;color:#fff}
.clarc-overlay .c-area{display:inline-block;padding:3px 10px;border-radius:50px;font-size:10px;font-weight:600;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);margin-bottom:6px;letter-spacing:.5px}
.clarc-overlay h3{font-family:var(--hd);font-size:20px;font-weight:600;margin-bottom:2px;line-height:1.3}
.clarc-overlay .c-en{font-size:11px;opacity:.7;font-weight:300;letter-spacing:.3px}

.clarc-body{padding:18px 20px}
.clarc-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.clarc-tag{padding:4px 10px;border-radius:50px;font-size:10px;font-weight:500;background:var(--petal);color:var(--plum)}
.clarc-tag.type{background:rgba(155,107,176,.08);color:var(--orchid)}

.clarc-stars{display:flex;align-items:center;gap:4px;margin-bottom:12px}
.clarc-stars .stars{color:#f5a623;font-size:13px;letter-spacing:1px}
.clarc-stars .rating{font-size:12px;font-weight:600;color:var(--deep);margin-left:4px}
.clarc-stars .count{font-size:11px;color:var(--muted)}

.clarc-desc{font-size:12.5px;color:var(--muted);line-height:1.6;margin-bottom:14px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.clarc-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(155,107,176,.08);padding-top:12px}
.clarc-more{font-size:12px;font-weight:600;color:var(--orchid);display:flex;align-items:center;gap:4px;transition:gap .3s}
.clarc-card:hover .clarc-more{gap:8px}
.clarc-more::after{content:'→'}
.clarc-cert{display:flex;gap:4px}
.clarc-cert span{width:20px;height:20px;border-radius:50%;background:rgba(155,107,176,.08);display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--orchid)}

.clarc-noresult{text-align:center;padding:80px 20px;display:none}
.clarc-noresult .emoji{font-size:48px;margin-bottom:16px}
.clarc-noresult p{font-size:14px;color:var(--muted)}

@media(max-width:1024px){
  .clarc-grid{grid-template-columns:1fr;padding:24px 24px 80px}
  .clarc-filter,.clarc-results{padding-left:24px;padding-right:24px}
  .clarc-hdr{padding:64px 24px 44px}
}
@media(max-width:768px){
  .clarc-hdr{padding:56px 20px 36px}
  .clarc-hdr h1{font-size:28px}
  .clarc-hdr p{font-size:14px}
  .clarc-stats{gap:20px;margin-top:20px}
  .clarc-stat .n{font-size:24px}
  .clarc-grid{padding:20px 20px 60px;gap:20px}
  .clarc-filter{padding:20px 20px 0;gap:14px}
  .clarc-results{padding:16px 20px 0}
  .clarc-img{height:180px}
}

/* ===========================================================
   PROMOTION ARCHIVE (優惠活動)
   =========================================================== */

/* Urgency marquee */
.urgency-mq{overflow:hidden;background:linear-gradient(90deg,#ff4757,var(--plum),var(--orchid),#ff4757);background-size:300%;animation:urgBg 4s linear infinite;padding:10px 0;position:relative}
@keyframes urgBg{0%{background-position:0%}100%{background-position:300%}}
.urgency-inner{display:flex;animation:urgScroll 30s linear infinite;white-space:nowrap;width:max-content}
@keyframes urgScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.urgency-inner span{padding:0 40px;font-size:13px;font-weight:600;color:#fff;letter-spacing:1.5px;flex-shrink:0}

/* Promo section wrapper */
.promo-sec{padding:64px 48px;background:var(--cream);max-width:none;margin:0}
.promo-sec > *{max-width:1200px;margin-left:auto;margin-right:auto}

/* Featured deal */
.feat-deal{display:flex;background:#fff;border-radius:24px;overflow:hidden;border:1px solid rgba(200,160,212,.1);box-shadow:0 12px 48px rgba(107,58,125,.08);margin-bottom:48px;animation:featGlow 3s ease-in-out infinite alternate;text-decoration:none;color:inherit}
@keyframes featGlow{0%{box-shadow:0 12px 48px rgba(107,58,125,.08)}100%{box-shadow:0 12px 48px rgba(107,58,125,.18),0 0 0 2px rgba(155,107,176,.15)}}
.feat-img{flex:0 0 45%;position:relative;overflow:hidden;min-height:360px}
.feat-img img{width:100%;height:100%;object-fit:cover;display:block}
.feat-badge{position:absolute;top:20px;left:20px;padding:10px 20px;border-radius:14px;font-size:22px;font-weight:700;background:linear-gradient(135deg,#ff4757,#ff6b81);color:#fff;box-shadow:0 4px 16px rgba(255,71,87,.3);z-index:2;font-family:var(--hd)}
.feat-flash{position:absolute;top:20px;right:20px;padding:6px 14px;border-radius:10px;font-size:11px;font-weight:600;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);color:#ff4757;animation:flashPulse 1.5s ease-in-out infinite;z-index:2}
@keyframes flashPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}
.feat-body{flex:1;padding:36px 40px;display:flex;flex-direction:column;justify-content:center}
.feat-clinic{font-size:12px;font-weight:600;color:var(--orchid);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px}
.feat-name{font-family:var(--hd);font-size:28px;font-weight:600;color:var(--deep);margin-bottom:12px;line-height:1.3}
.feat-desc{font-size:14px;line-height:1.7;color:var(--muted);margin-bottom:20px}
.feat-prices{margin-bottom:16px}
.feat-orig{font-size:14px;color:var(--muted);text-decoration:line-through;margin-bottom:4px}
.feat-deal-price{font-size:32px;font-weight:700;color:var(--orchid);font-family:var(--hd);line-height:1.1}
.feat-save{display:inline-block;padding:4px 12px;border-radius:8px;font-size:12px;font-weight:600;background:rgba(255,71,87,.1);color:#ff4757;margin-bottom:20px}
.feat-countdown{display:flex;gap:8px;margin-bottom:20px}
.cd-box{background:var(--deep);color:#fff;border-radius:10px;padding:10px 14px;text-align:center;min-width:56px}
.cd-num{font-family:var(--hd);font-size:22px;font-weight:700;display:block;line-height:1}
.cd-lbl{font-size:9px;text-transform:uppercase;opacity:.6;letter-spacing:1px;margin-top:2px;display:block}
.feat-cta{display:inline-block;padding:14px 36px;border-radius:50px;font-size:14px;font-weight:600;background:linear-gradient(135deg,var(--plum),var(--orchid));color:#fff;box-shadow:0 8px 28px rgba(107,58,125,.22);transition:all .4s var(--ease);width:fit-content;text-decoration:none;font-family:var(--bd)}
.feat-cta:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(107,58,125,.32)}
.feat-spots{margin-top:10px;font-size:12px;color:#ff4757;font-weight:600}

/* Filter tabs (promotion) */
.filter-tabs{display:flex;gap:8px;justify-content:center;margin-bottom:32px;flex-wrap:wrap}
.ftab{padding:8px 20px;border-radius:50px;font-size:13px;font-weight:500;color:var(--muted);background:rgba(255,255,255,.7);border:1px solid rgba(200,160,212,.15);transition:all .3s var(--ease);cursor:pointer;font-family:var(--bd)}
.ftab.on,.ftab:hover{background:var(--orchid);color:#fff;border-color:var(--orchid)}

/* Deal cards grid */
.deal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.deal-grid.promo-home-grid{grid-template-columns:repeat(3,1fr);max-width:1200px;margin:0 auto}
@media(max-width:1024px){.deal-grid.promo-home-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.deal-grid.promo-home-grid{grid-template-columns:1fr}}
.deal-card{background:#fff;border-radius:20px;overflow:hidden;border:1px solid rgba(200,160,212,.08);transition:all .5s var(--ease);cursor:pointer;position:relative;text-decoration:none;color:inherit;display:block}
.deal-card:hover{transform:translateY(-6px);box-shadow:0 16px 48px rgba(107,58,125,.1)}
.deal-card.flash{animation:cardFlash 2s ease-in-out infinite alternate}
@keyframes cardFlash{0%{border-color:rgba(200,160,212,.08)}100%{border-color:rgba(155,107,176,.35);box-shadow:0 0 20px rgba(155,107,176,.12)}}
.deal-img{height:240px;position:relative;overflow:hidden}
.deal-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);display:block}
.deal-card:hover .deal-img img{transform:scale(1.05)}
.deal-ribbon{position:absolute;top:14px;right:-30px;padding:4px 40px;font-size:11px;font-weight:700;color:#fff;background:linear-gradient(135deg,#ff4757,#ff6b81);transform:rotate(45deg);box-shadow:0 2px 8px rgba(255,71,87,.3);z-index:2}
.deal-limited{position:absolute;bottom:10px;left:10px;padding:4px 10px;border-radius:8px;font-size:10px;font-weight:600;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);color:#ff4757;display:flex;align-items:center;gap:5px}
.deal-limited .dot{width:6px;height:6px;border-radius:50%;background:#ff4757;animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.deal-body{padding:18px 20px}
.deal-clinic{font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--orchid);margin-bottom:6px}
.deal-name{font-family:var(--hd);font-size:18px;font-weight:600;color:var(--deep);margin-bottom:8px;line-height:1.3}
.deal-price-row{display:flex;align-items:baseline;gap:10px;margin-bottom:6px;flex-wrap:wrap}
.deal-orig{font-size:13px;color:var(--muted);text-decoration:line-through}
.deal-now{font-size:22px;font-weight:700;color:var(--orchid);font-family:var(--hd)}
.deal-save-tag{display:inline-block;padding:3px 10px;border-radius:6px;font-size:10px;font-weight:600;background:rgba(255,71,87,.1);color:#ff4757;margin-bottom:10px}
.deal-validity{font-size:11px;color:var(--muted);margin-bottom:10px;display:flex;align-items:center;gap:4px}
.deal-countdown{display:flex;gap:5px;margin-bottom:12px}
.deal-cd-box{background:var(--deep);color:#fff;border-radius:6px;padding:4px 8px;text-align:center;min-width:36px}
.deal-cd-num{font-family:var(--hd);font-size:14px;font-weight:700;display:block;line-height:1}
.deal-cd-lbl{font-size:7px;text-transform:uppercase;opacity:.5;letter-spacing:.5px;display:block;margin-top:1px}
.deal-foot{display:flex;justify-content:flex-end;align-items:center;padding-top:12px;border-top:1px solid rgba(200,160,212,.06)}
.deal-btn{padding:8px 20px;border-radius:50px;font-size:12px;font-weight:600;background:var(--plum);color:#fff;transition:all .3s var(--ease);display:inline-block}
.deal-card:hover .deal-btn{background:var(--orchid)}

.deal-noresult{text-align:center;padding:60px 20px}
.deal-noresult .emoji{font-size:40px;margin-bottom:12px}
.deal-noresult p{font-size:14px;color:var(--muted)}

@media(max-width:1100px){
  .feat-deal{flex-direction:column}
  .feat-img{flex:none;min-height:260px}
}
@media(max-width:768px){
  .promo-sec{padding:40px 20px}
  .feat-img{min-height:220px}
  .feat-body{padding:24px 20px}
  .feat-name{font-size:22px}
  .feat-deal-price{font-size:26px}
  .feat-countdown{flex-wrap:wrap}
  .deal-grid{grid-template-columns:1fr;gap:18px}
  .deal-img{height:200px}
  .filter-tabs{gap:6px;margin-bottom:24px}
  .ftab{padding:6px 14px;font-size:12px}
  .urgency-inner{animation-duration:24s}
  .urgency-inner span{padding:0 24px;font-size:12px}
}
