/* ============================================================
   Mark Tonge — marktonge.com.au
   Plain, hand-written static site. No build step, no framework.
   Just HTML + this one stylesheet. Australian English throughout.
   Fonts load from Google Fonts (self-host later if preferred).
   ============================================================ */

:root {
  /* palette */
  --navy:        #021D49;
  --navy-deep:   #01142F;
  --gold:        #BD9A59;
  --gold-soft:   #CAAE7A;
  --paper:       #F8F5EF;
  --paper-card:  #fcfaf5;
  --ink:         #2c2e33;
  --ink-soft:    #5d5f68;
  --line:        #ddd6c8;
  --line-soft:   #e6e0d4;
  --paper-muted: #cfd3dc;
  --paper-faint: #9aa2b3;

  /* type */
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'EB Garamond', Georgia, serif;
  --font-label:   'Montserrat', system-ui, sans-serif;

  --step-eyebrow: 0.72rem;
  --measure: 68ch;
  --gutter: clamp(1.25rem, 4vw, 3rem);
  --maxw: 1100px;

  --display-xl: clamp(2.9rem, 8vw, 5.4rem);
  --display-lg: clamp(2.2rem, 5.5vw, 3.6rem);
  --display-md: clamp(1.8rem, 3.6vw, 2.6rem);
  --display-sm: clamp(1.45rem, 2.6vw, 1.9rem);

  --radius: 4px;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 1.18rem;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--navy);
  line-height: 1.06;
  margin: 0 0 0.4em;
}
p { margin: 0 0 1.1em; }
a { color: var(--navy); text-underline-offset: 3px; text-decoration-color: var(--line); }
a:hover { text-decoration-color: var(--gold); }
img { max-width: 100%; height: auto; display: block; }
::selection { background: var(--gold-soft); color: var(--navy-deep); }

/* layout */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.measure { max-width: var(--measure); }
.section { padding-block: clamp(3.5rem, 8vw, 6rem); }
.section--tight { padding-block: clamp(2.5rem, 5vw, 3.5rem); }
.rule-top { border-top: 1px solid var(--line); }

/* eyebrow + rules */
.eyebrow {
  font-family: var(--font-label);
  font-size: var(--step-eyebrow);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin: 0 0 1.1rem;
  display: block;
}
.eyebrow--rule { display: inline-flex; align-items: center; gap: 0.85rem; }
.eyebrow--rule::before { content: ""; width: 34px; height: 1.5px; background: var(--gold); display: inline-block; }
.goldrule { width: 46px; height: 1.5px; background: var(--gold); border: 0; margin: 1.4rem 0; }

/* display headings */
.display { font-family: var(--font-display); font-weight: 500; color: var(--navy); line-height: 1.06; }
.display .em { font-style: italic; color: var(--navy); }
.band-dark .display .em { color: var(--gold-soft); }
.standfirst {
  font-family: var(--font-body);
  font-style: italic;
  color: var(--navy);
  font-size: clamp(1.25rem, 2.3vw, 1.6rem);
  line-height: 1.45;
  max-width: 42ch;
}

/* ring mark */
.ring { display: none;
  width: 42px; height: 42px; border-radius: 50%;
  background: conic-gradient(from 215deg, var(--gold-soft), var(--gold) 38%, #7d6224 68%, var(--gold-soft));
  position: relative; flex: none;
}
.ring::after { content: ""; position: absolute; inset: 12px; border-radius: 50%; background: var(--paper); }
.ring--dark::after { background: var(--navy-deep); }

/* links / buttons */
.textlink {
  font-family: var(--font-label); font-size: 0.82rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--navy); text-decoration: none;
  display: inline-flex; align-items: center; gap: 0.5rem; font-weight: 600;
  border-bottom: 1.5px solid var(--gold); padding-bottom: 3px; transition: gap 0.2s ease;
}
.textlink:hover { gap: 0.85rem; }
.btn {
  font-family: var(--font-label); font-size: 0.82rem; letter-spacing: 0.14em;
  text-transform: uppercase; font-weight: 600; display: inline-flex; align-items: center;
  gap: 0.6rem; padding: 0.85rem 1.6rem; text-decoration: none; border-radius: var(--radius);
  transition: gap 0.2s ease, background 0.2s ease;
}
.btn--gold { background: var(--gold); color: var(--navy-deep); }
.btn--gold:hover { gap: 0.95rem; background: var(--gold-soft); }

/* dark band */
.band-dark { background: var(--navy); color: var(--paper); }
.band-dark .eyebrow { color: var(--gold-soft); }
.band-dark h1, .band-dark h2, .band-dark h3 { color: var(--paper); }
.band-dark p { color: var(--paper-muted); }
.band-dark .standfirst { color: var(--paper); }

