/* Yeti.Security — site styles (paired with tokens.css for brand variables) */

body { background: var(--ink-1); color: var(--snow-1); margin: 0; font-family: var(--font-sans);}
a { color: inherit; text-decoration: none;}
img { max-width: 100%; height: auto;}
main:focus { outline: none;}

.skip-link {
  position: absolute; left: 16px; top: 12px; z-index: 100;
  transform: translateY(-150%);
  background: var(--yeti-green); color: var(--ink-0);
  padding: 10px 14px; border-radius: 4px;
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.08em; text-transform: uppercase;
}
.skip-link:focus { transform: translateY(0);}

/* ===== NAV ===== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(11,13,18,0.7);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--ink-4);
}
.nav .inner {
  max-width: 1280px; margin: 0 auto;
  padding: 18px 32px;
  display: flex; align-items: center; justify-content: space-between;
}
.nav .lockup { display: flex; align-items: center; gap: 12px;}
.nav .lockup img { width: 28px; height: 28px; object-fit: contain;}
.nav .lockup span { font-family: var(--font-display); font-weight: 700; font-size: 17px; letter-spacing: -0.02em; color: var(--snow-0);}
.nav .lockup em { font-style: normal; color: var(--yeti-green);}
.nav ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 28px; font-family: var(--font-mono); font-size: 12px; color: var(--snow-2); letter-spacing: 0.08em; text-transform: uppercase;}
.nav ul a:hover,
.nav ul a[aria-current="page"] { color: var(--yeti-green);}
.nav .cta {
  font-family: var(--font-mono); font-size: 12px;
  color: var(--ink-0); background: var(--yeti-green);
  padding: 10px 16px; border-radius: 4px;
  letter-spacing: 0.08em; text-transform: uppercase; font-weight: 500;
}
.nav .cta:hover { background: var(--yeti-green-bright);}

/* ===== HERO ===== */
.hero {
  position: relative; overflow: hidden;
  padding: 120px 32px;
  border-bottom: 1px solid var(--ink-4);
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(900px circle at 78% 28%, rgba(32,194,14,.14), transparent 60%),
    radial-gradient(600px circle at 8% 92%, rgba(32,194,14,.05), transparent 60%);
}
.hero.with-ridges::after {
  content: ""; position: absolute; inset: 0; opacity: .25; pointer-events: none;
  background-image:
    radial-gradient(ellipse 1000px 280px at 50% 100%, transparent 30%, rgba(32,194,14,.45) 30.3%, transparent 30.6%),
    radial-gradient(ellipse 840px 240px at 50% 100%, transparent 30%, rgba(32,194,14,.35) 30.3%, transparent 30.6%),
    radial-gradient(ellipse 680px 200px at 50% 100%, transparent 30%, rgba(32,194,14,.28) 30.3%, transparent 30.6%),
    radial-gradient(ellipse 520px 160px at 50% 100%, transparent 30%, rgba(32,194,14,.20) 30.3%, transparent 30.6%),
    radial-gradient(ellipse 360px 120px at 50% 100%, transparent 30%, rgba(32,194,14,.15) 30.3%, transparent 30.6%);
}
.hero .inner { max-width: 1280px; margin: 0 auto; position: relative; z-index: 1;}
.hero .eb, .eyebrow { font-family: var(--font-mono); font-size: 13px; color: var(--yeti-green); letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 24px;}
.hero h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(56px, 9vw, 132px);
  letter-spacing: -0.04em; line-height: 0.92;
  margin: 0; color: var(--snow-0); max-width: 1100px;
}
.hero h1 em { font-style: normal; color: var(--yeti-green);}
.hero p.lede {
  font-size: clamp(18px, 2vw, 22px);
  color: var(--snow-2); line-height: 1.5;
  max-width: 720px; margin: 40px 0 0;
}
.hero .ctas { margin-top: 48px; display: flex; gap: 14px; flex-wrap: wrap;}
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 13px;
  padding: 14px 22px; border-radius: 6px;
  letter-spacing: 0.1em; text-transform: uppercase; font-weight: 500;
  transition: transform .15s, background .15s, border-color .15s;
  cursor: pointer; border: none;
}
.btn:hover { transform: translateY(-2px);}
.btn.primary { background: var(--yeti-green); color: var(--ink-0);}
.btn.primary:hover { background: var(--yeti-green-bright);}
.btn.ghost { border: 1px solid var(--ink-5); color: var(--snow-1); background: transparent;}
.btn.ghost:hover { border-color: var(--yeti-green); color: var(--yeti-green);}

