:root {
  color-scheme: light;

  --font-primary: "Inter", Helvetica, Arial, sans-serif;

  --color-text: #000000;
  --color-link: #0073b1;
  --color-link-hover: #09609c;
  --color-link-active: #002e6e;
  --color-white: #ffffff;
  --color-bg: #f0f0f0;
  --color-surface: #f5f5f7;
  --color-border: #d2d2d7;
  --color-muted: #555555;
  --footer-background: rgb(245, 245, 247);
  --footer-border-color: rgba(0, 0, 0, 0.16);
  --footer-text-color: rgba(0, 0, 0, 0.72);

  --container-max: 1110px;
  --container-padding: 16px;

  --space-8: 8px;
  --space-10: 10px;
  --space-16: 16px;
  --space-20: 20px;
  --space-24: 24px;
  --space-32: 32px;
  --space-40: 40px;
  --space-48: 48px;
  --space-64: 64px;
}

* {
  box-sizing: border-box;
}

html {
  background: var(--color-white);
  color: var(--color-text);
}

body {
  margin: 0;
  font-family: var(--font-primary);
  font-weight: 300;
  font-size: 16px;
  line-height: 24px;
  text-rendering: optimizeLegibility;
}

a {
  color: var(--color-link);
}

a:hover {
  color: var(--color-link-hover);
}

a:active {
  color: var(--color-link-active);
}

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

h1,
h2 {
  margin-bottom: var(--space-8);
  font-size: 26px;
  line-height: 32px;
  letter-spacing: 0;
}

h1 {
  font-weight: 400;
}

h2 {
  font-weight: 400;
}

h3 {
  margin-bottom: var(--space-8);
  font-size: 17px;
  line-height: 24px;
  font-weight: 400;
  letter-spacing: 0;
}

p {
  margin-bottom: var(--space-16);
}

.skip-link {
  position: absolute;
  left: var(--space-16);
  top: var(--space-16);
  z-index: 100;
  transform: translateY(-160%);
  background: var(--color-text);
  color: var(--color-white);
  padding: var(--space-8) var(--space-10);
}

.skip-link:focus {
  transform: translateY(0);
}

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

.site-header {
  background: var(--color-white);
  border-bottom: 1px solid var(--color-border);
}

.header-inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-16);
  padding-top: var(--space-20);
  padding-bottom: var(--space-16);
}

.logo {
  display: inline-flex;
  gap: 0;
  color: var(--color-text);
  text-decoration: none;
  letter-spacing: 0;
}

.logo span {
  color: var(--color-text);
  font-weight: 500;
}

.logo strong {
  font-weight: 500;
}

.nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-10) var(--space-20);
  font-size: 16px;
  line-height: 20px;
}

.nav a {
  color: var(--color-text);
  text-decoration: none;
}

.nav a:hover {
  color: var(--color-link-hover);
}

.nav a:active,
.nav a[aria-current="page"] {
  color: var(--color-link-active);
}

.service-nav {
  position: sticky;
  top: 0;
  z-index: 30;
  border-bottom: 1px solid var(--color-border);
  background: rgba(245, 245, 247, 0.82);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  backdrop-filter: saturate(180%) blur(20px);
}

.service-nav-inner {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-10) var(--space-20);
  padding-top: var(--space-10);
  padding-bottom: var(--space-10);
  font-size: 16px;
  line-height: 20px;
}

.service-nav a {
  color: var(--color-text);
  text-decoration: none;
}

.service-nav a:hover {
  color: var(--color-link-hover);
}

.service-nav a:active,
.service-nav a[aria-current="page"] {
  color: var(--color-link-active);
  font-weight: 500;
}

.hero,
.media-block {
  padding-top: var(--space-48);
  padding-bottom: var(--space-48);
}

.hero h1 {
  max-width: 760px;
}

.media-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-24);
}

.media-block-content,
.media-block-media {
  min-width: 0;
}

