.elementor-widget-icon.elementor-view-stacked .elementor-icon{background-color:var( --e-global-color-primary );}.elementor-widget-icon.elementor-view-framed .elementor-icon, .elementor-widget-icon.elementor-view-default .elementor-icon{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-widget-icon.elementor-view-framed .elementor-icon, .elementor-widget-icon.elementor-view-default .elementor-icon svg{fill:var( --e-global-color-primary );}.elementor-507 .elementor-element.elementor-element-pillar-1-icon .elementor-icon-wrapper{text-align:center;}.elementor-507 .elementor-element.elementor-element-pillar-1-icon.elementor-view-stacked .elementor-icon{background-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-1-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-1-icon.elementor-view-default .elementor-icon{color:#6EC1E400;border-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-1-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-1-icon.elementor-view-default .elementor-icon svg{fill:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-2-icon .elementor-icon-wrapper{text-align:center;}.elementor-507 .elementor-element.elementor-element-pillar-2-icon.elementor-view-stacked .elementor-icon{background-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-2-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-2-icon.elementor-view-default .elementor-icon{color:#6EC1E400;border-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-2-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-2-icon.elementor-view-default .elementor-icon svg{fill:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-3-icon .elementor-icon-wrapper{text-align:center;}.elementor-507 .elementor-element.elementor-element-pillar-3-icon.elementor-view-stacked .elementor-icon{background-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-3-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-3-icon.elementor-view-default .elementor-icon{color:#6EC1E400;border-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-3-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-3-icon.elementor-view-default .elementor-icon svg{fill:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-4-icon .elementor-icon-wrapper{text-align:center;}.elementor-507 .elementor-element.elementor-element-pillar-4-icon.elementor-view-stacked .elementor-icon{background-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-4-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-4-icon.elementor-view-default .elementor-icon{color:#6EC1E400;border-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-pillar-4-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-pillar-4-icon.elementor-view-default .elementor-icon svg{fill:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-1-icon{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + -5px) 0px;}.elementor-507 .elementor-element.elementor-element-service-1-icon .elementor-icon-wrapper{text-align:center;}.elementor-507 .elementor-element.elementor-element-service-1-icon.elementor-view-stacked .elementor-icon{background-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-1-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-service-1-icon.elementor-view-default .elementor-icon{color:#6EC1E400;border-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-1-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-service-1-icon.elementor-view-default .elementor-icon svg{fill:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-1-icon .elementor-icon{font-size:40px;}.elementor-507 .elementor-element.elementor-element-service-1-icon .elementor-icon svg{height:40px;}.elementor-507 .elementor-element.elementor-element-service-2-icon{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + -5px) 0px;}.elementor-507 .elementor-element.elementor-element-service-2-icon .elementor-icon-wrapper{text-align:center;}.elementor-507 .elementor-element.elementor-element-service-2-icon.elementor-view-stacked .elementor-icon{background-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-2-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-service-2-icon.elementor-view-default .elementor-icon{color:#6EC1E400;border-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-2-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-service-2-icon.elementor-view-default .elementor-icon svg{fill:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-2-icon .elementor-icon{font-size:40px;}.elementor-507 .elementor-element.elementor-element-service-2-icon .elementor-icon svg{height:40px;}.elementor-507 .elementor-element.elementor-element-service-3-icon{margin:0px 0px calc(var(--kit-widget-spacing, 0px) + -5px) 0px;}.elementor-507 .elementor-element.elementor-element-service-3-icon .elementor-icon-wrapper{text-align:center;}.elementor-507 .elementor-element.elementor-element-service-3-icon.elementor-view-stacked .elementor-icon{background-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-3-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-service-3-icon.elementor-view-default .elementor-icon{color:#6EC1E400;border-color:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-3-icon.elementor-view-framed .elementor-icon, .elementor-507 .elementor-element.elementor-element-service-3-icon.elementor-view-default .elementor-icon svg{fill:#6EC1E400;}.elementor-507 .elementor-element.elementor-element-service-3-icon .elementor-icon{font-size:40px;}.elementor-507 .elementor-element.elementor-element-service-3-icon .elementor-icon svg{height:40px;}.elementor-widget-form .elementor-field-group > label, .elementor-widget-form .elementor-field-subgroup label{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group > label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-type-html{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-field-group .elementor-field{color:var( --e-global-color-text );}.elementor-widget-form .elementor-field-group .elementor-field, .elementor-widget-form .elementor-field-subgroup label{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .elementor-button{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form .e-form__buttons__wrapper__button-next{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-button[type="submit"]{background-color:var( --e-global-color-accent );}.elementor-widget-form .e-form__buttons__wrapper__button-previous{background-color:var( --e-global-color-accent );}.elementor-widget-form .elementor-message{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-widget-form .e-form__indicators__indicator, .elementor-widget-form .e-form__indicators__indicator__label{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-widget-form{--e-form-steps-indicator-inactive-primary-color:var( --e-global-color-text );--e-form-steps-indicator-active-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-completed-primary-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-color:var( --e-global-color-accent );--e-form-steps-indicator-progress-background-color:var( --e-global-color-text );--e-form-steps-indicator-progress-meter-color:var( --e-global-color-text );}.elementor-widget-form .e-form__indicators__indicator__progress__meter{font-family:var( --e-global-typography-accent-font-family ), Sans-serif;font-weight:var( --e-global-typography-accent-font-weight );}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:10px;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-10px;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-field-group.recaptcha_v3-bottomleft, .elementor-507 .elementor-element.elementor-element-contact-form .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}body.rtl .elementor-507 .elementor-element.elementor-element-contact-form .elementor-labels-inline .elementor-field-group > label{padding-left:0px;}body:not(.rtl) .elementor-507 .elementor-element.elementor-element-contact-form .elementor-labels-inline .elementor-field-group > label{padding-right:0px;}body .elementor-507 .elementor-element.elementor-element-contact-form .elementor-labels-above .elementor-field-group > label{padding-bottom:0px;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-field-type-html{padding-bottom:0px;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .e-form__buttons__wrapper__button-next{color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-button[type="submit"]{color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .e-form__buttons__wrapper__button-previous{color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .e-form__buttons__wrapper__button-next:hover{color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-button[type="submit"]:hover{color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}.elementor-507 .elementor-element.elementor-element-contact-form{--e-form-steps-indicators-spacing:20px;--e-form-steps-indicator-padding:30px;--e-form-steps-indicator-inactive-secondary-color:#ffffff;--e-form-steps-indicator-active-secondary-color:#ffffff;--e-form-steps-indicator-completed-secondary-color:#ffffff;--e-form-steps-divider-width:1px;--e-form-steps-divider-gap:10px;}/* Start custom CSS *//* ============================================================
   K-Solutio page CSS - genuine pseudos/animations/overrides only
   (Hover states + simple styles live on widget settings now)
   ============================================================ */

/* Eyebrow decorative bar before text (pseudo, no native control) */
.g-eyebrow { position: relative; text-transform: uppercase; }
.g-eyebrow::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  width: 28px;
  height: 1px;
  background: #0AA9E2;
}

/* Featured body paragraph - cyan highlighter on <strong> (gradient bg, no native control) */
.g-band-body strong, .g-band-body b {
  font-weight: 500;
  color: #062338;
  background: linear-gradient(to top, rgba(10,169,226,.18) 0%, rgba(10,169,226,.18) 22%, transparent 22%);
  padding: 0 2px;
}

/* Marquee infinite scroll animation (no native keyframe support) */
@keyframes g-slide {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
.marquee-track {
  animation: g-slide 48s linear infinite;
  flex-shrink: 0 !important;
  width: max-content !important;
}
@media (max-width: 767px) { .marquee-track { animation-duration: 28s; } }
.marquee-item { display: inline-flex !important; align-items: center !important; position: relative; }
.marquee-item::after {
  content: '◆';
  color: #0AA9E2;
  font-size: 8px;
  font-style: normal;
  display: inline-block;
  margin-left: 60px;
  position: relative;
  top: -2px;
}

/* Service card visual: aspect-ratio + full-bleed margin trick (object-fit set on widget) */
.g-service-vis-img {
  aspect-ratio: 1.8/1;
  object-fit: cover;
  background: #eef4f8;
}

/* Card title tag stays inline with title - block display for span */
.g-h-card-tag { display: block !important; margin-top: 6px !important; letter-spacing: 0 !important; }

/* Service desc strong styling (inline override) */
.g-service-desc strong, .g-service-desc b { color: #062338; font-weight: 500; }

/* ============================================================
   CONTACT FORM v3 widget overrides (heavy because of v3 defaults)
   ============================================================ */
[data-id="contact-form"] form { background: transparent; }
[data-id="contact-form"] .elementor-form-fields-wrapper { row-gap: 28px !important; column-gap: 28px !important; }
[data-id="contact-form"] .elementor-col-50 { width: calc(50% - 14px) !important; flex: 0 0 calc(50% - 14px) !important; }
[data-id="contact-form"] .elementor-col-100 { width: 100% !important; flex: 0 0 100% !important; }
@media (max-width: 767px) {
  [data-id="contact-form"] .elementor-col-50,
  [data-id="contact-form"] .elementor-col-100 { width: 100% !important; flex: 0 0 100% !important; }
}
[data-id="contact-form"] .elementor-field-group { margin-bottom: 0; padding: 0; }
[data-id="contact-form"] .elementor-field-label,
[data-id="contact-form"] label {
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.16em !important;
  color: #8ea3bc !important;
  margin-bottom: 16px !important;
  display: block !important;
  font-weight: 500 !important;
}
[data-id="contact-form"] input[type="text"],
[data-id="contact-form"] input[type="email"],
[data-id="contact-form"] input[type="tel"],
[data-id="contact-form"] input[type="url"],
[data-id="contact-form"] textarea,
[data-id="contact-form"] select {
  background: transparent !important;
  border: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.18) !important;
  border-radius: 0 !important;
  color: #ffffff !important;
  padding: 12px 0 !important;
  font-family: 'Inter Tight', sans-serif !important;
  font-size: 16px !important;
  width: 100% !important;
  outline: none !important;
  box-shadow: none !important;
  transition: border-color .25s;
}
[data-id="contact-form"] input:focus,
[data-id="contact-form"] textarea:focus,
[data-id="contact-form"] select:focus { border-bottom-color: #0AA9E2 !important; }
[data-id="contact-form"] textarea { min-height: 110px !important; height: 110px !important; resize: vertical; }
@media (max-width: 767px) {
  [data-id="contact-form"] textarea { min-height: 90px !important; height: 90px !important; }
}
[data-id="contact-form"] select {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23ffffff' fill='none' stroke-width='1.5'/></svg>") !important;
  background-position: right 0 center !important;
  background-repeat: no-repeat !important;
  background-size: 12px 8px !important;
  padding-right: 24px !important;
}
[data-id="contact-form"] select option { background: #062338; color: #ffffff; }
[data-id="contact-form"] button[type="submit"],
[data-id="contact-form"] .elementor-button {
  background: #0AA9E2 !important;
  border: none !important;
  color: #ffffff !important;
  border-radius: 999px !important;
  padding: 11px 22px !important;
  font-family: 'Inter Tight', sans-serif !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: 0.01em !important;
  cursor: pointer !important;
  transition: background-color .25s, transform .25s !important;
  box-shadow: none !important;
  text-transform: none !important;
  min-width: 0 !important;
  width: auto !important;
}
[data-id="contact-form"] button[type="submit"]:hover,
[data-id="contact-form"] .elementor-button:hover {
  background: #0892c4 !important;
  transform: translateY(-1px) !important;
}
[data-id="contact-form"] input::placeholder,
[data-id="contact-form"] textarea::placeholder { color: rgba(255,255,255,0.3); }
@media (max-width: 767px) {
  [data-id="contact-form"] .elementor-field-group { width: 100% !important; }
}


/* ============================================================
   ABOUT picbox — vertical line grid overlay (gradient bg-image,
   not a v4 native prop) + callout backdrop blur (works on top of
   widget settings).
   ============================================================ */
.g-picbox-grid {
  background-image: linear-gradient(to right, rgba(6,35,56,.07) 1px, transparent 1px) !important;
  background-size: 25% 100% !important;
  background-repeat: repeat-x !important;
  pointer-events: none;
}
.about-callout-style {
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}


/* Contact form select — kill all default arrows + dropdown wrappers */
[data-id="contact-form"] .elementor-select-wrapper { background: none !important; position: relative; }
[data-id="contact-form"] .elementor-select-wrapper::before,
[data-id="contact-form"] .elementor-select-wrapper::after {
  display: none !important;
  content: none !important;
}
[data-id="contact-form"] .elementor-select-wrapper .e-icon,
[data-id="contact-form"] .elementor-select-wrapper i,
[data-id="contact-form"] .elementor-select-wrapper svg {
  display: none !important;
}
[data-id="contact-form"] select {
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%238ea3bc' fill='none' stroke-width='1.5'/></svg>") !important;
  background-repeat: no-repeat !important;
  background-position: right 4px center !important;
  background-size: 12px 8px !important;
  padding-right: 28px !important;
}


/* ============================================================
   ABOUT motto pulse — animated dot with halo (no native
   keyframe / box-shadow halo control on a div-block).
   ============================================================ */
@keyframes g-motto-pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(10, 169, 226, 0.15); }
  50%      { box-shadow: 0 0 0 8px rgba(10, 169, 226, 0.05); }
}
.motto-dot-style {
  box-shadow: 0 0 0 4px rgba(10, 169, 226, 0.15);
  animation: g-motto-pulse 1.8s ease-in-out infinite;
}


/* ============================================================
   APPROACH pillar icons — cyan accent, 28px, breathing room
   above the P# label.
   ============================================================ */
.pillar-icon-style { margin-bottom: 14px; }
.pillar-icon-style .elementor-icon { color: #0AA9E2; font-size: 28px; line-height: 1; }
.pillar-icon-style .elementor-icon i { color: inherit; font-size: inherit; }
.pillar-icon-style .elementor-icon-wrapper { display: inline-flex; align-items: center; }


/* Contact form submit — left align (default Elementor center) */
[data-id="contact-form"] .elementor-field-type-submit {
  text-align: left !important;
  display: flex !important;
  justify-content: flex-start !important;
}
[data-id="contact-form"] .elementor-field-type-submit button[type="submit"] {
  width: auto !important;
  flex: 0 0 auto !important;
  align-self: flex-start !important;
}


/* Motto pill — enforce content-width + dot perfect circle */
.motto-style {
  width: fit-content !important;
  max-width: max-content !important;
}
.motto-dot-style {
  width: 8px !important;
  height: 8px !important;
  min-width: 8px !important;
  min-height: 8px !important;
  max-width: 8px !important;
  max-height: 8px !important;
  aspect-ratio: 1 / 1 !important;
  flex: 0 0 8px !important;
  border-radius: 50% !important;
}/* End custom CSS */