@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@500;600;700;800&display=swap');

    :root {
      color-scheme: light;
      --active-header-height: 149px;
    }
    * { letter-spacing: 0 !important; }
    body {
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif;
      background: #f4f6f7;
      color: #293129;
      overflow-anchor: none;
    }
    body.home-page {
      height: 100dvh;
      overflow: hidden;
    }
    body.home-page main {
      height: 100dvh;
      overflow: hidden;
    }
    body.home-page main > section:not(.home-screen),
    body.home-page > footer {
      display: none !important;
    }
    body:not(.home-page) main > section:not(.home-screen) {
      scroll-margin-top: var(--active-header-height);
    }
    body:not(.home-page) main > section:not(.home-screen) > .mx-auto {
      width: 100%;
    }
    .material-symbols-outlined {
      font-variation-settings: 'FILL' 0, 'wght' 350, 'GRAD' 0, 'opsz' 24;
      line-height: 1;
    }
    .section-label {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
      color: #c96f4a;
    }
    .section-label::before {
      content: '';
      width: 34px;
      height: 2px;
      background: #d8ff48;
    }
    .language-button,
    .path-card,
    .primary-action,
    .secondary-action {
      transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
    }
    .language-button[aria-pressed='true'] {
      background: #566645;
      border-color: #566645;
      color: #fff;
    }
    .language-button:hover,
    .language-button:focus-visible,
    .path-card:hover,
    .path-card:focus-visible,
    .primary-action:hover,
    .primary-action:focus-visible,
    .secondary-action:hover,
    .secondary-action:focus-visible {
      transform: translateY(-2px);
      outline: none;
    }
    .path-card:hover,
    .path-card:focus-visible {
      box-shadow: 0 18px 42px rgba(41, 49, 41, .14), 0 2px 10px rgba(41, 49, 41, .05);
    }
    .capability-card-body {
      display: -webkit-box;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
      overflow: hidden;
    }
    .route-radar {
      background:
        radial-gradient(circle at 72% 28%, rgba(93, 183, 158, .18), transparent 25%),
        radial-gradient(circle at 24% 70%, rgba(216, 255, 72, .18), transparent 28%),
        linear-gradient(135deg, rgba(255,255,255,.1), rgba(255,255,255,0));
    }
    .route-radar::before {
      content: '';
      position: absolute;
      inset: 18px;
      border: 1px solid rgba(255,255,255,.14);
      background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
      background-size: 34px 34px;
    }
    .dark-section .section-label {
      color: #d8ff48;
    }
    .dark-section .section-label::before {
      background: #d8ff48;
    }
    .friction-stage {
      position: relative;
      min-height: 560px;
      overflow: hidden;
      border: 1px solid rgba(255,255,255,.12);
      background:
        radial-gradient(circle at 72% 28%, rgba(93, 183, 158, .16), transparent 24%),
        radial-gradient(circle at 24% 78%, rgba(216, 255, 72, .16), transparent 26%),
        linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02));
      box-shadow: 0 28px 80px rgba(0, 12, 28, .32), inset 0 1px 0 rgba(255,255,255,.08);
    }
    .friction-stage::before {
      content: '';
      position: absolute;
      inset: 24px;
      border: 1px solid rgba(255,255,255,.09);
      background-image:
        linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
      background-size: 46px 46px;
      opacity: .75;
    }
    .friction-stage::after {
      content: '';
      position: absolute;
      left: 52%;
      top: 10%;
      width: 1px;
      height: 80%;
      background: linear-gradient(180deg, transparent, rgba(216,255,72,.7), transparent);
      transform: rotate(18deg);
    }
    .friction-card {
      position: relative;
      z-index: 1;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(41, 49, 41, .64);
      padding: 22px;
      color: #fff;
      backdrop-filter: blur(14px);
      box-shadow: 0 18px 48px rgba(0, 12, 28, .24);
      transition: transform 180ms cubic-bezier(0.16, 1, 0.3, 1), border-color 180ms ease, background-color 180ms ease;
    }
    .friction-card:hover {
      transform: translateY(-4px);
      border-color: rgba(216,255,72,.48);
      background: rgba(9, 33, 61, .78);
    }
    .friction-card:nth-child(1) { margin: 46px 34% 0 8%; }
    .friction-card:nth-child(2) { margin: -8px 8% 0 42%; }
    .friction-card:nth-child(3) { margin: 24px 36% 0 14%; }
    .friction-card:nth-child(4) { margin: -6px 10% 0 45%; }
    .partner-stage {
      position: relative;
      min-height: 590px;
      overflow: hidden;
      border: 1px solid #d8dde3;
      background: #293129;
      box-shadow: 0 28px 70px rgba(41, 49, 41, .18), 0 2px 10px rgba(41, 49, 41, .05);
    }
    .partner-stage img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: .58;
      filter: saturate(.9) contrast(1.04);
    }
    .partner-stage::after {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(90deg, rgba(7,26,49,.78), rgba(7,26,49,.38) 52%, rgba(7,26,49,.72)),
        radial-gradient(circle at 72% 22%, rgba(216,255,72,.22), transparent 25%);
    }
    .partner-stage-content {
      position: relative;
      z-index: 1;
      display: flex;
      min-height: inherit;
      flex-direction: column;
      justify-content: space-between;
      gap: 28px;
      padding: clamp(24px, 4vw, 44px);
    }
    .partner-process {
      display: grid;
      gap: 14px;
      max-width: 460px;
    }
    .partner-process-item {
      display: grid;
      grid-template-columns: 42px 1fr;
      gap: 16px;
      border: 1px solid rgba(255,255,255,.14);
      background: rgba(5, 19, 38, .58);
      padding: 18px;
      color: #fff;
      backdrop-filter: blur(10px);
      transition: transform 180ms cubic-bezier(0.16, 1, 0.3, 1), border-color 180ms ease, background-color 180ms ease;
    }
    .partner-process-item:hover {
      transform: translateX(6px);
      border-color: rgba(216,255,72,.48);
      background: rgba(8, 31, 58, .76);
    }
    .partner-process-index {
      display: flex;
      width: 42px;
      height: 42px;
      align-items: center;
      justify-content: center;
      border: 1px solid rgba(216,255,72,.55);
      color: #d8ff48;
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif;
      font-size: 12px;
      font-weight: 800;
    }
    .partner-proof-row {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
      max-width: 620px;
    }
    .partner-proof-row > div {
      border-top: 1px solid rgba(255,255,255,.18);
      background: rgba(255,255,255,.07);
      padding: 16px;
      color: #fff;
      backdrop-filter: blur(8px);
    }
    .system-console {
      position: relative;
      min-height: 560px;
      overflow: hidden;
      background: #293129;
      box-shadow: 0 28px 70px rgba(41, 49, 41, .18), 0 2px 10px rgba(41, 49, 41, .05);
    }
    .system-console img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: .42;
      filter: saturate(.95) contrast(1.05);
    }
    .system-console::after {
      content: '';
      position: absolute;
      inset: 0;
      background:
        linear-gradient(180deg, rgba(7,26,49,.2), rgba(7,26,49,.82)),
        radial-gradient(circle at 24% 22%, rgba(93,183,158,.16), transparent 24%);
    }
    .system-console-content {
      position: relative;
      z-index: 1;
      display: grid;
      min-height: inherit;
      grid-template-rows: 1fr auto;
      gap: 24px;
      padding: clamp(24px, 4vw, 42px);
    }
    .system-flow {
      align-self: end;
      display: grid;
      gap: 12px;
      max-width: 520px;
    }
    .system-flow-item {
      display: grid;
      grid-template-columns: 48px 1fr;
      gap: 16px;
      border-left: 2px solid rgba(216,255,72,.72);
      background: rgba(255,255,255,.08);
      padding: 16px 18px;
      color: #fff;
      backdrop-filter: blur(10px);
    }
    .system-proof-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 1px;
      background: rgba(255,255,255,.14);
    }
    .system-proof-grid > div {
      background: rgba(7,26,49,.72);
      padding: 18px;
      color: #fff;
    }
    .feature-hero-grid {
      min-height: calc(100dvh - var(--active-header-height));
    }
    .feature-visual {
      position: relative;
      min-height: 540px;
      overflow: hidden;
      border: 1px solid #d8dde3;
      background: #293129;
      box-shadow: 0 30px 70px rgba(41, 49, 41, .16), 0 2px 10px rgba(41, 49, 41, .05);
    }
    .feature-visual img {
      position: absolute;
      inset: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
      opacity: 1;
      filter: none;
    }
    .feature-number-row {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 18px;
      max-width: 620px;
    }
    .feature-number-row > div {
      border-top: 1px solid #d8dde3;
      padding-top: 18px;
    }
    .locale-card[hidden] {
      display: none !important;
    }
    .home-panel[hidden] {
      display: none !important;
    }
    .home-screen {
      height: calc(100dvh - 149px);
      overflow: hidden;
    }
    .home-hero-bg {
      position: relative;
      z-index: 1;
      background: transparent;
    }
    .home-hero-bg::before {
      content: '';
      position: absolute;
      inset: 0;
      z-index: 0;
      pointer-events: none;
      background:
        linear-gradient(90deg, rgba(3, 14, 31, .80), rgba(3, 14, 31, .54) 48%, rgba(3, 14, 31, .18)),
        linear-gradient(0deg, rgba(3, 14, 31, .46), rgba(3, 14, 31, .06));
    }
    .home-hero-bg > .mx-auto {
      position: relative;
      z-index: 1;
    }
    body:not(.home-page) #growth-bg {
      opacity: 0;
      visibility: hidden;
    }
    .nav-group {
      position: relative;
    }
    .nav-trigger {
      display: inline-flex;
      align-items: center;
      gap: 0.25rem;
      border-radius: 0.125rem;
      padding: 0.625rem 0.5rem;
      color: #5c6672;
      transition: color 160ms ease, background-color 160ms ease;
    }
    .nav-trigger:hover,
    .nav-trigger:focus-visible,
    .nav-group:focus-within .nav-trigger {
      color: #566645;
      background: #f4f6f7;
      outline: none;
    }
    .nav-panel {
      position: absolute;
      left: 0;
      top: calc(100% + 0.5rem);
      z-index: 60;
      min-width: 240px;
      border: 1px solid #d8dde3;
      background: rgba(255, 255, 255, 0.98);
      padding: 0.5rem;
      box-shadow: 0 18px 42px rgba(41, 49, 41, .12);
      opacity: 0;
      visibility: hidden;
      transform: translateY(6px);
      transition: opacity 160ms ease, transform 160ms ease, visibility 160ms ease;
    }
    .nav-group:hover .nav-panel,
    .nav-group:focus-within .nav-panel {
      opacity: 1;
      visibility: visible;
      transform: translateY(0);
    }
    .nav-panel a {
      display: block;
      border-radius: 0.125rem;
      padding: 0.75rem 0.85rem;
      font-size: 0.8125rem;
      font-weight: 700;
      color: #5c6672;
      white-space: nowrap;
    }
    .nav-panel a:hover,
    .nav-panel a:focus-visible {
      color: #566645;
      background: #f4f6f7;
      outline: none;
    }
    .mobile-menu-button {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 44px;
      height: 44px;
      border: 1px solid #d8dde3;
      background: #fff;
      color: #566645;
      transition: border-color 160ms ease, background-color 160ms ease, transform 160ms ease;
    }
    .mobile-menu-button:hover,
    .mobile-menu-button:focus-visible {
      border-color: #566645;
      background: #f4f6f7;
      transform: translateY(-1px);
      outline: none;
    }
    .mobile-nav-panel {
      max-height: calc(100dvh - 75px);
      overflow-y: auto;
      border-top: 1px solid #d8dde3;
      background: rgba(255, 255, 255, .98);
      box-shadow: 0 20px 60px rgba(41, 49, 41, .12);
    }
    .mobile-nav-panel[hidden] {
      display: none !important;
    }
    .mobile-nav-section {
      border-bottom: 1px solid #edf0f3;
    }
    .mobile-nav-panel a {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 0.95rem 1.25rem;
      font-size: 0.9375rem;
      font-weight: 800;
      color: #293129;
    }
    .mobile-nav-primary {
      background: #fff;
    }
    .mobile-nav-sub {
      display: grid;
      gap: 0;
      padding: 0 0 0.55rem;
      background: #f8fafb;
    }
    .mobile-nav-sub a {
      padding: 0.62rem 1.25rem 0.62rem 2rem;
      font-size: 0.8125rem;
      font-weight: 700;
      color: #5c6672;
    }
    .mobile-nav-panel a:hover,
    .mobile-nav-panel a:focus-visible {
      background: #f4f6f7;
      color: #c96f4a;
      outline: none;
    }
    body.mobile-nav-open {
      overflow: hidden;
    }
    .operating-cockpit {
      min-height: 500px;
    }
    .dashboard-screen {
      animation: dashboardCycle 25s infinite;
      opacity: 0;
      transform: translateY(18px) scale(.985);
      pointer-events: none;
    }
    .dashboard-screen:nth-child(1) { animation-delay: 0s; }
    .dashboard-screen:nth-child(2) { animation-delay: 5s; }
    .dashboard-screen:nth-child(3) { animation-delay: 10s; }
    .dashboard-screen:nth-child(4) { animation-delay: 15s; }
    .dashboard-screen:nth-child(5) { animation-delay: 20s; }
    .metric-line {
      stroke-dasharray: 720;
      stroke-dashoffset: 720;
      animation: drawLine 5s ease-in-out infinite;
    }
    .bar-grow {
      transform-origin: bottom;
      animation: barGrow 5s ease-in-out infinite;
    }
    .signal-dot {
      animation: signalPulse 2.4s ease-in-out infinite;
    }
    .flow-glow {
      animation: flowGlow 2.6s ease-in-out infinite;
    }
    .timeline-track::before {
      content: '';
      position: absolute;
      left: 18px;
      top: 30px;
      bottom: 30px;
      width: 2px;
      background: #d8dde3;
    }
    .org-node {
      position: relative;
      isolation: isolate;
    }
    .org-node::after {
      content: '';
      position: absolute;
      inset: 0;
      z-index: -1;
      background: linear-gradient(135deg, rgba(255,255,255,.12), rgba(255,255,255,0));
      opacity: .75;
    }
    .org-branch {
      position: relative;
    }
    .org-branch::before {
      content: '';
      position: absolute;
      left: 50%;
      top: -34px;
      width: 1px;
      height: 34px;
      background: rgba(216, 255, 72, .9);
    }
    .org-branch::after {
      content: '';
      position: absolute;
      left: 8%;
      right: 8%;
      top: -34px;
      height: 1px;
      background: rgba(216, 255, 72, .55);
    }
    .growth-runway,
    .pipeline-stage {
      position: relative;
      overflow: hidden;
      background: #293129;
      color: #fff;
      box-shadow: 0 30px 80px rgba(41, 49, 41, .18), 0 2px 10px rgba(41, 49, 41, .05);
    }
    .growth-runway::before,
    .pipeline-stage::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image:
        linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px);
      background-size: 44px 44px;
      opacity: .44;
      pointer-events: none;
    }
    .growth-runway::after {
      content: '';
      position: absolute;
      inset: auto 0 0 0;
      height: 42%;
      background: linear-gradient(180deg, rgba(7,26,49,0), rgba(7,26,49,.92));
      pointer-events: none;
    }
    .growth-runway-inner,
    .pipeline-stage-inner {
      position: relative;
      z-index: 1;
    }
    .seo-note {
      position: relative;
      overflow: visible;
    }
    .growth-rail {
      position: relative;
      display: grid;
      gap: 1px;
      background: rgba(255,255,255,.16);
    }
    .growth-rail::before {
      content: '';
      position: absolute;
      left: 10%;
      right: 10%;
      top: 42px;
      height: 1px;
      background: linear-gradient(90deg, rgba(216,255,72,.35), rgba(216,255,72,1));
      pointer-events: none;
    }
    .growth-node {
      position: relative;
      min-height: 220px;
      background:
        linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.025)),
        rgba(7,26,49,.82);
      padding: 24px;
    }
    .growth-node::before {
      content: '';
      position: absolute;
      left: 24px;
      top: 37px;
      width: 12px;
      height: 12px;
      border: 2px solid #d8ff48;
      background: #293129;
      transform: rotate(45deg);
    }
    .growth-node.is-target {
      background:
        linear-gradient(180deg, rgba(216,255,72,.32), rgba(255,255,255,.035)),
        rgba(7,26,49,.9);
    }
    .growth-metric-line {
      display: grid;
      gap: 10px;
      margin-top: 18px;
    }
    .growth-metric-line span {
      display: block;
      height: 2px;
      transform-origin: left center;
      background: linear-gradient(90deg, #d8ff48, rgba(216,255,72,.16));
    }
    .pipeline-command,
    .executive-row {
      display: grid;
      gap: 1px;
      background: rgba(255,255,255,.14);
    }
    .pipeline-command > div,
    .executive-card,
    .pipeline-lane {
      background: rgba(255,255,255,.075);
      backdrop-filter: blur(10px);
    }
    .leader-strip > div {
      background: #293129;
      backdrop-filter: blur(10px);
    }
    .pipeline-stage .leader-strip > div {
      background: rgba(255,255,255,.075);
    }
    .pipeline-lanes {
      position: relative;
      display: grid;
      gap: 1px;
      background: rgba(255,255,255,.14);
      counter-reset: pipeline;
    }
    .pipeline-lane {
      position: relative;
      min-height: 300px;
      padding: 24px;
      transition: transform 220ms cubic-bezier(0.16, 1, 0.3, 1), background-color 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
    }
    .pipeline-lane:hover,
    .executive-card:hover {
      transform: translateY(-6px);
      background: rgba(255,255,255,.13);
      box-shadow: 0 22px 48px rgba(0, 12, 28, .28);
    }
    .pipeline-lane-index {
      display: inline-flex;
      align-items: center;
      gap: 10px;
      color: #d8ff48;
      font-size: 12px;
      font-weight: 800;
      text-transform: uppercase;
    }
    .pipeline-lane-index::after {
      content: '';
      display: block;
      width: 34px;
      height: 1px;
      background: rgba(216,255,72,.7);
    }
    .leader-strip {
      display: grid;
      gap: 1px;
      background: rgba(255,255,255,.14);
    }
    .executive-card {
      position: relative;
      padding: 24px;
      color: #fff;
      transition: transform 220ms cubic-bezier(0.16, 1, 0.3, 1), background-color 220ms ease, box-shadow 220ms ease;
    }
    .executive-card::before {
      content: attr(data-exec-label);
      display: block;
      margin-bottom: 14px;
      font-size: 11px;
      font-weight: 800;
      color: #d8ff48;
      text-transform: uppercase;
    }
    .owner-pill {
      display: inline-flex;
      margin-top: 22px;
      border: 1px solid rgba(216,255,72,.34);
      padding: 7px 10px;
      color: #d8ff48;
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
    }
    .pipeline-stage .is-linked {
      transform: translateY(-8px);
      background: rgba(255,255,255,.16);
      box-shadow: 0 24px 58px rgba(0, 12, 28, .34);
    }
    .pipeline-stage .pipeline-lane.is-linked {
      outline: 1px solid rgba(216,255,72,.7);
      z-index: 4;
    }
    @media (prefers-reduced-motion: reduce) {
      .dashboard-screen,
      .metric-line,
      .bar-grow,
      .signal-dot,
      .flow-glow {
        animation: none;
      }
      .dashboard-screen {
        opacity: 1;
        position: relative;
        transform: none;
      }
    }
    @media (max-width: 1023px) {
      body.home-page,
      body.home-page main {
        height: auto;
        overflow: auto;
      }
      .home-screen {
        min-height: calc(100dvh - 75px);
        height: auto;
        overflow: hidden;
      }
      .friction-stage,
      .partner-stage,
      .system-console {
        min-height: auto;
      }
      .friction-card:nth-child(n) {
        margin: 0;
      }
      .friction-stage {
        display: grid;
        gap: 12px;
        padding: 18px;
      }
      .partner-stage img,
      .system-console img {
        opacity: .34;
      }
      .partner-proof-row,
      .system-proof-grid {
        grid-template-columns: 1fr;
      }
      .feature-hero-grid {
        min-height: auto;
      }
      .feature-visual {
        min-height: 500px;
      }
      .feature-number-row {
        grid-template-columns: 1fr;
      }
      .org-branch::before,
      .org-branch::after {
        display: none;
      }
      .growth-rail,
      .pipeline-command,
      .pipeline-lanes,
      .leader-strip {
        grid-template-columns: 1fr;
      }
      .pipeline-lane:hover,
      .executive-card:hover,
      .pipeline-stage .is-linked {
        transform: translateY(-3px);
      }
    }
    @media (min-width: 1024px) {
      .mobile-menu-button,
      .mobile-nav-panel {
        display: none !important;
      }
      body:not(.home-page) main > section:not(.home-screen) {
        display: flex;
        align-items: center;
        min-height: calc(100dvh - var(--active-header-height));
      }
    }
    @media (max-width: 767px) {
      body.home-page {
        height: 100dvh;
        overflow: hidden;
      }
      body.home-page main {
        height: 100dvh;
        overflow: hidden;
      }
      .home-screen {
        min-height: calc(100dvh - 75px);
        height: calc(100dvh - 75px);
      }
      .home-hero-bg::before {
        background:
          linear-gradient(90deg, rgba(3, 14, 31, .88), rgba(3, 14, 31, .66)),
          linear-gradient(0deg, rgba(3, 14, 31, .48), rgba(3, 14, 31, .10));
      }
    }
    @keyframes dashboardCycle {
      0%, 18% { opacity: 1; transform: translateY(0) scale(1); }
      22%, 100% { opacity: 0; transform: translateY(-12px) scale(.99); }
    }
    @keyframes drawLine {
      0% { stroke-dashoffset: 720; }
      45%, 70% { stroke-dashoffset: 0; }
      100% { stroke-dashoffset: -220; }
    }
    @keyframes barGrow {
      0% { transform: scaleY(.38); opacity: .55; }
      45%, 75% { transform: scaleY(1); opacity: 1; }
      100% { transform: scaleY(.66); opacity: .7; }
    }
    @keyframes signalPulse {
      0%, 100% { opacity: .42; transform: scale(1); }
      50% { opacity: 1; transform: scale(1.18); }
    }
    @keyframes flowGlow {
      0%, 100% { opacity: .46; }
      50% { opacity: 1; }
    }

    /* Home refresh: lighter Vietnam execution platform direction */
    :root {
      --home-paper: #fbfaf6;
      --home-mint-paper: #f1fbf1;
      --home-sky-paper: #f3f7ec;
      --home-ink: #171717;
      --home-muted: #66635d;
      --home-navy: #566645;
      --home-red: #e12a23;
      --home-lime: #d8ff48;
      --home-sky: #9fb277;
      --home-coral: #ff664d;
      --home-line: rgba(86, 102, 69, .14);
      --home-ease: cubic-bezier(0.16, 1, 0.3, 1);
    }

    body.home-page {
      min-height: 100dvh;
      height: auto;
      overflow-x: hidden;
      overflow-y: auto;
      background:
        radial-gradient(circle at 78% 9%, rgba(216, 255, 72, .24), transparent 18rem),
        radial-gradient(circle at 11% 38%, rgba(159, 178, 119, .17), transparent 25rem),
        radial-gradient(circle at 86% 77%, rgba(255, 102, 77, .10), transparent 19rem),
        var(--home-paper);
      color: var(--home-ink);
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif !important;
    }

    html[lang='ko'] body.home-page,
    html[lang='ko'] body.home-page .home-copy,
    html[lang='ko'] body.home-page .home-chip-row,
    html[lang='ko'] body.home-page .home-route-card {
      font-family: 'Pretendard', 'Plus Jakarta Sans', sans-serif !important;
    }

    body.home-page::before {
      content: '';
      position: fixed;
      inset: 0;
      z-index: -1;
      pointer-events: none;
      opacity: .34;
      background-image:
        linear-gradient(rgba(86, 102, 69, .045) 1px, transparent 1px),
        linear-gradient(90deg, rgba(86, 102, 69, .045) 1px, transparent 1px);
      background-size: 88px 88px;
      mask-image: linear-gradient(180deg, #000 0%, rgba(0,0,0,.78) 58%, transparent 100%);
    }

    body.home-page #growth-bg {
      display: none !important;
    }

    body.home-page main,
    body.home-page .site-main-home {
      min-height: 100dvh;
      height: auto;
      overflow: visible;
      padding-top: var(--active-header-height);
    }

    body.home-page header {
      border-bottom: 1px solid rgba(86, 102, 69, .11);
      background: rgba(251, 250, 246, .88);
      box-shadow: 0 1px 0 rgba(255,255,255,.82), 0 18px 42px rgba(86, 102, 69, .08);
      backdrop-filter: blur(18px);
    }

    body.home-page header > div {
      padding-top: .85rem;
      padding-bottom: .85rem;
    }

    body.home-page .brand-name {
      display: inline-flex;
      align-items: center;
      gap: .7rem;
      color: var(--home-navy);
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif !important;
      font-size: clamp(1rem, 1.5vw, 1.45rem);
      font-weight: 800;
      text-transform: uppercase;
    }

    body.home-page nav {
      border-top-color: rgba(86, 102, 69, .09);
    }

    body.home-page .nav-trigger {
      border-radius: 999px;
      padding: .62rem .82rem;
      color: rgba(86, 102, 69, .64);
      transition: color 180ms ease, background-color 180ms ease, transform 180ms var(--home-ease);
    }

    body.home-page .nav-trigger:hover,
    body.home-page .nav-trigger:focus-visible,
    body.home-page .nav-group:focus-within .nav-trigger {
      color: var(--home-navy);
      background: rgba(159, 178, 119, .13);
      transform: translateY(-1px);
    }

    body.home-page .nav-panel {
      border-radius: 14px;
      border-color: rgba(86, 102, 69, .12);
      background: rgba(251, 250, 246, .97);
      box-shadow: 0 18px 44px rgba(86, 102, 69, .13), 0 1px 0 rgba(255,255,255,.92) inset;
    }

    body.home-page .nav-panel a {
      border-radius: 10px;
    }

    body.home-page .language-button {
      border-radius: 999px;
      transition: transform 180ms var(--home-ease), background-color 180ms ease, color 180ms ease, box-shadow 180ms ease;
    }

    body.home-page .language-button[aria-pressed='true'] {
      background: var(--home-navy);
      border-color: var(--home-navy);
      color: #fff;
      box-shadow: 0 10px 24px rgba(86, 102, 69, .16);
    }

    body.home-page .home-screen {
      min-height: calc(100dvh - var(--active-header-height));
      height: auto;
      overflow: visible;
    }

    body.home-page .home-hero-bg {
      position: relative;
      padding: clamp(20px, 2.8vw, 38px) 0 clamp(24px, 3.4vw, 46px);
      background: transparent;
      color: var(--home-ink);
      isolation: isolate;
    }

    body.home-page .home-hero-bg::before {
      content: '';
      position: absolute;
      inset: 0;
      z-index: -1;
      pointer-events: none;
      background:
        linear-gradient(105deg, rgba(243, 247, 236, .78), rgba(251, 250, 246, .62) 46%, rgba(241, 251, 241, .86)),
        radial-gradient(circle at 64% 0%, rgba(216, 255, 72, .26), transparent 18rem),
        radial-gradient(circle at 86% 42%, rgba(159, 178, 119, .20), transparent 24rem);
    }

    .home-shell {
      position: relative;
      z-index: 1;
      display: grid;
      grid-template-columns: minmax(220px, .82fr) minmax(440px, 1.16fr) minmax(260px, .86fr);
      grid-template-rows: auto minmax(500px, 1fr);
      gap: clamp(16px, 2vw, 28px);
      width: min(100% - 40px, 1320px);
      min-height: calc(100dvh - var(--active-header-height) - clamp(52px, 6vw, 84px));
      margin: 0 auto;
      align-items: stretch;
    }

    .home-kicker {
      grid-column: 1 / -1;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 16px;
      color: var(--home-red);
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif !important;
      font-size: .7rem;
      font-weight: 800;
      text-transform: uppercase;
    }

    .home-kicker span:first-child {
      display: inline-flex;
      align-items: center;
      gap: 12px;
    }

    .home-kicker span:first-child::before {
      content: '';
      width: 42px;
      height: 2px;
      background: var(--home-red);
    }

    .home-kicker span:last-child {
      color: rgba(86, 102, 69, .54);
    }

    .home-copy-panel {
      grid-column: 2;
      grid-row: 2;
      display: flex;
      flex-direction: column;
      justify-content: space-between;
      gap: clamp(18px, 2vw, 26px);
      padding: clamp(26px, 3.6vw, 54px);
      border: 1px solid rgba(86, 102, 69, .12);
      border-radius: 22px;
      background:
        linear-gradient(180deg, rgba(255,255,255,.84), rgba(255,255,255,.64)),
        var(--home-paper);
      box-shadow:
        0 26px 70px rgba(86, 102, 69, .13),
        0 2px 0 rgba(255,255,255,.85) inset;
    }

    .home-eyebrow {
      display: inline-flex;
      align-items: center;
      gap: .7rem;
      color: var(--home-red);
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif !important;
      font-size: .7rem;
      font-weight: 800;
      text-transform: uppercase;
    }

    .home-eyebrow::after {
      content: '';
      width: 34px;
      height: 2px;
      background: var(--home-lime);
    }

    .home-title {
      max-width: 780px;
      color: var(--home-ink);
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif !important;
      font-size: clamp(2.65rem, 5vw, 5.95rem);
      font-weight: 800;
      line-height: .96;
    }

    html[lang='ko'] .home-title {
      font-family: 'Pretendard', 'Plus Jakarta Sans', sans-serif !important;
      font-size: clamp(2.35rem, 4.2vw, 4.85rem);
      line-height: 1.04;
      word-break: keep-all;
    }

    .home-copy {
      max-width: 720px;
      color: rgba(23, 23, 23, .68);
      font-size: clamp(.95rem, 1.18vw, 1.14rem);
      line-height: 1.75;
    }

    html[lang='ko'] .home-copy {
      word-break: keep-all;
    }

    .home-chip-row {
      display: flex;
      flex-wrap: wrap;
      gap: 8px;
    }

    .home-chip-row span {
      display: inline-flex;
      align-items: center;
      min-height: 34px;
      border: 1px solid rgba(86, 102, 69, .12);
      border-radius: 999px;
      background: rgba(243, 247, 236, .78);
      padding: .45rem .72rem;
      color: rgba(86, 102, 69, .74);
      font-size: .76rem;
      font-weight: 800;
    }

    .home-chip-row span:nth-child(2) {
      background: rgba(216, 255, 72, .32);
    }

    .home-chip-row span:nth-child(3) {
      background: rgba(255, 102, 77, .12);
    }

    .home-actions {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .home-btn {
      display: inline-flex;
      min-height: 58px;
      align-items: center;
      justify-content: center;
      gap: 10px;
      border-radius: 999px;
      padding: 1rem 1.2rem;
      text-align: center;
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif !important;
      font-size: .82rem;
      font-weight: 800;
      transition: transform 200ms var(--home-ease), background-color 200ms ease, border-color 200ms ease, color 200ms ease, box-shadow 200ms ease;
    }

    .home-btn:hover,
    .home-btn:focus-visible {
      transform: translateY(-3px);
      outline: none;
    }

    .home-btn-primary {
      background: var(--home-navy);
      color: #fff;
      box-shadow: 0 18px 38px rgba(86, 102, 69, .20);
    }

    .home-btn-primary:hover,
    .home-btn-primary:focus-visible {
      background: var(--home-red);
      box-shadow: 0 20px 42px rgba(225, 42, 35, .22);
    }

    .home-btn-secondary {
      border: 1px solid rgba(86, 102, 69, .18);
      background: rgba(255, 255, 255, .62);
      color: var(--home-navy);
    }

    .home-btn-secondary:hover,
    .home-btn-secondary:focus-visible {
      border-color: rgba(86, 102, 69, .30);
      background: rgba(216, 255, 72, .34);
    }

    .home-proof-strip {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 10px;
    }

    .home-proof-strip a {
      display: grid;
      gap: 6px;
      border-top: 2px solid rgba(225, 42, 35, .72);
      border-radius: 0 0 14px 14px;
      background: rgba(86, 102, 69, .055);
      padding: 14px;
      color: var(--home-navy);
      transition: transform 190ms var(--home-ease), background-color 190ms ease, box-shadow 190ms ease;
    }

    .home-proof-strip a:hover,
    .home-proof-strip a:focus-visible {
      transform: translateY(-3px);
      background: rgba(159, 178, 119, .14);
      box-shadow: 0 16px 28px rgba(86, 102, 69, .09);
      outline: none;
    }

    .home-proof-strip strong {
      font-size: clamp(1.05rem, 1.7vw, 1.5rem);
      font-weight: 800;
    }

    .home-proof-strip span {
      color: rgba(86, 102, 69, .58);
      font-size: .72rem;
      font-weight: 800;
      text-transform: uppercase;
    }

    .home-photo-card,
    .home-mini-photo {
      position: relative;
      overflow: hidden;
      border: 1px solid rgba(86, 102, 69, .16);
      border-radius: 22px;
      background: #566645;
      box-shadow:
        0 24px 58px rgba(86, 102, 69, .18),
        0 2px 0 rgba(255,255,255,.72) inset;
    }

    .home-photo-card a,
    .home-mini-photo a {
      display: block;
      width: 100%;
      height: 100%;
      color: inherit;
    }

    .home-photo-card img,
    .home-mini-photo img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
      transform: scale(1.01);
      filter: saturate(.98) contrast(1.02);
      transition: transform 520ms var(--home-ease), filter 520ms ease;
    }

    .home-photo-card:hover img,
    .home-photo-card:focus-within img,
    .home-mini-photo:hover img,
    .home-mini-photo:focus-within img {
      transform: scale(1.045);
      filter: saturate(1.06) contrast(1.04);
    }

    .home-photo-card figcaption,
    .home-mini-photo figcaption {
      position: absolute;
      left: 16px;
      right: 16px;
      bottom: 16px;
      display: grid;
      gap: 6px;
      border: 1px solid rgba(255,255,255,.42);
      border-radius: 14px;
      background: rgba(251, 250, 246, .88);
      padding: 12px 14px;
      color: var(--home-ink);
      box-shadow: 0 16px 34px rgba(86, 102, 69, .18);
      backdrop-filter: blur(12px);
    }

    .home-photo-card figcaption span,
    .home-mini-photo figcaption span {
      color: var(--home-red);
      font-family: 'Plus Jakarta Sans', 'Pretendard', sans-serif !important;
      font-size: .64rem;
      font-weight: 800;
      text-transform: uppercase;
    }

    .home-photo-card figcaption strong,
    .home-mini-photo figcaption strong {
      color: var(--home-navy);
      font-size: .78rem;
      font-weight: 800;
      line-height: 1.45;
    }

    .home-photo-primary {
      grid-column: 1;
      grid-row: 2;
      min-height: 500px;
    }

    .home-market-stack {
      grid-column: 3;
      grid-row: 2;
      display: grid;
      grid-template-rows: minmax(145px, .72fr) minmax(165px, .88fr) auto;
      gap: clamp(12px, 1.5vw, 18px);
    }

    .home-mini-photo {
      min-height: 148px;
    }

    .home-mini-photo::after {
      content: '';
      position: absolute;
      inset: 0;
      pointer-events: none;
      background:
        linear-gradient(180deg, rgba(86, 102, 69, .02), rgba(86, 102, 69, .26)),
        radial-gradient(circle at 90% 15%, rgba(216, 255, 72, .32), transparent 7rem);
    }

    .home-system-card::after {
      background:
        linear-gradient(180deg, rgba(86, 102, 69, .06), rgba(86, 102, 69, .36)),
        radial-gradient(circle at 12% 86%, rgba(159, 178, 119, .28), transparent 8rem);
    }

    .home-route-card {
      display: grid;
      gap: 8px;
      border: 1px solid rgba(86, 102, 69, .12);
      border-radius: 22px;
      background:
        linear-gradient(135deg, rgba(255,255,255,.84), rgba(237,248,255,.72)),
        var(--home-sky-paper);
      padding: 16px;
      box-shadow: 0 18px 42px rgba(86, 102, 69, .10), 0 1px 0 rgba(255,255,255,.88) inset;
    }

    .home-route-card p {
      margin-bottom: 4px;
      color: rgba(86, 102, 69, .58);
      font-size: .72rem;
      font-weight: 800;
      text-transform: uppercase;
    }

    .home-route-card a {
      display: grid;
      grid-template-columns: 34px 1fr;
      align-items: center;
      gap: 10px;
      border: 1px solid rgba(86, 102, 69, .09);
      border-radius: 14px;
      background: rgba(255,255,255,.72);
      padding: 10px;
      color: var(--home-navy);
      transition: transform 190ms var(--home-ease), background-color 190ms ease, border-color 190ms ease, box-shadow 190ms ease;
    }

    .home-route-card a:hover,
    .home-route-card a:focus-visible {
      transform: translateX(4px);
      border-color: rgba(225, 42, 35, .18);
      background: rgba(255,255,255,.96);
      box-shadow: 0 12px 22px rgba(86, 102, 69, .09);
      outline: none;
    }

    .home-route-card a span {
      display: inline-flex;
      width: 34px;
      height: 34px;
      align-items: center;
      justify-content: center;
      border-radius: 999px;
      background: var(--home-navy);
      color: #fff;
      font-size: .72rem;
      font-weight: 800;
    }

    .home-route-card a:nth-of-type(2) span {
      background: var(--home-red);
    }

    .home-route-card a:nth-of-type(3) span {
      background: #0b80b2;
    }

    .home-route-card strong {
      min-width: 0;
      color: var(--home-navy);
      font-size: .78rem;
      font-weight: 800;
      line-height: 1.35;
    }

    @media (max-width: 1180px) {
      .home-shell {
        grid-template-columns: minmax(220px, .8fr) minmax(410px, 1.1fr);
      }

      .home-market-stack {
        grid-column: 1 / -1;
        grid-row: 3;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        grid-template-rows: none;
      }

      .home-market-stack .home-mini-photo,
      .home-route-card {
        min-height: 220px;
      }
    }

    @media (max-width: 1023px) {
      body.home-page,
      body.home-page main {
        height: auto;
        overflow-x: hidden;
        overflow-y: auto;
      }

      body.home-page .site-main-home {
        padding-top: 75px;
      }

      body.home-page .home-screen {
        min-height: auto;
        height: auto;
        overflow: visible;
      }

      .home-shell {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
        width: min(100% - 28px, 720px);
        min-height: auto;
        gap: 16px;
      }

      .home-kicker,
      .home-copy-panel,
      .home-photo-primary,
      .home-market-stack {
        grid-column: 1;
        grid-row: auto;
      }

      .home-copy-panel {
        padding: clamp(24px, 7vw, 36px);
      }

      .home-photo-primary {
        min-height: 310px;
      }

      .home-market-stack {
        grid-template-columns: 1fr;
      }

      .home-market-stack .home-mini-photo,
      .home-route-card {
        min-height: auto;
      }

      .home-mini-photo {
        height: 260px;
      }
    }

    @media (max-width: 767px) {
      body.home-page,
      body.home-page main {
        height: auto;
        overflow-x: hidden;
        overflow-y: auto;
      }

      body.home-page header > div {
        padding-top: .65rem;
        padding-bottom: .65rem;
      }

      body.home-page .brand-name {
        max-width: 46vw;
        font-size: .9rem;
      }

      body.home-page .home-hero-bg {
        padding-top: 16px;
      }

      .home-kicker {
        align-items: flex-start;
        flex-direction: column;
        gap: 8px;
      }

      .home-title {
        font-size: clamp(2.3rem, 13vw, 3.4rem);
        line-height: 1;
      }

      html[lang='ko'] .home-title {
        font-size: clamp(2rem, 10.5vw, 3rem);
      }

      .home-copy {
        font-size: .94rem;
        line-height: 1.68;
      }

      .home-actions,
      .home-proof-strip {
        grid-template-columns: 1fr;
      }

      .home-btn {
        min-height: 54px;
      }

      .home-photo-card,
      .home-mini-photo,
      .home-copy-panel,
      .home-route-card {
        border-radius: 18px;
      }

      .home-photo-card figcaption,
      .home-mini-photo figcaption {
        left: 12px;
        right: 12px;
        bottom: 12px;
      }

      .home-photo-primary {
        min-height: 280px;
      }

      .home-mini-photo {
        height: 230px;
      }
    }

    .home-mini-photo img[src*="product-screens"],
    .home-photo-card img[src*="product-screens"] {
      object-position: left top;
    }

    .product-screen-img,
    .feature-visual img[src*="product-screens"] {
      object-fit: contain !important;
      object-position: left top;
      background: #f7fbff;
    }

    .path-card-service {
      position: relative;
      display: flex;
      min-height: 310px;
      flex-direction: column;
      overflow: hidden;
      border: 1px solid rgba(86, 102, 69, .08);
      border-radius: 24px;
      background:
        linear-gradient(180deg, rgba(255,255,255,.92), rgba(246,250,255,.86)),
        #fff;
      padding: 12px;
      box-shadow: 0 18px 44px rgba(86, 102, 69, .08), 0 1px 0 rgba(255,255,255,.88) inset;
    }

    .path-card-service::after {
      content: '';
      position: absolute;
      right: 14px;
      bottom: 14px;
      width: 38px;
      height: 5px;
      border-radius: 999px;
      background: linear-gradient(90deg, #caff22, #71d7ff, #ef4436);
      opacity: .9;
    }

    .path-card-service .card-media {
      display: block;
      aspect-ratio: 1.48 / 1;
      overflow: hidden;
      border: 1px solid rgba(86, 102, 69, .08);
      border-radius: 18px;
      background: #edf5ff;
    }

    .path-card-service .card-media img {
      display: block;
      width: 100%;
      height: 100%;
      object-fit: cover;
      object-position: center;
      transform: scale(1.01);
    }

    .path-card-service.path-card-screen .card-media img {
      object-position: left top;
    }

    .path-card-service .card-top {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      margin-top: 14px;
    }

    .path-card-service .card-code {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-width: 34px;
      height: 30px;
      border-radius: 999px;
      background: #293129;
      color: #fff;
      font-size: 11px;
      font-weight: 800;
    }

    .path-card-service .material-symbols-outlined {
      display: inline-flex;
      width: 38px;
      height: 38px;
      align-items: center;
      justify-content: center;
      border-radius: 14px;
      background: rgba(202, 255, 34, .32);
      color: #293129;
      font-size: 20px;
    }

    .path-card-service h3 {
      margin-top: 14px;
      min-height: 2.55em;
      color: #293129;
      font-family: var(--globos-font-display, 'Plus Jakarta Sans', 'Pretendard', sans-serif);
      font-size: 1.22rem;
      font-weight: 800;
      line-height: 1.16;
    }

    .path-card-service p {
      margin-top: 10px;
      color: rgba(86, 102, 69, .66);
      font-size: .82rem;
      font-weight: 600;
      line-height: 1.48;
    }

    .path-card-service:hover,
    .path-card-service:focus-visible {
      border-color: rgba(239, 68, 54, .18);
      background: #fff;
      box-shadow: 0 26px 60px rgba(86, 102, 69, .13), 0 1px 0 rgba(255,255,255,.9) inset;
    }

    .product-system-strip figure {
      position: relative;
      overflow: hidden;
      border: 1px solid rgba(86, 102, 69, .08);
      border-radius: 24px;
      background: #f7fbff;
      padding: 10px;
      box-shadow: 0 18px 44px rgba(86, 102, 69, .08);
    }

    .product-system-strip img {
      display: block;
      width: 100%;
      aspect-ratio: 16 / 10;
      border-radius: 16px;
      object-fit: cover;
      object-position: left top;
    }

    .product-system-strip figcaption {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
      padding: 14px 6px 4px;
    }

    .product-system-strip span {
      display: inline-flex;
      border-radius: 999px;
      background: rgba(202, 255, 34, .44);
      padding: 6px 10px;
      color: #293129;
      font-size: 11px;
      font-weight: 800;
      text-transform: uppercase;
    }

    .product-system-strip strong {
      color: #293129;
      font-size: .92rem;
      font-weight: 800;
      text-align: right;
    }

    #proof .relative.overflow-hidden.rounded-sm.border,
    .feature-visual {
      border-radius: 26px;
      border-color: rgba(86, 102, 69, .1);
      background:
        linear-gradient(135deg, rgba(202,255,34,.16), rgba(113,215,255,.14)),
        #f7fbff;
      box-shadow: 0 22px 56px rgba(86, 102, 69, .11);
    }

    #leadership .leader-strip {
      gap: 12px;
      background: transparent;
    }

    #leadership .leader-strip > div {
      position: relative;
      overflow: hidden;
      border: 1px solid rgba(86, 102, 69, .08);
      border-radius: 22px;
      background:
        linear-gradient(135deg, #293129 0%, #6f8056 72%),
        #293129;
      box-shadow: 0 18px 42px rgba(86, 102, 69, .12);
    }

    #leadership .leader-strip > div :where(p, span, strong, .font-headline) {
      color: rgba(255, 255, 255, .92) !important;
    }

    #leadership .leader-strip > div::after {
      content: '';
      position: absolute;
      right: 18px;
      bottom: 18px;
      width: 42px;
      height: 6px;
      border-radius: 999px;
      background: linear-gradient(90deg, #caff22, #71d7ff, #ef4436);
    }

    #leadership .pipeline-stage {
      border-radius: 28px;
      background:
        radial-gradient(circle at 18% 12%, rgba(202,255,34,.16), transparent 26%),
        radial-gradient(circle at 78% 22%, rgba(113,215,255,.12), transparent 28%),
        #293129;
    }

    #leadership .pipeline-lanes,
    #leadership .executive-row {
      gap: 12px;
      background: transparent;
    }

    #leadership .pipeline-lane,
    #leadership .executive-card {
      border: 1px solid rgba(255,255,255,.12);
      border-radius: 22px;
      background: rgba(255,255,255,.08);
    }

    @media (max-width: 767px) {
      .path-card-service {
        min-height: 270px;
        border-radius: 20px;
      }

      .path-card-service .card-media {
        border-radius: 16px;
      }

      .path-card-service h3 {
        min-height: 0;
        font-size: 1.06rem;
      }

      .product-system-strip figure {
        border-radius: 20px;
      }

      .product-system-strip figcaption {
        align-items: flex-start;
        flex-direction: column;
      }

      .product-system-strip strong {
        text-align: left;
      }
    }

    /* GLOBOS HOLDINGS production design standard */
    :root {
      --gh-bg: #fbfaf6;
      --gh-bg-cool: #f3f7ec;
      --gh-surface: #ffffff;
      --gh-ink: #14171f;
      --gh-navy: #566645;
      --gh-muted: #687282;
      --gh-line: rgba(86, 102, 69, 0.13);
      --gh-red: #ed2d25;
      --gh-coral: #ff664d;
      --gh-sky: #9fb277;
      --gh-lime: #d8ff48;
      --gh-shadow: 0 24px 64px rgba(86, 102, 69, 0.12);
      --active-header-height: 96px;
      --globos-font-display: 'Plus Jakarta Sans', 'Pretendard', sans-serif;
      --globos-font-body: 'Plus Jakarta Sans', 'Pretendard', sans-serif;
      --globos-font-korean: 'Pretendard', 'Plus Jakarta Sans', sans-serif;
      --home-paper: var(--gh-bg);
      --home-sky-paper: var(--gh-bg-cool);
      --home-ink: var(--gh-ink);
      --home-muted: var(--gh-muted);
      --home-navy: var(--gh-navy);
      --home-red: var(--gh-red);
      --home-lime: var(--gh-lime);
      --home-sky: var(--gh-sky);
      --home-coral: var(--gh-coral);
      --home-line: var(--gh-line);
    }

    html {
      background: var(--gh-bg);
    }

    body,
    .font-body,
    .font-headline,
    .font-label,
    input,
    textarea,
    select,
    button {
      font-family: var(--globos-font-body) !important;
      letter-spacing: 0 !important;
    }

    body {
      min-height: 100dvh;
      overflow-x: hidden;
      background:
        radial-gradient(circle at 82% 8%, rgba(216, 255, 72, .22), transparent 18rem),
        radial-gradient(circle at 8% 30%, rgba(159, 178, 119, .18), transparent 24rem),
        radial-gradient(circle at 92% 72%, rgba(255, 102, 77, .10), transparent 22rem),
        var(--gh-bg) !important;
      color: var(--gh-ink) !important;
      font-size: 16px;
      line-height: 1.62;
    }

    body.home-page,
    body.home-page main,
    body.home-page .site-main-home {
      height: auto !important;
      overflow: visible !important;
    }

    body.home-page {
      overflow-x: hidden !important;
      overflow-y: auto !important;
    }

    body.home-page main > section:not(.home-screen),
    body.home-page > footer {
      display: block !important;
    }

    body.home-page #growth-bg {
      display: none !important;
    }

    body::before {
      background-image:
        linear-gradient(rgba(86, 102, 69, .04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(86, 102, 69, .04) 1px, transparent 1px);
      background-size: 92px 92px;
    }

    header.fixed,
    body.home-page header,
    nav.fixed {
      border-bottom: 1px solid var(--gh-line) !important;
      background: rgba(255, 255, 255, .86) !important;
      box-shadow: 0 18px 46px rgba(86, 102, 69, .08) !important;
      backdrop-filter: blur(20px);
    }

    .brand-name {
      display: inline-flex !important;
      align-items: center;
      gap: .68rem;
      color: var(--gh-navy) !important;
      font-family: var(--globos-font-display) !important;
      font-weight: 800 !important;
      text-transform: uppercase;
    }

    .nav-trigger,
    header a:not(.brand-name),
    nav a:not(.brand-name),
    .language-button {
      color: rgba(86, 102, 69, .72) !important;
      font-weight: 750 !important;
    }

    .nav-trigger:hover,
    .nav-trigger:focus-visible,
    .nav-group:focus-within .nav-trigger,
    header a:not(.brand-name):hover,
    nav a:not(.brand-name):hover {
      color: var(--gh-red) !important;
      background: rgba(216, 255, 72, .24) !important;
    }

    .nav-panel,
    .mobile-nav-panel {
      border: 1px solid var(--gh-line) !important;
      border-radius: 18px !important;
      background: rgba(255, 255, 255, .96) !important;
      box-shadow: var(--gh-shadow) !important;
    }

    .section-label,
    .home-eyebrow,
    .home-kicker,
    .brief-label,
    .text-brass,
    .text-cobalt,
    .text-accent {
      color: var(--gh-red) !important;
    }

    .section-label::before {
      width: 32px;
      height: 5px;
      border-radius: 999px;
      background: linear-gradient(90deg, var(--gh-lime), var(--gh-sky), var(--gh-coral)) !important;
    }

    .text-ink,
    .text-primary,
    .text-on-surface,
    h1,
    h2,
    h3,
    h4 {
      color: var(--gh-ink) !important;
    }

    .text-slatecopy,
    .text-secondary,
    .text-on-surface-variant,
    main p,
    main li {
      color: var(--gh-muted) !important;
    }

    .bg-fog,
    .bg-surface,
    .bg-surface-container-low,
    .bg-surface-container,
    .bg-surface-container-high,
    .bg-surface-container-highest {
      background: rgba(255, 255, 255, .64) !important;
    }

    .bg-navy,
    .bg-primary,
    .bg-primary-container {
      background: var(--gh-navy) !important;
    }

    .bg-brass,
    .bg-secondary-fixed,
    .bg-tertiary-fixed-dim {
      background: var(--gh-lime) !important;
      color: var(--gh-navy) !important;
    }

    .border-line,
    .border-outline-variant,
    .border-outline-variant\/20,
    .border-outline-variant\/30,
    .border-outline-variant\/50 {
      border-color: var(--gh-line) !important;
    }

    .primary-action,
    .home-btn-primary,
    .hover-lift.inline-flex.bg-navy,
    form button[type='submit'],
    a[href*='contact'].bg-navy,
    a[href*='contact'].bg-primary {
      border-radius: 999px !important;
      background: var(--gh-navy) !important;
      color: #fff !important;
      box-shadow: 0 16px 34px rgba(86, 102, 69, .18);
    }

    .primary-action:hover,
    .primary-action:focus-visible,
    .home-btn-primary:hover,
    .home-btn-primary:focus-visible,
    form button[type='submit']:hover,
    form button[type='submit']:focus-visible {
      background: var(--gh-red) !important;
      transform: translateY(-2px);
    }

    .secondary-action,
    .home-btn-secondary,
    .hover-lift.inline-flex.border,
    .language-button {
      border-radius: 999px !important;
      border-color: var(--gh-line) !important;
      background: rgba(255, 255, 255, .78) !important;
      color: var(--gh-navy) !important;
    }

    .home-screen,
    .home-hero-bg {
      min-height: calc(100dvh - var(--active-header-height));
      background: transparent !important;
    }

    .home-copy-panel,
    .home-route-card,
    .path-card,
    .brief-panel,
    .locale-card,
    form,
    details,
    .feature-visual,
    .system-console,
    .partner-stage,
    .friction-stage,
    .product-system-strip figure,
    .relative.h-\[650px\],
    .bg-white.p-10,
    .bg-white.p-12,
    .bg-white.p-5,
    .border.bg-white,
    .rounded-sm.bg-white {
      border-color: var(--gh-line) !important;
      border-radius: 24px !important;
      background: rgba(255, 255, 255, .82) !important;
      box-shadow: var(--gh-shadow) !important;
    }

    .path-card-service {
      min-height: 320px;
      border-color: var(--gh-line) !important;
      border-radius: 24px !important;
      background:
        linear-gradient(180deg, rgba(255,255,255,.95), rgba(237,248,255,.62)),
        var(--gh-surface) !important;
      box-shadow: 0 20px 52px rgba(86, 102, 69, .10) !important;
    }

    .path-card-service::after,
    #leadership .leader-strip > div::after {
      background: linear-gradient(90deg, var(--gh-lime), var(--gh-sky), var(--gh-coral)) !important;
    }

    .path-card-service .card-media,
    .home-photo-card,
    .home-mini-photo,
    .feature-visual {
      border-radius: 22px !important;
      background: var(--gh-bg-cool) !important;
    }

    img[src*='product-screens'] {
      filter: saturate(1.04) contrast(1.02);
    }

    .path-card-service .card-media img,
    .feature-visual img,
    .product-system-strip img,
    .home-photo-card img,
    .home-mini-photo img,
    img[src*='product-screens'] {
      object-position: left top;
    }

    .feature-visual img,
    .path-card-service .card-media img[src*='product-screens'],
    .product-system-strip img[src*='product-screens'],
    .feature-visual img[src*='product-screens'] {
      object-fit: contain !important;
      background: var(--gh-bg-cool);
    }

    .home-photo-card img[src*='product-screens'],
    .home-mini-photo img[src*='product-screens'],
    .relative.h-\[650px\] img[src*='product-screens'],
    .aspect-\[4\/5\] img[src*='product-screens'] {
      object-fit: cover !important;
      object-position: center top;
      background: var(--gh-bg-cool);
    }

    .dark-section,
    .brief-stage,
    #leadership .pipeline-stage,
    #leadership .leader-strip > div,
    footer,
    .system-console {
      background:
        radial-gradient(circle at 12% 14%, rgba(216, 255, 72, .18), transparent 20rem),
        radial-gradient(circle at 82% 20%, rgba(159, 178, 119, .12), transparent 22rem),
        var(--gh-navy) !important;
      color: #fff !important;
    }

    .dark-section *,
    .brief-stage *,
    footer * {
      color: inherit;
    }

    .dark-section :where(h1, h2, h3, h4, a, strong, .text-ink, .text-primary, .font-headline),
    .brief-stage :where(h1, h2, h3, h4, a, strong, .text-ink, .text-primary, .font-headline),
    footer :where(h1, h2, h3, h4, a, strong, .text-ink, .text-primary, .font-headline) {
      color: #fff !important;
    }

    [class*="bg-[#293129]"] :where(h1, h2, h3, h4, p, span, a, strong),
    [class*="bg-primary"] :where(h1, h2, h3, h4, p, span, a, strong) {
      color: #fff !important;
    }

    [class*="bg-[#293129]"] .text-brass,
    [class*="bg-primary"] .text-brass {
      color: var(--gh-lime) !important;
    }

    .dark-section p,
    .brief-stage p,
    .brief-stage li,
    footer p,
    footer li {
      color: rgba(255, 255, 255, .70) !important;
    }

    .brief-panel,
    .brief-console article,
    .friction-card,
    .partner-process-item,
    .partner-proof-row > div {
      border-color: rgba(255, 255, 255, .16) !important;
      background: rgba(255, 255, 255, .08) !important;
      box-shadow: none !important;
    }

    input,
    textarea,
    select {
      border-color: var(--gh-line) !important;
      color: var(--gh-ink) !important;
    }

    input:focus,
    textarea:focus,
    select:focus {
      border-color: var(--gh-red) !important;
      box-shadow: 0 10px 30px rgba(237, 45, 37, .08) !important;
    }

    .material-symbols-outlined {
      color: currentColor;
    }

    @media (max-width: 767px) {
      :root {
        --active-header-height: 86px;
      }

      body {
        font-size: 16px;
      }

      .home-screen {
        min-height: auto;
      }

      .path-card-service,
      .home-copy-panel,
      .home-route-card,
      .feature-visual,
      form {
        border-radius: 20px !important;
      }
    }

    body.contact-page main.pt-40 {
      padding-top: clamp(7rem, 10vw, 9rem) !important;
    }

    body.contact-page main > section:first-child {
      display: block !important;
      min-height: auto !important;
      margin-bottom: clamp(5rem, 7vw, 7rem) !important;
    }

    body.contact-page main > section:not(.home-screen) {
      display: block !important;
      min-height: auto !important;
    }

    body.contact-page main > section:first-child .editorial-grid {
      align-items: center;
    }

    body.contact-page main > section:first-child .aspect-\[4\/5\] {
      aspect-ratio: 16 / 10 !important;
      border-radius: 28px;
      border: 1px solid var(--gh-line);
      background: var(--gh-bg-cool);
      box-shadow: var(--gh-shadow);
    }

    body.contact-page main > section:first-child .aspect-\[4\/5\] img {
      object-fit: cover !important;
      object-position: center top;
    }

    body:not(.home-page) main.pt-\[73px\] > section:first-child > .mx-auto.grid {
      min-height: auto !important;
      padding-top: clamp(5rem, 8vw, 7rem) !important;
      padding-bottom: clamp(5rem, 8vw, 7rem) !important;
    }

    @media (max-width: 767px) {
      body.contact-page main.pt-40 {
        padding-top: 6rem !important;
      }

      body.contact-page main > section:first-child {
        margin-bottom: 4rem !important;
      }
    }

