/* ============================================================
   ORCD — Organization for Research and Community Development
   Redesign 2026 · shared stylesheet
   Palette: lapis #1E4D8C · ink #16222F · saffron #C9881B
            paper #FFFFFF · mist #F2F5F9
   Type:    Bricolage Grotesque (display) · Public Sans (body)
            IBM Plex Mono (labels / data)
   ============================================================ */

:root{
  --lapis:#198754;
  --lapis-deep:#146C43;
  --lapis-night:#0F5132;
  --ink:#16222F;
  --slate:#46586B;
  --saffron:#C9881B;
  --paper:#FFFFFF;
  --mist:#F2F5F9;
  --line:#D8E0E9;
  --radius:10px;
  --max:1180px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}

body{
  font-family:"Public Sans",system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  font-size:17px;
}

img{max-width:100%;display:block}
a{color:var(--lapis);text-decoration:none}
a:hover{text-decoration:underline}
a:focus-visible,button:focus-visible{outline:3px solid var(--saffron);outline-offset:2px}

h1,h2,h3,h4{
  font-family:"Bricolage Grotesque","Public Sans",sans-serif;
  line-height:1.12;
  font-weight:700;
  color:var(--ink);
}

.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

.eyebrow{
  font-family:"IBM Plex Mono",monospace;
  font-size:.78rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--saffron);
  display:block;
  margin-bottom:14px;
}

.brand-mark img{
width:48px;
height:48px;
object-fit:contain;
}

