/*
	Theme Name: Revolution Child Theme
	Theme URI: http://themeforest.net/user/fuelthemes
	Description: <strong>A Premium theme for magazine, editor, community and more! WordPress Theme by <a href="http://www.themeforest.net/user/fuelthemes">fuelthemes</a></strong> – Update notifications available on Twitter and Themeforest <a href="http://twitter.com/anteksiler">Follow us on twitter</a> – <a href="http://themeforest.net/user/fuelthemes">Follow us on Themeforest</a>
	Version: 1.0.0
	Author: fuelthemes
	Template: revolution
	Text Domain: revolution
	Domain Path: /inc/languages
*/

/* =========================================================
   GLOBAL THEME OVERRIDES
========================================================= */

h1,
h2 {
  color: #00143e;
}

.vc_custom_1779259405697 {
  background: #ea162c !important;
  background: linear-gradient(
    90deg,
    rgba(234, 22, 44, 1) 0%,
    rgba(2, 176, 187, 1) 75%,
    rgba(2, 176, 187, 1) 100%
  ) !important;
}


/* =========================================================
   HEADER MENU UNDERLINE
========================================================= */

.thb-full-menu.thb-underline > li > a:before {
  height: 3px !important;
}


/* =========================================================
   POSTS STYLE 10 - BLOG CARDS
========================================================= */

.posts-shortcode.posts-style10 {
  --kr-card-radius: 18px;
  --kr-card-bg: #ffffff;
  --kr-card-shadow: 0 10px 28px rgba(0, 20, 62, 0.08);

  --kr-card-padding-x: 36px;
  --kr-card-padding-top: 30px;
  --kr-card-padding-bottom: 34px;

  --kr-category-color: #ea162c;
  --kr-category-hover: #02b0bb;
  --kr-category-size: 12px;

  --kr-title-color: #00143e;
  --kr-title-hover: #02b0bb;
  --kr-title-size: 16px;

  --kr-excerpt-color: #5f6673;
  --kr-excerpt-size: 14px;

  --kr-readmore-color: #ea162c;
  --kr-readmore-hover: #02b0bb;
  --kr-readmore-size: 15px;
  --kr-readmore-gap: 22px;
}

.posts-shortcode.posts-style10.row {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch !important;
}

.posts-shortcode.posts-style10.row > .columns {
  display: flex !important;
  float: none !important;
  margin-bottom: 28px !important;
}

.posts-shortcode.posts-style10 .post.style10 {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  background-color: var(--kr-card-bg) !important;
  border-radius: var(--kr-card-radius) !important;
  overflow: hidden !important;
  box-shadow: var(--kr-card-shadow) !important;
}

.posts-shortcode.posts-style10 .post.style10 > div {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  background-color: var(--kr-card-bg) !important;
}

.posts-shortcode.posts-style10 .post-gallery {
  display: block !important;
  margin: 0 !important;
  padding: 10px 10px 0 !important;
  background-color: var(--kr-card-bg) !important;
  overflow: hidden !important;
}

.posts-shortcode.posts-style10 .post-gallery a {
  display: block !important;
  width: 100% !important;
  background-color: var(--kr-card-bg) !important;
  overflow: hidden !important;
}

.posts-shortcode.posts-style10 .post-gallery img {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: auto !important;
  min-height: 0 !important;
  object-fit: contain !important;
  object-position: center center !important;
  background-color: var(--kr-card-bg) !important;
}

.posts-shortcode.posts-style10 .style10-content {
  display: flex !important;
  flex-direction: column !important;
  flex: 0 0 auto !important;
  padding: var(--kr-card-padding-top) var(--kr-card-padding-x) var(--kr-card-padding-bottom) !important;
  background-color: var(--kr-card-bg) !important;
}

.posts-shortcode.posts-style10 .post-category {
  display: block !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
}

.posts-shortcode.posts-style10 .post-category a {
  color: var(--kr-category-color) !important;
  font-size: var(--kr-category-size) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  text-decoration: none !important;
}

.posts-shortcode.posts-style10 .post-category a:hover {
  color: var(--kr-category-hover) !important;
}

.posts-shortcode.posts-style10 .post-title {
  margin: 0 0 18px !important;
  padding: 0 !important;
}

.posts-shortcode.posts-style10 h4.entry-title,
.posts-shortcode.posts-style10 .entry-title {
  margin: 0 !important;
  padding: 0 !important;
  color: var(--kr-title-color) !important;
  font-size: var(--kr-title-size) !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
}

