
/* ── 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-l-ghost{position:absolute;font-family:var(--serif);font-size:clamp(120px,16vw,210px);font-weight:600;color:rgba(255,255,255,0.03);bottom:-20px;left:-10px;line-height:1;pointer-events:none;letter-spacing:-0.04em;user-select: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-pills{display:flex;gap:12px;flex-wrap:wrap;position:relative;z-index:3;border-top:1px solid rgba(255,255,255,0.08);padding-top:28px}
.hero-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--purple);border-radius:40px;padding:12px 28px;text-align:center;box-shadow:0 4px 20px rgba(139,123,184,0.3)}
.pill-num{font-family:var(--serif);font-size:24px;font-weight:600;color:#fff;line-height:1;letter-spacing:-0.02em}
.pill-label{font-size:9px;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 — service nav list (like NDIS hero-r) */
.hero-r{background:var(--off);position:relative;overflow:hidden;padding:56px 52px;display:flex;flex-direction:column;justify-content:center}
.hero-r-orb1{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.13) 0%,transparent 65%);top:-80px;right:-80px;pointer-events:none;will-change:transform}
.hero-r-orb2{position:absolute;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(139,123,184,0.07) 0%,transparent 65%);bottom:40px;left:20px;pointer-events:none;will-change:transform}
.hero-r-ghost{position:absolute;font-family:var(--serif);font-size:200px;font-weight:600;color:rgba(0,0,0,0.04);bottom:-20px;right:-10px;line-height:1;pointer-events:none;letter-spacing:-0.04em;user-select:none;will-change:transform}
.hero-r-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--mid);margin-bottom:28px;display:flex;align-items:center;gap:10px;position:relative;z-index:3}
.hero-r-label::before{content:'';width:24px;height:1px;background:var(--purple);flex-shrink:0}
.svc-nav{list-style:none;position:relative;z-index:3}
.svc-nav-item{border-bottom:1px solid var(--line)}
.svc-nav-item:first-child{border-top:1px solid var(--line)}
.svc-nav-link{display:flex;align-items:center;justify-content:space-between;padding:18px 0;text-decoration:none;color:var(--ink);transition:all .2s;gap:16px}
.svc-nav-link:hover{padding-left:8px}
.svc-nav-link:hover .snl-name{color:var(--purple)}
.svc-nav-link:hover .snl-arr{transform:translateX(4px);color:var(--purple)}
.snl-left{display:flex;align-items:center;gap:14px}
.snl-tag{font-size:9px;letter-spacing:0.14em;text-transform:uppercase;color:var(--purple);font-weight:600;background:var(--purple-pale);padding:3px 10px;border-radius:20px}
.snl-name{font-family:var(--serif);font-size:22px;font-weight:400;letter-spacing:-0.005em;line-height:1.1;transition:color .2s}
.snl-arr{font-size:18px;color:var(--soft);transition:transform .22s,color .22s;flex-shrink:0}

