/* GPA South Africa — static site
   Design tokens
   ink    #14141a  — primary text / dark sections
   paper  #f6f4ef  — page background
   signal #fe4935  — brand accent (from GPA mark)
   slate  #5b6472  — secondary text
   line   #e2ddd2  — hairline rules
   card   #ffffff  — card surfaces
*/

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --ink:#14141a;
  --paper:#f6f4ef;
  --signal:#fe4935;
  --slate:#5b6472;
  --line:#e2ddd2;
  --card:#ffffff;
  --mist:#e3e0d8;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:'IBM Plex Sans',system-ui,sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;display:block;}
a{color:inherit;}

h1,h2,h3,h4{
  font-family:'Fraunces',serif;
  font-weight:600;
  line-height:1.12;
  margin:0 0 .5em;
  letter-spacing:-0.01em;
}
h1{font-size:clamp(2.4rem,5vw,4.2rem);font-weight:500;}
h2{font-size:clamp(1.7rem,3vw,2.6rem);}
h3{font-size:1.3rem;}

p{margin:0 0 1em;color:var(--slate);}

.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:.75rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--signal);
  display:flex;
  align-items:center;
  gap:.6em;
  margin-bottom:1em;
}
.eyebrow::before{
  content:"";
  width:26px;height:1px;
  background:var(--signal);
  display:inline-block;
}

.wrap{max-width:1180px;margin:0 auto;padding:0 32px;}

:focus-visible{outline:2px solid var(--signal);outline-offset:3px;}

[id]{scroll-margin-top:118px;}

/* -------- utility bar -------- */
.utility-bar{
  background:var(--mist);
  color:var(--ink);
  font-family:'IBM Plex Sans',system-ui,sans-serif;
  font-size:.82rem;
  border-bottom:1px solid var(--line);
}
.utility-bar .wrap{
  display:flex;
  justify-content:flex-end;
  gap:28px;
  padding:9px 32px;
}
.utility-bar a{text-decoration:none;color:var(--ink);transition:color .15s;}
.utility-bar a:hover{color:var(--signal);}

/* -------- header / nav -------- */
header.site-header{
  background:#ffffff;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.nav-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 32px;
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;}
.brand img{height:58px;width:auto;}
.brand-text{font-family:'Fraunces',serif;color:var(--ink);line-height:1.1;}
.brand-text strong{display:block;font-size:1.15rem;font-weight:600;}
.brand-text span{
  display:block;font-family:'IBM Plex Mono',monospace;
  font-size:.65rem;letter-spacing:.1em;text-transform:uppercase;color:var(--signal);
  margin-top:2px;
}
nav.main-nav ul{
  list-style:none;display:flex;gap:2px;margin:0;padding:0;
}
nav.main-nav a{
  text-decoration:none;color:var(--slate);
  font-size:.92rem;font-weight:500;
  padding:10px 18px;display:block;border-radius:2px;
  position:relative;
  transition:color .15s;
}
nav.main-nav a::after{
  content:"";position:absolute;left:18px;right:18px;bottom:6px;height:1px;
  background:var(--signal);transform:scaleX(0);transform-origin:left;
  transition:transform .2s ease;
}
nav.main-nav a:hover{color:var(--ink);}
nav.main-nav a:hover::after,
nav.main-nav a.active::after{transform:scaleX(1);}
nav.main-nav a.active{color:var(--ink);}

.nav-toggle{display:none;color:var(--ink);}