.posts-shortcode.posts-style10 h4.entry-title a,
.posts-shortcode.posts-style10 .entry-title a {
  color: var(--kr-title-color) !important;
  font-size: var(--kr-title-size) !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  text-decoration: none !important;
}

.posts-shortcode.posts-style10 h4.entry-title a:hover,
.posts-shortcode.posts-style10 .entry-title a:hover {
  color: var(--kr-title-hover) !important;
}

.posts-shortcode.posts-style10 .post-content {
  margin: 0 !important;
  padding: 0 !important;
}

.posts-shortcode.posts-style10 .post-content p {
  display: -webkit-box !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden !important;
  color: var(--kr-excerpt-color) !important;
  font-size: var(--kr-excerpt-size) !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  text-overflow: ellipsis !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
}

.posts-shortcode.posts-style10 .style10-readmore {
  display: inline-block !important;
  width: fit-content !important;
  margin-top: var(--kr-readmore-gap) !important;
  color: var(--kr-readmore-color) !important;
  font-size: var(--kr-readmore-size) !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
  text-decoration: none !important;
  transition: color 0.2s ease !important;
}

.posts-shortcode.posts-style10 .style10-readmore:hover {
  color: var(--kr-readmore-hover) !important;
}


/* =========================================================
   BLOG CARDS - READ MORE SVG ARROW
========================================================= */