.hero .footstats {
  margin-top: 96px; padding-top: 24px; border-top: 1px solid var(--ink-4);
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
  font-family: var(--font-mono); font-size: 12px;
  color: var(--snow-3); letter-spacing: 0.1em; text-transform: uppercase;
}
.hero .footstats .stat .v {
  font-family: var(--font-display); color: var(--snow-0);
  font-size: 32px; font-weight: 700; letter-spacing: -0.02em;
  margin-bottom: 4px; text-transform: none;
}
.hero .footstats .stat .v em { font-style: normal; color: var(--yeti-green);}

/* ===== PAGE HEADER (non-home) ===== */
.page-header {
  padding: 96px 32px 56px;
  border-bottom: 1px solid var(--ink-4);
  position: relative; overflow: hidden;
}
.page-header::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(800px circle at 78% 28%, rgba(32,194,14,.08), transparent 60%);
}
.page-header .inner { max-width: 1280px; margin: 0 auto; position: relative; z-index: 1;}
.page-header h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(44px, 6vw, 80px); letter-spacing: -0.035em; line-height: 1; margin: 0 0 18px;
  color: var(--snow-0); max-width: 1000px;
}
.page-header h1 em { font-style: normal; color: var(--yeti-green);}
.page-header p.lede { font-size: 18px; color: var(--snow-2); line-height: 1.5; max-width: 720px; margin: 0;}
.page-header .crumbs { font-family: var(--font-mono); font-size: 11px; color: var(--snow-3); letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 16px;}
.page-header .crumbs a:hover { color: var(--yeti-green);}

/* ===== 404 ===== */
.not-found {
  min-height: 64vh;
  display: flex; align-items: center;
  padding: 120px 32px;
  border-bottom: 1px solid var(--ink-4);
  position: relative; overflow: hidden;
}
.not-found::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(760px circle at 75% 25%, rgba(32,194,14,.12), transparent 60%),
    radial-gradient(ellipse 900px 240px at 50% 115%, transparent 30%, rgba(32,194,14,.24) 30.3%, transparent 30.6%);
}
.not-found .inner { max-width: 1280px; margin: 0 auto; width: 100%; position: relative; z-index: 1;}
.not-found h1 {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(56px, 9vw, 112px);
  letter-spacing: -0.04em; line-height: .95;
  margin: 0 0 24px; color: var(--snow-0);
}
.not-found .lede { font-size: 20px; color: var(--snow-2); line-height: 1.5; max-width: 560px; margin: 0;}
.not-found .ctas { margin-top: 40px; display: flex; gap: 14px; flex-wrap: wrap;}

/* ===== SECTIONS ===== */
section.s { padding: 120px 32px; border-bottom: 1px solid var(--ink-4);}
section.s:last-of-type { border-bottom: none;}
section.s .inner { max-width: 1280px; margin: 0 auto;}
.s h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(40px, 5vw, 64px); letter-spacing: -0.03em; line-height: 1; margin: 0 0 18px; color: var(--snow-0);}
.s h2 em { font-style: normal; color: var(--yeti-green);}
.s .lede { font-size: 18px; color: var(--snow-2); line-height: 1.5; max-width: 720px; margin: 0 0 56px;}

/* ===== Services grid ===== */
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;}
.svc {
  background: var(--ink-2); border: 1px solid var(--ink-4);
  border-radius: 12px; padding: 36px;
  display: flex; flex-direction: column; gap: 16px;
  transition: border-color .2s, transform .2s;
}
.svc:hover { border-color: var(--yeti-green); transform: translateY(-2px);}
.svc.featured { border-color: var(--yeti-green); background: linear-gradient(180deg, var(--ink-2), rgba(32,194,14,.04));}
.svc .num { font-family: var(--font-mono); font-size: 12px; color: var(--yeti-green); letter-spacing: 0.1em;}
.svc h3 { font-family: var(--font-display); font-size: 28px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.1; margin: 0;}
.svc p { color: var(--snow-2); font-size: 15px; line-height: 1.55; margin: 0; flex: 1;}
.svc .price { font-family: var(--font-mono); font-size: 11px; color: var(--snow-3); letter-spacing: 0.1em; text-transform: uppercase; border-top: 1px solid var(--ink-4); padding-top: 14px;}
.svc .price b { color: var(--snow-0); font-weight: 500;}

