/* ============================================
   INFORYTICA - MAIN STYLESHEET
   Design: Dot Grid Pattern | Technical Precise
   ============================================ */


:root {
  
  --clrPrimary: #0f2a4a;
  --clrPrimaryLight: #1a3d6b;
  --clrPrimaryDark: #081a2e;
  --clrSecondary: #1e6fa8;
  --clrSecondaryLight: #2d8fd4;
  --clrAccent: #00b4d8;
  --clrAccentWarm: #0096c7;
  --clrBg: #f5f7fa;
  --clrBgAlt: #eef1f6;
  --clrBgDark: #0a1f38;
  --clrSurface: #ffffff;
  --clrText: #1a2535;
  --clrTextMuted: #5a6a7e;
  --clrTextLight: #f0f4f8;
  --clrBorder: #d4dce8;
  --clrBorderLight: #e8edf5;

  
  --shadowSm: 0 2px 8px rgba(15,42,74,0.08), 0 1px 3px rgba(15,42,74,0.05);
  --shadowMd: 0 4px 16px rgba(15,42,74,0.10), 0 2px 6px rgba(15,42,74,0.06);
  --shadowLg: 0 8px 32px rgba(15,42,74,0.12), 0 4px 12px rgba(15,42,74,0.07);
  --shadowXl: 0 16px 48px rgba(15,42,74,0.15), 0 6px 18px rgba(15,42,74,0.08);
  --shadowFloat: 0 20px 60px rgba(15,42,74,0.18), 0 8px 24px rgba(15,42,74,0.10);

  
  --sp1: 0.25rem;
  --sp2: 0.5rem;
  --sp3: 0.75rem;
  --sp4: 1rem;
  --sp5: 1.25rem;
  --sp6: 1.5rem;
  --sp8: 2rem;
  --sp10: 2.5rem;
  --sp12: 3rem;
  --sp16: 4rem;
  --sp20: 5rem;
  --sp24: 6rem;

  
  --rSm: 6px;
  --rMd: 12px;
  --rLg: 18px;
  --rXl: 24px;
  --rFull: 9999px;

  
  --fontMain: 'Nunito Sans', sans-serif;

  
  --transBase: 0.25s ease;
  --transSlow: 0.4s ease;
  --transFast: 0.15s ease;

  
  --dotColor: rgba(15,42,74,0.07);
  --dotSize: 1.5px;
  --dotSpacing: 22px;
}


*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  overflow-x: hidden;
}

body {
  font-family: var(--fontMain);
  background-color: var(--clrBg);
  color: var(--clrText);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img {
  max-inline-size: 100%;
  block-size: auto;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--transBase);
}

ul {
  list-style: none;
}

button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
}

address {
  font-style: normal;
}


.dotGridBg,
.mainHero_dotGrid,
.pageFooter_dotGrid,
.ctaSection_dotGrid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, var(--dotColor) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
  pointer-events: none;
  z-index: 0;
}


.container {
  max-inline-size: 1200px;
  margin-inline: auto;
  padding-inline: var(--sp6);
}


h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  line-height: 1.2;
  color: var(--clrText);
}


.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp2);
  padding-block: var(--sp3);
  padding-inline: var(--sp6);
  border-radius: var(--rFull);
  font-family: var(--fontMain);
  font-size: 0.95rem;
  font-weight: 600;
  transition: all var(--transBase);
  cursor: pointer;
  border: 2px solid transparent;
  white-space: nowrap;
  min-block-size: 44px;
}

.btn--primary {
  background: var(--clrSecondary);
  color: var(--clrSurface);
  border-color: var(--clrSecondary);
  box-shadow: var(--shadowMd);
}
.btn--primary:hover {
  background: var(--clrSecondaryLight);
  border-color: var(--clrSecondaryLight);
  box-shadow: var(--shadowLg);
  transform: translateY(-2px);
}

.btn--ghost {
  background: transparent;
  color: var(--clrPrimary);
  border-color: var(--clrBorder);
}
.btn--ghost:hover {
  background: var(--clrBgAlt);
  border-color: var(--clrSecondary);
  color: var(--clrSecondary);
}

.btn--white {
  background: var(--clrSurface);
  color: var(--clrPrimary);
  border-color: var(--clrSurface);
  box-shadow: var(--shadowMd);
}
.btn--white:hover {
  background: var(--clrBgAlt);
  transform: translateY(-2px);
  box-shadow: var(--shadowLg);
}

.btn--whiteOutline {
  background: transparent;
  color: var(--clrSurface);
  border-color: rgba(255,255,255,0.5);
}
.btn--whiteOutline:hover {
  background: rgba(255,255,255,0.1);
  border-color: var(--clrSurface);
}

.btn--full {
  inline-size: 100%;
  justify-content: center;
}


.cookieBar {
  background: var(--clrPrimary);
  padding-block: var(--sp3);
  padding-inline: var(--sp6);
  position: relative;
  z-index: 1000;
  transition: all var(--transSlow);
}

.cookieBar.cookieBar--hidden {
  display: none;
}

.cookieBar_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp4);
  max-inline-size: 1200px;
  margin-inline: auto;
  flex-wrap: wrap;
}

.cookieBar_text {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.85);
}

.cookieBar_link {
  color: var(--clrAccent);
  text-decoration: underline;
}

.cookieBar_actions {
  display: flex;
  gap: var(--sp2);
  flex-shrink: 0;
}

.cookieBar_btn {
  font-family: var(--fontMain);
  font-size: 0.8rem;
  font-weight: 600;
  padding: var(--sp2) var(--sp4);
  border-radius: var(--rFull);
  cursor: pointer;
  transition: all var(--transBase);
  min-block-size: 32px;
}

.cookieBar_btn--solid {
  background: var(--clrAccent);
  color: var(--clrPrimary);
  border: 2px solid var(--clrAccent);
}
.cookieBar_btn--solid:hover {
  background: var(--clrSecondaryLight);
  border-color: var(--clrSecondaryLight);
  color: white;
}

.cookieBar_btn--outline {
  background: transparent;
  color: rgba(255,255,255,0.7);
  border: 2px solid rgba(255,255,255,0.3);
}
.cookieBar_btn--outline:hover {
  border-color: rgba(255,255,255,0.6);
  color: white;
}


.siteHeader {
  position: sticky;
  top: 0;
  z-index: 900;
  background: rgba(245,247,250,0.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-block-end: 1px solid var(--clrBorderLight);
  transition: all var(--transBase);
}

.siteHeader.siteHeader--dark {
  background: rgba(10,31,56,0.95);
  border-block-end-color: rgba(255,255,255,0.1);
}

.siteNav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp4);
  max-inline-size: 1200px;
  margin-inline: auto;
  padding-inline: var(--sp6);
  padding-block: var(--sp4);
}

.siteHeader_logo {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}

.siteHeader_logoImg {
  block-size: 36px;
  inline-size: auto;
}

.siteNav_links {
  display: flex;
  align-items: center;
  gap: var(--sp2);
}

.siteNav_link {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--clrTextMuted);
  padding: var(--sp2) var(--sp3);
  border-radius: var(--rSm);
  transition: all var(--transBase);
}

.siteNav_link:hover,
.siteNav_link--active {
  color: var(--clrSecondary);
  background: rgba(30,111,168,0.08);
}

.siteHeader--dark .siteNav_link {
  color: rgba(255,255,255,0.7);
}
.siteHeader--dark .siteNav_link:hover,
.siteHeader--dark .siteNav_link--active {
  color: var(--clrAccent);
  background: rgba(0,180,216,0.1);
}

.siteNav_actions {
  display: flex;
  align-items: center;
  gap: var(--sp3);
}

.siteNav_searchBtn {
  inline-size: 40px;
  block-size: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--rFull);
  color: var(--clrTextMuted);
  transition: all var(--transBase);
  font-size: 0.95rem;
}
.siteNav_searchBtn:hover {
  background: var(--clrBgAlt);
  color: var(--clrSecondary);
}
.siteHeader--dark .siteNav_searchBtn {
  color: rgba(255,255,255,0.7);
}
.siteHeader--dark .siteNav_searchBtn:hover {
  background: rgba(255,255,255,0.1);
  color: white;
}