/* -------- hero -------- */
.hero{
  position:relative;
  color:#fff;
  min-height:78vh;
  display:flex;
  align-items:flex-end;
  background-size:cover;
  background-position:center;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(20,20,26,.35) 0%, rgba(20,20,26,.55) 55%, rgba(20,20,26,.92) 100%);
}
.hero-inner{position:relative;z-index:1;padding:64px 0 56px;width:100%;}
.hero .eyebrow{color:#fed03d;}
.hero .eyebrow::before{background:#fed03d;}
.hero h1{color:#fff;max-width:14ch;}
.hero-lede{max-width:52ch;font-size:1.08rem;color:#e9e7e1;}
.hero-actions{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;}

/* page (inner) header, no full hero */
.page-header{
  position:relative;color:#fff;background-size:cover;background-position:center;
  padding:120px 0 54px;
}
.page-header::before{
  content:"";position:absolute;inset:0;background:rgba(20,20,26,.72);
}
.page-header .wrap{position:relative;z-index:1;}
.page-header h1{color:#fff;margin-bottom:.2em;}
.crumb{
  font-family:'IBM Plex Mono',monospace;font-size:.75rem;letter-spacing:.1em;
  text-transform:uppercase;color:#cfcdc6;
}
.crumb a{color:#cfcdc6;text-decoration:none;}
.crumb a:hover{color:var(--signal);}

/* -------- buttons -------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'IBM Plex Mono',monospace;
  font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;
  padding:14px 26px;
  text-decoration:none;
  border:1px solid transparent;
  transition:all .18s ease;
}
.btn-primary{background:var(--signal);color:#fff;}
.btn-primary:hover{background:#e33d24;}
.btn-outline{border-color:rgba(255,255,255,.55);color:#fff;}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.btn-dark{border-color:var(--ink);color:var(--ink);}
.btn-dark:hover{background:var(--ink);color:#fff;}

/* -------- sections -------- */
section{padding:88px 0;}
.section-tight{padding:56px 0;}
.section-line{border-top:1px solid var(--line);}
.bg-ink{background:var(--ink);color:#fff;}
.bg-ink p{color:#c8c6bf;}
.bg-ink h2{color:#fff;}
.bg-card{background:var(--card);}

.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:56px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}

/* -------- ledger / statement list (signature element) -------- */
.statement{border-top:1px solid var(--line);}
.ledger-item{
  display:grid;
  grid-template-columns:56px 1fr;
  gap:24px;
  padding:26px 0;
  border-bottom:1px solid var(--line);
}
.ledger-num{
  font-family:'IBM Plex Mono',monospace;
  font-size:.85rem;color:var(--signal);padding-top:.3em;
}
.ledger-body h3{margin-bottom:.35em;font-size:1.15rem;}
.ledger-head{
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
}
.ledger-head .dots{
  flex:1;border-bottom:1px dotted #c9c4b7;
  height:0;min-width:24px;
  transform:translateY(-6px);
}
.ledger-body p{margin:0;max-width:58ch;}

/* -------- cards -------- */
.card{
  background:var(--card);border:1px solid var(--line);
  padding:32px 28px;
}
.card .eyebrow{margin-bottom:.7em;}

.quote-card{
  background:var(--card);border:1px solid var(--line);
  padding:30px 26px;
}
.quote-mark{color:var(--signal);font-size:1.6rem;font-family:'Fraunces',serif;line-height:1;}
.quote-card p{color:var(--ink);font-style:italic;margin-top:.6em;}
.quote-source{
  font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--slate);margin-top:14px;display:block;
}

/* -------- stats strip -------- */
.stat-strip{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--line);
}
.stat-strip div{
  padding:26px 22px;border-left:1px solid var(--line);
}
.stat-strip div:first-child{border-left:none;}
.stat-num{font-family:'Fraunces',serif;font-size:1.9rem;font-weight:600;}
.stat-label{
  font-family:'IBM Plex Mono',monospace;font-size:.7rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--slate);
}

/* -------- contact -------- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:0;border:1px solid var(--line);}
.contact-panel{background:var(--ink);color:#fff;padding:44px 38px;}
.contact-panel h3{color:#fff;font-size:1rem;text-transform:uppercase;letter-spacing:.08em;font-family:'IBM Plex Mono',monospace;font-weight:500;margin-bottom:1.4em;}
.contact-line{border-top:1px dashed rgba(255,255,255,.25);padding:16px 0;}
.contact-line:first-of-type{border-top:none;}
.contact-line .k{font-family:'IBM Plex Mono',monospace;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:#fed03d;margin-bottom:6px;}
.contact-line a{color:#fff;text-decoration:none;font-size:1.02rem;}
.contact-line a:hover{color:var(--signal);}
.contact-form{padding:44px 38px;background:var(--card);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{margin-bottom:16px;}
.field label{
  display:block;font-family:'IBM Plex Mono',monospace;font-size:.7rem;
  letter-spacing:.08em;text-transform:uppercase;color:var(--slate);margin-bottom:6px;
}
.field input,.field textarea{
  width:100%;border:1px solid var(--line);background:var(--paper);
  padding:12px 14px;font-family:'IBM Plex Sans',sans-serif;font-size:.95rem;color:var(--ink);
}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--signal);}
.field textarea{resize:vertical;min-height:120px;}
.map-frame{border:1px solid var(--line);height:340px;}
.map-frame iframe{width:100%;height:100%;border:0;}

/* -------- footer -------- */
footer.site-footer{background:var(--mist);color:var(--slate);padding:64px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--line);}
.footer-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.footer-brand img{height:50px;}
.footer-brand strong{font-family:'Fraunces',serif;color:var(--ink);font-size:1.05rem;}
footer h4{
  font-family:'IBM Plex Mono',monospace;font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--signal);margin-bottom:1.1em;font-weight:500;
}
footer ul{list-style:none;margin:0;padding:0;}
footer li{margin-bottom:10px;}
footer a{color:var(--slate);text-decoration:none;font-size:.92rem;}
footer a:hover{color:var(--signal);}
.footer-bottom{
  display:flex;justify-content:space-between;padding:20px 0;
  font-family:'IBM Plex Mono',monospace;font-size:.72rem;color:var(--slate);flex-wrap:wrap;gap:8px;
}

/* -------- responsive -------- */
@media (max-width: 900px){
  .grid-2{grid-template-columns:1fr;gap:32px;}
  .grid-3{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .stat-strip{grid-template-columns:1fr 1fr;}
  .stat-strip div:nth-child(3){border-left:none;}
  .footer-grid{grid-template-columns:1fr;}
  nav.main-nav{
    position:fixed;inset:64px 0 0 0;background:#ffffff;border-top:1px solid var(--line);
    display:none;flex-direction:column;padding:20px 32px;
  }
  nav.main-nav.open{display:flex;}
  nav.main-nav ul{flex-direction:column;}
  .nav-toggle{
    display:block;background:none;border:0;color:var(--ink);font-size:1.6rem;cursor:pointer;
    line-height:1;padding:4px;
  }
  .form-row{grid-template-columns:1fr;}
}
@media (max-width: 600px){
  .wrap{padding:0 20px;}
  section{padding:56px 0;}
  .hero{min-height:88vh;}
  .ledger-item{grid-template-columns:36px 1fr;}
}
