:root {
  color-scheme: light;
  --ink: oklch(18% 0.018 210);
  --ink-soft: oklch(38% 0.026 214);
  --muted: oklch(54% 0.024 210);
  --cloud: oklch(98% 0.008 205);
  --mist: oklch(94% 0.018 196);
  --panel: oklch(99% 0.006 205);
  --slate: oklch(25% 0.026 218);
  --line: oklch(84% 0.021 204);
  --line-dark: oklch(38% 0.026 215);
  --teal: oklch(70% 0.145 178);
  --teal-deep: oklch(43% 0.105 183);
  --orange: oklch(70% 0.19 42);
  --amber: oklch(80% 0.14 76);
  --green: oklch(72% 0.14 150);
  --max: 1240px;
  --shadow-panel: 0 28px 70px color-mix(in oklch, var(--ink) 13%, transparent);
  --shadow-lift: 0 14px 34px color-mix(in oklch, var(--ink) 10%, transparent);
  font-family: Manrope, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  overflow-x: hidden;
  background:
    linear-gradient(90deg, color-mix(in oklch, var(--line) 22%, transparent) 1px, transparent 1px),
    linear-gradient(180deg, color-mix(in oklch, var(--line) 16%, transparent) 1px, transparent 1px),
    linear-gradient(180deg, var(--cloud) 0%, color-mix(in oklch, var(--mist) 72%, var(--cloud)) 46%, var(--cloud) 100%);
  background-size: 88px 88px, 88px 88px, auto;
  color: var(--ink);
  letter-spacing: 0;
}

img,
svg {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

button,
input,
textarea {
  font: inherit;
}

.site-header {
  position: sticky;
  top: 14px;
  z-index: 30;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 26px;
  width: min(calc(100% - 32px), var(--max));
  min-height: 72px;
  margin: 14px auto 0;
  padding: 9px 10px 9px 16px;
  border: 1px solid color-mix(in oklch, var(--line) 70%, transparent);
  border-radius: 18px;
  background: color-mix(in oklch, var(--panel) 92%, transparent);
  box-shadow: 0 16px 46px color-mix(in oklch, var(--ink) 8%, transparent);
  backdrop-filter: blur(16px);
}

.site-header[data-scrolled] {
  background: color-mix(in oklch, var(--panel) 96%, transparent);
}

.brand {
  display: flex;
  align-items: center;
  width: 174px;
  height: 48px;
  overflow: hidden;
}

.brand img {
  width: 170px;
  height: auto;
}

.nav {
  display: flex;
  justify-content: center;
  gap: 6px;
  min-width: 0;
}

.nav a {
  display: inline-flex;
  align-items: center;
  min-height: 44px;
  padding: 0 11px;
  border-radius: 8px;
  color: var(--ink-soft);
  font-size: 14px;
  font-weight: 700;
  transition: background 170ms ease, color 170ms ease;
}

.nav a:hover,
.nav a:focus-visible {
  background: color-mix(in oklch, var(--teal) 16%, transparent);
  color: var(--ink);
  outline: none;
}

.button,
.header-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: 8px;
  font-weight: 800;
  letter-spacing: 0;
  cursor: pointer;
  white-space: nowrap;
  transition: transform 170ms ease, box-shadow 170ms ease, background 170ms ease;
}

.button:hover,
.header-cta:hover {
  transform: translateY(-1px);
}

.primary,
.header-cta {
  background: var(--ink);
  color: var(--cloud);
  box-shadow: 0 14px 30px color-mix(in oklch, var(--ink) 16%, transparent);
}

.ghost {
  border-color: color-mix(in oklch, var(--line) 86%, transparent);
  background: color-mix(in oklch, var(--panel) 78%, transparent);
  color: var(--ink);
}

.section,
.hero,
.case-section,
.guarantee,
.contact {
  width: min(calc(100% - 40px), var(--max));
  margin-inline: auto;
}

