/* Estilos CSS para Calculadora CIDCP - Basado en diseño OIT */

/* Variables de colores */
#cidcp-root {
  --blanco: #ffffff;
  --negro: #000000;
  --azul-oscuro: #1e2dbe;
  --azul-claro: #5f6dfd;
  --azul-sombra: #0066ff;
  --azul-borde: #1e2dbe;
  --azul-radio-fondo: #aec7ff;
  --azul-fondo-icono: #b5bcff;
  --gris-botones: #e5edff;
  --gris-fondo-icono: #f2f0f0;
  --gris-fondo-claro: #f5f8ff;
  --gris-fondo-resultados: #f0f4ff;
  --gris-claro: #9ca3af;
  --gris-oscuro: #747982;
  --gris-texto-footer: #929292;
  --gris-900: #111827;
  --gris-900-85: rgba(17, 24, 39, 0.85);
  --gris-100: #f3f4f6;
  --rojo-error: #ef4444;
  --rojo-fondo: #fef1f1;
  --rojo-borde: #fca5a5;
  --rojo-texto-warning: #6e0000;
  --logo-height: 38px;
}

.cidcp-result-grid .cidcp-result-grid-spacer {
  display: none;
}

.cidcp-icon {
  display: inline-block;
  width: 1em;
  height: 1em;
  background-color: currentColor;
  -webkit-mask-image: var(--cidcp-icon-url);
  mask-image: var(--cidcp-icon-url);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-size: contain;
  mask-size: contain;
}

.cidcp-icon--disclaimer-info {
  --cidcp-icon-url: url("images/icon-disclaimer-info.svg");
}
.cidcp-icon--disclaimer-close {
  --cidcp-icon-url: url("images/icon-disclaimer-close.svg");
}
.cidcp-icon--calendar {
  --cidcp-icon-url: url("images/icon-calendar.svg");
}
.cidcp-icon--back {
  --cidcp-icon-url: url("images/icon-back.svg");
}
.cidcp-icon--chevron-down {
  --cidcp-icon-url: url("images/icon-chevron-down.svg");
}
.cidcp-icon--check {
  --cidcp-icon-url: url("images/icon-check.svg");
}
.cidcp-icon--question {
  --cidcp-icon-url: url("images/icon-question.svg");
}
.cidcp-icon--info {
  --cidcp-icon-url: url("images/icon-info.svg");
}
.cidcp-icon--download {
  --cidcp-icon-url: url("images/icon-download.svg");
}
.cidcp-icon--role-employer {
  --cidcp-icon-url: url("images/icon-role-employer.svg");
}
.cidcp-icon--role-employee {
  --cidcp-icon-url: url("images/icon-role-employee.svg");
}
.cidcp-icon--social-facebook {
  --cidcp-icon-url: url("images/icon-social-facebook.svg");
}
.cidcp-icon--social-whatsapp {
  --cidcp-icon-url: url("images/icon-social-whatsapp.svg");
}
.cidcp-icon--social-share {
  --cidcp-icon-url: url("images/icon-social-share.svg");
}

/* Contenedor principal */
#cidcp-root * {
  box-sizing: border-box;
}

#cidcp-root {
  width: 100% !important;
  max-width: 100%;
  margin: 0;
  border-radius: 1rem;
  background-color: var(--blanco);
  min-height: 100vh;
  padding: 0;
  font-family:
    "Raleway",
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.cidcp-main-container {
  width: 100% !important;
  max-width: 100%;
  border-radius: 1rem;
  padding: 2rem 0;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.cidcp-main-container.cidcp-mode-page {
  min-height: 0;
}

#cidcp-root h1,
#cidcp-root h2,
#cidcp-root h3,
#cidcp-root h4,
#cidcp-root h5,
#cidcp-root h6 {
  font-family: inherit;
}

#cidcp-root input,
#cidcp-root button,
#cidcp-root option,
#cidcp-root textarea,
#cidcp-root select {
  font: inherit;
}

/* Reset de contenedores de WP */
.entry-content .cidcp-calculadora-wrapper,
.post-content .cidcp-calculadora-wrapper,
.page-content .cidcp-calculadora-wrapper,
.site-content .cidcp-calculadora-wrapper,
.elementor-section .cidcp-calculadora-wrapper,
.avada-section .cidcp-calculadora-wrapper,
.divi-section .cidcp-calculadora-wrapper,
.gutenberg-block .cidcp-calculadora-wrapper,
.page-template-full-width .cidcp-calculadora-wrapper,
.full-width .cidcp-calculadora-wrapper,
.no-sidebar .cidcp-calculadora-wrapper {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.entry-content #cidcp-root,
.post-content #cidcp-root,
.page-content #cidcp-root,
.site-content #cidcp-root,
.elementor-section #cidcp-root,
.avada-section #cidcp-root,
.divi-section #cidcp-root,
.gutenberg-block #cidcp-root,
.page-template-full-width #cidcp-root,
.full-width #cidcp-root,
.no-sidebar #cidcp-root {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

#cidcp-root :focus {
  outline: 2px solid var(--gris-botones);
  outline-offset: 2px;
}

#cidcp-root :focus:not(:focus-visible) {
  outline: none;
}

/* Header */
.cidcp-header {
  background-color: var(--azul-oscuro);
  color: var(--blanco);
  padding: 0.5rem 0;
  width: 100%;
  margin: 0;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
  position: relative;
  z-index: 1003;
  overflow: visible;
}

.header-container {
  padding: 0 1rem;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.role-selector-container {
  padding: 0;
  width: 100%;
  margin: 0;
}

.cidcp-header .header-logos {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.cidcp-header .cidcp-site-logo {
  min-width: 65px;
  height: var(--logo-height);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: transparent;
}

.cidcp-header .header-logos {
  flex: 0 0 auto;
}

.cidcp-header .cidcp-site-logo.cidcp-site-sacra {
  width: 71px;
  background-image: url("images/logo-sacra.png");
}

.cidcp-header .cidcp-site-logo.cidcp-site-upacp {
  width: 100px;
  background-image: url("images/logo-upacp.png");
}

.cidcp-disclaimer-wrapper {
  width: 100%;
  margin: 1rem 0;
  padding: 0;
}

.cidcp-disclaimer-banner {
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 2rem;
  padding-right: 2rem;
}

.cidcp-main-content {
  flex: 1;
}

.cidcp-main-container.cidcp-mode-page .cidcp-main-content {
  flex: initial;
}

.cidcp-overlay-scope {
  position: relative;
}

.cidcp-disclaimer-banner {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  background-color: var(--rojo-fondo);
  color: var(--rojo-texto-warning);
  border-radius: 1rem;
  padding: 0.875rem 2.5rem 0.875rem 1rem;
  line-height: 1.5;
}

#cidcp-root .cidcp-disclaimer-banner {
  font-size: 1rem;
}

#cidcp-root .cidcp-disclaimer-banner * {
  font-size: inherit;
}

.cidcp-disclaimer-icon {
  width: 1.125rem;
  height: 1.125rem;
  flex: 0 0 auto;
  color: var(--rojo-texto-warning);
  margin-top: 0.15em;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cidcp-disclaimer-icon .cidcp-icon {
  width: 13px;
  height: 13px;
  display: block;
}

.cidcp-disclaimer-text {
  flex: 1;
}

.cidcp-disclaimer-close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 1.25rem;
  height: 1.25rem;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--rojo-texto-warning);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cidcp-disclaimer-close .cidcp-icon {
  width: 13px;
  height: 13px;
  display: block;
}

.cidcp-header .header-nav {
  display: none;
  justify-content: center;
  flex: 1;
}

#cidcp-root .cidcp-header .header-nav a {
  font-weight: 600 !important;
}

