
/* ── HERO ── */
.hero{display:grid;grid-template-columns:1fr 1fr;min-height:calc(100vh - 60px);border-bottom:1px solid rgba(255,255,255,0.06)}
.hero-l{background:var(--charcoal);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:56px 56px 64px}
.hero-l-glow{position:absolute;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.18) 0%,transparent 65%);top:-120px;right:-160px;pointer-events:none;will-change:transform}
.hero-eyebrow{display:flex;align-items:center;gap:10px;font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-bottom:24px;position:relative;z-index:3}
.hero-eyebrow::before{content:'';width:24px;height:1px;background:var(--purple);flex-shrink:0}
.hero h1{font-family:var(--serif);font-size:clamp(54px,6.5vw,86px);line-height:0.97;font-weight:600;color:#fff;letter-spacing:-0.02em;margin-bottom:22px;position:relative;z-index:3}
.hero h1 .ghost{color:rgba(255,255,255,0.18);font-style:italic;font-weight:300;display:block}
.hero h1 .accent{color:var(--purple);display:block}
.hero-sub{font-size:15px;color:rgba(255,255,255,0.45);max-width:420px;line-height:1.85;font-weight:300;margin-bottom:36px;position:relative;z-index:3}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:40px;position:relative;z-index:3}
.btn-fill{background:var(--white);color:var(--ink);font-size:11px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;padding:13px 28px;border:none;cursor:none;transition:all .22s;text-decoration:none;display:inline-block}
.btn-fill:hover{background:var(--purple);color:#fff}
.hero-pills{display:flex;gap:10px;flex-wrap:wrap;position:relative;z-index:3;border-top:1px solid rgba(255,255,255,0.08);padding-top:28px;justify-content:space-between;width:100%}
.hero-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--purple);border-radius:40px;padding:10px 20px;flex:1;text-align:center;box-shadow:0 4px 20px rgba(139,123,184,0.3)}
.pill-num{font-family:var(--serif);font-size:20px;font-weight:600;color:#fff;line-height:1;letter-spacing:-0.01em}
.pill-label{font-size:8px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-top:2px;font-weight:500}
.scroll-hint{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:10}
.scroll-hint span{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.3)}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--purple-mid),transparent);animation:sp 2s ease-in-out infinite}
@keyframes sp{0%,100%{opacity:.4}50%{opacity:1}}

/* right panel — photo */
.hero-r{position:relative;overflow:hidden;min-height:100%}
.hero-r img{width:100%;height:100%;object-fit:cover;filter:grayscale(100%) contrast(1.08);display:block}
.hero-r-ph{position:absolute;inset:0;background:linear-gradient(135deg,#b0aca4,#7a7872);display:flex;align-items:center;justify-content:center}
.hero-r-ph svg{stroke:rgba(255,255,255,0.3);width:48px;height:48px}
.hero-r-ph::after{content:'YOUR PHYSIO PHOTO';position:absolute;bottom:24px;left:24px;font-size:9px;letter-spacing:0.14em;color:rgba(255,255,255,0.4);text-transform:uppercase}
.hero-r-tag{position:absolute;bottom:0;left:0;right:0;background:rgba(15,15,15,0.75);backdrop-filter:blur(10px);padding:16px 24px;display:flex;align-items:center;gap:10px;border-top:1px solid rgba(255,255,255,0.1)}
.tag-dot{width:7px;height:7px;border-radius:50%;background:var(--purple);flex-shrink:0}
.hero-r-tag span{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.55)}

/* ── INTRO SPLIT ── */
.intro{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--line)}
.intro-l{padding:80px 56px;background:var(--white);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.intro-bg-n{position:absolute;font-family:var(--serif);font-size:220px;font-weight:600;color:rgba(139,123,184,0.05);bottom:-30px;left:-10px;line-height:1;pointer-events:none;letter-spacing:-0.04em;user-select:none;will-change:transform}
.intro-l h2{font-family:var(--serif);font-size:clamp(38px,4vw,52px);font-weight:600;line-height:1.07;letter-spacing:-0.01em;margin-bottom:20px;position:relative;z-index:1}
.intro-l h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.intro-l p{font-size:15px;color:var(--mid);line-height:1.9;font-weight:300;max-width:420px;position:relative;z-index:1;margin-bottom:14px}
.intro-l p strong{color:var(--ink);font-weight:600}
.intro-bullets{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
.intro-bullets li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--ink)}
.ib-dot{width:8px;height:8px;border-radius:50%;background:var(--purple);flex-shrink:0;margin-top:7px;box-shadow:0 0 0 3px rgba(139,123,184,0.18)}
.intro-r{padding:80px 56px;background:var(--off);display:flex;flex-direction:column;justify-content:center}
.intro-r h3{font-family:var(--serif);font-size:28px;font-weight:600;letter-spacing:-0.01em;margin-bottom:20px;color:var(--ink)}
.intro-r h3 em{font-style:italic;font-weight:300;color:var(--purple)}

