@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&display=swap");

:root{
  --header-offset: 72px;
  --header-height: 72px;
  --bg: #f7f6f2;
  --panel: #ffffff;
  --panel-2: #f1ede6;
  --text: #0b1f33;
  --muted: #516273;
  --muted-2: #6b7a8a;
  --accent: #0f2942;
  --accent-deep: #0b1f33;
  --accent-2: #2f6fb3;
  --gold: #b8860b;
  --gold-light: #d4a84b;
  --accent-red: #b8860b;
  --accent-green: #1a6b4a;
  --accent-soft: rgba(184,134,11,.12);
  --border: rgba(15,41,66,0.12);
  --border-strong: rgba(15,41,66,0.2);
  --shadow: 0 10px 30px rgba(11,31,51,.08);
  --shadow-soft: 0 8px 18px rgba(11,31,51,.08);
  --warm-accent: #b8860b;
  --warm-soft: rgba(184,134,11,.12);
  --radius-sm: 6px;
  --radius: 10px;
  --radius-lg: 16px;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 32px;
  --space-8: 40px;
  --space-9: 56px;
  --space-10: 72px;
  --max-width: 1160px;
  --font-sans: "IBM Plex Sans", "Segoe UI", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth; overflow-x:hidden; overflow-y:scroll; background: var(--bg); min-height:100%}
