
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy: #0d1f3c;
  --navy-mid: #152a4e;
  --navy-light: #1e3a66;
  --terra: #c4622d;
  --terra-light: #e07a45;
  --gold: #d4a843;
  --white: #ffffff;
  --text-dim: rgba(255,255,255,0.6);
  --text-muted: rgba(255,255,255,0.4);
  --border: rgba(255,255,255,0.1);
}

html { scroll-behavior: smooth; background: #0d1f3c; }
body { font-family: 'Outfit', sans-serif; background: var(--navy); color: var(--white); overflow-x: hidden; }

/* ── CURSOR ── */
.cursor { width:8px; height:8px; background:var(--terra); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9999; transition:transform .1s; }
.cursor-ring { width:36px; height:36px; border:1.5px solid rgba(196,98,45,.5); border-radius:50%; position:fixed; top:0; left:0; pointer-events:none; z-index:9998; transition:transform .08s, width .3s, height .3s; }

/* ── NAV ── */
nav { position:fixed; top:0; width:100%; z-index:500; display:flex; align-items:center; justify-content:space-between; padding:20px 64px; transition:background .4s, padding .4s; }
nav.scrolled { background:rgba(13,31,60,.96); backdrop-filter:blur(20px); padding:14px 64px; border-bottom:1px solid var(--border); }
.nav-logo { display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav-logo-icon { width:42px; height:42px; background:var(--terra); border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:20px; font-weight:900; color:#fff; font-family:'Playfair Display',serif; }
.nav-logo-text { display:flex; flex-direction:column; line-height:1; }
.nav-logo-name { font-family:'Playfair Display',serif; font-size:18px; font-weight:700; color:#fff; letter-spacing:2px; text-transform:uppercase; }
.nav-logo-sub { font-size:9px; color:var(--terra-light); letter-spacing:1.5px; text-transform:uppercase; font-weight:500; margin-top:3px; }
.nav-links { display:flex; align-items:center; gap:40px; }
.nav-links a { text-decoration:none; color:var(--text-dim); font-size:13px; font-weight:500; letter-spacing:.5px; transition:color .2s; }
.nav-links a:hover { color:#fff; }
.btn-nav { background:var(--terra); color:#fff; padding:10px 24px; border-radius:6px; font-weight:600; font-size:13px; text-decoration:none; letter-spacing:.5px; transition:all .25s; box-shadow:0 4px 20px rgba(196,98,45,.3); }
.btn-nav:hover { background:var(--terra-light); transform:translateY(-1px); }

/* ── HERO ── */
.hero { position:relative; min-height:100vh; display:flex; align-items:center; overflow:hidden; }
#hero-canvas { position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(13,31,60,.88) 0%,rgba(13,31,60,.5) 55%,rgba(13,31,60,.78) 100%); z-index:1; }
.hero-content { position:relative; z-index:2; padding:120px 64px 80px; max-width:700px; }
.hero-eyebrow { display:inline-flex; align-items:center; gap:10px; margin-bottom:28px; }
.hero-eyebrow-line { width:40px; height:1px; background:var(--terra); }
.hero-eyebrow span { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--terra-light); font-weight:600; }
.hero h1 { font-family:'Playfair Display',serif; font-size:clamp(52px,6vw,84px); font-weight:900; line-height:1.04; letter-spacing:-1px; margin-bottom:24px; }
.hero h1 .line-accent { color:var(--terra-light); font-style:italic; }
.hero p { font-size:16px; color:var(--text-dim); line-height:1.8; max-width:460px; margin-bottom:44px; font-weight:300; }
.hero-ctas { display:flex; gap:16px; flex-wrap:wrap; }
.btn-primary-hero { background:var(--terra); color:#fff; padding:16px 36px; border-radius:6px; font-weight:600; font-size:14px; text-decoration:none; letter-spacing:.5px; transition:all .3s; box-shadow:0 8px 32px rgba(196,98,45,.35); position:relative; overflow:hidden; }
.btn-primary-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent); transform:translateX(-100%); transition:transform .6s; }
.btn-primary-hero:hover::before { transform:translateX(100%); }
.btn-primary-hero:hover { transform:translateY(-2px); box-shadow:0 16px 48px rgba(196,98,45,.4); }
.btn-outline-hero { border:1px solid rgba(255,255,255,.25); color:#fff; padding:15px 36px; border-radius:6px; font-weight:500; font-size:14px; text-decoration:none; letter-spacing:.5px; transition:all .3s; }
.btn-outline-hero:hover { border-color:rgba(255,255,255,.6); background:rgba(255,255,255,.05); }
.hero-stats { position:absolute; bottom:64px; right:64px; z-index:2; display:flex; gap:48px; }
.stat { text-align:center; }
.stat-num { font-family:'Playfair Display',serif; font-size:40px; font-weight:900; color:var(--terra-light); line-height:1; }
.stat-line { width:32px; height:2px; background:var(--terra); margin:8px auto 6px; }
.stat-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); font-weight:600; }
.scroll-hint { position:absolute; bottom:40px; left:64px; z-index:2; display:flex; align-items:center; gap:12px; color:var(--text-muted); font-size:11px; letter-spacing:2px; text-transform:uppercase; }
.scroll-line { width:60px; height:1px; background:var(--terra); position:relative; overflow:hidden; }
.scroll-line::after { content:''; position:absolute; top:0; left:-100%; width:100%; height:100%; background:#fff; animation:scrollLine 2s ease-in-out infinite; }
@keyframes scrollLine { 0%{left:-100%} 100%{left:100%} }

/* ── SECTION COMMONS ── */
section { padding:100px 64px; }
.section-label { display:inline-flex; align-items:center; gap:10px; margin-bottom:16px; }
.section-label-line { width:32px; height:1px; background:var(--terra); }
.section-label span { font-size:11px; letter-spacing:3px; text-transform:uppercase; color:var(--terra-light); font-weight:600; }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(36px,4vw,56px); font-weight:700; line-height:1.1; color:#fff; }
.section-title em { font-style:italic; color:var(--terra-light); }
.section-sub { font-size:15px; color:var(--text-dim); line-height:1.8; font-weight:300; max-width:500px; margin-top:14px; }

/* ── TREATMENTS ── */
.treatments { background:var(--navy-mid); }
.treatments-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:64px; flex-wrap:wrap; gap:24px; }
.treatments-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:2px; }
.treatment-card { background:var(--navy); padding:40px 28px; position:relative; overflow:hidden; cursor:pointer; transition:background .3s; }
.treatment-card:hover { background:var(--navy-light); }
.treatment-card::after { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--terra); transition:width .4s; }
.treatment-card:hover::after { width:100%; }
.treatment-num { font-family:'Playfair Display',serif; font-size:64px; font-weight:900; color:rgba(255,255,255,.04); position:absolute; top:16px; right:20px; line-height:1; }
.treatment-icon-wrap { width:52px; height:52px; border:1px solid rgba(196,98,45,.3); border-radius:12px; display:flex; align-items:center; justify-content:center; margin-bottom:24px; transition:border-color .3s, background .3s; }
.treatment-card:hover .treatment-icon-wrap { border-color:var(--terra); background:rgba(196,98,45,.1); }
.treatment-icon-wrap svg { width:24px; height:24px; stroke:var(--terra-light); fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }
.treatment-title { font-family:'Playfair Display',serif; font-size:19px; font-weight:700; color:#fff; margin-bottom:12px; }
.treatment-desc { font-size:13px; color:var(--text-dim); line-height:1.75; margin-bottom:24px; font-weight:300; }
.treatment-link { font-size:11px; font-weight:600; color:var(--terra-light); letter-spacing:1px; text-transform:uppercase; text-decoration:none; display:flex; align-items:center; gap:8px; transition:gap .2s; }
.treatment-card:hover .treatment-link { gap:14px; }

.bodymap-section{background:var(--navy);padding:100px 64px 80px;display:grid;grid-template-columns:320px 1fr;gap:0 60px;align-items:start}
.bodymap-left{position:sticky;top:100px;display:flex;flex-direction:column}
.bodymap-sub{font-size:14px;color:var(--text-muted);line-height:1.75;font-weight:300;margin-top:14px;max-width:280px}
.bodymap-nav{display:flex;align-items:center;gap:16px;margin-top:36px}
.bm-arrow{width:44px;height:44px;border:1px solid rgba(255,255,255,.18);border-radius:50%;background:transparent;color:#fff;font-size:18px;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bm-arrow:hover{border-color:var(--terra);color:var(--terra-light);background:rgba(196,98,45,.08)}
.bm-dots{display:flex;gap:8px}
.bm-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.2);cursor:pointer;transition:all .3s}
.bm-dot.active{background:var(--terra);transform:scale(1.3)}
.bm-info-panel{margin-top:36px}
.bm-region-name{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;color:#fff;margin-bottom:10px;transition:opacity .35s,transform .35s}
.bm-region-desc{font-size:13px;color:var(--text-dim);line-height:1.8;font-weight:300;margin-bottom:18px;transition:opacity .35s,transform .35s}
.bm-points-list{display:flex;flex-wrap:wrap;gap:7px}
.bm-point-tag{font-size:10px;font-weight:600;letter-spacing:.6px;padding:4px 12px;border-radius:100px;border:1px solid rgba(196,98,45,.35);color:var(--terra-light);cursor:default;transition:all .2s;animation:tagPop .3s ease both}
.bm-point-tag:hover{background:rgba(196,98,45,.1);border-color:var(--terra)}
@keyframes tagPop{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.bodymap-stage{position:relative;background:linear-gradient(160deg,#0a1628 0%,#0f2040 50%,#0a1628 100%);border-radius:20px;border:1px solid rgba(255,255,255,.08);overflow:hidden;display:flex;flex-direction:column}
.bm-3d-wrap{flex:1;position:relative;min-height:580px}
.bm-3d-canvas{width:100%;height:100%;display:block;cursor:grab}
.bm-3d-canvas:active{cursor:grabbing}
.bm-slide-badge{position:absolute;top:16px;left:20px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;background:rgba(13,31,60,.9);color:#fff;padding:4px 12px;border-radius:100px;border-left:3px solid var(--terra);z-index:10;pointer-events:none}
.bm-loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(160deg,#0a1628,#0f2040);z-index:20;transition:opacity .6s}
.bm-loading-bar-wrap{width:160px;height:3px;background:rgba(255,255,255,.1);border-radius:2px;margin-top:16px}
.bm-loading-bar{height:100%;width:0%;background:var(--terra);border-radius:2px;transition:width .3s}
.bm-loading-text{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-top:10px}
.bm-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.3);pointer-events:none;display:flex;align-items:center;gap:6px;white-space:nowrap;animation:fadeHint 5s ease 3s forwards;z-index:5}
@keyframes fadeHint{0%{opacity:1}100%{opacity:0}}
.bm-credits{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);white-space:nowrap;font-size:9px;color:rgba(255,255,255,.22);z-index:5;letter-spacing:.3px}
.bm-credits a{color:rgba(255,255,255,.38);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.15);transition:color .2s}
.bm-credits a:hover{color:rgba(255,255,255,.7)}
@media(max-width:900px){.bodymap-section{grid-template-columns:1fr}.bodymap-left{position:static}.bm-3d-wrap{min-height:400px}}
/* ── TEAM ── */
.team { background:var(--navy-mid); }
.team-inner { display:grid; grid-template-columns:1fr 1fr; margin-top:64px; min-height:520px; }
.team-photo-wrap { position:relative; overflow:hidden; }
.team-group-img { width:100%; height:100%; object-fit:cover; object-position:center top; display:block; transition:transform .7s, filter .5s; min-height:480px; filter:grayscale(15%); }
.team-photo-wrap:hover .team-group-img { transform:scale(1.04); filter:grayscale(0%); }
.team-photo-overlay { position:absolute; inset:0; background:linear-gradient(to right, transparent 55%, var(--navy-mid) 100%); pointer-events:none; }
.team-photo-label { position:absolute; bottom:28px; left:28px; background:var(--terra); color:#fff; padding:8px 16px; border-radius:4px; font-size:11px; font-weight:700; letter-spacing:2px; text-transform:uppercase; }
.team-info-panel { padding:56px 52px; display:flex; flex-direction:column; justify-content:center; }
.team-tagline { font-family:'Playfair Display',serif; font-size:26px; font-weight:700; color:#fff; line-height:1.35; margin-bottom:18px; }
.team-tagline em { font-style:italic; color:var(--terra-light); }
.team-desc { font-size:14px; color:var(--text-dim); line-height:1.8; font-weight:300; max-width:380px; margin-bottom:40px; }
.team-stats-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:36px; }
.team-stat { padding:18px; border:1px solid var(--border); border-radius:6px; transition:border-color .3s; }
.team-stat:hover { border-color:rgba(196,98,45,.5); }
.team-stat-num { font-family:'Playfair Display',serif; font-size:30px; font-weight:900; color:var(--terra-light); line-height:1; }
.team-stat-label { font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; font-weight:600; margin-top:5px; }
.team-specialties { display:flex; flex-wrap:wrap; gap:8px; }
.specialty-tag { font-size:11px; font-weight:600; letter-spacing:.5px; color:var(--terra-light); border:1px solid rgba(196,98,45,.3); padding:5px 12px; border-radius:100px; transition:all .2s; cursor:default; }
.specialty-tag:hover { background:rgba(196,98,45,.1); border-color:var(--terra); }

/* ── TESTIMONIALS ── */
.testimonials { background:var(--navy); }
.testi-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:64px; background:var(--border); }
.testi-card { background:var(--navy); padding:48px 36px; transition:background .3s; }
.testi-card:hover { background:var(--navy-mid); }
.testi-stars { color:var(--gold); font-size:14px; letter-spacing:2px; margin-bottom:24px; }
.testi-text { font-family:'Playfair Display',serif; font-size:17px; line-height:1.7; color:rgba(255,255,255,.85); font-style:italic; margin-bottom:32px; }
.testi-divider { width:40px; height:1px; background:var(--terra); margin-bottom:24px; }
.testi-name { font-size:14px; font-weight:600; color:#fff; }
.testi-condition { font-size:11px; color:var(--terra-light); letter-spacing:1px; text-transform:uppercase; margin-top:4px; }

/* ── CONTACT ── */
.contact { background:var(--navy-mid); display:grid; grid-template-columns:1fr 1fr; padding:0; }
.contact-left { padding:100px 64px; }
.contact-details { margin-top:48px; display:flex; flex-direction:column; gap:28px; }
.contact-item { display:flex; gap:16px; }
.ci-icon { width:44px; height:44px; flex-shrink:0; border:1px solid rgba(196,98,45,.3); border-radius:8px; display:flex; align-items:center; justify-content:center; }
.ci-icon svg { width:20px; height:20px; stroke:var(--terra-light); fill:none; stroke-width:1.5; stroke-linecap:round; }
.ci-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); font-weight:600; }
.ci-val { font-size:15px; color:#fff; font-weight:500; margin-top:4px; }
.contact-right { padding:100px 64px; background:var(--navy); }
.contact-right h3 { font-family:'Playfair Display',serif; font-size:28px; font-weight:700; margin-bottom:36px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:16px; }
.form-group label { font-size:11px; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); font-weight:600; display:block; margin-bottom:8px; }
.form-group input, .form-group textarea, .form-group select { width:100%; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:6px; padding:14px 16px; color:#fff; font-family:'Outfit',sans-serif; font-size:14px; font-weight:300; outline:none; transition:border-color .2s; }
.form-group input:focus, .form-group textarea:focus, .form-group select:focus { border-color:var(--terra); }
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--text-muted); }
.form-group textarea { min-height:120px; resize:vertical; }
.form-group select { cursor:pointer; }
.form-group select option { background:var(--navy-mid); }
.btn-submit { width:100%; background:var(--terra); color:#fff; border:none; padding:16px; border-radius:6px; font-family:'Outfit',sans-serif; font-size:14px; font-weight:600; letter-spacing:1px; text-transform:uppercase; cursor:pointer; transition:all .3s; box-shadow:0 8px 32px rgba(196,98,45,.3); margin-top:8px; }
.btn-submit:hover { background:var(--terra-light); transform:translateY(-2px); }

/* ── FOOTER ── */
footer { background:#080f1e; padding:60px 64px 36px; }
.footer-top { display:grid; grid-template-columns:2fr 1.8fr 1.8fr; gap:80px; padding-bottom:48px; border-bottom:1px solid var(--border); }
.footer-logo { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.footer-logo-icon { width:40px; height:40px; background:var(--terra); border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Playfair Display',serif; font-size:18px; font-weight:900; color:#fff; }
.footer-logo-name { font-family:'Playfair Display',serif; font-size:18px; font-weight:700; letter-spacing:2px; text-transform:uppercase; }
.footer-about { font-size:13px; color:var(--text-muted); line-height:1.8; max-width:260px; }
.footer-col h4 { font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--terra-light); font-weight:600; margin-bottom:20px; }
.footer-col a { display:block; font-size:13px; color:var(--text-muted); text-decoration:none; margin-bottom:12px; transition:color .2s; }
.footer-col a:hover { color:#fff; }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; padding-top:32px; }
.footer-bottom p { font-size:12px; color:var(--text-muted); }
.social-links { display:flex; gap:10px; }
.social-link { width:36px; height:36px; border:1px solid var(--border); border-radius:6px; display:flex; align-items:center; justify-content:center; color:var(--text-dim); text-decoration:none; transition:all .2s; }
.social-link:hover { border-color:var(--terra); color:var(--terra-light); }
.social-link svg { width:15px; height:15px; }

/* ── REVEAL ── */
.reveal { opacity:0; transform:translateY(32px); transition:opacity .8s ease, transform .8s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-left { opacity:0; transform:translateX(-32px); transition:opacity .8s ease, transform .8s ease; }
.reveal-left.visible { opacity:1; transform:translateX(0); }
@keyframes fadeDown { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:translateY(0)} }
nav { animation:fadeDown .8s ease both; }

/* ── RESPONSIVE ── */
@media (max-width:960px) {
  nav { padding:16px 24px; } .nav-links { display:none; }
  section { padding:64px 24px; }
  .hero-content { padding:100px 24px 80px; }
  .hero-stats { position:static; margin-top:48px; justify-content:flex-start; }
  .scroll-hint { display:none; }
  .treatments-grid { grid-template-columns:1fr 1fr; }
  .muscle-section, .team-inner, .contact { grid-template-columns:1fr; }
  .muscle-canvas-wrap { height:380px; }
  .testi-grid { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
  .team-photo-overlay { background:linear-gradient(to bottom,transparent 60%,var(--navy-mid) 100%); }
  .contact-left, .contact-right { padding:64px 24px; }
}

.glb-backdrop.open 




.glb-backdrop.open 

/* ── HERO RIGHT PANEL ── */
.hero-right{position:absolute;right:0;top:0;bottom:0;width:48%;z-index:2;display:flex;align-items:center;justify-content:center;pointer-events:none}
.hero-services{position:relative;width:380px;height:420px}
.hsvc{position:absolute;display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);backdrop-filter:blur(12px);border-radius:16px;padding:16px 20px;opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease;min-width:210px}
.hsvc.visible{opacity:1;transform:translateY(0)}
.hsvc:nth-child(4){top:0;left:20px}
.hsvc:nth-child(5){top:80px;right:0}
.hsvc:nth-child(6){top:175px;left:0}
.hsvc:nth-child(7){top:255px;right:10px}
.hsvc:nth-child(8){top:345px;left:50px}
.hsvc-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hsvc-icon svg{width:22px;height:22px}
.hsvc-name{font-size:13px;font-weight:600;color:#fff;letter-spacing:.2px;line-height:1.3}
.hsvc-desc{font-size:11px;color:rgba(255,255,255,.45);margin-top:2px;font-weight:300}
.hero-dot{position:absolute;border-radius:50%;animation:heroPulse 3s ease-in-out infinite}
.hero-dot-1{width:6px;height:6px;background:var(--terra);top:42px;left:108px;animation-delay:0s}
.hero-dot-2{width:5px;height:5px;background:#2979d5;top:218px;right:118px;animation-delay:1.2s}
.hero-dot-3{width:4px;height:4px;background:rgba(255,255,255,.3);top:155px;left:190px;animation-delay:.6s}
@keyframes heroPulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.8);opacity:1}}
/* ── TREATMENT POPUP ── */
.treatment-link{cursor:pointer}
.tx-popup{position:fixed;z-index:900;width:340px;background:#0d1f3c;border:1px solid rgba(255,255,255,.1);border-radius:18px;box-shadow:0 32px 80px rgba(0,0,0,.7);overflow:hidden;opacity:0;pointer-events:none;transform:translateY(8px) scale(.97);transition:opacity .22s,transform .22s}
.tx-popup.show{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}
.tx-popup-img{width:100%;height:155px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.tx-popup-img-bg{position:absolute;inset:0}
.tx-popup-img svg{position:relative;z-index:1;width:52px;height:52px;opacity:.55}
.tx-popup-body{padding:18px 22px 22px}
.tx-popup-tag{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;color:var(--terra-light);margin-bottom:7px}
.tx-popup-title{font-family:'Playfair Display',serif;font-size:19px;font-weight:700;color:#fff;line-height:1.25;margin-bottom:9px}
.tx-popup-desc{font-size:12px;color:rgba(255,255,255,.58);line-height:1.7;font-weight:300;margin-bottom:13px}
.tx-popup-points{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:5px}
.tx-popup-points li{font-size:11px;color:rgba(255,255,255,.5);display:flex;align-items:center;gap:8px}
.tx-popup-points li::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--terra);flex-shrink:0}
.tx-popup-cta{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.tx-popup-cta:hover{gap:10px}



.hero-right{position:absolute;right:0;top:0;bottom:0;width:48%;z-index:2;display:flex;align-items:center;justify-content:center;pointer-events:none}
.hero-services{position:relative;width:380px;height:420px}
.hsvc{position:absolute;display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);backdrop-filter:blur(12px);border-radius:16px;padding:16px 20px;opacity:0;transform:translateY(20px);transition:opacity .6s,transform .6s;min-width:210px}
.hsvc.visible{opacity:1;transform:translateY(0)}
.hsvc:nth-child(4){top:0;left:20px}.hsvc:nth-child(5){top:80px;right:0}.hsvc:nth-child(6){top:175px;left:0}.hsvc:nth-child(7){top:255px;right:10px}.hsvc:nth-child(8){top:345px;left:50px}
.hsvc-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hsvc-icon svg{width:22px;height:22px}
.hsvc-name{font-size:13px;font-weight:600;color:#fff;letter-spacing:.2px;line-height:1.3}
.hsvc-desc{font-size:11px;color:rgba(255,255,255,.45);margin-top:2px;font-weight:300}
.hero-dot{position:absolute;border-radius:50%;animation:heroPulse 3s ease-in-out infinite}
.hero-dot-1{width:6px;height:6px;background:var(--terra);top:42px;left:108px}
.hero-dot-2{width:5px;height:5px;background:#2979d5;top:218px;right:118px;animation-delay:1.2s}
.hero-dot-3{width:4px;height:4px;background:rgba(255,255,255,.3);top:155px;left:190px;animation-delay:.6s}
@keyframes heroPulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.8);opacity:1}}
.treatment-link{cursor:pointer;user-select:none}
.txm-backdrop{position:fixed;inset:0;background:rgba(4,8,18,.88);z-index:950;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(10px)}
.txm-backdrop.open{opacity:1;pointer-events:all}
.txm-box{width:100%;max-width:860px;height:520px;background:#0c1a30;border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.09);box-shadow:0 40px 100px rgba(0,0,0,.8);transform:scale(.88) translateY(24px);transition:transform .38s cubic-bezier(.25,.46,.45,.94);display:flex;flex-direction:row;position:relative}
.txm-backdrop.open .txm-box{transform:scale(1) translateY(0)}
.txm-close{position:absolute;top:16px;right:16px;z-index:10;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(0,0,0,.4);color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.txm-close:hover{border-color:var(--terra);color:var(--terra-light)}
.txm-body{flex:1;padding:36px 32px 36px 40px;overflow-y:auto;display:flex;flex-direction:column;justify-content:center}
.txm-tag{font-size:9px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:8px}
.txm-title{font-family:'Playfair Display',serif;font-size:26px;font-weight:700;color:#fff;margin:0 0 14px;line-height:1.2}
.txm-desc{font-size:13px;color:rgba(255,255,255,.6);line-height:1.8;font-weight:300;margin-bottom:20px}
.txm-points{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:9px}
.txm-points li{font-size:12px;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:10px}
.txm-cta{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;text-decoration:none;padding:13px 26px;border-radius:100px;color:#fff;transition:all .25s;align-self:flex-start}
.txm-cta:hover{filter:brightness(1.15);transform:translateY(-2px)}
.txm-img{flex:0 0 316px;position:relative;height:100%;padding:16px 16px 16px 0;overflow:visible}
.txm-img-frame{position:relative;width:100%;height:100%;overflow:hidden;border-radius:14px}
.txm-img-frame::before{content:'';position:absolute;inset:-1px;border-radius:15px;padding:1px;background:linear-gradient(160deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.04) 50%,rgba(255,255,255,.12) 100%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:3;pointer-events:none}
.txm-img-bg{position:absolute;inset:0;background-size:cover;background-position:center top;transition:transform .6s ease;border-radius:14px}
.txm-backdrop.open .txm-img-bg{transform:scale(1.03)}
.txm-img-corner{position:absolute;width:22px;height:22px;z-index:4;pointer-events:none}
.txm-img-corner::before,.txm-img-corner::after{content:'';position:absolute;background:var(--terra);border-radius:2px}
.txm-img-corner::before{width:2px;height:100%}
.txm-img-corner::after{width:100%;height:2px}
.txm-img-corner.tl{top:8px;left:8px}.txm-img-corner.tr{top:8px;right:8px;transform:scaleX(-1)}.txm-img-corner.bl{bottom:8px;left:8px;transform:scaleY(-1)}.txm-img-corner.br{bottom:8px;right:8px;transform:scale(-1)}
.txm-img-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:70px;height:70px;display:flex;align-items:center;justify-content:center}
.txm-img-icon svg{width:70px;height:70px;opacity:.45}

.glb-backdrop.open 

@media(max-width:900px){.txm-box{flex-direction:column;height:auto;max-height:92vh}.txm-img{flex:0 0 240px;width:100%;padding:0 16px 16px}}






/* Lightbox */





/* ══ GALLERY ══ */
.gallery-section{background:#080e1a;padding:80px 0 48px}
.gs-head{padding:0 64px 36px}
.gs-strip{
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:0 64px 20px;
  scrollbar-width:none;
  cursor:grab;
}
.gs-strip::-webkit-scrollbar{display:none}
.gs-strip:active{cursor:grabbing}
.gc{
  flex:0 0 320px;
  height:240px;
  border-radius:14px;
  overflow:hidden;
  position:relative;
  flex-shrink:0;
  scroll-snap-align:start;
  cursor:pointer;
  transition:transform .3s,box-shadow .3s;
}
.gc:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(0,0,0,.6)}
.gc img{width:100%;height:100%;object-fit:cover;display:block}
.gc-ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(4,8,18,.88) 0%,transparent 55%);opacity:0;transition:opacity .28s;display:flex;flex-direction:column;justify-content:flex-end;padding:14px 16px}
.gc:hover .gc-ov{opacity:1}
.gc-lbl{font-size:13px;font-weight:600;color:#fff;line-height:1.3}
.gc-sub{font-size:11px;color:rgba(255,255,255,.45);margin-top:2px}
.gs-bar-row{display:flex;align-items:center;gap:12px;padding:14px 64px 0}
.gs-bar{flex:1;height:2px;background:rgba(255,255,255,.08);border-radius:2px;overflow:hidden}
.gs-fill{height:100%;width:9%;background:linear-gradient(90deg,#c4622d,#e07040);border-radius:2px;transition:width .15s}
.gs-btn{width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:transparent;color:rgba(255,255,255,.65);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}
.gs-btn:hover:not(:disabled){border-color:#c4622d;color:#e07040;background:rgba(196,98,45,.1)}
.gs-btn:disabled{opacity:.2;cursor:default}
/* lightbox */
#gsLb{position:fixed;inset:0;background:rgba(4,8,18,.96);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .25s;backdrop-filter:blur(8px)}
#gsLb.open{opacity:1;pointer-events:all}
.gslb-box{max-width:880px;width:92%;background:#0a1628;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.08);transform:scale(.95);transition:transform .28s}
#gsLb.open .gslb-box{transform:scale(1)}
.gslb-box img{width:100%;max-height:70vh;object-fit:contain;display:block;background:#060e1c}
.gslb-meta{padding:14px 18px;display:flex;align-items:center;justify-content:space-between}
.gslb-meta b{font-size:13px;color:#fff;display:block}
.gslb-meta p{font-size:11px;color:rgba(255,255,255,.4);margin:2px 0 0}
.gslb-meta button{width:32px;height:32px;border-radius:50%;border:1px solid rgba(255,255,255,.15);background:transparent;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center}
@media(max-width:860px){.gs-head,.gs-bar-row{padding-left:24px;padding-right:24px}.gs-strip{padding-left:24px;padding-right:24px}}
@media(max-width:500px){.gc{flex:0 0 240px;height:180px}}



/* ══════════════════════════════════════════
   MOBILE RESPONSIVE — comprehensive
══════════════════════════════════════════ */

/* ── Tablet (max 960px) ── */
@media (max-width: 960px) {
  /* Nav */
  nav { padding: 14px 20px; }
  .nav-links { display: none; }
  .nav-book-btn { padding: 10px 18px; font-size: 12px; }

  /* Hero */
  .hero-content { padding: 100px 24px 60px; }
  .hero h1 { font-size: clamp(38px, 7vw, 60px); }
  .hero p { font-size: 14px; }
  .hero-right { display: none; }
  .scroll-hint { display: none; }

  /* Sections */
  section { padding: 60px 24px; }
  .section-title { font-size: clamp(30px, 5vw, 48px); }

  /* Treatments */
  .treatments-grid { grid-template-columns: 1fr 1fr; }

  /* Body map */
  .bodymap-section { grid-template-columns: 1fr; }
  .bodymap-left { position: static; }
  .bm-3d-wrap { min-height: 380px; }

  /* Team */
  .team-inner { grid-template-columns: 1fr; min-height: auto; }
  .team-group-img { min-height: 360px; }
  .team-info-panel { padding: 40px 28px; }
  .team-stats-grid { gap: 16px; }

  /* Testimonials */
  .testi-grid { grid-template-columns: 1fr; }

  /* Contact */
  .contact { grid-template-columns: 1fr; }
  .contact-left { padding: 60px 24px; }
  .contact-right { padding: 60px 24px; }

  /* Footer */
  footer { padding: 48px 24px 28px; }
  .footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }

  /* Gallery */
  .gs-head { padding: 0 24px 28px; }
  .gs-strip { padding: 0 24px 16px; }
  .gs-bar-row { padding: 12px 24px 0; }

  /* Modal */
  .txm-box { flex-direction: column; height: auto; max-height: 90vh; overflow-y: auto; }
  .txm-body { padding: 28px 24px; }
  .txm-img { flex: 0 0 220px; width: 100%; padding: 0 16px 16px; }

  /* Form */
  .form-row { grid-template-columns: 1fr; }
}

/* ── Mobile (max 600px) ── */
@media (max-width: 600px) {
  /* Hero */
  .hero-content { padding: 90px 20px 48px; }
  .hero h1 { font-size: clamp(32px, 9vw, 48px); }
  .hero p { font-size: 13px; max-width: 100%; }
  .hero-btns { flex-direction: column; gap: 12px; }
  .hero-btns a { width: 100%; text-align: center; justify-content: center; }

  /* Treatments */
  .treatments-grid { grid-template-columns: 1fr; }
  .treatment-card { padding: 28px 20px; }
  .treatment-num { font-size: 48px; }

  /* Section */
  section { padding: 48px 20px; }
  .section-title { font-size: clamp(28px, 8vw, 40px); }
  .section-label span { font-size: 9px; }

  /* Body map */
  .bm-3d-wrap { min-height: 300px; }
  .bm-hotspot-label { font-size: 10px; padding: 3px 8px; }

  /* Team */
  .team-group-img { min-height: 280px; }
  .team-info-panel { padding: 28px 20px; }
  .team-tagline { font-size: 20px; }
  .team-desc { font-size: 13px; }
  .specialty-tag { font-size: 10px; padding: 4px 10px; }

  /* Testimonials */
  .testi-card { padding: 24px 20px; }
  .testi-quote { font-size: 15px; }

  /* Contact */
  .contact-left { padding: 40px 20px; }
  .contact-right { padding: 40px 20px; }
  .contact-right h3 { font-size: 22px; }
  .form-input, .form-select, .form-textarea { font-size: 14px; padding: 12px 14px; }
  .submit-btn { width: 100%; justify-content: center; }

  /* Gallery */
  .gc { flex: 0 0 240px; height: 190px; }
  .gc-lbl { font-size: 12px; }

  /* Footer */
  .footer-top { grid-template-columns: 1fr; gap: 28px; }
  .footer-bottom { flex-direction: column; text-align: center; gap: 8px; }
  .footer-links { justify-content: center; }

  /* Modal */
  .txm-box { border-radius: 14px; }
  .txm-title { font-size: 20px; }
  .txm-desc { font-size: 12px; }
  .txm-img { flex: 0 0 180px; }

  /* Misc */
  .glb-box { border-radius: 12px; }
  .lb-img { max-height: 55vh; }
}

/* ── Small mobile (max 400px) ── */
@media (max-width: 400px) {
  .hero h1 { font-size: 28px; }
  .treatments-grid { grid-template-columns: 1fr; }
  .gc { flex: 0 0 200px; height: 160px; }
  .section-title { font-size: 26px; }
}

/* ── Hamburger menu ── */
.nav-menu-btn {
  display: none;
  background: transparent;
  border: 1px solid rgba(255,255,255,.15);
  color: #fff;
  width: 38px;
  height: 38px;
  border-radius: 8px;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
}
@media (max-width: 960px) {
  .nav-menu-btn { display: flex; }
  .nav-links.open {
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 64px;
    left: 0;
    right: 0;
    background: rgba(8,15,36,.97);
    backdrop-filter: blur(16px);
    padding: 24px;
    gap: 8px;
    z-index: 999;
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .nav-links.open a {
    font-size: 15px;
    padding: 12px 0;
    border-bottom: 1px solid rgba(255,255,255,.06);
  }
  .nav-links.open .nav-book-btn {
    margin-top: 8px;
    width: 100%;
    text-align: center;
  }
}


/* ── HERO LOGO ── */
.hero-brand-logo { margin-bottom: 28px; }
.hero-brand-mobile { display: none; }
img.hero-logo-img {
  height: 44px !important;
  width: auto !important;
  max-width: 280px !important;
  min-width: unset !important;
  object-fit: contain !important;
  display: block !important;
  opacity: 0.95;
}
@media (max-width: 768px) {
  .hero-brand-logo { margin-bottom: 16px; }
  img.hero-logo-img { height: 34px !important; max-width: 180px !important; }
}

/* ── MOBILE RESPONSIVE ── */
@media (max-width: 768px) {
  html, body { overflow-x: hidden !important; width: 100% !important; }
  .hero { align-items: flex-start !important; min-height: unset !important; height: auto !important; padding-bottom: 60px !important; }
  .cursor, .cursor-ring { display: none !important; }
  .tx-popup, [id^="txp"] { display: none !important; opacity: 0 !important; pointer-events: none !important; }
  .treatments { padding: 0 !important; }
  .treatments-header { padding: 40px 20px 28px !important; }
  .treatments-grid { display: grid !important; grid-template-columns: 1fr !important; width: 100% !important; gap: 2px !important; }
  .treatment-card { width: 100% !important; min-width: 0 !important; max-width: 100% !important; box-sizing: border-box !important; padding: 28px 20px !important; grid-column: span 1 !important; }
  .txm-backdrop { padding: 0 !important; align-items: flex-end !important; }
  .txm-box { flex-direction: column-reverse !important; height: 92vh !important; max-height: 92vh !important; width: 100% !important; border-radius: 20px 20px 0 0 !important; overflow-y: auto !important; }
  .txm-body { padding: 24px 20px 32px !important; }
  .txm-img { flex: 0 0 220px !important; width: 100% !important; height: 220px !important; padding: 0 !important; }
  .txm-close { top: 12px !important; right: 12px !important; z-index: 10 !important; }
}

/* Gallery lightbox nav */
.gslb-nav { display:flex; align-items:center; gap:12px; }
.gslb-prev, .gslb-next {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff;
  width: 36px; height: 36px;
  border-radius: 50%;
  font-size: 16px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
  flex-shrink: 0;
}
.gslb-prev:hover, .gslb-next:hover { background: var(--terra); border-color: var(--terra); }
#gsLbCount { font-size: 12px; color: rgba(255,255,255,0.5); min-width: 40px; text-align: center; }
.gslb-close {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  color: #fff;
  width: 36px; height: 36px;
  border-radius: 50%;
  font-size: 16px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
  margin-left: auto;
}
.gslb-close:hover { background: rgba(255,255,255,0.2); }

/* Footer address & contact */
.footer-address {
  font-size: 13px;
  color: var(--text-dim);
  line-height: 1.6;
  margin-bottom: 10px;
}
.footer-contact-link {
  display: block;
  font-size: 13px;
  color: var(--text-dim);
  text-decoration: none;
  margin-bottom: 6px;
  transition: color .2s;
}
.footer-contact-link:hover { color: var(--terra-light); }

/* Footer credit */
.footer-credit {
  text-align: center;
  padding: 12px 0 6px;
  font-size: 12px;
  color: rgba(255,255,255,0.25);
  border-top: 1px solid rgba(255,255,255,0.05);
}
.footer-credit a {
  color: rgba(255,255,255,0.4);
  text-decoration: none;
  transition: color .2s;
}
.footer-credit a:hover { color: var(--terra-light); }

/* ── TEAM MEMBER CARDS ── */
.team-members-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 32px;
  padding: 48px 64px 80px;
  max-width: 1200px;
  margin: 0 auto;
}

.team-member-card {
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: 20px;
  overflow: hidden;
  transition: transform .3s, box-shadow .3s;
}
.team-member-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(0,0,0,.4);
}

.tm-photo-wrap {
  position: relative;
  height: 380px;
  overflow: hidden;
}
.tm-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  transition: transform .5s;
}
.team-member-card:hover .tm-photo { transform: scale(1.04); }
.tm-photo-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 50%, var(--navy-mid) 100%);
}

.tm-info {
  padding: 24px 28px 32px;
}
.tm-credentials {
  font-size: 11px;
  letter-spacing: 1px;
  color: var(--terra-light);
  text-transform: uppercase;
  margin-bottom: 8px;
  font-weight: 500;
}
.tm-name {
  font-family: 'Playfair Display', serif;
  font-size: 26px;
  font-weight: 700;
  color: var(--white);
  margin-bottom: 4px;
}
.tm-role {
  font-size: 13px;
  color: var(--text-dim);
  margin-bottom: 16px;
  font-style: italic;
}
.tm-bio {
  font-size: 13px;
  color: var(--text-dim);
  line-height: 1.8;
  margin-bottom: 20px;
}
.tm-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.tm-tags span {
  font-size: 11px;
  padding: 4px 12px;
  border-radius: 20px;
  border: 1px solid rgba(196,98,45,.4);
  color: var(--terra-light);
  background: rgba(196,98,45,.08);
}

@media (max-width: 768px) {
  .team-members-grid { padding: 32px 20px 60px; grid-template-columns: 1fr; }
  .tm-photo-wrap { height: 300px; }
}

/* ── TEAM SLIDESHOW ── */
.team-slideshow {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 32px 64px 48px;
}
.tm-slides {
  display: flex;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.tm-slide {
  min-width: 100%;
  padding: 0 8px;
  box-sizing: border-box;
}
.tm-slide-inner {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 56px;
  align-items: start;
  background: var(--navy-mid);
  border: 1px solid var(--border);
  border-radius: 24px;
  overflow: hidden;
}
.tm-slide-photo {
  height: 420px;
  overflow: hidden;
  flex-shrink: 0;
}
.tm-slide-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.tm-slide-info {
  padding: 48px 40px 48px 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.tm-credentials {
  font-size: 11px;
  letter-spacing: 1.5px;
  color: var(--terra-light);
  text-transform: uppercase;
  font-weight: 500;
}
.tm-name {
  font-family: 'Playfair Display', serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--white);
  margin: 0;
}
.tm-role {
  font-size: 14px;
  color: var(--text-dim);
  font-style: italic;
}
.tm-bio {
  font-size: 14px;
  color: var(--text-dim);
  line-height: 1.85;
  margin-top: 4px;
}
.tm-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.tm-tags span {
  font-size: 11px;
  padding: 5px 14px;
  border-radius: 20px;
  border: 1px solid rgba(196,98,45,.4);
  color: var(--terra-light);
  background: rgba(196,98,45,.08);
}

/* Controls */
.tm-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
  margin-top: 32px;
}
.tm-btn {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--navy-mid);
  color: var(--white);
  font-size: 18px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s, border-color .2s;
}
.tm-btn:hover { background: var(--terra); border-color: var(--terra); }
.tm-dots { display: flex; gap: 8px; }
.tm-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--border);
  cursor: pointer;
  transition: background .3s, transform .3s;
}
.tm-dot.active { background: var(--terra); transform: scale(1.3); }

/* Mobile */
@media (max-width: 768px) {
  .team-slideshow { padding: 24px 16px 60px; }
  .tm-slide-inner { grid-template-columns: 1fr; gap: 0; }
  .tm-slide-photo { height: 320px; }
  .tm-slide-info { padding: 28px 24px 32px; }
  .tm-name { font-size: 26px; }
}

/* Fix slideshow overflow */
.tm-track {
  overflow: hidden;
  width: 100%;
  border-radius: 24px;
}
.tm-slides {
  display: flex;
  transition: transform .5s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.tm-slide {
  min-width: 100%;
  box-sizing: border-box;
}

/* Tighten team section */
#team { padding: 80px 64px 40px !important; }

@media (max-width: 768px) {
  #team { padding: 60px 20px 32px !important; }
}