.media-block-media img {
  display: block;
  width: 100%;
  height: auto;
}

.landing-hero-section h1 {
  margin-bottom: var(--space-32);
}

.smart-nation-section h2 {
  margin-bottom: var(--space-32);
}

.hero-text-link {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-8);
  color: var(--color-link);
  font-weight: 500;
  text-decoration: none;
}

.hero-text-link:hover {
  color: var(--color-link-hover);
}

.hero-text-link:active {
  color: var(--color-link-active);
}

.eyebrow,
.row-kicker,
.process-step span {
  display: block;
  margin-bottom: var(--space-8);
  color: var(--color-text);
  font-size: 14px;
  line-height: 20px;
  font-weight: 500;
  letter-spacing: 0;
}

.hero-lead,
.hero-intro,
.row-lead,
.feature-row p,
.process-step p,
.message-page p,
.link-row span,
.site-footer p {
  color: var(--color-muted);
}

.hero-lead {
  max-width: 820px;
  margin-bottom: var(--space-16);
  font-size: 19px;
  line-height: 29px;
}

.hero-intro {
  max-width: 820px;
  margin-bottom: 0;
}

.hero-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-10);
  margin-top: var(--space-24);
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 8px 16px;
  border: 1px solid var(--color-border);
  background: var(--color-white);
  color: var(--color-text);
  font-size: 16px;
  line-height: 20px;
  font-weight: 500;
  text-decoration: none;
}

.button.primary {
  border-color: var(--color-link);
  background: var(--color-link);
  color: var(--color-white);
}

.button.secondary {
  border-color: var(--color-border);
  background: var(--color-white);
}

.button:hover {
  border-color: var(--color-link-hover);
  background: var(--color-link-hover);
  color: var(--color-white);
}

.button:active {
  border-color: var(--color-link-active);
  background: var(--color-link-active);
  color: var(--color-white);
}

.content-row,
.contact-panel {
  background: var(--color-white);
}

.content-row:not(.landing-hero-section):not(.smart-nation-section):not(.faq-section):not(.service-detail-media-section) > .shell.row-grid,
.content-row:not(.landing-hero-section):not(.smart-nation-section):not(.faq-section):not(.service-detail-media-section) > .shell.media-block,
.contact-panel > .shell.contact-split {
  position: relative;
}

.content-row:not(.landing-hero-section):not(.smart-nation-section):not(.faq-section):not(.service-detail-media-section) > .shell.row-grid::before,
.content-row:not(.landing-hero-section):not(.smart-nation-section):not(.faq-section):not(.service-detail-media-section) > .shell.media-block::before,
.contact-panel > .shell.contact-split::before {
  content: "";
  position: absolute;
  top: 0;
  left: var(--container-padding);
  right: var(--container-padding);
  border-top: 1px solid var(--color-border);
}

.row-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-24);
  padding-top: var(--space-48);
  padding-bottom: var(--space-48);
}

.row-heading h2,
.row-heading p {
  max-width: 360px;
}

.row-body {
  max-width: 760px;
}

.row-lead {
  max-width: 700px;
  margin-bottom: var(--space-24);
}

.row-heading .row-lead {
  margin-top: var(--space-16);
  margin-bottom: 0;
}

.link-list {
  border-top: 1px solid var(--color-border);
}

.quiet-link-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-24);
  border-top: 0;
}

.quiet-link-list .link-row {
  padding-top: 0;
  padding-bottom: 0;
  border-bottom: 0;
}

.media-block-image,
.smart-nation-media {
  margin: 0 0 var(--space-40);
}

.media-block-image img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
}

.service-summary-top {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-16);
}

.service-summary-link {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-8);
}

.service-summary-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-24);
  margin-top: 60px;
  padding-top: var(--space-24);
  border-top: 1px solid var(--color-border);
}

.service-summary-item h3 {
  margin-bottom: var(--space-8);
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
}