.post.style10 .style10-readmore {
  display: inline-flex !important;
  align-items: center !important;
  width: fit-content !important;
  gap: 10px !important;
  color: var(--kr-readmore-color, #ea162c) !important;
  text-decoration: none !important;
}

.post.style10 .style10-readmore::after {
  content: "" !important;
  display: inline-block !important;
  width: 20px !important;
  height: 10px !important;
  background-color: currentColor !important;
  transform: translateX(0) !important;
  transition: transform 0.2s ease, background-color 0.2s ease !important;

  -webkit-mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='18' viewBox='0 0 30 18'%3E%3Cpath d='M20.305,16.212c-0.407,0.409-0.407,1.071,0,1.479s1.068,0.408,1.476,0l7.914-7.952c0.408-0.409,0.408-1.071,0-1.481l-7.914-7.952c-0.407-0.409-1.068-0.409-1.476,0s-0.407,1.071,0,1.48l7.185,7.221L20.305,16.212z'/%3E%3Cpath d='M1,8h28.001c0.551,0,1,0.448,1,1c0,0.553-0.449,1-1,1H1c-0.553,0-1-0.447-1-1C0,8.448,0.447,8,1,8z'/%3E%3C/svg%3E") !important;
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='18' viewBox='0 0 30 18'%3E%3Cpath d='M20.305,16.212c-0.407,0.409-0.407,1.071,0,1.479s1.068,0.408,1.476,0l7.914-7.952c0.408-0.409,0.408-1.071,0-1.481l-7.914-7.952c-0.407-0.409-1.068-0.409-1.476,0s-0.407,1.071,0,1.48l7.185,7.221L20.305,16.212z'/%3E%3Cpath d='M1,8h28.001c0.551,0,1,0.448,1,1c0,0.553-0.449,1-1,1H1c-0.553,0-1-0.447-1-1C0,8.448,0.447,8,1,8z'/%3E%3C/svg%3E") !important;

  -webkit-mask-repeat: no-repeat !important;
  mask-repeat: no-repeat !important;
  -webkit-mask-position: center !important;
  mask-position: center !important;
  -webkit-mask-size: contain !important;
  mask-size: contain !important;
}

.post.style10 .style10-readmore:hover {
  color: var(--kr-readmore-hover, #02b0bb) !important;
}

.post.style10 .style10-readmore:hover::after {
  transform: translateX(4px) !important;
}


/* =========================================================
   POSTS STYLE 10 - RESPONSIVE
========================================================= */

@media (max-width: 767px) {
  .posts-shortcode.posts-style10.row {
    display: block !important;
  }

  .posts-shortcode.posts-style10.row > .columns {
    display: block !important;
    margin-bottom: 24px !important;
  }

  .posts-shortcode.posts-style10 .style10-content {
    padding: 26px 26px 30px !important;
  }

  .posts-shortcode.posts-style10 .post-gallery {
    padding: 10px 10px 0 !important;
  }
}


/* =========================================================
   METHODOLOGY TIMELINE - ICONBOX STEPS
========================================================= */

.kr-methodology-timeline {
  --kr-timeline-line-color: rgba(255, 255, 255, 0.35);
  --kr-timeline-line-height: 2px;
  --kr-timeline-line-style: dashed;
  --kr-timeline-y: 25px;
  --kr-timeline-gap: 38px;
}

.kr-methodology-timeline .thb-content-carousel,
.kr-methodology-timeline .slick-list,
.kr-methodology-timeline .slick-track {
  overflow: visible !important;
}

.kr-methodology-timeline .thb-iconbox {
  position: relative !important;
  overflow: visible !important;
}

.kr-methodology-timeline .thb-iconbox:not(:last-child)::after {
  content: "";
  position: absolute;
  top: var(--kr-timeline-y);
  left: calc(50% + var(--kr-timeline-gap));
  width: calc(100% - calc(var(--kr-timeline-gap) * 2));
  height: var(--kr-timeline-line-height);
  border-top: var(--kr-timeline-line-height) var(--kr-timeline-line-style) var(--kr-timeline-line-color);
  z-index: 0;
  pointer-events: none;
}

.kr-methodology-timeline .thb-iconbox figure {
  position: relative !important;
  z-index: 2 !important;
}

.kr-methodology-timeline .thb-iconbox .iconbox-image {
  position: relative !important;
  z-index: 3 !important;
}


/* =========================================================
   SOCIAL ICONS
========================================================= */

.kr-social-icons {
  display: flex;
  align-items: center;
  gap: 14px;
}

.kr-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border: 2px solid rgba(255, 255, 255, 0.45);
  border-radius: 50%;
  color: #ffffff;
  font-size: 16px;
  line-height: 1;
  text-decoration: none;
  transition: all 0.25s ease;
}

.kr-social-link:hover {
  border-color: #02b0bb;
  background-color: #02b0bb;
  color: #ffffff;
}

.kr-social-x span {
  display: none;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 16px;
  font-weight: 700;
}


/* =========================================================
   CONTACT INFO ICONS
========================================================= */

.kr-contact-info {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.kr-contact-item {
  display: flex;
  align-items: center;
  gap: 12px;
  color: #ffffff;
  font-size: 15px;
  font-weight: 600;
  line-height: 1.4;
}

.kr-contact-item a,
.kr-contact-item span {
  color: #ffffff;
  text-decoration: none;
}

.kr-contact-item a:hover {
  color: #02b0bb;
}

.kr-contact-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-color: rgba(2, 176, 187, 0.16);
  color: #ffffff;
  font-size: 12px;
  line-height: 1;
}

.kr-contact-icon i {
  display: block;
  line-height: 1;
}

/* =========================================================
   METHODOLOGY TIMELINE - RETINA SVG SIZE FIX
========================================================= */

.kr-methodology-timeline {
  --kr-methodology-icon-size: 50px;
}

.kr-methodology-timeline .thb-iconbox figure {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
}

.kr-methodology-timeline .thb-iconbox .iconbox-image {
  display: inline-flex !important;
  justify-content: center !important;
  align-items: center !important;
  width: var(--kr-methodology-icon-size) !important;
  height: var(--kr-methodology-icon-size) !important;
  max-width: var(--kr-methodology-icon-size) !important;
  max-height: var(--kr-methodology-icon-size) !important;
}

.kr-methodology-timeline .thb-iconbox .iconbox-image img,
.kr-methodology-timeline .thb-iconbox img.thb_image,
.kr-methodology-timeline .thb-iconbox img.retina_active {
  display: block !important;
  width: var(--kr-methodology-icon-size) !important;
  height: var(--kr-methodology-icon-size) !important;
  max-width: var(--kr-methodology-icon-size) !important;
  max-height: var(--kr-methodology-icon-size) !important;
  object-fit: contain !important;
}

/* =========================================================
   SERVICES CARDS - SVG SIZE + EQUAL HEIGHT
========================================================= */

.kr-services-cards {
  --kr-service-card-radius: 4px;
  --kr-service-card-border: 1px solid rgba(0, 20, 62, 0.12);
  --kr-service-card-bg: #ffffff;
  --kr-service-card-padding: 36px 28px;
  --kr-service-icon-height: 60px;
  --kr-service-icon-area-height: 82px;
}

.kr-services-cards .slick-track {
  display: flex !important;
  align-items: stretch !important;
}

.kr-services-cards .thb-iconbox.type7.slick-slide {
  display: flex !important;
  flex-direction: column !important;
  height: auto !important;
  min-height: 100% !important;
  box-sizing: border-box !important;
  background-color: var(--kr-service-card-bg) !important;
  border: var(--kr-service-card-border) !important;
  border-radius: var(--kr-service-card-radius) !important;
  padding: var(--kr-service-card-padding) !important;
}

.kr-services-cards .thb-iconbox.type7 figure {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 var(--kr-service-icon-area-height) !important;
  width: 100% !important;
  height: var(--kr-service-icon-area-height) !important;
  margin: 0 0 26px !important;
}

.kr-services-cards .thb-iconbox.type7 .iconbox-image {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: var(--kr-service-icon-area-height) !important;
}

.kr-services-cards .thb-iconbox.type7 .iconbox-image img,
.kr-services-cards .thb-iconbox.type7 img.thb_image,
.kr-services-cards .thb-iconbox.type7 img.retina_active {
  display: block !important;
  width: auto !important;
  height: var(--kr-service-icon-height) !important;
  max-width: 100% !important;
  max-height: var(--kr-service-icon-height) !important;
  object-fit: contain !important;
}

.kr-services-cards .thb-iconbox.type7 .iconbox-content {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
  text-align: center !important;
}

.kr-services-cards .thb-iconbox.type7 .iconbox-content h5 {
  min-height: 44px !important;
  margin-bottom: 18px !important;
}

.kr-services-cards .thb-iconbox.type7 .iconbox-content p {
  margin-bottom: 0 !important;
}

/* =========================================================
   CLIENT LOGOS - RETINA SVG SIZE FIX
========================================================= */

.kr-client-logos-row {
  --kr-client-logo-height: 60px;
  --kr-client-logo-max-width: 200px;
}

.kr-client-logos-row .thb-client-row,
.kr-client-logos-row .thb-client-row .row {
  overflow: visible !important;
}

.kr-client-logos-row .thb-client {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 90px !important;
}

.kr-client-logos-row .thb-client img,
.kr-client-logos-row .thb-client img.attachment-full {
  display: block !important;
  width: auto !important;
  height: var(--kr-client-logo-height) !important;
  max-width: var(--kr-client-logo-max-width) !important;
  max-height: var(--kr-client-logo-height) !important;
  object-fit: contain !important;
}

/* =========================================================
   CONTACT FORM 7 - COMPACT FORM
========================================================= */

.kr-contact-form {
  --kr-form-field-gap: 24px;
  --kr-form-label-gap: 10px;
  --kr-form-input-height: 54px;
  --kr-form-textarea-height: 170px;
  --kr-form-border: #e2e4e8;
  --kr-form-border-focus: #02b0bb;
  --kr-form-text: #00143e;
  --kr-form-placeholder: #b9bdc4;
}

/* Reduce espacios generados por Contact Form 7 */
.kr-contact-form p {
  margin: 0 !important;
  padding: 0 !important;
}

.kr-contact-form br {
  display: none !important;
}

/* Espacio entre campos */
.kr-contact-form > .columns {
  margin-bottom: var(--kr-form-field-gap) !important;
}

/* Labels */
.kr-contact-form label {
  display: block !important;
  margin-bottom: var(--kr-form-label-gap) !important;
  color: #00143e !important;
  font-size: 14px !important;
  font-weight: 300 !important;
  line-height: 1.3 !important;
}

/* Inputs, select y textarea */
.kr-contact-form input[type="text"],
.kr-contact-form input[type="email"],
.kr-contact-form input[type="tel"],
.kr-contact-form select,
.kr-contact-form textarea {
  width: 100% !important;
  margin: 0 !important;
  border: 1px solid var(--kr-form-border) !important;
  border-radius: 4px !important;
  background-color: #ffffff !important;
  color: var(--kr-form-text) !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  box-shadow: none !important;
}

.kr-contact-form input[type="text"],
.kr-contact-form input[type="email"],
.kr-contact-form input[type="tel"],
.kr-contact-form select {
  height: var(--kr-form-input-height) !important;
  padding: 0 18px !important;
}

/* Textarea más compacto */
.kr-contact-form textarea {
  height: var(--kr-form-textarea-height) !important;
  min-height: var(--kr-form-textarea-height) !important;
  max-height: 260px !important;
  padding: 18px !important;
  resize: vertical !important;
}

/* Placeholder */
.kr-contact-form input::placeholder,
.kr-contact-form textarea::placeholder {
  color: var(--kr-form-placeholder) !important;
  opacity: 1 !important;
}

/* Focus */
.kr-contact-form input:focus,
.kr-contact-form select:focus,
.kr-contact-form textarea:focus {
  border-color: var(--kr-form-border-focus) !important;
  outline: none !important;
  box-shadow: 0 0 0 1px rgba(2, 176, 187, 0.18) !important;
}

/* Botón */
.kr-contact-form input[type="submit"].btn {
  margin-top: 8px !important;
}

/* Spinner de CF7 */
.kr-contact-form .wpcf7-spinner {
  margin-left: 12px !important;
}

/* Responsive */
@media (max-width: 767px) {
  .kr-contact-form {
    --kr-form-field-gap: 20px;
    --kr-form-textarea-height: 150px;
  }

  .kr-contact-form label {
    font-size: 14px !important;
  }
}

.post-detail .post-title .entry-title {
font-weight: 700 !important;
}

.kratos-sidebar-widget {
  --k-white: #ffffff;
  --k-dark: #07080c;
  --k-muted: rgba(255, 255, 255, 0.78);
  --k-radius: 28px;
  --k-padding-x: 20px;

  width: 100%;
  box-sizing: border-box;
  padding: 24px var(--k-padding-x);
  border-radius: var(--k-radius);
  color: var(--k-white);
  font-size: 16px;
  line-height: 1.6;
  overflow: hidden;
  background: #00143e
}

.kratos-sidebar-widget *,
.kratos-sidebar-widget *::before,
.kratos-sidebar-widget *::after {
  box-sizing: border-box;
}

.kratos-widget-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
  min-width: 0;
}