.hero {
  min-height: calc(100svh - 86px);
  display: grid;
  grid-template-columns: minmax(0, 0.94fr) minmax(430px, 1.06fr);
  align-items: center;
  gap: clamp(34px, 5vw, 74px);
  padding: clamp(58px, 8vw, 108px) 0 clamp(56px, 7vw, 90px);
}

.hero-copy {
  max-width: 670px;
  min-width: 0;
}

.hero > *,
.intro > *,
.process-grid > *,
.sectors > *,
.case-section > *,
.service-row > *,
.guarantee > *,
.contact > * {
  min-width: 0;
}

.eyebrow,
.section-kicker {
  margin: 0 0 18px;
  color: var(--teal-deep);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1,
h2 {
  font-family: Onest, Manrope, system-ui, sans-serif;
  letter-spacing: 0;
  overflow-wrap: break-word;
  word-break: normal;
}

h1 {
  max-width: 560px;
  margin-bottom: 28px;
  font-size: clamp(58px, 6.4vw, 94px);
  line-height: 0.9;
  font-weight: 900;
  overflow-wrap: normal;
  hyphens: manual;
}

h2 {
  margin-bottom: 0;
  font-size: clamp(34px, 4.8vw, 68px);
  line-height: 0.96;
  font-weight: 850;
}

h3 {
  margin-bottom: 0;
  font-size: 20px;
  line-height: 1.18;
}

.lead {
  max-width: 620px;
  margin-bottom: 30px;
  color: var(--ink-soft);
  font-size: clamp(18px, 1.5vw, 22px);
  line-height: 1.58;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 30px;
}

.hero-note {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  max-width: 650px;
}

.hero-note span {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  padding: 0 12px;
  border: 1px solid color-mix(in oklch, var(--line) 80%, transparent);
  border-radius: 8px;
  background: color-mix(in oklch, var(--panel) 76%, transparent);
  color: var(--ink-soft);
  font-size: 13px;
  font-weight: 800;
}

.hero-console {
  position: relative;
  min-height: 650px;
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--line-dark) 36%, transparent);
  border-radius: 18px;
  background:
    linear-gradient(135deg, color-mix(in oklch, var(--slate) 96%, var(--teal)), color-mix(in oklch, var(--ink) 88%, var(--teal))),
    var(--slate);
  box-shadow: var(--shadow-panel);
  contain: paint;
}

.hero-console::before {
  content: "";
  position: absolute;
  inset: 28px;
  opacity: 0.34;
  background:
    linear-gradient(90deg, color-mix(in oklch, var(--cloud) 18%, transparent) 1px, transparent 1px),
    linear-gradient(180deg, color-mix(in oklch, var(--cloud) 18%, transparent) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: linear-gradient(180deg, black 0%, transparent 92%);
}

.hero-console::after {
  content: "";
  position: absolute;
  right: -90px;
  bottom: -80px;
  width: 340px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: color-mix(in oklch, var(--teal) 38%, transparent);
  filter: blur(12px);
  opacity: 0.72;
}

.console-top,
.meeting-card,
.eligibility-card,
.route-map,
.deadline-strip {
  position: relative;
  z-index: 1;
}

.console-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 28px;
  color: color-mix(in oklch, var(--cloud) 76%, transparent);
  font-size: 14px;
  font-weight: 800;
}

.console-top strong {
  color: var(--cloud);
}

.meeting-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: min(480px, calc(100% - 56px));
  margin: 82px auto 18px;
  padding: 24px;
  border: 1px solid color-mix(in oklch, var(--cloud) 18%, transparent);
  border-radius: 14px;
  background: color-mix(in oklch, var(--panel) 94%, transparent);
  box-shadow: var(--shadow-lift);
}

.meeting-card span,
.eligibility-card span,
.deadline-strip span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.meeting-card strong {
  display: block;
  margin-top: 7px;
  color: var(--ink);
  font-family: Onest, Manrope, system-ui, sans-serif;
  font-size: 36px;
}