.service-summary-item p {
  margin-bottom: 0;
  color: var(--color-muted);
}

.link-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  padding: var(--space-20) 0;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-text);
  text-decoration: none;
}

.link-row:hover .row-action,
.text-link:hover {
  color: var(--color-link-hover);
}

.row-main strong {
  display: block;
  margin-bottom: var(--space-8);
  color: var(--color-text);
}

.row-main span {
  display: block;
}

.link-row .row-action,
.text-link {
  color: var(--color-link);
  font-size: 16px;
  line-height: 20px;
  font-weight: 500;
  text-decoration: none;
}

.contact-large {
  font-size: 26px;
  line-height: 32px;
}

.contact-large a {
  text-decoration: none;
}

.contact-page-header {
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-24);
}

.service-page-header {
  background: var(--color-surface);
  margin-bottom: var(--space-24);
}

.contact-page-hero {
  padding-top: var(--space-24);
  padding-bottom: var(--space-48);
}

.service-page-hero {
  padding-top: var(--space-24);
  padding-bottom: var(--space-48);
}

.contact-page-hero h1 {
  margin-bottom: 0;
  font-weight: 700;
}

.service-page-hero h1 {
  max-width: 820px;
  margin-bottom: 0;
  font-weight: 700;
}

.contact-page-hero h2 {
  max-width: 700px;
  margin-bottom: 0;
  font-size: 26px;
  line-height: 32px;
  font-weight: 300;
}

.service-page-hero h2 {
  max-width: 820px;
  margin-bottom: 0;
  font-size: 26px;
  line-height: 32px;
  font-weight: 300;
}

.contact-page-hero .contact-large {
  margin-top: var(--space-32);
  margin-bottom: 0;
}

.service-detail-media {
  margin: 0 0 var(--space-40);
}

.web-mobile-service-overview .media-block-content .row-lead,
.cloud-service-overview .media-block-content .row-lead,
.smart-farming-service-overview .media-block-content .row-lead {
  margin-bottom: 0;
}

.pricing-grid {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-24);
  padding-top: var(--space-48);
  padding-bottom: var(--space-48);
}

.pricing-grid::before {
  content: "";
  position: absolute;
  top: 0;
  left: var(--container-padding);
  right: var(--container-padding);
  border-top: 1px solid var(--color-border);
}

.pricing-grid h2 {
  margin-bottom: 0;
}

.pricing-introduction p {
  color: var(--color-muted);
}

.pricing-factor-list {
  border-top: 1px solid var(--color-border);
}

.pricing-factor {
  padding: var(--space-20) 0;
  border-bottom: 1px solid var(--color-border);
}

.pricing-factor:last-child {
  border-bottom: 0;
}

.pricing-factor h3 {
  font-size: 16px;
  line-height: 24px;
}

.pricing-factor p {
  margin-bottom: 0;
  color: var(--color-muted);
}

.pricing-cta .button {
  display: block;
  width: 100%;
  padding: 10px 15px;
  border: 0;
  border-radius: 2px;
  text-align: center;
  white-space: normal;
}

.contact-inquiries,
.contact-location {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-24);
  padding-bottom: var(--space-48);
}

.contact-inquiries {
  padding-top: 0;
}

.contact-location {
  padding-top: var(--space-20);
}

.contact-location::before {
  content: "";
  position: absolute;
  top: 0;
  left: var(--container-padding);
  right: var(--container-padding);
  border-top: 1px solid var(--color-border);
}

.contact-inquiries h2,
.contact-location h2 {
  margin-bottom: 0;
  font-weight: 300;
}

.contact-inquiries h3,
.contact-location h3 {
  margin-bottom: var(--space-8);
}

.contact-inquiries p,
.contact-location p {
  margin-bottom: var(--space-24);
}

.contact-inquiries-links {
  margin-bottom: 0;
}