/* 2026-06 product-screen-only redesign layer.
   This is the top design source: real POS / ERP / delivery app screens, no legacy photo mood. */
:root {
  --ps-bg: #ffffff;
  --ps-bg-cool: #f5f9fd;
  --ps-panel: rgba(255, 255, 255, .92);
  --ps-ink: #293129;
  --ps-muted: #607086;
  --ps-line: #dce5ee;
  --ps-navy: #526146;
  --ps-lime: #c9ff25;
  --ps-sky: #9fb277;
  --ps-coral: #ed3d32;
  --ps-radius: 24px;
  --ps-shadow: 0 26px 70px rgba(41, 49, 41, .10), 0 1px 0 rgba(255,255,255,.9) inset;
}

html,
body {
  background:
    radial-gradient(circle at 74% 10%, rgba(201, 255, 37, .16), transparent 22rem),
    linear-gradient(180deg, #fff 0%, #f7fbff 48%, #fff 100%) !important;
  color: var(--ps-ink) !important;
}

main > section {
  background-color: transparent !important;
}

body.home-page .home-kicker,
.home-eyebrow {
  display: none !important;
}

body.home-page .site-main-home {
  padding-top: var(--active-header-height) !important;
}

.home-screen {
  min-height: calc(100dvh - var(--active-header-height)) !important;
  display: flex;
  align-items: center;
  padding: clamp(28px, 4vw, 56px) 0;
}

.home-shell {
  width: min(100% - 40px, 1260px) !important;
  min-height: auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, .88fr) minmax(0, 1.12fr) !important;
  grid-template-rows: auto auto !important;
  gap: clamp(18px, 2.6vw, 34px) !important;
  align-items: center !important;
}