.meeting-card a {
  display: inline-flex;
  min-height: 44px;
  align-items: center;
  padding: 0 16px;
  border-radius: 8px;
  background: var(--teal);
  color: var(--ink);
  font-weight: 900;
}

.eligibility-card {
  display: flex;
  align-items: center;
  gap: 18px;
  width: min(420px, calc(100% - 78px));
  margin-left: auto;
  margin-right: 28px;
  padding: 18px;
  border: 1px solid color-mix(in oklch, var(--teal) 44%, transparent);
  border-radius: 14px;
  background: color-mix(in oklch, var(--ink) 56%, transparent);
}

.eligibility-card .score {
  display: inline-grid;
  place-items: center;
  width: 82px;
  aspect-ratio: 1;
  border: 1px solid color-mix(in oklch, var(--teal) 62%, transparent);
  border-radius: 50%;
  color: var(--teal);
  font-family: Onest, Manrope, system-ui, sans-serif;
  font-size: 28px;
}

.eligibility-card strong {
  display: block;
  margin-bottom: 4px;
  color: var(--cloud);
  font-size: 20px;
}

.route-map {
  display: grid;
  gap: 12px;
  width: min(520px, calc(100% - 56px));
  margin: 34px auto 0;
  padding: 0;
  list-style: none;
}

.route-map li {
  display: grid;
  grid-template-columns: 54px 1fr;
  align-items: center;
  min-height: 62px;
  padding: 9px 14px;
  border: 1px solid color-mix(in oklch, var(--cloud) 14%, transparent);
  border-radius: 10px;
  background: color-mix(in oklch, var(--cloud) 7%, transparent);
  color: var(--cloud);
  font-weight: 800;
}

.route-map span {
  color: var(--amber);
  font-size: 13px;
}

.deadline-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  width: min(520px, calc(100% - 56px));
  margin: 26px auto 0;
}

.deadline-strip span {
  min-height: 34px;
  padding: 8px 12px;
  border-radius: 8px;
  background: color-mix(in oklch, var(--teal) 18%, transparent);
  color: color-mix(in oklch, var(--cloud) 84%, var(--teal));
}

.intro {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(320px, 0.68fr);
  gap: clamp(32px, 6vw, 84px);
  align-items: end;
  padding: clamp(48px, 7vw, 86px) 0;
  border-top: 1px solid var(--line);
}

.intro p:not(.section-kicker) {
  margin-bottom: 0;
  color: var(--ink-soft);
  font-size: 19px;
  line-height: 1.64;
}

.process-section {
  padding: clamp(52px, 7vw, 90px) 0;
}

.section-head {
  max-width: 850px;
  margin-bottom: 38px;
}

.process-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(420px, 1.14fr);
  gap: 24px;
}

.process-list {
  display: grid;
  gap: 6px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.process-list li {
  min-height: 122px;
  display: grid;
  align-content: center;
  gap: 7px;
  padding: 22px 24px;
  border: 1px solid var(--line);
  background: color-mix(in oklch, var(--panel) 90%, transparent);
}

.process-list li:nth-child(even) {
  background: color-mix(in oklch, var(--mist) 70%, var(--panel));
}

.process-list span,
.mini-process span {
  color: var(--teal-deep);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.process-list strong {
  font-family: Onest, Manrope, system-ui, sans-serif;
  font-size: clamp(20px, 2.2vw, 30px);
  line-height: 1.04;
}

.process-list p {
  margin-bottom: 0;
  color: var(--ink-soft);
  font-size: 15px;
  line-height: 1.5;
}

.map-visual {
  position: relative;
  min-height: 636px;
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--line-dark) 34%, transparent);
  border-radius: 16px;
  background:
    linear-gradient(120deg, color-mix(in oklch, var(--mist) 72%, var(--panel)), var(--panel)),
    var(--panel);
  box-shadow: var(--shadow-lift);
}

