/* ============================================================
   LAYOUT — Nav, Footer, Container, Sections, Grid
   ============================================================ */

/* ---- Container ---- */
.container {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
}

/* ---- Sections ---- */
.section        { padding-block: var(--sp-20); }
.section--alt   { background: #f0f1f1; }
.section--blue  { background: var(--clr-primary-light); }
.section--dark  { background: var(--clr-primary-dark); color: var(--clr-white); }
.section--dark h2, .section--dark h3 { color: var(--clr-white); }

.section__header {
  text-align: center;
  margin-bottom: var(--sp-12);
}
.section__eyebrow {
  display: inline-block;
  font-size: var(--fs-sm);
  font-weight: var(--fw-m);
  color: var(--clr-gray-600);
  letter-spacing: 0.03em;
  margin-bottom: var(--sp-3);
}
.section--dark .section__eyebrow { color: rgba(255,255,255,.55); }
.section__title { margin-bottom: var(--sp-4); }
.section__lead {
  font-size: var(--fs-lg);
  color: var(--clr-gray-600);
  max-width: 700px;
  margin-inline: auto;
  margin-bottom: 0;
}
.section--dark .section__lead { color: rgba(255,255,255,.8); }

/* ---- Navigation ---- */
body { padding-top: 64px; }

.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  background: var(--clr-white);
  border-bottom: 1px solid var(--clr-gray-200);
  box-shadow: var(--sh-sm);
}
.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}
.nav__logo {
  font-size: var(--fs-xl);
  font-weight: var(--fw-b);
  color: var(--clr-primary-dark);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.nav__logo:hover { text-decoration: none; }
.nav__logo-icon {
  width: 32px; height: 32px;
  background: var(--clr-primary);
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--clr-white);
  font-size: var(--fs-base);
}
.nav__links {
  display: flex;
  align-items: center;
  gap: var(--sp-6);
}
.nav__link {
  font-size: var(--fs-sm);
  font-weight: var(--fw-m);
  color: var(--clr-gray-800);
  transition: color var(--tr);
}
.nav__link:hover, .nav__link.active { color: var(--clr-primary); text-decoration: none; }
.nav__link.active { font-weight: var(--fw-b); }

.nav__hamburger {
  display: none;
  background: none; border: none;
  cursor: pointer; padding: var(--sp-2);
  color: var(--clr-gray-800); font-size: 1.4rem;
  line-height: 1;
}

@media (max-width: 768px) {
  .nav__hamburger { display: block; }
  .nav__links {
    display: none;
    position: absolute;
    top: 64px; left: 0; right: 0;
    flex-direction: column;
    background: var(--clr-white);
    padding: var(--sp-6);
    gap: var(--sp-4);
    border-bottom: 1px solid var(--clr-gray-200);
    box-shadow: var(--sh);
  }
  .nav__links.open { display: flex; }
  .nav__cta-wrap { width: 100%; }
  .nav__cta-wrap .btn { width: 100%; }
}

/* ---- Footer ---- */
.footer {
  background: var(--clr-gray-900);
  color: var(--clr-gray-400);
  padding-block: var(--sp-12) var(--sp-8);
  border-top: 4px solid var(--clr-accent);
}
.footer__inner {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: var(--sp-10);
  margin-bottom: var(--sp-10);
}
.footer__brand {
  color: var(--clr-white);
  font-size: var(--fs-xl);
  font-weight: var(--fw-b);
  display: block;
  margin-bottom: var(--sp-3);
  letter-spacing: 0.02em;
}
.footer__tagline {
  font-size: var(--fs-sm);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-4);
  color: rgba(255,255,255,.6);
}
.footer__company {
  font-size: var(--fs-xs);
  font-weight: var(--fw-b);
  color: var(--clr-white);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-2);
}
.footer__heading {
  font-size: var(--fs-xs);
  font-weight: var(--fw-b);
  color: var(--clr-accent);
  letter-spacing: 0.08em;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-2);
  border-bottom: 1px solid rgba(0,151,167,.3);
}
.footer__nav { display: flex; flex-direction: column; gap: var(--sp-3); }
.footer__nav-link {
  font-size: var(--fs-sm);
  color: var(--clr-gray-400);
  transition: color var(--tr), padding-left var(--tr);
}
.footer__nav-link:hover {
  color: var(--clr-accent);
  padding-left: var(--sp-1);
  text-decoration: none;
}
.footer__bottom {
  padding-top: var(--sp-6);
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-4);
  font-size: var(--fs-xs);
  color: rgba(255,255,255,.4);
}

@media (max-width: 768px) {
  .footer__inner { grid-template-columns: 1fr; gap: var(--sp-8); }
  .footer__bottom { justify-content: center; text-align: center; }
}

/* ---- Grid Utilities ---- */
.grid   { display: grid; gap: var(--sp-6); }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }

@media (max-width: 1024px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}

/* ---- Page Hero (inner pages) ---- */
.page-hero {
  background: #0f172a;
  color: var(--clr-white);
  padding-block: var(--sp-16);
  text-align: center;
}
.page-hero h1 { color: var(--clr-white); margin-bottom: var(--sp-4); }
.page-hero p  {
  font-size: var(--fs-lg);
  opacity: .85;
  max-width: 640px;
  margin-inline: auto;
}