.home-copy-panel {
  grid-column: 1 !important;
  grid-row: 1 / span 2 !important;
  display: block !important;
  max-width: 590px;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.home-title {
  max-width: 9.5em;
  color: var(--ps-ink) !important;
  font-size: clamp(3.6rem, 6vw, 6.15rem) !important;
  line-height: .96 !important;
  letter-spacing: 0 !important;
}

html[lang='ko'] .home-title {
  max-width: 8.8em;
  font-size: clamp(3.1rem, 5.25vw, 5.45rem) !important;
  line-height: 1.02 !important;
}

.home-copy {
  max-width: 34rem;
  margin-top: clamp(22px, 2.4vw, 32px);
  color: var(--ps-muted) !important;
  font-size: 1.02rem !important;
  line-height: 1.85 !important;
}

.home-chip-row {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 34rem;
  margin-top: clamp(22px, 2vw, 30px);
  gap: 14px !important;
}

.home-chip-row span {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--ps-ink) !important;
  font-size: .86rem !important;
  font-weight: 800 !important;
  line-height: 1.35;
}

.home-chip-row span::before {
  content: '';
  display: block;
  width: 28px;
  height: 28px;
  margin-bottom: 10px;
  border: 1px solid var(--ps-line);
  border-radius: 9px;
  background: linear-gradient(135deg, rgba(201,255,37,.45), rgba(88,200,242,.28));
}