body{background: var(--bg); min-height:100%}
body{
  margin:0;
  font-family: var(--font-sans);
  font-size: 17px;
  color: var(--text);
  background: var(--bg);
  line-height:1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  overflow-x:hidden;
  width:100%;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
main{min-height:60vh; width:100%; background: var(--bg)}
h1, h2, h3, h4{margin:0; letter-spacing:-.12px}
h1{font-weight:650; font-size: clamp(34px, 4.6vw, 52px); line-height:1.12}
h2, h3{font-weight:600}
h3{font-size: clamp(19px, 2.4vw, 26px); line-height:1.35}
h4{font-size: 16px; line-height:1.4}
p{margin:0 0 16px 0}
p:last-child{margin-bottom:0}

.muted{color: var(--muted)}
.page-title{font-size: clamp(34px, 5vw, 50px); line-height:1.12; margin-bottom: 12px}

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

.site-header{
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: rgba(247,246,242,.94);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.site-header.is-scrolled{
  box-shadow: var(--shadow-soft);
}
.site-header + main{padding-top: var(--header-offset)}

.header-container{
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 72px;
  gap: 20px;
}

.header-left{
  flex-shrink: 0;
}

.brand{
  display: inline-flex;
  align-items: center;
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  transition: opacity .2s ease;
}
.brand:hover{
  opacity: 0.8;
}
.brand-text{
  font-size: 17px;
  font-weight: 600;
  line-height: 1.2;
}
.brand-logo{
  height: 40px;
  width: auto;
  display: block;
}
.brand-text--sr{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}

@media (min-width: 900px){
  .brand-logo{height: 44px}
}

.header-nav{
  display: flex;
  align-items: center;
  gap: 32px;
}

/* Sticky page jump navigation */
.jump-nav{
  position: sticky;
  top: var(--header-offset);
  z-index: 950;
  background: rgba(247,246,242,.92);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 rgba(11,18,32,.06);
  transition: transform .22s ease, opacity .22s ease;
  will-change: transform;
}
.jump-nav.is-pinned{
  position: fixed;
  top: var(--header-offset);
  left: 0;
  right: 0;
  width: 100%;
}
.jump-nav-spacer{display:none}
.jump-nav--static{
  position: static;
  top: auto;
  z-index: auto;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.jump-nav.is-hidden{
  transform: translateY(-120%);
  opacity: 0;
  pointer-events: none;
}

.jump-nav-inner{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 24px;
  overflow-x:auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.jump-nav-inner::-webkit-scrollbar{display:none}

.jump-nav-label{
  flex: 0 0 auto;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--muted-2);
  margin-right: 6px;
  white-space: nowrap;
}

.jump-link{
  flex: 0 0 auto;
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--panel-2);
  color: var(--text);
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  transition: border .2s ease, background .2s ease, transform .2s ease;
}
.jump-link:hover{
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.jump-link:active{transform: translateY(0)}
.jump-link.is-active{
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}
.case-context-note{
  display:block;
  margin-top:16px;
  padding-left: 0;
  padding-right: 0;
}

@media (max-width: 760px){
  .jump-nav-inner{padding: 8px 16px}
  .jump-nav-label{display:none}
}

/* Anchor offset so headings don't hide under sticky header + jump-nav */
section[id], h2[id], h3[id]{
  scroll-margin-top: calc(var(--header-offset) + 72px);
}

.nav-link{
  font-size: 15px;
  font-weight: 500;
  color: var(--muted);
  text-decoration: none;
  padding: 8px 0;
  border-bottom: 2px solid transparent;
  transition: color .2s ease, border-color .2s ease;
}
.nav-link:hover{
  color: var(--text);
}
.nav-link[aria-current="page"]{
  color: var(--text);
  border-bottom-color: var(--accent);
}

.header-right{
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
}

.header-btn{
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  text-decoration: none;
  padding: 8px 16px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #ffffff;
  transition: all .2s ease;
}
.header-btn:hover{
  background: var(--panel-2);
  border-color: var(--border-strong);
}

.menu-toggle{
  display: none;
  width: 44px;
  height: 44px;
  padding: 0;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  position: relative;
  transition: all .2s ease;
}
.menu-toggle:hover{
  background: var(--panel-2);
  border-color: var(--border-strong);
}
.menu-toggle-bar{
  display: block;
  position: absolute;
  left: 50%;
  width: 20px;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transform: translateX(-50%);
  transition: all .25s ease;
}
.menu-toggle-bar:nth-child(1){
  top: 14px;
}
.menu-toggle-bar:nth-child(2){
  top: 21px;
}
.menu-toggle-bar:nth-child(3){
  top: 28px;
}
.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(1){
  top: 21px;
  transform: translateX(-50%) rotate(45deg);
}
.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(2){
  opacity: 0;
}
.menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(3){
  top: 21px;
  transform: translateX(-50%) rotate(-45deg);
}

.mobile-overlay{display:none}

.mobile-nav{
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  width: 100%;
  min-width: 0;
  max-width: none;
  background: var(--bg);
  border-top: 1px solid var(--border);
  box-shadow: var(--shadow-soft);
  z-index: 1200;
}
.mobile-nav.open{display:block}

.mobile-nav-header{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px;
  background: #ffffff;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 10;
}

.mobile-nav-title{
  font-size: 16px;
  font-weight: 600;
  color: var(--text);
}

.mobile-nav-close{
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  background: var(--panel-2);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  color: var(--text);
  transition: all .2s ease;
}
.mobile-nav-close:hover{
  background: var(--border);
}

.mobile-nav-content{
  padding: 24px 20px;
  display: block;
}

.mobile-nav-section{
  margin-bottom: 32px;
}
.mobile-nav-section:last-child{
  margin-bottom: 0;
}

.mobile-nav-label{
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted-2);
  margin-bottom: 12px;
  padding: 0 4px;
}

.mobile-nav-link{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  margin-bottom: 8px;
  background: #ffffff;
  border: 1px solid var(--border);
  border-radius: 10px;
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  text-decoration: none;
  transition: all .2s ease;
}
.mobile-nav-link:hover{
  background: var(--panel-2);
  border-color: var(--border-strong);
  transform: translateX(-4px);
}
.mobile-nav-link[aria-current="page"]{background: var(--accent); border-color: var(--accent); color: #ffffff}
.mobile-nav-link[aria-current="page"] .icon{
  color: #ffffff;
}
.mobile-nav-link .icon{
  flex-shrink: 0;
  color: var(--muted-2);
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding: 10px 16px;
  border-radius: 8px;
  border:1px solid var(--border);
  background: transparent;
  color: var(--text);
  font-weight:600;
  font-size: 14px;
  letter-spacing:.1px;
  box-shadow: 0 2px 6px rgba(15,23,42,.06);
  transition: transform .2s ease, border .2s ease, background .2s ease, box-shadow .2s ease, color .2s ease;
}
.btn.primary{
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}
.contact-submit.btn.primary{
  background: #ffffff;
  color: var(--accent);
  border-color: var(--accent);
}
.contact-submit.btn.primary .icon{
  color: var(--accent);
}
.contact-submit.btn.primary:hover{
  background: var(--accent);
  border-color: var(--accent);
  color: #ffffff;
}
.contact-submit.btn.primary:hover .icon{
  color: #ffffff;
}
.btn.outline{
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(31,47,73,.06);
}
.btn.ghost{
  border-color: transparent;
  background: rgba(17,24,39,.06);
  color: var(--text);
  box-shadow: none;
}
.btn.text{
  border-color: transparent;
  color: var(--accent);
  padding: 8px 6px;
  box-shadow: none;
}
.btn.small{padding: 7px 12px; font-size: 13px}
.btn:hover{transform: translateY(-1px); box-shadow: 0 6px 12px rgba(11,18,32,.12)}
.btn.primary:hover{background: var(--accent-deep); border-color: var(--accent-deep)}
.btn:active{transform: translateY(0); box-shadow: 0 4px 10px rgba(15,23,42,.1)}
.btn:focus-visible, a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline: 2px solid rgba(47,111,179,.35);
  outline-offset: 2px;
}

.icon-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  border:1px solid var(--border);
  color: var(--accent);
  background: #ffffff;
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}
.icon-link:hover{background: var(--panel-2); transform: translateY(-1px); box-shadow: 0 8px 18px rgba(26,34,51,.12)}

.hero{
  position: relative;
  padding: 64px 0 40px;
  overflow:hidden;
  width:100%;
  background: radial-gradient(circle at 10% 10%, var(--warm-soft), transparent 48%),
              linear-gradient(180deg, var(--bg) 0%, var(--panel-2) 100%);
}
.hero-inner{max-width: 70ch; position: relative; z-index:1}
.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 28px;
  align-items:center;
  width:100%;
  min-width:0;
}
.hero-panel{
  border: 1px solid var(--border);
  background: #ffffff;
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--shadow-soft);
}
.hero-panel .eyebrow{margin-bottom: 8px}
.stat-grid{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-top: 12px;
}
.stat-card{
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--panel-2);
}
.stat-value{font-size: clamp(20px, 3vw, 28px); font-weight:600; color: var(--accent)}
.stat-label{font-size: 14px; color: var(--muted)}
.metrics-band{
  margin: 16px 0 0;
  padding: 16px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}