.siteNav_cta {
  display: inline-flex;
  align-items: center;
  padding: var(--sp2) var(--sp5);
  background: var(--clrSecondary);
  color: white;
  border-radius: var(--rFull);
  font-size: 0.88rem;
  font-weight: 700;
  transition: all var(--transBase);
  min-block-size: 40px;
  box-shadow: var(--shadowSm);
}
.siteNav_cta:hover {
  background: var(--clrSecondaryLight);
  box-shadow: var(--shadowMd);
  transform: translateY(-1px);
}

.siteNav_hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--sp2);
  inline-size: 44px;
  block-size: 44px;
  align-items: center;
  justify-content: center;
  border-radius: var(--rSm);
  transition: background var(--transBase);
}
.siteNav_hamburger span {
  display: block;
  inline-size: 22px;
  block-size: 2px;
  background: var(--clrText);
  border-radius: var(--rFull);
  transition: all var(--transBase);
}
.siteHeader--dark .siteNav_hamburger span {
  background: white;
}
.siteNav_hamburger:hover {
  background: var(--clrBgAlt);
}


.searchOverlay {
  position: fixed;
  inset: 0;
  background: rgba(10,31,56,0.97);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transSlow);
}

.searchOverlay.searchOverlay--open {
  opacity: 1;
  pointer-events: all;
}

.searchOverlay_inner {
  inline-size: min(700px, 90vw);
  display: flex;
  align-items: center;
  gap: var(--sp4);
  border-block-end: 2px solid rgba(255,255,255,0.2);
  padding-block-end: var(--sp4);
}

.searchOverlay_input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  font-family: var(--fontMain);
  font-size: clamp(1.4rem, 3vw, 2rem);
  color: white;
  font-weight: 300;
}
.searchOverlay_input::placeholder {
  color: rgba(255,255,255,0.3);
}

.searchOverlay_close {
  color: rgba(255,255,255,0.6);
  font-size: 1.5rem;
  transition: color var(--transBase);
  padding: var(--sp2);
  min-inline-size: 44px;
  min-block-size: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.searchOverlay_close:hover {
  color: white;
}


.mobileMenu {
  position: fixed;
  inset: 0;
  z-index: 9998;
  display: flex;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transSlow);
}

.mobileMenu.mobileMenu--open {
  opacity: 1;
  pointer-events: all;
}

.mobileMenu_left {
  flex: 1;
  background: var(--clrPrimary);
  padding: var(--sp8);
  display: flex;
  flex-direction: column;
  justify-content: center;
  position: relative;
  transform: translateX(-100%);
  transition: transform var(--transSlow);
}

.mobileMenu.mobileMenu--open .mobileMenu_left {
  transform: translateX(0);
}

.mobileMenu_right {
  flex: 1;
  position: relative;
  overflow: hidden;
  transform: translateX(100%);
  transition: transform var(--transSlow);
}

.mobileMenu.mobileMenu--open .mobileMenu_right {
  transform: translateX(0);
}

.mobileMenu_close {
  position: absolute;
  top: var(--sp6);
  left: var(--sp6);
  color: rgba(255,255,255,0.6);
  font-size: 1.3rem;
  transition: color var(--transBase);
  inline-size: 44px;
  block-size: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--rFull);
  background: rgba(255,255,255,0.08);
}
.mobileMenu_close:hover {
  color: white;
  background: rgba(255,255,255,0.15);
}

.mobileMenu_nav {
  display: flex;
  flex-direction: column;
  gap: var(--sp3);
}

.mobileMenu_link {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 700;
  color: rgba(255,255,255,0.8);
  transition: all var(--transBase);
  padding-block: var(--sp2);
  border-block-end: 1px solid rgba(255,255,255,0.08);
}
.mobileMenu_link:hover {
  color: var(--clrAccent);
  padding-inline-start: var(--sp3);
}

.mobileMenu_contact {
  margin-block-start: var(--sp8);
  font-size: 0.85rem;
  color: rgba(255,255,255,0.4);
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
}

.mobileMenu_img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
}

.mobileMenu_graphicOverlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(10,31,56,0.7) 0%, rgba(30,111,168,0.4) 100%);
  display: flex;
  align-items: flex-end;
  padding: var(--sp8);
}

.mobileMenu_tagline {
  font-size: clamp(1.2rem, 2.5vw, 1.8rem);
  font-weight: 800;
  color: white;
  line-height: 1.3;
}


.sectionHead {
  text-align: center;
  margin-block-end: var(--sp12);
}

.sectionHead_label {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--clrAccent);
  background: rgba(0,180,216,0.1);
  padding: var(--sp1) var(--sp4);
  border-radius: var(--rFull);
  margin-block-end: var(--sp4);
  border: 1px solid rgba(0,180,216,0.2);
}

.sectionHead_title {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block-end: var(--sp4);
}

.sectionHead_sub {
  font-size: 1.05rem;
  color: var(--clrTextMuted);
  max-inline-size: 620px;
  margin-inline: auto;
  line-height: 1.7;
}

.sectionHead--light .sectionHead_title,
.sectionHead--light .sectionHead_sub {
  color: rgba(255,255,255,0.9);
}
.sectionHead--light .sectionHead_sub {
  color: rgba(255,255,255,0.7);
}


.mainHero {
  position: relative;
  min-block-size: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  background: linear-gradient(135deg, var(--clrBg) 0%, var(--clrBgAlt) 100%);
  overflow: hidden;
  padding-block: var(--sp20);
}

.mainHero_container {
  position: relative;
  z-index: 2;
  padding-inline-start: max(var(--sp6), calc((100vw - 1200px) / 2 + var(--sp6)));
  padding-inline-end: var(--sp8);
}

.mainHero_eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp2);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clrSecondary);
  background: rgba(30,111,168,0.08);
  padding: var(--sp2) var(--sp4);
  border-radius: var(--rFull);
  margin-block-end: var(--sp5);
  border: 1px solid rgba(30,111,168,0.15);
}

.mainHero_title {
  font-size: clamp(2.2rem, 4.5vw, 3.6rem);
  font-weight: 800;
  line-height: 1.1;
  color: var(--clrPrimary);
  margin-block-end: var(--sp5);
}

.mainHero_titleAccent {
  color: var(--clrSecondary);
  position: relative;
}

.mainHero_desc {
  font-size: 1.1rem;
  color: var(--clrTextMuted);
  line-height: 1.75;
  margin-block-end: var(--sp8);
  max-inline-size: 520px;
}

.mainHero_actions {
  display: flex;
  gap: var(--sp3);
  flex-wrap: wrap;
}


.mainHero_floatCard {
  position: absolute;
  background: var(--clrSurface);
  border-radius: var(--rMd);
  padding: var(--sp3) var(--sp4);
  display: flex;
  align-items: center;
  gap: var(--sp3);
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--clrPrimary);
  box-shadow: var(--shadowLg);
  border: 1px solid var(--clrBorderLight);
  white-space: nowrap;
  z-index: 3;
}

.mainHero_floatIcon {
  color: var(--clrAccent);
  font-size: 1rem;
}

.mainHero_floatCard--tl { top: 15%; left: 2%; }
.mainHero_floatCard--tr { top: 20%; right: 5%; }
.mainHero_floatCard--bl { bottom: 25%; left: 0%; }
.mainHero_floatCard--br { bottom: 18%; right: 8%; }


.mainHero_imageWrap {
  position: relative;
  z-index: 2;
  padding-inline-end: max(var(--sp6), calc((100vw - 1200px) / 2 + var(--sp6)));
  padding-inline-start: var(--sp4);
}

.mainHero_image {
  inline-size: 100%;
  block-size: 600px;
  object-fit: cover;
  border-radius: var(--rXl);
  box-shadow: var(--shadowXl);
}

