.elementor-kit-3{--e-global-color-primary:#0F1C2B;--e-global-color-secondary:#F3F3F1;--e-global-color-text:#111923;--e-global-color-accent:#B8B4AD;--e-global-typography-primary-font-family:"Cormorant Garamond";--e-global-typography-primary-font-weight:600;--e-global-typography-secondary-font-family:"Inter Tight";--e-global-typography-secondary-font-weight:400;--e-global-typography-text-font-family:"Roboto";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Roboto";--e-global-typography-accent-font-weight:500;}.elementor-kit-3 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* ============================================================
   CROWN BRIDGE CONSULTING — ELEMENTOR-SAFE CSS
   No direct-child .elementor-kit-3s. No escaped .elementor-kit-3s.
   ============================================================ */

/* FONT INJECTION */

@font-face {
  font-family: "CMU Serif";
  src: url("/wp-content/mu-plugins/ottero-crownbridge/assets/fonts/cmunrm.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "CMU Serif";
  src: url("/wp-content/mu-plugins/ottero-crownbridge/assets/fonts/cmunti.woff") format("woff");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "CMU Serif";
  src: url("/wp-content/mu-plugins/ottero-crownbridge/assets/fonts/cmunbx.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "CMU Serif";
  src: url("/wp-content/mu-plugins/ottero-crownbridge/assets/fonts/cmunbi.woff") format("woff");
  font-weight: 700;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: "Perandory";
  src: url("/wp-content/mu-plugins/ottero-crownbridge/assets/fonts/PerandorySemiCondensed.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* TOKENS */

:root {
  --cb-navy: #0F1C2B;
  --cb-navy-deep: #071426;
  --cb-bone: #F3F3F1;
  --cb-bone-soft: #F3F3F1;
  --cb-ink: #111923;
  --cb-ink-soft: #24303D;
  --cb-grey: #B8B4AD;

  --cb-line: rgba(15, 28, 43, 0.10);
  --cb-line-strong: rgba(15, 28, 43, 0.16);
  --cb-line-light: rgba(245, 243, 239, 0.18);

  --cb-serif: "CMU Serif", Georgia, serif;
  --cb-display: "CMU Serif", Georgia, serif;
  --cb-institutional: "Perandory", "Inter Tight", Arial, sans-serif;
}

/* BASE */

html,
body {
  margin: 0;
  padding: 0;
  background: var(--cb-bone);
  color: var(--cb-ink);
  font-family: var(--cb-serif);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body,
.site,
.elementor,
.elementor-page {
  background-color: var(--cb-bone) !important;
}

::selection {
  background: var(--cb-navy);
  color: var(--cb-bone);
}

/* TYPOGRAPHY */

p,
.elementor-widget-text-editor,
.elementor-widget-text-editor p {
  font-family: var(--cb-serif) !important;
  font-size: 19px;
  line-height: 1.85;
  color: var(--cb-ink-soft);
  font-weight: 400;
}

h1,
h2,
h3,
h4,
h5,
h6,
.elementor-heading-title {
  font-family: var(--cb-display) !important;
  color: var(--cb-ink);
  font-weight: 400 !important;
  letter-spacing: -0.025em;
}

h1,
.elementor-widget-heading h1.elementor-heading-title {
  font-size: clamp(54px, 6vw, 94px) !important;
  line-height: 1.05 !important;
  letter-spacing: -0.035em;
}

h2,
.elementor-widget-heading h2.elementor-heading-title {
  font-size: clamp(44px, 4.6vw, 72px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.032em;
}

h3,
.elementor-widget-heading h3.elementor-heading-title {
  font-size: clamp(30px, 3vw, 45px) !important;
  line-height: 1.12 !important;
}

h6,
.elementor-widget-heading h6.elementor-heading-title {
  font-family: var(--cb-institutional) !important;
  font-size: 12px !important;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

/* LINKS */

a {
  color: inherit;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.22em;
  transition: opacity 220ms ease;
}

a:hover {
  opacity: 0.72;
}

/* HEADER */

header,
.elementor-location-header {
  background: var(--cb-bone) !important;
  border-bottom: 1px solid rgba(15, 28, 43, 0.08);
}

.elementor-location-header .elementor-container,
.elementor-location-header .e-con {
  min-height: 92px !important;
}

.elementor-location-header img {
  max-height: 58px;
  width: auto;
  opacity: 0.92;
  filter: grayscale(1) contrast(0.95);
}

.elementor-nav-menu a,
.elementor-item,
.elementor-location-header a {
  font-family: var(--cb-institutional) !important;
  font-size: 12px !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cb-ink) !important;
  font-weight: 400 !important;
}

.elementor-nav-menu .sub-arrow {
  display: none !important;
}

/* HERO */

.home .elementor-section:first-of-type,
.home .elementor-top-section:first-of-type {
  min-height: 92vh;
  background:
    radial-gradient(circle at 76% 34%, rgba(245,243,239,0.055), transparent 30%),
    linear-gradient(180deg, var(--cb-navy-deep), var(--cb-navy)) !important;
  position: relative;
  overflow: hidden;
}

.home .elementor-section:first-of-type::after,
.home .elementor-top-section:first-of-type::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(circle at center, transparent 42%, rgba(0,0,0,0.26) 100%),
    repeating-linear-gradient(
      0deg,
      rgba(245,243,239,0.012),
      rgba(245,243,239,0.012) 1px,
      transparent 1px,
      transparent 5px
    );
  opacity: 0.62;
}

.home .elementor-section:first-of-type .elementor-container,
.home .elementor-top-section:first-of-type .elementor-container,
.home .elementor-section:first-of-type .e-con,
.home .elementor-top-section:first-of-type .e-con,
.home .elementor-section:first-of-type .elementor-widget,
.home .elementor-top-section:first-of-type .elementor-widget {
  position: relative;
  z-index: 2;
}

.home .elementor-section:first-of-type .elementor-container,
.home .elementor-top-section:first-of-type .elementor-container {
  min-height: 92vh;
  align-items: center;
}

.home .elementor-section:first-of-type h1,
.home .elementor-top-section:first-of-type h1 {
  max-width: 1200px !important;
  color: var(--cb-bone) !important;
  font-size: clamp(54px, 6.2vw, 96px) !important;
  line-height: 1.04 !important;
}

.home .elementor-section:first-of-type p,
.home .elementor-top-section:first-of-type p {
  max-width: 880px !important;
  color: rgba(245,243,239,0.84) !important;
  font-size: 21px;
  line-height: 1.75;
}

.home .elementor-section:first-of-type h6,
.home .elementor-top-section:first-of-type h6 {
  color: rgba(245,243,239,0.9) !important;
}

/* GLOBAL LAYOUT */

.elementor-section,
.elementor-top-section,
.e-con,
.elementor-widget-container {
  box-shadow: none !important;
  border-radius: 0 !important;
}

.home section:not(:first-of-type),
.home .elementor-top-section:not(:first-of-type),
.cb-why-section,
.cb-services-section,
.cb-architecture-section {
  background-color: var(--cb-bone) !important;
}

.home section:not(:first-of-type),
.home .elementor-top-section:not(:first-of-type) {
  padding-top: 140px !important;
  padding-bottom: 140px !important;
}

.elementor-column,
.e-con,
.elementor-widget-container {
  border-color: var(--cb-line) !important;
}

hr,
.elementor-divider-separator {
  border-color: var(--cb-line) !important;
}

/* BUTTONS */

.elementor-button,
button,
input[type="submit"] {
  background: transparent !important;
  color: var(--cb-ink) !important;
  border: 1px solid var(--cb-line-strong) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  font-family: var(--cb-institutional) !important;
  font-size: 12px !important;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 17px 30px !important;
}

.elementor-button:hover,
button:hover,
input[type="submit"]:hover {
  background: var(--cb-navy) !important;
  color: var(--cb-bone) !important;
  border-color: var(--cb-navy) !important;
  opacity: 1;
}

/* IMAGES */

.elementor-widget-image img,
.wp-post-image {
  filter: grayscale(1) contrast(0.92) saturate(0);
}

/* FORMS */

input,
textarea,
select {
  background: transparent !important;
  border: 1px solid var(--cb-line) !important;
  border-radius: 0 !important;
  color: var(--cb-ink) !important;
  font-family: var(--cb-serif) !important;
  font-size: 18px !important;
}

/* WHY CROWN BRIDGE */

.cb-why-section {
  padding-top: 140px !important;
  padding-bottom: 140px !important;
}

.cb-why-section .e-con-inner,
.cb-why-section .elementor-container {
  max-width: 1400px !important;
  margin-left: auto;
  margin-right: auto;
}

.cb-why-section h2 {
  max-width: 1100px !important;
  margin-left: 0 !important;
  margin-bottom: 90px !important;
  text-align: left !important;
}

.cb-why-item {
  display: flex;
  gap: 0 !important;
  align-items: stretch;
  border-top: 1px solid var(--cb-line);
  border-bottom: 1px solid var(--cb-line);
}

.cb-why-item .e-con,
.cb-why-item .elementor-element {
  flex: 1;
  padding: 54px 44px !important;
  border-right: 1px solid rgba(15,28,43,0.08);
  min-height: 240px;
}

.cb-why-item .e-con:last-child,
.cb-why-item .elementor-element:last-child {
  border-right: none;
}

.cb-why-item .e-con:nth-child(2),
.cb-why-item .elementor-element:nth-child(2) {
  transform: translateY(36px);
}

.cb-why-item .e-con:nth-child(3),
.cb-why-item .elementor-element:nth-child(3) {
  transform: translateY(-18px);
}

.cb-why-item h3,
.cb-why-item .elementor-heading-title {
  font-size: 34px !important;
  line-height: 1.1 !important;
  margin-bottom: 24px !important;
}

.cb-why-item p {
  max-width: 330px;
  font-size: 18px;
  line-height: 1.75;
}

/* SERVICES */

.cb-services-section {
  padding-top: 140px !important;
  padding-bottom: 140px !important;
}

.cb-services-section h2 {
  font-size: clamp(48px, 4.6vw, 72px) !important;
  max-width: 980px !important;
  margin-bottom: 110px !important;
}

.cb-services-grid {
  display: grid !important;
  grid-template-columns: repeat(12, 1fr);
  gap: 0 !important;
  border-top: 1px solid var(--cb-line);
}

.cb-services-grid .e-con,
.cb-services-grid .elementor-element {
  border-top: 1px solid var(--cb-line);
  border-right: 1px solid rgba(15,28,43,0.08);
  border-bottom: 1px solid rgba(15,28,43,0.08);
  padding: 46px 40px !important;
  min-height: 250px;
  margin-top: 0 !important;
}

.cb-services-grid .e-con:nth-child(1),
.cb-services-grid .elementor-element:nth-child(1) {
  grid-column: span 5;
}

.cb-services-grid .e-con:nth-child(2),
.cb-services-grid .elementor-element:nth-child(2) {
  grid-column: span 7;
}

.cb-services-grid .e-con:nth-child(3),
.cb-services-grid .elementor-element:nth-child(3) {
  grid-column: span 4;
}

.cb-services-grid .e-con:nth-child(4),
.cb-services-grid .elementor-element:nth-child(4) {
  grid-column: span 8;
}

.cb-services-grid .e-con:nth-child(5),
.cb-services-grid .elementor-element:nth-child(5) {
  grid-column: span 6;
}

.cb-services-grid .e-con:nth-child(6),
.cb-services-grid .elementor-element:nth-child(6) {
  grid-column: span 6;
}

.cb-services-grid .e-con:nth-child(3n),
.cb-services-grid .elementor-element:nth-child(3n) {
  border-right: none;
}

.cb-services-grid h3 {
  font-size: 30px !important;
  line-height: 1.08 !important;
  margin-bottom: 22px !important;
}

.cb-services-grid p {
  max-width: 340px;
}

/* ARCHITECTURE */

.cb-architecture-section {
  background-color: var(--cb-bone) !important;
  padding-top: 150px !important;
  padding-bottom: 150px !important;
  border-top: 1px solid var(--cb-line);
}

.cb-architecture-section h2 {
  font-size: clamp(42px, 4.2vw, 68px) !important;
  line-height: 1.08 !important;
  max-width: 700px !important;
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.cb-architecture-section p {
  max-width: 720px;
  font-size: 20px;
  line-height: 1.9;
}

/* PROCESS */

.cb-process-section {
  padding-top: 140px !important;
  padding-bottom: 140px !important;
  background-color: var(--cb-bone-soft) !important;
  border-top: 1px solid var(--cb-line);
  border-bottom: 1px solid var(--cb-line);
}

.cb-process-section h2 {
  max-width: 1100px !important;
  margin-left: 0 !important;
  margin-bottom: 100px !important;
}

.cb-process-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--cb-line);
  border-bottom: 1px solid var(--cb-line);
}

.cb-process-grid .e-con,
.cb-process-grid .elementor-element {
  padding: 46px 40px !important;
  border-right: 1px solid rgba(15, 28, 43, 0.08);
  min-height: 210px;
}

.cb-process-grid .e-con:last-child,
.cb-process-grid .elementor-element:last-child {
  border-right: none;
}

.cb-process-grid h3,
.cb-process-grid .elementor-heading-title {
  font-size: 34px !important;
  line-height: 1.1 !important;
  margin-bottom: 24px !important;
}

.cb-process-grid p {
  max-width: 360px;
  font-size: 18px;
  line-height: 1.75;
}

/* FOOTER */

footer,
.elementor-location-footer {
  background: var(--cb-navy) !important;
  color: rgba(245,243,239,0.76) !important;
  border-top: 1px solid rgba(245,243,239,0.14);
  padding-top: 90px !important;
  padding-bottom: 40px !important;
}

footer p,
footer a,
.elementor-location-footer p,
.elementor-location-footer a {
  color: rgba(245,243,239,0.7) !important;
  font-family: var(--cb-serif) !important;
  font-size: 16px !important;
  line-height: 1.8;
}

footer h1,
footer h2,
footer h3,
footer h4,
footer .elementor-heading-title,
.elementor-location-footer h1,
.elementor-location-footer h2,
.elementor-location-footer h3,
.elementor-location-footer h4,
.elementor-location-footer .elementor-heading-title {
  color: var(--cb-bone) !important;
}

footer h2,
footer h3,
.elementor-location-footer h2,
.elementor-location-footer h3 {
  font-size: 24px !important;
}

footer a[href*="ottero"],
.elementor-location-footer a[href*="ottero"] {
  opacity: 0.22 !important;
  font-size: 11px !important;
  transition: opacity 220ms ease;
}

footer a[href*="ottero"]:hover,
.elementor-location-footer a[href*="ottero"]:hover {
  opacity: 0.55 !important;
}

/* CLEANUP */

.elementor-widget-spacer {
  display: none !important;
}

/* MOBILE */

@media (max-width: 767px) {
  p,
  .elementor-widget-text-editor p {
    font-size: 18px;
    line-height: 1.75;
  }

  h1,
  .elementor-widget-heading h1.elementor-heading-title {
    font-size: 46px !important;
  }

  h2,
  .elementor-widget-heading h2.elementor-heading-title {
    font-size: 40px !important;
  }

  .home section:not(:first-of-type),
  .home .elementor-top-section:not(:first-of-type),
  .cb-why-section,
  .cb-services-section,
  .cb-architecture-section,
  .cb-process-section {
    padding-top: 90px !important;
    padding-bottom: 90px !important;
  }

  .cb-why-item,
  .cb-services-grid,
  .cb-process-grid {
    display: flex !important;
    flex-direction: column !important;
  }

  .cb-why-item .e-con,
  .cb-why-item .elementor-element,
  .cb-services-grid .e-con,
  .cb-services-grid .elementor-element,
  .cb-process-grid .e-con,
  .cb-process-grid .elementor-element {
    transform: none !important;
    margin-top: 0 !important;
    grid-column: unset !important;
    border-right: none !important;
  }

  .cb-architecture-section h2 {
    text-align: left !important;
  }
}/* End custom CSS */