#cidcp-root .cidcp-header .header-nav > nav a {
  color: var(--blanco);
  text-decoration: none !important;
  background-image: none !important;
  box-shadow: none !important;
  transition: all 0.2s ease;
  padding-bottom: 2px;
  border-bottom: 3px solid transparent;
}

#cidcp-root .cidcp-header .header-nav > nav a.is-active {
  border-bottom-color: var(--azul-claro);
}

#cidcp-root .cidcp-header .header-nav > nav a:hover {
  border-bottom-color: var(--azul-claro);
}

.logo-oit {
  width: 65px;
  height: var(--logo-height);
  background-image: url("images/logo-oit.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: transparent;
}

.logo-insightlac {
  width: 44px;
  height: var(--logo-height);
  background-image: url("images/logo-insightlac.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: transparent;
}

.logo-epyca {
  width: 92px;
  height: var(--logo-height);
  background-image: url("images/logo-epyca.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  background-color: transparent;
}

.cidcp-header .header-nav > nav {
  display: none;
}

.cidcp-header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.25rem;
  flex: 1;
  min-width: 0;
  flex-direction: column;
  align-items: flex-end;
}

.cidcp-header .cidcp-social {
  justify-content: flex-end;
  flex: 0 0 auto;
  gap: 0.875rem;
}

.cidcp-header .cidcp-social-link {
  color: var(--blanco);
}

.cidcp-header-menu-button {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--blanco);
  width: 44px;
  height: 44px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.cidcp-header-menu-button:focus {
  outline: none;
}

.cidcp-header-menu-button:focus-visible {
  outline: 2px solid var(--gris-botones);
  outline-offset: 2px;
}

.cidcp-header-menu-icon {
  position: relative;
  display: block;
  width: 22px;
  height: 16px;
  background:
    linear-gradient(currentColor 0 0) left top / 22px 2px no-repeat,
    linear-gradient(currentColor 0 0) left center / 22px 2px no-repeat,
    linear-gradient(currentColor 0 0) left bottom / 22px 2px no-repeat;
}

.cidcp-header-menu {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--blanco);
  border-bottom-left-radius: 1.25rem;
  border-bottom-right-radius: 1.25rem;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
  padding: 0.75rem 1rem 1rem;
  z-index: 1002;
}

.cidcp-header-menu nav {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

#cidcp-root .cidcp-header-menu nav a {
  display: block;
  color: var(--azul-oscuro);
  text-decoration: none !important;
  font-weight: 700 !important;
  padding: 0.75rem 0.875rem;
  border-radius: 0.875rem;
}

#cidcp-root .cidcp-header-menu nav a.is-active {
  background: var(--gris-botones);
  border-color: rgba(30, 45, 190, 0.2);
}

.cidcp-header-backdrop {
  position: absolute;
  top: var(--cidcp-header-height, 0px);
  left: 0;
  right: 0;
  bottom: 0;
  border: 0;
  padding: 0;
  margin: 0;
  background: rgba(17, 24, 39, 0.45);
  z-index: 1001;
}

/* Selector de rol */
.cidcp-role-selector {
  padding: 1.5rem 0;
  width: 100%;
  margin: 0;
}

.cidcp-role-selector .role-selector-container {
  text-align: center;
}

.cidcp-role-selector .role-selector-title {
  text-align: center;
  color: var(--negro);
  margin: 0;
  padding: 0;
  font-size: 18px;
}

.cidcp-role-selector .role-buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 9px;
  margin: 1rem 0 0;
  border: 2px solid var(--azul-borde);
  border-radius: 2rem;
  padding: 9px;
  width: 100%;
  max-width: 100%;
}

.cidcp-role-button {
  border-radius: 2rem;
  transition: all 0.2s ease;
  border: none;
  background: none;
  font-weight: 600 !important;
  cursor: pointer;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  flex-direction: row;
  flex: 1 1 0;
  min-width: 0;
  white-space: normal;
  line-height: 1.2;
}

.cidcp-role-button.active {
  background-color: var(--gris-botones) !important;
  color: var(--azul-oscuro) !important;
}

.role-button-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  padding: 4px;
  transition: background-color 0.2s ease;
}

.role-button-icon .cidcp-icon {
  width: 100%;
  height: 100%;
  display: block;
}

.cidcp-role-button.active .role-button-icon {
  background-color: var(--azul-fondo-icono);
}

.cidcp-role-button.inactive {
  background-color: var(--blanco) !important;
  color: var(--azul-oscuro) !important;
}

.cidcp-role-button.inactive .role-button-icon {
  background-color: var(--gris-fondo-icono);
}

/* Pestañas */
.cidcp-tabs {
  padding: 0;
  margin-bottom: 0;
  width: 100%;
  position: sticky;
  top: calc(env(safe-area-inset-top) + 0px);
  z-index: 1100;
  background-color: var(--blanco);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.08);
  border-bottom: 2px solid var(--azul-borde);
}

.cidcp-tabs-container {
  display: block;
  position: relative;
  background-color: transparent;
  border-radius: 0;
  padding: 0;
  overflow-x: auto;
  overflow-y: hidden;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding-left: 1rem;
  padding-right: 1rem;
  box-shadow: none;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.cidcp-tabs-inner {
  display: flex;
  width: max-content;
  min-width: 100%;
  justify-content: center;
  gap: 0;
}

.cidcp-tabs-container::-webkit-scrollbar {
  display: none;
  height: 0;
}

.cidcp-tabs-scroll-indicator {
  position: absolute;
  top: 0;
  bottom: 2px;
  width: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
  z-index: 1;
}

.cidcp-tabs-scroll-indicator--left {
  left: 0;
  justify-content: flex-start;
  padding-left: 0.25rem;
  background: linear-gradient(
    to right,
    rgba(255, 255, 255, 1),
    rgba(255, 255, 255, 0)
  );
}

.cidcp-tabs-scroll-indicator--right {
  right: 0;
  justify-content: flex-end;
  padding-right: 0.25rem;
  background: linear-gradient(
    to left,
    rgba(255, 255, 255, 1),
    rgba(255, 255, 255, 0)
  );
}

.cidcp-tabs-scroll-indicator-icon {
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  opacity: 0.85;
}

.cidcp-tabs-scroll-indicator--left .cidcp-tabs-scroll-indicator-icon {
  border-right: 8px solid var(--azul-borde);
}

.cidcp-tabs-scroll-indicator--right .cidcp-tabs-scroll-indicator-icon {
  border-left: 8px solid var(--azul-borde);
}

.cidcp-tab-button {
  display: flex;
  align-items: center;
  justify-content: center;
  flex: none;
  min-width: 0;
  min-height: 44px;
  white-space: nowrap;
  padding: 0.625rem 1rem;
  border: none;
  border-bottom: 0px solid transparent;
  border-top-left-radius: 1.5rem;
  border-top-right-radius: 1.5rem;
  background: none;
  color: var(--negro);
  text-align: center;
  line-height: 1.2;
  font-weight: 600 !important;
  cursor: pointer;
  transition: all 0.2s ease;
}

.cidcp-tab-button.active {
  position: relative;
  z-index: 1;
  background-color: var(--gris-botones);
  color: var(--azul-oscuro);
}

.cidcp-tab-button.inactive:hover {
  position: relative;
  z-index: 1;
  background-color: var(--gris-botones);
  color: var(--azul-oscuro);
}

/* Grid Principal */
.cidcp-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
  border-radius: 0;
  overflow: visible;
  box-shadow: none;
  background-color: var(--blanco);
}

.cidcp-grid h2.cidcp-form-title,
.cidcp-grid h3.cidcp-optional-title,
.cidcp-grid .cidcp-form-card,
.cidcp-grid .calculate-button {
  grid-column: span all;
}