.mainHero_imageBadge {
  position: absolute;
  bottom: var(--sp6);
  left: var(--sp8);
  background: var(--clrPrimary);
  color: white;
  padding: var(--sp3) var(--sp5);
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  gap: var(--sp3);
  font-size: 0.88rem;
  font-weight: 600;
  box-shadow: var(--shadowLg);
}
.mainHero_imageBadge i {
  color: var(--clrAccent);
}


.servicesSection {
  padding-block: var(--sp24);
  background: var(--clrSurface);
  position: relative;
}

.servicesGrid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: var(--sp5);
}

.serviceCard {
  background: var(--clrSurface);
  border-radius: var(--rLg);
  padding: var(--sp6);
  border: 1px solid var(--clrBorderLight);
  box-shadow: var(--shadowSm);
  transition: all var(--transSlow);
  display: flex;
  flex-direction: column;
  gap: var(--sp3);
}

.serviceCard:hover {
  box-shadow: var(--shadowLg);
  transform: translateY(-4px);
  border-color: var(--clrBorder);
}

.serviceCard--featured {
  grid-row: 1 / 3;
  padding: 0;
  overflow: hidden;
}

.serviceCard_imgWrap {
  block-size: 220px;
  overflow: hidden;
}

.serviceCard_img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  transition: transform var(--transSlow);
}
.serviceCard--featured:hover .serviceCard_img {
  transform: scale(1.04);
}

.serviceCard--featured .serviceCard_body {
  padding: var(--sp6);
  display: flex;
  flex-direction: column;
  gap: var(--sp3);
  flex: 1;
}

.serviceCard_icon {
  inline-size: 48px;
  block-size: 48px;
  background: linear-gradient(135deg, rgba(30,111,168,0.1), rgba(0,180,216,0.1));
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--clrSecondary);
  flex-shrink: 0;
}

.serviceCard_title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--clrPrimary);
}

.serviceCard--featured .serviceCard_title {
  font-size: 1.3rem;
}

.serviceCard_text {
  font-size: 0.9rem;
  color: var(--clrTextMuted);
  line-height: 1.7;
  flex: 1;
}

.serviceCard_link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp2);
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--clrSecondary);
  margin-block-start: auto;
  transition: gap var(--transBase);
}
.serviceCard_link:hover {
  gap: var(--sp3);
  color: var(--clrAccent);
}


.whySection {
  padding-block: var(--sp24);
  position: relative;
  overflow: hidden;
}

.whySection_bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--clrPrimary) 0%, var(--clrPrimaryLight) 100%);
}

.whySection .container {
  position: relative;
  z-index: 2;
}

.whyGrid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp5);
}

.whyCard {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--rLg);
  padding: var(--sp8);
  backdrop-filter: blur(8px);
  transition: all var(--transSlow);
  position: relative;
  overflow: hidden;
}

.whyCard:hover {
  background: rgba(255,255,255,0.1);
  transform: translateY(-3px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.2);
}

.whyCard_num {
  font-size: 3rem;
  font-weight: 800;
  color: rgba(255,255,255,0.06);
  position: absolute;
  top: var(--sp4);
  right: var(--sp5);
  line-height: 1;
  font-variant-numeric: tabular-nums;
}

.whyCard_icon {
  inline-size: 52px;
  block-size: 52px;
  background: rgba(0,180,216,0.15);
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: var(--clrAccent);
  margin-block-end: var(--sp5);
}

.whyCard_title {
  font-size: 1.05rem;
  font-weight: 700;
  color: white;
  margin-block-end: var(--sp3);
}

.whyCard_text {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.65);
  line-height: 1.7;
}


.valuesSection {
  padding-block: var(--sp24);
  background: var(--clrBg);
}

.valuesSection_inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--sp12);
  align-items: start;
}

.valuesSection_imageCol {
  position: relative;
}

.valuesSection_img {
  inline-size: 100%;
  block-size: 520px;
  object-fit: cover;
  border-radius: var(--rXl);
  box-shadow: var(--shadowXl);
}

.valuesSection_imgCard {
  position: absolute;
  bottom: var(--sp6);
  right: -var(--sp6);
  background: var(--clrSecondary);
  color: white;
  padding: var(--sp4) var(--sp5);
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  gap: var(--sp3);
  font-size: 0.88rem;
  font-weight: 600;
  box-shadow: var(--shadowLg);
  right: calc(-1 * var(--sp6));
}
.valuesSection_imgCard i {
  font-size: 1.1rem;
}

.valuesSection_title {
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block: var(--sp3) var(--sp4);
}

.valuesSection_intro {
  color: var(--clrTextMuted);
  margin-block-end: var(--sp8);
  line-height: 1.75;
}

.valueItem {
  display: flex;
  gap: var(--sp4);
  margin-block-end: var(--sp6);
  padding-block-end: var(--sp6);
  border-block-end: 1px solid var(--clrBorderLight);
}

.valueItem:last-child {
  border-block-end: none;
  margin-block-end: 0;
}

.valueItem_icon {
  inline-size: 44px;
  block-size: 44px;
  background: linear-gradient(135deg, rgba(30,111,168,0.1), rgba(0,180,216,0.1));
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  color: var(--clrSecondary);
  flex-shrink: 0;
  margin-block-start: var(--sp1);
}

.valueItem_title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp2);
}

.valueItem_body p {
  font-size: 0.88rem;
  color: var(--clrTextMuted);
  line-height: 1.7;
}


.compareSection {
  padding-block: var(--sp24);
  background: var(--clrSurface);
}

.compareLayout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp5);
}

.compareCol {
  border-radius: var(--rLg);
  overflow: hidden;
  box-shadow: var(--shadowMd);
}

.compareCol_head {
  padding: var(--sp6);
  display: flex;
  align-items: center;
  gap: var(--sp4);
}

.compareCol_head h3 {
  font-size: 1.05rem;
  font-weight: 700;
}

.compareCol_head i {
  font-size: 1.3rem;
}

.compareCol--a .compareCol_head {
  background: var(--clrPrimary);
  color: white;
}
.compareCol--a .compareCol_head i {
  color: var(--clrAccent);
}

.compareCol--b .compareCol_head {
  background: var(--clrBgAlt);
  color: var(--clrPrimary);
}
.compareCol--b .compareCol_head i {
  color: var(--clrTextMuted);
}

.compareList {
  padding: var(--sp5) var(--sp6);
  background: var(--clrSurface);
  display: flex;
  flex-direction: column;
  gap: var(--sp3);
}

.compareList_item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp3);
  font-size: 0.9rem;
  line-height: 1.5;
  padding-block: var(--sp2);
}

.compareList_item i {
  flex-shrink: 0;
  margin-block-start: 2px;
  font-size: 0.85rem;
}