.contact-inquiries-links a {
  font-size: 24px;
  line-height: 30px;
  overflow-wrap: anywhere;
}

.contact-inquiries a,
.contact-location a {
  color: var(--color-link);
  text-decoration: none;
}

.contact-location-media {
  margin: 0;
}

.contact-location-media img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
}

.feature-list {
  border-top: 1px solid var(--color-border);
}

.feature-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-8);
  padding: var(--space-20) 0;
  border-bottom: 1px solid var(--color-border);
}

.feature-row:last-child {
  border-bottom: 0;
}

.feature-row h3 {
  font-size: 16px;
  line-height: 24px;
  font-weight: 400;
}

.feature-row p {
  margin-bottom: 0;
}

.service-deliverables-section .row-lead {
  margin-bottom: var(--space-32);
}

.process-grid {
  display: grid;
  grid-template-columns: 1fr;
  border-top: 1px solid var(--color-border);
}

.process-step {
  padding: var(--space-20) 0;
  border-bottom: 1px solid var(--color-border);
}

.process-step span {
  margin-bottom: var(--space-16);
}

.process-step p {
  margin-bottom: 0;
}

.faq-list {
  border-bottom: 1px solid var(--color-border);
}

.faq-list details {
  border-top: 1px solid var(--color-border);
}

.faq-list summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--space-16);
  align-items: center;
  padding: var(--space-20) 0;
  color: var(--color-text);
  cursor: pointer;
  list-style: none;
}

.faq-list summary::-webkit-details-marker {
  display: none;
}

.faq-list summary::after {
  content: "+";
  color: var(--color-link);
  font-size: 26px;
  line-height: 20px;
  font-weight: 400;
}

.faq-list details[open] summary::after {
  content: "-";
}

.faq-list details p {
  max-width: 620px;
  margin-bottom: var(--space-20);
  color: var(--color-muted);
}

.faq-more-link {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-8);
  margin-top: var(--space-32);
}

.contact-split {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-24);
  padding-top: var(--space-48);
  padding-bottom: var(--space-48);
}

.contact-copy {
  min-width: 0;
}

.contact-copy h2 {
  margin-bottom: var(--space-32);
  font-weight: 400;
}

.contact-copy .button {
  display: block;
  width: 100%;
  padding: 10px 15px;
  border: 0;
  border-radius: 2px;
  text-align: center;
  white-space: normal;
}

.contact-media {
  min-width: 0;
}

.contact-media img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  object-fit: cover;
}

.site-footer {
  background: var(--footer-background);
  border-top: 1px solid var(--footer-border-color);
  color: var(--footer-text-color);
}

.footer-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-32);
  padding-top: var(--space-40);
  padding-bottom: var(--space-40);
}

.footer-grid h2 {
  margin-bottom: var(--space-16);
}

.footer-grid h3 {
  margin-bottom: var(--space-10);
}

.footer-grid a {
  display: block;
  margin-bottom: var(--space-8);
  color: var(--footer-text-color);
  text-decoration: none;
}

.footer-grid a:hover {
  color: var(--color-link-hover);
}

.social-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-10);
  margin-top: var(--space-20);
}

.footer-grid .social-links a {
  display: inline-grid;
  width: 32px;
  height: 32px;
  place-items: center;
  margin-bottom: 0;
  border: 1px solid var(--footer-border-color);
  border-radius: 2px;
  color: var(--footer-text-color);
  font-size: 14px;
  line-height: 20px;
  font-weight: 500;
}

.footer-grid .button {
  display: inline-flex;
  margin-top: var(--space-8);
  margin-bottom: 0;
}

.legal-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-10);
  padding-top: var(--space-16);
  padding-bottom: var(--space-16);
  border-top: 1px solid var(--footer-border-color);
  color: var(--footer-text-color);
  font-size: 14px;
  line-height: 20px;
}

.legal-row a {
  color: var(--footer-text-color);
  text-decoration: none;
}