.metrics{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.metric{
  padding: 8px 6px;
  border-radius: 10px;
  border: none;
  background: transparent;
}
.metric .stat-value{font-size: clamp(22px, 3.2vw, 32px); font-weight:600; color: var(--text)}
.metric .stat-label{font-size: 13px; color: var(--muted)}
.eyebrow{
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--muted-2);
  margin-bottom: 12px;
}
.hero h1{font-size: clamp(40px, 5vw, 56px); line-height:1.12; margin-bottom: 16px}
.lead{font-size: 19px; color: var(--muted); margin:0; max-width: 72ch}
.lead + p{margin-top:10px}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-top: 14px}
.hero-actions.spaced{margin-top: 16px}
.hero-actions.loose{margin-top: 16px}

.cred-strip{
  margin-top: 24px;
  padding: 12px 0 0;
  border-top: 1px solid var(--border);
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px 18px;
  color: var(--muted);
  font-size: 14px;
}
.cred-strip span{
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: none;
}

.section{padding: 72px 0; width:100%}
.section-compact{padding: 48px 0}
.section.alt{background: var(--panel-2)}
.section-head{margin-bottom: 22px}
.section-tight{margin-bottom: 12px}
.section-slim{margin-bottom: 8px}
.section-head h2{margin: 8px 0 6px; font-size: clamp(22px, 3vw, 32px); line-height:1.3}
.section-head p{color: var(--muted); max-width: 72ch; margin:0}

.grid-2{display:grid; grid-template-columns: repeat(2, 1fr); gap: 20px; min-width:0}
.grid-2 > *{min-width: 0; max-width: 100%}
.grid-3{display:grid; grid-template-columns: repeat(3, 1fr); gap: 20px; min-width:0}
.artifact-grid{display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px}
.artifact{
  border:1px solid var(--border);
  background: #ffffff;
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: var(--shadow-soft);
}
.artifact p{margin: 6px 0 0 0; color: var(--muted); font-size: 14px}
.deliverable-grid{display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px}
.deliverable{
  border:1px solid var(--border);
  background: #ffffff;
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: var(--shadow-soft);
}
.deliverable p{margin: 6px 0 0 0; color: var(--muted); font-size: 14px}
.split{display:grid; grid-template-columns: repeat(2, 1fr); gap: 24px; align-items:stretch; min-width:0}
.split > .card,
.split > .callout{
  height:100%;
  display:flex;
  flex-direction:column;
}
.split > .card .hero-actions,
.split > .callout .hero-actions{margin-top:auto}
.split > .callout.map-callout .hero-actions{margin-top:16px}
.evidence-grid{display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px}