.compareList_item--yes i { color: #22c55e; }
.compareList_item--no i { color: #ef4444; }
.compareList_item--neutral i { color: var(--clrTextMuted); }


.tableSection {
  padding-block: var(--sp24);
  background: var(--clrBg);
}

.tableWrap {
  overflow-x: auto;
  border-radius: var(--rLg);
  box-shadow: var(--shadowLg);
}

.comparisonTable {
  inline-size: 100%;
  border-collapse: collapse;
  background: var(--clrSurface);
  min-inline-size: 600px;
}

.comparisonTable th,
.comparisonTable td {
  padding: var(--sp4) var(--sp5);
  text-align: center;
  border-block-end: 1px solid var(--clrBorderLight);
  font-size: 0.9rem;
}

.comparisonTable th {
  background: var(--clrPrimary);
  color: white;
  font-weight: 700;
  font-size: 0.85rem;
}

.comparisonTable_feature {
  text-align: start !important;
}

.comparisonTable td:first-child {
  text-align: start;
  font-weight: 500;
  color: var(--clrText);
}

.comparisonTable_tier--recommended {
  background: var(--clrSecondary) !important;
  position: relative;
}

.tierBadge {
  display: inline-block;
  font-size: 0.65rem;
  background: var(--clrAccent);
  color: var(--clrPrimary);
  padding: 2px 8px;
  border-radius: var(--rFull);
  margin-inline-start: var(--sp2);
  font-weight: 700;
  vertical-align: middle;
}

.comparisonTable tbody tr:hover {
  background: var(--clrBgAlt);
}

.comparisonTable td:nth-child(3) {
  background: rgba(30,111,168,0.04);
}

.tableCheck { color: #22c55e; font-size: 1rem; }
.tableMinus { color: var(--clrBorder); font-size: 0.9rem; }

.tableSection_note {
  text-align: center;
  margin-block-start: var(--sp6);
  font-size: 0.9rem;
  color: var(--clrTextMuted);
}


.gallerySection {
  padding-block: var(--sp24);
  background: var(--clrSurface);
}

.galleryGrid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 240px 240px;
  gap: var(--sp3);
}

.galleryItem {
  position: relative;
  overflow: hidden;
  border-radius: var(--rLg);
  box-shadow: var(--shadowMd);
}

.galleryItem--wide {
  grid-column: 1;
  grid-row: 1 / 3;
}

.galleryItem--tall {
  grid-row: 1 / 3;
}

.galleryItem_img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  transition: transform var(--transSlow);
}

.galleryItem:hover .galleryItem_img {
  transform: scale(1.06);
}

.galleryItem_overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(10,31,56,0.75) 0%, transparent 60%);
  display: flex;
  align-items: flex-end;
  padding: var(--sp4);
  opacity: 0;
  transition: opacity var(--transBase);
}

.galleryItem:hover .galleryItem_overlay {
  opacity: 1;
}

.galleryItem_overlay span {
  color: white;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.05em;
}


.faqSection {
  padding-block: var(--sp24);
  background: var(--clrBg);
}

.faqSection_inner {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: var(--sp12);
  align-items: start;
}

.faqSection_title {
  font-size: clamp(1.4rem, 2.5vw, 1.9rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block: var(--sp3) var(--sp4);
}

.faqSection_head p {
  color: var(--clrTextMuted);
  font-size: 0.95rem;
  line-height: 1.7;
}

.faqList {
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
}

.faqItem {
  background: var(--clrSurface);
  border-radius: var(--rMd);
  border: 1px solid var(--clrBorderLight);
  overflow: hidden;
  transition: box-shadow var(--transBase);
}

.faqItem:has(.faqItem_trigger[aria-expanded="true"]) {
  box-shadow: var(--shadowMd);
  border-color: var(--clrBorder);
}

.faqItem_trigger {
  inline-size: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp4);
  padding: var(--sp5) var(--sp6);
  text-align: start;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--clrPrimary);
  background: none;
  cursor: pointer;
  transition: background var(--transBase);
  min-block-size: 44px;
}

.faqItem_trigger:hover {
  background: var(--clrBgAlt);
}

.faqItem_icon {
  flex-shrink: 0;
  color: var(--clrSecondary);
  font-size: 0.85rem;
  transition: transform var(--transBase);
}

.faqItem_trigger[aria-expanded="true"] .faqItem_icon {
  transform: rotate(45deg);
}

.faqItem_body {
  max-block-size: 0;
  overflow: hidden;
  transition: max-block-size var(--transSlow);
}

.faqItem_body p {
  padding: 0 var(--sp6) var(--sp5);
  font-size: 0.9rem;
  color: var(--clrTextMuted);
  line-height: 1.75;
}


.ctaSection {
  padding-block: var(--sp16);
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--clrPrimaryDark) 0%, var(--clrPrimary) 60%, var(--clrPrimaryLight) 100%);
}

.ctaSection .container {
  position: relative;
  z-index: 2;
}

.ctaBanner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp10);
  align-items: center;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--rXl);
  padding: var(--sp10);
  backdrop-filter: blur(10px);
}

.ctaBanner_title {
  font-size: clamp(1.5rem, 2.5vw, 2.2rem);
  font-weight: 800;
  color: white;
  margin-block-end: var(--sp4);
}

.ctaBanner_text {
  font-size: 1rem;
  color: rgba(255,255,255,0.7);
  line-height: 1.7;
  margin-block-end: var(--sp6);
}

.ctaBanner_actions {
  display: flex;
  gap: var(--sp3);
  flex-wrap: wrap;
}

.ctaBanner_img {
  inline-size: 100%;
  block-size: 280px;
  object-fit: cover;
  border-radius: var(--rLg);
  box-shadow: var(--shadowXl);
}


.contactPreview {
  padding-block: var(--sp24);
  background: var(--clrBgAlt);
}

.contactPreview_inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp10);
  align-items: start;
}

.contactPreview_title {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block: var(--sp3) var(--sp4);
}

.contactPreview_info p {
  color: var(--clrTextMuted);
  line-height: 1.7;
}

.contactPreview_details {
  display: flex;
  flex-direction: column;
  gap: var(--sp5);
  margin-block-start: var(--sp6);
}

.contactDetail {
  display: flex;
  gap: var(--sp4);
  align-items: flex-start;
}

.contactDetail_icon {
  inline-size: 40px;
  block-size: 40px;
  background: rgba(30,111,168,0.1);
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clrSecondary);
  flex-shrink: 0;
  font-size: 0.95rem;
}

.contactDetail strong {
  display: block;
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--clrTextMuted);
  margin-block-end: var(--sp1);
}

.contactDetail p,
.contactDetail a {
  font-size: 0.95rem;
  color: var(--clrText);
}
.contactDetail a:hover {
  color: var(--clrSecondary);
}

.contactPreview_card {
  position: relative;
}

.contactPreview_quickForm {
  background: var(--clrSurface);
  border-radius: var(--rXl);
  padding: var(--sp8);
  box-shadow: var(--shadowXl);
  border: 1px solid var(--clrBorderLight);
}

.contactPreview_quickForm h3 {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp6);
}


.formGroup {
  margin-block-end: var(--sp5);
}

.formLabel {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--clrText);
  margin-block-end: var(--sp2);
}

.formRequired {
  color: #ef4444;
}

.formInput {
  inline-size: 100%;
  padding: var(--sp3) var(--sp4);
  border: 1.5px solid var(--clrBorder);
  border-radius: var(--rMd);
  font-family: var(--fontMain);
  font-size: 0.95rem;
  color: var(--clrText);
  background: var(--clrSurface);
  transition: all var(--transBase);
  min-block-size: 44px;
  appearance: none;
}

.formInput:focus {
  outline: none;
  border-color: var(--clrSecondary);
  box-shadow: 0 0 0 3px rgba(30,111,168,0.12);
}

.formTextarea {
  min-block-size: 120px;
  resize: vertical;
}

.formGroup--checkbox {
  margin-block-end: var(--sp6);
}

.checkboxLabel {
  display: flex;
  align-items: flex-start;
  gap: var(--sp3);
  cursor: pointer;
  font-size: 0.85rem;
  color: var(--clrTextMuted);
  line-height: 1.6;
}

.checkboxLabel input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  inline-size: 0;
  block-size: 0;
}

.checkboxCustom {
  inline-size: 20px;
  block-size: 20px;
  border: 2px solid var(--clrBorder);
  border-radius: var(--rSm);
  flex-shrink: 0;
  transition: all var(--transBase);
  position: relative;
  margin-block-start: 1px;
}

.checkboxLabel input:checked + .checkboxCustom {
  background: var(--clrSecondary);
  border-color: var(--clrSecondary);
}

.checkboxLabel input:checked + .checkboxCustom::after {
  content: '';
  position: absolute;
  inset-inline-start: 5px;
  inset-block-start: 2px;
  inline-size: 6px;
  block-size: 10px;
  border: 2px solid white;
  border-block-start: none;
  border-inline-start: none;
  transform: rotate(45deg);
}

.formLink {
  color: var(--clrSecondary);
  text-decoration: underline;
}


