:root {
  --primary: #4f46e5;          /* indigo — trustworthy, premium education */
  --primary-press: #4338ca;
  --primary-soft: rgba(79, 70, 229, 0.10);
  --money: #047857;            /* emerald for salaries / positive */
  --bg: #f3f4fb;
  --surface: #ffffff;
  --surface-2: #fbfbff;
  --ink: #1a1c2e;
  --ink-2: #41445c;
  --ink-dim: #71748c;
  --hairline: rgba(20, 22, 46, 0.08);
  --glass: rgba(255, 255, 255, 0.72);
  --shadow-card: 0 10px 30px rgba(30, 32, 60, 0.08), 0 2px 6px rgba(30, 32, 60, 0.05);
  --shadow-soft: 0 4px 16px rgba(30, 32, 60, 0.06);
  --spring: linear(0,0.006,0.025 2.8%,0.101 6.1%,0.539 18.9%,0.721 25.3%,0.849 31.5%,0.937 38.1%,0.968 41.8%,0.991 45.7%,1.006 50.1%,1.015 55%,1.017 63.9%,1.001);
  --r: 20px;
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }

html, body {
  background: var(--bg);
  color: var(--ink);
  min-height: 100%;
  font-variant-numeric: tabular-nums;
  -webkit-font-smoothing: antialiased;
  overscroll-behavior-y: none;
}

/* soft light mesh ground */
.mesh {
  position: fixed; inset: -30%; z-index: -1;
  background:
    radial-gradient(40% 40% at 16% 12%, rgba(79,70,229,0.10), transparent 70%),
    radial-gradient(42% 42% at 86% 22%, rgba(16,185,129,0.09), transparent 70%),
    radial-gradient(50% 50% at 64% 92%, rgba(99,102,241,0.08), transparent 72%),
    var(--bg);
  filter: blur(30px);
  animation: drift 28s ease-in-out infinite alternate;
}
@keyframes drift { 0%{transform:translate(0,0) scale(1);} 50%{transform:translate(2%,-1.5%) scale(1.05);} 100%{transform:translate(-1.5%,2%) scale(1.03);} }
@media (prefers-reduced-motion: reduce){ .mesh{animation:none;} }

#app { max-width: 720px; margin: 0 auto; padding: 0 16px calc(40px + env(safe-area-inset-bottom)); }
.loading { color: var(--ink-dim); text-align: center; padding-top: 40vh; }

/* glass utility (light frosted) */
.glass {
  background: var(--glass);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.6);
  box-shadow: var(--shadow-soft);
}

/* ---- Top bar ---- */
.topbar { position: sticky; top: 0; z-index: 10; padding: calc(10px + env(safe-area-inset-top)) 4px 12px; margin: 0 -16px; border-radius: 0 0 26px 26px; }
.title { font-size: 32px; font-weight: 800; letter-spacing: -0.02em; padding: 6px 14px 12px; }
.title small { display:block; font-size: 13px; font-weight: 600; color: var(--ink-dim); letter-spacing: 0; margin-top: 2px; }

.search { display: flex; align-items: center; gap: 9px; margin: 0 12px; padding: 12px 14px; border-radius: 14px; background: var(--surface); border: 1px solid var(--hairline); }
.search input { background: none; border: none; outline: none; color: var(--ink); font-size: 17px; width: 100%; font-family: inherit; }
.search input::placeholder { color: var(--ink-dim); }
.search svg { flex: 0 0 18px; color: var(--ink-dim); }