.card{
  border:1px solid var(--border);
  background: #ffffff;
  border-radius: var(--radius-lg);
  padding: 22px;
  box-shadow: var(--shadow-soft);
  transition: transform .2s ease, box-shadow .2s ease, border .2s ease;
}
.card:hover{transform: translateY(-1px); box-shadow: var(--shadow)}
.card-title{position:relative; display:block}
.card-title .icon{
  position:absolute;
  left:-24px;
  top:4px;
  color: var(--accent);
}
.mini-card{padding: 16px}
.pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border-strong);
  background: var(--accent-soft);
  font-size: 12px;
  color: var(--muted);
}

.title-rule{
  height: 2px;
  width: 64px;
  border-radius: 999px;
  background: var(--gold);
  margin-top: 12px;
  opacity: 0.95;
}

.section-head h1::after,
.section-head h2::after{
  content: "";
  display: block;
  height: 2px;
  width: 48px;
  background: var(--gold);
  border-radius: 99px;
  margin-top: 12px;
}

.trust-bar{
  display:flex;
  flex-wrap:wrap;
  gap: 12px;
  align-items:center;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--muted-2);
  padding: 10px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.trust-bar span{
  position: relative;
  padding-right: 12px;
}
.trust-bar span::after{
  content: "•";
  position: absolute;
  right: 0;
  color: var(--gold);
}
.trust-bar span:last-child::after{
  content: "";
}

.service-directory{display:grid; gap: 14px}
.service-line{
  display:grid;
  grid-template-columns: 1.1fr 1.3fr auto;
  gap: 14px;
  align-items:start;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}
.service-line h3{margin:0; font-size: 18px}
.service-line p{margin:0; color: var(--muted)}
.service-line .service-link{color: var(--accent); font-weight:600}
.service-actions{display:flex; flex-direction:column; gap:6px; align-items:flex-start}
.service-line .bullets{margin: 6px 0 0 0; font-size: 14px}

.principles-grid{display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px}
.principle-card{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}
.principle-card p{margin: 6px 0 0 0; color: var(--muted); font-size: 14px}

.offer{
  border: 1px solid var(--border);
  padding: 16px;
  border-radius: var(--radius);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
  margin-bottom: 14px;
}
.offer:last-child{margin-bottom:0}

.tags{display:flex; flex-wrap:wrap; gap:8px; margin-top:8px}
.tag{
  font-family: var(--font-mono);
  font-size: 13px;
  padding: 4px 8px;
  border-radius: 999px;
  border:1px solid var(--border);
  background: var(--panel-2);
  color: var(--muted);
}

.bullets{
  margin: 6px 0 0 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 16px;
}
.bullets li{margin:3px 0}
.checklist{list-style:none; padding:0; margin:0; display:grid; gap:8px; color: var(--muted)}
.checklist li{display:flex; gap:10px; align-items:flex-start}
.checklist .icon{margin-top:2px; color: var(--accent-2)}
.timeline{display:grid; gap: 12px}
.timeline-item{
  display:grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  padding: 12px;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}
.timeline-marker{
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: var(--panel-2);
  border: 1px solid var(--border);
  display:grid;
  place-items:center;
  font-weight:600;
  color: var(--accent);
}
.callout{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px;
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}

.steps{display:grid; grid-template-columns: repeat(4, 1fr); gap: 16px}
.step{
  border: 1px solid var(--border);
  border-top: 3px solid var(--accent);
  padding: 16px;
  border-radius: var(--radius);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
}
.step-number{font-size: 12px; color: var(--muted-2); text-transform: uppercase; letter-spacing:.14em}
.step h3{margin: 6px 0 6px; font-size: 16px}