.cidcp-form-title-note {
  display: block;
  width: 100%;
  margin-top: 0.75rem;
  padding: 0.75rem 0.875rem;
  background: var(--gris-fondo-claro);
  border: 1px solid var(--gris-claro);
  border-radius: 0.75rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  color: var(--gris-900-85);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  white-space: normal;
}

h2.cidcp-form-title {
  color: var(--azul-oscuro);
  font-size: 22px !important;
  margin-top: 1rem;
  margin-bottom: 1.25rem;
  padding-left: 1rem;
}

h3.cidcp-optional-title {
  color: var(--azul-oscuro);
  font-size: 18px !important;
  font-weight: 500 !important;
  margin-top: 0.75rem;
  margin-bottom: 1rem;
  padding-left: 1rem;
}

/* Formulario */
.cidcp-form-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  justify-items: stretch;
  align-items: start;
  width: 100% !important;
  max-width: 100%;
  margin: 0;
  padding: 0.75rem 0.5rem 0;
  background-color: var(--blanco);
  border: none;
  border-radius: 0;
  box-shadow: none;
}

.cidcp-form-card > * {
  min-width: 0;
}

/* Grid con resultados - 2 columnas */
.cidcp-grid.has-results {
  grid-template-columns: 1fr;
  align-items: stretch;
}

.cidcp-grid.has-results > * {
  grid-column: 1 / -1;
  min-width: 0;
}
.cidcp-grid.has-results .cidcp-result-sidebar {
  grid-column: 1 / -1;
  grid-row: auto;
  align-self: stretch;
  justify-self: stretch;
  min-height: 0;
  position: relative;
  padding: 0.75rem 0.5rem 0;
}

.cidcp-grid.has-results {
  padding-bottom: 5.5rem;
}

.cidcp-result-sidebar .cidcp-result-card-wrapper {
  will-change: transform;
  margin: 0;
}

/* Footer */
.cidcp-footer {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  width: 100%;
  margin: 0;
  padding: 1.5rem 0;
}

.cidcp-footer-top,
.cidcp-footer-bottom {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1rem;
}

.cidcp-grid .cidcp-footer {
  grid-column: 1 / -1;
}

.cidcp-footer-top {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
}

.cidcp-footer-updated {
  color: var(--gris-texto-footer);
}

.cidcp-footer-top-right {
  display: flex;
  align-items: center;
  width: 100%;
  justify-content: space-between;
  gap: 1rem;
}

.cidcp-footer-terms {
  color: var(--azul-oscuro);
  text-decoration: none;
}

.cidcp-footer-terms:hover {
  text-decoration: underline;
}

.cidcp-footer-divider {
  width: 100%;
  height: 1px;
  background-color: var(--azul-claro);
  opacity: 0.35;
}

.cidcp-footer-bottom {
  color: var(--negro);
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 7px;
  line-height: 1rem;
  flex-wrap: wrap;
  white-space: normal;
}

.cidcp-footer-bottom > * {
  flex: 0 0 auto;
}

#cidcp-root .cidcp-footer {
  font-size: 0.875rem;
}

#cidcp-root .cidcp-footer * {
  font-size: inherit;
}

#cidcp-root .cidcp-footer-bottom {
  font-size: 0.75rem;
}

.cidcp-social {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.875rem;
}

.cidcp-footer .cidcp-social {
  display: none;
}

.cidcp-social-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: var(--logo-height);
  background-color: transparent;
  border-radius: 0.5rem;
  color: var(--azul-oscuro);
  text-decoration: none;
  transition: background-color 0.2s ease;
}

.cidcp-social-link .cidcp-icon {
  width: 100%;
  height: 100%;
  display: block;
}

.cidcp-social-link:hover {
  background-color: var(--azul-fondo-icono);
}

/* Campos de entrada */
.cidcp-input-group {
  margin-bottom: 0.5rem;
  min-width: 0;
  width: 100%;
  justify-self: stretch;
}

.cidcp-input-label {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: baseline;
  column-gap: 0.5rem;
  width: 100%;
  margin-bottom: 0.625rem;
  padding-left: 0.5rem;
  color: inherit;
  font-weight: 600 !important;
  position: relative;
}

.cidcp-input-label > span {
  min-width: 0;
  max-width: 100%;
}

.cidcp-label-tooltip {
  position: static;
  display: inline-flex;
  align-items: baseline;
  gap: 0.25rem;
  line-height: inherit;
  margin-left: 0;
  flex: 0 0 auto;
  font-weight: 600;
  justify-self: end;
}

.cidcp-label-tooltip-trigger {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  font: inherit;
  font-weight: inherit;
  color: var(--azul-oscuro);
  cursor: pointer;
  text-decoration: underline;
  white-space: nowrap;
  display: inline;
  vertical-align: baseline;
}

#cidcp-root .cidcp-label-tooltip-trigger,
#cidcp-root .cidcp-label-tooltip-trigger:hover,
#cidcp-root .cidcp-label-tooltip-trigger:focus,
#cidcp-root .cidcp-label-tooltip-trigger:active {
  background: transparent !important;
  background-color: transparent !important;
  color: var(--azul-oscuro) !important;
  box-shadow: none !important;
  border: 0 !important;
  padding: 0 !important;
}

.cidcp-label-tooltip-trigger:hover {
  text-decoration: underline;
}

.cidcp-label-tooltip-trigger:focus-visible {
  outline: 2px solid var(--azul-claro);
  outline-offset: 2px;
}

.cidcp-label-tooltip .cidcp-label-tooltip-content {
  position: absolute;
  left: 1rem;
  right: auto;
  top: calc(100% + 0.25rem);
  width: 75%;
  min-width: 50%;
  max-width: 75%;

  padding: 0.75rem 0.875rem;
  background: var(--blanco);
  border: 1px solid var(--gris-claro);
  border-radius: 0.75rem;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  color: var(--negro);
  font-size: 1rem;
  font-weight: 400;
  white-space: normal;
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition:
    opacity 0.15s ease,
    transform 0.15s ease,
    visibility 0.15s;
  z-index: 20;
}

.cidcp-label-tooltip.is-flipped .cidcp-label-tooltip-content {
  top: auto;
  bottom: calc(1em + 1rem);
  transform: translateY(-4px);
}

.cidcp-input-group[data-input-id="zonaDesfavorable"]
  .cidcp-label-tooltip
  .cidcp-label-tooltip-content {
  left: 0.5rem;
  right: 0.5rem;
  width: auto;
  min-width: 0;
  max-width: none;
}

.cidcp-tooltip-note {
  display: block;
  margin-top: 0.5rem;
  padding: 0.5rem 0.625rem;
  background: var(--gris-fondo-claro);
  border-radius: 0.75rem;
}

.cidcp-label-tooltip .cidcp-label-tooltip-content ul {
  margin: 0.5rem 0 0;
  padding-left: 1.25rem;
  list-style: disc;
}

.cidcp-label-tooltip .cidcp-label-tooltip-content li {
  margin: 0.25rem 0;
}

.cidcp-tooltip-button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-top: 0.75rem;
  border-radius: 2rem !important;
  padding: 0.875rem 1rem;
  min-height: 48px;
  text-align: center;
  text-decoration: none;
}