.home-chip-row span:nth-child(n+4) {
  display: none !important;
}

.home-actions {
  max-width: 34rem;
  margin-top: clamp(26px, 2.8vw, 40px);
}

.home-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  max-width: 36rem;
  margin-top: clamp(22px, 2.3vw, 32px);
  border-top: 1px solid var(--ps-line);
  border-bottom: 1px solid var(--ps-line);
}

.home-proof-grid a {
  display: grid;
  gap: 8px;
  min-height: 96px;
  padding: 16px 16px 16px 0;
  color: var(--ps-ink);
}

.home-proof-grid a + a {
  border-left: 1px solid var(--ps-line);
  padding-left: 16px;
}

.home-proof-grid span {
  color: var(--ps-coral);
  font-size: .68rem;
  font-weight: 800;
  line-height: 1.2;
  text-transform: uppercase;
}

.home-proof-grid strong {
  color: var(--ps-ink);
  font-size: .9rem;
  font-weight: 800;
  line-height: 1.35;
}

.home-entry-routes {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: 36rem;
  margin-top: 16px;
  gap: 10px;
}

.home-entry-routes a {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: 5px 10px;
  min-height: 94px;
  align-items: start;
  border: 1px solid rgba(82, 97, 70, .14);
  border-radius: 14px;
  background: rgba(255, 255, 255, .72);
  padding: 13px;
  color: var(--ps-ink);
  box-shadow: 0 12px 28px rgba(41, 49, 41, .055);
  transition: transform 190ms cubic-bezier(0.16, 1, 0.3, 1), border-color 190ms ease, background-color 190ms ease, box-shadow 190ms ease;
}

