/* ============================================================
   Community Music Australia — design system
   Navy #00245B · Gold #E0C037 · Fraunces (display) + Public Sans (body)
   ============================================================ */

:root{
  --navy:#00245B;
  --navy-deep:#001A42;
  --navy-700:#123a78;
  --gold:#E0C037;
  --gold-soft:#F2E4A8;
  --gold-wash:#FBF4D8;
  --paper:#FBFAF7;
  --paper-2:#F4F2EC;
  --ink:#16233D;
  --ink-soft:#46506b;
  --line:#E3E2DC;
  --white:#ffffff;

  --maxw:1140px;
  --gut:clamp(1.25rem,5vw,3rem);

  --f-display:"Fraunces",Georgia,"Times New Roman",serif;
  --f-body:"Public Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;

  --step--1:clamp(.82rem,.79rem + .12vw,.9rem);
  --step-0:clamp(1rem,.96rem + .2vw,1.12rem);
  --step-1:clamp(1.2rem,1.1rem + .4vw,1.45rem);
  --step-2:clamp(1.5rem,1.3rem + .8vw,2rem);
  --step-3:clamp(2rem,1.6rem + 1.6vw,3rem);
  --step-4:clamp(2.6rem,2rem + 2.8vw,4.4rem);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--f-body);font-size:var(--step-0);line-height:1.65;
  font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--navy);text-underline-offset:.18em;text-decoration-thickness:.06em}
a:hover{color:var(--navy-700)}

h1,h2,h3,h4{font-family:var(--f-display);color:var(--navy);line-height:1.1;font-weight:560;
  letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:var(--step-4);font-weight:600}
h2{font-size:var(--step-3)}
h3{font-size:var(--step-1)}
p{margin:0 0 1.1em}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut)}
.wrap-narrow{max-width:760px;margin-inline:auto;padding-inline:var(--gut)}
.section{padding-block:clamp(3.5rem,7vw,6rem)}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.section--paper2{background:var(--paper-2)}

/* eyebrow label — encodes section purpose */
.eyebrow{font-family:var(--f-body);font-size:var(--step--1);font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--navy-700);
  display:inline-flex;align-items:center;gap:.6rem;margin:0 0 1rem}
.eyebrow::before{content:"";width:1.6rem;height:2px;background:var(--gold);display:inline-block}

.lede{font-size:var(--step-1);line-height:1.5;color:var(--ink);font-family:var(--f-display);
  font-weight:380}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-body);
  font-weight:600;font-size:var(--step-0);line-height:1;padding:.85em 1.5em;border-radius:2px;
  border:2px solid transparent;cursor:pointer;text-decoration:none;transition:.18s ease}