.cidcp-label-tooltip:hover .cidcp-label-tooltip-content,
.cidcp-label-tooltip:focus-within .cidcp-label-tooltip-content {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.cidcp-input-wrapper {
  position: relative;
}

.cidcp-input-wrapper .cidcp-input-icon {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.5rem;
  height: 1.5rem;
  color: var(--gris-claro);
  pointer-events: none;
}

.cidcp-input-wrapper:hover .cidcp-input-icon {
  color: var(--azul-claro);
}

.cidcp-input-wrapper .cidcp-input-icon .cidcp-icon {
  width: 100%;
  height: 100%;
  display: block;
}

.cidcp-select {
  position: relative;
}

.cidcp-select-button {
  cursor: pointer;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  position: relative;
  padding-right: 3.25rem;
}

.cidcp-select-button.is-placeholder .cidcp-select-value {
  color: var(--gris-claro);
}

.cidcp-select-chevron {
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1.25rem;
  height: 1.25rem;
  flex: 0 0 auto;
  color: var(--gris-claro);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.cidcp-select-chevron .cidcp-icon {
  width: 100%;
  height: 100%;
  transform: rotate(-90deg);
}

.cidcp-select-dropdown {
  position: absolute;
  left: 0;
  right: 0;
  top: calc(100% + 0.5rem);
  background: var(--blanco);
  border-radius: 1rem;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.18);
  padding: 0.5rem;
  z-index: 60;
  max-height: 320px;
  overflow: auto;
}

.cidcp-select-option {
  width: 100%;
  border: 0;
  background: transparent;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0.875rem;
  border-radius: 0.75rem;
  color: var(--negro);
  font: inherit;
  text-align: left;
}

#cidcp-root .cidcp-select-option {
  color: var(--negro) !important;
}

.cidcp-select-option:hover {
  background: var(--gris-100);
}

#cidcp-root .cidcp-select-option:hover,
#cidcp-root .cidcp-select-option:focus,
#cidcp-root .cidcp-select-option:active {
  background: var(--gris-100) !important;
  color: var(--negro) !important;
}

.cidcp-select-option.is-selected {
  background: rgba(95, 109, 253, 0.22);
  color: var(--negro);
}

#cidcp-root .cidcp-select-option.is-selected,
#cidcp-root .cidcp-select-option.is-selected:hover,
#cidcp-root .cidcp-select-option.is-selected:focus,
#cidcp-root .cidcp-select-option.is-selected:active {
  background: rgba(95, 109, 253, 0.22) !important;
  color: var(--negro) !important;
}

#cidcp-root .cidcp-select-option .cidcp-select-option-label {
  color: inherit !important;
}

.cidcp-select-option-check {
  width: 1rem;
  height: 1rem;
  flex: 0 0 auto;
  opacity: 0;
}

.cidcp-select-option.is-selected .cidcp-select-option-check {
  opacity: 1;
  color: var(--azul-oscuro);
}

.cidcp-select-option-check .cidcp-icon {
  width: 100%;
  height: 100%;
  display: block;
}

#cidcp-root .cidcp-input {
  display: block;
  width: 100%;
  min-height: 48px;
  padding: 0.875rem 1rem;
  border: 1px solid var(--gris-claro) !important;
  border-radius: 2rem !important;
  background-color: var(--blanco) !important;
  color: inherit !important;
  font: inherit;
  transition: all 0.2s ease;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05) !important;
  -webkit-appearance: none;
  appearance: none;
}

#cidcp-root .cidcp-input:hover {
  border-color: var(--azul-claro);
  border-width: 2px;
}

#cidcp-root .cidcp-input:disabled {
  background-color: var(--gris-100) !important;
  border-color: var(--gris-claro) !important;
  color: var(--gris-oscuro) !important;
  cursor: not-allowed;
  box-shadow: none;
  opacity: 0.85;
}

#cidcp-root .cidcp-select-button:disabled {
  opacity: 0.75;
}

#cidcp-root .cidcp-select-button:disabled .cidcp-select-chevron {
  color: var(--gris-oscuro);
}

#cidcp-root .cidcp-input:disabled:hover,
#cidcp-root .cidcp-input:disabled:focus {
  border-color: var(--gris-claro);
  border-width: 1px;
  box-shadow: none;
  transform: none;
}

#cidcp-root .cidcp-input:focus {
  outline: none;
  border-color: var(--azul-claro);
  border-width: 2px;
  box-shadow:
    0 0 0 3px rgba(95, 109, 253, 0.25),
    0 0 18px rgba(95, 109, 253, 0.35),
    0 1px 2px rgba(0, 0, 0, 0.05);
}

#cidcp-root .cidcp-input.is-warning {
  background-color: var(--rojo-fondo);
  border-color: var(--rojo-error);
  border-width: 2px;
}

#cidcp-root .cidcp-input.is-warning:hover {
  border-color: var(--rojo-error);
}

#cidcp-root .cidcp-input.is-warning:focus {
  border-color: var(--rojo-error);
  box-shadow:
    0 0 0 3px rgba(239, 68, 68, 0.25),
    0 1px 2px rgba(0, 0, 0, 0.05);
}

#cidcp-root .cidcp-input.with-icon {
  padding-right: 2.875rem;
}

.cidcp-date-range {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
}

.flatpickr-calendar {
  border-radius: 1.5rem;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.16);
  border: 0;
  overflow: hidden;
  max-width: 96vw;
  min-width: 0;
  font-size: 14px;
}

.flatpickr-innerContainer {
  padding: 1rem 1.25rem 1.25rem;
}

.flatpickr-rContainer,
.flatpickr-weekdaycontainer,
.flatpickr-days,
.dayContainer {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
}

.flatpickr-months {
  padding: 0.75rem 0.75rem 0;
  display: grid !important;
  grid-template-columns: 2.25rem minmax(0, 1fr) 2.25rem;
  align-items: center;
  min-height: 2.75rem;
}

.flatpickr-months .flatpickr-prev-month {
  grid-column: 1;
}

.flatpickr-months .flatpickr-month {
  grid-column: 2;
  min-width: 0;
}

.flatpickr-months .flatpickr-next-month {
  grid-column: 3;
}

.flatpickr-months .flatpickr-month {
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 2.75rem;
}

.flatpickr-current-month {
  position: static;
  font-size: 1.1em;
  line-height: 1.2;
  font-weight: 600;
  color: var(--negro);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  padding: 0;
  height: 100%;
  flex-wrap: nowrap;
  white-space: nowrap;
  width: 100%;
  min-width: 0;
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
  display: inline-flex;
  width: auto;
}

.flatpickr-current-month .numInputWrapper {
  display: inline-flex;
  width: 8ch;
}

.flatpickr-current-month .numInputWrapper input,
.flatpickr-current-month .numInputWrapper span {
  line-height: inherit;
}

@media (max-width: 420px) {
  .flatpickr-months {
    padding: 0.75rem 0.5rem 0;
    grid-template-columns: 2rem 1fr 2rem;
  }

  .flatpickr-current-month {
    justify-content: flex-start;
    padding-left: 0.25rem;
    width: 80%;
  }
}

.flatpickr-weekdays {
  margin-top: 0.75rem;
}

.flatpickr-weekday {
  color: var(--gris-oscuro);
  font-weight: 600;
}

.flatpickr-day {
  border-radius: 9999px;
  aspect-ratio: 1 / 1;
  height: auto;
  line-height: normal;
  display: flex;
  align-items: center;
  justify-content: center;
}

.flatpickr-day:hover {
  background: rgba(95, 109, 253, 0.18);
  border-color: transparent;
}

.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange,
.flatpickr-day.selected:hover,
.flatpickr-day.startRange:hover,
.flatpickr-day.endRange:hover {
  background: var(--azul-oscuro);
  border-color: var(--azul-oscuro);
  color: var(--blanco);
}

.flatpickr-day.inRange {
  background: rgba(30, 45, 190, 0.12);
  border-color: transparent;
  box-shadow: none;
}

.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay {
  color: var(--gris-claro);
}

.flatpickr-calendar .flatpickr-months .flatpickr-prev-month,
.flatpickr-calendar .flatpickr-months .flatpickr-next-month {
  position: static !important;
  top: auto !important;
  right: auto !important;
  bottom: auto !important;
  left: auto !important;
  transform: none !important;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 2.25rem;
  width: 2.25rem;
}

.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg {
  fill: var(--gris-oscuro);
}

.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg {
  fill: var(--negro);
}