.home-entry-routes a:hover,
.home-entry-routes a:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(237, 61, 50, .26);
  background: #fff;
  box-shadow: 0 18px 36px rgba(41, 49, 41, .09);
  outline: none;
}

.home-entry-routes span {
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: var(--ps-navy);
  color: #fff;
  font-size: .75rem;
  font-weight: 800;
}

.home-entry-routes a:nth-child(2) span {
  background: var(--ps-coral);
}

.home-entry-routes a:nth-child(3) span {
  background: #0b80b2;
}

.home-entry-routes a:nth-child(4) span {
  background: #74865f;
}

.home-entry-routes strong {
  min-width: 0;
  color: var(--ps-ink);
  font-size: .88rem;
  font-weight: 800;
  line-height: 1.25;
}

.home-entry-routes em {
  min-width: 0;
  color: var(--ps-muted);
  font-size: .76rem;
  font-style: normal;
  font-weight: 700;
  line-height: 1.35;
}

.home-btn {
  min-height: 62px;
  border-radius: 10px !important;
  font-size: .95rem !important;
}

.home-proof-strip {
  max-width: 34rem;
  margin-top: clamp(30px, 3vw, 46px);
  border-top: 1px solid var(--ps-line);
  background: transparent !important;
  box-shadow: none !important;
}