/* header */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  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: 0.85rem; }
.brand { display: inline-flex; align-items: center; gap: 0.85rem; text-decoration: none; }
.brand__text { display: flex; flex-direction: column; line-height: 1; }
.brand__name { font-family: var(--font-display); font-size: 1.5rem; letter-spacing: 0.18em; color: var(--navy); font-weight: 500; }
.brand__sub { font-family: var(--font-label); font-size: 0.52rem; letter-spacing: 0.24em; color: var(--gold); margin-top: 0.35rem; font-weight: 600; }
.nav { display: flex; align-items: center; gap: clamp(1rem, 3vw, 2rem); list-style: none; margin: 0; padding: 0; }
.nav a { font-family: var(--font-label); font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink); text-decoration: none; font-weight: 500; padding-bottom: 2px; border-bottom: 1.5px solid transparent; }
.nav a:hover, .nav a[aria-current="page"] { border-bottom-color: var(--gold); color: var(--navy); }
@media (max-width: 560px) { .brand__sub { display: none; } .brand__name { font-size: 1.25rem; letter-spacing: 0.14em; } }

/* footer */
.site-footer { padding-top: clamp(3rem, 6vw, 4.5rem); }
.site-footer__inner { display: grid; grid-template-columns: 1fr 1.2fr; gap: clamp(2rem, 5vw, 4rem); padding-bottom: 2.5rem; }
.footer-brand { display: inline-flex; align-items: center; gap: 0.8rem; text-decoration: none; }
.footer-brand__name { font-family: var(--font-display); font-size: 1.4rem; letter-spacing: 0.18em; color: var(--paper); }
.site-footer__sub { font-family: var(--font-label); font-size: 0.58rem; letter-spacing: 0.24em; color: var(--gold-soft); margin-top: 1rem; }
.site-footer__heading { font-family: var(--font-label); font-size: 0.7rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-soft); margin-bottom: 1.2rem; font-weight: 600; }
.site-footer__firms ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 1rem; }
.site-footer__firms li { display: flex; flex-direction: column; }
.site-footer__firms a { font-family: var(--font-display); font-size: 1.25rem; color: var(--paper); text-decoration: none; }
.site-footer__firms a:hover { color: var(--gold-soft); }
.site-footer__firms span { font-family: var(--font-label); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--paper-faint); margin-top: 0.2rem; }
.site-footer__base { border-top: 1px solid color-mix(in srgb, var(--paper) 16%, transparent); padding-block: 1.6rem 2.4rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.site-footer__base p { margin: 0; font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.06em; color: var(--paper-faint); }
.site-footer__base nav { display: flex; gap: 1.4rem; }
.site-footer__base a { font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--paper-muted); text-decoration: none; }
.site-footer__base a:hover { color: var(--gold-soft); }
@media (max-width: 640px) { .site-footer__inner { grid-template-columns: 1fr; } }

/* cards */
.grid-2 { display: grid; gap: clamp(1.1rem, 2.5vw, 1.6rem); grid-template-columns: repeat(2, 1fr); }
@media (max-width: 720px) { .grid-2 { grid-template-columns: 1fr; } }
.card { background: var(--paper-card); border: 1px solid var(--line-soft); border-radius: var(--radius); padding: clamp(1.5rem, 3vw, 2.2rem); display: flex; flex-direction: column; gap: 0.6rem; text-decoration: none; color: inherit; transition: border-color 0.2s ease, transform 0.2s ease; }
a.card:hover { border-color: var(--gold); transform: translateY(-2px); }
.card__label { font-family: var(--font-label); font-size: 0.66rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.card__title { font-family: var(--font-display); font-size: 1.7rem; color: var(--navy); margin: 0; }
.card__body { color: var(--ink-soft); font-size: 1.05rem; margin: 0; line-height: 1.5; }
.card__more { margin-top: auto; font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--navy); padding-top: 0.6rem; }

/* definition list (contact) */
.deflist { display: grid; gap: 1.4rem; margin: 2rem 0; }
.deflist dt { font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); font-weight: 600; margin-bottom: 0.25rem; }
.deflist dd { margin: 0; font-size: 1.2rem; color: var(--ink); }

/* homepage selected writing */
.writing-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 2.4rem; }
.writing-item { display: grid; gap: 0.4rem; }
.writing-item__pillar { font-family: var(--font-label); font-size: 0.66rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 600; }
.writing-item__title { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2rem); margin: 0; }
.writing-item__title a { text-decoration: none; color: var(--navy); }
.writing-item__title a:hover { color: var(--gold); }
.writing-item__desc { color: var(--ink-soft); margin: 0.2rem 0 0; max-width: 60ch; }
.writing-item__date { font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.1em; color: var(--ink-soft); }

/* hero */
.hero { padding-block: clamp(4.5rem, 12vw, 8rem); }
.hero__title { font-size: var(--display-xl); margin: 0.2em 0 0.3em; }
.hero__standfirst { margin-top: 1.2rem; }
.hero__cta { margin-top: 2.4rem; }