/* ===== Process ===== */
.process { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;}
.step { background: var(--ink-2); border: 1px solid var(--ink-4); border-radius: 12px; padding: 28px;}
.step .wk { font-family: var(--font-mono); font-size: 11px; color: var(--yeti-green); letter-spacing: 0.1em; text-transform: uppercase;}
.step h4 { font-family: var(--font-display); font-size: 22px; font-weight: 600; letter-spacing: -0.015em; margin: 10px 0 12px; color: var(--snow-0);}
.step p { color: var(--snow-2); font-size: 14px; line-height: 1.55; margin: 0;}

/* ===== Quote ===== */
.quote {
  background: var(--ink-2); border-left: 2px solid var(--yeti-green);
  padding: 56px; border-radius: 0 12px 12px 0;
}
.quote .mark { font-family: var(--font-display); font-size: 96px; color: var(--yeti-green); line-height: 0.4; margin-bottom: 12px;}
.quote p { font-family: var(--font-display); font-size: 32px; font-weight: 500; letter-spacing: -0.015em; line-height: 1.25; color: var(--snow-0); margin: 0 0 32px; max-width: 920px;}
.quote .byline { font-family: var(--font-mono); font-size: 12px; color: var(--snow-3); letter-spacing: 0.1em; text-transform: uppercase;}
.quote .byline b { color: var(--snow-0); font-family: var(--font-display); font-size: 16px; font-weight: 600; letter-spacing: -0.01em; text-transform: none; display: block; margin-bottom: 2px;}

/* ===== Posts ===== */
.posts { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;}
.post {
  background: var(--ink-2); border: 1px solid var(--ink-4); border-radius: 12px;
  overflow: hidden; transition: border-color .2s, transform .2s;
  display: flex; flex-direction: column;
}
.post:hover { border-color: var(--yeti-green); transform: translateY(-2px);}
.post .img {
  aspect-ratio: 16/9; position: relative; overflow: hidden;
  background: linear-gradient(135deg, var(--ink-3), var(--ink-1));
  display: flex; align-items: center; justify-content: center;
}
.post .img::before {
  content: ""; position: absolute; inset: 0; opacity: .4;
  background-image:
    radial-gradient(ellipse 400px 100px at 50% 130%, transparent 32%, rgba(32,194,14,.4) 32.4%, transparent 32.8%),
    radial-gradient(ellipse 300px 80px at 50% 130%, transparent 32%, rgba(32,194,14,.3) 32.4%, transparent 32.8%);
}
.post .img .marker { font-family: var(--font-mono); font-size: 14px; color: var(--yeti-green); letter-spacing: 0.18em; text-transform: uppercase; position: relative; z-index: 1;}
.post .img.threat-brief::before { background-image:
  radial-gradient(ellipse 400px 100px at 50% 130%, transparent 32%, rgba(239,68,68,.4) 32.4%, transparent 32.8%),
  radial-gradient(ellipse 300px 80px at 50% 130%, transparent 32%, rgba(239,68,68,.3) 32.4%, transparent 32.8%);}
.post .img.threat-brief .marker { color: var(--sev-critical);}
.post .body { padding: 24px; flex: 1; display: flex; flex-direction: column;}
.post .date { font-family: var(--font-mono); font-size: 10px; color: var(--snow-3); letter-spacing: 0.1em; margin-bottom: 8px;}
.post h4 { font-family: var(--font-display); font-size: 20px; font-weight: 600; letter-spacing: -0.015em; line-height: 1.2; margin: 0 0 12px; color: var(--snow-0);}
.post p { font-size: 14px; color: var(--snow-2); line-height: 1.5; margin: 0 0 16px; flex: 1;}
.post .read { font-family: var(--font-mono); font-size: 11px; color: var(--yeti-green); letter-spacing: 0.1em; text-transform: uppercase;}

