/* ============================================================
   ALBERTA FREEDOM FOUNDATION — site stylesheet
   ============================================================ */

:root{
  /* core palette, drawn from the AFF mark */
  --ink:        #16294f;   /* deep navy — headlines, header/footer */
  --ink2:       #1f3a6b;   /* lighter navy for gradients/hovers */
  --paper:      #f7f4ec;   /* warm paper background */
  --paper2:     #efe9da;   /* slightly deeper paper for cards */
  --line:       #ddd4be;   /* hairline rule on paper */
  --line-dark:  rgba(255,255,255,0.14);
  --char:       #2a2722;   /* body text */
  --char2:      #534f46;   /* muted body text */
  --char3:      #7a756a;   /* captions */
  --red:        #b32c26;   /* leaf red */
  --red-deep:   #8c211c;
  --skyblue:    #6fa8c9;   /* leaf blue */
  --skyblue-deep:#3d7796;
  --gold:       #c0922f;   /* wheat gold accent */
  --gold-deep:  #97701f;
  --cream:      #fbf9f3;

  --font-display: "Oswald", "Arial Narrow", sans-serif;
  --font-body: "Source Serif 4", "Georgia", serif;
  --font-sans: "Inter", "Helvetica Neue", Arial, sans-serif;

  --maxw: 1180px;
  --maxw-article: 700px;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin:0;
  background: var(--paper);
  color: var(--char);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img{ max-width:100%; display:block; }
a{ color: inherit; }
.container{ max-width: var(--maxw); margin: 0 auto; padding: 0 1.75rem; }

h1,h2,h3,h4{
  font-family: var(--font-display);
  color: var(--ink);
  margin: 0;
  line-height: 1.08;
}

/* ── split rule, the signature device: red / gold / blue ── */
.split-rule{
  height: 5px;
  width: 100%;
  background: linear-gradient(90deg,
    var(--red) 0%, var(--red) 33%,
    var(--gold) 33%, var(--gold) 67%,
    var(--skyblue) 67%, var(--skyblue) 100%);
}
.split-rule--thin{ height:3px; }

/* eyebrow label */
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:0.6rem;
  font-family: var(--font-sans);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 0.9rem;
}
.eyebrow::before{
  content:"";
  width: 26px; height: 2px;
  background: var(--gold-deep);
  display:inline-block;
}

/* ============================================================
   SKIP LINK / FOCUS
   ============================================================ */
.skip-link{
  position:absolute; left:-999px; top:0;
  background: var(--ink); color:#fff; padding: 0.6rem 1rem;
  z-index: 2000; font-family: var(--font-sans); font-size:0.9rem;
}
.skip-link:focus{ left: 0.5rem; top: 0.5rem; }
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline: 3px solid var(--gold);
  outline-offset: 2px;
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  background: var(--ink);
  border-bottom: 4px solid var(--gold);
}
.site-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 1.5rem;
  padding: 0.9rem 0;
}
.brand{
  display:flex;
  align-items:center;
  gap: 0.85rem;
  text-decoration:none;
  flex-shrink:0;
}
.brand img{ height: 42px; width:auto; }
.brand-text{
  font-family: var(--font-display);
  color: #fff;
  font-weight: 600;
  font-size: 1.18rem;
  letter-spacing: 0.01em;
  line-height: 1.05;
}
.brand-text span{
  display:block;
  font-family: var(--font-sans);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 0.2rem;
}