.case-block{
  padding: 22px;
  border: 1px solid var(--border);
  border-top: 3px solid transparent;
  border-radius: var(--radius-lg);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
  margin-bottom: 16px;
}
.case-block h3 a{color: inherit; text-decoration: none}
.case-block h3 a:hover{text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px}
.case-block:last-of-type{margin-bottom:0}
.theme-governance{
  --accent: #16263a;
  --accent-2: #2f6fb3;
  --accent-soft: rgba(47,111,179,.12);
}
.theme-treasury{
  --accent: #1d3144;
  --accent-2: #3d7fc2;
  --accent-soft: rgba(47,111,179,.12);
}
.theme-platform{
  --accent: #1c2f40;
  --accent-2: #4a86c7;
  --accent-soft: rgba(47,111,179,.12);
}
.theme-risk{
  --accent: #1b2a24;
  --accent-2: var(--gold);
}
.case-block.theme-governance{border-top-color: var(--accent)}
.case-block.theme-treasury{border-top-color: var(--accent)}
.case-block.theme-platform{border-top-color: var(--accent)}
.case-block.theme-risk{border-top-color: var(--accent)}
.case-meta{color: var(--muted); font-size: 14px}
.case-grid{display:grid; grid-template-columns: 1.2fr .8fr; gap: 20px; margin-top: 12px}
.case-grid h4{margin:0 0 4px; font-size:16px; color: var(--muted-2)}

.accordion-group{display:grid; gap: 12px}
.accordion{
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: #ffffff;
  box-shadow: var(--shadow-soft);
  overflow: hidden;
}
.accordion summary{
  list-style: none;
  padding: 14px 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-weight: 600;
  color: var(--text);
}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary::after{
  content: \"+\";
  font-size: 18px;
  color: var(--gold);
  margin-left: 12px;
}
.accordion[open] summary::after{content: \"–\"}
.accordion summary a{color: inherit}
.accordion-body{padding: 0 18px 18px}

.divider{height:1px; background: var(--border); margin: 12px 0}
.section-divider{height:1px; background: var(--border); margin: 20px 0}

.cta-panel{
  border: 1px solid rgba(255,255,255,.15);
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-deep) 100%);
  border-radius: var(--radius-lg);
  padding: 22px;
  color: #ffffff;
  box-shadow: var(--shadow);
}
.cta-panel.spaced{margin-top:20px}
.cta-panel .muted{color: rgba(255,255,255,.76)}
.cta-panel .eyebrow{color: rgba(255,255,255,.7)}
.cta-panel .btn.outline{
  border-color: rgba(255,255,255,.4);
  color: #ffffff;
  background: transparent;
}
.cta-panel .btn.outline:hover{
  border-color: rgba(255,255,255,.7);
  background: rgba(255,255,255,.08);
}
.cta-panel .btn.outline.gold-outline{
  border-color: #ffffff;
  color: #ffffff;
}
.cta-panel .btn.outline.gold-outline:hover{
  border-color: var(--gold);
  color: #ffffff;
  background: transparent;
}

.list{margin: 6px 0 0 0; padding-left: 18px; color: var(--muted)}
.list li{margin:4px 0}
ul + p{margin-top: 10px}

