:root {
  --ink: #13202a;
  --muted: #5c6b73;
  --line: #dfe7e9;
  --paper: #fbfaf6;
  --white: #ffffff;
  --river: #0d6f8f;
  --river-dark: #084d63;
  --jacaranda: #6f5aa8;
  --green: #26735f;
  --sand: #e8c98f;
  --coral: #c85f42;
  --shadow: 0 22px 70px rgba(19, 32, 42, .12);
  --radius: 8px;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; color: var(--ink); background: var(--paper); line-height: 1.6; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--river); }
img { max-width: 100%; display: block; }
.skip-link { position: absolute; left: -999px; top: 1rem; background: var(--ink); color: white; padding: .7rem 1rem; z-index: 10; }
.skip-link:focus { left: 1rem; }
.site-header { position: sticky; top: 0; z-index: 8; background: rgba(251, 250, 246, .94); border-bottom: 1px solid var(--line); backdrop-filter: blur(18px); }
.masthead { max-width: 1180px; margin: 0 auto; padding: .8rem 1rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.brand { display: inline-flex; align-items: center; min-width: 0; }
.brand-logo { width: min(330px, 58vw); height: 78px; object-fit: contain; object-position: left center; display: block; }
.brand-mark { width: 42px; height: 42px; display: grid; place-items: center; background: var(--ink); color: white; font-weight: 800; letter-spacing: 0; border-radius: 50%; }
.brand strong, .footer-brand { display: block; font-family: Georgia, "Times New Roman", serif; font-size: 1.35rem; line-height: 1; }
.brand em { display: block; color: var(--muted); font-style: normal; font-size: .78rem; margin-top: .2rem; }
.nav-toggle { display: none; border: 1px solid var(--line); background: var(--white); color: var(--ink); padding: .55rem .75rem; border-radius: var(--radius); font-weight: 700; }
.site-nav { max-width: 1180px; margin: 0 auto; padding: 0 1rem .8rem; display: flex; gap: .45rem; overflow-x: auto; }
.site-nav a { padding: .5rem .78rem; border: 1px solid transparent; border-radius: 999px; color: var(--muted); white-space: nowrap; font-size: .92rem; font-weight: 700; }
.site-nav a:hover { border-color: var(--line); background: white; color: var(--ink); }
main { overflow: hidden; }
.hero, .section, .category-band, .newsletter-block, .page-hero, .article { max-width: 1180px; margin: 0 auto; padding: 4.5rem 1rem; }
.hero { min-height: calc(100vh - 116px); display: grid; grid-template-columns: minmax(0, .95fr) minmax(360px, 1.05fr); gap: 2.5rem; align-items: center; padding-top: 3rem; padding-bottom: 3rem; }
.hero-copy { min-width: 0; position: relative; z-index: 1; }
.hero h1, .page-hero h1, .article-header h1 { font-family: Georgia, "Times New Roman", serif; font-size: clamp(3rem, 8vw, 7rem); line-height: .9; margin: .25rem 0 1rem; letter-spacing: 0; }
.hero h1 { font-size: clamp(3rem, 6.4vw, 5.6rem); max-width: 8.8ch; }
.hero-deck, .page-hero p, .article-header p { color: var(--muted); font-size: 1.18rem; max-width: 720px; }
.eyebrow { color: #a03e22; text-transform: uppercase; letter-spacing: .08em; font-weight: 800; font-size: .75rem; margin: 0 0 .6rem; }
.button, button { border: 0; border-radius: var(--radius); padding: .85rem 1rem; font-weight: 800; cursor: pointer; min-height: 44px; }
.primary, button { background: var(--river); color: white; }
.secondary { border: 1px solid var(--line); background: white; }
.hero-actions { display: flex; gap: .7rem; flex-wrap: wrap; margin-top: 1.5rem; }
.hero-feature { display: grid; grid-template-columns: 1fr; background: var(--white); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); min-width: 0; position: relative; z-index: 0; }
.hero-feature > div:last-child { padding: 1.35rem; }
.hero-feature h2, .section-heading h2, .split h2, .newsletter-block h2, .article-body h2, .related h2 { font-family: Georgia, "Times New Roman", serif; font-size: clamp(1.8rem, 3vw, 3rem); line-height: 1; margin: 0 0 .8rem; }
.story-art { min-height: 280px; display: flex; align-items: flex-end; padding: 1rem; color: white; background: linear-gradient(135deg, var(--river), var(--jacaranda)); background-size: cover; background-position: center; position: relative; overflow: hidden; }
.story-art:before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(19,32,42,.05), rgba(19,32,42,.72)); }
.story-art span { position: relative; font-family: Georgia, "Times New Roman", serif; font-size: 2.25rem; line-height: 1; text-shadow: 0 2px 18px rgba(0,0,0,.35); }
.story-art.river { background-image: linear-gradient(180deg, rgba(19,32,42,.05), rgba(19,32,42,.72)), url("../img/locations/brisbane-river.webp"); }
.story-art.weekend { background-image: linear-gradient(180deg, rgba(19,32,42,.05), rgba(19,32,42,.72)), url("../img/locations/south-bank.webp"); }
.story-art.cafe { background-image: linear-gradient(180deg, rgba(19,32,42,.1), rgba(19,32,42,.72)), url("../img/locations/queen-street-mall.webp"); }
.story-art.queenstreet { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.72)), url("../img/locations/queen-street-mall.webp"); }
.story-art.brunch { background-image: linear-gradient(180deg, rgba(19,32,42,.1), rgba(19,32,42,.72)), url("../img/locations/new-farm.webp"); }
.story-art.bar { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.76)), url("../img/locations/story-bridge.webp"); }
.story-art.bakery { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.72)), url("../img/locations/south-bank.webp"); }
.story-art.cheap-eats { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.74)), url("../img/locations/queen-street-mall.webp"); }
.story-art.restaurant { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.76)), url("../img/locations/queens-wharf.webp"); }
.story-art.hotel { background-image: linear-gradient(180deg, rgba(19,32,42,.1), rgba(19,32,42,.76)), url("../img/locations/queens-wharf.webp"); }
.story-art.attractions { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.74)), url("../img/locations/story-bridge.webp"); }
.story-art.olympics { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.76)), url("../img/locations/brisbane-skyline.webp"); }
.story-art.queenswharf { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.74)), url("../img/locations/queens-wharf.webp"); }
.story-art.events { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.76)), url("../img/locations/riverfire.webp"); }
.story-art.coast { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.72)), url("../img/locations/redcliffe.webp"); }
.story-art.southbank { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.72)), url("../img/locations/brisbane-river.webp"); }
.story-art.living { background-image: linear-gradient(180deg, rgba(19,32,42,.08), rgba(19,32,42,.72)), url("../img/locations/new-farm.webp"); }
.section-heading { display: flex; justify-content: space-between; align-items: end; gap: 1rem; margin-bottom: 1.2rem; border-bottom: 1px solid var(--line); padding-bottom: 1rem; }
.story-grid { display: grid; gap: 1rem; }
.story-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.story-grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.story-card { background: white; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
.story-card .story-art { min-height: 210px; }
.story-card-body { padding: 1rem; }
.story-card h3 { font-family: Georgia, "Times New Roman", serif; font-size: 1.45rem; line-height: 1.1; margin: 0 0 .55rem; }
.story-card p { color: var(--muted); margin-bottom: 0; }
.feature-row .wide { display: grid; grid-template-columns: 1.1fr .9fr; align-items: stretch; }
.feature-row .wide .story-art { min-height: 340px; }
.category-band { max-width: none; background: #eef6f3; }
.category-band > * { max-width: 1180px; margin-left: auto; margin-right: auto; }
.category-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1rem; }
.category-card { min-height: 230px; border-radius: var(--radius); padding: 1rem; color: white; display: flex; flex-direction: column; justify-content: flex-end; background: var(--river); background-size: cover; background-position: center; position: relative; overflow: hidden; }
.category-card:before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(19,32,42,.12), rgba(19,32,42,.74)); }
.category-card.green { background-color: var(--green); }
.category-card.purple { background-color: var(--jacaranda); }
.category-card.sand { background-color: #b98235; }
.category-card.coral { background-color: var(--coral); }
.category-card span, .category-card strong, .category-card p { position: relative; }
.category-card span { font-size: .76rem; text-transform: uppercase; font-weight: 900; }
.category-card strong { font-family: Georgia, "Times New Roman", serif; font-size: 2rem; line-height: 1; margin: .4rem 0; }
.category-card p { margin: 0; color: rgba(255,255,255,.86); }
.cat-things-to-do { background-image: url("../img/locations/brisbane-river.webp"); }
.cat-food-drink { background-image: url("../img/locations/queen-street-mall.webp"); }
.cat-restaurants { background-image: url("../img/locations/queens-wharf.webp"); }
.cat-brisbane-2032 { background-image: url("../img/locations/brisbane-skyline.webp"); }
.cat-events { background-image: url("../img/locations/riverfire.webp"); }
.cat-suburbs { background-image: url("../img/locations/new-farm.webp"); }
.cat-weekend-guides { background-image: url("../img/locations/south-bank.webp"); }
.cat-living-in-brisbane { background-image: url("../img/locations/new-farm.webp"); }
.cat-hotels { background-image: url("../img/locations/queens-wharf.webp"); }
.cat-attractions { background-image: url("../img/locations/story-bridge.webp"); }
.split { display: grid; grid-template-columns: .9fr 1.1fr; gap: 2rem; align-items: center; }
.split > p, .split p { color: var(--muted); }
.text-link { color: var(--river-dark); font-weight: 900; border-bottom: 2px solid currentColor; }
.living-panel { border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.sponsor-banner { max-width: 1180px; margin: 0 auto; padding: 2.4rem 1rem; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.sponsor-label { display: flex; justify-content: space-between; align-items: end; gap: 1rem; margin-bottom: 1rem; }
.sponsor-banner h2 { margin: 0; font-family: Georgia, "Times New Roman", serif; font-size: clamp(1.8rem, 3vw, 3rem); line-height: 1; }
.sponsor-artwork { display: block; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; background: white; box-shadow: var(--shadow); }
.sponsor-artwork img { width: 100%; height: auto; display: block; }
.sponsor-caption { display: flex; justify-content: space-between; gap: 1rem; align-items: center; margin-top: 1rem; }
.sponsor-caption p { margin: 0; color: var(--muted); max-width: 720px; }
.newsletter-block { max-width: none; background: var(--ink); color: white; display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; align-items: center; }
.newsletter-block > * { max-width: 560px; }
.newsletter-block > div { justify-self: end; }
.newsletter-block p { color: rgba(255,255,255,.72); }
label { display: block; font-weight: 800; margin-bottom: .45rem; }
input, textarea { width: 100%; border: 1px solid var(--line); border-radius: var(--radius); padding: .9rem; font: inherit; background: white; color: var(--ink); }
.form-row { display: grid; grid-template-columns: 1fr auto; gap: .6rem; }
.hidden { display: none; }
.page-hero { padding-top: 5.5rem; padding-bottom: 5.5rem; border-bottom: 1px solid var(--line); background-size: cover; background-position: center; position: relative; }
.page-hero:before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(251,250,246,.96), rgba(251,250,246,.74), rgba(251,250,246,.42)); }
.page-hero > * { position: relative; }
.page-hero.blue { background-image: url("../img/locations/brisbane-river.webp"); }
.page-hero.green { background-image: url("../img/locations/new-farm.webp"); }
.page-hero.purple { background-image: url("../img/locations/riverfire.webp"); }
.page-hero.sand { background-image: url("../img/locations/redcliffe.webp"); }
.page-hero.coral { background-image: url("../img/locations/queens-wharf.webp"); }
.section-intro { max-width: 780px; color: var(--muted); font-size: 1.08rem; margin: -0.4rem 0 1.2rem; }
.directory-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .8rem; }
.directory-item { background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: 1rem; min-height: 160px; }
.directory-item span { color: var(--coral); text-transform: uppercase; letter-spacing: .08em; font-weight: 900; font-size: .72rem; }
.directory-item h3 { font-family: Georgia, "Times New Roman", serif; font-size: 1.55rem; line-height: 1; margin: .45rem 0 .55rem; }
.directory-item p { color: var(--muted); margin: 0; }
.source-note { color: var(--muted); font-size: .88rem; margin-top: 1rem; border-top: 1px solid var(--line); padding-top: 1rem; }
.suburb-directory { padding-top: 3rem; }
.suburb-directory .section-intro { max-width: 840px; color: var(--muted); font-size: 1.08rem; }
.suburb-region { margin-top: 2rem; border-top: 1px solid var(--line); padding-top: 1.2rem; }
.suburb-region h3 { font-family: Georgia, "Times New Roman", serif; font-size: clamp(1.6rem, 3vw, 2.35rem); line-height: 1; margin: 0 0 1rem; }
.suburb-link-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .65rem; }
.suburb-link-grid a { min-height: 96px; display: flex; flex-direction: column; justify-content: space-between; gap: .7rem; background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: .85rem; box-shadow: 0 8px 22px rgba(19,32,42,.04); }
.suburb-link-grid a:hover { border-color: rgba(13,111,143,.42); box-shadow: 0 14px 36px rgba(19,32,42,.08); }
.suburb-link-grid span { font-weight: 900; line-height: 1.15; }
.suburb-link-grid small { color: var(--muted); font-size: .78rem; line-height: 1.25; }
.text-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; border-top: 1px solid var(--line); }
.narrow { max-width: 850px; }
.prose { background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.2rem; }
.article { max-width: 920px; }
.breadcrumbs { display: flex; gap: .5rem; color: var(--muted); font-size: .9rem; margin-bottom: 1rem; }
.article-header { margin-bottom: 2rem; }
.article > .story-art { min-height: 430px; border-radius: var(--radius); margin-bottom: 2rem; }
.article-body { max-width: 730px; margin: 0 auto; }
.article-body p { font-size: 1.08rem; color: #2f3d45; }
.related { margin: 3rem auto 0; max-width: 730px; border-top: 1px solid var(--line); padding-top: 1.5rem; display: grid; gap: .75rem; }
.related a { display: block; background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: .9rem; font-weight: 800; }
.contact-form { background: white; border: 1px solid var(--line); border-radius: var(--radius); padding: 1.2rem; display: grid; gap: 1rem; }
.language-links { display: flex; flex-wrap: wrap; gap: .6rem; margin-bottom: 1.2rem; }
.language-links a { border: 1px solid var(--line); background: white; border-radius: 999px; padding: .55rem .85rem; font-weight: 800; }
.site-footer { background: white; border-top: 1px solid var(--line); padding: .5rem 0 0; }
.site-footer .footer-inner-compact { padding: 1.5rem 1.5rem 1rem; }
.footer-grid { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2rem; }
.footer-logo { width: min(280px, 70vw); height: auto; margin-bottom: .8rem; }
.site-footer h2 { font-size: .85rem; text-transform: uppercase; letter-spacing: .08em; margin: 0 0 .6rem; }
.site-footer .footer-grid a { display: block; color: var(--muted); margin: .35rem 0; }
.site-footer p { color: var(--muted); }
.photo-credit { font-size: .78rem; line-height: 1.45; margin-top: 1rem; }
.copyright { max-width: 1180px; margin: 2rem auto 0; font-size: .85rem; }
@media (max-width: 860px) {
  .nav-toggle { display: inline-flex; align-items: center; }
  .site-nav { display: none; padding: .3rem 1rem 1rem; flex-direction: column; }
  .site-nav.open { display: flex; }
  .site-nav a { border-color: var(--line); background: white; }
  .hero { min-height: auto; grid-template-columns: 1fr; padding-top: 2.5rem; }
  .brand-logo { width: min(235px, 62vw); height: 58px; }
  .hero h1, .page-hero h1, .article-header h1 { font-size: 3.1rem; }
  .story-grid.three, .story-grid.two, .feature-row .wide, .category-grid, .split, .newsletter-block, .text-columns, .footer-grid, .directory-grid, .suburb-link-grid { grid-template-columns: 1fr; }
  .sponsor-label, .sponsor-caption { display: block; }
  .sponsor-caption .text-link { display: inline-block; margin-top: .8rem; }
  .section-heading { display: block; }
  .newsletter-block > div { justify-self: start; }
  .form-row { grid-template-columns: 1fr; }
  .story-art, .article > .story-art { min-height: 260px; }
}
@media (max-width: 520px) {
  .brand em { display: none; }
  .hero, .section, .category-band, .newsletter-block, .page-hero, .article { padding-left: .85rem; padding-right: .85rem; }
  .hero-actions { display: grid; }
  .category-card { min-height: 180px; }
}

/* ── News card grid ──────────────────────────────────────────────────────── */
.news-card-grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: 1.25rem; }
.news-card { border-radius: var(--radius); overflow: hidden; background: white; border: 1px solid var(--line); transition: box-shadow .2s, transform .2s; }
.news-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.10); transform: translateY(-3px); }
.news-card-link { display: flex; flex-direction: column; height: 100%; text-decoration: none; color: inherit; }
.news-card-accent { height: 5px; }
.news-card--river  .news-card-accent { background: var(--river); }
.news-card--green  .news-card-accent { background: var(--green); }
.news-card--purple .news-card-accent { background: var(--jacaranda); }
.news-card--coral  .news-card-accent { background: var(--coral); }
.news-card--sand   .news-card-accent { background: #b98235; }
.news-card-body { padding: 1rem 1.1rem; flex: 1; display: flex; flex-direction: column; gap: .45rem; }
.news-card-meta { display: flex; justify-content: space-between; align-items: center; }
.news-card-source { font-size: .7rem; text-transform: uppercase; font-weight: 800; letter-spacing: .06em; color: var(--river); }
.news-card--green  .news-card-source { color: var(--green); }
.news-card--purple .news-card-source { color: var(--jacaranda); }
.news-card--coral  .news-card-source { color: #a03e22; }
.news-card--sand   .news-card-source { color: #7a4f0e; }
.news-card-date { font-size: .7rem; color: var(--muted); }
.news-card h3 { font-family: Georgia,"Times New Roman",serif; font-size: 1.08rem; line-height: 1.3; margin: 0; color: var(--ink); }
.news-card-snippet { font-size: .84rem; color: var(--muted); margin: 0; flex: 1; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.news-card-read { padding: .65rem 1.1rem; font-size: .76rem; font-weight: 700; color: var(--river); border-top: 1px solid var(--line); }
/* ── Job card grid ───────────────────────────────────────────────────────── */
.job-card-grid { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(270px, 1fr)); gap: 1.25rem; }
.job-card { border-radius: var(--radius); background: white; border: 1px solid var(--line); border-left: 4px solid var(--river); transition: box-shadow .2s, transform .2s; }
.job-card--river  { border-left-color: var(--river); }
.job-card--green  { border-left-color: var(--green); }
.job-card--purple { border-left-color: var(--jacaranda); }
.job-card--coral  { border-left-color: var(--coral); }
.job-card--sand   { border-left-color: #b98235; }
.job-card:hover { box-shadow: 0 6px 24px rgba(0,0,0,.10); transform: translateY(-3px); }
.job-card-link { display: flex; flex-direction: column; height: 100%; text-decoration: none; color: inherit; padding: 1.1rem; gap: .45rem; }
.job-card-industry { font-size: .7rem; text-transform: uppercase; font-weight: 800; letter-spacing: .06em; color: var(--muted); }
.job-card h3 { font-family: Georgia,"Times New Roman",serif; font-size: 1.05rem; line-height: 1.3; margin: 0; color: var(--ink); flex: 1; }
.job-card-company { font-size: .84rem; font-weight: 600; color: var(--river); }
.job-card-tags { display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .35rem; }
.job-tag { background: var(--bg); border: 1px solid var(--line); border-radius: 100px; padding: .18rem .55rem; font-size: .7rem; color: var(--muted); white-space: nowrap; }
.job-card-read { font-size: .76rem; font-weight: 700; color: var(--river); padding-top: .6rem; border-top: 1px solid var(--line); margin-top: .3rem; }

/* ── Hostiq compact strip ─────────────────────────────────────────────────── */
.hostiq-strip { background: #0d1f35; border-top: 2px solid #1de9c4; }
.hostiq-strip a { max-width: 1180px; margin: 0 auto; padding: .85rem 1rem; display: flex; align-items: center; gap: 1.2rem; text-decoration: none; flex-wrap: wrap; }
.hostiq-strip__badge { background: #1de9c4; color: #0d1f35; font-size: .68rem; font-weight: 900; letter-spacing: .1em; text-transform: uppercase; padding: .25rem .7rem; border-radius: 2rem; white-space: nowrap; }
.hostiq-strip__logo { display: flex; align-items: center; gap: .5rem; }
.hostiq-strip__logo strong { color: white; font-size: 1.05rem; letter-spacing: -.01em; }
.hostiq-strip__tagline { color: rgba(255,255,255,.8); font-size: .9rem; flex: 1; }
.hostiq-strip__tagline span { color: #1de9c4; }
.hostiq-strip__cta { color: #1de9c4; font-size: .85rem; font-weight: 600; white-space: nowrap; margin-left: auto; }

/* ── News & Jobs band — editorial style ──────────────────────────────────── */
.news-jobs-band { max-width: 1180px; margin: 0 auto; padding: 2.5rem 1rem; display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.news-col > .eyebrow, .jobs-col > .eyebrow { margin-bottom: .3rem; }
.news-col > h2, .jobs-col > h2 { margin: 0 0 1.2rem; }
.news-list, .jobs-list { list-style: none; margin: 0 0 1rem; padding: 0; }
.news-list li { border-bottom: 1px solid var(--line); padding: .75rem 0; display: flex; flex-direction: column; gap: .2rem; }
.news-list li:last-child { border-bottom: none; }
.news-list a { font-size: .97rem; font-weight: 600; color: var(--ink); text-decoration: none; line-height: 1.35; }
.news-list a:hover { color: var(--accent); }
.news-meta { display: flex; gap: .5rem; align-items: center; }
.news-source { font-size: .75rem; color: var(--muted); font-weight: 500; }
.news-date { font-size: .75rem; color: var(--muted); }
.news-date::before { content: '·'; margin-right: .35rem; color: var(--line); }
.jobs-list li { border-bottom: 1px solid var(--line); padding: .75rem 0; }
.jobs-list li:last-child { border-bottom: none; }
.jobs-list a { text-decoration: none; color: inherit; }
.jobs-list a:hover .job-title { color: var(--accent); }
.job-title { font-size: .97rem; font-weight: 600; color: var(--ink); display: block; line-height: 1.35; margin-bottom: .2rem; }
.job-company { font-size: .8rem; color: var(--muted); font-weight: 500; display: block; }
.job-meta { font-size: .75rem; color: var(--muted); display: block; margin-top: .1rem; }

/* ── Compact footer ───────────────────────────────────────────────────────── */
.footer-inner-compact { max-width: 1180px; margin: 0 auto; padding: 2rem 1rem 1.2rem; }
.wordmark-sm { font-family: Georgia, "Times New Roman", serif; font-size: 1.1rem; font-weight: 700; color: var(--ink); text-decoration: none; display: inline-block; margin-bottom: 1rem; }
.footer-nav-compact { display: flex; flex-wrap: wrap; gap: .3rem .1rem; margin-bottom: 1.4rem; }
.footer-nav-compact a { color: var(--muted); font-size: .82rem; text-decoration: none; padding: .2rem .6rem; border-radius: 3px; }
.footer-nav-compact a:hover { color: var(--ink); background: var(--line); }
.footer-nav-compact a + a::before { content: '·'; margin-right: .4rem; color: var(--line); }
.footer-bottom { display: flex; justify-content: space-between; align-items: center; border-top: 1px solid var(--line); padding-top: .8rem; flex-wrap: wrap; gap: .5rem; }
.footer-bottom p { font-size: .78rem; color: var(--muted); margin: 0; }
.footer-languages a { color: var(--muted); font-size: .78rem; text-decoration: none; }
.footer-languages a:hover { color: var(--ink); }

@media (max-width: 860px) {
  .news-jobs-band { grid-template-columns: 1fr; gap: 2rem; }
  .hostiq-strip a { gap: .8rem; }
  .hostiq-strip__cta { margin-left: 0; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* ── On-site news & job article pages ─────────────────────────────────── */
.news-source-credit { font-size: .85rem; color: var(--muted); margin-top: 2rem; padding-top: 1rem; border-top: 1px solid var(--line); }
.news-source-credit a { color: var(--accent); }

.job-article .article-header { margin-bottom: 1.5rem; }
.job-meta-header { display: flex; flex-wrap: wrap; gap: .6rem; align-items: center; margin-top: .6rem; font-size: .85rem; color: var(--muted); }
.job-company-name { font-weight: 600; color: var(--ink); }
.job-location { color: var(--muted); }
.job-type-badge { background: var(--accent); color: #fff; padding: .2em .55em; border-radius: 3px; font-size: .75rem; font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.job-posted { margin-left: auto; }

.apply-btn { display: inline-block; background: var(--river); color: #fff !important; padding: .65em 1.4em; border-radius: 4px; font-weight: 700; text-decoration: none !important; transition: opacity .15s; }
.apply-btn:hover { opacity: .85; }