/* ── SERVICE CARDS ── */
.svc-section{background:var(--charcoal);border-bottom:1px solid rgba(255,255,255,0.07)}
.svc-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}
.svc-header h2{font-family:var(--serif);font-size:clamp(40px,4vw,54px);font-weight:600;line-height:1.06;letter-spacing:-0.01em;color:#fff}
.svc-header h2 em{font-style:italic;font-weight:300;color:rgba(255,255,255,0.3)}
.svc-header p{font-size:15px;color:rgba(255,255,255,0.45);line-height:1.85;font-weight:300}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;padding:32px 40px 48px}
.svc-card{border-radius:20px;text-decoration:none;color:inherit;background:rgba(255,255,255,0.04);display:flex;flex-direction:column;position:relative;overflow:hidden;transition:transform .4s cubic-bezier(0.22,1,0.36,1),box-shadow .4s,background .3s;cursor:none;border:1px solid rgba(255,255,255,0.08)}
.svc-card:hover{background:rgba(255,255,255,0.08);transform:translateY(-10px) scale(1.02);box-shadow:0 32px 64px rgba(0,0,0,0.5),0 0 0 1px rgba(139,123,184,0.4);z-index:4}
.svc-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--purple),rgba(139,123,184,0.4));transform:scaleX(0);transform-origin:left;transition:transform .35s;z-index:2;border-radius:20px 20px 0 0}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card:hover .svc-img{filter:grayscale(100%) contrast(1.2) brightness(0.65)}
.svc-card:hover .sc-arr{transform:translateX(5px);color:var(--purple)}
.svc-img{height:220px;width:100%;object-fit:cover;filter:grayscale(100%) contrast(1.05) brightness(0.72);transition:filter .4s;display:block;border-radius:16px 16px 0 0}
.svc-body{padding:28px 28px 24px;flex:1;display:flex;flex-direction:column}
.sc-tag{font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--purple);font-weight:600;margin-bottom:10px}
.sc-title{font-family:var(--serif);font-size:26px;font-weight:600;line-height:1.1;margin-bottom:10px;letter-spacing:-0.01em;color:#fff}
.sc-text{font-size:13px;color:rgba(255,255,255,0.42);line-height:1.8;font-weight:300;flex:1;margin-bottom:18px}
.sc-row{display:flex;align-items:center;justify-content:space-between;font-size:10px;letter-spacing:0.1em;font-weight:600;text-transform:uppercase;padding-top:14px;border-top:1px solid rgba(255,255,255,0.08);color:rgba(255,255,255,0.5)}
.sc-arr{font-size:16px;transition:transform .22s,color .22s;color:rgba(255,255,255,0.22)}

/* ── 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:220px;font-weight:600;color:rgba(139,123,184,0.06);bottom:-30px;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(38px,4vw,52px);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.85;font-weight:300;max-width:380px;position:relative;z-index:1;margin-bottom:14px}
.ndis-bullets{list-style:none;margin-top:20px;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)}
.nb-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)}
.ndis-r{padding:80px 56px;background:var(--bg);display:flex;flex-direction:column;justify-content:center;gap:14px}
/* NDIS pill badges */
.ndis-pills{display:flex;gap:12px;flex-wrap:wrap}
.ndis-pill{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--purple);border-radius:40px;padding:14px 32px;min-width:120px;text-align:center;box-shadow:0 4px 20px rgba(139,123,184,0.3)}
.ndis-pill .pn{font-family:var(--serif);font-size:26px;font-weight:600;color:#fff;line-height:1;letter-spacing:-0.02em}
.ndis-pill .pl{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-top:3px;font-weight:500}
.ndis-refer{margin-top:10px}
.btn-fill{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-fill: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(38px,4vw,52px);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;gap:0;padding:32px 40px 48px}
.step-arrow{display:flex;align-items:center;justify-content:center;padding:0 8px;color:rgba(139,123,184,0.45);font-size:24px;flex-shrink:0;margin-top:-20px}
.step{padding:36px 32px;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:52px;font-weight:600;color:rgba(139,123,184,0.18);line-height:1;margin-bottom:12px;letter-spacing:-0.02em;transition:color .3s}
.step:hover .step-num{color:rgba(139,123,184,0.45)}
.step-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:8px}
.step-body{font-size:13px;color:var(--mid);line-height:1.75;font-weight:300}

/* ── STATS BUBBLES ── */
.stats{display:flex;gap:20px;padding:48px 40px;background:var(--charcoal);border-bottom:1px solid rgba(255,255,255,0.07);flex-wrap:wrap}
.stat-b{flex:1;min-width:160px;padding:40px 32px;border-radius:24px;background:var(--white);border:1px solid rgba(255,255,255,0.1);transition:transform .35s cubic-bezier(0.22,1,0.36,1),box-shadow .35s}
.stat-b:hover{transform:translateY(-7px) scale(1.02);box-shadow:0 24px 48px rgba(0,0,0,0.5)}
.sb-num{font-family:var(--serif);font-size:44px;font-weight:600;line-height:1;color:var(--ink);letter-spacing:-0.02em;margin-bottom:5px}
.sb-num span{color:var(--purple);font-weight:300;font-size:28px}
.sb-label{font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--mid)}

/* ── 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(46px,5vw,62px);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)}