/* ===== CTA banner ===== */
.cta-banner {
  background: linear-gradient(180deg, var(--ink-2), rgba(32,194,14,.04));
  border: 1px solid var(--yeti-green); border-radius: 16px;
  padding: 80px 56px;
  display: flex; justify-content: space-between; align-items: center; gap: 48px;
  position: relative; overflow: hidden;
}
.cta-banner::before {
  content: ""; position: absolute; inset: 0; opacity: .3;
  background-image: radial-gradient(ellipse 700px 200px at 50% 130%, transparent 32%, rgba(32,194,14,.4) 32.4%, transparent 32.8%);
}
.cta-banner .copy { position: relative; z-index: 1;}
.cta-banner h2 { font-family: var(--font-display); font-size: 56px; font-weight: 700; letter-spacing: -0.03em; line-height: 1; margin: 0 0 12px; color: var(--snow-0);}
.cta-banner h2 em { font-style: normal; color: var(--yeti-green);}
.cta-banner p { font-size: 17px; color: var(--snow-2); margin: 0; max-width: 540px; line-height: 1.5;}
.cta-banner .btn { position: relative; z-index: 1; background: var(--yeti-green); color: var(--ink-0); white-space: nowrap; font-size: 14px; padding: 18px 28px;}

/* ===== Article / single page ===== */
article.prose {
  max-width: 760px; margin: 0 auto;
  padding: 64px 32px 120px;
  font-size: 17px; line-height: 1.65; color: var(--snow-1);
}
article.prose h2 { font-family: var(--font-display); font-size: 32px; font-weight: 700; letter-spacing: -0.02em; margin: 56px 0 16px; color: var(--snow-0);}
article.prose h3 { font-family: var(--font-display); font-size: 22px; font-weight: 600; letter-spacing: -0.015em; margin: 32px 0 12px; color: var(--snow-0);}
article.prose p { margin: 0 0 18px;}
article.prose a { color: var(--yeti-green); border-bottom: 1px solid rgba(32,194,14,.4);}
article.prose a:hover { border-bottom-color: var(--yeti-green);}
article.prose ul, article.prose ol { padding-left: 22px; margin: 0 0 18px;}
article.prose ul li::marker { color: var(--yeti-green);}
article.prose ol li::marker { color: var(--yeti-green); font-family: var(--font-mono);}
article.prose li { margin-bottom: 8px;}
article.prose strong { color: var(--snow-0); font-weight: 600;}
article.prose em { color: var(--yeti-green); font-style: normal; font-weight: 500;}
article.prose blockquote {
  border-left: 2px solid var(--yeti-green); padding: 4px 0 4px 24px;
  margin: 24px 0; color: var(--snow-1); font-style: italic;
}
article.prose hr { border: 0; border-top: 1px solid var(--ink-4); margin: 56px 0;}
article.prose pre, article.prose code {
  font-family: var(--font-mono); font-size: 14px;
}
article.prose code {
  background: var(--ink-2); padding: 2px 6px; border-radius: 3px;
  color: var(--yeti-green); font-size: 0.9em;
}
article.prose pre {
  background: #06070A; border: 1px solid var(--ink-4); border-left: 2px solid var(--yeti-green);
  border-radius: 4px; padding: 18px 20px; overflow-x: auto;
  margin: 24px 0; line-height: 1.6;
}
article.prose pre code { background: none; padding: 0; color: var(--snow-1);}
article.prose table {
  width: 100%; border-collapse: collapse; margin: 24px 0;
  font-size: 15px;
}
article.prose th, article.prose td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--ink-4); vertical-align: top;}
article.prose th { font-family: var(--font-mono); font-size: 11px; color: var(--snow-3); letter-spacing: 0.1em; text-transform: uppercase; font-weight: 500; border-bottom: 1px solid var(--ink-5);}
article.prose img { border-radius: 8px; border: 1px solid var(--ink-4); margin: 24px 0;}

article.prose .meta {
  display: flex; gap: 16px; flex-wrap: wrap; align-items: center;
  font-family: var(--font-mono); font-size: 12px; color: var(--snow-3);
  letter-spacing: 0.1em; text-transform: uppercase;
  padding-bottom: 24px; border-bottom: 1px solid var(--ink-4); margin-bottom: 40px;
}
article.prose .meta .kind { color: var(--yeti-green);}
article.prose .meta .tags { display: flex; gap: 6px;}
article.prose .meta .tags .tag { background: var(--ink-2); padding: 2px 8px; border-radius: 999px; border: 1px solid var(--ink-4);}