.main-nav{ display:flex; align-items:center; gap: 2rem; }
.main-nav ul{
  list-style:none; display:flex; gap: 1.7rem; margin:0; padding:0;
}
.main-nav a{
  font-family: var(--font-sans);
  font-size: 0.86rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #e8e4d8;
  text-decoration:none;
  border-bottom: 2px solid transparent;
  padding-bottom: 0.2rem;
  transition: color 0.2s, border-color 0.2s;
}
.main-nav a:hover, .main-nav a.current{ color:#fff; border-bottom-color: var(--gold); }

.nav-toggle{
  display:none;
  background:none; border:none; cursor:pointer;
  color:#fff; padding: 0.4rem;
  flex-direction:column; gap:5px;
}
.nav-toggle span{ width:24px; height:2px; background:#fff; display:block; }

.mobile-nav{ display:none; }
.mobile-nav.open{
  display:flex; flex-direction:column;
  background: var(--ink2);
  padding: 0.5rem 1.75rem 1.25rem;
}
.mobile-nav a{
  color:#e8e4d8; text-decoration:none; padding: 0.8rem 0;
  border-bottom: 1px solid var(--line-dark);
  font-family: var(--font-sans); font-weight:600; font-size:0.95rem;
}
.mobile-nav a.current{ color: var(--gold); }

@media (max-width: 1180px){
  .main-nav ul{ display:none; }
  .nav-toggle{ display:flex; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  background: var(--ink);
  color: #cfc9b8;
  margin-top: 5rem;
}
.footer-top{
  padding: 3.5rem 0 2.5rem;
  display:grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap: 2.5rem;
}
.footer-brand{ display:flex; align-items:flex-start; gap:0.85rem; margin-bottom:1rem; }
.footer-brand img{ height:38px; }
.footer-brand-text{ font-family: var(--font-display); color:#fff; font-size:1.05rem; }
.footer-col-title{
  font-family: var(--font-sans); font-size: 0.74rem; font-weight:700;
  letter-spacing: 0.14em; text-transform:uppercase; color: var(--gold);
  margin-bottom: 1rem;
}
.footer-links{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:0.65rem; }
.footer-links a{ color:#cfc9b8; text-decoration:none; font-size:0.92rem; }
.footer-links a:hover{ color:#fff; text-decoration:underline; }
.footer-desc{ font-size: 0.92rem; line-height:1.7; color:#b9b3a0; max-width: 360px; }
.footer-bottom{
  border-top: 1px solid var(--line-dark);
  padding: 1.5rem 0;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem;
}
.footer-bottom p{ margin:0; font-size:0.8rem; color:#a39c88; font-family: var(--font-sans); }
.footer-bottom a{ color:#cfc9b8; text-decoration:underline; }

@media(max-width:760px){
  .footer-top{ grid-template-columns: 1fr; gap:2rem; }
}

/* ============================================================
   HOME — HERO
   ============================================================ */
.hero{
  position:relative;
  background: var(--ink);
  color:#fff;
  overflow:hidden;
  padding: 5.5rem 0 4.5rem;
}
.hero-bg-leaf{
  position:absolute;
  right: -120px;
  top: 50%;
  transform: translateY(-50%);
  width: 620px;
  opacity: 0.10;
  pointer-events:none;
}
.hero-inner{ position:relative; z-index:2; max-width: 760px; }
.hero h1{
  font-size: clamp(2.4rem, 5.2vw, 4rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.005em;
  color: #fff;
}
.hero h1 em{
  font-style:normal;
  color: var(--gold);
}
.hero-sub{
  font-family: var(--font-body);
  font-size: 1.2rem;
  color: #d8d3c2;
  max-width: 600px;
  margin: 1.4rem 0 2.2rem;
  line-height: 1.65;
}
.hero-ctas{ display:flex; gap:1rem; flex-wrap:wrap; }

.btn{
  display:inline-flex; align-items:center; gap:0.5rem;
  font-family: var(--font-sans); font-weight:700; font-size:0.88rem;
  letter-spacing:0.02em;
  padding: 0.85rem 1.6rem;
  border-radius: 2px;
  text-decoration:none;
  border: 2px solid transparent;
  transition: transform 0.15s, background 0.2s, color .2s, border-color .2s;
}
.btn:hover{ transform: translateY(-2px); }
.btn--gold{ background: var(--gold); color: var(--ink); }
.btn--gold:hover{ background:#d6a847; }
.btn--outline{ border-color: rgba(255,255,255,0.4); color:#fff; }
.btn--outline:hover{ border-color:#fff; background: rgba(255,255,255,0.08); }
.btn--ink{ background:var(--ink); color:#fff; }
.btn--ink:hover{ background:var(--ink2); }

/* ============================================================
   STATEMENT BAR (mission strip under hero)
   ============================================================ */
.statement-bar{
  background: var(--paper2);
  border-bottom: 1px solid var(--line);
  padding: 2.6rem 0;
}
.statement-bar p{
  font-family: var(--font-display);
  font-size: clamp(1.15rem, 2vw, 1.5rem);
  text-transform: uppercase;
  letter-spacing: 0.01em;
  color: var(--ink);
  max-width: 920px;
  line-height: 1.4;
  margin:0;
}
.statement-bar p strong{ color: var(--red); }

/* ============================================================
   ESSAY GRID (homepage + index page)
   ============================================================ */
.section{ padding: 4.5rem 0; }
.section-head{ max-width: 680px; margin-bottom: 2.75rem; }
.section-head h2{
  font-size: clamp(1.7rem, 3vw, 2.3rem);
  text-transform: uppercase;
}
.section-head p{
  font-family: var(--font-body);
  color: var(--char2);
  font-size: 1.05rem;
  margin-top: 0.75rem;
}

.essay-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
}
@media(max-width:980px){ .essay-grid{ grid-template-columns: repeat(2,1fr); } }
@media(max-width:640px){ .essay-grid{ grid-template-columns: 1fr; } }

.essay-card{
  background: #fff;
  border: 1px solid var(--line);
  display:flex; flex-direction:column;
  text-decoration:none; color: inherit;
  transition: box-shadow 0.2s, transform 0.2s;
  position:relative;
}
.essay-card:hover{
  box-shadow: 0 14px 34px rgba(22,41,79,0.14);
  transform: translateY(-3px);
}
.essay-card-bar{ height:5px; }
.essay-card-bar--1{ background: var(--red); }
.essay-card-bar--2{ background: var(--gold); }
.essay-card-bar--3{ background: var(--skyblue-deep); }
.essay-card-img{ width:100%; height:170px; object-fit:cover; background: var(--paper2); }
.essay-card-body{ padding: 1.5rem 1.5rem 1.75rem; display:flex; flex-direction:column; gap:0.6rem; flex:1; }
.essay-card-num{
  font-family: var(--font-sans); font-size: 0.72rem; font-weight:700;
  letter-spacing:0.12em; text-transform:uppercase; color: var(--char3);
}
.essay-card h3{
  font-size: 1.28rem;
  text-transform: none;
  letter-spacing: 0;
}
.essay-card p{
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--char2);
  line-height: 1.6;
  flex:1;
}
.essay-card-read{
  font-family: var(--font-sans); font-size: 0.82rem; font-weight:700;
  color: var(--ink); letter-spacing:0.02em;
  display:flex; align-items:center; gap:0.4rem;
  margin-top: 0.4rem;
}
.essay-card:hover .essay-card-read{ color: var(--red); }

/* ============================================================
   PILLARS / VALUES (home)
   ============================================================ */
.pillars{
  display:grid;
  grid-template-columns: repeat(4,1fr);
  gap: 1.5rem;
}
@media(max-width:980px){ .pillars{ grid-template-columns: repeat(2,1fr); } }
@media(max-width:560px){ .pillars{ grid-template-columns: 1fr; } }
.pillar{
  border-top: 3px solid var(--gold);
  padding-top: 1.25rem;
}
.pillar-num{
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--line);
  -webkit-text-stroke: 1.5px var(--ink);
  color: transparent;
  margin-bottom: 0.5rem;
  display:block;
}
.pillar h3{ font-size: 1.05rem; text-transform: uppercase; margin-bottom: 0.5rem; }
.pillar p{ font-family: var(--font-body); font-size: 0.92rem; color: var(--char2); line-height:1.6; }

/* ============================================================
   DISCLOSURE / ABOUT CALLOUT BOX
   ============================================================ */
.callout{
  max-width: var(--maxw-article);
  margin: 0 auto;
  padding: 1.6rem 1.85rem;
  background: var(--cream);
  border: 1px solid var(--line);
  border-left: 4px solid var(--gold);
}
.callout p{ font-size: 0.94rem; color: var(--char2); line-height: 1.7; margin:0; }
.callout p + p{ margin-top: 0.7rem; }
.callout strong{ color: var(--ink); }

/* ============================================================
   ARTICLE / OPINION PAGE
   ============================================================ */
.article-banner{
  background: var(--gold);
  color: var(--ink);
  text-align:center;
  padding: 0.7rem 1rem;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.essay-subnav{
  background: var(--ink);
  border-bottom: 1px solid var(--line-dark);
  position: sticky; top:0; z-index: 400;
}
.essay-subnav-inner{
  max-width: var(--maxw);
  margin:0 auto;
  padding: 0.8rem 1.75rem;
  display:flex; align-items:center; gap:1.25rem 1.75rem; flex-wrap:wrap;
  min-height: 54px;
}
.essay-subnav-label{
  font-family: var(--font-sans); font-size: 0.72rem; font-weight:700;
  letter-spacing:0.14em; text-transform:uppercase; color: var(--gold);
  flex-shrink:0;
}
.essay-subnav-list{ list-style:none; display:flex; gap:1.5rem; margin:0; padding:0; flex-wrap:wrap; flex:1; }
.essay-subnav-list a{
  font-family: var(--font-sans); font-size:0.86rem; font-weight:600;
  color: #cfc9b8; text-decoration:none; border-bottom:1px solid transparent;
  padding-bottom:0.15rem; white-space:nowrap;
}
.essay-subnav-list a:hover{ color:#fff; }
.essay-subnav-list a.current{ color: var(--gold); border-bottom-color: var(--gold); }

.essay-nav-toggle{
  display:none; align-items:center; gap:0.6rem;
  background:none; border:none; color:#fff; cursor:pointer;
  font-family: var(--font-sans); font-size:0.82rem; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase; width:100%; padding:0;
}
.essay-nav-toggle .ham{ display:flex; flex-direction:column; gap:4px; width:20px; flex-shrink:0; }
.essay-nav-toggle .ham span{ width:100%; height:2px; background: var(--gold); display:block; transition: transform .2s, opacity .2s; }
.essay-nav-toggle.open .ham span:nth-child(1){ transform: translateY(6px) rotate(45deg); }
.essay-nav-toggle.open .ham span:nth-child(2){ opacity:0; }
.essay-nav-toggle.open .ham span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }
.essay-nav-toggle-current{ color:#cfc9b8; font-weight:400; text-transform:none; letter-spacing:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

.essay-mobile-dropdown{ display:none; flex-direction:column; padding: 0 1.75rem 0.9rem; max-width:var(--maxw); margin:0 auto; }
.essay-mobile-dropdown.open{ display:flex; }
.essay-mobile-dropdown a{
  padding:0.8rem 0; border-bottom:1px solid var(--line-dark);
  font-family: var(--font-sans); font-size:0.98rem; font-weight:600;
  color:#cfc9b8; text-decoration:none;
}
.essay-mobile-dropdown a.current{ color: var(--gold); }

@media(max-width:1180px){
  .essay-subnav-inner{ display:none; }
  .essay-nav-toggle{ display:flex; }
  .essay-nav-toggle-wrap{ max-width:var(--maxw); margin:0 auto; padding:0.85rem 1.75rem; }
}

.article-hero{
  padding: 3.5rem 0 2.75rem;
  background: var(--paper2);
  border-bottom: 1px solid var(--line);
}
.article-hero .eyebrow{ color: var(--red-deep); }
.article-hero .eyebrow::before{ background: var(--red-deep); }
.article-title{
  font-size: clamp(2rem, 4.2vw, 3.1rem);
  text-transform: uppercase;
  max-width: 820px;
}
.article-byline{
  margin-top: 1.1rem;
  font-family: var(--font-sans);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--char3);
}
.article-hero-media{
  margin-top: 2.25rem;
  max-width: 460px;
  border: 1px solid var(--line);
  overflow:hidden;
  box-shadow: 0 18px 40px rgba(22,41,79,0.12);
}
.article-hero-media img{ width:100%; display:block; }

.article-body{
  max-width: var(--maxw-article);
  margin: 0 auto;
  padding: 3.75rem 0;
}
.article-body h2{
  font-size: 1.7rem;
  text-transform: uppercase;
  letter-spacing: 0.015em;
  margin: 2.75rem 0 1rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--line);
  display:flex; align-items:center; gap:0.7rem;
}
.article-body h2:first-of-type{ border-top:none; margin-top:0; padding-top:0; }
.article-body h3{
  font-size: 1.12rem;
  color: var(--red-deep);
  margin: 1.6rem 0 0.7rem;
  text-transform: uppercase;
  letter-spacing:0.02em;
}
.article-body p{
  font-size: 1.06rem;
  color: var(--char);
  line-height: 1.82;
  margin-bottom: 1.2rem;
}
.article-body p strong{ color: var(--ink); font-weight:700; }
.article-body p em{ color: var(--red-deep); font-style:italic; }
.article-body ul, .article-body ol{
  margin: 1.2rem 0 1.5rem; padding-left:1.4rem;
  display:flex; flex-direction:column; gap:0.6rem;
}
.article-body ul li, .article-body ol li{ font-size:1rem; color:var(--char); line-height:1.7; }
.article-body ul li strong, .article-body ol li strong{ color: var(--ink); }

/* sources / citation list — last h2 block in each essay, set smaller & quieter */
.article-body .sources-list{
  font-size: 0.88rem;
  color: var(--char2);
  gap: 0.5rem;
}
.article-body .sources-list li{ font-size: 0.88rem; color: var(--char2); line-height:1.6; }

.section-num{
  display:inline-flex; align-items:center; justify-content:center;
  width:30px; height:30px; border-radius:50%;
  background: var(--ink); color:#fff;
  font-family: var(--font-display); font-size:0.85rem; font-weight:700;
  flex-shrink:0;
}

/* ── BILL / LEGISLATION STATUS TABLE ── */
.bill-table{
  margin: 2rem 0;
  border: 1px solid var(--line);
  background: #fff;
}
.bill-row{
  display:grid;
  grid-template-columns: 90px 1fr 150px;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.bill-row:last-child{ border-bottom:none; }
.bill-row .bill-num{
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--gold-deep);
}
.bill-row .bill-desc{
  font-size: 0.88rem;
  color: var(--char2);
  line-height: 1.5;
}
.bill-row .bill-status{
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-align: right;
  color: var(--char3);
}
.bill-status.is-law{ color: #3f7d3f; }
.bill-status.is-dead{ color: var(--char3); }

@media(max-width:640px){
  .bill-row{ grid-template-columns: 1fr; gap: 0.35rem; }
  .bill-row .bill-status{ text-align:left; }
}

/* ── SOURCES BOX (boxed variant used by longer essays) ── */
.sources-box{
  max-width: var(--maxw-article);
  margin: 3rem auto 0;
  padding: 2rem 2.25rem;
  background: var(--cream);
  border: 1px solid var(--line);
}
.sources-box h2{ border-top:none; margin-top:0; padding-top:0; font-size:1.1rem; }
.sources-box ol{ margin:1rem 0 0; padding-left:1.3rem; display:flex; flex-direction:column; gap:0.5rem; }
.sources-box ol li{ font-size:0.88rem; color:var(--char3); line-height:1.6; }

/* ── STATUS TIMELINE (legislative/process timeline rows) ── */
.status-box{
  margin: 2rem 0;
  border: 1px solid var(--line);
  background: #fff;
}
.status-row{
  display:grid;
  grid-template-columns: 130px 1fr;
  gap: 1.25rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.status-row:last-child{ border-bottom:none; }
.status-row .status-date{
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--gold-deep);
}
.status-row .status-text{ font-size:0.92rem; color:var(--char2); line-height:1.6; }
.status-row .status-text strong{ color: var(--ink); }

@media(max-width:640px){
  .status-row{ grid-template-columns: 1fr; gap:0.35rem; }
}

/* ── STAT GRID (key figures, 3-up) ── */
.stat-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  margin: 2rem 0;
}
.stat-item{
  background: #fff;
  padding: 1.5rem 1.25rem;
  text-align: center;
}
.stat-num{
  font-family: var(--font-display);
  font-size: 1.9rem;
  font-weight: 700;
  color: var(--gold-deep);
  line-height: 1;
}
.stat-label{
  font-family: var(--font-sans);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--char3);
  margin-top: 0.5rem;
  line-height: 1.4;
}
@media(max-width:640px){
  .stat-grid{ grid-template-columns: 1fr; }
}

.pull-quote{
  margin: 2.4rem 0;
  padding: 1.6rem 1.9rem;
  background: var(--cream);
  border-left: 4px solid var(--red-deep);
}
.pull-quote p{
  font-family: var(--font-body); font-style:italic;
  font-size: 1.28rem; color: var(--ink); margin:0; line-height:1.5;
}

.fn-callout{
  max-width: var(--maxw-article);
  margin: 3rem auto 0;
  padding: 2.1rem 2.3rem;
  background: var(--paper2);
  border: 1px solid var(--line);
}
.fn-callout .eyebrow{ color: var(--skyblue-deep); }
.fn-callout .eyebrow::before{ background: var(--skyblue-deep); }
.fn-callout h2{ border-top:none; margin-top:0; padding-top:0; }
.fn-callout p{ font-size:1rem; color:var(--char2); line-height:1.75; }

.article-disclosure{
  max-width: var(--maxw-article);
  margin: 0 auto 1rem;
}

.article-foot-nav{
  max-width: var(--maxw-article);
  margin: 0 auto 4rem;
  padding-top: 2rem;
  border-top: 1px solid var(--line);
  display:flex; justify-content:space-between; gap:1.5rem; flex-wrap:wrap;
}
.article-foot-nav a{
  font-family: var(--font-sans); font-weight:700; font-size:0.88rem;
  color: var(--ink); text-decoration:none;
}
.article-foot-nav a:hover{ color: var(--red-deep); }

@media(max-width:640px){
  .article-body h2{ font-size:1.35rem; }
  .pull-quote p{ font-size:1.08rem; }
  .fn-callout{ padding:1.5rem 1.4rem; }
}

/* ============================================================
   GENERIC PAGE (about, transparency, etc.)
   ============================================================ */
.page-hero{
  padding: 4rem 0 3rem;
  background: var(--ink);
  color:#fff;
}
.page-hero h1{ color:#fff; font-size: clamp(2.1rem,4vw,3rem); text-transform:uppercase; }
.page-hero .eyebrow{ color: var(--gold); }
.page-hero .eyebrow::before{ background: var(--gold); }
.page-hero p.lead{ font-family: var(--font-body); color:#d8d3c2; font-size:1.1rem; max-width:680px; margin-top:1rem; line-height:1.65; }

.prose{ max-width: var(--maxw-article); margin:0 auto; padding: 3.5rem 0; }
.prose h2{ font-size:1.5rem; text-transform:uppercase; margin: 2.2rem 0 0.9rem; }
.prose h2:first-child{ margin-top:0; }
.prose p{ font-size:1.04rem; color:var(--char); line-height:1.8; margin-bottom:1.1rem; }
.prose ul{ padding-left:1.4rem; display:flex; flex-direction:column; gap:0.55rem; margin-bottom:1.3rem; }
.prose li{ font-size:1rem; color:var(--char); line-height:1.7; }
.prose a{ color: var(--red-deep); text-decoration:underline; }

table.data-table{ width:100%; border-collapse:collapse; margin: 1.5rem 0 2rem; font-family: var(--font-sans); font-size:0.92rem; }
table.data-table th, table.data-table td{ padding:0.65rem 0.9rem; border:1px solid var(--line); text-align:left; }
table.data-table th{ background: var(--paper2); font-weight:700; color: var(--ink); }

/* contact form */
.contact-form{ display:flex; flex-direction:column; gap:1.2rem; max-width:520px; }
.contact-form label{ font-family: var(--font-sans); font-size:0.82rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink); margin-bottom:0.4rem; display:block; }
.contact-form input, .contact-form textarea{
  width:100%; padding:0.75rem 0.9rem; border:1px solid var(--line);
  background:#fff; font-family: var(--font-body); font-size:1rem; color: var(--char);
}
.contact-form input:focus, .contact-form textarea:focus{ outline:2px solid var(--gold); border-color: var(--gold); }
.contact-form button{ align-self:flex-start; cursor:pointer; font-family: var(--font-sans); }

/* reveal-on-scroll (progressive enhancement; CSS-only fallback = always visible) */
.reveal{ opacity:1; }

.visually-hidden{
  position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0,0,0,0);
}