.home-proof-strip a {
  border: 0 !important;
  border-right: 1px solid var(--ps-line) !important;
  border-radius: 0 !important;
  background: transparent !important;
  padding: 22px 22px 0 0 !important;
}

.home-proof-strip a:last-child {
  border-right: 0 !important;
  padding-left: 22px !important;
}

.home-proof-strip strong {
  color: var(--ps-ink) !important;
  font-size: clamp(2rem, 3vw, 3rem) !important;
}

.home-photo-primary {
  grid-column: 2 !important;
  grid-row: 1 !important;
  min-height: clamp(380px, 44vw, 560px) !important;
  border: 0 !important;
  border-radius: 28px !important;
  background: transparent !important;
  box-shadow: none !important;
  overflow: visible !important;
}

.home-photo-primary a {
  overflow: visible !important;
  border-radius: 28px !important;
}

.home-photo-primary img {
  object-fit: contain !important;
  object-position: center !important;
  filter: drop-shadow(0 34px 54px rgba(41, 49, 41, .16)) saturate(1.02) !important;
}

.home-photo-primary figcaption {
  left: clamp(16px, 2vw, 28px) !important;
  right: auto !important;
  bottom: clamp(12px, 2vw, 24px) !important;
  width: min(420px, 72%);
  border: 1px solid rgba(255,255,255,.72) !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.84) !important;
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 44px rgba(41, 49, 41, .12) !important;
}

.home-market-stack {
  grid-column: 2 !important;
  grid-row: 2 !important;
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.home-mini-photo,
.home-route-card {
  min-height: 190px !important;
  height: auto !important;
  border: 1px solid var(--ps-line) !important;
  border-radius: 20px !important;
  background: var(--ps-panel) !important;
  box-shadow: 0 16px 46px rgba(41, 49, 41, .08) !important;
}

.home-mini-photo img {
  object-fit: contain !important;
  object-position: center top !important;
  padding: 10px;
}

.home-mini-photo figcaption {
  left: 10px !important;
  right: 10px !important;
  bottom: 10px !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.82) !important;
  padding: 12px !important;
}

.home-route-card {
  padding: 16px !important;
}

.home-route-card p {
  color: var(--ps-muted) !important;
}

.home-route-card a {
  border-radius: 12px !important;
  background: #fff !important;
}

#capabilities {
  padding-top: clamp(56px, 7vw, 96px) !important;
  padding-bottom: clamp(56px, 7vw, 96px) !important;
}

#capabilities .route-radar {
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--ps-ink) !important;
  padding: 0 0 clamp(24px, 3vw, 38px) 0 !important;
}

#capabilities .route-radar::before {
  display: none !important;
}

#capabilities .route-radar > div {
  grid-template-columns: minmax(260px, .42fr) minmax(0, .58fr) auto !important;
  align-items: end !important;
}

#capabilities .route-radar p,
#capabilities .route-radar h2 {
  color: var(--ps-ink) !important;
}

#capabilities .route-radar p[data-i18n='services.body'] {
  color: var(--ps-muted) !important;
  font-size: .95rem !important;
  line-height: 1.7 !important;
}

#capabilities .route-radar + .grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 0 !important;
  overflow: hidden;
  border: 1px solid var(--ps-line);
  border-radius: var(--ps-radius);
  background: #fff;
  box-shadow: var(--ps-shadow);
}

.path-card-service {
  min-height: 150px !important;
  display: grid !important;
  grid-template-columns: 76px minmax(0, 1fr) minmax(250px, .36fr) 46px !important;
  align-items: center !important;
  gap: clamp(18px, 2.4vw, 34px) !important;
  border: 0 !important;
  border-bottom: 1px solid var(--ps-line) !important;
  border-radius: 0 !important;
  background: #fff !important;
  box-shadow: none !important;
  padding: 22px clamp(18px, 2.4vw, 34px) !important;
}

.path-card-service:last-child {
  border-bottom: 0 !important;
}

.path-card-service::after {
  content: 'arrow_forward' !important;
  position: static !important;
  width: 46px !important;
  height: 46px !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 999px !important;
  background: transparent !important;
  color: var(--ps-navy) !important;
  font-family: 'Material Symbols Outlined' !important;
  font-size: 26px;
}

.path-card-service .card-media {
  grid-column: 3;
  grid-row: 1 / span 3;
  width: 100%;
  aspect-ratio: 16 / 7.4 !important;
  border-radius: 14px !important;
  background: var(--ps-bg-cool) !important;
}

.path-card-service .card-media img {
  object-fit: contain !important;
  object-position: center !important;
  padding: 8px;
}

.path-card-service .card-top {
  grid-column: 1;
  grid-row: 1 / span 3;
  display: flex !important;
  flex-direction: column;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  margin: 0 !important;
}

.path-card-service .card-code {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  background: var(--ps-navy) !important;
}

.path-card-service .material-symbols-outlined {
  width: 42px !important;
  height: 42px !important;
  border-radius: 12px !important;
  background: rgba(201,255,37,.42) !important;
}

.path-card-service h3 {
  grid-column: 2;
  grid-row: 1;
  min-height: 0 !important;
  margin: 0 !important;
  font-size: clamp(1.18rem, 1.8vw, 1.7rem) !important;
}

.path-card-service p {
  grid-column: 2;
  grid-row: 2;
  margin: 8px 0 0 !important;
  font-size: .96rem !important;
  line-height: 1.7 !important;
}

.feature-visual,
.product-system-strip figure,
body:not(.home-page) main.pt-\[73px\] > section:first-child .relative.overflow-hidden.rounded-sm.border {
  border: 1px solid var(--ps-line) !important;
  border-radius: 28px !important;
  background: var(--ps-bg-cool) !important;
  box-shadow: var(--ps-shadow) !important;
}

.feature-visual img,
.product-system-strip img,
body:not(.home-page) main.pt-\[73px\] > section:first-child img[src*='product-screens'] {
  object-fit: contain !important;
  object-position: center !important;
  padding: 12px;
}

.brief-stage {
  background: var(--ps-navy) !important;
}

@media (max-width: 1023px) {
  .home-shell {
    grid-template-columns: 1fr !important;
    width: min(100% - 28px, 760px) !important;
  }

  .home-copy-panel,
  .home-photo-primary,
  .home-market-stack {
    grid-column: 1 !important;
    grid-row: auto !important;
  }

  .home-copy-panel {
    max-width: none;
  }

  .home-photo-primary {
    min-height: 360px !important;
  }

  .home-market-stack {
    grid-template-columns: 1fr !important;
  }

  #capabilities .route-radar > div {
    grid-template-columns: 1fr !important;
  }

  .path-card-service {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    gap: 16px !important;
  }

  .path-card-service::after {
    display: none !important;
  }

  .path-card-service .card-media {
    grid-column: 1 / -1;
    grid-row: 1;
    aspect-ratio: 16 / 8.6 !important;
  }

  .path-card-service .card-top {
    grid-column: 1;
    grid-row: 2 / span 2;
  }

  .path-card-service h3 {
    grid-column: 2;
    grid-row: 2;
  }

  .path-card-service p {
    grid-column: 2;
    grid-row: 3;
  }
}

@media (max-width: 767px) {
  .home-screen {
    padding: 30px 0 44px;
  }

  .home-title,
  html[lang='ko'] .home-title {
    max-width: 100%;
    font-size: clamp(2.9rem, 14vw, 4rem) !important;
  }

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

  .home-actions,
  .home-proof-strip,
  .home-proof-grid,
  .home-entry-routes {
    grid-template-columns: 1fr !important;
  }

  .home-proof-grid a + a {
    border-left: 0;
    border-top: 1px solid var(--ps-line);
    padding-left: 0;
  }

  .home-proof-strip a {
    border-right: 0 !important;
    padding-left: 0 !important;
  }

  .home-photo-primary {
    min-height: 300px !important;
  }

  .home-photo-primary figcaption {
    width: auto;
  }
}

