/* ============ KLINIK WILUJENG — SHARED STYLES ============ */
:root{
  --teal:#1B8B82; --teal-dark:#14706a; --forest:#2E5A4B; --rose:#C98B95; --rose-soft:#f3e3e5;
  --cream:#F7F4EF; --cream-2:#efe9e0; --white:#fff; --ink:#2B2B2B; --ink-soft:#5c5a55;
  --line:rgba(46,90,75,.12); --wa:#25D366;
  --gold:#B6924A; --gold-soft:#d8b86a;
  --shadow-sm:0 1px 3px rgba(46,90,75,.06), 0 8px 24px rgba(46,90,75,.05);
  --shadow-md:0 4px 14px rgba(46,90,75,.08), 0 18px 50px rgba(46,90,75,.08);
  --r-sm:14px; --r-md:20px; --r-lg:28px; --maxw:1180px; --pad:clamp(20px,5vw,40px);
  --ff-serif:"Cormorant Garamond", Georgia, serif;
  --ff-sans:"Nunito Sans", system-ui, -apple-system, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth; scroll-padding-top:94px; -webkit-text-size-adjust:100%}
body{margin:0; background:var(--cream); color:var(--ink); font-family:var(--ff-sans); font-weight:400; font-size:17px; line-height:1.7; -webkit-font-smoothing:antialiased; overflow-x:hidden}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit; cursor:pointer}

h1,h2,h3,h4{font-family:var(--ff-serif); font-weight:600; line-height:1.1; margin:0; color:var(--forest); letter-spacing:.2px}
h2{font-size:clamp(2rem,4.4vw,3.1rem)}
h3{font-size:clamp(1.45rem,2.6vw,1.9rem)}
p{margin:0 0 1rem}
.eyebrow{font-family:var(--ff-sans); font-weight:700; font-size:.78rem; letter-spacing:.22em; text-transform:uppercase; color:var(--teal); margin:0 0 14px; display:inline-flex; align-items:center; gap:9px}
.eyebrow::before{content:""; width:26px; height:2px; background:linear-gradient(90deg,var(--gold),var(--rose)); display:inline-block; border-radius:2px}
.center .eyebrow{justify-content:center}
.lead{font-size:1.12rem; color:var(--ink-soft); max-width:62ch}