/* ===== Inquiry form ===== */
.inquiry-form {
  margin: 40px 0;
  padding: 28px;
  background: var(--ink-2);
  border: 1px solid var(--ink-4);
  border-radius: 8px;
}
.inquiry-form .form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}
.inquiry-form .field {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 18px;
}
.inquiry-form .field span,
.inquiry-form .consent span {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--snow-3);
}
.inquiry-form input,
.inquiry-form select,
.inquiry-form textarea {
  width: 100%;
  border: 1px solid var(--ink-4);
  border-radius: 6px;
  background: var(--ink-1);
  color: var(--snow-0);
  font: inherit;
  padding: 12px 14px;
}
.inquiry-form select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 6L8 10L12 6' stroke='%23DCE1EB' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  background-size: 16px;
  padding-right: 44px;
}
.inquiry-form select::-ms-expand { display: none;}
.inquiry-form option {
  background: var(--ink-1);
  color: var(--snow-0);
}
.inquiry-form textarea { resize: vertical; min-height: 160px;}
.inquiry-form input:focus,
.inquiry-form select:focus,
.inquiry-form textarea:focus {
  outline: none;
  border-color: var(--yeti-green);
  box-shadow: 0 0 0 3px rgba(32,194,14,.14);
}
.inquiry-form .consent {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 8px 0 24px;
}
.inquiry-form .consent input {
  width: 16px;
  height: 16px;
  margin-top: 2px;
  accent-color: var(--yeti-green);
}
.inquiry-form .form-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.inquiry-form .form-actions span {
  color: var(--snow-3);
  font-size: 14px;
}
.inquiry-form .form-alert {
  margin-bottom: 20px;
  padding: 12px 14px;
  border-left: 2px solid var(--sev-medium);
  background: rgba(245,165,36,.08);
  color: var(--snow-1);
  font-size: 14px;
}
.inquiry-form .form-status {
  margin-bottom: 20px;
  padding: 12px 14px;
  border-left: 2px solid var(--yeti-green);
  background: rgba(32,194,14,.08);
  color: var(--snow-1);
  font-size: 14px;
}
.inquiry-form .form-status[data-state="error"] {
  border-left-color: var(--sev-critical);
  background: rgba(239,68,68,.08);
}
.inquiry-form .form-status[data-state="pending"] {
  border-left-color: var(--sev-medium);
  background: rgba(245,165,36,.08);
}
.inquiry-form .form-botcheck {
  position: absolute;
  left: -9999px;
}
.inquiry-form button[disabled] {
  cursor: not-allowed;
  opacity: .55;
}

/* ===== Journal list ===== */
.journal-list { max-width: 1000px; margin: 0 auto; padding: 56px 32px 120px;}
.journal-list .item {
  display: grid; grid-template-columns: 1fr 3fr; gap: 32px;
  padding: 28px 0; border-bottom: 1px solid var(--ink-4);
  transition: background .15s;
}
.journal-list .item:hover { background: var(--ink-2); margin: 0 -24px; padding: 28px 24px;}
.journal-list .item .date { font-family: var(--font-mono); font-size: 12px; color: var(--snow-3); letter-spacing: 0.1em; padding-top: 4px;}
.journal-list .item .date .kind { color: var(--yeti-green); display: block; margin-top: 4px; text-transform: uppercase;}
.journal-list .item h3 { font-family: var(--font-display); font-size: 28px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.15; margin: 0 0 8px; color: var(--snow-0);}
.journal-list .item p { color: var(--snow-2); font-size: 15px; line-height: 1.5; margin: 0;}

/* ===== Shortcodes ===== */
.callout {
  border-radius: 6px; padding: 16px 20px;
  margin: 24px 0;
  background: rgba(32,194,14,.05);
  border-left: 2px solid var(--yeti-green);
  font-size: 15px; line-height: 1.55;
}
.callout .label { font-family: var(--font-mono); font-size: 10px; color: var(--yeti-green); letter-spacing: 0.12em; text-transform: uppercase; margin-bottom: 6px; display: block;}
.callout.warn { background: rgba(245,165,36,.06); border-left-color: var(--sev-medium);}
.callout.warn .label { color: var(--sev-medium);}
.callout.crit { background: rgba(239,68,68,.06); border-left-color: var(--sev-critical);}
.callout.crit .label { color: var(--sev-critical);}