.kratos-widget-logo {
  width: 72px;
  height: 72px;
  flex: 0 0 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  border: 1px solid var(--k-border);
  background: rgba(255, 255, 255, 0.025);
}

.kratos-widget-logo img {
  display: block;
  width: 52px;
  height: auto;
  max-width: 52px;
}

.kratos-widget-brand {
  min-width: 0;
  overflow: hidden;
}

.kratos-widget-title {
  font-size: 20px;
  line-height: 1.1;
  font-weight: 800;
  color: var(--k-white);
}

.kratos-widget-subtitle {
  margin-top: 6px;
  font-size: 16px;
  line-height: 1.1;
  font-weight: 600;
  letter-spacing: 0.18em;
  color: var(--k-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: clip;
}

.kratos-widget-description {
  margin: 0 0 22px;
  font-size: 16px;
  line-height: 1.65;
  font-weight: 400;
  color: var(--k-white);
}

.kratos-widget-contact,
.kratos-widget-social {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  text-decoration: none;
  line-height: 1;
  transition: transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

.kratos-widget-contact {
  min-height: 48px;
  margin-bottom: 16px;
  padding: 14px 20px;
  border-radius: 999px;
  background: var(--k-white);
  color: var(--k-dark);
  font-size: 16px;
  font-weight: 500;
}

.kratos-widget-contact i,
.kratos-widget-social i {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  width: 16px;
  font-size: 16px;
  line-height: 1;
}

.kratos-widget-socials {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.kratos-widget-social {
  min-height: 46px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid var(--k-border);
  background: rgba(255, 255, 255, 0.025);
  color: var(--k-white);
  font-size: 16px;
  font-weight: 500;
  white-space: nowrap;
}

.kratos-widget-contact:hover,
.kratos-widget-social:hover {
  transform: translateY(-1px);
  text-decoration: none;
}

.kratos-widget-contact:hover {
  background: #f2f2f2;
  color: var(--k-dark);
}

.kratos-widget-social:hover {
  border-color: rgba(255, 255, 255, 0.32);
  background: rgba(255, 255, 255, 0.06);
  color: var(--k-white);
}

@media (max-width: 360px) {
  .kratos-sidebar-widget {
    --k-padding-x: 14px;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .kratos-widget-socials {
    grid-template-columns: 1fr;
  }
}

.kratos-sticky-sidebar-widget {
  position: -webkit-sticky;
  position: sticky;
  top: 100px;
  z-index: 5;
  align-self: flex-start;
}

@media (max-width: 768px) {
  .kratos-sticky-sidebar-widget {
    position: static;
  }
}