.pageFooter {
  background: var(--clrPrimaryDark);
  padding-block: var(--sp16) var(--sp8);
  position: relative;
  overflow: hidden;
}

.pageFooter_dotGrid {
  --dotColor: rgba(255,255,255,0.03);
}

.pageFooter .container {
  position: relative;
  z-index: 2;
}

.pageFooter_grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr 1fr;
  gap: var(--sp8);
  padding-block-end: var(--sp10);
  border-block-end: 1px solid rgba(255,255,255,0.08);
}

.pageFooter_logo {
  block-size: 32px;
  inline-size: auto;
  margin-block-end: var(--sp4);
  filter: brightness(0) invert(1);
  opacity: 0.9;
}

.pageFooter_tagline {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.7;
  margin-block-end: var(--sp3);
}

.pageFooter_legal {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.3);
  line-height: 1.6;
  border-inline-start: 2px solid rgba(0,180,216,0.3);
  padding-inline-start: var(--sp3);
}

.pageFooter_colTitle {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  margin-block-end: var(--sp4);
}

.pageFooter_links {
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
}

.pageFooter_link {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  transition: color var(--transBase);
  padding-block: var(--sp1);
}
.pageFooter_link:hover {
  color: var(--clrAccent);
}

.pageFooter_address {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.8;
}

.pageFooter_address a {
  color: rgba(255,255,255,0.55);
  transition: color var(--transBase);
}
.pageFooter_address a:hover {
  color: var(--clrAccent);
}

.pageFooter_bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block-start: var(--sp6);
  font-size: 0.82rem;
  color: rgba(255,255,255,0.3);
  flex-wrap: wrap;
  gap: var(--sp4);
}

.pageFooter_legalLinks {
  display: flex;
  gap: var(--sp5);
}

.pageFooter_legalLinks a {
  color: rgba(255,255,255,0.3);
  font-size: 0.82rem;
  transition: color var(--transBase);
}
.pageFooter_legalLinks a:hover {
  color: var(--clrAccent);
}

.backToTop {
  position: fixed;
  bottom: var(--sp8);
  right: var(--sp8);
  inline-size: 52px;
  block-size: 52px;
  background: var(--clrSecondary);
  color: white;
  border-radius: var(--rFull);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  box-shadow: var(--shadowLg);
  opacity: 0;
  transform: translateY(20px);
  transition: all var(--transBase);
  z-index: 500;
  cursor: pointer;
}

.backToTop.backToTop--visible {
  opacity: 1;
  transform: translateY(0);
}

.backToTop:hover {
  background: var(--clrAccent);
  transform: translateY(-3px);
  box-shadow: var(--shadowXl);
}


.innerHero {
  padding-block: var(--sp16) var(--sp12);
  position: relative;
  overflow: hidden;
}

.innerHero--story {
  background: linear-gradient(135deg, var(--clrBg) 0%, var(--clrBgAlt) 100%);
  background-image: radial-gradient(circle, var(--dotColor) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
}

.innerHero--scope {
  background: var(--clrPrimary);
  background-image: radial-gradient(circle, rgba(255,255,255,0.04) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
}

.innerHero--scope .innerHero_title,
.innerHero--scope .innerHero_desc {
  color: white;
}
.innerHero--scope .innerHero_desc {
  color: rgba(255,255,255,0.7);
}
.innerHero--scope .breadcrumb_item a,
.innerHero--scope .breadcrumb_sep {
  color: rgba(255,255,255,0.5);
}
.innerHero--scope .breadcrumb_item--current {
  color: rgba(255,255,255,0.85);
}

.innerHero--matching {
  background: linear-gradient(135deg, var(--clrBgAlt) 0%, var(--clrBg) 100%);
  background-image: radial-gradient(circle, var(--dotColor) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
}

.innerHero--contact {
  background: var(--clrPrimary);
  background-image: radial-gradient(circle, rgba(255,255,255,0.04) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
}

.innerHero--contact .innerHero_title,
.innerHero--contact .innerHero_desc {
  color: white;
}
.innerHero--contact .innerHero_desc {
  color: rgba(255,255,255,0.7);
}
.innerHero--contact .breadcrumb_item a,
.innerHero--contact .breadcrumb_sep {
  color: rgba(255,255,255,0.5);
}
.innerHero--contact .breadcrumb_item--current {
  color: rgba(255,255,255,0.85);
}

.innerHero--legal {
  background: var(--clrBgAlt);
  background-image: radial-gradient(circle, var(--dotColor) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
}

.innerHero_title {
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block-end: var(--sp3);
}

.innerHero_desc {
  font-size: 1.05rem;
  color: var(--clrTextMuted);
  max-inline-size: 600px;
  line-height: 1.7;
}


.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--sp2);
  margin-block-end: var(--sp6);
  font-size: 0.82rem;
}

.breadcrumb_item a {
  color: var(--clrTextMuted);
  transition: color var(--transBase);
}
.breadcrumb_item a:hover {
  color: var(--clrSecondary);
}

.breadcrumb_sep {
  color: var(--clrBorder);
}

.breadcrumb_item--current {
  color: var(--clrText);
  font-weight: 600;
}


.storySection {
  padding-block: var(--sp20);
  background: var(--clrSurface);
}

.storySection_inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp12);
  align-items: center;
}

.storySection_title {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block-end: var(--sp5);
}

.storySection_text p {
  color: var(--clrTextMuted);
  line-height: 1.8;
  margin-block-end: var(--sp4);
}

.storySection_imageCol img {
  inline-size: 100%;
  block-size: 420px;
  object-fit: cover;
  border-radius: var(--rXl);
  box-shadow: var(--shadowXl);
}

.storyMission {
  padding-block: var(--sp16);
  background: var(--clrBg);
}

.storyMission_inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp5);
}

.storyMission_card {
  background: var(--clrSurface);
  border-radius: var(--rLg);
  padding: var(--sp8);
  text-align: center;
  border: 1px solid var(--clrBorderLight);
  box-shadow: var(--shadowSm);
  transition: all var(--transSlow);
}

.storyMission_card:hover {
  box-shadow: var(--shadowLg);
  transform: translateY(-4px);
}

.storyMission_icon {
  inline-size: 60px;
  block-size: 60px;
  background: linear-gradient(135deg, rgba(30,111,168,0.1), rgba(0,180,216,0.1));
  border-radius: var(--rFull);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--clrSecondary);
  margin-inline: auto;
  margin-block-end: var(--sp5);
}

.storyMission_card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp3);
}

.storyMission_card p {
  font-size: 0.88rem;
  color: var(--clrTextMuted);
  line-height: 1.7;
}

.storyWhy {
  padding-block: var(--sp20);
  background: var(--clrSurface);
}

.storyWhy_inner {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: var(--sp12);
  align-items: center;
}

.storyWhy_img {
  inline-size: 100%;
  block-size: 480px;
  object-fit: cover;
  border-radius: var(--rXl);
  box-shadow: var(--shadowXl);
}

.storyWhy_text p {
  color: var(--clrTextMuted);
  line-height: 1.8;
  margin-block-end: var(--sp4);
}


.timelineSection {
  padding-block: var(--sp20);
  background: var(--clrBg);
}

.timeline {
  position: relative;
  max-inline-size: 800px;
  margin-inline: auto;
  padding-block: var(--sp4);
}

.timeline::before {
  content: '';
  position: absolute;
  inset-inline-start: 50%;
  inset-block: 0;
  inline-size: 2px;
  background: var(--clrBorderLight);
  transform: translateX(-50%);
}

.timeline_item {
  display: flex;
  justify-content: flex-end;
  padding-inline-end: calc(50% + var(--sp8));
  margin-block-end: var(--sp8);
  position: relative;
}

.timeline_item--right {
  justify-content: flex-start;
  padding-inline-end: 0;
  padding-inline-start: calc(50% + var(--sp8));
}