.message-page {
  max-width: 680px;
  padding: var(--space-48) var(--container-padding);
  margin: 0 auto;
}

:focus-visible {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}

@media (min-width: 620px) {
  :root {
    --container-padding: 32px;
  }

  h1,
  h2 {
    font-size: 32px;
    line-height: 40px;
  }

  .contact-page-hero h2,
  .service-page-hero h2 {
    font-size: 32px;
    line-height: 40px;
  }

  .contact-page-header,
  .service-page-header {
    margin-bottom: var(--space-40);
  }

  .contact-page-hero,
  .service-page-hero {
    padding-top: var(--space-32);
    padding-bottom: var(--space-64);
  }

  .pricing-grid {
    padding-bottom: var(--space-64);
  }

  .contact-inquiries,
  .contact-location {
    padding-bottom: var(--space-64);
  }

  .contact-large {
    font-size: 32px;
    line-height: 40px;
  }

  .contact-inquiries-links a {
    font-size: 32px;
    line-height: 40px;
  }

  .hero-actions {
    flex-direction: row;
  }

  .link-row {
    grid-template-columns: minmax(130px, 0.28fr) minmax(0, 1fr);
  }

  .quiet-link-list .link-row {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .row-action {
    grid-column: 2;
  }

  .process-grid,
  .footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-32);
  }

  .legal-row {
    flex-direction: row;
    justify-content: space-between;
  }
}

@media (min-width: 860px) {
  .contact-page-hero,
  .service-page-hero {
    padding-top: var(--space-40);
    padding-bottom: 80px;
  }

  .media-block {
    flex-direction: row;
    align-items: flex-start;
    gap: var(--space-32);
  }

  .media-block-content {
    flex: 1 1 0;
  }

  .media-block-media {
    flex: 2 1 0;
  }

  .media-block h1,
  .media-block h2 {
    max-width: none;
  }

  .row-grid {
    grid-template-columns: minmax(220px, 0.36fr) minmax(0, 0.64fr);
    gap: var(--space-32);
  }

  .link-row {
    grid-template-columns: minmax(120px, 0.24fr) minmax(0, 1fr) auto;
    align-items: start;
    gap: var(--space-32);
  }

  .quiet-link-list .link-row {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .row-action {
    grid-column: auto;
    white-space: nowrap;
  }

  .service-summary-top {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: var(--space-32);
  }

  .service-summary-link {
    text-align: right;
    white-space: nowrap;
  }

  .contact-split {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
    gap: var(--space-32);
  }

  .contact-inquiries {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: 5.8823529412%;
  }

  .contact-inquiries-list {
    grid-column: 2 / 4;
  }

  .contact-location {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
    column-gap: 5.8823529412%;
  }

  .pricing-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: start;
    column-gap: 5.8823529412%;
  }

  .feature-row {
    grid-template-columns: minmax(220px, 0.4fr) minmax(0, 1fr);
    gap: var(--space-32);
    padding: var(--space-24) 0;
  }

  .service-deliverables-section .row-grid {
    grid-template-columns: minmax(0, 31.4285714286%) minmax(0, 65.7142857143%);
    column-gap: 2.8571428571%;
  }

  .service-deliverables-section .row-body {
    max-width: none;
  }

  .service-deliverables-section .feature-row {
    grid-template-columns: minmax(180px, 31.4285714286%) minmax(0, 1fr);
    column-gap: 5.8823529412%;
  }

  .process-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-32);
  }

  .footer-grid {
    grid-template-columns: 1.6fr repeat(3, 1fr);
  }
}

@media (min-width: 970px) {
  .header-inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}

@media (min-width: 1024px) {
  .hero {
    padding-top: var(--space-64);
    padding-bottom: var(--space-64);
  }

  .row-grid {
    padding-top: var(--space-64);
    padding-bottom: var(--space-64);
  }
}