.cidcp-input-group.is-disabled .cidcp-input-wrapper:hover .cidcp-input-icon {
  color: var(--gris-claro);
}

#cidcp-root .cidcp-input::placeholder {
  color: var(--gris-claro);
}

.cidcp-input-help {
  margin-top: 0.375rem;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  color: var(--gris-oscuro);
  font-size: 0.85rem;
  line-height: 1.4;
}

.cidcp-input-warning {
  margin-top: 0.375rem;
  padding-left: 0.75rem;
  padding-right: 0.75rem;
  color: var(--rojo-texto-warning);
  font-size: 0.85rem;
}

/* Radio buttons */
.cidcp-radio-group {
  display: flex;
  flex-direction: row;
  gap: 0.4rem;
}

.cidcp-radio-label {
  display: flex;
  align-items: center;
  color: var(--negro);
  cursor: pointer;
  min-height: 48px;
  padding: 0.5rem 0;
}

.cidcp-radio-label input[type="radio"] {
  margin-right: 0.875rem;
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: 20px;
  position: relative;
  top: -1px;
  border-radius: 9999px;
  appearance: none;
  -webkit-appearance: none;
  background-color: var(--blanco);
  border: 2px solid var(--azul-oscuro);
  transition:
    background-color 0.15s ease,
    transform 0.15s ease;
  cursor: pointer;
}

.cidcp-radio-label input[type="radio"]:hover {
  box-shadow: none;
}

.cidcp-radio-label input[type="radio"]:active {
  transform: scale(0.98);
}

.cidcp-radio-label input[type="radio"]:checked {
  background-image: radial-gradient(
    circle at center,
    var(--azul-radio-fondo) 0 45%,
    transparent 46%
  );
  box-shadow: none;
}

.cidcp-radio-label input[type="radio"]:focus-visible {
  outline: 2px solid var(--azul-oscuro);
  outline-offset: 2px;
  box-shadow: none;
}

.cidcp-radio-label input[type="radio"]:disabled {
  background-color: var(--gris-100);
  border-color: var(--gris-claro);
  cursor: not-allowed;
  opacity: 0.7;
}

.cidcp-input-group.is-disabled .cidcp-radio-label {
  cursor: not-allowed;
  color: var(--gris-oscuro);
}

.cidcp-radio-label input[type="radio"]:disabled:active {
  transform: none;
}

.cidcp-radio-label input[type="radio"]:disabled:focus-visible {
  outline: none;
}

.cidcp-radio-label input[type="radio"]:checked + span {
  font-weight: 600;
}

.cidcp-toggle-amount {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.75rem;
  position: relative;
  width: 100%;
  min-width: 0;
}

.cidcp-toggle-amount-header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
  row-gap: 0.25rem;
  position: relative;
  width: 100%;
  min-width: 0;
  max-width: 100%;
}

.cidcp-toggle-amount-header .cidcp-input-label {
  margin-bottom: 0;
  padding-left: 0.5rem;
  flex: 0 1 auto;
  width: auto;
  min-width: 0;
}

.cidcp-toggle-amount-header .cidcp-input-label > span {
  overflow-wrap: anywhere;
}

.cidcp-toggle-amount-header .cidcp-label-tooltip {
  margin-top: 0;
  width: auto;
  justify-content: flex-end;
  margin-left: auto;
}

.cidcp-toggle-amount-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  flex: 0 0 auto;
}

.cidcp-toggle-amount-toggle input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
}

.cidcp-toggle-amount-visual {
  width: 47px;
  height: 25px;
  border: 1px solid var(--gris-claro);
  background-color: var(--gris-100);
  border-radius: 9999px;
  display: inline-block;
  position: relative;
  transition:
    background-color 0.15s ease,
    border-color 0.15s ease;
}

.cidcp-toggle-amount-visual::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 4px;
  width: 15px;
  height: 15px;
  border-radius: 9999px;
  transform: translateY(-50%);
  background-color: var(--gris-claro);
  transition:
    transform 0.15s ease,
    background-color 0.15s ease;
}

.cidcp-toggle-amount-toggle
  input[type="checkbox"]:checked
  + .cidcp-toggle-amount-visual {
  background-color: rgba(95, 109, 253, 0.22);
  border-color: rgba(30, 45, 190, 0.35);
}

.cidcp-toggle-amount-toggle
  input[type="checkbox"]:checked
  + .cidcp-toggle-amount-visual::after {
  transform: translateY(-50%) translateX(24px);
  background-color: var(--azul-oscuro);
}

.cidcp-toggle-amount-toggle
  input[type="checkbox"]:focus-visible
  + .cidcp-toggle-amount-visual {
  outline: 2px solid var(--azul-oscuro);
  outline-offset: 3px;
}

.cidcp-toggle-amount-input {
  width: 100%;
}

.cidcp-optional-section {
  padding-top: 1.5rem;
}

/* Botones */
.cidcp-button-primary {
  background-color: var(--gris-botones);
  color: var(--azul-oscuro);
  border: none;
  border-radius: 0.75rem;
  padding: 1rem 2rem;
  font-weight: 700 !important;
  transition: all 0.2s ease;
  cursor: pointer;
  min-height: 52px;
  width: 100%;
  box-shadow: none;
}

.cidcp-button-primary:hover:not(:disabled) {
  background-color: var(--azul-oscuro);
  color: var(--blanco);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(0, 102, 255, 0.3);
}

.cidcp-button-primary:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(0, 102, 255, 0.2);
}

.cidcp-button-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

#cidcp-root button.cidcp-button-primary:disabled,
#cidcp-root .cidcp-button-primary:disabled {
  background: var(--gris-botones) !important;
  background-color: var(--gris-botones) !important;
  color: var(--azul-oscuro) !important;
  box-shadow: none !important;
  filter: none !important;
}

#cidcp-root button.cidcp-calculate-button:disabled,
#cidcp-root button.cidcp-calculate-button[disabled],
#cidcp-root button.cidcp-calculate-button.cidcp-button-primary:disabled,
#cidcp-root button.cidcp-calculate-button.cidcp-button-primary[disabled],
#cidcp-root button.cidcp-calculate-button:disabled:hover,
#cidcp-root button.cidcp-calculate-button:disabled:active,
#cidcp-root button.cidcp-calculate-button:disabled:focus {
  background: var(--gris-botones) !important;
  background-color: var(--gris-botones) !important;
  color: var(--azul-oscuro) !important;
  box-shadow: none !important;
  filter: none !important;
}

.cidcp-button-secondary {
  background-color: transparent;
  color: var(--azul-oscuro);
  border: 1px solid var(--azul-oscuro);
  border-radius: 0.75rem;
  padding: 1rem 2rem;
  font-weight: 700 !important;
  transition: all 0.2s ease;
  cursor: pointer;
  min-height: 52px;
  width: 100%;
  box-shadow: none;
}

.cidcp-button-secondary:hover:not(:disabled) {
  background-color: var(--azul-oscuro);
  color: var(--blanco);
  transform: translateY(-1px);
  box-shadow: 0 4px 8px rgba(0, 102, 255, 0.3);
}

.cidcp-button-secondary:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(0, 102, 255, 0.2);
}

.cidcp-button-secondary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.cidcp-calculate-button-wrapper {
  margin-top: 1rem;
}

.cidcp-calculate-button {
  padding-top: 1.5rem;
  margin-bottom: 2rem;
  border-radius: 2rem;
}

/* Resultados */
.cidcp-result-card-wrapper {
  background-color: var(--gris-fondo-resultados);
  border-radius: 2rem;
  margin: 1.25rem;
  padding: 1.25rem;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  display: flex;
  align-items: stretch;
  min-height: 0;
}