.form{display:grid; gap: 10px; margin-top: 14px; min-width: 0; max-width: 100%}
label{min-width: 0}
.input, textarea, select{
  width:100%;
  max-width: 100%;
  min-width: 0;
  padding: 12px 14px;
  border-radius: 8px;
  border:1px solid var(--border);
  background: #ffffff;
  color: var(--text);
  font: inherit;
  transition: border .2s ease, box-shadow .2s ease;
}
.input:focus, textarea:focus, select:focus{border-color: var(--accent-2); box-shadow: 0 0 0 3px rgba(47,111,179,.15)}
.input:invalid:focus, textarea:invalid:focus, select:invalid:focus{border-color: #b45309}
textarea{min-height:120px; resize:vertical}

.hp-field{
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.alert{
  display:flex;
  align-items:flex-start;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 8px;
  border:1px solid var(--border);
  background: var(--panel-2);
  color: var(--muted);
  margin-bottom: 16px;
}
.alert.success{border-color: rgba(31,59,109,.3); background: rgba(31,59,109,.08); color: var(--text)}
.alert.error{border-color: rgba(180,83,9,.35); background: rgba(180,83,9,.08); color: var(--text)}

.footer{
  padding: 28px 0 36px 0;
  /* Footer background: aligned to primary brand accent for consistent UI hierarchy. */
  background: var(--accent);
  border-top: 1px solid rgba(255,255,255,0.10);
  box-shadow: inset 0 2px 0 var(--gold);
  margin-top: 24px;
  color: #ffffff;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 12px;
}
.footer-brand{display:flex; flex-direction:column; gap:6px}
.footer-logo{
  height:auto;
  width:auto;
  max-height: 56px;
  max-width: 240px;
  display:block;
}
.footer-tagline{
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  gap: 2px 6px;
  color: rgba(255,255,255,0.72);
  font-size: 12px;
  line-height: 1.4;
}
.footer-tagline .sep{
  color: rgba(212,168,75,0.75);
  margin: 0;
}
.credential-badges{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 6px 0 10px 0;
}
.credential-badge{
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.10);
  color: #ffffff;
}
.footer small{display:block; margin-top:8px; color: rgba(255,255,255,0.72)}
.footer a{color: rgba(255,255,255,0.78)}
.footer a{text-decoration: none}
.footer a:hover{
  text-decoration: underline;
  text-underline-offset: 2px;
}
.footer a:hover{color: #ffffff}

@media (hover:hover) and (pointer:fine){
  main a[href$=".html"]:not(.btn):not(.nav-link):not(.mobile-nav-link):not(.header-btn){
    text-decoration: none;
    background-image: linear-gradient(var(--warm-accent), var(--warm-accent));
    background-size: 0 2px;
    background-position: 0 100%;
    background-repeat: no-repeat;
    transition: background-size 160ms ease;
  }
  main a[href$=".html"]:not(.btn):not(.nav-link):not(.mobile-nav-link):not(.header-btn):hover{
    background-size: 100% 2px;
  }
}

.icon{width:16px; height:16px; display:inline-block}

.no-scroll{overflow:hidden}

@media (max-width: 1020px){
  .header-nav{
    display: none;
  }
  .header-btn{
    display: none;
  }
  .menu-toggle{
    display: block;
  }
  .mobile-overlay{display:none}
}
@media (max-width: 900px){
  .grid-3{grid-template-columns: 1fr}
  .grid-2{grid-template-columns: 1fr}
  .artifact-grid{grid-template-columns: 1fr}
  .deliverable-grid{grid-template-columns: 1fr}
  .service-line{grid-template-columns: 1fr}
  .principles-grid{grid-template-columns: 1fr}
  .steps{grid-template-columns: 1fr 1fr}
  .case-grid{grid-template-columns: 1fr}
  .footer-grid{grid-template-columns: 1fr}
  .hero-grid{grid-template-columns: 1fr}
  .split{grid-template-columns: 1fr}
  .stat-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .metrics{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .evidence-grid{grid-template-columns: 1fr}
  .card-title{display:flex; align-items:flex-start; gap:10px}
  .card-title .icon{position:static; margin-top:2px}
}
@media (max-width: 760px){
  :root{--header-offset: 64px; --header-height: 64px;}
  .header-container{
    min-height: 64px;
    padding: 0 16px;
  }
  .site-header{
    background: rgba(246,244,241,.86);
  }
  .site-header + main{padding-top: var(--header-offset)}
  .brand-text{
    font-size: 15px;
  }
  .brand-logo{
    height: 42px;
  }
  .menu-toggle{
    width: 40px;
    height: 40px;
  }
  .menu-toggle-bar{
    width: 18px;
  }
  .menu-toggle-bar:nth-child(1){
    top: 12px;
  }
  .menu-toggle-bar:nth-child(2){
    top: 19px;
  }
  .menu-toggle-bar:nth-child(3){
    top: 26px;
  }
  .menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(1){
    top: 19px;
  }
  .menu-toggle[aria-expanded="true"] .menu-toggle-bar:nth-child(3){
    top: 19px;
  }
  .mobile-nav{width:100%}
  .hero{padding: 52px 0 32px}
  .section{padding: 52px 0}
  .section-compact{padding: 44px 0}
  .steps{grid-template-columns: 1fr}
  .cred-strip{gap: 8px 12px; padding-top: 10px; grid-template-columns: 1fr}
  .stat-grid{grid-template-columns: 1fr}
  .metrics{grid-template-columns: 1fr}
  .container{padding: 0 16px}
  h1, h2, h3, h4{word-wrap:break-word; overflow-wrap:break-word}
  .hero-actions{width:100%}
  .btn{max-width:100%; word-wrap:break-word}
}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto}
  .btn, .mobile-menu{transition:none}
}