.timeline_marker {
  position: absolute;
  inset-inline-start: 50%;
  inset-block-start: var(--sp5);
  inline-size: 16px;
  block-size: 16px;
  background: var(--clrSecondary);
  border: 3px solid var(--clrSurface);
  border-radius: var(--rFull);
  transform: translateX(-50%);
  box-shadow: var(--shadowMd);
}

.timeline_content {
  background: var(--clrSurface);
  border-radius: var(--rLg);
  padding: var(--sp5) var(--sp6);
  box-shadow: var(--shadowMd);
  border: 1px solid var(--clrBorderLight);
  max-inline-size: 320px;
}

.timeline_year {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--clrAccent);
  display: block;
  margin-block-end: var(--sp2);
}

.timeline_content h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp2);
}

.timeline_content p {
  font-size: 0.85rem;
  color: var(--clrTextMuted);
  line-height: 1.7;
}


.scopeSection {
  padding-block: var(--sp20);
  background: var(--clrBg);
}

.scopeIntro {
  margin-block-end: var(--sp10);
}

.scopeIntro_card {
  background: rgba(30,111,168,0.06);
  border: 1px solid rgba(30,111,168,0.15);
  border-radius: var(--rLg);
  padding: var(--sp5) var(--sp6);
  display: flex;
  align-items: flex-start;
  gap: var(--sp4);
}

.scopeIntro_card i {
  color: var(--clrSecondary);
  font-size: 1.1rem;
  flex-shrink: 0;
  margin-block-start: 2px;
}

.scopeIntro_card p {
  font-size: 0.9rem;
  color: var(--clrText);
  line-height: 1.7;
}

.scopeGrid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp5);
}

.scopeCard {
  background: var(--clrSurface);
  border-radius: var(--rLg);
  border: 1px solid var(--clrBorderLight);
  box-shadow: var(--shadowSm);
  overflow: hidden;
  transition: box-shadow var(--transSlow);
}

.scopeCard:hover {
  box-shadow: var(--shadowLg);
}

.scopeCard_header {
  background: var(--clrPrimary);
  padding: var(--sp5) var(--sp6);
  display: flex;
  align-items: center;
  gap: var(--sp4);
}

.scopeCard_iconWrap {
  inline-size: 44px;
  block-size: 44px;
  background: rgba(0,180,216,0.2);
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--clrAccent);
  flex-shrink: 0;
}

.scopeCard_title {
  font-size: 1rem;
  font-weight: 700;
  color: white;
  flex: 1;
}

.scopeCard_phase {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--clrAccent);
  background: rgba(0,180,216,0.15);
  padding: 3px 10px;
  border-radius: var(--rFull);
  white-space: nowrap;
}

.scopeCard_body {
  padding: var(--sp6);
}

.scopeCard_body p {
  font-size: 0.9rem;
  color: var(--clrTextMuted);
  line-height: 1.75;
  margin-block-end: var(--sp4);
}

.scopeCard_body h4 {
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--clrSecondary);
  margin-block: var(--sp4) var(--sp3);
}

.scopeCard_body ul {
  list-style: disc;
  padding-inline-start: var(--sp5);
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
}

.scopeCard_body ul li {
  font-size: 0.88rem;
  color: var(--clrTextMuted);
  line-height: 1.6;
}


.processSection {
  padding-block: var(--sp20);
  background: var(--clrSurface);
}

.processFlow {
  display: flex;
  align-items: flex-start;
  gap: var(--sp2);
  flex-wrap: wrap;
  justify-content: center;
}

.processStep {
  flex: 1;
  min-inline-size: 160px;
  max-inline-size: 200px;
  text-align: center;
  padding: var(--sp5);
  background: var(--clrBg);
  border-radius: var(--rLg);
  border: 1px solid var(--clrBorderLight);
  box-shadow: var(--shadowSm);
  transition: all var(--transSlow);
}

.processStep:hover {
  box-shadow: var(--shadowMd);
  transform: translateY(-3px);
}

.processStep_num {
  inline-size: 44px;
  block-size: 44px;
  background: var(--clrSecondary);
  color: white;
  border-radius: var(--rFull);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 800;
  margin-inline: auto;
  margin-block-end: var(--sp4);
  box-shadow: var(--shadowMd);
}

.processStep h3 {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp2);
}

.processStep p {
  font-size: 0.8rem;
  color: var(--clrTextMuted);
  line-height: 1.6;
}

.processStep_arrow {
  display: flex;
  align-items: center;
  color: var(--clrBorder);
  font-size: 1rem;
  padding-block-start: var(--sp8);
}


.matchingIntro {
  padding-block: var(--sp20);
  background: var(--clrSurface);
}

.matchingIntro_inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp12);
  align-items: center;
}

.matchingIntro_text h2 {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block-end: var(--sp5);
}

.matchingIntro_text p {
  color: var(--clrTextMuted);
  line-height: 1.8;
  margin-block-end: var(--sp4);
}

.matchingIntro_img {
  inline-size: 100%;
  block-size: 400px;
  object-fit: cover;
  border-radius: var(--rXl);
  box-shadow: var(--shadowXl);
}

.rolesSection {
  padding-block: var(--sp20);
  background: var(--clrBg);
}

.rolesGrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp5);
  margin-block-end: var(--sp6);
}

.roleCard {
  background: var(--clrSurface);
  border-radius: var(--rLg);
  padding: var(--sp6);
  border: 1px solid var(--clrBorderLight);
  box-shadow: var(--shadowSm);
  transition: all var(--transSlow);
}

.roleCard:hover {
  box-shadow: var(--shadowLg);
  transform: translateY(-3px);
  border-color: rgba(30,111,168,0.2);
}

.roleCard_icon {
  inline-size: 48px;
  block-size: 48px;
  background: linear-gradient(135deg, rgba(30,111,168,0.1), rgba(0,180,216,0.1));
  border-radius: var(--rMd);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: var(--clrSecondary);
  margin-block-end: var(--sp4);
}

.roleCard h3 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp3);
}

.roleCard p {
  font-size: 0.88rem;
  color: var(--clrTextMuted);
  line-height: 1.7;
}

.rolesSection_note {
  text-align: center;
  font-size: 0.9rem;
  color: var(--clrTextMuted);
  font-style: italic;
}

.evalSection {
  padding-block: var(--sp20);
  background: var(--clrSurface);
}

.evalGrid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp5);
}

.evalItem {
  background: var(--clrBg);
  border-radius: var(--rLg);
  padding: var(--sp6);
  border: 1px solid var(--clrBorderLight);
  position: relative;
  overflow: hidden;
  transition: all var(--transSlow);
}

.evalItem:hover {
  box-shadow: var(--shadowMd);
  transform: translateY(-2px);
}

.evalItem_bar {
  position: absolute;
  inset-block-start: 0;
  inset-inline-start: 0;
  inline-size: 4px;
  block-size: 100%;
  background: var(--barColor);
}

.evalItem h4 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp3);
}

.evalItem p {
  font-size: 0.88rem;
  color: var(--clrTextMuted);
  line-height: 1.75;
}


.tipsSection {
  padding-block: var(--sp20);
  background: var(--clrBg);
}

.tipsSwiper {
  padding-block-end: var(--sp10) !important;
}

.tipCard {
  background: var(--clrSurface);
  border-radius: var(--rLg);
  padding: var(--sp8);
  border: 1px solid var(--clrBorderLight);
  box-shadow: var(--shadowMd);
  min-block-size: 220px;
}

.tipCard_num {
  font-size: 2.5rem;
  font-weight: 800;
  color: rgba(30,111,168,0.1);
  margin-block-end: var(--sp4);
  line-height: 1;
}

.tipCard h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clr
Primary);
  margin-block-end: var(--sp3);
}

.tipCard p {
  font-size: 0.9rem;
  color: var(--clrTextMuted);
  line-height: 1.75;
}

.swiper-button-next,
.swiper-button-prev {
  color: var(--clrSecondary) !important;
}

.swiper-pagination-bullet-active {
  background: var(--clrSecondary) !important;
}