.cidcp-result-card {
  background-color: var(--gris-fondo-resultados);
  border-radius: 1.75rem;
  border: 1px solid var(--azul-borde);
  padding: 1.25rem;
  box-shadow: none;
  align-self: flex-start;
  height: auto;
  width: 100%;
  max-height: none;
  overflow: visible;
  display: flex;
  flex-direction: column;
}

#cidcp-root .cidcp-result-title {
  font-size: 22px !important;
  font-weight: 700;
  color: var(--azul-oscuro) !important;
  margin: 0;
  text-align: center;
}

.cidcp-result-title::after {
  content: "";
  display: block;
  height: 1px;
  background-color: var(--azul-borde);
  margin: 1.25rem 0 1.75rem;
}

.cidcp-result-grid {
  display: grid;
  grid-template-columns: 1fr;
  column-gap: 3rem;
  row-gap: 1.5rem;
}

#cidcp-root .cidcp-result-sidebar--accordion .cidcp-result-grid {
  grid-template-columns: 1fr 1fr;
  column-gap: 1rem;
  row-gap: 1.5rem;
}

.cidcp-result-cell {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.cidcp-result-cell--full {
  grid-column: 1 / -1;
}

#cidcp-root .cidcp-result-sidebar--accordion .cidcp-page-back {
  position: static;
  margin: 0 0 1rem;
}

.cidcp-result-label {
  color: var(--negro);
  font-weight: 700;
  line-height: 1.2;
}

.cidcp-result-money {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 700;
  font-size: 22px;
  color: var(--azul-oscuro);
}

.cidcp-result-icon {
  width: 1rem;
  height: 1rem;
  color: var(--azul-claro);
  flex-shrink: 0;
}

.cidcp-result-total-section {
  margin-top: 1.75rem;
  border-top: 1px solid var(--azul-borde);
}

.cidcp-result-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}

.cidcp-result-total-label {
  flex: 1 1 auto;
  min-width: 0;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--negro) !important;
}

.cidcp-result-total-money {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  flex: 0 0 auto;
  font-weight: 700;
  font-size: 28px;
  color: var(--azul-oscuro);
}

.cidcp-result-actions {
  margin-top: 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.75rem;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}

#cidcp-root .cidcp-result-download-button {
  background-color: var(--gris-botones);
  color: var(--azul-oscuro);
  border: none;
  border-radius: 2rem;
  padding: 1rem 1.25rem;
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.75rem;
  font-weight: 700;
  cursor: pointer;
  flex: 1 1 auto;
  min-width: 0;
  width: auto;
}

#cidcp-root .cidcp-result-download-button--icon {
  width: 52px;
  height: 52px;
  padding-left: 0;
  padding-right: 0;
  flex: 0 0 auto;
}

.cidcp-result-download-button .cidcp-icon {
  width: 1.125rem;
  height: 1.125rem;
  color: var(--azul-oscuro);
}

#cidcp-root .cidcp-result-download-button--icon .cidcp-icon {
  width: 38px;
  height: 38px;
}

#cidcp-root .cidcp-result-sidebar--accordion {
  padding: 0;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 1200;
  background: transparent;
  pointer-events: auto;
}

#cidcp-root .cidcp-result-accordion {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: 0.75rem 0.5rem;
  pointer-events: auto;
}

#cidcp-root .cidcp-result-sidebar--accordion .cidcp-result-accordion-header {
  display: none;
}

#cidcp-root .cidcp-result-accordion-header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-radius: 1.5rem;
  border: 1px solid var(--azul-borde);
  background-color: var(--gris-fondo-resultados);
  color: var(--azul-oscuro);
  cursor: pointer;
}

#cidcp-root .cidcp-result-accordion-title {
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

#cidcp-root .cidcp-result-accordion-total {
  margin-left: auto;
  font-weight: 800;
  white-space: nowrap;
}

#cidcp-root .cidcp-result-accordion-chevron {
  flex-shrink: 0;
  display: inline-flex;
  width: 1.5rem;
  height: 1.5rem;
  align-items: center;
  justify-content: center;
  transform: rotate(0deg);
  transition: transform 0.2s ease;
}

#cidcp-root .cidcp-result-accordion-chevron.is-open {
  transform: rotate(180deg);
}

#cidcp-root .cidcp-result-accordion-body {
  margin: 0;
  flex: 1 1 auto;
  max-height: none;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: 2rem;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.22);
}

#cidcp-root .cidcp-result-sidebar--accordion .cidcp-result-card-wrapper {
  margin: 0;
  overflow: visible;
  flex-direction: column;
  align-items: stretch;
}

.cidcp-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(17, 24, 39, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  z-index: 9999;
}

.cidcp-modal {
  position: relative;
  width: min(720px, 100%);
  max-height: 90vh;
  background: var(--blanco);
  font-family:
    "Raleway",
    system-ui,
    -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    sans-serif;
  font-size: 16px;
  font-weight: 400;
  border-radius: 2rem;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.25);
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.cidcp-modal h1,
.cidcp-modal h2,
.cidcp-modal h3,
.cidcp-modal h4,
.cidcp-modal h5,
.cidcp-modal h6 {
  font-family: inherit;
}

.cidcp-modal-close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, 0.25);
  background: rgba(255, 255, 255, 0.95);
  color: rgba(17, 24, 39, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 24px;
  line-height: 1;
}

.cidcp-modal-scroll {
  overflow: auto;
  padding-top: 0.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.cidcp-modal .cidcp-result-card-wrapper {
  margin: 0;
  max-height: none;
}

.cidcp-modal .cidcp-result-card {
  max-height: none;
  overflow: visible;
}

.cidcp-modal .cidcp-result-card--dialog .cidcp-result-cell {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
}

.cidcp-modal .cidcp-result-card--dialog .cidcp-result-label {
  max-width: none;
}

.cidcp-modal .cidcp-result-card--dialog .cidcp-result-money {
  white-space: nowrap;
}

#cidcp-root [data-cidcp-capture="pdf"] {
  font-size: 16px;
}

#cidcp-root [data-cidcp-capture="pdf"] .cidcp-result-grid {
  grid-template-columns: 1fr 1fr;
  column-gap: 1rem;
}

#cidcp-root [data-cidcp-capture="pdf"] .cidcp-result-label {
  font-size: 16px;
}

#cidcp-root [data-cidcp-capture="pdf"] .cidcp-result-money {
  font-size: 22px;
}

#cidcp-root [data-cidcp-capture="pdf"] .cidcp-result-total-label {
  font-size: 26px;
}

#cidcp-root [data-cidcp-capture="pdf"] .cidcp-result-total-money {
  font-size: 28px;
}

.cidcp-modal-disclaimer {
  background: var(--gris-100);
  border-radius: 2rem;
  margin-top: 1rem;
  padding: 1.25rem;
  color: rgba(17, 24, 39, 0.75);
  font-size: 14px;
  line-height: 1.55;
}

.cidcp-modal-actions {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
  width: 100%;
  align-items: stretch;
}

.cidcp-modal-action {
  width: 100%;
  border: none;
  border-radius: 2rem;
  padding: 1.1rem 1.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  cursor: pointer;
  font-weight: 700;
  font-size: 18px;
}

.cidcp-modal-action .cidcp-icon {
  width: 1.125rem;
  height: 1.125rem;
}

.cidcp-modal-action--primary {
  background: #e6efff;
  color: var(--azul-oscuro);
  grid-column: 1 / -1;
}

#cidcp-root .cidcp-modal-action--primary:hover,
#cidcp-root .cidcp-modal-action--primary:focus,
#cidcp-root .cidcp-modal-action--primary:active {
  background: #e6efff !important;
  color: var(--azul-oscuro) !important;
  filter: none !important;
  opacity: 1 !important;
}

.cidcp-modal-action--secondary {
  background: var(--gris-100);
  color: var(--azul-oscuro);
}