/* ---------- top bar ---------- */
.topbar{background:var(--lapis-night);color:#D8F3DC;font-size:.82rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;min-height:38px;gap:16px;flex-wrap:wrap}
.topbar a{color:#FFFFFF;}
.topbar .mono{font-family:"IBM Plex Mono",monospace;letter-spacing:.04em}

/* ---------- header / nav ---------- */
.site-header{
  background:var(--paper);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:50;
}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;min-height:78px;gap:20px}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand:hover{text-decoration:none}
.brand-mark{
  width:46px;height:46px;flex:0 0 46px;border-radius:9px;
  background:transparent;
  display:grid;place-items:center;
}
.brand-mark svg{width:30px;height:30px}
.brand-text{line-height:1.15}
.brand-text strong{
  font-family:"Bricolage Grotesque",sans-serif;
  font-size:1.3rem;color:var(--ink);display:block;letter-spacing:.01em;
}
.brand-text span{font-size:.72rem;color:var(--slate);display:block;max-width:340px}

nav.main-nav ul{display:flex;list-style:none;gap:6px;align-items:center;flex-wrap:wrap}
nav.main-nav a{
  display:block;padding:10px 14px;border-radius:8px;
  color:var(--ink);font-weight:600;font-size:.92rem;
}
nav.main-nav a:hover{background:var(--mist);text-decoration:none}
nav.main-nav a[aria-current="page"]{background:var(--mist);color:var(--lapis)}
nav.main-nav a.cta{
  background:var(--saffron);color:#fff;margin-left:6px;
}
nav.main-nav a.cta:hover{background:#A86F12}

.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:1.1rem;cursor:pointer;color:var(--ink)}

@media (max-width:920px){
  .nav-toggle{display:block}
  nav.main-nav{display:none;width:100%}
  nav.main-nav.open{display:block;padding-bottom:14px}
  nav.main-nav ul{flex-direction:column;align-items:stretch;gap:2px}
  .site-header .wrap{flex-wrap:wrap}
}

/* ---------- girih lattice band (signature) ---------- */
.lattice{
  height:14px;
  background-color:var(--lapis-deep);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='14' viewBox='0 0 56 14'%3E%3Cg fill='none' stroke='%235B83B8' stroke-width='1.2'%3E%3Cpath d='M0 7 L14 0 L28 7 L14 14 Z'/%3E%3Cpath d='M28 7 L42 0 L56 7 L42 14 Z'/%3E%3C/g%3E%3C/svg%3E");
  background-repeat:repeat-x;
}

/* ---------- hero ---------- */
.hero{
  background:var(--lapis-night);
  color:#EAF1F8;
  position:relative;
  overflow:hidden;
}
.hero::after{
  content:"";
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='112' height='112' viewBox='0 0 112 112'%3E%3Cg fill='none' stroke='%23388E3C' stroke-width='1'%3E%3Cpath d='M0 56 L28 28 L56 56 L28 84 Z'/%3E%3Cpath d='M56 56 L84 28 L112 56 L84 84 Z'/%3E%3Cpath d='M28 0 L56 28 L84 0'/%3E%3Cpath d='M28 112 L56 84 L84 112'/%3E%3C/g%3E%3C/svg%3E");
  opacity:.5;
  pointer-events:none;
}
.hero .wrap{position:relative;z-index:1;padding-top:84px;padding-bottom:64px}
.hero h1{
  color:#fff;
  font-size:clamp(2.1rem,4.6vw,3.6rem);
  max-width:18ch;
  letter-spacing:-.01em;
}
.hero p.lede{
  margin-top:22px;max-width:62ch;font-size:1.08rem;color:#D8F3DC;
}
.hero .actions{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.btn{
  display:inline-block;padding:13px 26px;border-radius:9px;
  font-weight:700;font-size:.95rem;border:0;cursor:pointer;
}
.btn-primary{background:var(--saffron);color:#fff}
.btn-primary:hover{background:#A86F12;text-decoration:none}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid #5B83B8}
.btn-ghost:hover{border-color:#fff;text-decoration:none}

/* stats strip */
.stats{
  background:var(--lapis-deep);
  border-top:1px solid #2E7D32;
  color:#fff;position:relative;z-index:1;
}
.stats .wrap{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;padding-top:30px;padding-bottom:30px;
}
.stat{padding:0 22px;border-left:1px solid #2E7D32}
.stat:first-child{border-left:0;padding-left:0}
.stat b{
  font-family:"Bricolage Grotesque",sans-serif;
  font-size:2.1rem;display:block;line-height:1;
}
.stat span{font-family:"IBM Plex Mono",monospace;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:#B7E4C7;display:block;margin-top:8px}
@media (max-width:760px){
  .stats .wrap{grid-template-columns:repeat(2,1fr);row-gap:26px}
  .stat:nth-child(3){border-left:0;padding-left:0}
}

/* provinces ribbon */
.provinces{
  background:var(--mist);border-bottom:1px solid var(--line);
  overflow:hidden;white-space:nowrap;
}
.provinces .track{
  display:inline-block;padding:12px 0;
  font-family:"IBM Plex Mono",monospace;font-size:.78rem;
  letter-spacing:.12em;text-transform:uppercase;color:var(--slate);
  animation:ticker 60s linear infinite;
}
.provinces .track i{font-style:normal;color:var(--saffron);padding:0 14px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.provinces .track{animation:none}}

/* ---------- sections ---------- */
section.block{padding:78px 0}
section.block.tint{background:var(--mist)}
.section-head{max-width:720px;margin-bottom:44px}
.section-head h2{font-size:clamp(1.7rem,3vw,2.4rem)}
.section-head p{margin-top:14px;color:var(--slate)}

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

.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
}
.tint .card{background:#fff}
.card h3{font-size:1.18rem;margin-bottom:10px}
.card p{font-size:.95rem;color:var(--slate)}
.card .tag{
  font-family:"IBM Plex Mono",monospace;font-size:.7rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--lapis);display:block;margin-bottom:12px;
}

/* credential rows */
.cred{
  display:grid;grid-template-columns:120px 1fr;gap:26px;
  padding:30px 0;border-top:1px solid var(--line);align-items:start;
}
.cred:last-child{border-bottom:1px solid var(--line)}
.cred .year{
  font-family:"IBM Plex Mono",monospace;color:var(--saffron);
  font-size:.9rem;letter-spacing:.08em;padding-top:4px;
}
.cred h3{font-size:1.15rem;margin-bottom:8px}
.cred p{color:var(--slate);font-size:.96rem;max-width:70ch}
@media (max-width:640px){.cred{grid-template-columns:1fr;gap:8px}}

/* partner list */
.partners{display:flex;flex-wrap:wrap;gap:10px}
.partners a{
  border:1px solid var(--line);border-radius:999px;
  padding:9px 18px;font-size:.88rem;font-weight:600;color:var(--ink);
  background:#fff;
}
.partners a:hover{border-color:var(--lapis);color:var(--lapis);text-decoration:none}

/* announcements */
.notice{
  border-left:4px solid var(--saffron);
  background:#fff;border-radius:0 var(--radius) var(--radius) 0;
  border-top:1px solid var(--line);border-right:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 26px;margin-bottom:18px;
}
.notice h3{font-size:1.05rem;margin-bottom:6px}
.notice p{font-size:.93rem;color:var(--slate)}

/* photo band */
.photo-band img{width:100%;height:340px;object-fit:cover;border-radius:var(--radius)}

/* contact */
.contact-card{
  background:var(--lapis-night);color:#DCE7F2;border-radius:var(--radius);
  padding:40px;display:grid;grid-template-columns:1.2fr 1fr;gap:36px;
}
.contact-card h2{color:#fff;font-size:1.8rem}
.contact-card a{color:#FFD27A}
.contact-card .mono{font-family:"IBM Plex Mono",monospace;font-size:.92rem;line-height:2}
@media (max-width:760px){.contact-card{grid-template-columns:1fr}}

/* ---------- footer ---------- */
footer{background:var(--lapis-night);color:#D8F3DC;font-size:.9rem}
footer .wrap{padding:60px 24px 36px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px}
footer h4{color:#fff;font-size:.95rem;margin-bottom:16px;font-family:"IBM Plex Mono",monospace;letter-spacing:.1em;text-transform:uppercase;font-weight:600}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:#B9CADD}
footer a:hover{color:#fff}
.foot-base{border-top:1px solid #2E7D32}
.foot-base .wrap{display:flex;justify-content:space-between;gap:16px;padding:20px 24px;flex-wrap:wrap;font-size:.8rem;color:#7E96B0}
@media (max-width:920px){footer .wrap{grid-template-columns:1fr 1fr}}
@media (max-width:560px){footer .wrap{grid-template-columns:1fr}}

/* page hero (inner pages) */
.page-hero{background:var(--lapis-night);color:#fff}
.page-hero .wrap{padding:64px 24px 52px}
.page-hero h1{color:#fff;font-size:clamp(1.9rem,3.6vw,2.8rem)}
.page-hero p{margin-top:14px;color:#D8F3DC;max-width:62ch}

/* prose */
.prose{max-width:760px}
.prose p{margin-bottom:18px;color:var(--ink)}
.prose h2{font-size:1.5rem;margin:38px 0 14px}
.prose ul{margin:0 0 18px 22px}
.prose li{margin-bottom:8px}