/* ---- filter chip rows ---- */
.chiprow { display: flex; gap: 8px; overflow-x: auto; padding: 11px 12px 3px; margin: 0 -4px; scrollbar-width: none; }
.chiprow::-webkit-scrollbar { display: none; }
.chiprow.tier2 { padding-top: 4px; }
.chip {
  flex: 0 0 auto; padding: 8px 15px; border-radius: 100px; font-size: 13.5px; font-weight: 600; white-space: nowrap; cursor: pointer;
  background: var(--surface); border: 1px solid var(--hairline); color: var(--ink-2);
  transition: transform .35s var(--spring), background .2s, color .2s, border-color .2s;
}
.chip:active { transform: scale(0.94); }
.chip.on { background: var(--primary); color: #fff; border-color: transparent; box-shadow: 0 4px 12px rgba(79,70,229,0.3); }
.chip.path { display:inline-flex; align-items:center; gap:6px; }
.chip.path.on { background: var(--money); box-shadow: 0 4px 12px rgba(4,120,87,0.28); }

.count { color: var(--ink-dim); font-size: 13px; padding: 15px 12px 9px; font-weight: 600; }

/* ---- Cards ---- */
.cards { display: flex; flex-direction: column; gap: 13px; }
.card {
  background: var(--surface); border: 1px solid var(--hairline); border-radius: var(--r);
  padding: 16px 17px; cursor: pointer; box-shadow: var(--shadow-card);
  transition: transform .4s var(--spring); animation: rise .5s var(--spring) both;
}
.card:active { transform: scale(0.975); }
@keyframes rise { from{opacity:0;transform:translateY(14px) scale(0.98);} to{opacity:1;transform:none;} }
.card h2 { font-size: 17.5px; font-weight: 700; letter-spacing: -0.01em; display:flex; justify-content:space-between; align-items:center; gap:10px; }
.card h2 .chev { color: var(--ink-dim); font-size: 16px; }
.card p { color: var(--ink-dim); font-size: 14px; line-height: 1.4; margin-top: 4px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.card .meta { display: flex; gap: 8px; margin-top: 11px; flex-wrap: wrap; }
.pill { font-size: 11.5px; font-weight: 600; padding: 4px 9px; border-radius: 8px; display:inline-flex; align-items:center; gap:4px; }
.pill.cat { background: var(--primary-soft); color: var(--primary); }
.pill.pay { background: rgba(4,120,87,0.10); color: var(--money); }
.pill.path { background: rgba(20,22,46,0.05); color: var(--ink-2); }

/* ---- Detail ---- */
.detail { animation: fade .35s ease both; }
@keyframes fade { from{opacity:0;} to{opacity:1;} }
.back { position: sticky; top: 0; z-index: 10; display:inline-flex; align-items:center; gap:5px; margin: calc(10px + env(safe-area-inset-top)) 0 6px; padding: 9px 16px 9px 12px; border-radius:100px; font-size:15px; font-weight:600; color: var(--primary); cursor:pointer; width:fit-content; }

.hero { border-radius: 24px; padding: 20px; margin-top: 4px; }
.hero .kicker { color: var(--primary); font-size: 11.5px; font-weight: 800; letter-spacing:0.07em; text-transform:uppercase; }
.hero h1 { font-size: 27px; font-weight: 800; letter-spacing:-0.02em; margin: 6px 0 8px; line-height: 1.08; }
.hero .summary { color: var(--ink-2); font-size: 15px; line-height: 1.45; }
.hero .demand { display:inline-flex; align-items:center; gap:6px; margin-top:12px; color: var(--money); font-weight:600; font-size:13.5px; background: rgba(4,120,87,0.09); padding: 6px 11px; border-radius: 100px; }

/* quick-glance stat strip */
.glance { display:flex; gap:10px; margin-top:14px; }
.glance .g { flex:1; background: var(--surface); border:1px solid var(--hairline); border-radius:14px; padding:11px 12px; box-shadow: var(--shadow-soft); }
.glance .g .v { font-size:18px; font-weight:800; color: var(--ink); letter-spacing:-0.01em; }
.glance .g .v.money { color: var(--money); }
.glance .g .k { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color: var(--ink-dim); margin-top:2px; }

/* ---- Accordion ---- */
.acc { background: var(--surface); border:1px solid var(--hairline); border-radius: var(--r); margin-top: 12px; box-shadow: var(--shadow-soft); overflow: hidden; }
.acc-head { display:flex; align-items:center; justify-content:space-between; gap:10px; padding: 16px 17px; cursor:pointer; user-select:none; }
.acc-head .lhs { display:flex; align-items:center; gap:11px; }
.acc-head .ic { width:30px; height:30px; border-radius:9px; background: var(--primary-soft); display:grid; place-items:center; font-size:15px; }
.acc-head h3 { font-size: 16.5px; font-weight: 700; letter-spacing:-0.01em; }
.acc-head .arrow { color: var(--ink-dim); transition: transform .35s var(--spring); font-size: 13px; }
.acc.open .acc-head .arrow { transform: rotate(90deg); }
.acc-wrap { display:grid; grid-template-rows: 0fr; transition: grid-template-rows .4s var(--spring); }
.acc.open .acc-wrap { grid-template-rows: 1fr; }
.acc-body { overflow:hidden; }
.acc-inner { padding: 0 17px 17px; }

.field { margin-bottom: 12px; }
.field:last-child { margin: 0; }
.field .label { font-size: 11px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; color: var(--ink-dim); }
.field .value { font-size: 14.5px; margin-top:3px; line-height:1.45; color: var(--ink); white-space: pre-line; }
.bullet { font-size:14.5px; line-height:1.5; color: var(--ink-2); padding-left: 4px; }

.tafe-flag { background: rgba(4,120,87,0.08); border:1px solid rgba(4,120,87,0.18); border-radius:12px; padding:11px 13px; margin-bottom:12px; }
.tafe-flag .t { font-weight:700; color: var(--money); font-size:13px; display:flex; align-items:center; gap:6px; }
.tafe-flag .d { font-size:13.5px; color: var(--ink-2); margin-top:4px; line-height:1.4; }

.stats { display:flex; gap:20px; flex-wrap:wrap; }
.stat .big { font-size:26px; font-weight:800; color: var(--primary); letter-spacing:-0.02em; }
.stat .lbl { font-size:10.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; color: var(--ink-dim); }
.note { color: var(--ink-dim); font-size:13px; line-height:1.45; margin-top:11px; }

.rung { display:flex; gap:13px; }
.rung .rail { display:flex; flex-direction:column; align-items:center; }
.rung .dot { width:12px; height:12px; border-radius:50%; background: var(--primary); margin-top:4px; box-shadow:0 0 0 4px var(--primary-soft); }
.rung .line { width:2px; flex:1; background: linear-gradient(var(--primary), rgba(79,70,229,0.12)); margin:4px 0; }
.rung .body { padding-bottom:20px; }
.rung .body h4 { font-size:16px; font-weight:700; }
.rung .body .sub { display:flex; gap:12px; font-size:13.5px; color: var(--ink-dim); margin:3px 0 5px; font-weight:600; }
.rung .body .sub .pay { color: var(--money); }
.rung .body .what { font-size:13.5px; color: var(--ink-2); line-height:1.4; }
.reveal { opacity:0; transform:translateX(-8px); transition: all .5s var(--spring); }
.reveal.in { opacity:1; transform:none; }

.traits { display:flex; flex-wrap:wrap; gap:8px; }
.trait { background: var(--primary-soft); color: var(--primary); padding:7px 12px; border-radius:100px; font-size:12.5px; font-weight:600; }
.holland { color: var(--primary); font-size:12.5px; font-weight:600; margin-top:11px; }

.src { display:flex; gap:9px; align-items:flex-start; padding:9px 0; border-top:1px solid var(--hairline); cursor:pointer; text-decoration:none; color:inherit; }
.src:first-of-type { border-top:none; }
.src .stitle { color: var(--primary); font-size:13.5px; }
.src .pub { color: var(--ink-dim); font-size:11.5px; margin-top:1px; }
.verified { text-align:center; color: var(--ink-dim); font-size:11.5px; margin-top:18px; }

/* ---- Onboarding ---- */
.onb { position: fixed; inset: 0; z-index: 100; background: var(--bg); display:flex; flex-direction:column; animation: fade .3s ease; }
.onb-track { flex:1; display:flex; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; }
.onb-track::-webkit-scrollbar { display:none; }
.slide { flex:0 0 100%; scroll-snap-align:center; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding: 40px 34px; }
.slide .art { width:128px; height:128px; border-radius:32px; display:grid; place-items:center; font-size:60px; margin-bottom:30px; box-shadow: var(--shadow-card); background: var(--surface); }
.slide h2 { font-size:27px; font-weight:800; letter-spacing:-0.02em; margin-bottom:12px; }
.slide p { font-size:16px; color: var(--ink-2); line-height:1.5; max-width: 320px; }
.onb-foot { padding: 18px 24px calc(28px + env(safe-area-inset-bottom)); display:flex; flex-direction:column; gap:16px; align-items:center; }
.dots { display:flex; gap:8px; }
.dots i { width:7px; height:7px; border-radius:50%; background: var(--hairline); transition: all .3s; }
.dots i.on { background: var(--primary); width:22px; border-radius:100px; }
.btn { background: var(--primary); color:#fff; border:none; font-family:inherit; font-size:16px; font-weight:700; padding:15px; border-radius:15px; width:100%; cursor:pointer; box-shadow:0 6px 16px rgba(79,70,229,0.3); transition: transform .3s var(--spring); }
.btn:active { transform: scale(0.97); }
.skip { position:absolute; top:calc(14px + env(safe-area-inset-top)); right:20px; color: var(--ink-dim); font-size:15px; font-weight:600; cursor:pointer; z-index:1; background:none; border:none; font-family:inherit; }

/* filter row labels + two-tone clarity */
.rowlabel { font-size: 10.5px; font-weight: 800; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-dim); padding: 9px 14px 0; }
.chip.ind.on { background: var(--primary); color:#fff; box-shadow:0 4px 12px rgba(79,70,229,0.3); }
.chip.path { color: var(--money); border-color: rgba(4,120,87,0.22); }
.chip.path.on { background: var(--money); color:#fff; border-color: transparent; box-shadow:0 4px 12px rgba(4,120,87,0.28); }

.grouplabel { display:flex; align-items:center; justify-content:space-between; font-size:13px; font-weight:700; color: var(--ink-2); padding: 18px 12px 9px; }
.grouplabel .count { color: var(--ink-dim); font-weight:600; padding:0; }

/* course rows */
.card.course { border-left: 3px solid var(--money); }
.pill.lvl { background: rgba(4,120,87,0.10); color: var(--money); }
.pill.leads { background: rgba(20,22,46,0.05); color: var(--ink-2); }
.pill.exp { background: rgba(217,119,6,0.12); color:#b45309; }
.pill.nodeg { background: rgba(4,120,87,0.10); color: var(--money); }

/* hero flags */
.flags { display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; }
.flag { font-size:12.5px; font-weight:700; padding:7px 12px; border-radius:100px; }
.flag.nodeg { background: rgba(4,120,87,0.12); color: var(--money); }
.flag.exp { background: rgba(217,119,6,0.14); color:#b45309; }

/* entry routes section */
.callout { border-radius:14px; padding:13px 14px; margin-bottom:14px; }
.callout.exp { background: rgba(217,119,6,0.10); border:1px solid rgba(217,119,6,0.22); }
.callout.vet { background: var(--primary-soft); border:1px solid rgba(79,70,229,0.20); }
.callout .t { font-weight:800; font-size:13.5px; margin-bottom:4px; }
.callout.exp .t { color:#b45309; } .callout.vet .t { color: var(--primary); }
.callout .d { font-size:13.5px; line-height:1.5; color: var(--ink-2); }

.routes { display:flex; flex-direction:column; gap:11px; margin-bottom:14px; }
.route { display:flex; gap:11px; align-items:flex-start; }
.rspeed { flex:0 0 auto; font-size:9.5px; font-weight:800; letter-spacing:0.04em; padding:4px 8px; border-radius:7px; margin-top:1px; background: rgba(20,22,46,0.06); color: var(--ink-dim); }
.rspeed.fast { background: rgba(4,120,87,0.14); color: var(--money); }
.rspeed.long { background: rgba(79,70,229,0.12); color: var(--primary); }
.route .rtype { font-weight:700; font-size:14.5px; }
.route .rhow { font-size:13.5px; color: var(--ink-2); line-height:1.4; margin-top:1px; }

.ff { display:flex; gap:10px; margin-bottom:14px; }
.ff .f { flex:1; border-radius:14px; padding:11px 13px; font-size:13.5px; line-height:1.4; }
.ff .f.fast { background: rgba(4,120,87,0.09); }
.ff .f.long { background: var(--primary-soft); }
.ff .f .lbl { font-weight:800; font-size:11.5px; margin-bottom:3px; }
.ff .f.fast .lbl { color: var(--money); } .ff .f.long .lbl { color: var(--primary); }

/* TAFE honesty levels */
.tafe-flag.path { background: var(--primary-soft); border-color: rgba(79,70,229,0.2); }
.tafe-flag.path .t { color: var(--primary); }
.tafe-flag.warn { background: rgba(217,119,6,0.09); border-color: rgba(217,119,6,0.22); }
.tafe-flag.warn .t { color:#b45309; }

::view-transition-old(root), ::view-transition-new(root) { animation-duration: .4s; }