.cidcp-modal-action--icon {
  width: 52px;
  height: 52px;
  padding: 0;
  justify-self: end;
}

.cidcp-modal-action--icon .cidcp-icon {
  width: 38px;
  height: 38px;
}

#cidcp-root .cidcp-modal-action--secondary:hover,
#cidcp-root .cidcp-modal-action--secondary:focus,
#cidcp-root .cidcp-modal-action--secondary:active {
  background: var(--gris-100) !important;
  color: var(--azul-oscuro) !important;
  filter: none !important;
  opacity: 1 !important;
}

.cidcp-page-overlay {
  background: var(--blanco);
}

.cidcp-toast-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 1rem;
  background: rgba(17, 24, 39, 0.35);
}

.cidcp-toast {
  width: 100%;
  max-width: 720px;
  background: var(--blanco);
  border: 1px solid rgba(17, 24, 39, 0.15);
  border-radius: 1rem;
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
  padding: 1rem 1.25rem;
  color: var(--gris-900-85);
  font-weight: 600;
  line-height: 1.4;
}

.cidcp-toast-link {
  display: inline-flex;
  margin-top: 0.75rem;
  font-weight: 800;
  color: var(--azul-oscuro);
  text-decoration: underline;
}

.cidcp-pdf-capture-host {
  position: fixed;
  left: -10000px;
  top: 0;
  width: 1024px;
  background: #ffffff;
  pointer-events: none;
  z-index: -1;
}

.cidcp-page-overlay-inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 1.25rem 1rem 2rem;
}

.cidcp-page-back {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  border: 0;
  background: transparent;
  color: var(--azul-oscuro);
  font-size: 0.9rem;
  font-weight: 600;
  cursor: pointer;
  padding: 0;
}

.cidcp-page-back .cidcp-icon {
  width: 10px;
  height: 10px;
}

.cidcp-page-title {
  margin-top: 1rem;
  margin-bottom: 1rem;
  color: var(--azul-oscuro);
  font-size: 22px !important;
}

.cidcp-page-divider {
  width: 100%;
  height: 2px;
  background-color: var(--azul-borde);
  margin-bottom: 1.5rem;
}

.cidcp-page-content {
  width: 100%;
  padding: 0 0.25rem 1.5rem;
  color: var(--gris-900);
}

.cidcp-page-content p {
  margin: 0.75rem 0;
}

.cidcp-page-content ul {
  margin: 0.75rem 0 0.75rem 1.25rem;
}

@media print {
  @page {
    margin: 8mm;
  }

  body:not(.cidcp-print-mode) * {
    visibility: hidden !important;
  }

  body:not(.cidcp-print-mode) .cidcp-calculadora-wrapper,
  body:not(.cidcp-print-mode) .cidcp-calculadora-wrapper * {
    visibility: visible !important;
  }

  body:not(.cidcp-print-mode) .cidcp-calculadora-wrapper {
    position: absolute !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
  }

  body:not(.cidcp-print-mode) #cidcp-root,
  body:not(.cidcp-print-mode) .cidcp-main-container {
    min-height: 0 !important;
    height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  body:not(.cidcp-print-mode) #cidcp-root .cidcp-header,
  body:not(.cidcp-print-mode) #cidcp-root .role-selector-container,
  body:not(.cidcp-print-mode) #cidcp-root .cidcp-tabs,
  body:not(.cidcp-print-mode) #cidcp-root .cidcp-social,
  body:not(.cidcp-print-mode) #cidcp-root .cidcp-result-actions,
  body:not(.cidcp-print-mode) #cidcp-root .cidcp-page-back {
    display: none !important;
  }

  body.cidcp-print-mode * {
    visibility: hidden !important;
  }

  body.cidcp-print-mode .cidcp-modal-overlay,
  body.cidcp-print-mode .cidcp-modal-overlay * {
    visibility: visible !important;
  }

  body.cidcp-print-mode #cidcp-root > :not(.cidcp-modal-overlay) {
    display: none !important;
  }

  body.cidcp-print-mode .cidcp-pdf-capture-host {
    display: none !important;
  }

  body {
    margin: 0 !important;
    padding: 0 !important;
  }

  body.cidcp-print-mode #cidcp-root {
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    min-height: 0 !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
  }

  body.cidcp-print-mode,
  body.cidcp-print-mode .cidcp-modal,
  body.cidcp-print-mode .cidcp-modal * {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }

  body.cidcp-print-mode .cidcp-modal-overlay {
    display: block !important;
    position: static !important;
    inset: auto;
    background: transparent;
    padding: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    break-before: avoid-page;
    page-break-before: avoid;
    break-inside: avoid;
    page-break-inside: avoid;
  }

  body.cidcp-print-mode .cidcp-modal {
    width: 100% !important;
    max-width: 720px !important;
    max-height: none;
    box-shadow: none;
    position: static !important;
    padding: 0.75rem !important;
    margin: 0 auto !important;
    border-radius: 1.25rem !important;
    break-inside: avoid;
    page-break-inside: avoid;
  }

  body.cidcp-print-mode .cidcp-modal-scroll {
    overflow: visible;
    padding-top: 0.25rem !important;
    gap: 0.75rem !important;
  }

  body.cidcp-print-mode .cidcp-modal .cidcp-result-card-wrapper {
    margin: 0 !important;
    padding: 0.75rem !important;
    border-radius: 1.25rem !important;
    overflow: hidden !important;
    break-inside: avoid;
    page-break-inside: avoid;
  }

  body.cidcp-print-mode .cidcp-modal-disclaimer {
    display: block !important;
    margin-top: 0.5rem !important;
    padding: 0.625rem 0.75rem !important;
    border-radius: 1.25rem !important;
    font-size: 11px !important;
    line-height: 1.35 !important;
    break-inside: avoid;
    page-break-inside: avoid;
  }

  body.cidcp-print-mode .cidcp-modal .cidcp-result-card {
    border-radius: 1.75rem !important;
  }

  body.cidcp-print-mode #cidcp-root .cidcp-modal .cidcp-result-label {
    font-size: 16px !important;
  }

  body.cidcp-print-mode #cidcp-root .cidcp-modal .cidcp-result-money {
    font-size: 22px !important;
  }

  body.cidcp-print-mode #cidcp-root .cidcp-modal .cidcp-result-total-label {
    font-size: 26px !important;
  }

  body.cidcp-print-mode #cidcp-root .cidcp-modal .cidcp-result-total-money {
    font-size: 28px !important;
  }

  body.cidcp-print-mode
    .cidcp-modal
    .cidcp-result-card--dialog
    .cidcp-result-cell {
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
  }

  body.cidcp-print-mode
    .cidcp-modal
    .cidcp-result-card--dialog
    .cidcp-result-label {
    max-width: none !important;
  }

  body.cidcp-print-mode
    .cidcp-modal
    .cidcp-result-card--dialog
    .cidcp-result-money {
    white-space: nowrap;
  }

  body.cidcp-print-mode .cidcp-modal-close,
  body.cidcp-print-mode .cidcp-modal-actions {
    display: none;
  }
}

/* Mensajes de error */
.cidcp-error-message {
  background-color: var(--rojo-fondo);
  border: 1px solid var(--rojo-borde);
  color: var(--rojo-error);
  padding: 1rem 1.25rem;
  margin-top: 0.5rem;
  border-radius: 0.75rem;
  line-height: 1.5;
  box-shadow: 0 1px 3px rgba(239, 68, 68, 0.1);
}

.cidcp-warning-message {
  background-color: #fff7ed;
  border: 1px solid #fdba74;
  color: #9a3412;
  padding: 1rem 1.25rem;
  margin-top: 0.5rem;
  border-radius: 0.75rem;
  line-height: 1.5;
}