.stat-inline {
  display: inline-flex; flex-direction: column; padding: 14px 18px;
  background: var(--ink-2); border: 1px solid var(--ink-4); border-radius: 8px;
  margin: 8px 8px 8px 0;
  vertical-align: middle;
}
.stat-inline .v { font-family: var(--font-display); font-size: 28px; font-weight: 700; color: var(--snow-0); letter-spacing: -0.02em; line-height: 1;}
.stat-inline .v em { font-style: normal; color: var(--yeti-green);}
.stat-inline .l { font-family: var(--font-mono); font-size: 10px; color: var(--snow-3); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 6px;}

.kbd {
  display: inline-block;
  font-family: var(--font-mono); font-size: 0.85em;
  background: var(--ink-2); border: 1px solid var(--ink-4); border-bottom-width: 2px;
  border-radius: 4px; padding: 2px 8px; color: var(--snow-0);
}

.finding {
  background: var(--ink-2); border: 1px solid var(--ink-4);
  border-left: 3px solid var(--sev-medium);
  border-radius: 6px; padding: 20px; margin: 24px 0;
}
.finding.crit { border-left-color: var(--sev-critical);}
.finding.high { border-left-color: var(--sev-high);}
.finding.low { border-left-color: var(--sev-low);}
.finding .head { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 8px; margin-bottom: 12px;}
.finding .head .ttl { font-family: var(--font-display); font-size: 18px; font-weight: 700; color: var(--snow-0); letter-spacing: -0.01em;}
.finding .head .id { font-family: var(--font-mono); font-size: 11px; color: var(--snow-3); letter-spacing: 0.08em;}
.finding .meta-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
  padding: 12px 0; margin: 12px 0;
  border-top: 1px solid var(--ink-4); border-bottom: 1px solid var(--ink-4);
}
.finding .meta-row dt { font-family: var(--font-mono); font-size: 9px; color: var(--snow-3); letter-spacing: 0.1em; text-transform: uppercase; margin: 0;}
.finding .meta-row dd { margin: 4px 0 0; color: var(--snow-0); font-size: 13px; font-family: var(--font-mono);}

/* ===== Footer ===== */
footer.site {
  padding: 80px 32px 48px;
  background: var(--ink-0);
  border-top: 1px solid var(--ink-4);
}
footer.site .inner { max-width: 1280px; margin: 0 auto;}
footer.site .grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 56px; border-bottom: 1px solid var(--ink-4);
}
footer.site .lockup { display: flex; align-items: center; gap: 12px; margin-bottom: 16px;}
footer.site .lockup img { width: 32px; height: 32px; object-fit: contain;}
footer.site .lockup span { font-family: var(--font-display); font-weight: 700; font-size: 18px; letter-spacing: -0.02em; color: var(--snow-0);}
footer.site .lockup em { font-style: normal; color: var(--yeti-green);}
footer.site .tagline { color: var(--snow-2); font-size: 14px; line-height: 1.55; max-width: 320px;}
footer.site h5 { font-family: var(--font-mono); font-size: 10px; color: var(--snow-3); letter-spacing: 0.15em; text-transform: uppercase; margin: 0 0 16px;}
footer.site ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; font-size: 14px;}
footer.site ul a { color: var(--snow-1);}
footer.site ul a:hover { color: var(--yeti-green);}
footer.site .bottom {
  padding-top: 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 16px;
  font-family: var(--font-mono); font-size: 11px; color: var(--snow-3);
  letter-spacing: 0.08em; text-transform: uppercase;
}
footer.site .bottom a { color: var(--snow-3);}
footer.site .bottom a:hover { color: var(--yeti-green);}

/* ===== Preview stripe ===== */
.preview-strip {
  background: var(--yeti-green); color: var(--ink-0);
  padding: 10px 32px;
  text-align: center;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase;
}

/* ===== Responsive ===== */
@media (max-width: 900px) {
  .nav ul { display: none;}
  .nav .inner { padding: 14px 20px;}
  .svc-grid, .process, .posts { grid-template-columns: 1fr;}
  .hero { padding: 80px 24px;}
  .hero .footstats { grid-template-columns: 1fr 1fr;}
  .cta-banner { flex-direction: column; align-items: flex-start; padding: 48px 32px;}
  footer.site .grid { grid-template-columns: 1fr 1fr;}
  section.s { padding: 80px 24px;}
  .journal-list .item { grid-template-columns: 1fr; gap: 8px;}
  .finding .meta-row { grid-template-columns: 1fr 1fr;}
  .inquiry-form { padding: 22px;}
  .inquiry-form .form-grid { grid-template-columns: 1fr;}
}