.matchingCta {
  padding-block: var(--sp16);
  background: var(--clrPrimary);
  background-image: radial-gradient(circle, rgba(255,255,255,0.04) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
}

.matchingCta_inner {
  text-align: center;
  max-inline-size: 600px;
  margin-inline: auto;
}

.matchingCta_inner h2 {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  font-weight: 800;
  color: white;
  margin-block-end: var(--sp4);
}

.matchingCta_inner p {
  color: rgba(255,255,255,0.7);
  line-height: 1.7;
  margin-block-end: var(--sp6);
}


.contactSection {
  padding-block: var(--sp20);
  background: var(--clrBg);
}

.contactSection_inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: var(--sp10);
  align-items: start;
}

.contactForm_card {
  background: var(--clrSurface);
  border-radius: var(--rXl);
  padding: var(--sp8);
  box-shadow: var(--shadowXl);
  border: 1px solid var(--clrBorderLight);
}

.contactForm_title {
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block-end: var(--sp2);
}

.contactForm_sub {
  font-size: 0.9rem;
  color: var(--clrTextMuted);
  line-height: 1.6;
  margin-block-end: var(--sp6);
}

.contactInfo_card {
  background: var(--clrSurface);
  border-radius: var(--rXl);
  padding: var(--sp8);
  box-shadow: var(--shadowLg);
  border: 1px solid var(--clrBorderLight);
  margin-block-end: var(--sp5);
}

.contactInfo_card h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp6);
  padding-block-end: var(--sp4);
  border-block-end: 1px solid var(--clrBorderLight);
}

.contactSection_info .contactDetail {
  margin-block-end: var(--sp5);
}

.contactInfo_note {
  background: rgba(30,111,168,0.06);
  border: 1px solid rgba(30,111,168,0.15);
  border-radius: var(--rMd);
  padding: var(--sp4) var(--sp5);
  display: flex;
  align-items: flex-start;
  gap: var(--sp3);
  margin-block-end: var(--sp5);
}

.contactInfo_note i {
  color: var(--clrSecondary);
  flex-shrink: 0;
  margin-block-start: 2px;
}

.contactInfo_note p {
  font-size: 0.82rem;
  color: var(--clrTextMuted);
  line-height: 1.6;
}

.contactMap {
  border-radius: var(--rLg);
  overflow: hidden;
  box-shadow: var(--shadowMd);
}


.legalSection {
  padding-block: var(--sp16) var(--sp20);
  background: var(--clrBg);
}

.legalContent {
  max-inline-size: 820px;
  margin-inline: auto;
  background: var(--clrSurface);
  border-radius: var(--rXl);
  padding: var(--sp10);
  box-shadow: var(--shadowLg);
  border: 1px solid var(--clrBorderLight);
}

.legalIntro {
  margin-block-end: var(--sp8);
  padding-block-end: var(--sp8);
  border-block-end: 1px solid var(--clrBorderLight);
}

.legalIntro p {
  font-size: 0.95rem;
  color: var(--clrText);
  line-height: 1.8;
}

.legalContent h2 {
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block: var(--sp8) var(--sp4);
  padding-block-start: var(--sp6);
  border-block-start: 1px solid var(--clrBorderLight);
}

.legalContent h2:first-of-type {
  border-block-start: none;
  padding-block-start: 0;
}

.legalContent h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block: var(--sp5) var(--sp3);
}

.legalContent p {
  font-size: 0.92rem;
  color: var(--clrTextMuted);
  line-height: 1.8;
  margin-block-end: var(--sp4);
}

.legalContent ul {
  list-style: disc;
  padding-inline-start: var(--sp6);
  margin-block-end: var(--sp4);
  display: flex;
  flex-direction: column;
  gap: var(--sp2);
}

.legalContent ul li {
  font-size: 0.92rem;
  color: var(--clrTextMuted);
  line-height: 1.7;
}

.legalContent a {
  color: var(--clrSecondary);
  text-decoration: underline;
}

.legalTerm {
  color: var(--clrSecondary);
  font-weight: 700;
  border-block-end: 1px dashed var(--clrSecondary);
  cursor: help;
}

.legalDefinition {
  background: rgba(30,111,168,0.05);
  border-inline-start: 3px solid var(--clrSecondary);
  border-radius: 0 var(--rMd) var(--rMd) 0;
  padding: var(--sp4) var(--sp5);
  margin-block: var(--sp4) var(--sp6);
  font-size: 0.88rem;
  color: var(--clrText);
  line-height: 1.7;
}

.legalDefinition strong {
  display: block;
  color: var(--clrPrimary);
  margin-block-end: var(--sp2);
  font-size: 0.85rem;
}

.legalAddress {
  background: var(--clrBgAlt);
  border-radius: var(--rMd);
  padding: var(--sp4) var(--sp5);
  font-size: 0.9rem;
  color: var(--clrText);
  line-height: 1.9;
  margin-block-start: var(--sp2);
}


.legalContent--terms .termsClause {
  margin-block-end: var(--sp6);
  padding-block-end: var(--sp6);
  border-block-end: 1px solid var(--clrBorderLight);
}

.legalContent--terms .termsClause:last-child {
  border-block-end: none;
}

.termsClause_num {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--clrAccent);
  margin-block-end: var(--sp2);
}

.termsClause_title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--clrPrimary);
  margin-block-end: var(--sp4);
  border: none !important;
  padding: 0 !important;
  margin-block-start: 0 !important;
}


.cookieTechSection {
  margin-block-end: var(--sp8);
  padding-block-end: var(--sp8);
  border-block-end: 1px solid var(--clrBorderLight);
}

.cookieTechSection:last-child {
  border-block-end: none;
  margin-block-end: 0;
}

.cookieTechSection h2 {
  border-block-start: none !important;
  padding-block-start: 0 !important;
  margin-block-start: 0 !important;
}

.cookieTable_wrap {
  overflow-x: auto;
  margin-block: var(--sp4);
  border-radius: var(--rMd);
  box-shadow: var(--shadowSm);
}

.cookieTable {
  inline-size: 100%;
  border-collapse: collapse;
  min-inline-size: 500px;
  font-size: 0.85rem;
}

.cookieTable th {
  background: var(--clrPrimary);
  color: white;
  padding: var(--sp3) var(--sp4);
  text-align: start;
  font-weight: 700;
  font-size: 0.8rem;
}

.cookieTable td {
  padding: var(--sp3) var(--sp4);
  border-block-end: 1px solid var(--clrBorderLight);
  color: var(--clrTextMuted);
  background: var(--clrSurface);
  vertical-align: top;
}

.cookieTable tr:last-child td {
  border-block-end: none;
}

.cookieTable code {
  background: var(--clrBgAlt);
  padding: 2px 6px;
  border-radius: var(--rSm);
  font-size: 0.82rem;
  color: var(--clrSecondary);
  font-family: monospace;
}

.legalContent code {
  background: var(--clrBgAlt);
  padding: 2px 6px;
  border-radius: var(--rSm);
  font-size: 0.85rem;
  color: var(--clrSecondary);
  font-family: monospace;
}


.thanksPage {
  min-block-size: calc(100vh - 200px);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--clrBg);
  background-image: radial-gradient(circle, var(--dotColor) var(--dotSize), transparent var(--dotSize));
  background-size: var(--dotSpacing) var(--dotSpacing);
}

.thanksPage_inner {
  text-align: center;
  padding: var(--sp8);
}

.thanksDot {
  inline-size: 80px;
  block-size: 80px;
  background: var(--clrSecondary);
  border-radius: var(--rFull);
  margin-inline: auto;
  margin-block-end: var(--sp8);
  animation: dotScale 0.8s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
  transform: scale(0);
}

.thanksPage_title {
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 800;
  color: var(--clrPrimary);
  margin-block-end: var(--sp6);
  opacity: 0;
  animation: fadeInUp 0.6s ease 0.8s forwards;
}