/* Utilidades */
.cidcp-text-center {
  text-align: center;
}
.cidcp-flex {
  display: flex;
}
.cidcp-flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.cidcp-space-y-4 > * + * {
  margin-top: 1.25rem;
}
.cidcp-space-y-6 > * + * {
  margin-top: 1.75rem;
}

.full-width {
  width: 100%;
}

@media (max-width: 639px) {
  #cidcp-root,
  #cidcp-root .cidcp-label-tooltip .cidcp-label-tooltip-content,
  #cidcp-root .cidcp-button-primary,
  #cidcp-root .cidcp-button-secondary,
  #cidcp-root .cidcp-result-download-button,
  #cidcp-root .cidcp-error-message {
    font-size: 14px;
  }

  #cidcp-root h3.cidcp-optional-title,
  #cidcp-root .cidcp-result-money {
    font-size: 14px;
  }

  #cidcp-root .cidcp-result-label {
    font-size: 16px;
  }

  #cidcp-root .cidcp-result-total-money {
    font-size: 16px;
  }

  #cidcp-root h2.cidcp-form-title,
  #cidcp-root .cidcp-result-total-label {
    font-size: 18px;
  }

  #cidcp-root .cidcp-form-title-note,
  #cidcp-root .cidcp-disclaimer-banner,
  #cidcp-root .cidcp-tab-button,
  #cidcp-root .cidcp-role-button {
    font-size: 12px;
  }

  #cidcp-root .cidcp-page-back {
    font-size: 10px;
  }

  #cidcp-root .cidcp-result-total-row {
    display: grid;
    gap: 0.5rem;
  }

  .flatpickr-innerContainer {
    padding: 0.75rem 0.75rem 1rem;
  }

  .flatpickr-calendar {
    font-size: 12px;
    max-width: min(360px, 96vw);
  }

  .flatpickr-rContainer,
  .flatpickr-weekdaycontainer,
  .flatpickr-days,
  .dayContainer {
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
  }

  .flatpickr-months {
    padding: 0.5rem 0.5rem 0;
  }

  .flatpickr-months {
    min-height: 2.5rem;
  }

  .flatpickr-months .flatpickr-month {
    min-height: 2.5rem;
  }

  .flatpickr-current-month {
    font-size: 16px;
  }

  .flatpickr-weekdays {
    margin-top: 0.5rem;
  }

  .flatpickr-calendar .flatpickr-months .flatpickr-prev-month,
  .flatpickr-calendar .flatpickr-months .flatpickr-next-month {
    height: 2rem;
    width: 2rem;
  }
}

@media (min-width: 640px) {
  /* Role Selector Desktop */
  .cidcp-role-button {
    padding: 1rem 3rem;
  }
  .cidcp-role-selector .role-buttons {
    display: inline-flex;
    width: auto;
    max-width: none;
    margin: 1rem auto 0;
  }

  .cidcp-role-button {
    flex: 0 0 auto;
    min-width: auto;
    line-height: normal;
  }

  /* Pestañas Desktop */
  .cidcp-tabs {
    padding: 0;
  }

  .cidcp-tab-button {
    padding: 0.75rem 1rem;
    line-height: 1.4;
    min-height: 48px;
  }

  /* Campos Desktop */
  .cidcp-input-label {
    margin-bottom: 0.75rem;
  }

  .cidcp-form-card {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0 2rem;
    padding: 1rem 0.5rem 0;
  }

  .cidcp-form-card .cidcp-input-group > .cidcp-input-label {
    min-height: 3rem;
    align-content: end;
  }
  .cidcp-form-card .cidcp-toggle-amount-header {
    min-height: 3rem;
    align-items: flex-end;
  }
  .cidcp-input {
    padding: 1rem 1.125rem;
    min-height: 52px;
  }
  .cidcp-input.with-icon {
    padding-right: 3.25rem;
  }
  .cidcp-input-wrapper .cidcp-input-icon {
    right: 1.125rem;
  }
  .cidcp-date-range {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
  .cidcp-radio-group {
    flex-direction: row;
    gap: 0.75rem;
  }
  .cidcp-radio-label {
    min-height: 52px;
    padding: 0.625rem 0;
  }
  .cidcp-radio-label input[type="radio"] {
    width: 22px;
    height: 22px;
    min-width: 22px;
    min-height: 22px;
    margin-right: 1rem;
  }

  /* Campos adicionales Desktop */
  .cidcp-optional-section {
    padding-top: 2rem;
  }

  /* Botones Desktop */
  .cidcp-button-primary {
    padding: 1.125rem 2.5rem;
    min-height: 56px;
  }

  .cidcp-result-grid {
    grid-template-columns: 1fr 1fr;
    column-gap: 1rem;
  }

  .cidcp-modal .cidcp-result-grid .cidcp-result-grid-spacer {
    display: block;
  }
}

@media (min-width: 768px) {
  .cidcp-header {
    padding: 0.75rem 0;
  }
  .header-container {
    padding: 0 1.5rem;
    gap: 2rem;
  }
  .cidcp-header .header-nav {
    display: flex;
  }
  .cidcp-header .header-nav > nav {
    display: flex;
    gap: 2rem;
  }

  .cidcp-header-actions {
    display: none;
  }

  .cidcp-header-backdrop {
    display: none;
  }

  .cidcp-header-menu {
    display: none;
  }

  .cidcp-tabs-inner {
    gap: 2rem;
  }

  .cidcp-footer .cidcp-social {
    display: flex;
  }

  .cidcp-footer-top {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }

  .cidcp-footer-top-right {
    width: auto;
    justify-content: flex-end;
    gap: 1.5rem;
  }

  .cidcp-footer-bottom {
    justify-content: center;
    flex-wrap: nowrap;
    white-space: nowrap;
  }
}

@media (min-width: 1024px) {
  .cidcp-grid.has-results {
    grid-template-columns: minmax(0, 3fr) minmax(0, 2fr);
    align-items: stretch;
  }

  .cidcp-grid.has-results > * {
    grid-column: 1 / 2;
    min-width: 0;
  }

  .cidcp-grid.has-results h2.cidcp-form-title,
  .cidcp-grid.has-results h3.cidcp-optional-title,
  .cidcp-grid.has-results .cidcp-form-card {
    grid-column: span 1;
  }

  .cidcp-grid.has-results h2.cidcp-form-title {
    grid-column: 1 / 2;
    grid-row: 1;
  }

  .cidcp-grid.has-results .cidcp-form-card:nth-of-type(1) {
    grid-column: 1 / 2;
    grid-row: 2;
  }

  .cidcp-grid.has-results h3.cidcp-optional-title {
    grid-column: 1 / 2;
    grid-row: 3;
  }

  .cidcp-grid.has-results .cidcp-form-card:nth-of-type(2) {
    grid-column: 1 / 2;
    grid-row: 4;
  }

  .cidcp-grid.has-results .cidcp-result-sidebar {
    grid-column: 2 / 3;
    grid-row: 1 / span 99;
    align-self: stretch;
    justify-self: stretch;
    min-height: 0;
    position: relative;
    padding: 1.25rem;
  }

  .cidcp-grid.has-results .cidcp-footer {
    grid-column: 1 / -1;
  }

  .cidcp-grid.has-results .calculate-button {
    grid-column: 1 / 2;
  }

  .cidcp-header .header-left {
    gap: 3rem;
  }
}

/* Accesibilidad y Touch Targets */
@media (hover: none) and (pointer: coarse) {
  .cidcp-role-button,
  .cidcp-button-primary,
  .cidcp-radio-label {
    min-height: 48px;
    min-width: 48px;
  }
  .cidcp-input {
    min-height: 48px; /* Previene zoom en iOS */
  }
}

/* Animaciones sutiles */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.cidcp-form-card,
.cidcp-result-card {
  animation: fadeIn 0.3s ease-out;
}