.map-label {
  position: absolute;
  left: 28px;
  top: 28px;
  color: var(--teal-deep);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.path-line {
  position: absolute;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--teal), color-mix(in oklch, var(--orange) 86%, var(--amber)));
  transform-origin: left center;
}

.path-a {
  left: 90px;
  top: 380px;
  width: 560px;
  transform: rotate(-23deg);
}

.path-b {
  left: 128px;
  top: 436px;
  width: 410px;
  transform: rotate(14deg);
  opacity: 0.7;
}

.path-c {
  right: 72px;
  top: 230px;
  width: 320px;
  transform: rotate(64deg);
  opacity: 0.55;
}

.map-node {
  position: absolute;
  width: 26px;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--panel);
  border: 7px solid var(--teal);
  box-shadow: 0 0 0 14px color-mix(in oklch, var(--teal) 15%, transparent);
}

.node-one {
  left: 108px;
  bottom: 172px;
}

.node-two {
  right: 160px;
  top: 210px;
}

.node-three {
  right: 104px;
  bottom: 148px;
  border-color: var(--orange);
  box-shadow: 0 0 0 14px color-mix(in oklch, var(--orange) 14%, transparent);
}

.node-four {
  left: 46%;
  top: 48%;
  border-color: var(--amber);
}

.program-ticket {
  position: absolute;
  left: 38px;
  bottom: 38px;
  width: min(330px, calc(100% - 76px));
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in oklch, var(--panel) 94%, transparent);
  box-shadow: var(--shadow-lift);
}

.program-ticket strong {
  display: block;
  margin-bottom: 6px;
  font-size: 22px;
}

.program-ticket span {
  color: var(--muted);
  font-weight: 800;
}

.sectors {
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(360px, 1fr);
  gap: clamp(32px, 5vw, 74px);
  padding: clamp(52px, 7vw, 86px) 0;
  border-top: 1px solid var(--line);
}

.sector-copy {
  align-self: start;
  position: sticky;
  top: 120px;
}

.sector-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-content: start;
}

.sector-grid span {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in oklch, var(--panel) 86%, transparent);
  color: var(--ink-soft);
  font-size: 14px;
  font-weight: 800;
}

.case-section {
  display: grid;
  grid-template-columns: minmax(280px, 0.62fr) minmax(0, 1fr);
  gap: 24px;
  align-items: stretch;
  padding: clamp(24px, 4vw, 36px);
  border: 1px solid color-mix(in oklch, var(--line-dark) 32%, transparent);
  border-radius: 18px;
  background: var(--slate);
  color: var(--cloud);
}

.case-image,
.case-card {
  min-height: 430px;
  border-radius: 12px;
}

.case-image {
  position: relative;
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--cloud) 15%, transparent);
  background:
    linear-gradient(135deg, color-mix(in oklch, var(--teal) 34%, transparent), transparent 42%),
    color-mix(in oklch, var(--ink) 70%, var(--slate));
}

.case-photo {
  position: absolute;
  inset: 40px;
  display: grid;
  place-items: center;
  border: 1px solid color-mix(in oklch, var(--cloud) 30%, transparent);
  background:
    linear-gradient(30deg, transparent calc(50% - 1px), color-mix(in oklch, var(--cloud) 25%, transparent) 50%, transparent calc(50% + 1px)),
    linear-gradient(150deg, transparent calc(50% - 1px), color-mix(in oklch, var(--cloud) 25%, transparent) 50%, transparent calc(50% + 1px));
}

.case-photo span {
  padding: 8px 12px;
  border-radius: 8px;
  background: color-mix(in oklch, var(--cloud) 92%, transparent);
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
}

.case-badge {
  position: absolute;
  right: 28px;
  top: 28px;
  padding: 10px 14px;
  border-radius: 8px;
  background: var(--teal);
  color: var(--ink);
  font-weight: 900;
  text-transform: uppercase;
}