.thanksPage_link {
  display: inline-flex;
  align-items: center;
  gap: var(--sp2);
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--clrSecondary);
  opacity: 0;
  animation: fadeInUp 0.5s ease 1.4s forwards;
  border-block-end: 2px solid var(--clrBorder);
  padding-block-end: var(--sp1);
  transition: all var(--transBase);
}

.thanksPage_link:hover {
  color: var(--clrAccent);
  border-block-end-color: var(--clrAccent);
}

@keyframes dotScale {
  0% { transform: scale(0); opacity: 0; }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}




@media (max-width: 1024px) {
  .siteNav_links {
    display: none;
  }

  .siteNav_cta {
    display: none;
  }

  .siteNav_hamburger {
    display: flex;
  }

  .mainHero {
    grid-template-columns: 1fr;
    min-block-size: auto;
    padding-block: var(--sp16);
    gap: var(--sp10);
  }

  .mainHero_container {
    padding-inline: var(--sp6);
    order: 1;
  }

  .mainHero_imageWrap {
    padding-inline: var(--sp6);
    order: 2;
  }

  .mainHero_image {
    block-size: 400px;
  }

  .mainHero_floatCard--tl,
  .mainHero_floatCard--bl {
    display: none;
  }

  .mainHero_floatCard--tr {
    top: 10px;
    right: 20px;
  }

  .mainHero_floatCard--br {
    bottom: 20px;
    right: 20px;
  }

  .servicesGrid {
    grid-template-columns: 1fr 1fr;
  }

  .serviceCard--featured {
    grid-column: 1 / -1;
    grid-row: auto;
    display: grid;
    grid-template-columns: 1fr 1.5fr;
  }

  .serviceCard--featured .serviceCard_imgWrap {
    block-size: auto;
  }

  .whyGrid {
    grid-template-columns: 1fr;
  }

  .valuesSection_inner {
    grid-template-columns: 1fr;
    gap: var(--sp8);
  }

  .valuesSection_img {
    block-size: 350px;
  }

  .compareLayout {
    grid-template-columns: 1fr;
  }

  .ctaBanner {
    grid-template-columns: 1fr;
  }

  .ctaBanner_img {
    block-size: 220px;
  }

  .contactPreview_inner {
    grid-template-columns: 1fr;
  }

  .pageFooter_grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp6);
  }

  .pageFooter_brand {
    grid-column: 1 / -1;
  }

  .storySection_inner {
    grid-template-columns: 1fr;
  }

  .storyMission_inner {
    grid-template-columns: 1fr;
  }

  .storyWhy_inner {
    grid-template-columns: 1fr;
  }

  .scopeGrid {
    grid-template-columns: 1fr;
  }

  .matchingIntro_inner {
    grid-template-columns: 1fr;
  }

  .rolesGrid {
    grid-template-columns: repeat(2, 1fr);
  }

  .evalGrid {
    grid-template-columns: 1fr;
  }

  .contactSection_inner {
    grid-template-columns: 1fr;
  }

  .faqSection_inner {
    grid-template-columns: 1fr;
  }

  .galleryGrid {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }

  .galleryItem--wide {
    grid-column: 1 / -1;
    grid-row: auto;
    block-size: 280px;
  }

  .galleryItem--tall {
    grid-row: auto;
  }

  .galleryItem {
    block-size: 200px;
  }

  .timeline::before {
    display: none;
  }

  .timeline_item,
  .timeline_item--right {
    justify-content: flex-start;
    padding-inline: 0;
    padding-inline-start: var(--sp8);
  }

  .timeline_marker {
    inset-inline-start: 0;
    transform: none;
  }

  .timeline_content {
    max-inline-size: 100%;
  }

  .processFlow {
    gap: var(--sp4);
  }

  .processStep_arrow {
    display: none;
  }

  .processStep {
    min-inline-size: 140px;
  }
}


@media (max-width: 767px) {
  :root {
    --sp24: 4rem;
    --sp20: 3rem;
    --sp16: 2.5rem;
  }

  .container {
    padding-inline: var(--sp4);
  }

  .cookieBar_inner {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--sp3);
  }

  .mainHero {
    padding-block: var(--sp12) var(--sp8);
  }

  .mainHero_title {
    font-size: clamp(1.8rem, 6vw, 2.5rem);
  }

  .mainHero_image {
    block-size: 280px;
  }

  .mainHero_floatCard {
    display: none;
  }

  .mainHero_imageBadge {
    font-size: 0.78rem;
    padding: var(--sp2) var(--sp3);
  }

  .mainHero_actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .servicesGrid {
    grid-template-columns: 1fr;
  }

  .serviceCard--featured {
    grid-column: auto;
    grid-template-columns: 1fr;
  }

  .serviceCard--featured .serviceCard_imgWrap {
    block-size: 200px;
  }

  .whyGrid {
    grid-template-columns: 1fr;
    gap: var(--sp4);
  }

  .valuesSection_img {
    block-size: 260px;
  }

  .valuesSection_imgCard {
    right: var(--sp4);
    font-size: 0.8rem;
    padding: var(--sp3);
  }

  .compareLayout {
    grid-template-columns: 1fr;
  }

  .tableWrap {
    border-radius: var(--rMd);
  }

  .galleryGrid {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .galleryItem,
  .galleryItem--wide,
  .galleryItem--tall {
    grid-column: auto;
    grid-row: auto;
    block-size: 200px;
  }

  .faqSection_inner {
    grid-template-columns: 1fr;
    gap: var(--sp6);
  }

  .ctaBanner {
    padding: var(--sp6);
    gap: var(--sp6);
  }

  .ctaBanner_visual {
    display: none;
  }

  .contactPreview_inner {
    grid-template-columns: 1fr;
    gap: var(--sp6);
  }

  .pageFooter_grid {
    grid-template-columns: 1fr;
  }

  .pageFooter_bottom {
    flex-direction: column;
    text-align: center;
  }

  .pageFooter_legalLinks {
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--sp3);
  }

  .backToTop {
    bottom: var(--sp4);
    right: var(--sp4);
    inline-size: 44px;
    block-size: 44px;
  }

  .storySection_inner,
  .storyWhy_inner {
    grid-template-columns: 1fr;
    gap: var(--sp6);
  }

  .storySection_imageCol img,
  .storyWhy_img {
    block-size: 240px;
  }

  .storyMission_inner {
    grid-template-columns: 1fr;
  }

  .scopeGrid {
    grid-template-columns: 1fr;
  }

  .matchingIntro_inner {
    grid-template-columns: 1fr;
    gap: var(--sp6);
  }

  .matchingIntro_img {
    block-size: 260px;
  }

  .rolesGrid {
    grid-template-columns: 1fr;
  }

  .evalGrid {
    grid-template-columns: 1fr;
  }

  .contactSection_inner {
    grid-template-columns: 1fr;
    gap: var(--sp6);
  }

  .processFlow {
    flex-direction: column;
    align-items: stretch;
  }

  .processStep {
    max-inline-size: 100%;
    text-align: start;
    display: flex;
    gap: var(--sp4);
    align-items: flex-start;
  }

  .processStep_num {
    flex-shrink: 0;
    margin: 0;
  }

  .mobileMenu_left {
    flex: 1.2;
  }

  .mobileMenu_right {
    flex: 0.8;
  }

  .legalContent {
    padding: var(--sp6);
  }

  .ctaBanner_actions {
    flex-direction: column;
    align-items: flex-start;
  }

  .sectionHead_title {
    font-size: clamp(1.4rem, 4vw, 2rem);
  }

  .innerHero {
    padding-block: var(--sp10) var(--sp8);
  }

  .innerHero_title {
    font-size: clamp(1.6rem, 5vw, 2.2rem);
  }
}


@media (max-width: 380px) {
  .mobileMenu_right {
    display: none;
  }

  .mobileMenu_left {
    flex: 1;
  }

  .mainHero_actions .btn {
    inline-size: 100%;
    justify-content: center;
  }
}


@media print {
  .siteHeader,
  .cookieBar,
  .mobileMenu,
  .searchOverlay,
  .backToTop {
    display: none;
  }
}