/* condition pills */
.cond-grid{display:flex;flex-wrap:wrap;gap:10px}
.cond-pill{font-size:12px;font-weight:500;padding:9px 18px;border-radius:40px;border:1.5px solid var(--line);background:var(--white);color:var(--ink);transition:all .22s;cursor:none}
.cond-pill:hover{border-color:var(--purple);background:var(--purple-pale);color:var(--purple-dark)}

/* ── WHAT WE DO (dark) ── */
.what{background:var(--charcoal);border-bottom:1px solid rgba(255,255,255,0.07)}
.what-header{padding:72px 56px 52px;border-bottom:1px solid rgba(255,255,255,0.07);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end}
.what-header h2{font-family:var(--serif);font-size:clamp(38px,4vw,52px);font-weight:600;line-height:1.06;letter-spacing:-0.01em;color:#fff}
.what-header h2 em{font-style:italic;font-weight:300;color:rgba(255,255,255,0.3)}
.what-header p{font-size:15px;color:rgba(255,255,255,0.45);line-height:1.85;font-weight:300}
.what-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:32px 40px 48px}
.what-card{padding:36px 32px;border-radius:20px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);position:relative;overflow:hidden;transition:transform .4s cubic-bezier(0.22,1,0.36,1),box-shadow .4s,background .3s;cursor:none}
.what-card:hover{background:rgba(255,255,255,0.08);transform:translateY(-8px) scale(1.02);box-shadow:0 28px 56px rgba(0,0,0,0.4),0 0 0 1px rgba(139,123,184,0.35)}
.wc-bg-num{position:absolute;font-family:var(--serif);font-size:90px;font-weight:600;color:rgba(255,255,255,0.03);bottom:-10px;right:12px;line-height:1;pointer-events:none;letter-spacing:-0.04em;transition:color .3s}
.what-card:hover .wc-bg-num{color:rgba(139,123,184,0.12)}
.wc-icon{width:40px;height:40px;border-radius:50%;background:rgba(139,123,184,0.15);border:1px solid rgba(139,123,184,0.3);display:flex;align-items:center;justify-content:center;margin-bottom:16px;transition:all .3s}
.what-card:hover .wc-icon{background:var(--purple);border-color:var(--purple);transform:scale(1.1) rotate(-5deg)}
.wc-icon svg{width:16px;height:16px;stroke:var(--purple);fill:none;stroke-width:1.5;transition:stroke .25s}
.what-card:hover .wc-icon svg{stroke:#fff}
.wc-title{font-size:14px;font-weight:600;color:#fff;margin-bottom:8px}
.wc-body{font-size:13px;color:rgba(255,255,255,0.42);line-height:1.8;font-weight:300}

/* ── NDIS BAND ── */
.ndis-band{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--line)}
.ndis-l{padding:80px 56px;background:var(--off);position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center}
.ndis-bg-n{position:absolute;font-family:var(--serif);font-size:200px;font-weight:600;color:rgba(139,123,184,0.06);bottom:-20px;left:-10px;line-height:1;pointer-events:none;letter-spacing:-0.04em;user-select:none}
.ndis-l h2{font-family:var(--serif);font-size:clamp(36px,3.5vw,48px);font-weight:600;line-height:1.07;letter-spacing:-0.01em;margin-bottom:18px;position:relative;z-index:1}
.ndis-l h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.ndis-l p{font-size:15px;color:var(--mid);line-height:1.9;font-weight:300;max-width:400px;position:relative;z-index:1;margin-bottom:14px}
.ndis-bullets{list-style:none;margin-top:16px;display:flex;flex-direction:column;gap:12px;position:relative;z-index:1}
.ndis-bullets li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--ink)}
.ndis-r{padding:80px 56px;background:var(--white);display:flex;flex-direction:column;justify-content:center;gap:20px}
.ndis-pills{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%}
.ndis-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--purple);border-radius:40px;padding:16px 20px;text-align:center;box-shadow:0 4px 20px rgba(139,123,184,0.3)}
.ndis-pill .pn{font-family:var(--serif);font-size:24px;font-weight:600;color:#fff;line-height:1;letter-spacing:-0.02em}
.ndis-pill .pl{font-size:8px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-top:3px;font-weight:500}
.btn-dark{background:var(--ink);color:#fff;font-size:11px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;padding:14px 32px;border:none;cursor:none;transition:all .22s;text-decoration:none;display:inline-block}
.btn-dark:hover{background:var(--purple)}

/* ── PROCESS ── */
.process{border-bottom:1px solid var(--line);background:var(--off)}
.process-header{padding:72px 56px 52px;border-bottom:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end}
.process-header h2{font-family:var(--serif);font-size:clamp(36px,3.5vw,48px);font-weight:600;line-height:1.06;letter-spacing:-0.01em}
.process-header h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.process-header p{font-size:15px;color:var(--mid);line-height:1.85;font-weight:300}
.process-steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:center;padding:32px 40px 48px}
.step-arrow{display:flex;align-items:center;justify-content:center;padding:0 8px;color:rgba(139,123,184,0.4);font-size:22px;flex-shrink:0;margin-top:-20px}
.step{padding:34px 28px;border-radius:20px;background:var(--white);border:1px solid var(--line);transition:transform .4s cubic-bezier(0.22,1,0.36,1),box-shadow .4s,background .3s;cursor:none;position:relative;overflow:hidden}
.step:hover{background:var(--purple-pale);transform:translateY(-8px) scale(1.02);box-shadow:0 24px 48px rgba(139,123,184,0.18),0 0 0 1.5px rgba(139,123,184,0.35)}
.step-num{font-family:var(--serif);font-size:48px;font-weight:600;color:rgba(139,123,184,0.18);line-height:1;margin-bottom:10px;letter-spacing:-0.02em;transition:color .3s}
.step:hover .step-num{color:rgba(139,123,184,0.45)}
.step-title{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:6px}
.step-body{font-size:12px;color:var(--mid);line-height:1.75;font-weight:300}

/* ── MISSION QUOTE ── */
.quote-band{background:var(--charcoal);padding:80px 64px;display:flex;align-items:flex-start;gap:48px;position:relative;overflow:hidden;border-bottom:1px solid rgba(255,255,255,0.07)}
.quote-glow{position:absolute;width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.14) 0%,transparent 65%);top:-200px;right:-80px;pointer-events:none;will-change:transform}
.quote-bar{width:3px;background:var(--purple);flex-shrink:0;align-self:stretch;opacity:0.5;border-radius:2px}
.quote-band blockquote{font-family:var(--serif);font-size:clamp(28px,3vw,40px);font-weight:300;color:#fff;line-height:1.3;font-style:italic;position:relative;z-index:1}
.quote-band blockquote strong{font-weight:600;font-style:normal;color:#c4b8e0}
.quote-sub{margin-top:18px;font-size:11px;color:rgba(255,255,255,0.35);letter-spacing:0.14em;text-transform:uppercase;position:relative;z-index:1}

/* ── RELATED SERVICES — horizontal scroll strip ── */
.related{border-bottom:1px solid var(--line);background:var(--white);overflow:hidden}
.related-header{padding:52px 56px 36px;display:flex;align-items:flex-end;justify-content:space-between;gap:40px}
.related-header-l h2{font-family:var(--serif);font-size:clamp(28px,3vw,38px);font-weight:600;line-height:1.07;letter-spacing:-0.01em;color:var(--ink)}
.related-header-l h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.related-header-r{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--soft);flex-shrink:0;display:flex;align-items:center;gap:10px}
.related{border-bottom:1px solid var(--line);background:var(--charcoal);overflow:hidden}
.related-header{padding:52px 56px 36px;display:flex;align-items:flex-end;justify-content:space-between;gap:40px}
.related-header-l h2{font-family:var(--serif);font-size:clamp(28px,3vw,38px);font-weight:600;line-height:1.07;letter-spacing:-0.01em;color:#fff}
.related-header-l h2 em{font-style:italic;font-weight:300;color:rgba(255,255,255,0.35)}
.related-header-r{font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.3);flex-shrink:0;display:flex;align-items:center;gap:10px}
.scroll-track-wrap{position:relative;padding:0 40px 52px;overflow:hidden}
.scroll-track{display:flex;gap:16px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;cursor:grab;padding:8px 0 8px}
.scroll-track:active{cursor:grabbing}
.scroll-track::-webkit-scrollbar{display:none}
/* alternating card colours for boldness */
.svc-chip{flex-shrink:0;width:220px;padding:32px 28px;border-radius:24px;text-decoration:none;color:inherit;transition:transform .4s cubic-bezier(0.22,1,0.36,1),box-shadow .4s,filter .3s;cursor:none;display:flex;flex-direction:column;position:relative;overflow:hidden;border:none}
.svc-chip:nth-child(1){background:var(--purple)}
.svc-chip:nth-child(2){background:rgba(255,255,255,0.07);border:1.5px solid rgba(255,255,255,0.12)}
.svc-chip:nth-child(3){background:var(--purple-dark)}
.svc-chip:nth-child(4){background:rgba(255,255,255,0.07);border:1.5px solid rgba(255,255,255,0.12)}
.svc-chip:nth-child(5){background:var(--purple)}
.svc-chip:nth-child(6){background:rgba(255,255,255,0.07);border:1.5px solid rgba(255,255,255,0.12)}
.svc-chip:hover{transform:translateY(-10px) scale(1.04);box-shadow:0 28px 56px rgba(0,0,0,0.5),0 0 0 2px rgba(255,255,255,0.15);filter:brightness(1.12);z-index:2}
.svc-chip:hover .chip-arr{transform:translateX(4px);color:rgba(255,255,255,0.9)}
.svc-chip:hover .chip-icon{background:rgba(255,255,255,0.25);border-color:rgba(255,255,255,0.4);transform:scale(1.1) rotate(-6deg)}
/* ghost large letter behind content */
.chip-ghost{position:absolute;font-family:var(--serif);font-size:110px;font-weight:600;color:rgba(255,255,255,0.06);bottom:-14px;right:8px;line-height:1;pointer-events:none;letter-spacing:-0.04em;user-select:none;transition:color .3s}
.svc-chip:hover .chip-ghost{color:rgba(255,255,255,0.12)}
.chip-icon{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,0.15);border:1.5px solid rgba(255,255,255,0.3);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:all .3s;flex-shrink:0}
.chip-icon svg{width:15px;height:15px;stroke:#fff;fill:none;stroke-width:1.5}
.chip-tag{font-size:8px;letter-spacing:0.16em;text-transform:uppercase;color:rgba(255,255,255,0.5);font-weight:600;margin-bottom:6px}
.chip-title{font-family:var(--serif);font-size:22px;font-weight:600;line-height:1.15;color:#fff;margin-bottom:8px;letter-spacing:-0.01em}
.chip-body{font-size:12px;color:rgba(255,255,255,0.5);line-height:1.65;font-weight:300;flex:1}
.chip-arr{font-size:14px;color:rgba(255,255,255,0.35);transition:transform .22s,color .22s;margin-top:18px;align-self:flex-start}

/* ── CTA ── */
.cta{position:relative;padding:100px 56px;overflow:hidden;background:var(--charcoal);border-bottom:1px solid rgba(255,255,255,0.07)}
.cta-wash{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 20% 50%,rgba(139,123,184,0.12) 0%,transparent 70%)}
.cta-inner{position:relative;z-index:3;max-width:520px}
.cta-inner h2{font-family:var(--serif);font-size:clamp(44px,5vw,60px);font-weight:600;line-height:1;letter-spacing:-0.02em;color:#fff;margin-bottom:16px}
.cta-inner h2 em{font-style:italic;font-weight:300;color:var(--purple)}
.cta-inner p{font-size:15px;color:rgba(255,255,255,0.4);line-height:1.85;font-weight:300;max-width:400px;margin-bottom:34px}
.btn-cta{background:var(--white);color:var(--ink);font-size:11px;font-weight:600;letter-spacing:0.09em;text-transform:uppercase;padding:14px 32px;border:none;cursor:none;transition:all .22s;text-decoration:none;display:inline-block}
.btn-cta:hover{background:var(--purple);color:#fff}

/* FOOTER */
footer{padding:28px 48px;display:flex;align-items:center;justify-content:space-between;background:var(--charcoal);border-top:1px solid rgba(255,255,255,0.07)}
.f-logo{font-family:var(--serif);font-size:14px;color:rgba(255,255,255,0.4)}
.f-logo i{font-style:italic;color:var(--purple)}
.f-links{display:flex;gap:28px;list-style:none}
.f-links a{font-size:10px;letter-spacing:0.09em;text-transform:uppercase;color:rgba(255,255,255,0.3);text-decoration:none;transition:color .2s}
.f-links a:hover{color:var(--purple)}
.f-copy{font-size:10px;color:rgba(255,255,255,0.2)}