.btn--primary{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn--primary:hover{background:#cdae2c;border-color:#cdae2c;color:var(--navy)}
.btn--ghost{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn--ghost:hover{background:var(--navy);color:#fff}
.btn--onnavy{background:var(--gold);color:var(--navy);border-color:var(--gold)}
.btn--onnavy:hover{background:#fff;border-color:#fff}
.btn--ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost-light:hover{background:#fff;color:var(--navy);border-color:#fff}

/* ---------- soundwave (the signature element) ---------- */
.eq{display:flex;align-items:flex-end;gap:3px;height:var(--eq-h,28px)}
.eq span{flex:0 0 var(--eq-w,5px);background:var(--gold);border-radius:2px;
  height:30%;transform-origin:bottom;animation:eq 1.4s ease-in-out infinite}
.eq span:nth-child(1){height:40%;animation-delay:-.2s}
.eq span:nth-child(2){height:75%;animation-delay:-.9s}
.eq span:nth-child(3){height:95%;animation-delay:-.4s}
.eq span:nth-child(4){height:60%;animation-delay:-1.1s}
.eq span:nth-child(5){height:100%;animation-delay:-.6s}
.eq span:nth-child(6){height:48%;animation-delay:-.3s}
.eq span:nth-child(7){height:80%;animation-delay:-1s}
.eq span:nth-child(8){height:35%;animation-delay:-.7s}
@keyframes eq{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(1)}}
@media (prefers-reduced-motion:reduce){.eq span{animation:none}}

/* divider made of waveform bars */
.wavebreak{display:flex;justify-content:center;align-items:flex-end;gap:4px;height:34px;
  padding-block:0;opacity:.9}
.wavebreak span{width:5px;background:var(--gold);border-radius:3px}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,250,247,.92);
  backdrop-filter:saturate(1.1) blur(6px);border-bottom:1px solid var(--line)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;padding-block:.7rem}
.brand{display:flex;align-items:center;gap:.7rem;text-decoration:none}
.brand img{height:54px;width:auto}
.brand:hover{color:inherit}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem;color:var(--navy)}
.main-nav ul{list-style:none;display:flex;flex-wrap:wrap;gap:1.15rem;margin:0;padding:0;align-items:center}
.main-nav a{font-family:var(--f-body);font-weight:500;font-size:.98rem;color:var(--navy);
  text-decoration:none;padding:.3rem 0;position:relative}
.main-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;
  background:var(--gold);transition:right .22s ease}
.main-nav a:hover::after,.main-nav a[aria-current="page"]::after{right:0}
.main-nav .btn{padding:.55em 1em;font-size:.92rem}
.main-nav .btn::after{display:none}

/* ---------- hero ---------- */
.hero{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.hero__bg{position:absolute;inset:0;opacity:.5;pointer-events:none}
.hero__bg svg{width:100%;height:100%}
.hero__inner{position:relative;padding-block:clamp(3.5rem,9vw,7rem);max-width:880px}
.hero h1{color:#fff;margin-bottom:.35em}
.hero .eyebrow{color:var(--gold-soft)}
.hero .eyebrow::before{background:var(--gold)}
.hero__lede{font-family:var(--f-display);font-weight:340;font-size:var(--step-2);
  line-height:1.32;color:#eaf0fb;margin-bottom:1.8rem;max-width:42ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem}
.hero__eq{margin-top:2.6rem;--eq-h:40px;--eq-w:6px}

/* ---------- priorities cards ---------- */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.pcard{background:#fff;border:1px solid var(--line);border-radius:4px;padding:2rem 1.7rem;
  display:flex;flex-direction:column;gap:.4rem;transition:.2s ease;border-top:4px solid var(--gold)}
.pcard:hover{transform:translateY(-4px);box-shadow:0 16px 40px -24px rgba(0,36,91,.4)}
.pcard h3{margin-bottom:.25em}
.pcard p{color:var(--ink-soft);margin-bottom:0}
.pcard .eq{margin-bottom:1rem;--eq-h:22px;--eq-w:4px}

/* ---------- survey band ---------- */
.survey{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden}
.survey h2{color:#fff}
.survey .eyebrow{color:var(--gold-soft)}
.survey__lede{color:#dde5f4;max-width:60ch;font-size:var(--step-1);font-family:var(--f-display);font-weight:340}
.timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2.2rem 0;
  counter-reset:tl}
.timeline li{list-style:none;position:relative;padding-top:1.3rem;border-top:2px solid rgba(255,255,255,.18)}
.timeline li::before{counter-increment:tl;content:counter(tl);position:absolute;top:-.95rem;left:0;
  background:var(--gold);color:var(--navy);font-weight:700;font-family:var(--f-body);
  width:1.9rem;height:1.9rem;border-radius:50%;display:grid;place-items:center;font-size:.9rem}
.timeline .t-label{font-size:var(--step--1);text-transform:uppercase;letter-spacing:.1em;
  color:var(--gold-soft);font-weight:700;display:block;margin-bottom:.2rem}
.timeline .t-date{font-family:var(--f-display);font-size:var(--step-1);color:#fff}

/* ---------- forms ---------- */
.form{display:grid;gap:1.1rem;max-width:560px}
.form.form--inline{grid-template-columns:1fr auto;gap:.7rem;align-items:end;max-width:560px}
.field{display:flex;flex-direction:column;gap:.35rem}
.field label{font-weight:600;font-size:.92rem;color:var(--navy)}
.field .opt{font-weight:400;color:var(--ink-soft)}
.field input,.field textarea,.field select{font-family:var(--f-body);font-size:1rem;
  padding:.7em .8em;border:1.5px solid var(--line);border-radius:3px;background:#fff;color:var(--ink);
  width:100%}
.field input:focus,.field textarea:focus{outline:2px solid var(--gold);outline-offset:1px;border-color:var(--navy)}
.form--onnavy .field label{color:var(--gold-soft)}
.form--onnavy .field input{background:rgba(255,255,255,.95)}
.form__note{font-size:.85rem;color:var(--ink-soft)}
.form--onnavy .form__note{color:#c3cfe6}
.form__status{font-weight:600;padding:.6rem 0}

/* ---------- news ---------- */
.newslist{list-style:none;margin:0;padding:0;display:grid;gap:0}
.newslist li{border-top:1px solid var(--line)}
.newslist li:last-child{border-bottom:1px solid var(--line)}
.newsrow{display:grid;grid-template-columns:160px 1fr auto;gap:1.5rem;align-items:baseline;
  padding:1.5rem 0;text-decoration:none;color:var(--ink);transition:.15s}
.newsrow:hover{color:var(--navy);background:linear-gradient(90deg,transparent,rgba(224,192,55,.06))}
.newsrow time{font-size:.9rem;color:var(--ink-soft);font-variant-numeric:tabular-nums}
.newsrow h3{margin:0;font-size:var(--step-1)}
.newsrow .arrow{color:var(--gold);font-size:1.3rem}

.home-news h2{margin-bottom:.2em}

/* ---------- prose (markdown body) ---------- */
.prose{font-size:var(--step-0)}
.prose h2{margin-top:1.8em}
.prose h3{margin-top:1.4em}
.prose ul,.prose ol{padding-left:1.3em;margin:0 0 1.2em}
.prose li{margin-bottom:.4em}
.prose blockquote{border-left:3px solid var(--gold);margin:1.5em 0;padding:.2em 0 .2em 1.2em;
  font-family:var(--f-display);font-size:var(--step-1);color:var(--navy)}
.prose a{color:var(--navy-700)}

/* page header */
.page-head{background:var(--navy);color:#fff;padding-block:clamp(2.6rem,6vw,4.2rem)}
.page-head h1{color:#fff;margin:0}
.page-head .eyebrow{color:var(--gold-soft)}
.page-head p{color:#dde5f4;margin:.7rem 0 0;font-size:var(--step-1);font-family:var(--f-display);font-weight:340;max-width:62ch}

/* PDF download card */
.pdfcard{display:flex;align-items:center;gap:1.2rem;background:#fff;border:1px solid var(--line);
  border-left:5px solid var(--gold);border-radius:4px;padding:1.4rem 1.5rem;margin:1.8rem 0}
.pdfcard__icon{flex:none;width:46px;height:46px;display:grid;place-items:center;background:var(--gold-wash);
  border-radius:4px;color:var(--navy);font-weight:700;font-size:.8rem;font-family:var(--f-body)}
.pdfcard__body{flex:1}
.pdfcard__body strong{display:block;color:var(--navy);font-size:var(--step-0)}
.pdfcard__body span{font-size:.88rem;color:var(--ink-soft)}

/* contact layout */
.split{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.contact-aside{background:var(--paper-2);border-radius:4px;padding:1.8rem;border-top:4px solid var(--gold)}
.contact-aside h3{margin-top:0}
.contact-aside a{color:var(--navy-700);font-weight:600}

/* two-col intro */
.lead-cols{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem)}

/* ---------- footer ---------- */
.site-footer{background:var(--navy-deep);color:#cdd8ee;padding-block:clamp(3rem,5vw,4rem) 1.5rem;
  font-size:.95rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.site-footer img{height:64px;margin-bottom:1rem}
.site-footer h4{color:#fff;font-family:var(--f-body);font-size:.85rem;letter-spacing:.12em;
  text-transform:uppercase;margin:0 0 1rem}
.site-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}
.site-footer a{color:#cdd8ee;text-decoration:none}
.site-footer a:hover{color:#fff;text-decoration:underline}
.acknowledgement{border-top:1px solid rgba(255,255,255,.14);padding-top:1.5rem;
  font-size:.85rem;color:#aebbd6;max-width:80ch;line-height:1.6}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:1.5rem;padding-top:1.2rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;font-size:.82rem;color:#9fb0d0}

.skip-link{position:absolute;left:-999px;top:.5rem;background:var(--gold);color:var(--navy);
  padding:.6rem 1rem;border-radius:3px;z-index:100;font-weight:600}
.skip-link:focus{left:.5rem}

/* ---------- responsive ---------- */
@media (max-width:880px){
  .grid-3,.timeline,.split,.lead-cols,.footer-grid{grid-template-columns:1fr}
  .timeline li{padding-top:1.4rem}
  .nav-toggle{display:block}
  .main-nav{display:none;width:100%;order:3}
  .main-nav.open{display:block}
  .main-nav ul{flex-direction:column;align-items:flex-start;gap:.2rem;padding:.6rem 0}
  .main-nav li{width:100%}
  .main-nav a{display:block;padding:.7rem 0;border-bottom:1px solid var(--line);width:100%}
  .main-nav a::after{display:none}
  .site-header__inner{flex-wrap:wrap}
  .newsrow{grid-template-columns:1fr;gap:.3rem}
  .newsrow .arrow{display:none}
  .form.form--inline{grid-template-columns:1fr}
}

/* ---------- social icons ---------- */
.social{display:flex;gap:.6rem;align-items:center;margin-top:1rem}
.social a{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;
  border:1.5px solid currentColor;color:inherit;transition:.18s ease}
.social svg{width:19px;height:19px}
.social--footer a{color:#cdd8ee;border-color:rgba(255,255,255,.32)}
.social--footer a:hover{color:var(--navy);background:var(--gold);border-color:var(--gold)}
.social--contact a{color:var(--navy);border-color:var(--line)}
.social--contact a:hover{color:#fff;background:var(--navy);border-color:var(--navy)}