.case-card {
  display: grid;
  align-content: center;
  padding: clamp(28px, 5vw, 56px);
  border: 1px solid color-mix(in oklch, var(--cloud) 12%, transparent);
  background: color-mix(in oklch, var(--cloud) 6%, transparent);
}

.case-card .section-kicker,
.guarantee .section-kicker,
.contact .section-kicker {
  color: var(--teal);
}

.case-card h2 {
  color: var(--cloud);
  margin-bottom: 14px;
}

.case-amount {
  width: fit-content;
  margin-bottom: 24px;
  padding: 12px 14px;
  border-radius: 8px;
  background: color-mix(in oklch, var(--teal) 18%, transparent);
  color: var(--teal);
  font-family: Onest, Manrope, system-ui, sans-serif;
  font-size: clamp(24px, 3vw, 40px);
  font-weight: 900;
}

.case-card p {
  max-width: 66ch;
  margin-bottom: 0;
  color: color-mix(in oklch, var(--cloud) 74%, var(--teal));
  font-size: 18px;
  line-height: 1.62;
}

.service-stack {
  display: grid;
  gap: 24px;
  padding: clamp(54px, 7vw, 94px) 0;
}

.service-row {
  display: grid;
  grid-template-columns: minmax(300px, 0.66fr) minmax(0, 1fr);
  gap: 22px;
  align-items: stretch;
}

.service-row.reverse {
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.66fr);
}

.service-row.reverse .mini-process {
  order: 2;
}

.mini-process,
.document-visual,
.consortium-visual {
  min-height: 340px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklch, var(--panel) 88%, transparent);
}

.mini-process {
  display: grid;
  align-content: center;
  gap: 8px;
  padding: 26px;
}

.mini-process strong {
  padding-bottom: 16px;
  border-bottom: 1px solid var(--line);
  font-family: Onest, Manrope, system-ui, sans-serif;
  font-size: 24px;
  line-height: 1.08;
}

.mini-process strong:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.document-visual,
.consortium-visual {
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-lift);
}

.document-visual::before {
  content: "";
  position: absolute;
  inset: 28px;
  border: 1px solid color-mix(in oklch, var(--line-dark) 30%, transparent);
  border-radius: 10px;
  background: var(--panel);
}

.doc-toolbar {
  position: absolute;
  left: 58px;
  right: 58px;
  top: 58px;
  height: 42px;
  border-radius: 8px;
  background: color-mix(in oklch, var(--mist) 84%, transparent);
}

.doc-lines,
.doc-lines::before,
.doc-lines::after {
  position: absolute;
  left: 58px;
  right: 110px;
  height: 10px;
  border-radius: 999px;
  background: color-mix(in oklch, var(--line-dark) 18%, transparent);
}

.doc-lines {
  top: 144px;
}

.doc-lines::before,
.doc-lines::after {
  content: "";
  left: 0;
}

.doc-lines::before {
  top: 34px;
  right: 70px;
}

.doc-lines::after {
  top: 68px;
  right: 150px;
}

.doc-lines.short {
  top: 272px;
  right: 240px;
  background: var(--teal);
}

.doc-chip {
  position: absolute;
  right: 58px;
  bottom: 58px;
  padding: 12px 14px;
  border-radius: 8px;
  background: var(--orange);
  color: var(--ink);
  font-weight: 900;
}

.consortium-visual {
  background:
    linear-gradient(90deg, color-mix(in oklch, var(--line) 22%, transparent) 1px, transparent 1px),
    linear-gradient(180deg, color-mix(in oklch, var(--line) 22%, transparent) 1px, transparent 1px),
    color-mix(in oklch, var(--mist) 80%, var(--panel));
  background-size: 54px 54px;
}

.partner {
  position: absolute;
  display: inline-grid;
  place-items: center;
  width: 92px;
  aspect-ratio: 1;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--panel);
  color: var(--ink);
  font-weight: 900;
  box-shadow: var(--shadow-lift);
}

.p1 {
  left: 18%;
  top: 28%;
}

