/* ===========================================================
   Care Coaching Melbourne — Components / Sections
   =========================================================== */

/* ---------- Top utility bar ---------- */
.topbar { background: var(--ink); color: #cddbe2; font-size: .86rem; }
.topbar__in { display: flex; align-items: center; justify-content: space-between; gap: 18px; height: 42px; }
.topbar__list { display: flex; align-items: center; gap: 22px; flex-wrap: wrap; }
.topbar a { display: inline-flex; align-items: center; gap: 8px; color: #cddbe2; font-weight: 500; }
.topbar a:hover { color: #fff; }
.topbar svg { width: 15px; height: 15px; color: var(--ndis-lime); }
.topbar__right { display: flex; align-items: center; gap: 18px; }
.topbar__badge { display: inline-flex; align-items: center; gap: 8px; color: #fff; font-weight: 600; }
.topbar__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ndis-lime); box-shadow: 0 0 0 4px rgba(140,198,63,.18); }
@media (max-width: 860px){ .topbar { display: none; } }

/* ---------- Header ---------- */
.header { position: sticky; top: 0; z-index: 60; background: rgba(255,255,255,.86); backdrop-filter: blur(12px); border-bottom: 1px solid transparent; transition: box-shadow .25s ease, border-color .25s ease, background .25s; }
.header.is-stuck { box-shadow: 0 6px 24px rgba(20,50,70,.08); border-color: var(--line-2); }
.header__in { display: flex; align-items: center; justify-content: space-between; gap: 20px; height: 76px; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand img { height: 46px; width: auto; }
.brand__txt { display: flex; flex-direction: column; line-height: 1.05; white-space: nowrap; }
.brand__name { font-weight: 800; font-size: 1.18rem; letter-spacing: -.02em; }
.brand__name b1 { color: var(--blue); } .brand__name b2 { color: var(--green-700); }
.brand__tag { font-size: .72rem; color: var(--muted); font-weight: 600; letter-spacing: .01em; }
@media (max-width: 520px){ .brand__name { font-size: 1rem; letter-spacing: -.01em; } }

.brand-with-badge { display: flex; align-items: center; gap: 14px; }
.brand-divider { width: 1px; height: 34px; background: var(--line); flex: none; }
.brand__ndis-inline { height: 38px; width: auto; }
@media (max-width: 860px){ .brand-divider, .brand__ndis-inline { display: none; } }

.nav { display: flex; align-items: center; gap: 1px; }
.nav a { padding: 9px 11px; border-radius: 10px; font-weight: 600; font-size: .95rem; color: var(--ink-2); white-space: nowrap; transition: background .15s, color .15s; }
.nav a:hover { background: var(--blue-tint); color: var(--blue-700); }
.nav a.active { color: var(--blue-700); }

.header__cta { display: flex; align-items: center; gap: 12px; }
.header__ndis { height: 38px; width: auto; }
@media (max-width: 1340px){ .header__ndis { display: none; } }

.burger { display: none; width: 46px; height: 46px; border-radius: 12px; border: 1px solid var(--line); background: #fff; cursor: pointer; align-items: center; justify-content: center; }
.burger svg { width: 24px; height: 24px; color: var(--ink); }

@media (max-width: 1240px){
  .nav, .header__cta .btn span.lbl { display: none; }
  .header__cta .header__ndis { display: none; }
  .header__cta .btn { display: none; }
  .burger { display: inline-flex; }
}

/* mobile menu */
.mmenu { position: fixed; inset: 0; z-index: 80; background: rgba(16,37,48,.5); opacity: 0; visibility: hidden; transition: opacity .25s; overflow: hidden; }
.mmenu.open { opacity: 1; visibility: visible; }
.mmenu__panel { position: absolute; top: 0; right: 0; height: 100%; width: min(360px, 88vw); background: #fff; padding: 24px; transform: translateX(100%); transition: transform .3s cubic-bezier(.3,.8,.3,1); display: flex; flex-direction: column; gap: 6px; overflow-y: auto; }
.mmenu.open .mmenu__panel { transform: none; }
.mmenu__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.mmenu__panel a.mlink { padding: 14px 14px; border-radius: 12px; font-weight: 600; font-size: 1.05rem; color: var(--ink); border-bottom: 1px solid var(--line-2); }
.mmenu__panel a.mlink:hover { background: var(--blue-tint); }
.mclose { width: 44px; height: 44px; border-radius: 12px; border: 1px solid var(--line); background: #fff; cursor: pointer; }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; background:
   radial-gradient(120% 90% at 85% -10%, var(--green-tint) 0%, transparent 45%),
   radial-gradient(110% 80% at 0% 0%, var(--blue-tint) 0%, transparent 42%),
   #fff; }
.hero__in { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(32px, 5vw, 72px); align-items: center; padding-block: clamp(52px, 7vw, 96px); }
.hero__badgepill { margin-bottom: 22px; }
.hero h1 { font-size: clamp(2.2rem, 4vw, 3.4rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.16; }
.hero h1 .g { color: var(--blue); }
.hero__sub { margin-top: 28px; font-size: clamp(1.06rem, 1.4vw, 1.2rem); color: var(--muted); max-width: 560px; }
.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 32px; }
.hero__trust { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 30px; }
.hero__trust .pill { background: rgba(255,255,255,.7); }

/* hero visual */
.hero__visual { position: relative; }
.hero__img { aspect-ratio: 4/4.4; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); object-fit: cover; width: 100%; display: block; }
.hero__float {
  position: absolute; background: #fff; border-radius: 18px; box-shadow: var(--shadow);
  border: 1px solid var(--line); padding: 16px 18px;
}
.hero__float--reg { left: -28px; bottom: 56px; display: flex; align-items: center; gap: 13px; max-width: 270px; }
.hero__float--reg img { height: 50px; width: auto; }
.hero__float--reg .t { font-size: .8rem; color: var(--muted); font-weight: 600; }
.hero__float--reg .b { font-size: 1rem; font-weight: 800; color: var(--ink); }
.hero__float--stat { right: -22px; top: 40px; text-align: left; min-width: 150px; }
.hero__float--stat .n { font-size: 1.7rem; font-weight: 800; color: var(--green-700); letter-spacing: -.02em; }
.hero__float--stat .l { font-size: .82rem; color: var(--muted); font-weight: 600; }
.hero__ndisbadge { position: absolute; right: 16px; bottom: -18px; height: 84px; background: #fff; padding: 10px 16px; border-radius: 16px; box-shadow: var(--shadow); border: 1px solid var(--line); }

@media (max-width: 900px){
  .hero__in { grid-template-columns: 1fr; }
  .hero__visual { order: -1; max-width: 520px; }
  .hero__float--reg { left: 0; }
  .hero__float--stat { right: 0; }
}

/* ---------- Trust strip ---------- */
.trustrip { border-top: 1px solid var(--line-2); border-bottom: 1px solid var(--line-2); background: #fff; }
.trustrip__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.trustrip__item { display: flex; align-items: center; gap: 14px; padding: 26px clamp(14px, 2.4vw, 30px); border-right: 1px solid var(--line-2); }
.trustrip__item:last-child { border-right: 0; }
.trustrip__n { font-size: 1.7rem; font-weight: 800; letter-spacing: -.02em; color: var(--ink); }
.trustrip__l { font-size: .9rem; color: var(--muted); font-weight: 600; line-height: 1.3; }
.trustrip__ic { color: var(--blue); }
.trustrip__ic svg { width: 30px; height: 30px; }
@media (max-width: 760px){ .trustrip__grid { grid-template-columns: repeat(2, 1fr); } .trustrip__item:nth-child(2){ border-right: 0; } .trustrip__item:nth-child(1),.trustrip__item:nth-child(2){ border-bottom: 1px solid var(--line-2); } }

/* ---------- Who we are split ---------- */
.split { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 72px); align-items: center; }
.split--rev .split__media { order: 2; }
@media (max-width: 900px){ .split { grid-template-columns: 1fr; } .split--rev .split__media { order: 0; } }

/* ---------- Who We Are — 3-column ---------- */
.who3 { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(0,1.5fr) minmax(0,0.95fr); gap: clamp(24px,3.2vw,52px); align-items: stretch; }
.who3__photos { min-height: 420px; }
.who3__photo { display: block; width: 100%; height: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); object-fit: cover; }
.who3__body { }
.who3__cards { display: flex; flex-direction: column; gap: 14px; }
/* Tablet: photos stacks under content on left */
@media (max-width: 1100px) {
  .who3 { grid-template-columns: 1fr 1fr; }
  .who3__photos { grid-column: 1; grid-row: 1; }
  .who3__body  { grid-column: 2; grid-row: 1 / 3; }
  .who3__cards { grid-column: 1; grid-row: 2; }
}
/* Mobile: single column — content → photos → cards */
@media (max-width: 700px) {
  .who3 { grid-template-columns: 1fr; gap: 28px; align-items: start; }
  .who3__body  { order: 1; grid-column: auto; grid-row: auto; }
  .who3__photos { order: 2; grid-column: auto; grid-row: auto; min-height: auto; }
  .who3__cards { order: 3; grid-column: auto; grid-row: auto; }
  .who3__photo { height: 280px; width: 100%; }
}
.who__quote { margin-top: 26px; padding: 22px 24px; border-radius: var(--radius); background: var(--blue-tint-2); border: 1px solid var(--line); border-left: 4px solid var(--blue); }
.who__quote p { font-size: 1.08rem; color: var(--ink-2); font-weight: 500; }
.who__media { aspect-ratio: 5/5.6; }
.who__media-duo { position: relative; width: 100%; aspect-ratio: 9/10; }
.who__media-duo__a { position: absolute; top: 0; left: 0; width: 68%; height: 80%; border-radius: 20px; box-shadow: var(--shadow-lg); }
.who__media-duo__b { position: absolute; bottom: 0; right: 0; width: 60%; height: 70%; border-radius: 18px; box-shadow: var(--shadow-lg); border: 5px solid #fff; z-index: 2; }
.who__chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 26px; }
.who__pillars { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 20px; }
.who__pillars .wp { display: inline-flex; align-items: center; gap: 9px; font-size: .9rem; font-weight: 700; color: var(--green-700); padding: 10px 16px; background: var(--green-tint); border: 1px solid #d9ecd0; border-radius: var(--radius-pill); }
.who__pillars .wp svg { width: 15px; height: 15px; color: var(--green-600); }
.who__values { margin-top: 24px; display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 560px){ .who__values { grid-template-columns: 1fr; } }
.wv { display: flex; gap: 14px; align-items: flex-start; padding: 18px; background: var(--bg); border-radius: var(--radius-sm); border: 1px solid var(--line-2); }
.wv .ichip { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; flex: none; }
.wv .ichip svg { width: 22px; height: 22px; }
.wv b { display: block; font-size: .98rem; color: var(--ink); font-weight: 700; }
.wv div > span { display: block; font-size: .9rem; color: var(--muted); margin-top: 3px; line-height: 1.45; }

/* directors */
.people { display: flex; gap: 14px; margin-top: 28px; flex-wrap: wrap; }
.person { display: flex; align-items: center; gap: 12px; padding: 12px 16px 12px 12px; border-radius: var(--radius-pill); border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow-sm); }
.person__av { width: 44px; height: 44px; border-radius: 50%; background: var(--blue-tint); color: var(--blue-700); display: grid; place-items: center; font-weight: 800; }
.person__n { font-weight: 700; font-size: .95rem; }
.person__r { font-size: .8rem; color: var(--muted); }

/* ---------- Services grid ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; margin-top: 48px; align-items: start; }
@media (max-width: 1000px){ .svc-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .svc-grid { grid-template-columns: 1fr; } }
.svc { padding: 26px; display: flex; flex-direction: column; gap: 14px; }
.svc h3 { font-size: 1.16rem; }
.svc > p { font-size: .96rem; color: var(--muted); flex: 1; }

/* ---------- Services card hover (modal replaces inline expand) ---------- */
.svc--expand { cursor: default; transition: transform .25s ease, box-shadow .25s ease; min-width: 0; overflow: hidden; }
@media (hover: hover) {
  .svc--expand:hover { transform: translateY(-4px); box-shadow: 0 16px 48px rgba(20,50,70,.12), 0 4px 16px rgba(20,50,70,.07); }
}
/* Detail div is a hidden data container — content shown in modal */
.svc__detail { display: none; }
.svc__img { display: block; width: 100%; aspect-ratio: 16/10; margin-top: 4px; object-fit: cover; border-radius: 12px; }
.svc__detail-txt { font-size: .9rem; color: var(--muted); line-height: 1.6; margin-top: 10px; }
.svc__more { background: none; border: none; padding: 0; font-family: inherit; font-size: .93rem; cursor: pointer; color: var(--blue-700); font-weight: 700; display: inline-flex; align-items: center; gap: 6px; margin-top: auto; }
.svc__more:hover { color: var(--blue); }
.svc__arrow { width: 17px; height: 17px; flex-shrink: 0; }

/* ---------- Service detail modal ---------- */
.svc-modal-overlay {
  position: fixed; inset: 0; z-index: 200;
  background: rgba(16,37,48,.62);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: clamp(16px, 4vw, 48px);
  opacity: 0; visibility: hidden;
  transition: opacity .25s ease, visibility .25s;
}
.svc-modal-overlay.open { opacity: 1; visibility: visible; }
.svc-modal__panel {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: 0 28px 80px rgba(16,37,48,.28), 0 8px 24px rgba(16,37,48,.14);
  width: 100%; max-width: 660px;
  max-height: calc(100dvh - 64px);
  overflow-y: auto;
  position: relative;
  transform: scale(.96) translateY(16px);
  transition: transform .32s cubic-bezier(.3,.8,.3,1);
}
.svc-modal-overlay.open .svc-modal__panel { transform: none; }
.svc-modal__close {
  position: absolute; top: 14px; right: 14px; z-index: 3;
  width: 42px; height: 42px; border-radius: 50%;
  background: rgba(255,255,255,.96); border: 1px solid var(--line);
  box-shadow: var(--shadow-sm);
  display: grid; place-items: center; cursor: pointer;
  transition: background .15s, transform .15s;
}
.svc-modal__close:hover { background: #fff; transform: scale(1.1); }
.svc-modal__close svg { width: 18px; height: 18px; color: var(--ink); }
.svc-modal__img {
  display: block; width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
}
.svc-modal__body { padding: clamp(24px, 3.2vw, 38px); }
.svc-modal__ichip-wrap { margin-bottom: 16px; }
.svc-modal__ichip-wrap .ichip { width: 52px; height: 52px; border-radius: 15px; }
.svc-modal__ichip-wrap .ichip svg { width: 26px; height: 26px; }
.svc-modal__title {
  font-size: clamp(1.35rem, 2.6vw, 1.8rem);
  font-weight: 800; letter-spacing: -.025em; color: var(--ink);
  margin-bottom: 14px;
}
.svc-modal__text { font-size: 1.05rem; color: var(--muted); line-height: 1.72; max-width: 58ch; }
@media (max-width: 560px) {
  .svc-modal-overlay { padding: 0; align-items: flex-end; }
  .svc-modal__panel {
    max-width: 100%; border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    max-height: 90dvh;
    transform: translateY(100%);
  }
  .svc-modal-overlay.open .svc-modal__panel { transform: none; }
}

/* ---------- Why choose (feature grid) ---------- */
.feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 48px; }
@media (max-width: 1000px){ .feat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .feat-grid { grid-template-columns: 1fr; } }
.feat { padding: 24px; display: flex; flex-direction: column; gap: 12px; }
.feat h3 { font-size: 1.04rem; }
.feat p { font-size: .92rem; color: var(--muted); }

/* ---------- Onboarding journey (premium, interactive) ---------- */
.journey { margin-top: 56px; }
.journey__rail { position: relative; display: grid; grid-template-columns: repeat(7, 1fr); gap: 0; margin-bottom: 30px; }
.jnode { position: relative; display: flex; flex-direction: column; align-items: center; gap: 9px; padding: 4px 6px 0; background: none; border: 0; cursor: pointer; font-family: inherit; }
.jnode::before { content: ""; position: absolute; top: 28px; right: 50%; left: -50%; height: 3px; background: var(--line); z-index: 0; transition: background .4s ease; }
.jnode:first-child::before { display: none; }
.jnode.reached::before { background: linear-gradient(90deg, var(--blue), var(--green)); }
.jnode__dot { position: relative; z-index: 1; width: 58px; height: 58px; border-radius: 50%; display: grid; place-items: center; background: #fff; color: var(--muted); border: 2px solid var(--line); transition: transform .25s ease, background .25s, border-color .25s, color .25s, box-shadow .25s; }
.jnode__dot svg { width: 25px; height: 25px; }
.jnode.done .jnode__dot { background: var(--green); border-color: var(--green); color: #fff; }
.jnode.active .jnode__dot { background: var(--blue); border-color: var(--blue); color: #fff; transform: scale(1.12); box-shadow: 0 0 0 6px rgba(27,117,188,.16), var(--shadow); }
.jnode:hover .jnode__dot { border-color: var(--blue); color: var(--blue); }
.jnode.active:hover .jnode__dot { color: #fff; }
.jnode__num { font-size: .72rem; font-weight: 800; letter-spacing: .08em; color: var(--muted-2); transition: color .25s; }
.jnode.active .jnode__num { color: var(--blue-700); }
.jnode.done .jnode__num { color: var(--green-700); }
.jnode__lbl { font-size: .8rem; font-weight: 700; color: var(--ink-2); text-align: center; line-height: 1.25; max-width: 13ch; }
.jnode.active .jnode__lbl { color: var(--blue-700); }

.journey__card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); overflow: hidden; }
.jcard__inner { display: grid; grid-template-columns: 280px 1fr; min-height: 300px; animation: jfade .4s ease; }
@keyframes jfade { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }
.jcard__side { background:
   radial-gradient(120% 100% at 0% 0%, rgba(255,255,255,.14), transparent 60%),
   linear-gradient(160deg, var(--blue) 0%, var(--blue-700) 100%);
   color: #fff; padding: clamp(28px, 3vw, 40px); display: flex; flex-direction: column; justify-content: space-between; gap: 20px; position: relative; overflow: hidden; }
.jcard__side.tone-green { background: linear-gradient(160deg, var(--green) 0%, var(--green-700) 100%); }
.jcard__icon { width: 80px; height: 80px; border-radius: 22px; background: rgba(255,255,255,.2); display: grid; place-items: center; box-shadow: 0 0 0 10px rgba(255,255,255,.08); }
.jcard__icon svg { width: 40px; height: 40px; color: #fff; }
.jcard__side-lbl { font-size: 1rem; font-weight: 700; opacity: .85; line-height: 1.3; max-width: 14ch; margin-top: 18px; }
.jcard__stepno { }
.jcard__stepno .big { font-size: 3.4rem; font-weight: 800; line-height: 1; letter-spacing: -.03em; }
.jcard__stepno .of { font-size: .92rem; opacity: .8; font-weight: 600; margin-top: 4px; }
.jcard__body { padding: clamp(28px, 3.4vw, 44px); display: flex; flex-direction: column; }
.jcard__body .kicker { font-size: .8rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--green-700); }
.jcard__body h3 { font-size: clamp(1.5rem, 2.4vw, 2.1rem); margin-top: 10px; letter-spacing: -.02em; }
.jcard__body p { margin-top: 16px; color: var(--muted); font-size: 1.08rem; max-width: 60ch; }
.jcard__tags { margin-top: 22px; display: flex; flex-wrap: wrap; gap: 9px; }
.jcard__tags .t { display: inline-flex; align-items: center; gap: 8px; padding: 8px 14px; border-radius: 999px; background: var(--blue-tint-2); border: 1px solid var(--line); font-size: .86rem; font-weight: 600; color: var(--ink-2); }
.jcard__tags .t svg { width: 15px; height: 15px; color: var(--green-600); }
.jcard__nav { margin-top: auto; padding-top: 28px; display: flex; align-items: center; gap: 14px; }
.jcard__nav .spacer { flex: 1; }
.jdots { display: flex; gap: 7px; }
.jdots button { width: 9px; height: 9px; border-radius: 50%; border: 0; padding: 0; background: var(--line); cursor: pointer; transition: background .2s, transform .2s; }
.jdots button.on { background: var(--blue); transform: scale(1.25); }
.jbtn { width: 48px; height: 48px; border-radius: 50%; border: 1.5px solid var(--line); background: #fff; display: grid; place-items: center; cursor: pointer; color: var(--ink); transition: all .18s; }
.jbtn:hover:not(:disabled) { border-color: var(--blue); color: var(--blue); transform: translateY(-2px); }
.jbtn:disabled { opacity: .4; cursor: default; }
.jbtn svg { width: 20px; height: 20px; }
.jbtn--next { background: var(--blue); color: #fff; border-color: var(--blue); box-shadow: var(--shadow-blue); }
.jbtn--next:hover:not(:disabled) { background: var(--blue-600); color: #fff; }

@media (max-width: 860px){
  .journey__rail { grid-template-columns: repeat(7, 1fr); overflow-x: auto; gap: 0; padding-bottom: 8px; }
  .jnode__lbl { display: none; }
  .jcard__inner { grid-template-columns: 1fr; }
  .jcard__side { flex-direction: row; align-items: center; padding: 22px 24px; }
  .jcard__stepno .big { font-size: 2.4rem; }
}
@media (max-width: 540px){
  .journey__rail { grid-template-columns: repeat(7, minmax(52px, 1fr)); }
  .jnode__dot { width: 46px; height: 46px; }
  .jnode__dot svg { width: 20px; height: 20px; }
  .jnode::before { top: 22px; }
  .jnode__num { display: none; }
}

/* ---------- Complex needs ---------- */
.complex { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 60px); align-items: start; }
@media (max-width: 900px){ .complex { grid-template-columns: 1fr; } }
.docgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 26px; }
.docitem { display: flex; align-items: center; gap: 11px; padding: 13px 15px; background: #fff; border: 1px solid var(--line); border-radius: 12px; font-size: .92rem; font-weight: 600; color: var(--ink-2); }
.docitem svg { width: 18px; height: 18px; color: var(--blue); flex: none; }
.decide { background: var(--ink); color: #d3e1e8; border-radius: var(--radius); padding: clamp(26px,3vw,38px); }
.decide h3 { color: #fff; }
.decide__list { margin-top: 18px; display: flex; flex-direction: column; gap: 14px; }
.decide__list li { display: flex; gap: 13px; align-items: flex-start; font-size: .98rem; }
.decide__list .dot { width: 26px; height: 26px; border-radius: 50%; flex: none; display: grid; place-items: center; background: rgba(140,198,63,.18); color: var(--ndis-lime); }
.decide__list .dot svg { width: 15px; height: 15px; }

/* ---------- Care App ---------- */
.careapp { position: relative; overflow: hidden; background:
  radial-gradient(100% 120% at 100% 0%, rgba(106,44,132,.10) 0%, transparent 50%),
  linear-gradient(180deg, #122a3a 0%, #0f2230 100%); color: #d6e4ec; }
.careapp__in { display: grid; grid-template-columns: 1fr .85fr; gap: clamp(32px, 5vw, 64px); align-items: center; }
@media (max-width: 900px){ .careapp__in { grid-template-columns: 1fr; } }
.careapp h2 { color: #fff; }
.careapp .lede { color: #a9c2d0; }
.careapp__soon { display: inline-flex; align-items: center; gap: 9px; padding: 8px 16px; border-radius: 999px; background: rgba(140,198,63,.15); color: var(--ndis-lime); font-weight: 700; font-size: .82rem; letter-spacing: .06em; text-transform: uppercase; }
.feat2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 26px; margin-top: 30px; }
@media (max-width: 540px){ .feat2 { grid-template-columns: 1fr; } }
.feat2 li { display: flex; gap: 12px; align-items: flex-start; font-size: .97rem; color: #cadae3; }
.feat2 .ic { width: 30px; height: 30px; border-radius: 9px; flex: none; display: grid; place-items: center; background: rgba(255,255,255,.08); color: var(--ndis-lime); }
.feat2 .ic svg { width: 17px; height: 17px; }

/* phone mock — branded Care App preview */
.phone { position: relative; width: 296px; margin-inline: auto; aspect-ratio: 296/610; background: linear-gradient(145deg, #1a2b38, #0b1a24); border-radius: 46px; padding: 13px; box-shadow: 0 40px 90px rgba(11,26,36,.5), inset 0 0 0 2px rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); }
.phone::before { content: ""; position: absolute; left: -3px; top: 120px; width: 3px; height: 56px; border-radius: 3px 0 0 3px; background: linear-gradient(#2a3b48, #14222d); }
.phone::after { content: ""; position: absolute; right: -3px; top: 104px; width: 3px; height: 36px; border-radius: 0 3px 3px 0; background: linear-gradient(#2a3b48, #14222d); }
.phone__screen { width: 100%; height: 100%; border-radius: 34px; background: #f3f7fb; overflow: hidden; position: relative; display: flex; flex-direction: column; }
.phone__notch { position: absolute; top: 11px; left: 50%; transform: translateX(-50%); width: 96px; height: 26px; background: #0b1a24; border-radius: 999px; z-index: 5; }

.appstatus { display: flex; align-items: center; justify-content: space-between; padding: 12px 22px 4px; font-size: .7rem; font-weight: 700; color: var(--ink); }
.appstatus__ic { display: inline-flex; gap: 3px; align-items: flex-end; }
.appstatus__ic i { width: 4px; height: 9px; border-radius: 1px; background: var(--ink); display: inline-block; opacity: .85; }
.appstatus__ic i:nth-child(2){ height: 11px; } .appstatus__ic i:nth-child(3){ height: 7px; opacity: .5; }

.appbar2 { display: flex; align-items: center; justify-content: space-between; padding: 8px 16px 12px; background: #fff; border-bottom: 1px solid var(--line-2); }
.appbar2__brand { display: flex; align-items: center; gap: 8px; }
.appbar2__brand img { height: 24px; width: auto; }
.appbar2__name { font-weight: 800; font-size: 1rem; letter-spacing: -.01em; color: var(--blue); }
.appbar2__name { color: var(--blue); }
.appbell { width: 32px; height: 32px; border-radius: 10px; background: var(--blue-tint); color: var(--blue); display: grid; place-items: center; }
.appbell svg { width: 16px; height: 16px; }

.appfeed { padding: 14px; display: flex; flex-direction: column; gap: 11px; overflow: hidden; background: #f3f7fb; flex: 1; }
.appgreet .hi { font-size: .74rem; color: var(--muted); font-weight: 600; }
.appgreet .nm { font-weight: 800; font-size: 1.04rem; color: var(--ink); letter-spacing: -.01em; }

.acard { background: #fff; border-radius: 14px; padding: 12px; box-shadow: 0 4px 14px rgba(20,50,70,.06); display: flex; gap: 11px; align-items: flex-start; }
.acard--hero { background: linear-gradient(120deg, var(--green-tint) 0%, #fff 70%); border: 1px solid #d9ecd0; }
.acard__ic { width: 34px; height: 34px; border-radius: 10px; flex: none; display: grid; place-items: center; }
.acard__ic.b { background: var(--blue-tint); color: var(--blue); }
.acard__ic.g { background: var(--green); color: #fff; }
.acard__ic.p { background: var(--purple-tint); color: var(--purple); }
.acard__ic svg { width: 18px; height: 18px; }
.acard .tt { font-weight: 700; font-size: .82rem; color: var(--ink); }
.acard .ss { font-size: .72rem; color: var(--muted); margin-top: 2px; line-height: 1.35; }
.acard .time { font-size: .64rem; color: var(--muted-2); margin-top: 5px; font-weight: 600; }

.ashift { background: #fff; border-radius: 16px; padding: 12px; box-shadow: 0 4px 14px rgba(20,50,70,.06); }
.ashift__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 9px; }
.ashift__lbl { font-size: .72rem; font-weight: 800; color: var(--ink-2); letter-spacing: .02em; white-space: nowrap; }
.ashift__pill { display: inline-flex; align-items: center; gap: 5px; font-size: .64rem; font-weight: 800; color: var(--green-700); background: var(--green-tint); padding: 4px 9px; border-radius: 999px; white-space: nowrap; }
.ashift__pill i { width: 6px; height: 6px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 3px rgba(90,168,59,.2); }
.ashift__map { height: 96px; border-radius: 12px; overflow: hidden; }
.ashift__map svg { width: 100%; height: 100%; display: block; }
.ashift__worker { display: flex; align-items: center; gap: 10px; margin-top: 11px; }
.ashift__av { width: 34px; height: 34px; border-radius: 50%; background: var(--blue-tint); color: var(--blue); display: grid; place-items: center; flex: none; }
.ashift__av svg { width: 18px; height: 18px; }
.ashift__wt { flex: 1; }
.ashift__wt .tt { font-weight: 700; font-size: .8rem; color: var(--ink); }
.ashift__wt .ss { font-size: .7rem; color: var(--muted); margin-top: 1px; }
.ashift__on { color: var(--green); font-size: .7rem; }
.ashift__msg { margin-top: 11px; width: 100%; border: 0; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 11px; border-radius: 12px; background: linear-gradient(120deg, var(--blue) 0%, var(--green) 150%); color: #fff; font-family: inherit; font-weight: 700; font-size: .82rem; box-shadow: 0 6px 16px rgba(27,117,188,.25); }
.ashift__msg svg { width: 15px; height: 15px; }

/* ---------- Quality / compliance ---------- */
.qual-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 44px; }
@media (max-width: 880px){ .qual-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .qual-grid { grid-template-columns: 1fr; } }
.qitem { display: flex; align-items: center; gap: 12px; padding: 16px 18px; background: #fff; border: 1px solid var(--line); border-radius: 14px; font-weight: 600; font-size: .95rem; color: var(--ink-2); transition: border-color .18s, transform .18s; }
.qitem:hover { border-color: #cfe5d6; transform: translateY(-2px); }
.qitem .ck { width: 24px; height: 24px; border-radius: 7px; background: var(--green-tint); color: var(--green-700); display: grid; place-items: center; flex: none; }
.qitem .ck svg { width: 15px; height: 15px; }

/* systems */
.sys-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 40px; }
@media (max-width: 900px){ .sys-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 480px){ .sys-grid { grid-template-columns: 1fr; } }
.sys { padding: 22px; text-align: left; }
.sys h4 { font-size: 1.02rem; font-weight: 700; margin-top: 14px; }
.sys p { font-size: .88rem; color: var(--muted); margin-top: 6px; }

/* ---------- Providers marquee ---------- */
.prov-grid { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 28px; }
.prov-tag { padding: 10px 16px; border-radius: 999px; background: #fff; border: 1px solid var(--line); font-weight: 600; font-size: .92rem; color: var(--ink-2); box-shadow: var(--shadow-sm); }

/* ---------- CTA band ---------- */
.ctaband { position: relative; overflow: hidden; border-radius: var(--radius-lg); padding: clamp(40px, 5vw, 68px); background:
  radial-gradient(120% 140% at 0% 0%, rgba(140,198,63,.22) 0, transparent 50%),
  linear-gradient(120deg, var(--blue) 0%, var(--blue-700) 100%); color: #fff; box-shadow: var(--shadow-lg); }
.ctaband h2 { color: #fff; }
.ctaband p { color: rgba(255,255,255,.85); margin-top: 14px; max-width: 52ch; }
.ctaband__row { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }

/* ---------- Referral form ---------- */
.form-shell { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(28px,4vw,56px); align-items: start; }
@media (max-width: 940px){ .form-shell { grid-template-columns: 1fr; } }
.form-aside .pill { margin-top: 10px; }
.contact-list { margin-top: 28px; display: flex; flex-direction: column; gap: 14px; }
.contact-row { display: flex; align-items: center; gap: 14px; }
.contact-row .ic { width: 46px; height: 46px; border-radius: 13px; background: var(--blue-tint); color: var(--blue); display: grid; place-items: center; flex: none; }
.contact-row .ic svg { width: 21px; height: 21px; }
.contact-row .t { font-size: .8rem; color: var(--muted); font-weight: 600; }
.contact-row .v { font-weight: 700; color: var(--ink); white-space: nowrap; }

.formcard { background: #fff; border: 1px solid var(--line); border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: clamp(24px, 3vw, 40px); }
.steps-head { display: flex; align-items: center; gap: 8px; margin-bottom: 26px; }
.steps-head .sdot { flex: 1; height: 6px; border-radius: 999px; background: var(--line); transition: background .3s; }
.steps-head .sdot.on { background: var(--blue); }
.fstep { display: none; animation: fade .35s ease; }
.fstep.show { display: block; }
@keyframes fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.fgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 540px){ .fgrid { grid-template-columns: 1fr; } }
.field { display: flex; flex-direction: column; gap: 7px; }
.field.full { grid-column: 1 / -1; }
.field label { font-size: .86rem; font-weight: 700; color: var(--ink-2); }
.field label .req { color: var(--green-700); }
.field input, .field select, .field textarea {
  font-family: inherit; font-size: .98rem; color: var(--ink); padding: 13px 15px;
  border: 1.5px solid var(--line); border-radius: 12px; background: #fff; width: 100%; transition: border-color .15s, box-shadow .15s;
}
.field textarea { resize: vertical; min-height: 110px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--blue); box-shadow: var(--ring); }
.field input.err, .field select.err { border-color: #e0564f; box-shadow: 0 0 0 4px rgba(224,86,79,.12); }
.fhint { font-size: .8rem; color: var(--muted); }
.chips-row { display: flex; flex-wrap: wrap; gap: 9px; }
.chip-opt { position: relative; }
.chip-opt input { position: absolute; opacity: 0; }
.chip-opt span { display: inline-flex; padding: 10px 15px; border-radius: 999px; border: 1.5px solid var(--line); font-size: .9rem; font-weight: 600; color: var(--ink-2); cursor: pointer; transition: all .15s; }
.chip-opt input:checked + span { background: var(--blue); border-color: var(--blue); color: #fff; }
.chip-opt input:focus-visible + span { box-shadow: var(--ring); }
.consent { display: flex; gap: 12px; align-items: flex-start; padding: 16px; border-radius: 14px; background: var(--blue-tint-2); border: 1px solid var(--line); }
.consent input { margin-top: 3px; width: 20px; height: 20px; flex: none; accent-color: var(--blue); }
.consent label { font-size: .9rem; color: var(--ink-2); font-weight: 500; }
.form-actions { display: flex; justify-content: space-between; gap: 12px; margin-top: 26px; }
.form-done { text-align: center; padding: 24px 0; }
.form-done .tick { width: 76px; height: 76px; border-radius: 50%; background: var(--green-tint); color: var(--green-700); display: grid; place-items: center; margin: 0 auto 20px; }
.form-done .tick svg { width: 38px; height: 38px; }

/* ---------- Footer ---------- */
.footer { background: var(--ink); color: #9fb3bd; padding-top: clamp(56px, 6vw, 88px); }
.footer a { color: #c4d3db; }
.footer a:hover { color: #fff; }
.footer__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 48px; border-bottom: 1px solid rgba(255,255,255,.1); }
@media (max-width: 900px){ .footer__top { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 540px){ .footer__top { grid-template-columns: 1fr; } }
.footer__brand img { height: 52px; background: #fff; padding: 8px 12px; border-radius: 12px; }
.footer__brand .footer__logo-mark { height: 68px; padding: 10px; }
.footer__brand p { margin-top: 18px; font-size: .94rem; max-width: 36ch; }
.footer__badges { display: flex; gap: 10px; margin-top: 20px; align-items: center; }
.footer__badges img { height: 56px; background: #fff; padding: 6px 10px; border-radius: 10px; }
.footer h4 { color: #fff; font-size: .82rem; letter-spacing: .1em; text-transform: uppercase; margin-bottom: 16px; }
.footer__links { display: flex; flex-direction: column; gap: 11px; font-size: .95rem; }
.footer__contact { display: flex; flex-direction: column; gap: 14px; font-size: .94rem; }
.footer__contact .r { display: flex; gap: 11px; align-items: flex-start; }
.footer__contact svg { width: 17px; height: 17px; color: var(--ndis-lime); flex: none; margin-top: 3px; }
.footer__bottom { display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-block: 26px; font-size: .86rem; }
.footer__bottom .reg { display: inline-flex; align-items: center; gap: 8px; }
.footer__bottom .reg .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--ndis-lime); }

/* disclaimer */
.disclaimer { font-size: .82rem; color: var(--muted); max-width: 70ch; margin-top: 10px; }

/* image slots fill their layout cell + show a visible empty state */
image-slot.hero__img, image-slot.who__media {
  display: block; width: 100%; height: auto;
  background: repeating-linear-gradient(135deg, #e9f0f5 0 14px, #eef4f8 14px 28px);
  border: 1px solid var(--line);
}
image-slot.hero__img { aspect-ratio: 4 / 4.4; }
image-slot.who__media { aspect-ratio: 5 / 5.6; }

/* ===========================================================
   HERO STYLE VARIANTS (Tweaks)
   data-hero: clinical (default) | editorial | purple
   =========================================================== */

/* --- Calm / clinical (baseline, a touch airier) --- */
body[data-hero="clinical"] .hero {
  background:
    radial-gradient(120% 90% at 88% -12%, var(--green-tint) 0%, transparent 42%),
    radial-gradient(100% 75% at -4% -4%, var(--blue-tint) 0%, transparent 40%),
    #fff;
}
body[data-hero="clinical"] .hero h1 { font-weight: 800; }

/* --- Warm / editorial --- */
body[data-hero="editorial"] .hero {
  background:
    radial-gradient(125% 95% at 92% -10%, #f4ead9 0%, transparent 48%),
    radial-gradient(110% 80% at -6% 0%, #e9f1f8 0%, transparent 42%),
    #fbf7f0;
}
body[data-hero="editorial"] .hero h1 {
  font-family: "Newsreader", Georgia, "Times New Roman", serif;
  font-weight: 500; letter-spacing: -.015em; line-height: 1.08;
  font-size: clamp(2.5rem, 4.6vw, 4rem);
}
body[data-hero="editorial"] .hero h1 .g { color: var(--green-700); font-style: italic; font-weight: 500; }
body[data-hero="editorial"] .hero__sub { font-size: clamp(1.1rem, 1.5vw, 1.28rem); color: #5a5247; }
body[data-hero="editorial"] .hero__img { border-radius: 220px 220px var(--radius) var(--radius); }
body[data-hero="editorial"] .hero__badgepill { background: rgba(255,255,255,.75); border-color: #ecdfca; }
body[data-hero="editorial"] .hero__badgepill svg { color: var(--green-700); }
body[data-hero="editorial"] .hero__float--stat .n { color: var(--blue-700); }

/* --- Stronger NDIS purple accent --- */
body[data-hero="purple"] .hero {
  background:
    radial-gradient(125% 95% at 88% -12%, var(--purple-tint) 0%, transparent 46%),
    radial-gradient(105% 78% at -4% 0%, var(--blue-tint) 0%, transparent 40%),
    #fff;
}
body[data-hero="purple"] .hero h1 .g { color: var(--purple); }
body[data-hero="purple"] .hero__badgepill { background: var(--purple-tint-2); border-color: #e6d8ef; color: var(--purple-600); }
body[data-hero="purple"] .hero__badgepill svg { color: var(--purple); }
body[data-hero="purple"] .hero__cta .btn--primary { background: var(--purple); box-shadow: 0 10px 30px rgba(106,44,132,.26); }
body[data-hero="purple"] .hero__cta .btn--primary:hover { background: var(--purple-600); }
body[data-hero="purple"] .hero__trust .pill svg { color: var(--purple); }
body[data-hero="purple"] .hero__float--stat .n { color: var(--purple); }
body[data-hero="purple"] .hero__img { box-shadow: 0 10px 30px rgba(106,44,132,.12), 0 30px 70px rgba(106,44,132,.16); }

/* ===========================================================
   MOBILE POLISH (phones)
   =========================================================== */
@media (max-width: 560px){
  /* full-width, easy-tap primary CTAs */
  .btn { white-space: normal; text-align: center; }
  .hero__cta { flex-direction: column; align-items: stretch; gap: 12px; }
  .hero__cta .btn { width: 100%; }
  .ctaband { padding: 32px 22px; }
  .ctaband__row { gap: 12px; }
  .ctaband__row .btn { width: 100%; }
  /* a bit more air below the hero headline block */
  .hero__in { padding-block: 40px 56px; }
  /* slightly smaller floating cards so they don't crowd the photo */
  .hero__float--stat { display: none; }
  .hero__float--reg { padding: 10px 12px; gap: 10px; max-width: 210px; bottom: 16px; left: 8px; border-radius: 14px; }
  .hero__float--reg img { height: 34px; }
  .hero__float--reg .b { font-size: .86rem; }
  .hero__float--reg .t { font-size: .72rem; }
  /* journey: comfy card padding + readable copy */
  .jcard__body p { font-size: 1rem; }
  .jcard__nav { gap: 10px; }
  /* services / why: generous tap + spacing already single-col */
  .svc-grid, .feat-grid { margin-top: 32px; gap: 14px; }
  /* trust strip: stack label under number cleanly */
  .trustrip__grid > * { min-width: 0; }
  .trustrip__item { padding: 16px 12px; gap: 11px; }
  .trustrip__ic svg { width: 24px; height: 24px; }
  .trustrip__n { font-size: 1.18rem; }
  .trustrip__l { font-size: .8rem; }
  /* care app: keep phone centred with breathing room */
  .careapp__in { gap: 28px; }
  /* compliance + systems tighter top margins */
  .qual-grid { margin-top: 28px; }
  .sys-grid { margin-top: 26px; }
  /* contact: email can shrink rather than overflow */
  .contact-row .v { white-space: normal; word-break: break-word; }
  .contact-list .contact-row:first-child .v { white-space: nowrap; }
}
@media (max-width: 380px){
  .hero h1 { font-size: 1.95rem; }
  .section-head .lede, .lede { font-size: 1.04rem; }
}