.wrap{max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad)}
section{padding:clamp(58px,8vw,104px) 0}
.section-head{max-width:720px; margin-bottom:clamp(34px,5vw,58px)}
.center{text-align:center} .center.section-head{margin-left:auto; margin-right:auto}
.bg-white{background:var(--white)} .bg-cream2{background:linear-gradient(180deg,var(--cream),#f1ece3)}

/* buttons */
.btn{display:inline-flex; align-items:center; gap:10px; font-family:var(--ff-sans); font-weight:700; font-size:1rem; padding:15px 28px; border-radius:999px; border:1.5px solid transparent; transition:transform .25s, box-shadow .25s, background .25s, color .25s; white-space:nowrap}
.btn svg{width:19px; height:19px}
.btn-primary{background:var(--teal); color:#fff; box-shadow:0 8px 22px rgba(27,139,130,.28)}
.btn-primary:hover{background:var(--teal-dark); transform:translateY(-2px); box-shadow:0 12px 28px rgba(27,139,130,.36)}
.btn-wa{background:var(--wa); color:#fff; box-shadow:0 8px 22px rgba(37,211,102,.28)}
.btn-wa:hover{filter:brightness(.95); transform:translateY(-2px)}
.btn-ghost{background:rgba(255,255,255,.14); color:#fff; border-color:rgba(255,255,255,.55); backdrop-filter:blur(4px)}
.btn-ghost:hover{background:#fff; color:var(--forest); border-color:#fff; transform:translateY(-2px)}
.btn-outline{background:transparent; color:var(--teal); border-color:var(--teal)}
.btn-outline:hover{background:var(--teal); color:#fff; transform:translateY(-2px)}

/* navbar */
.nav{position:sticky; top:0; z-index:60; background:rgba(247,244,239,.85); backdrop-filter:blur(14px); border-bottom:1px solid transparent; transition:box-shadow .3s, border-color .3s, background .3s}
.nav.scrolled{box-shadow:0 4px 24px rgba(46,90,75,.07); border-color:var(--line); background:rgba(247,244,239,.95)}
.nav-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; height:74px; max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad)}
.brand{display:flex; align-items:center; gap:12px}
.brand img{height:46px; width:auto}
.brand-txt{display:flex; flex-direction:column; line-height:1}
.brand-txt b{font-family:var(--ff-serif); font-size:1.3rem; color:var(--forest); font-weight:700; letter-spacing:.5px}
.brand-txt span{font-size:.64rem; letter-spacing:.12em; text-transform:uppercase; color:var(--teal); font-weight:700; margin-top:3px}
.nav-links{display:flex; align-items:center; gap:2px; list-style:none; margin:0; padding:0}
.nav-links a{font-weight:600; font-size:.94rem; color:var(--forest); padding:9px 12px; border-radius:10px; transition:background .2s, color .2s; position:relative}
.nav-links a:hover{background:rgba(27,139,130,.1); color:var(--teal)}
.nav-links a.active{color:var(--teal)}
.nav-links a.active::after{content:""; position:absolute; left:12px; right:12px; bottom:2px; height:2px; background:var(--rose); border-radius:2px}
.nav-cta{display:flex; align-items:center; gap:12px}
.nav-cta .btn{padding:11px 20px; font-size:.92rem}
.hamburger{display:none; flex-direction:column; gap:5px; background:none; border:0; padding:9px}
.hamburger span{width:24px; height:2.2px; background:var(--forest); border-radius:2px; transition:.3s}
.hamburger.open span:nth-child(1){transform:translateY(7.2px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7.2px) rotate(-45deg)}

/* page header band */
.page-head{position:relative; background:linear-gradient(160deg,var(--forest),#1d4338); color:#fff; overflow:hidden; padding:clamp(54px,8vw,86px) 0 clamp(48px,7vw,74px)}
.page-head::before{content:""; position:absolute; top:-130px; right:-90px; width:380px; height:380px; border-radius:50%; background:radial-gradient(circle, rgba(201,139,149,.32), transparent 70%)}
.page-head::after{content:""; position:absolute; bottom:-160px; left:-110px; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle, rgba(27,139,130,.4), transparent 70%)}
.page-head .wrap{position:relative; z-index:2}
.crumb{font-size:.82rem; letter-spacing:.08em; color:rgba(255,255,255,.7); font-weight:600; margin-bottom:14px}
.crumb a:hover{color:#fff}
.crumb span{margin:0 8px; opacity:.5}
.page-head h1{color:#fff; font-size:clamp(2.4rem,5.4vw,3.8rem); font-weight:600; line-height:1.05; margin-bottom:14px}
.page-head p{color:rgba(255,255,255,.88); font-size:1.12rem; max-width:60ch; font-weight:300; margin:0}

/* hero (home) */
.hero{position:relative; min-height:min(92vh,840px); display:flex; align-items:center; overflow:hidden; background:var(--forest)}
.hero-bg{position:absolute; inset:0}
.hero-bg img{width:100%; height:100%; object-fit:cover; object-position:center 18%}
.hero-bg::after{content:""; position:absolute; inset:0; background:linear-gradient(102deg, rgba(20,60,52,.94) 0%, rgba(27,90,82,.78) 38%, rgba(27,139,130,.28) 72%, rgba(27,139,130,.08) 100%)}
.hero-inner{position:relative; z-index:2; width:100%}
.hero-card{max-width:660px}
.hero-logo{height:84px; width:auto; margin-bottom:24px; filter:brightness(0) invert(1)}
.hero h1{color:#fff; font-size:clamp(2.7rem,6.2vw,4.7rem); font-weight:600; line-height:1.04; margin-bottom:18px}
.hero h1 em{font-style:italic; color:#ffe6ea}
.hero-sub{color:rgba(255,255,255,.92); font-size:1.22rem; max-width:38ch; margin-bottom:14px; font-weight:300}
.hero-pills{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:32px}
.hero-pills span{font-size:.8rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#fff; border:1px solid rgba(255,255,255,.4); padding:7px 16px; border-radius:999px}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap}
.hero-scroll{position:absolute; bottom:24px; left:50%; transform:translateX(-50%); z-index:2; color:rgba(255,255,255,.8); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:8px; font-weight:700}
.hero-scroll .dot{width:24px; height:38px; border:2px solid rgba(255,255,255,.55); border-radius:999px; position:relative}
.hero-scroll .dot::after{content:""; position:absolute; top:7px; left:50%; transform:translateX(-50%); width:4px; height:7px; background:#fff; border-radius:2px; animation:scrolldot 1.8s ease-in-out infinite}
@keyframes scrolldot{0%{opacity:0; transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0; transform:translate(-50%,12px)}}

/* hero split (home) */
.hero-split{display:grid; grid-template-columns:1.02fr 1fr; min-height:min(90vh,820px); background:linear-gradient(160deg,var(--forest),#1d4338)}
.hero-split .left{position:relative; display:flex; align-items:center; padding:clamp(40px,6vw,80px) clamp(28px,5vw,72px); overflow:hidden}
.hero-split .left::before{content:""; position:absolute; top:-120px; left:-120px; width:380px; height:380px; border-radius:50%; background:radial-gradient(circle, rgba(201,139,149,.28), transparent 70%)}
.hero-split .left::after{content:""; position:absolute; bottom:-150px; right:-90px; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle, rgba(27,139,130,.4), transparent 70%)}
.hero-split .inner{position:relative; z-index:2; max-width:560px}
.hero-split .right{position:relative; display:flex; align-items:flex-end; justify-content:center; padding:0 clamp(20px,4vw,56px)}
.hero-split .arch{position:relative; width:100%; max-width:500px; height:92%; border-radius:1000px 1000px 0 0; overflow:hidden; box-shadow:0 0 0 1px rgba(182,146,74,.5), 0 0 0 7px rgba(182,146,74,.22), 0 34px 80px rgba(0,0,0,.34)}
.hero-split .arch img{width:100%; height:100%; object-fit:cover; object-position:center 28%}
.hero-logo{height:80px; width:auto; margin-bottom:24px; filter:brightness(0) invert(1)}
.hero-split h1{color:#fff; font-size:clamp(2.6rem,5.4vw,4.4rem); font-weight:600; line-height:1.04; margin-bottom:18px}
.hero-split h1 em{font-style:italic; color:#ffe6ea}
.hero-sub{color:rgba(255,255,255,.92); font-size:1.2rem; max-width:40ch; margin-bottom:14px; font-weight:300}
.hero-pills{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:32px}
.hero-pills span{font-size:.8rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:#fff; border:1px solid rgba(255,255,255,.4); padding:7px 16px; border-radius:999px}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap}

/* about */
.about-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(34px,5vw,72px); align-items:center}
.feat-grid{display:grid; grid-template-columns:1fr 1fr; gap:18px}
.feat{background:var(--white); border:1px solid var(--line); border-radius:var(--r-md); padding:24px 22px; box-shadow:var(--shadow-sm); transition:transform .3s, box-shadow .3s}
.feat:hover{transform:translateY(-4px); box-shadow:var(--shadow-md)}
.feat .ic{width:46px; height:46px; border-radius:13px; background:var(--rose-soft); color:var(--teal); display:grid; place-items:center; margin-bottom:14px}
.feat .ic svg{width:24px; height:24px}
.feat b{display:block; font-family:var(--ff-serif); font-size:1.22rem; color:var(--forest); margin-bottom:5px; font-weight:600}
.feat p{margin:0; font-size:.95rem; color:var(--ink-soft); line-height:1.55}
.about-photo{position:relative}
.about-photo img{border-radius:var(--r-lg); box-shadow:var(--shadow-md); width:100%; aspect-ratio:4/5; object-fit:cover}
.award-badge{position:absolute; left:-18px; bottom:26px; background:#fff; border-radius:var(--r-md); padding:18px 22px; box-shadow:var(--shadow-md); display:flex; gap:14px; align-items:center; max-width:300px; border:1px solid var(--line)}
.award-badge .medal{width:50px; height:50px; flex:none; border-radius:50%; background:linear-gradient(140deg,#f5d98a,#d8a93f); display:grid; place-items:center; color:#7a5a12}
.award-badge .medal svg{width:27px; height:27px}
.award-badge b{font-family:var(--ff-sans); font-weight:800; font-size:.95rem; color:var(--forest); display:block; line-height:1.25}
.award-badge span{font-size:.78rem; color:var(--ink-soft)}

/* values strip */
.values{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.value{background:var(--white); border:1px solid var(--line); border-radius:var(--r-md); padding:32px 30px; box-shadow:var(--shadow-sm)}
.value .num{font-family:var(--ff-serif); font-size:2.6rem; color:var(--rose); font-weight:700; line-height:1}
.value h3{font-size:1.5rem; margin:10px 0 8px}
.value p{margin:0; color:var(--ink-soft); font-size:.98rem}

/* services */
.svc-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:26px}
.svc{background:var(--white); border-radius:var(--r-md); overflow:hidden; border:1px solid var(--line); box-shadow:var(--shadow-sm); transition:transform .3s, box-shadow .3s; display:flex; flex-direction:column}
.svc:hover{transform:translateY(-6px); box-shadow:var(--shadow-md)}
.svc-img{aspect-ratio:16/11; overflow:hidden; position:relative}
.svc-img img{width:100%; height:100%; object-fit:cover; transition:transform .6s ease}
.svc:hover .svc-img img{transform:scale(1.06)}
.svc-tag{position:absolute; top:14px; left:14px; background:rgba(255,255,255,.92); color:var(--teal); font-size:.7rem; font-weight:800; letter-spacing:.1em; text-transform:uppercase; padding:6px 12px; border-radius:999px; backdrop-filter:blur(4px)}
.svc-body{padding:22px 24px 26px; display:flex; flex-direction:column; flex:1}
.svc-body h3{font-size:1.4rem; margin-bottom:8px}
.svc-body p{margin:0; font-size:.96rem; color:var(--ink-soft); line-height:1.55}
.svc-body ul{margin:14px 0 0; padding-left:18px; color:var(--ink-soft); font-size:.92rem; line-height:1.6}
.svc-body ul li{margin-bottom:4px}

/* doctors (detailed) */
.doc-full{background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); overflow:hidden; display:grid; grid-template-columns:360px 1fr; margin-bottom:34px}
.doc-full .photo{position:relative; background:var(--cream-2); min-height:420px}
.doc-full .photo img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:top center}
.doc-full .info{padding:clamp(28px,3.5vw,46px)}
.doc-full .role{color:var(--teal); font-weight:800; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:9px}
.doc-full h2{font-size:clamp(1.8rem,3vw,2.5rem); line-height:1.05}
.doc-full .spec{color:var(--teal); font-weight:700; font-size:1rem; margin:6px 0 0}
.doc-meta{display:grid; gap:10px; margin:20px 0; padding:18px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.doc-meta div{display:flex; gap:11px; align-items:flex-start; font-size:.93rem; color:var(--ink-soft)}
.doc-meta svg{width:18px; height:18px; color:var(--teal); flex:none; margin-top:3px}
.doc-bio p{font-size:1rem; color:var(--ink); line-height:1.72; margin:0 0 14px}
.doc-bio .alumni{background:var(--cream); border-left:3px solid var(--rose); border-radius:0 12px 12px 0; padding:16px 20px; font-size:.95rem; color:var(--ink-soft); line-height:1.65; margin:0 0 14px}
.str-chip{display:inline-flex; align-items:center; gap:8px; background:var(--rose-soft); color:var(--forest); font-weight:700; font-size:.86rem; padding:9px 16px; border-radius:999px; margin-top:4px}
.str-chip svg{width:16px; height:16px; color:var(--teal)}

/* staff grid */
.staff-group{margin-top:14px}
.staff-group + .staff-group{margin-top:48px}
.staff-group .glabel{display:flex; align-items:center; gap:14px; margin-bottom:22px}
.staff-group .glabel h3{font-size:1.55rem; white-space:nowrap}
.staff-group .glabel .ln{height:1px; background:var(--line); flex:1}
.staff-group .glabel .tag{background:var(--teal); color:#fff; font-size:.72rem; font-weight:800; letter-spacing:.08em; text-transform:uppercase; padding:5px 13px; border-radius:999px}
.staff-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
.staff{background:var(--white); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .3s, box-shadow .3s; cursor:pointer}
.staff:hover{transform:translateY(-5px); box-shadow:var(--shadow-md)}
.staff .pic{aspect-ratio:4/5; overflow:hidden; background:var(--cream-2)}
.staff .pic img{width:100%; height:100%; object-fit:cover; transition:transform .6s ease}
.staff:hover .pic img{transform:scale(1.05)}
.staff .cap{padding:16px 18px 18px}
.staff .cap b{display:block; font-family:var(--ff-serif); font-size:1.3rem; color:var(--forest); font-weight:600; line-height:1.1}
.staff .cap span{font-size:.86rem; color:var(--teal); font-weight:700}
.staff .cap em{display:block; font-size:.85rem; color:var(--ink-soft); font-style:italic; margin-top:7px; line-height:1.45}

/* team intro card */
.team-note{margin:34px auto 0; font-size:1rem; color:var(--ink-soft); text-align:center; font-style:italic; max-width:60ch}

/* gallery */
.gal{display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px}
.gal figure{margin:0; position:relative; border-radius:var(--r-sm); overflow:hidden; cursor:pointer; box-shadow:var(--shadow-sm)}
.gal img{width:100%; height:100%; object-fit:cover; transition:transform .6s ease}
.gal figure:hover img{transform:scale(1.07)}
.gal figcaption{position:absolute; inset:auto 0 0 0; background:linear-gradient(0deg,rgba(20,60,52,.82),transparent); color:#fff; font-weight:700; font-size:.9rem; padding:26px 16px 14px; opacity:0; transform:translateY(8px); transition:.3s}
.gal figure:hover figcaption{opacity:1; transform:translateY(0)}
.gal .tall{grid-row:span 2} .gal .wide{grid-column:span 2}
.lb{position:fixed; inset:0; z-index:120; background:rgba(20,40,35,.94); display:none; align-items:center; justify-content:center; padding:30px; backdrop-filter:blur(6px)}
.lb.show{display:flex}
.lb img{max-width:92vw; max-height:82vh; border-radius:12px; box-shadow:0 30px 80px rgba(0,0,0,.5)}
.lb-cap{position:absolute; bottom:26px; left:0; right:0; text-align:center; color:#fff; font-weight:600; font-size:1.05rem}
.lb-btn{position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.3); color:#fff; width:54px; height:54px; border-radius:50%; display:grid; place-items:center; font-size:1.5rem; transition:.2s}
.lb-btn:hover{background:rgba(255,255,255,.28)}
.lb-prev{left:22px} .lb-next{right:22px}
.lb-close{position:absolute; top:22px; right:24px; background:none; border:0; color:#fff; font-size:2.4rem; line-height:1; opacity:.85}
.lb-close:hover{opacity:1}

/* pricing */
.price-tabs{display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-bottom:34px}
.price-tabs button{background:var(--white); border:1.5px solid var(--line); color:var(--forest); font-weight:700; font-size:.94rem; padding:11px 22px; border-radius:999px; transition:.25s}
.price-tabs button:hover{border-color:var(--teal)}
.price-tabs button.active{background:var(--teal); color:#fff; border-color:var(--teal); box-shadow:0 6px 18px rgba(27,139,130,.28)}
.price-panel{display:none; animation:fade .4s ease}
.price-panel.active{display:block}
@keyframes fade{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:none}}
.price-card{background:var(--white); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--shadow-sm); overflow:hidden; max-width:780px; margin:0 auto}
.price-card h3{padding:24px 30px 6px; font-size:1.5rem}
.price-card .ph-note{padding:0 30px 14px; margin:0; font-size:.86rem; color:var(--teal); font-style:italic}
.price-list{list-style:none; margin:0; padding:8px 14px 18px}
.price-list li{display:flex; justify-content:space-between; align-items:baseline; gap:20px; padding:14px 16px; border-radius:12px}
.price-list li:nth-child(odd){background:var(--cream)}
.price-list .name{font-weight:600; color:var(--ink)}
.price-list .name small{display:block; font-weight:400; font-size:.8rem; color:var(--ink-soft); font-style:italic}
.price-list .val{font-family:var(--ff-serif); font-weight:700; font-size:1.25rem; color:var(--teal); white-space:nowrap}
.price-note{text-align:center; margin-top:24px; font-size:.92rem; color:var(--ink-soft)}
.price-note b{color:var(--forest)}

/* testimonials */
.tst-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.tst{background:var(--white); border-radius:var(--r-md); padding:32px 30px; border:1px solid var(--line); box-shadow:var(--shadow-sm); display:flex; flex-direction:column}
.tst .quote{font-family:var(--ff-serif); font-size:4rem; line-height:.6; color:var(--rose); height:34px}
.tst p{font-size:1.05rem; color:var(--ink); line-height:1.6; margin:6px 0 22px; flex:1}
.tst .stars{color:#e7a93f; letter-spacing:2px; margin-bottom:12px; font-size:1rem}
.tst .who{display:flex; align-items:center; gap:13px; padding-top:18px; border-top:1px solid var(--line)}
.tst .who .av{width:46px; height:46px; border-radius:50%; background:var(--rose-soft); color:var(--teal); display:grid; place-items:center; font-weight:800; font-family:var(--ff-serif); font-size:1.25rem}
.tst .who b{font-family:var(--ff-sans); font-weight:700; color:var(--forest); font-size:1rem}
.tst .who span{font-size:.83rem; color:var(--ink-soft)}

/* booking */
.book{background:linear-gradient(160deg,var(--forest),#1d4338); color:#fff; position:relative; overflow:hidden}
.book::before{content:""; position:absolute; top:-120px; right:-100px; width:420px; height:420px; border-radius:50%; background:radial-gradient(circle, rgba(201,139,149,.3), transparent 70%)}
.book::after{content:""; position:absolute; bottom:-140px; left:-120px; width:460px; height:460px; border-radius:50%; background:radial-gradient(circle, rgba(27,139,130,.45), transparent 70%)}
.book-grid{display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(34px,5vw,64px); align-items:center; position:relative; z-index:2}
.book h2{color:#fff} .book .eyebrow{color:#ffd9de} .book .eyebrow::before{background:var(--rose)}
.book-intro p{color:rgba(255,255,255,.86); font-size:1.08rem}
.book-points{list-style:none; margin:26px 0 0; padding:0; display:flex; flex-direction:column; gap:14px}
.book-points li{display:flex; gap:12px; align-items:center; font-weight:600}
.book-points svg{width:22px; height:22px; color:var(--rose); flex:none}
.form{background:#fff; border-radius:var(--r-lg); padding:clamp(26px,3.5vw,40px); box-shadow:0 30px 70px rgba(0,0,0,.25)}
.form .row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.field{margin-bottom:16px} .field.full{grid-column:1/-1}
label{display:block; font-weight:700; font-size:.85rem; color:var(--forest); margin-bottom:7px}
label .req{color:var(--rose)}
input,select,textarea{width:100%; font-family:inherit; font-size:1rem; color:var(--ink); padding:13px 15px; border:1.5px solid var(--line); border-radius:12px; background:var(--cream); transition:border-color .2s, box-shadow .2s; -webkit-appearance:none; appearance:none}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232E5A4B' stroke-width='2.5' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 15px center; padding-right:40px}
input:focus,select:focus,textarea:focus{outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(27,139,130,.15); background:#fff}
textarea{resize:vertical; min-height:84px}
.form .btn-wa{width:100%; justify-content:center; margin-top:6px; font-size:1.05rem}
.form-note{text-align:center; font-size:.82rem; color:var(--ink-soft); margin:14px 0 0}

/* contact */
.contact-grid{display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(30px,4vw,56px); align-items:stretch}
.contact-info{display:flex; flex-direction:column; gap:8px}
.ci{display:flex; gap:16px; align-items:flex-start; padding:20px 0; border-bottom:1px solid var(--line)}
.ci:last-of-type{border-bottom:0}
.ci .ic{width:48px; height:48px; flex:none; border-radius:13px; background:var(--rose-soft); color:var(--teal); display:grid; place-items:center}
.ci .ic svg{width:23px; height:23px}
.ci b{display:block; font-family:var(--ff-serif); font-size:1.25rem; color:var(--forest); font-weight:600; margin-bottom:3px}
.ci p{margin:0; color:var(--ink-soft); font-size:.97rem; line-height:1.5}
.ci a{color:var(--teal); font-weight:600} .ci a:hover{text-decoration:underline}
.hours-list{list-style:none; margin:6px 0 0; padding:0}
.hours-list li{display:flex; justify-content:space-between; gap:14px; font-size:.95rem; padding:4px 0}
.hours-list .d{color:var(--ink-soft)} .hours-list .t{font-weight:700; color:var(--forest)}
.map-box{border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-md); min-height:420px; border:1px solid var(--line); position:relative}
.map-box iframe{width:100%; height:100%; min-height:420px; border:0; display:block; filter:saturate(.92)}
.map-actions{position:absolute; bottom:16px; left:16px; right:16px; display:flex; gap:10px; justify-content:center}
.map-actions .btn{padding:12px 22px; font-size:.92rem; box-shadow:0 8px 24px rgba(0,0,0,.18)}
.contact-socials{display:flex; gap:12px; margin-top:8px}
.contact-socials a{width:46px; height:46px; border-radius:13px; background:var(--white); border:1px solid var(--line); display:grid; place-items:center; color:var(--teal); transition:.25s}
.contact-socials a:hover{background:var(--teal); color:#fff; transform:translateY(-3px)}
.contact-socials svg{width:22px; height:22px}

/* CTA band */
.cta-band{background:linear-gradient(160deg,var(--teal),var(--teal-dark)); color:#fff; text-align:center; border-radius:var(--r-lg); padding:clamp(40px,6vw,68px) var(--pad); position:relative; overflow:hidden}
.cta-band h2{color:#fff; max-width:18ch; margin:0 auto}
.cta-band p{color:rgba(255,255,255,.88); max-width:48ch; margin:16px auto 28px; font-size:1.08rem}
.cta-band .btns{display:flex; gap:14px; justify-content:center; flex-wrap:wrap}

/* footer */
.footer{background:var(--forest); color:rgba(255,255,255,.78); padding:64px 0 30px}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px}
.footer img.logo{height:64px; filter:brightness(0) invert(1); margin-bottom:18px}
.footer h4{color:#fff; font-family:var(--ff-sans); font-weight:800; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin:0 0 18px}
.footer p{font-size:.95rem; line-height:1.6; max-width:34ch}
.footer ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px}
.footer ul a{font-size:.95rem; transition:color .2s; color:rgba(255,255,255,.78)}
.footer ul a:hover{color:#fff}
.footer .tagline{font-family:var(--ff-serif); font-size:1.5rem; color:#fff; font-style:italic; margin:14px 0 0}
.footer-bottom{border-top:1px solid rgba(255,255,255,.16); margin-top:48px; padding-top:24px; display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.85rem; color:rgba(255,255,255,.6)}

/* floating WA */
.wa-float{position:fixed; right:20px; bottom:20px; z-index:80; width:60px; height:60px; border-radius:50%; background:var(--wa); display:grid; place-items:center; box-shadow:0 10px 30px rgba(37,211,102,.45); transition:transform .25s; animation:wapulse 2.6s infinite}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px; height:32px; color:#fff}
@keyframes wapulse{0%{box-shadow:0 10px 30px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 10px 30px rgba(37,211,102,.45),0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 10px 30px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,0)}}

/* music player */
.music-float{position:fixed; right:20px; bottom:92px; z-index:80; width:60px; height:60px; border-radius:50%; background:var(--forest); color:#fff; display:grid; place-items:center; border:0; box-shadow:0 10px 30px rgba(46,90,75,.4); transition:transform .25s, background .25s}
.music-float:hover{transform:scale(1.08)}
.music-float svg{width:25px; height:25px}
.music-float.playing{background:var(--teal)}
.music-float.playing::after{content:""; position:absolute; inset:0; border-radius:50%; animation:musicpulse 2.2s infinite}
@keyframes musicpulse{0%{box-shadow:0 0 0 0 rgba(27,139,130,.5)}70%{box-shadow:0 0 0 14px rgba(27,139,130,0)}100%{box-shadow:0 0 0 0 rgba(27,139,130,0)}}
@media (prefers-reduced-motion:reduce){.music-float.playing::after{animation:none}}

/* reveal */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transform:none; transition:none} .hero-scroll .dot::after{animation:none} .wa-float{animation:none}}

/* responsive */
@media (max-width:1000px){
  .about-grid,.book-grid,.contact-grid{grid-template-columns:1fr}
  .svc-grid,.tst-grid,.values{grid-template-columns:repeat(2,1fr)}
  .staff-grid{grid-template-columns:repeat(3,1fr)}
  .about-photo{max-width:480px; margin:0 auto}
  .map-box{min-height:340px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .doc-full{grid-template-columns:1fr}
  .doc-full .photo{min-height:0; aspect-ratio:3/2}
  .doc-full .photo img{object-position:center 22%}
}
@media (max-width:760px){
  body{font-size:16px}
  html{scroll-padding-top:122px}
  .nav-inner{flex-wrap:wrap; height:auto; min-height:62px; row-gap:6px; padding-top:10px; padding-bottom:8px; justify-content:space-between; align-items:center}
  .brand{order:1; flex:0 1 auto}
  .nav-cta{order:2; flex:0 0 auto}
  .nav-cta .btn{padding:10px 18px; font-size:.86rem}
  .hamburger{display:none}
  .nav-inner > nav{order:3; flex:1 1 100%; width:100%}
  .nav-links{position:static; width:100%; flex-direction:row; flex-wrap:wrap; justify-content:center; align-items:center; gap:2px; transform:none; background:transparent; box-shadow:none; padding:8px 0 1px; margin-top:2px; border-top:1px solid var(--line)}
  .nav-links a{padding:7px 10px; font-size:.82rem; border-bottom:0; border-radius:8px}
  .nav-links a.active::after{display:none}
  .nav-links a.active{background:rgba(27,139,130,.12)}
  .hero-split{grid-template-columns:1fr}
  .hero-split .right{order:-1; padding:40px var(--pad) 0; align-items:flex-end}
  .hero-split .arch{height:auto; aspect-ratio:5/6; max-width:340px}
  .hero-split .left{padding:48px var(--pad) 56px}
  .gal{grid-template-columns:repeat(2,1fr); grid-auto-rows:150px}
  .gal .tall{grid-row:span 1}
  .staff-grid{grid-template-columns:repeat(2,1fr)}
  .feat-grid{grid-template-columns:1fr 1fr}
  .form .row{grid-template-columns:1fr}
  .award-badge{left:0; right:0; margin:0 auto; bottom:-24px; max-width:90%}
  .hero{min-height:auto; padding:118px 0 84px}
}
@media (max-width:480px){
  .svc-grid,.tst-grid,.values,.feat-grid,.footer-grid{grid-template-columns:1fr}
  .staff-grid{grid-template-columns:1fr 1fr; gap:14px}
  .staff .cap b{font-size:1.1rem}
  .brand-txt{display:none}
  .hero-actions .btn{flex:1; justify-content:center}
  .price-list li{flex-direction:column; gap:4px}
  .price-list .val{align-self:flex-start}
  .staff-group .glabel h3{font-size:1.25rem}
}