.p2 {
  right: 22%;
  top: 18%;
  background: color-mix(in oklch, var(--teal) 18%, var(--panel));
}

.p3 {
  left: 48%;
  bottom: 20%;
  background: color-mix(in oklch, var(--amber) 24%, var(--panel));
}

.connector {
  position: absolute;
  height: 2px;
  border-radius: 999px;
  background: var(--teal-deep);
  transform-origin: left center;
}

.c1 {
  left: 28%;
  top: 43%;
  width: 300px;
  transform: rotate(-13deg);
}

.c2 {
  left: 36%;
  top: 54%;
  width: 250px;
  transform: rotate(28deg);
}

.consortium-visual strong {
  position: absolute;
  left: 34px;
  bottom: 30px;
  color: var(--teal-deep);
  font-size: 22px;
}

.guarantee {
  display: grid;
  grid-template-columns: minmax(290px, 0.72fr) minmax(0, 1fr);
  gap: clamp(30px, 6vw, 84px);
  align-items: center;
  padding: clamp(46px, 6vw, 76px);
  border-radius: 18px;
  background: var(--ink);
  color: var(--cloud);
}

.guarantee-doc {
  position: relative;
  min-height: 480px;
  border-radius: 14px;
  background: var(--panel);
  color: var(--ink);
  box-shadow: var(--shadow-panel);
  overflow: hidden;
}

.doc-head {
  position: absolute;
  left: 34px;
  right: 34px;
  top: 34px;
  height: 56px;
  border-radius: 8px;
  background: color-mix(in oklch, var(--mist) 82%, transparent);
}

.doc-row {
  position: absolute;
  left: 34px;
  right: 80px;
  height: 12px;
  border-radius: 999px;
  background: color-mix(in oklch, var(--line-dark) 18%, transparent);
}

.doc-row.wide {
  top: 142px;
}

.doc-row:not(.wide):not(.short) {
  top: 184px;
}

.doc-row.short {
  top: 226px;
  right: 170px;
}

.stamp {
  position: absolute;
  right: 42px;
  bottom: 76px;
  padding: 18px 22px;
  border: 3px solid var(--orange);
  border-radius: 8px;
  color: var(--orange);
  font-family: Onest, Manrope, system-ui, sans-serif;
  font-size: 28px;
  font-weight: 900;
  text-transform: uppercase;
  transform: rotate(-8deg);
}

.guarantee-copy h2,
.contact h2 {
  color: var(--cloud);
  margin-bottom: 22px;
}

.guarantee-copy p,
.contact-copy p {
  max-width: 68ch;
  margin-bottom: 28px;
  color: color-mix(in oklch, var(--cloud) 76%, var(--teal));
  font-size: 18px;
  line-height: 1.62;
}

.news {
  padding: clamp(54px, 7vw, 94px) 0;
}

.news-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.news-row article {
  min-height: 190px;
  display: grid;
  align-content: space-between;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--panel) 88%, transparent);
}

.news-row time {
  color: var(--teal-deep);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.news-row h3 {
  max-width: 20ch;
  font-family: Onest, Manrope, system-ui, sans-serif;
  font-size: 25px;
}

.contact {
  display: grid;
  grid-template-columns: minmax(0, 0.82fr) minmax(360px, 0.74fr);
  gap: clamp(30px, 6vw, 78px);
  margin-bottom: 72px;
  padding: clamp(42px, 6vw, 78px);
  border-radius: 18px;
  background:
    linear-gradient(135deg, color-mix(in oklch, var(--teal-deep) 18%, transparent), transparent 44%),
    var(--slate);
  color: var(--cloud);
}

.contact-form {
  display: grid;
  gap: 14px;
  align-self: start;
}

.contact-form label {
  display: grid;
  gap: 8px;
  color: color-mix(in oklch, var(--cloud) 76%, var(--teal));
  font-size: 13px;
  font-weight: 900;
}

.contact-form input,
.contact-form textarea {
  width: 100%;
  border: 1px solid color-mix(in oklch, var(--cloud) 15%, transparent);
  border-radius: 8px;
  background: color-mix(in oklch, var(--ink) 46%, transparent);
  color: var(--cloud);
  outline: none;
}

.contact-form input {
  min-height: 52px;
  padding: 0 16px;
}

.contact-form textarea {
  resize: vertical;
  min-height: 126px;
  padding: 14px 16px;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: color-mix(in oklch, var(--cloud) 40%, transparent);
}

.contact-form input:focus,
.contact-form textarea:focus {
  border-color: var(--teal);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--teal) 22%, transparent);
}