/* Final contrast and product-screen-only lock.
   Keep this last: it overrides legacy report-style and dark-section color drift. */
#leadership .pipeline-stage,
main > section.bg-\[\#293129\],
main > section[class*="bg-[#293129]"],
.brief-stage,
footer {
  background:
    radial-gradient(circle at 12% 14%, rgba(201, 255, 37, .17), transparent 20rem),
    radial-gradient(circle at 82% 20%, rgba(159, 178, 119, .13), transparent 22rem),
    var(--ps-navy) !important;
  color: #fff !important;
}

#leadership .pipeline-stage :where(h1, h2, h3, h4, strong, a, .font-headline),
main > section.bg-\[\#293129\] :where(h1, h2, h3, h4, strong, a, .font-headline),
main > section[class*="bg-[#293129]"] :where(h1, h2, h3, h4, strong, a, .font-headline),
.brief-stage :where(h1, h2, h3, h4, strong, a, .font-headline),
footer :where(h1, h2, h3, h4, strong, a, .font-headline, .brand-name) {
  color: #fff !important;
}

#leadership .pipeline-stage :where(p, li):not(.pipeline-lane-index),
main > section.bg-\[\#293129\] :where(p, li, span):not(.material-symbols-outlined):not(.text-brass),
main > section[class*="bg-[#293129]"] :where(p, li, span):not(.material-symbols-outlined):not(.text-brass),
.brief-stage :where(p, li):not(.brief-label),
footer :where(p, li, span) {
  color: rgba(255, 255, 255, .72) !important;
}

#leadership .pipeline-stage .pipeline-lane-index,
#leadership .pipeline-stage .owner-pill,
.brief-stage .brief-label,
.brief-stage .text-brass,
main > section.bg-\[\#293129\] .text-brass,
main > section[class*="bg-[#293129]"] .text-brass {
  color: var(--ps-lime) !important;
}

#leadership .pipeline-stage .pipeline-lanes,
#leadership .pipeline-stage .executive-row {
  background: transparent !important;
}

#leadership .pipeline-stage .pipeline-lane,
#leadership .pipeline-stage .executive-card,
main > section.bg-\[\#293129\] .group,
main > section[class*="bg-[#293129]"] .group,
.brief-stage .brief-panel {
  border: 1px solid rgba(255, 255, 255, .16) !important;
  background: rgba(255, 255, 255, .08) !important;
  box-shadow: none !important;
}

main > section.bg-\[\#293129\] .group:hover,
main > section.bg-\[\#293129\] .group:focus-visible,
main > section[class*="bg-[#293129]"] .group:hover,
main > section[class*="bg-[#293129]"] .group:focus-visible {
  background: #fff !important;
  color: var(--ps-ink) !important;
}

main > section.bg-\[\#293129\] .group:hover :where(h1, h2, h3, h4, strong, span, .material-symbols-outlined),
main > section.bg-\[\#293129\] .group:focus-visible :where(h1, h2, h3, h4, strong, span, .material-symbols-outlined),
main > section[class*="bg-[#293129]"] .group:hover :where(h1, h2, h3, h4, strong, span, .material-symbols-outlined),
main > section[class*="bg-[#293129]"] .group:focus-visible :where(h1, h2, h3, h4, strong, span, .material-symbols-outlined) {
  color: var(--ps-ink) !important;
}

footer .brand-name,
footer a.brand-name {
  color: #fff !important;
}

/* Brand-operation imagery lock.
   These generated visuals are photos/brand scenes, not product screenshots. */
img[src*='brand-operations'],
img[src*='assets/images/homepage/home-'] {
  object-fit: cover !important;
  object-position: center !important;
  padding: 0 !important;
  background: #fff !important;
  filter: saturate(1.03) contrast(1.01) !important;
}

.home-photo-primary img[src*='brand-operations'],
.home-photo-primary img[src*='assets/images/homepage/home-'] {
  object-fit: cover !important;
  filter: saturate(1.03) contrast(1.01) drop-shadow(0 34px 54px rgba(41, 49, 41, .12)) !important;
}

.home-mini-photo img[src*='brand-operations'],
.home-mini-photo img[src*='assets/images/homepage/home-'],
.home-photo-card img[src*='brand-operations'],
.home-photo-card img[src*='assets/images/homepage/home-'],
.feature-visual img[src*='brand-operations'],
.feature-visual img[src*='assets/images/homepage/home-'],
.path-card-service .card-media img[src*='brand-operations'],
.path-card-service .card-media img[src*='assets/images/homepage/home-'],
body:not(.home-page) main.pt-\[73px\] > section:first-child img[src*='brand-operations'],
body:not(.home-page) main.pt-\[73px\] > section:first-child img[src*='assets/images/homepage/home-'] {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  padding: 0 !important;
}

.path-card-service .card-media:has(img[src*='brand-operations']),
.path-card-service .card-media:has(img[src*='assets/images/homepage/home-']),
.feature-visual:has(img[src*='brand-operations']),
.feature-visual:has(img[src*='assets/images/homepage/home-']),
.home-photo-card:has(img[src*='brand-operations']),
.home-photo-card:has(img[src*='assets/images/homepage/home-']),
.home-mini-photo:has(img[src*='brand-operations']),
.home-mini-photo:has(img[src*='assets/images/homepage/home-']) {
  background: #fff !important;
}

/* Home visual cleanup: no text overlays, no operations/system proof block. */
body.home-page .home-chip-row {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

body.home-page .home-proof-strip {
  display: none !important;
}

body.home-page .home-photo-primary {
  aspect-ratio: 3 / 2;
  min-height: 0 !important;
  overflow: hidden !important;
}

body.home-page .home-photo-primary a {
  height: 100% !important;
}

body.home-page .home-photo-card figcaption,
body.home-page .home-mini-photo figcaption,
body.home-page .home-mini-photo::after {
  display: none !important;
}

body.home-page .home-market-stack {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-template-rows: none !important;
}

body.home-page .home-market-stack .home-mini-photo {
  min-height: 220px !important;
}

@media (max-width: 1023px) {
  body.home-page .home-chip-row {
    grid-template-columns: 1fr !important;
  }

  body.home-page .home-market-stack {
    grid-template-columns: 1fr !important;
  }
}

/* Unified subpage design layer: align generated and static pages with the photo-led home screen. */
:root {
  --globos-font-display: 'Plus Jakarta Sans', 'Pretendard', sans-serif;
  --globos-font-body: 'Plus Jakarta Sans', 'Pretendard', sans-serif;
  --globos-font-korean: 'Pretendard', 'Plus Jakarta Sans', sans-serif;
  --gh-bg: #fbfcfd;
  --gh-bg-cool: #f3f7ec;
  --gh-ink: #293129;
  --gh-navy: #566645;
  --gh-muted: #687282;
  --gh-line: rgba(86, 102, 69, .14);
  --gh-lime: #d8ff48;
  --gh-coral: #ff5a4f;
  --gh-shadow: 0 28px 74px rgba(86, 102, 69, .13);
  --gh-soft-shadow: 0 16px 42px rgba(86, 102, 69, .09);
  --gh-ease: cubic-bezier(.16, 1, .3, 1);
}

html:not(:has(body.home-page)),
body:not(.home-page) {
  background:
    radial-gradient(circle at 84% 12%, rgba(216, 255, 72, .18), transparent 18rem),
    radial-gradient(circle at 8% 30%, rgba(159, 178, 119, .14), transparent 24rem),
    linear-gradient(180deg, #fff 0%, var(--gh-bg-cool) 52%, #fff 100%) !important;
}

body:not(.home-page),
body:not(.home-page) :where(.font-body, .font-headline, .font-label, input, textarea, select, button):not(.material-symbols-outlined) {
  font-family: var(--globos-font-body) !important;
}

html[lang='ko'] body:not(.home-page),
html[lang='ko'] body:not(.home-page) :where(h1, h2, h3, h4, h5, h6, p, li, a, button, span, input, textarea, select):not(.material-symbols-outlined) {
  font-family: var(--globos-font-korean) !important;
}

body:not(.home-page) :where(h1, h2, h3, h4, .brand-name, .font-headline):not(.material-symbols-outlined) {
  color: var(--gh-ink) !important;
  font-family: var(--globos-font-display) !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
}

body:not(.home-page) :where(p, li, dd, dt):not(.material-symbols-outlined) {
  color: var(--gh-muted) !important;
}

body:not(.home-page) header {
  border-color: rgba(86, 102, 69, .10) !important;
  background: rgba(255, 255, 255, .92) !important;
  backdrop-filter: blur(18px);
  box-shadow: 0 8px 24px rgba(86, 102, 69, .04);
}

body:not(.home-page) .brand-name {
  color: var(--gh-navy) !important;
  text-transform: uppercase;
}

body:not(.home-page) .language-button,
body:not(.home-page) [href*='?lang='],
body:not(.home-page) [href*='/ko/'],
body:not(.home-page) [href*='/en/'] {
  border-radius: 999px !important;
}

body:not(.home-page) .primary-action,
body:not(.home-page) .secondary-action,
body:not(.home-page) .hover-lift,
body:not(.home-page) .home-btn {
  border-radius: 999px !important;
  transition:
    transform 190ms var(--gh-ease),
    background-color 190ms ease,
    border-color 190ms ease,
    color 190ms ease,
    box-shadow 190ms ease !important;
}

body:not(.home-page) .primary-action,
body:not(.home-page) .hover-lift.bg-navy,
body:not(.home-page) a.bg-navy {
  background: var(--gh-navy) !important;
  box-shadow: 0 18px 38px rgba(86, 102, 69, .18) !important;
}

body:not(.home-page) .primary-action:hover,
body:not(.home-page) .primary-action:focus-visible,
body:not(.home-page) a.bg-navy:hover,
body:not(.home-page) a.bg-navy:focus-visible {
  background: var(--gh-coral) !important;
  transform: translateY(-2px);
}

body:not(.home-page) .secondary-action,
body:not(.home-page) a.border-line {
  border-color: var(--gh-line) !important;
}

body:not(.home-page) .section-label,
.seo-page main > section:first-child p:first-child,
.capability-page .section-label {
  color: var(--gh-coral) !important;
  font-size: .72rem !important;
  letter-spacing: 0 !important;
}

body:not(.home-page) .section-label::before,
.capability-page .section-label::before {
  background: var(--gh-lime) !important;
}

.capability-page main.pt-\[73px\] > section:first-child,
.seo-page main > section:first-child {
  overflow: hidden;
  background:
    radial-gradient(circle at 82% 18%, rgba(216, 255, 72, .22), transparent 18rem),
    linear-gradient(135deg, #fff 0%, var(--gh-bg-cool) 100%) !important;
}

.capability-page main.pt-\[73px\] > section:first-child > .mx-auto.grid,
.seo-page main > section:first-child > .mx-auto.grid {
  min-height: auto !important;
  padding-top: clamp(72px, 9vw, 128px) !important;
  padding-bottom: clamp(54px, 7vw, 96px) !important;
}

.capability-page main.pt-\[73px\] > section:first-child h1,
.seo-page main > section:first-child h1 {
  max-width: 760px;
  font-size: clamp(3.1rem, 7vw, 6.9rem) !important;
  line-height: .98 !important;
}

html[lang='ko'] .capability-page main.pt-\[73px\] > section:first-child h1,
html[lang='ko'] .seo-page main > section:first-child h1 {
  font-size: clamp(3rem, 6vw, 5.8rem) !important;
  line-height: 1.04 !important;
  word-break: keep-all;
}

.capability-page main.pt-\[73px\] > section:first-child p,
.seo-page main > section:first-child p {
  max-width: 660px;
  color: var(--gh-muted) !important;
}

.feature-visual,
.seo-visual-stage,
body:not(.home-page) main.pt-\[73px\] > section:first-child .relative.overflow-hidden.rounded-sm.border,
.seo-page main > section:first-child aside {
  overflow: hidden !important;
  border: 1px solid rgba(86, 102, 69, .10) !important;
  border-radius: 32px !important;
  background: rgba(255, 255, 255, .86) !important;
  box-shadow: var(--gh-shadow) !important;
}

.feature-visual {
  padding: clamp(10px, 1.2vw, 16px) !important;
  transform: rotate(.65deg);
}

.feature-visual img,
.seo-visual-frame img,
body:not(.home-page) main.pt-\[73px\] > section:first-child img[src*='brand-operations'] {
  display: block;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 16 / 10 !important;
  border-radius: 24px !important;
  object-fit: cover !important;
  object-position: center !important;
  padding: 0 !important;
}

.seo-visual-stage {
  position: relative;
  display: grid;
  gap: 14px;
}

.seo-visual-frame {
  overflow: hidden;
  border-radius: 26px;
  background: #fff;
}

.seo-proof-ribbon {
  display: grid;
  gap: 4px;
  border-radius: 22px;
  background: #fff;
  padding: 18px 20px;
  box-shadow: var(--gh-soft-shadow);
}

.seo-proof-ribbon p {
  color: var(--gh-coral) !important;
  font-size: .74rem !important;
  font-weight: 800;
  text-transform: uppercase;
}

.seo-proof-ribbon strong {
  color: var(--gh-ink) !important;
  font-size: clamp(1.4rem, 2vw, 2rem);
}

.seo-proof-ribbon span {
  color: var(--gh-muted) !important;
  font-size: .9rem;
  font-weight: 700;
}

.seo-proof-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.seo-proof-grid span {
  display: grid;
  gap: 4px;
  border-radius: 18px;
  background: var(--gh-bg-cool);
  padding: 14px;
  color: var(--gh-muted) !important;
  font-size: .78rem;
  font-weight: 800;
}

.seo-proof-grid strong {
  color: var(--gh-navy) !important;
  font-size: 1rem;
}

.capability-page .brief-stage {
  background:
    radial-gradient(circle at 16% 12%, rgba(216, 255, 72, .26), transparent 18rem),
    linear-gradient(135deg, #fff 0%, var(--gh-bg-cool) 100%) !important;
  color: var(--gh-ink) !important;
}

.capability-page .brief-stage::before {
  background-image:
    linear-gradient(rgba(86, 102, 69, .045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(86, 102, 69, .045) 1px, transparent 1px) !important;
  opacity: .46 !important;
}

.capability-page .brief-stage::after {
  display: none !important;
}

.capability-page .brief-intro {
  border-left: 0 !important;
  padding-left: 0 !important;
}

.capability-page .brief-stage :where(h2, h3, strong, .font-headline) {
  color: var(--gh-ink) !important;
}

.capability-page .brief-stage :where(p, li, span):not(.material-symbols-outlined):not(.brief-index) {
  color: var(--gh-muted) !important;
}

.capability-page .brief-console {
  border: 0 !important;
  gap: 16px !important;
  background: transparent !important;
  box-shadow: none !important;
}

.capability-page .brief-panel {
  border: 1px solid rgba(86, 102, 69, .10) !important;
  border-radius: 28px !important;
  background: rgba(255, 255, 255, .86) !important;
  box-shadow: var(--gh-soft-shadow) !important;
  backdrop-filter: blur(14px);
}

.capability-page .brief-proof {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .94), rgba(243, 247, 236, .92)) !important;
}

.capability-page .brief-label,
.capability-page .brief-index,
.capability-page .text-brass {
  color: var(--gh-coral) !important;
}

.capability-page .brief-label::before {
  background: var(--gh-lime) !important;
}

.capability-page .flow-stage,
.seo-page main section {
  background: transparent !important;
}

.capability-page .process-rail::before {
  background: linear-gradient(var(--gh-lime), rgba(255, 90, 79, .35)) !important;
}

.capability-page .process-step,
.seo-page article,
.seo-page details,
.seo-page #geo-answer > .mx-auto > div,
.seo-page [class*='bg-fog'] article,
.seo-page [class*='bg-white'] article {
  border: 1px solid rgba(86, 102, 69, .10) !important;
  border-radius: 26px !important;
  background: rgba(255, 255, 255, .88) !important;
  box-shadow: var(--gh-soft-shadow) !important;
}

.capability-page .process-step {
  min-height: 104px !important;
}

.capability-page .process-number {
  color: var(--gh-coral) !important;
}

.capability-page .process-number::after {
  border-color: var(--gh-lime) !important;
}

.capability-page .process-copy {
  color: var(--gh-ink) !important;
}

.capability-page main > section.bg-\[\#293129\],
.capability-page main > section[class*="bg-[#293129]"],
.seo-page main > section:last-of-type {
  background:
    radial-gradient(circle at 20% 10%, rgba(216, 255, 72, .22), transparent 20rem),
    linear-gradient(135deg, var(--gh-navy) 0%, #788863 100%) !important;
  color: #fff !important;
}

.capability-page main > section.bg-\[\#293129\] :where(h2, h3, strong, a, .font-headline),
.capability-page main > section[class*="bg-[#293129]"] :where(h2, h3, strong, a, .font-headline),
.seo-page main > section:last-of-type :where(h2, h3, strong, a, .font-headline) {
  color: #fff !important;
}

.capability-page main > section.bg-\[\#293129\] :where(p, li, span):not(.material-symbols-outlined),
.capability-page main > section[class*="bg-[#293129]"] :where(p, li, span):not(.material-symbols-outlined),
.seo-page main > section:last-of-type :where(p, li, span):not(.material-symbols-outlined) {
  color: rgba(255, 255, 255, .74) !important;
}

.capability-page .related-card,
.seo-page main > section:last-of-type [class*='rounded-sm'] {
  border: 1px solid rgba(255, 255, 255, .16) !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, .10) !important;
  box-shadow: none !important;
}

.capability-page .related-card:hover,
.capability-page .related-card:focus-visible {
  background: #fff !important;
}

.capability-page .related-card:hover :where(strong, span),
.capability-page .related-card:focus-visible :where(strong, span) {
  color: var(--gh-ink) !important;
}

.seo-page li[class*='rounded-sm'],
.seo-page a[class*='rounded-sm'],
.seo-page details[class*='rounded-sm'] {
  border-radius: 999px !important;
}

.seo-page .mt-8.grid.gap-3 details {
  border-radius: 24px !important;
}

body:not(.home-page) footer {
  border-top: 1px solid rgba(86, 102, 69, .10) !important;
  background: #fff !important;
  color: var(--gh-muted) !important;
}

body:not(.home-page) footer :where(.brand-name, h1, h2, h3, h4, strong, a, .font-headline) {
  color: var(--gh-navy) !important;
}

body:not(.home-page) footer :where(p, span, li) {
  color: var(--gh-muted) !important;
}

@media (max-width: 1023px) {
  .capability-page main.pt-\[73px\] > section:first-child > .mx-auto.grid,
  .seo-page main > section:first-child > .mx-auto.grid {
    padding-top: 56px !important;
  }

  .feature-visual {
    transform: none;
  }
}

@media (max-width: 767px) {
  .capability-page main.pt-\[73px\] > section:first-child h1,
  .seo-page main > section:first-child h1,
  html[lang='ko'] .capability-page main.pt-\[73px\] > section:first-child h1,
  html[lang='ko'] .seo-page main > section:first-child h1 {
    font-size: clamp(2.7rem, 13vw, 4rem) !important;
  }

  .feature-visual,
  .seo-visual-stage,
  .capability-page .brief-panel,
  .capability-page .process-step,
  .seo-page article,
  .seo-page details,
  .seo-page #geo-answer > .mx-auto > div {
    border-radius: 22px !important;
  }

  .seo-proof-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Warm visual reset: replaces the remaining navy/cobalt feel with the home page palette. */
:root {
  --gh-bg: #fbfaf4;
  --gh-bg-cool: #f3f7ec;
  --gh-ink: #293129;
  --gh-navy: #566645;
  --gh-muted: #6f7669;
  --gh-line: rgba(86, 102, 69, .18);
  --gh-lime: #dbe874;
  --gh-coral: #d3754f;
  --gh-red: #d3754f;
  --gh-sky: #9fb277;
  --gh-shadow: 0 28px 74px rgba(86, 102, 69, .13);
  --gh-soft-shadow: 0 16px 42px rgba(86, 102, 69, .09);
  --home-navy: #566645;
  --home-ink: #293129;
  --home-coral: #d3754f;
  --home-red: #d3754f;
  --home-sky: #9fb277;
  --home-sky-paper: #f3f7ec;
  --ps-ink: #293129;
  --ps-navy: #566645;
  --ps-sky: #9fb277;
}

body,
.text-ink,
.text-primary,
.text-on-surface {
  color: var(--gh-ink) !important;
}

.text-navy,
.text-cobalt,
.text-brass,
.hover\:text-navy:hover,
.hover\:text-cobalt:hover,
header a:not(.brand-name):hover,
nav a:not(.brand-name):hover {
  color: var(--gh-coral) !important;
}

.brand-name,
footer .brand-name,
.secondary-action,
.home-btn-secondary,
.language-button {
  color: var(--gh-navy) !important;
}

.bg-navy,
.bg-cobalt,
.bg-primary,
.bg-primary-container,
.bg-\[\#293129\],
[class*="bg-[#293129]"] {
  background: var(--gh-navy) !important;
}

.hover\:bg-cobalt:hover,
.hover\:bg-navy:hover,
.primary-action:hover,
form button[type='submit']:hover {
  background: var(--gh-coral) !important;
}

.border-navy,
.hover\:border-navy:hover,
.border-primary {
  border-color: var(--gh-navy) !important;
}

body::before {
  background-image:
    linear-gradient(rgba(86, 102, 69, .04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(86, 102, 69, .04) 1px, transparent 1px) !important;
}

body:not(.home-page),
html:not(:has(body.home-page)) {
  background:
    linear-gradient(180deg, #fff 0%, var(--gh-bg-cool) 54%, #fff 100%) !important;
}

header.fixed,
body.home-page header,
nav.fixed,
body:not(.home-page) header {
  border-bottom-color: var(--gh-line) !important;
  box-shadow: 0 18px 46px rgba(86, 102, 69, .08) !important;
}

.section-label,
.home-eyebrow,
.home-kicker,
.brief-label,
.seo-page main > section:first-child p:first-child,
.capability-page .section-label {
  color: var(--gh-coral) !important;
}

.section-label::before,
.brief-label::before,
.capability-page .section-label::before {
  background: linear-gradient(90deg, var(--gh-lime), var(--gh-coral)) !important;
}

.feature-visual,
.path-card,
.locale-card,
.brief-panel,
.capability-page .brief-panel,
.capability-page .process-step,
.seo-page article,
.seo-page details {
  border-color: var(--gh-line) !important;
  box-shadow: var(--gh-soft-shadow) !important;
}

main > section.bg-\[\#293129\],
main > section[class*="bg-[#293129]"],
.capability-page main > section.bg-\[\#293129\],
.capability-page main > section[class*="bg-[#293129]"],
.seo-page main > section:last-of-type {
  background:
    linear-gradient(135deg, #566645 0%, #74865f 100%) !important;
}

.route-radar,
#proof .relative.overflow-hidden.rounded-sm.border {
  background:
    linear-gradient(135deg, #566645 0%, #74865f 100%) !important;
}

.system-infra-section {
  background:
    linear-gradient(180deg, #fff 0%, #fbfaf4 46%, #f3f7ec 100%) !important;
}

.system-infra-header {
  max-width: 920px;
}

.system-photo-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

.system-photo-card {
  overflow: hidden;
  border: 1px solid var(--gh-line);
  border-radius: 8px;
  background: rgba(255, 255, 255, .9);
  box-shadow: var(--gh-soft-shadow);
}

.system-photo-media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: #ecebdd;
}

.system-photo-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.system-photo-copy {
  padding: 18px;
}

.system-photo-tag {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--gh-coral) !important;
  font-size: .74rem;
  font-weight: 850;
}

.system-photo-copy h3 {
  color: var(--gh-ink) !important;
  font-family: var(--globos-font-display) !important;
  font-size: clamp(1.15rem, 1.8vw, 1.45rem);
  font-weight: 850;
  line-height: 1.22;
}

.system-photo-copy p {
  margin-top: 10px;
  color: var(--gh-muted) !important;
  font-size: .95rem;
  font-weight: 650;
  line-height: 1.7;
}

@media (min-width: 768px) {
  .system-photo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .system-photo-copy {
    padding: 16px;
  }
}
