:root {
  --paper: #ffffff;
  --cream: #f7f3e8;
  --white: #ffffff;
  --black: #050706;
  --ink: #070b09;
  --muted: #5d6661;
  --line: #ddd6c4;
  --green: #05382e;
  --green-2: #0b4b3d;
  --green-3: #0f6451;
  --teal: #2d6e67;
  --rust: #a7662f;
  --gold: #efa758;
  --gold-soft: #f8d897;
  --shadow: 0 28px 80px rgba(5, 7, 6, .18);
  --radius: 6px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
* { box-sizing: border-box; }
html { background: var(--paper); color: var(--ink); font-family: var(--font); scroll-behavior: smooth; }
body { margin: 0; min-height: 100vh; overflow-x: hidden; }
body.nav-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; }
.site-header {
  position: sticky; top: 0; z-index: 20;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 18px clamp(18px, 4vw, 54px);
  background: rgba(5, 56, 46, .96); backdrop-filter: blur(18px);
  border-bottom: 2px solid var(--gold);
  box-shadow: 0 10px 36px rgba(5, 7, 6, .18);
}
.brand { display: flex; align-items: center; gap: 12px; min-width: 220px; }
.brand-mark { width: 42px; height: 42px; border-radius: var(--radius); border: 1px solid var(--gold); display: grid; place-items: center; background: var(--black); box-shadow: inset 0 0 0 1px rgba(255,255,255,.06); }
.brand-mark span { width: 20px; height: 20px; border: 2px solid #fffaf0; border-left-color: var(--gold); transform: rotate(45deg); }
.brand-copy { display: grid; gap: 1px; }
.brand-copy strong { font-size: 15px; line-height: 19px; color: #ffffff; }
.brand-copy em { font-size: 12px; line-height: 16px; color: var(--gold-soft); font-style: normal; }
.site-nav { display: flex; align-items: center; gap: clamp(10px, 1.15vw, 18px); font-size: 13px; font-weight: 650; color: #f7f3e8; }
.site-nav a { white-space: nowrap; }
.site-nav a:hover, .site-nav a.active { color: var(--gold); }
.nav-cta, .button {
  display: inline-flex; align-items: center; justify-content: center; min-height: 44px;
  padding: 0 18px; border-radius: var(--radius); border: 1px solid var(--gold);
  font-size: 14px; font-weight: 750; line-height: 1; text-decoration: none;
}
.nav-cta { background: var(--gold); color: var(--black); box-shadow: 0 12px 34px rgba(239, 167, 88, .22); }
.button.primary { background: var(--gold); color: var(--black); box-shadow: 0 16px 40px rgba(239, 167, 88, .24); }
.button.secondary { background: transparent; color: inherit; border-color: currentColor; }
.button.dark { border-color: #fffaf0; }
.button:hover { transform: translateY(-1px); }
.menu-button { display: none; min-height: 38px; border: 1px solid var(--gold); border-radius: var(--radius); background: var(--black); color: #fffaf0; padding: 0 12px; font-weight: 750; }
.hero {
  display: grid; grid-template-columns: minmax(0, .92fr) minmax(360px, 1.08fr); gap: clamp(28px, 5vw, 70px);
  padding: clamp(54px, 8vw, 104px) clamp(18px, 4vw, 54px) 40px;
  align-items: center;
  background:
    linear-gradient(90deg, rgba(5, 56, 46, .98) 0%, rgba(5, 56, 46, .94) 43%, rgba(5, 7, 6, .92) 100%);
  color: #fffaf0;
  border-bottom: 3px solid var(--gold);
}
.hero-compact { padding-top: clamp(44px, 6vw, 76px); }
.hero-copy h1 { max-width: 790px; margin: 0; font-size: clamp(40px, 5vw, 72px); line-height: 1; letter-spacing: 0; }
.hero-compact .hero-copy h1 { font-size: clamp(36px, 4.2vw, 60px); }
.hero-copy h1::after { content: ""; display: block; width: 86px; height: 4px; margin-top: 24px; background: var(--gold); }
.hero-copy p { max-width: 720px; margin: 24px 0 0; color: #eadfca; font-size: clamp(17px, 1.8vw, 21px); line-height: 1.55; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 30px; }
.hero-media { position: relative; border-radius: var(--radius); overflow: hidden; min-height: 440px; box-shadow: 0 34px 90px rgba(0,0,0,.38); background: #d7ddd1; border: 1px solid rgba(239, 167, 88, .74); }
.hero-media img { width: 100%; height: 100%; min-height: 440px; object-fit: cover; }
.map-note {
  position: absolute; left: 20px; bottom: 20px; max-width: 315px;
  padding: 16px; border-radius: var(--radius); background: rgba(5, 7, 6, .84);
  border: 1px solid var(--gold); box-shadow: 0 16px 44px rgba(5, 7, 6, .34);
}
.map-note strong, .map-note span { display: block; }
.map-note strong { color: #fffaf0; }
.map-note span { margin-top: 6px; color: #eadfca; font-size: 13px; line-height: 1.45; }
.section-label { margin: 0 0 12px; color: var(--gold); font-size: 12px; line-height: 16px; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; }
.process-band, .service-grid, .market-grid, .project-grid, .principles {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 1px;
  margin: 34px clamp(18px, 4vw, 54px); background: var(--line); border: 1px solid var(--line);
}
.process-band article, .service-grid article, .market-grid article, .project-grid article, .principles article {
  background: var(--white); padding: clamp(22px, 3vw, 34px); min-height: 220px;
  border-top: 4px solid var(--gold);
}
.process-band span, .project-grid span { color: var(--gold); font-weight: 850; font-size: 12px; }
h2, h3 { margin: 0; letter-spacing: 0; }
h2 { font-size: clamp(26px, 3vw, 42px); line-height: 1.05; }
h3 { font-size: 20px; line-height: 1.2; }
article h2, article h3 { margin-top: 14px; }
article p, .stack-copy p, .longform p, li { color: var(--muted); line-height: 1.65; font-size: 16px; }
.split-section, .proof-section, .case-study, .service-layout, .contact-layout {
  display: grid; grid-template-columns: minmax(260px, .72fr) minmax(0, 1fr); gap: clamp(28px, 6vw, 84px);
  padding: clamp(50px, 7vw, 92px) clamp(18px, 4vw, 54px);
}
.split-section h2, .proof-section h2 { max-width: 660px; }
.stack-copy { max-width: 760px; }
.service-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.service-grid article { min-height: 260px; }
.service-grid h2 a:hover, .article-list h2:hover, .project-grid h2 a:hover { color: var(--rust); }
.text-link { display: inline-flex; margin-top: 14px; color: var(--green-2); font-weight: 800; border-bottom: 2px solid var(--gold); padding-bottom: 2px; }
.market-section { padding: clamp(52px, 7vw, 90px) clamp(18px, 4vw, 54px); background: var(--black); color: #fffaf0; border-top: 3px solid var(--gold); border-bottom: 3px solid var(--gold); }
.section-heading { max-width: 760px; margin-bottom: 32px; }
.market-grid { margin: 0; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.market-grid article { min-height: 190px; }
.market-section h2, .market-section h3 { color: #fffaf0; }
.market-section p { color: #eadfca; }
.market-section .market-grid article { background: var(--green); border-top-color: var(--gold); }
.proof-section { background: var(--green); color: #fffaf0; border-top: 3px solid var(--gold); border-bottom: 3px solid var(--gold); }
.proof-section .section-label { color: var(--gold); }
.proof-section h2 { color: #fffaf0; }
.proof-list { display: grid; gap: 10px; align-self: start; }
.proof-list span { display: block; padding: 18px; border: 1px solid rgba(239, 167, 88, .56); border-radius: var(--radius); background: rgba(0, 0, 0, .20); color: #fffaf0; font-weight: 750; }
.cta-band {
  display: flex; align-items: center; justify-content: space-between; gap: 28px;
  margin: clamp(40px, 7vw, 86px) clamp(18px, 4vw, 54px);
  padding: clamp(28px, 4vw, 44px); border-radius: var(--radius); background: var(--black); color: #fffaf0;
  border: 1px solid var(--gold); box-shadow: 0 28px 80px rgba(5, 7, 6, .22);
}
.cta-band h2 { max-width: 850px; }
.cta-band p { max-width: 720px; color: #dce7df; line-height: 1.55; }
.service-layout { align-items: start; }
.service-aside { position: sticky; top: 98px; padding: 28px; background: var(--green); color: #fffaf0; border-radius: var(--radius); border: 1px solid var(--gold); box-shadow: var(--shadow); }
.service-aside p { color: #dce7df; line-height: 1.6; }
.service-aside .button { margin-top: 18px; border-color: #fffaf0; }
.check-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.check-grid div { padding: 22px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--white); box-shadow: 0 12px 32px rgba(5, 7, 6, .05); }
.check-grid span { display: block; width: 42px; height: 3px; background: var(--gold); margin-bottom: 18px; }
.check-grid strong { display: block; font-size: 18px; line-height: 1.25; }
.outcome-section {
  padding: clamp(56px, 8vw, 104px) clamp(18px, 4vw, 54px);
  background: var(--paper);
  border-top: 1px solid var(--line);
}
.outcome-section .section-heading { max-width: 900px; margin-bottom: clamp(30px, 4vw, 48px); }
.outcome-section .section-heading p:not(.section-label) { max-width: 790px; color: var(--muted); line-height: 1.65; }
.outcome-block {
  display: grid;
  grid-template-columns: minmax(280px, .92fr) minmax(280px, 1fr);
  gap: clamp(26px, 5vw, 64px);
  align-items: start;
}
.outcome-block h3 {
  max-width: 620px;
  margin-bottom: 18px;
  font-size: clamp(22px, 2.3vw, 32px);
  line-height: 1.12;
}
.bottleneck-grid, .outcome-grid { display: grid; gap: 14px; }
.bottleneck-grid article, .outcome-grid article {
  background: #fffdf7;
  border: 1px solid var(--line);
  border-left: 4px solid var(--gold);
  border-radius: var(--radius);
  padding: clamp(20px, 3vw, 28px);
  box-shadow: 0 14px 40px rgba(5, 7, 6, .06);
}
.bottleneck-grid span { display: block; width: 36px; height: 3px; margin-bottom: 16px; background: var(--green); }
.bottleneck-grid h4, .outcome-grid strong, .perspective-grid h4 {
  display: block;
  margin: 0 0 10px;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.25;
}
.bottleneck-grid p, .outcome-grid p, .perspective-grid p, .seo-trail p { margin: 0; line-height: 1.62; }
.perspective-panel {
  display: grid;
  grid-template-columns: minmax(260px, .45fr) minmax(0, 1fr);
  gap: clamp(24px, 4vw, 48px);
  margin-top: clamp(34px, 6vw, 64px);
  padding: clamp(26px, 4vw, 44px);
  border: 1px solid var(--gold);
  border-radius: var(--radius);
  background: var(--green);
  color: #fffaf0;
  box-shadow: var(--shadow);
}
.perspective-panel .section-label { color: var(--gold); }
.perspective-panel h3 { color: #fffaf0; font-size: clamp(24px, 2.4vw, 34px); }
.perspective-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  background: rgba(239, 167, 88, .46);
  border: 1px solid rgba(239, 167, 88, .46);
}
.perspective-grid article { padding: 22px; background: rgba(0, 0, 0, .18); border-top: 3px solid var(--gold); }
.perspective-grid h4 { color: #fffaf0; }
.perspective-grid p { color: #eadfca; }
.seo-trail {
  display: grid;
  grid-template-columns: minmax(260px, .45fr) minmax(0, 1fr);
  gap: clamp(24px, 5vw, 60px);
  padding: clamp(42px, 6vw, 72px) clamp(18px, 4vw, 54px);
  background: var(--black);
  color: #fffaf0;
  border-top: 3px solid var(--gold);
  border-bottom: 3px solid var(--gold);
}
.seo-trail h2 { color: #fffaf0; }
.seo-trail p { color: #eadfca; }
.seo-link-list {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  background: rgba(239, 167, 88, .42);
  border: 1px solid rgba(239, 167, 88, .42);
}
.seo-link-list article { min-height: 150px; padding: 20px; background: rgba(19, 49, 39, .78); }
.seo-link-list a {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--gold);
  font-weight: 850;
  border-bottom: 2px solid rgba(239, 167, 88, .58);
}
.contact-layout { align-items: start; }
.intake-form, .contact-card { background: var(--white); border: 1px solid var(--line); border-top: 4px solid var(--gold); border-radius: var(--radius); padding: clamp(22px, 3vw, 34px); box-shadow: 0 18px 60px rgba(5, 7, 6, .10); }
.form-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
label { display: grid; gap: 8px; margin-bottom: 16px; color: var(--ink); font-weight: 750; }
input, select, textarea { width: 100%; border: 1px solid var(--line); border-radius: var(--radius); background: #fbfbf7; color: var(--ink); padding: 13px 14px; line-height: 1.4; }
textarea { resize: vertical; }
.form-status { margin: 12px 0 0; color: var(--green-2); font-weight: 750; }
.contact-card ul, .longform ul { padding-left: 20px; }
.article-list { display: grid; gap: 1px; margin: 40px clamp(18px, 4vw, 54px); border: 1px solid var(--line); background: var(--line); }
.article-list article { background: var(--white); padding: clamp(24px, 4vw, 40px); border-left: 4px solid transparent; }
.article-list article:hover { border-left-color: var(--gold); }
.article-list-heading { background: var(--green); color: #fffaf0; padding: clamp(26px, 4vw, 44px); border-bottom: 2px solid var(--gold); }
.article-list-heading h2 { color: #fffaf0; }
.article-list-heading p:not(.section-label) { max-width: 760px; color: #eadfca; line-height: 1.6; }
.blog-home-intro {
  display: grid; grid-template-columns: minmax(260px, .52fr) minmax(0, 1fr); gap: clamp(28px, 6vw, 74px);
  padding: clamp(52px, 7vw, 90px) clamp(18px, 4vw, 54px);
  background: var(--white);
}
.education-paths, .featured-grid, .related-grid {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1px;
  background: var(--line); border: 1px solid var(--line);
}
.education-paths article, .featured-grid article, .related-grid article {
  background: var(--white); padding: clamp(22px, 3vw, 32px); border-top: 4px solid var(--gold);
}
.education-paths span, .related-grid span { display: inline-block; color: var(--green); font-size: 12px; font-weight: 850; text-transform: uppercase; letter-spacing: .06em; }
.featured-articles {
  padding: clamp(52px, 7vw, 90px) clamp(18px, 4vw, 54px);
  background: var(--black); color: #fffaf0; border-top: 3px solid var(--gold); border-bottom: 3px solid var(--gold);
}
.featured-articles h2, .featured-articles h3 { color: #fffaf0; }
.featured-articles p { color: #eadfca; }
.featured-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); border-color: rgba(239,167,88,.45); background: rgba(239,167,88,.45); }
.featured-grid article { background: var(--green); border-top-color: var(--gold); }
.featured-grid .text-link { color: #fffaf0; }
.related-blog-section {
  margin: clamp(46px, 7vw, 86px) clamp(18px, 4vw, 54px);
  padding: clamp(28px, 4vw, 44px);
  border-radius: var(--radius);
  background: var(--green);
  color: #fffaf0;
  border: 1px solid var(--gold);
  box-shadow: var(--shadow);
}
.related-blog-section .section-heading { margin-bottom: 26px; }
.related-blog-section h2 { color: #fffaf0; }
.related-blog-section .section-heading p:not(.section-label) { max-width: 780px; color: #eadfca; line-height: 1.6; }
.related-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); border-color: rgba(239,167,88,.42); background: rgba(239,167,88,.42); }
.related-grid article { background: #fffdf7; color: var(--ink); }
.related-grid p { color: var(--muted); }
.related-action { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 22px; }
.related-action .button.secondary { color: #fffaf0; border-color: #fffaf0; }
.longform { max-width: 860px; margin: 0 auto; padding: clamp(44px, 7vw, 86px) 18px; }
.longform h2 { margin-top: 34px; }
.post-meta { display: flex; flex-wrap: wrap; gap: 10px 18px; margin-bottom: 30px; padding-bottom: 18px; border-bottom: 1px solid var(--line); color: var(--muted); font-size: 13px; font-weight: 750; }
.post-meta span { color: var(--green); text-transform: uppercase; letter-spacing: .06em; }
.wp-content h2, .wp-content h3, .wp-content h4 { margin-top: 34px; color: var(--ink); }
.wp-content h2 { font-size: clamp(28px, 3vw, 42px); }
.wp-content h3 { font-size: clamp(22px, 2vw, 30px); }
.wp-content p { color: var(--muted); font-size: 17px; line-height: 1.72; }
.wp-content a { color: var(--green); font-weight: 800; text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: 3px; }
.wp-content figure { margin: 34px 0; }
.wp-content img { width: auto; max-width: 100%; height: auto; border-radius: var(--radius); box-shadow: 0 18px 54px rgba(23, 33, 29, .10); }
.wp-content figcaption { margin-top: 10px; color: var(--muted); font-size: 13px; }
.wp-content iframe { width: 100%; max-width: 100%; aspect-ratio: 16 / 9; height: auto; border: 0; border-radius: var(--radius); box-shadow: 0 18px 54px rgba(23, 33, 29, .10); }
.wp-content blockquote { margin: 30px 0; padding: 22px 26px; border-left: 4px solid var(--gold); background: var(--cream); }
.wp-content blockquote p { margin: 0; color: var(--ink); font-weight: 750; }
.blog-expansion { margin-top: 42px; padding-top: 8px; }
.blog-backlink-panel {
  margin: 44px 0 12px;
  padding: clamp(22px, 4vw, 34px);
  border-radius: var(--radius);
  border: 1px solid var(--gold);
  background: var(--green);
  color: #fffaf0;
  box-shadow: var(--shadow);
}
.blog-backlink-panel h2 { color: #fffaf0; }
.blog-backlink-panel p { color: #eadfca; }
.blog-backlink-panel ul { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1px; margin: 22px 0 0; padding: 0; list-style: none; background: rgba(239, 167, 88, .44); border: 1px solid rgba(239, 167, 88, .44); }
.blog-backlink-panel li { display: grid; gap: 8px; padding: 18px; background: rgba(5, 7, 6, .24); color: #eadfca; }
.blog-backlink-panel a { color: var(--gold); font-weight: 850; text-decoration: none; border-bottom: 2px solid rgba(239, 167, 88, .58); width: fit-content; }
.blog-backlink-panel span { color: #eadfca; line-height: 1.55; }
.wp-content .wp-block-gallery { display: grid; gap: 16px; }
.wp-content .wp-block-media-text { display: grid; grid-template-columns: minmax(180px, .45fr) minmax(0, 1fr); gap: 24px; align-items: center; }
.project-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.case-table { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); }
.case-table div { display: grid; grid-template-columns: 180px 1fr; gap: 18px; padding: 18px; background: var(--white); }
.site-footer { display: flex; justify-content: space-between; gap: 28px; padding: 34px clamp(18px, 4vw, 54px); border-top: 3px solid var(--gold); background: var(--green); color: #fffaf0; }
.site-footer p { margin: 6px 0 0; color: var(--gold-soft); }
.site-footer nav { display: flex; flex-wrap: wrap; gap: 14px 22px; justify-content: flex-end; color: #eadfca; font-size: 14px; font-weight: 650; }
@media (max-width: 1450px) {
  .menu-button { display: inline-flex; align-items: center; }
  .site-nav { position: fixed; inset: 78px 14px auto 14px; display: none; flex-direction: column; align-items: stretch; padding: 18px; background: var(--green); border: 1px solid var(--gold); border-radius: var(--radius); box-shadow: var(--shadow); }
  body.nav-open .site-nav { display: flex; }
  .hero, .split-section, .proof-section, .case-study, .service-layout, .contact-layout, .outcome-block, .perspective-panel, .seo-trail { grid-template-columns: 1fr; }
  .hero-media, .hero-media img { min-height: 330px; }
  .process-band, .service-grid, .market-grid, .project-grid, .principles { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .blog-home-intro { grid-template-columns: 1fr; }
  .featured-grid, .related-grid { grid-template-columns: 1fr; }
  .perspective-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .seo-link-list { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .service-aside { position: static; }
}
@media (max-width: 680px) {
  .site-header { padding: 14px 16px; }
  .brand { min-width: 0; }
  .brand-copy em { display: none; }
  .hero { padding: 42px 16px 24px; }
  .hero-copy h1 { font-size: 42px; }
  .process-band, .service-grid, .market-grid, .project-grid, .principles, .check-grid, .form-row, .education-paths, .perspective-grid, .seo-link-list, .blog-backlink-panel ul { grid-template-columns: 1fr; }
  .process-band, .service-grid, .project-grid, .principles { margin: 24px 16px; }
  .market-section, .split-section, .proof-section, .case-study, .service-layout, .contact-layout, .blog-home-intro, .featured-articles, .outcome-section, .seo-trail { padding-left: 16px; padding-right: 16px; }
  .cta-band { margin-left: 16px; margin-right: 16px; flex-direction: column; align-items: flex-start; }
  .related-blog-section { margin-left: 16px; margin-right: 16px; }
  .case-table div { grid-template-columns: 1fr; }
  .wp-content .wp-block-media-text { grid-template-columns: 1fr; }
  .site-footer { flex-direction: column; }
  .site-footer nav { justify-content: flex-start; }
}