/* journal index */
.filterbar { display: flex; flex-wrap: wrap; gap: 0.6rem; margin-top: 2rem; }
.filterbar a { font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink); text-decoration: none; border: 1px solid var(--line); border-radius: 999px; padding: 0.5rem 1rem; background: var(--paper-card); }
.filterbar a:hover { border-color: var(--gold); color: var(--navy); }
.journal-list { list-style: none; margin: 1.6rem 0 0; padding: 0; display: grid; gap: 1.4rem; }
.journal-item__link { display: grid; gap: 0.35rem; text-decoration: none; padding: 1.4rem 0; border-top: 1px solid var(--line-soft); }
.journal-item:first-child .journal-item__link { border-top: 0; }
.journal-item__title { font-family: var(--font-display); font-size: clamp(1.5rem, 3vw, 2.1rem); color: var(--navy); margin: 0; }
.journal-item__link:hover .journal-item__title { color: var(--gold); }
.journal-item__desc { color: var(--ink-soft); margin: 0; max-width: 64ch; }
.journal-item__date { font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.1em; color: var(--ink-soft); }
:where([id]) { scroll-margin-top: 90px; }

/* article */
.article-head { margin-bottom: 2.5rem; }
.article-pillar { font-family: var(--font-label); font-size: 0.7rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 600; text-decoration: none; }
.article-pillar:hover { color: var(--gold-soft); }
.article-title { font-size: clamp(2rem, 5vw, 3.3rem); margin: 0.5rem 0 1rem; max-width: 22ch; }
.article-meta { font-family: var(--font-label); font-size: 0.78rem; letter-spacing: 0.08em; color: var(--ink-soft); display: flex; gap: 0.7rem; align-items: center; margin: 0; }
.prose { font-size: 1.24rem; line-height: 1.68; }
.prose h2 { font-family: var(--font-display); font-size: clamp(1.6rem, 3vw, 2.1rem); color: var(--navy); margin: 2.4rem 0 0.8rem; }
.prose p { margin: 0 0 1.3em; }
.prose em { color: var(--navy); }
.article-foot { margin-top: 3rem; padding-top: 1.6rem; border-top: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.article-sign { font-family: var(--font-display); font-style: italic; font-size: 1.4rem; color: var(--navy); margin: 0; }
.more-list { list-style: none; margin: 1.4rem 0 0; padding: 0; display: grid; gap: 1.2rem; }
.more-list a { display: block; text-decoration: none; padding: 1.2rem 0; border-top: 1px solid var(--line-soft); }
.more-list li:first-child a { border-top: 0; }
.more-list h3 { font-family: var(--font-display); font-size: 1.5rem; color: var(--navy); margin: 0 0 0.2rem; }
.more-list a:hover h3 { color: var(--gold); }
.more-list p { color: var(--ink-soft); margin: 0; max-width: 64ch; }

/* about page */
.track-list { list-style: none; margin: 0 0 2.8rem; padding: 0; display: grid; gap: 1.6rem; }
.track-item { padding-bottom: 1.6rem; border-bottom: 1px solid var(--line-soft); }
.track-item:last-child { border-bottom: 0; }
.track-item__head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.track-item__name { font-family: var(--font-display); font-size: clamp(1.4rem, 3vw, 1.9rem); color: var(--navy); margin: 0; }
.track-item__where { font-family: var(--font-label); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); }
.track-item__note { color: var(--ink-soft); margin: 0.5rem 0 0; max-width: 70ch; }
.approvals { background: var(--paper-card); border: 1px solid var(--line-soft); border-radius: var(--radius); padding: clamp(1.4rem, 3vw, 2rem); }
.heritage { margin: 1.8rem 0 2rem; display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.4rem 2.5rem; }
.heritage__item { padding-bottom: 1.2rem; border-bottom: 1px solid var(--line-soft); }
.heritage dt { font-family: var(--font-display); font-size: 1.3rem; color: var(--navy); margin-bottom: 0.2rem; }
.heritage dd { margin: 0; color: var(--ink-soft); font-size: 1.02rem; line-height: 1.5; }
@media (max-width: 720px) { .heritage { grid-template-columns: 1fr; } }
.beyond { display: grid; gap: 2rem; margin-top: 0.5rem; }
.beyond__block { max-width: 70ch; }
.beyond__label { font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); font-weight: 600; display: block; margin-bottom: 0.5rem; }
.principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.5rem, 4vw, 2.5rem); margin-top: 0.5rem; }
.principle__label { font-family: var(--font-label); font-size: 0.72rem; letter-spacing: 0.24em; text-transform: uppercase; color: var(--gold-soft); font-weight: 600; }
.principle__lead { font-family: var(--font-display); font-style: italic; font-size: 1.45rem; color: var(--paper); margin: 0.6rem 0 0.4rem; }
.principle__body { color: var(--paper-muted); font-size: 1.02rem; }
@media (max-width: 720px) { .principles { grid-template-columns: 1fr; } }

/* focus + skip link */
:where(a, button, input, [tabindex]):focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 2px; }
.skip-link { position: absolute; left: -9999px; top: 0; background: var(--navy); color: var(--paper); padding: 0.7rem 1.1rem; z-index: 100; font-family: var(--font-label); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; }
.skip-link:focus { left: 0.5rem; top: 0.5rem; }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}