.contact-form .button {
  width: fit-content;
  background: var(--teal);
  color: var(--ink);
}

@media (max-width: 1060px) {
  .site-header {
    grid-template-columns: auto auto;
  }

  .nav {
    order: 3;
    grid-column: 1 / -1;
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 2px;
  }

  .hero,
  .intro,
  .process-grid,
  .sectors,
  .case-section,
  .service-row,
  .service-row.reverse,
  .guarantee,
  .contact {
    grid-template-columns: 1fr;
  }

  .service-row.reverse .mini-process {
    order: 0;
  }

  .sector-copy {
    position: static;
  }

  .hero-console {
    min-height: 560px;
  }

  h1 {
    max-width: 14ch;
  }
}

@media (max-width: 720px) {
  .section,
  .hero,
  .case-section,
  .guarantee,
  .contact {
    width: min(calc(100% - 24px), var(--max));
  }

  .site-header {
    top: 8px;
    width: min(calc(100% - 20px), var(--max));
    gap: 12px;
    min-height: 0;
    border-radius: 14px;
  }

  .brand {
    width: 142px;
    height: 44px;
  }

  .brand img {
    width: 138px;
  }

  .header-cta {
    min-height: 44px;
    padding: 0 12px;
    font-size: 12px;
  }

  .nav a {
    min-height: 44px;
    font-size: 13px;
  }

  .hero {
    min-height: auto;
    padding-top: 48px;
  }

  h1 {
    max-width: 100%;
    font-size: clamp(44px, 13.2vw, 60px);
  }

  h2 {
    font-size: clamp(32px, 11vw, 48px);
  }

  .hero-console,
  .map-visual {
    min-height: 500px;
  }

  .meeting-card,
  .route-map,
  .deadline-strip {
    width: calc(100% - 32px);
  }

  .meeting-card {
    margin-top: 58px;
    padding: 18px;
  }

  .meeting-card strong {
    font-size: 28px;
  }

  .eligibility-card {
    width: calc(100% - 32px);
    margin-right: 16px;
  }

  .process-list li {
    min-height: 0;
    padding: 20px;
  }

  .case-section,
  .guarantee,
  .contact {
    padding: 18px;
  }

  .case-image,
  .case-card,
  .guarantee-doc {
    min-height: 360px;
  }

  .news-row {
    grid-template-columns: 1fr;
  }

  .path-a {
    left: 36px;
    width: 300px;
  }

  .path-b {
    left: 40px;
    width: 250px;
  }

  .path-c {
    right: 18px;
    width: 210px;
  }

  .c1 {
    left: 24%;
    width: 210px;
  }

  .c2 {
    left: 30%;
    width: 190px;
  }
}

@media (max-width: 460px) {
  .site-header {
    grid-template-columns: 1fr;
  }

  .header-cta {
    width: 100%;
  }

  .hero-actions {
    display: grid;
  }

  .button {
    width: 100%;
  }

  .hero-note span,
  .sector-grid span {
    width: 100%;
  }

  .meeting-card,
  .eligibility-card {
    display: grid;
    gap: 14px;
  }

  .eligibility-card .score {
    width: 70px;
  }

  .route-map li {
    grid-template-columns: 42px 1fr;
  }

  .contact-form .button {
    width: 100%;
  }
}
