
/* ========================================= */
/* COMPONENT: back-button */
/* ========================================= */
/* ==========================================================================
   BACK BUTTON COMPONENT
   ========================================================================== */

.back-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--gn-spacing-2, 8px);
  padding: var(--gn-spacing-2, 8px) var(--gn-spacing-1, 4px) var(--gn-spacing-2, 8px) 0;
  border-radius: var(--gn-radius-base, 3px);
  color: var(--gn-color-text-default, #171717);
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  text-decoration: none;
  background: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  transition: all 0.2s ease;
}

.back-button__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--gn-color-primary, #d82b0f);
}

.back-button__text {
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 400;
  color: currentColor;
  text-decoration: underline;
  text-decoration-thickness: 4%;
  text-underline-offset: 25%;
  transition: text-decoration-thickness 0.2s ease;
}

/* Hover state */
.back-button:hover,
.back-button.is-hover {
  color: var(--gn-color-link-hover, #a3200b);
}

.back-button:hover .back-button__text,
.back-button.is-hover .back-button__text {
  text-decoration-thickness: 14%;
}

/* Focus state */
.back-button:focus-visible,
.back-button.is-focus {
  /* En Figma usa color text-error/primary para focus */
  color: var(--gn-color-primary, #d82b0f);
  background-color: rgba(255, 255, 255, 0.02);
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

.back-button:focus-visible .back-button__text,
.back-button.is-focus .back-button__text {
  text-decoration-thickness: 4%;
}


/* ========================================= */
/* COMPONENT: breadcrumbs */
/* ========================================= */
/* ==========================================================================
   BREADCRUMBS COMPONENT
   ========================================================================== */

.breadcrumbs {
  display: flex;
  align-items: center;
  min-height: 53px;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
}

.breadcrumbs__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin: 0;
  padding: 0;
  list-style: none;
  row-gap: var(--gn-spacing-2, 8px);
  column-gap: var(--gn-spacing-0, 2px);
}

.breadcrumbs__item {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0;
}

.breadcrumbs__separator {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 21px;
  height: 21px;
  color: var(--gn-color-text-default, #171717);
  flex-shrink: 0;
}

.breadcrumbs__link {
  display: inline-block;
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  text-decoration: underline;
  text-decoration-thickness: 4%;
  text-underline-offset: 25%;
  line-height: normal;
  max-width: 270px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  outline: none;
  border-radius: var(--gn-radius-base, 2px);
  transition: color 0.2s ease, text-decoration-thickness 0.2s ease;
}

/* Hover state */
.breadcrumbs__link:hover,
.breadcrumbs__link.is-hover {
  color: var(--gn-color-link-hover, #a3200b);
  text-decoration-thickness: 14%;
}

/* Focus state */
.breadcrumbs__link:focus-visible,
.breadcrumbs__link.is-focus {
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
  background-color: rgba(255, 255, 255, 0.02);
  text-decoration-thickness: 4%;
}

/* Current page state */
.breadcrumbs__link--current {
  font-weight: 700;
  text-decoration: none;
  color: var(--gn-color-text-default, #171717);
  cursor: default;
}

.breadcrumbs__link--current:hover,
.breadcrumbs__link--current.is-hover {
  color: var(--gn-color-text-default, #171717);
  text-decoration: none;
}

.breadcrumbs__link--current:focus-visible,
.breadcrumbs__link--current.is-focus {
  /* Current page item shouldn't be focusable if it's not a link, but just in case */
  outline: none;
  box-shadow: none;
  background-color: transparent;
}


/* ========================================= */
/* COMPONENT: button */
/* ========================================= */
/**
 * Button Component (BEM)
 */

.gn-button {

  --_ghost-underline-thickness-default: 4%;
  --_ghost-underline-thickness-hover-focus: 14%;

  --_button-gap: var(--gn-spacing-2);
  --_button-block-padding: 0;
  --_button-inline-padding: 0;
  --_button-line-height: normal;
  --_button-icon-size: 24px;
  --_button-icon-only-padding: 0;
  --_button-icon-only-icon-size: var(--_button-icon-size);

  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--_button-gap);
  padding: var(--_button-block-padding) var(--_button-inline-padding);
  border-radius: var(--gn-radius-base);
  font-family: inherit;
  font-weight: 500;
  font-style: normal;
  line-height: var(--_button-line-height);
  text-align: center;
  white-space: nowrap;
  cursor: pointer;
  border: var(--gn-border-base) solid transparent;
  text-decoration: none;
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    text-decoration-thickness 0.2s ease;
  appearance: none;
  -webkit-appearance: none;
  background: none;
}

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

.gn-button__icon {
  box-sizing: border-box;
  width: var(--_button-icon-size);
  height: var(--_button-icon-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: currentColor;
}

.gn-button__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* =========================================================================
   DISABLED
   ========================================================================= */

.gn-button:disabled,
.gn-button[disabled],
.gn-button[aria-disabled="true"] {
  cursor: not-allowed;
  pointer-events: none;
}

/* =========================================================================
   SIZES
   ========================================================================= */

.gn-button--sm {
  --_button-block-padding: var(--gn-spacing-2);
  --_button-inline-padding: var(--gn-spacing-3);
  --_button-line-height: 18px;
  --_button-icon-size: 18px;
  --_button-icon-only-padding: 6px;
  --_button-icon-only-icon-size: 22px;

  font-size: var(--gn-text-p-sm);
}

.gn-button--md {
  --_button-block-padding: var(--gn-spacing-3);
  --_button-inline-padding: var(--gn-spacing-4);
  --_button-line-height: 20px;
  --_button-icon-size: 20px;
  --_button-icon-only-padding: 14px;
  --_button-icon-only-icon-size: 24px;

  font-size: var(--gn-text-p-base);
}

.gn-button--lg {
  --_button-block-padding: var(--gn-spacing-4);
  --_button-inline-padding: var(--gn-spacing-6);
  --_button-line-height: 22px;
  --_button-icon-size: 24px;
  --_button-icon-only-padding: var(--gn-spacing-3);
  --_button-icon-only-icon-size: 30px;

  font-size: var(--gn-text-p-lg);
}

/* Ajustes asimétricos cuando llevan icono a los lados */
.gn-button--sm.gn-button--icon-left {
  padding-left: var(--gn-spacing-2);
}

.gn-button--sm.gn-button--icon-right {
  padding-right: var(--gn-spacing-2);
}

.gn-button--md.gn-button--icon-left {
  padding-left: var(--gn-spacing-3);
}

.gn-button--md.gn-button--icon-right {
  padding-right: var(--gn-spacing-3);
}

.gn-button--lg.gn-button--icon-left {
  padding-left: var(--gn-spacing-4);
}

.gn-button--lg.gn-button--icon-right {
  padding-right: var(--gn-spacing-4);
}

/* Icon only */
.gn-button--icon-only {
  gap: 0;
  padding: var(--_button-icon-only-padding);
}

.gn-button--icon-only .gn-button__icon {
  width: var(--_button-icon-only-icon-size);
  height: var(--_button-icon-only-icon-size);
}

/* =========================================================================
   FOCUS
   ========================================================================= */

.gn-button:focus-visible {
  outline: none;
  box-shadow:
    0 0 0 2px var(--gn-color-fill-default),
    0 0 0 6px var(--gn-color-border-focus);
}

/* =========================================================================
   VARIANTS
   ========================================================================= */

/* ===== PRIMARY ===== */

.gn-button--primary {
  background-color: var(--gn-color-primary);
  color: var(--gn-color-on-primary);
}

.gn-button--primary:hover:not(:disabled) {
  background-color: var(--gn-color-primary-hover);
}

.gn-button--primary:active:not(:disabled) {
  background-color: var(--gn-color-primary-click);
}

.gn-button--primary:focus-visible {
  background-color: var(--gn-color-primary-focus);
}

.gn-button--primary:disabled,
.gn-button--primary[disabled] {
  background-color: var(--gn-color-primary-disabled);
}

/* ===== SECONDARY ===== */

.gn-button--secondary {
  background-color: var(--gn-color-fill-default);
  color: var(--gn-color-text-default);
  border-color: var(--gn-color-border-neutral-base);
}

.gn-button--secondary:hover:not(:disabled) {
  background-color: var(--gn-color-fill-default);
  color: var(--gn-color-primary-hover);
}

.gn-button--secondary:active:not(:disabled) {
  border-color: var(--gn-color-primary-click);
  color: var(--gn-color-primary-click);
}

.gn-button--secondary:focus-visible {
  border-color: var(--gn-color-border-neutral-base);
  color: var(--gn-color-primary-focus);
}

.gn-button--secondary:disabled,
.gn-button--secondary[disabled] {
  border-color: var(--gn-color-border-neutral-disabled);
  color: var(--gn-color-text-default-disabled);
}

/* ===== GHOST ===== */

.gn-button--ghost {
  background-color: transparent;
  color: var(--gn-color-text-default);
  text-decoration-line: underline;
  text-decoration-thickness: var(--_ghost-underline-thickness-default);
  text-underline-offset: 25%;
}

.gn-button--ghost:hover:not(:disabled) {
  color: var(--gn-color-primary-hover);
  text-decoration-thickness: var(--_ghost-underline-thickness-hover-focus);
}

.gn-button--ghost:active:not(:disabled) {
  color: var(--gn-color-primary-click);
  text-decoration-thickness: var(--_ghost-underline-thickness-default);
}

.gn-button--ghost:focus-visible {
  color: var(--gn-color-primary-focus);
  text-decoration-thickness: var(--_ghost-underline-thickness-hover-focus);
}

.gn-button--ghost:disabled,
.gn-button--ghost[disabled] {
  color: var(--gn-color-text-default-light);
  text-decoration-thickness: var(--_ghost-underline-thickness-default);
}


/* ========================================= */
/* COMPONENT: button-group */
/* ========================================= */
/* ==========================================================================
   BUTTON GROUP COMPONENT
   ========================================================================== */

.button-group {
  display: inline-flex;
  align-items: center;
  background-color: var(--gn-color-fill-default, #ffffff);
  border-radius: var(--gn-radius-base, 3px);
}

.button-group__button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 53px;
  padding: var(--gn-spacing-2, 8px) var(--gn-spacing-3, 16px);
  
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  background-color: transparent;
  
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-black, #171717);
  
  cursor: pointer;
  outline: none;
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

/* Modificador de Tamaño SM */
.button-group--sm .button-group__button {
  min-height: 35px;
  padding: var(--gn-spacing-2, 8px);
  font-size: var(--gn-text-p-sm, 16px);
}

/* Lógica de segmentación visual continua (evitar doble borde intermedio) */
.button-group__button:not(:first-child) {
  margin-left: calc(var(--gn-border-base, 1px) * -1);
}

/* Lógica de redondeos únicamente en extremos */
.button-group__button:first-child {
  border-top-left-radius: var(--gn-radius-base, 3px);
  border-bottom-left-radius: var(--gn-radius-base, 3px);
}

.button-group__button:last-child {
  border-top-right-radius: var(--gn-radius-base, 3px);
  border-bottom-right-radius: var(--gn-radius-base, 3px);
}

/* Estado Focus */
.button-group__button:focus-visible,
.button-group__button.is-focus {
  z-index: 2; /* Para elevar el halo de foco por encima de los bordes adyacentes */
  background-color: var(--gn-color-info-lighter, #eaf4f8);
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

/* Estado Selected / Pressed */
.button-group__button--selected,
.button-group__button[aria-pressed="true"] {
  z-index: 1; /* Para elevar el borde activo sobre los inactivos */
  background-color: var(--gn-color-fill-primary, #d82b0f);
  color: var(--gn-color-text-invert, #ffffff);
  font-weight: 700;
}

/* Prioridad visual cuando está Seleccionado y Focalizado simultáneamente */
.button-group__button--selected:focus-visible,
.button-group__button[aria-pressed="true"]:focus-visible,
.button-group__button--selected.is-focus,
.button-group__button[aria-pressed="true"].is-focus {
  z-index: 2;
  background-color: var(--gn-color-fill-primary, #d82b0f); 
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}


/* ========================================= */
/* COMPONENT: checkbox */
/* ========================================= */
/* ========================================= */
/* COMPONENT: CHECKBOX                       */
/* ========================================= */

.gn-checkbox {
  display: flex;
  position: relative;
  width: var(--gn-layout-desktop-4colums-2-col);
  max-width: 100%;
}

.gn-checkbox__input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.gn-checkbox__label {
  display: flex;
  align-items: flex-start;
  gap: var(--gn-spacing-2, 8px);
  width: 100%;
  cursor: pointer;
  position: relative;
}

/* Base Box (LG Default) */
.gn-checkbox__box {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  width: 24px;
  height: 24px;
  background-color: var(--gn-color-fill-default, #ffffff);
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-black, #171717);
  box-sizing: border-box;
  margin-top: 1px;
  transition: all 0.2s ease-in-out;
}

/* Base Text */
.gn-checkbox__content {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-1, 4px);
  flex: 1 0 0;
  min-width: 1px;
}

.gn-checkbox__text {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-default, #171717);
  line-height: normal;
  font-variation-settings: 'wdth' 100;
}

.gn-checkbox__description {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  line-height: normal;
}

/* SVGs */
.gn-checkbox__icon {
  position: absolute;
  color: #ffffff;
  opacity: 0;
  transform: scale(0.5);
  transition: all 0.2s ease-in-out;
}

.gn-checkbox__icon--mix {
  width: 14px;
  height: 14px;
}

/* ================== */
/* STATES             */
/* ================== */

/* Focus */
.gn-checkbox__input:focus-visible+.gn-checkbox__label .gn-checkbox__box {
  border: var(--gn-border-lg, 4px) solid var(--gn-color-border-black, #171717);
  box-shadow: 0px 0px 0px 2px white, 0px 0px 0px 6px var(--gn-color-border-focus, #a9cfe0);
  outline: none;
}

/* Checked */
.gn-checkbox__input:checked+.gn-checkbox__label .gn-checkbox__box {
  background-color: var(--gn-color-fill-dark, #171717);
  border-color: var(--gn-color-fill-dark, #171717);
}

.gn-checkbox__input:checked+.gn-checkbox__label .gn-checkbox__box .gn-checkbox__icon--check {
  opacity: 1;
  transform: scale(1);
}

/* Mixed (Indeterminate) */
.gn-checkbox--mix .gn-checkbox__input:not(:checked)+.gn-checkbox__label .gn-checkbox__box {
  background-color: var(--gn-color-fill-dark, #171717);
  border-color: var(--gn-color-fill-dark, #171717);
}

.gn-checkbox--mix .gn-checkbox__input:not(:checked)+.gn-checkbox__label .gn-checkbox__box .gn-checkbox__icon--mix {
  opacity: 1;
  transform: scale(1);
}

/* Disabled */
.gn-checkbox__input:disabled+.gn-checkbox__label {
  cursor: not-allowed;
}

.gn-checkbox__input:disabled+.gn-checkbox__label .gn-checkbox__box {
  background-color: var(--gn-color-fill-neutral-disabled, #b5b5b5);
  border-color: var(--gn-color-fill-neutral-disabled, #b5b5b5);
}

.gn-checkbox__input:disabled+.gn-checkbox__label .gn-checkbox__content .gn-checkbox__text,
.gn-checkbox__input:disabled+.gn-checkbox__label .gn-checkbox__content .gn-checkbox__description {
  color: var(--gn-color-text-default-disabled, #737373);
}

/* Error */
.gn-checkbox--error .gn-checkbox__box {
  border: var(--border-error, 4px) solid var(--gn-color-border-error, #d82b0f) !important;
}

.gn-checkbox__error-text {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-error, #d82b0f);
  display: flex;
  gap: 4px;
  align-items: center;
  margin-top: 4px;
}

.gn-checkbox__error-text strong {
  font-weight: 700;
}

/* ================== */
/* MODIFIERS          */
/* ================== */

/* Small Size (SM) */
.gn-checkbox--sm .gn-checkbox__box {
  width: 19px;
  height: 19px;
}


.gn-checkbox--sm .gn-checkbox__text,
.gn-checkbox--sm .gn-checkbox__description,
.gn-checkbox--sm .gn-checkbox__error-text {
  font-size: var(--gn-text-p-sm, 16px);
}

/* Tiled / Card */
.gn-checkbox--tiled {
  width: 537px;
}

.gn-checkbox--tiled .gn-checkbox__label {
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-dark, #737373);
  border-radius: var(--gn-radius-base, 3px);
  padding: var(--gn-spacing-3, 16px) var(--gn-spacing-3, 16px) var(--gn-spacing-3, 16px) 55px;
  /* space for absolute box */
  position: relative;
  background-color: var(--gn-color-fill-default, #ffffff);
  transition: all 0.2s ease-in-out;
}

.gn-checkbox--tiled.gn-checkbox--sm .gn-checkbox__label {
  padding: 8px 8px 8px 40px;
}

.gn-checkbox--tiled .gn-checkbox__box {
  position: absolute;
  left: 16px;
  top: 13px;
  margin-top: 0;
}

.gn-checkbox--tiled.gn-checkbox--sm .gn-checkbox__box {
  left: 8px;
  top: 7px;
}

.gn-checkbox--tiled .gn-checkbox__input:checked+.gn-checkbox__label,
.gn-checkbox--tiled.gn-checkbox--mix .gn-checkbox__label {
  border-color: var(--gn-color-fill-dark, #171717);
  box-shadow: inset 0px 0px 0px 1px var(--gn-color-fill-dark, #171717);
}

.gn-checkbox--tiled .gn-checkbox__input:focus-visible+.gn-checkbox__label {
  border-color: var(--gn-color-border-black, #171717);
  box-shadow: inset 0px 0px 0px 1px var(--gn-color-border-black, #171717), 0px 0px 0px 2px white, 0px 0px 0px 6px var(--gn-color-border-focus, #a9cfe0);
  background-color: var(--gn-color-fill-default, #ffffff);
}

.gn-checkbox--tiled .gn-checkbox__input:disabled+.gn-checkbox__label {
  background-color: var(--gn-color-fill-neutral-lighter, #f9f9f9);
  border-color: var(--gn-color-border-neutral-disabled, #b5b5b5);
  box-shadow: none;
}

.gn-checkbox--tiled.gn-checkbox--error .gn-checkbox__label {
  border-color: var(--gn-color-border-error, #d82b0f) !important;
  box-shadow: inset 0px 0px 0px 3px var(--gn-color-border-error, #d82b0f) !important;
}

/* CONDITIONAL */
.gn-checkbox--conditional .gn-checkbox__label {
  padding-bottom: 30px;
}

.gn-checkbox--conditional::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 32px;
  bottom: 0;
  width: 2px;
  background-color: var(--gn-color-fill-dark, #171717);
  z-index: 10;
}

.gn-checkbox--conditional.gn-checkbox--sm::before {
  left: 9px;
  top: 26px;
}

/* ========================================= */
/* COMPONENT: date-input */
/* ========================================= */
/* ========================================= */
/* PATTERN: DATE INPUT                       */
/* ========================================= */

.gn-date-input {
  display: flex;
  flex-direction: row;
  align-items: flex-end;
  gap: var(--gn-spacing-3, 16px);
  margin: 0;
  padding: 0;
  border: none;
  width: 100%;
}

.gn-date-input__group {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
}

/* Modificamos comportamiento nativo de los inputs encapsulados para ajustarse al flex de fecha */
.gn-date-input__group .gn-input,
.gn-date-input__group .gn-select {
  gap: var(--gn-spacing-1, 4px);
}

.gn-date-input__label {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-default, #171717);
  font-weight: 400;
  line-height: normal;
  display: block;
}

/* Dimensiones canónicas */
.gn-date-input__day {
  width: 92px;
}

.gn-date-input__month {
  width: 247px;
}

.gn-date-input__year {
  width: 116px;
}

/*
 * Estados Heredados
 * La clase --error se inyectará dinámicamente en los .gn-input y .gn-select internos.
 * Este CSS solo gestiona la arquitectura de layout.
 */


/* ========================================= */
/* COMPONENT: dropdown-menu */
/* ========================================= */
/* ==========================================================================
   DROPDOWN MENU COMPONENT
   ========================================================================== */

.dropdown-menu {
  /* Default MD Sizes */
  --_dropdown-gap: var(--gn-spacing-2);
  --_dropdown-trigger-pad-y: var(--gn-spacing-3);
  --_dropdown-trigger-pad-x: var(--gn-spacing-4);
  --_dropdown-font-size: var(--gn-text-p-base);
  --_dropdown-line-height: 18px;
  --_dropdown-icon-size: 24px;
  --_dropdown-action-pad-y: var(--gn-spacing-2);
  --_dropdown-action-pad-x: var(--gn-spacing-3);
  --_dropdown-action-icon-size: 24px;

  position: relative;
  display: inline-flex;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
}

.dropdown-menu--sm {
  --_dropdown-gap: var(--gn-spacing-1);
  --_dropdown-trigger-pad-y: var(--gn-spacing-2);
  --_dropdown-trigger-pad-x: var(--gn-spacing-3);
  --_dropdown-font-size: var(--gn-text-p-sm);
  --_dropdown-line-height: 18px;
  --_dropdown-icon-size: 20px;
  --_dropdown-action-pad-y: var(--gn-spacing-1);
  --_dropdown-action-pad-x: var(--gn-spacing-2);
  --_dropdown-action-icon-size: 20px;
}

/* ==========================================================================
   TRIGGER BUTTON
   ========================================================================== */

.dropdown-menu__trigger {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--_dropdown-gap);
  padding: var(--_dropdown-trigger-pad-y) var(--_dropdown-trigger-pad-x);
  background-color: var(--gn-color-fill-default, #ffffff);
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-base, #959595);
  border-radius: var(--gn-radius-base, 3px);
  color: var(--gn-color-text-default, #171717);
  font-size: var(--_dropdown-font-size);
  font-weight: 500;
  line-height: var(--_dropdown-line-height);
  cursor: pointer;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: all 0.2s ease;
  width: 100%;
}

.dropdown-menu__trigger:hover {
  background-color: var(--gn-color-info-lighter, #eaf4f8);
}

.dropdown-menu__trigger:focus-visible {
  outline: none;
  border-color: var(--gn-color-border-black, #171717);
  box-shadow: 0px 0px 0px 2px white, 0px 0px 0px 6px var(--gn-color-border-focus, #a9cfe0);
}

.dropdown-menu__trigger[aria-expanded="true"] {
  background-color: var(--gn-color-info-lighter, #eaf4f8);
}

.dropdown-menu__trigger:disabled,
.dropdown-menu__trigger--disabled {
  background-color: var(--gn-color-fill-neutral-lighter-disabled, #f9f9f9);
  border-color: var(--gn-color-border-neutral-disabled, #b5b5b5);
  color: var(--gn-color-text-default-disabled, #737373);
  cursor: not-allowed;
  pointer-events: none;
}

/* Modifier: Ghost */
.dropdown-menu__trigger--ghost {
  background-color: transparent;
  border-color: transparent;
  padding-left: var(--_dropdown-trigger-pad-x);
  padding-right: var(--_dropdown-trigger-pad-x);
}

.dropdown-menu__trigger--ghost:hover,
.dropdown-menu__trigger--ghost[aria-expanded="true"] {
  background-color: var(--gn-color-info-lighter, #eaf4f8);
}

.dropdown-menu__trigger--ghost:disabled {
  background-color: transparent;
  border-color: transparent;
}

/* Modifier: Icon Only */
.dropdown-menu__trigger--icon-only {
  padding: var(--_dropdown-trigger-pad-y);
  justify-content: center;
}

/* Elements inside trigger */
.dropdown-menu__trigger-text {
  overflow: hidden;
  text-overflow: ellipsis;
}

.dropdown-menu__trigger-icon {
  width: var(--_dropdown-icon-size);
  height: var(--_dropdown-icon-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: currentColor;
}

.dropdown-menu__trigger-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

.dropdown-menu__trigger-label {
  display: inline-flex;
  align-items: center;
  gap: var(--_dropdown-gap);
}

/* ==========================================================================
   DROPDOWN PANEL
   ========================================================================== */

.dropdown-menu__panel {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 100;
  width: max-content;
  min-width: calc(100% + var(--gn-spacing-4));
  margin-top: var(--gn-spacing-1, 4px);
  background-color: var(--gn-color-fill-default, #ffffff);
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-base, #959595);
  box-shadow: 0 2px 4px 0 var(--gn-color-border-neutral-base, #959595);
  border-radius: var(--gn-radius-base, 3px);
  display: none;
  flex-direction: column;
}

.dropdown-menu__trigger[aria-expanded="true"]+.dropdown-menu__panel,
.dropdown-menu--open .dropdown-menu__panel {
  display: flex;
}

.dropdown-menu__list {
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  width: 100%;
}

.dropdown-menu__item {
  width: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

/* ==========================================================================
   DROPDOWN ACTIONS / LINKS
   ========================================================================== */

.dropdown-menu__action,
.dropdown-menu__link {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: var(--_dropdown-gap);
  width: 100%;
  padding: var(--gn-spacing-3);
  background-color: transparent;
  border: none;
  border-bottom: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-light, #e5e5e5);
  color: var(--gn-color-text-default, #171717);
  font-size: var(--_dropdown-font-size);
  font-family: inherit;
  font-weight: 400;
  line-height: var(--_dropdown-line-height);
  text-decoration: none;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  text-align: left;
}

.dropdown-menu__item:last-child .dropdown-menu__action,
.dropdown-menu__item:last-child .dropdown-menu__link {
  border-bottom: none;
}

.dropdown-menu__action:hover,
.dropdown-menu__link:hover {
  background-color: var(--gn-color-info-lighter, #eaf4f8);
}

.dropdown-menu__action:focus-visible,
.dropdown-menu__link:focus-visible {
  background-color: var(--gn-color-info-lighter, #eaf4f8);
  border-color: var(--gn-color-border-black, #171717);
  box-shadow: 0 0 0 2px #FFF, 0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
  position: relative;
  z-index: 2;
}

.dropdown-menu__action--selected,
.dropdown-menu__link--selected {
  font-weight: 700;
}

.dropdown-menu__icon {
  width: var(--_dropdown-action-icon-size);
  height: var(--_dropdown-action-icon-size);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: currentColor;
}

.dropdown-menu__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ========================================= */
/* COMPONENT: file-input */
/* ========================================= */
/* ==========================================================================
   FILE INPUT COMPONENT
   ========================================================================== */

.file-input {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  width: 100%;
}

/* Visually hidden native control but still focusable by screen readers */
.file-input__control {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

/* ==========================================================================
   VARIANT: BUTTON
   ========================================================================== */

.file-input--button .file-input__wrapper {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-3, 16px);
  position: relative;
  max-width: 100%;
}

/* Focus ring on wrapper instead of button to encompass everything natively */
.file-input--button .file-input__control:focus-visible~.file-input__wrapper {
  background-color: rgba(255, 255, 255, 0.01);
  border-radius: var(--radius-base, 3px);
  box-shadow: 0px 0px 0px 2px white, 0px 0px 0px 6px var(--color-border-focus, #a9cfe0);
}

.file-input__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2, 8px);
  padding: var(--spacing-3, 16px) var(--spacing-4, 20px) var(--spacing-3, 16px) var(--spacing-3, 16px);
  background-color: var(--color-fill-default, #ffffff);
  border: var(--border-base, 1px) solid var(--color-border-neutral-base, #959595);
  border-radius: var(--radius-base, 3px);
  color: var(--color-text-default, #171717);
  font-size: var(--text-p-base, 18px);
  line-height: 18px;
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease;
  flex-shrink: 0;
}

.file-input__button:hover {
  background-color: var(--color-info-lighter, #eaf4f8);
}

.file-input__control:disabled~.file-input__wrapper .file-input__button,
.file-input--disabled .file-input__button {
  background-color: var(--color-fill-neutral-lighter-disabled, #f9f9f9);
  border-color: var(--color-border-neutral-disabled, #b5b5b5);
  color: var(--color-text-default-disabled, #737373);
  cursor: not-allowed;
  pointer-events: none;
}

/* Icon */
.file-input__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Text */
.file-input__text,
.file-input__file-info {
  display: flex;
  align-items: baseline;
  gap: var(--spacing-2, 8px);
  font-size: var(--text-p-base, 18px);
  color: var(--color-text-default, #171717);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* If no file selected */
.file-input__text {
  color: var(--color-text-default-light, rgba(23, 23, 23, 0.6));
}

.file-input__control:disabled~.file-input__wrapper .file-input__text,
.file-input--disabled .file-input__text {
  color: var(--color-text-default-disabled, #737373);
}

.file-input__file-name {
  color: var(--color-text-default, #171717);
  text-decoration: underline;
  text-underline-offset: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.file-input__file-size {
  color: var(--color-text-default-light, rgba(23, 23, 23, 0.6));
  font-size: var(--text-p-sm, 16px);
}

/* Modifiers for BUTTON */
.file-input--sm .file-input__button {
  padding: var(--spacing-2, 8px) var(--spacing-3, 16px) var(--spacing-2, 8px) 10px;
  font-size: var(--text-p-sm, 16px);
}

.file-input--sm .file-input__icon {
  width: 19px;
  height: 19px;
}

.file-input--sm .file-input__text,
.file-input--sm .file-input__file-info {
  font-size: var(--text-p-sm, 16px);
}

/* ==========================================================================
   VARIANT: DROPZONE
   ========================================================================== */

.file-input--drop {
  min-width: 560px;
}

.file-input__dropzone {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 80px;
  padding: var(--spacing-6, 28px) var(--spacing-3, 16px);
  background-color: var(--color-fill-default, #ffffff);
  border: var(--border-base, 1px) dashed var(--color-border-neutral-dark, #737373);
  border-radius: var(--radius-base, 3px);
  transition: all 0.2s ease;
  cursor: pointer;
  position: relative;
}

/* Dragover state / Hover */
.file-input__dropzone:hover,
.file-input--dragover .file-input__dropzone {
  background-color: var(--color-info-lighter, #eaf4f8);
  border-color: var(--color-border-focus, #a9cfe0);
}

.file-input__control:focus-visible~.file-input__dropzone {
  box-shadow: 0px 0px 0px 2px white, 0px 0px 0px 6px var(--color-border-focus, #a9cfe0);
  border-style: dashed;
}

/* Has File State */
.file-input--has-file .file-input__dropzone {
  border-style: solid;
  border-color: var(--color-border-black, #171717);
  cursor: default;
  justify-content: flex-start;
}

.file-input--has-file .file-input__dropzone:hover {
  background-color: var(--color-fill-default, #ffffff);
}

/* Disabled */
.file-input__control:disabled~.file-input__dropzone,
.file-input--disabled .file-input__dropzone {
  background-color: var(--color-fill-neutral-lighter-disabled, #f9f9f9);
  border-color: var(--color-border-neutral-disabled, #b5b5b5);
  cursor: not-allowed;
  pointer-events: none;
}

/* Error */
.file-input--error .file-input__dropzone {
  border-color: var(--color-border-neutral-dark, #737373);
  box-shadow: inset 0px 0px 0px 4px var(--color-border-error, #d82b0f);
}

/* Dropzone Inner Elements */
.file-input__dropzone-text {
  font-size: var(--text-p-base, 18px);
  color: var(--color-text-default, #171717);
  text-align: center;
}

.file-input__control:disabled~.file-input__dropzone .file-input__dropzone-text {
  color: var(--color-text-default-light, rgba(23, 23, 23, 0.6));
}

.file-input__dropzone-link {
  text-decoration: underline;
  text-underline-offset: 4px;
  cursor: pointer;
}

/* Selected Info in Dropzone */
.file-input--drop .file-input__file-info {
  display: flex;
  align-items: center;
  width: 100%;
  gap: var(--spacing-2, 8px);
}

.file-input__remove {
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 4px;
  color: var(--color-text-default, #171717);
  border-radius: 3px;
}

.file-input__remove:hover {
  background-color: var(--color-fill-neutral-lighter, #f9f9f9);
}

.file-input__remove:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px white, 0 0 0 4px var(--color-border-focus, #a9cfe0);
}

/* ========================================= */
/* COMPONENT: input */
/* ========================================= */
/**
 * Component: Input
 * Node: 140:39
 */

.gn-input {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-2, 8px);
  align-items: flex-start;
  width: 100%;
  max-width: 400px;
}

.gn-input__control {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
  width: 100%;
  border-radius: var(--gn-radius-base, 3px);
  overflow: hidden;
  position: relative;
  transition: all 0.2s ease;
  background-color: var(--gn-color-fill-default, #ffffff);
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-black, #171717);
  height: 53px;
  padding: 0 var(--gn-spacing-3, 16px);
}

.gn-input__field {
  flex: 1 0 0;
  width: 100%;
  height: 100%;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  font-family: var(--gn-font-family-base, 'Roboto', sans-serif);
  font-style: normal;
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  font-size: var(--gn-text-p-base, 18px);
  line-height: normal;
  text-overflow: ellipsis;
  outline: none;
}

.gn-input__field::placeholder {
  font-style: italic;
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  opacity: 1;
}

.gn-input__icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gn-color-border-black, #171717);
}

.gn-input__icon svg {
  width: 100%;
  height: 100%;
}

.gn-input__count {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-1, 4px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  font-family: var(--gn-font-family-base, 'Roboto', sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  line-height: normal;
  white-space: nowrap;
}

/* =========================================================================
   ESTADOS (FOCUS, DISABLED, ERROR)
   ========================================================================= */

.gn-input__control:focus-within {
  border: 2px solid var(--gn-color-border-black, #171717);
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

.gn-input--disabled .gn-input__control,
.gn-input__field:disabled {
  background-color: var(--gn-color-fill-neutral-lighter-disabled, #f9f9f9);
  border-color: var(--gn-color-border-neutral-disabled, #b5b5b5);
  cursor: not-allowed;
}

.gn-input__field:disabled {
  color: var(--gn-color-text-default-disabled, #737373);
}

.gn-input__field:disabled::placeholder {
  color: var(--gn-color-text-default-disabled, #737373);
}

.gn-input--error .gn-input__control {
  border: 3px solid var(--gn-color-border-error, #d82b0f);
}

.gn-input--error .gn-input__control:focus-within {
  border-width: 3px;
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

/* =========================================================================
   TAMAÑOS
   ========================================================================= */

.gn-input--sm {
  max-width: 264px;
}

.gn-input--sm .gn-input__control {
  height: 35px;
  padding: 0 var(--gn-spacing-2, 8px);
}

.gn-input--sm .gn-input__field,
.gn-input--sm .gn-input__field::placeholder {
  font-size: var(--gn-text-p-sm, 16px);
}


/* ========================================= */
/* COMPONENT: modal */
/* ========================================= */
/*
  MODAL
*/

.modal {
  /* Overlay */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--gn-color-fill-dark-transparent);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--gn-spacing-3);
  z-index: 1000;
  
  /* Hidden state */
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.2s ease, visibility 0.2s ease;
}

.modal--open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.modal__dialog {
  background-color: var(--gn-color-fill-default);
  border-radius: var(--gn-radius-base);
  box-shadow: 0 2px 4px var(--gn-color-border-neutral-base);
  border: var(--gn-border-base) solid var(--gn-color-border-neutral-base);
  width: 100%;
  max-width: var(--gn-layout-desktop-4colums-2-col, 560px);
  max-height: calc(100vh - var(--gn-spacing-3) * 2);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  
  /* Subtle open animation */
  transform: translateY(-20px);
  transition: transform 0.2s ease;
}

.modal--open .modal__dialog {
  transform: translateY(0);
}

.modal--large .modal__dialog {
  max-width: var(--gn-layout-desktop-4colums-3-col, 850px);
}

.modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  padding: var(--gn-spacing-5) var(--gn-spacing-5) var(--gn-spacing-3) var(--gn-spacing-5);
}

.modal__title {
  margin: 0;
  color: var(--gn-color-text-default);
  font-size: var(--gn-text-h3);
  font-weight: 700;
  line-height: 1.2;
}

.modal__close {
  background: transparent;
  border: none;
  padding: var(--gn-spacing-1);
  margin-top: calc(var(--gn-spacing-1) * -1);
  margin-right: calc(var(--gn-spacing-1) * -1);
  cursor: pointer;
  color: var(--gn-color-text-default);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--gn-radius-base);
}

.modal__close:hover {
  color: var(--gn-color-primary-hover);
  background-color: var(--gn-color-fill-neutral-lighter);
}

.modal__close:focus-visible {
  outline: var(--gn-border-focus) solid var(--gn-color-border-focus);
  outline-offset: 2px;
}

.modal__close svg {
  width: 24px;
  height: 24px;
  fill: currentColor;
}

.modal__body {
  padding: var(--gn-spacing-3) var(--gn-spacing-5);
  overflow-y: auto;
  color: var(--gn-color-text-default);
  font-size: var(--gn-text-p-base);
  line-height: 1.5;
}

.modal__footer {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--gn-spacing-3);
  padding: var(--gn-spacing-4) var(--gn-spacing-5) var(--gn-spacing-5) var(--gn-spacing-5);
}


/* ========================================= */
/* COMPONENT: nav-menu */
/* ========================================= */
/* ==========================================================================
   NAV MENU COMPONENT
   ========================================================================== */

.nav-menu {
  display: block;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
}

.nav-menu__list {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-5, 24px);
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-menu__item {
  position: relative;
  display: inline-flex;
}

.nav-menu__link,
.nav-menu__trigger {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
  padding: var(--gn-spacing-3, 16px) 0;
  font-family: inherit;
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  text-decoration: none;
  background: transparent;
  border: none;
  border-bottom: var(--gn-border-xl, 4px) solid transparent;
  cursor: pointer;
  transition: border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.nav-menu__icon {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease;
  flex-shrink: 0;
}

.nav-menu__icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

/* Hover state */
.nav-menu__link:hover:not(:disabled):not(.nav-menu__link--disabled),
.nav-menu__trigger:hover:not(:disabled):not(.nav-menu__trigger--disabled),
.nav-menu__link--hover,
.nav-menu__trigger--hover {
  border-bottom-color: var(--gn-color-border-neutral-light, #e5e5e5);
}

/* Active / Current state */
.nav-menu__link--active,
.nav-menu__trigger--active,
.nav-menu__trigger[aria-expanded="true"] {
  border-bottom-color: var(--gn-color-border-primary, #d82b0f);
}

/* Open state icon rotation */
.nav-menu__trigger[aria-expanded="true"] .nav-menu__icon {
  transform: rotate(180deg);
}

/* Focus state */
.nav-menu__link:focus-visible,
.nav-menu__trigger:focus-visible,
.nav-menu__link--focus,
.nav-menu__trigger--focus {
  outline: none;
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
  border-radius: var(--gn-radius-base, 3px);
  z-index: 1;
}

/* Disabled state */
.nav-menu__link:disabled,
.nav-menu__trigger:disabled,
.nav-menu__link--disabled,
.nav-menu__trigger--disabled {
  color: var(--gn-color-text-default-disabled, #737373);
  cursor: not-allowed;
  pointer-events: none;
  border-bottom-color: transparent;
}

/* ==========================================================================
   NAV MENU PANEL (Submenu)
   ========================================================================== */
/* 
   Se compone junto a .dropdown-menu__panel en el HTML para heredar
   el estilo base de la caja flotante. 
   Aquí solo manejamos la interacción específica del nav-menu.
*/

.nav-menu__panel {
  /* Override margin to be flush with the bottom border */
  margin-top: 0;
}

/* Show panel when trigger is expanded */
.nav-menu__trigger[aria-expanded="true"] + .nav-menu__panel {
  display: flex;
}


/* ========================================= */
/* COMPONENT: radio */
/* ========================================= */
/* ========================================= */
/* COMPONENT: RADIO BUTTON                   */
/* ========================================= */

.gn-radio {
  display: flex;
  position: relative;
  width: var(--gn-layout-desktop-4colums-2-col);
  max-width: 100%;
}

.gn-radio__input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.gn-radio__label {
  display: flex;
  align-items: flex-start;
  gap: var(--gn-spacing-2, 8px);
  width: 100%;
  cursor: pointer;
  position: relative;
}

/* Base Box (LG Default) */
.gn-radio__box {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  position: relative;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: var(--gn-color-fill-default, #ffffff);
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-black, #171717);
  box-sizing: border-box;
  margin-top: 1px;
  transition: all 0.2s ease-in-out;
}

/* Inner Dot */
.gn-radio__dot {
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #ffffff;
  opacity: 0;
  transform: scale(0.5);
  transition: all 0.2s ease-in-out;
}

/* Base Text */
.gn-radio__content {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-1, 4px);
  flex: 1 0 0;
  min-width: 1px;
}

.gn-radio__text {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-default, #171717);
  line-height: normal;
  font-variation-settings: 'wdth' 100;
}

.gn-radio__description {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  line-height: normal;
}

/* ================== */
/* STATES             */
/* ================== */

/* Focus */
.gn-radio__input:focus-visible+.gn-radio__label .gn-radio__box {
  border: var(--border-focus, 2px) solid var(--gn-color-border-black, #171717);
  box-shadow: 0px 0px 0px 2px white, 0px 0px 0px 6px var(--gn-color-border-focus, #a9cfe0);
  outline: none;
}

/* Checked */
.gn-radio__input:checked+.gn-radio__label .gn-radio__box {
  background-color: var(--gn-color-fill-dark, #171717);
  border-color: var(--gn-color-fill-dark, #171717);
}

.gn-radio__input:checked+.gn-radio__label .gn-radio__box .gn-radio__dot {
  opacity: 1;
  transform: scale(1);
}

/* Disabled */
.gn-radio__input:disabled+.gn-radio__label {
  cursor: not-allowed;
}

.gn-radio__input:disabled+.gn-radio__label .gn-radio__box {
  background-color: var(--gn-color-fill-neutral-disabled, #b5b5b5);
  border-color: var(--gn-color-fill-neutral-disabled, #b5b5b5);
}

.gn-radio__input:disabled+.gn-radio__label .gn-radio__content .gn-radio__text,
.gn-radio__input:disabled+.gn-radio__label .gn-radio__content .gn-radio__description {
  color: var(--gn-color-text-default-disabled, #737373);
}

/* Error */
.gn-radio--error .gn-radio__box {
  border: var(--border-error, 4px) solid var(--gn-color-border-error, #d82b0f) !important;
}

.gn-radio__error-text {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-error, #d82b0f);
  display: flex;
  gap: 4px;
  align-items: center;
  margin-top: 4px;
}

.gn-radio__error-text strong {
  font-weight: 700;
}

/* ================== */
/* MODIFIERS          */
/* ================== */

/* Small Size (SM) */
.gn-radio--sm .gn-radio__box {
  width: 19px;
  height: 19px;
}

.gn-radio--sm .gn-radio__dot {
  width: 5px;
  height: 5px;
}

.gn-radio--sm .gn-radio__text,
.gn-radio--sm .gn-radio__description,
.gn-radio--sm .gn-radio__error-text {
  font-size: var(--gn-text-p-sm, 16px);
}

/* Tiled / Card */
.gn-radio--tiled {
  width: 537px;
}

.gn-radio--tiled .gn-radio__label {
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-dark, #737373);
  border-radius: var(--gn-radius-base, 3px);
  padding: var(--gn-spacing-3, 16px) var(--gn-spacing-3, 16px) var(--gn-spacing-3, 16px) 55px;
  position: relative;
  background-color: var(--gn-color-fill-default, #ffffff);
  transition: all 0.2s ease-in-out;
}

.gn-radio--tiled.gn-radio--sm .gn-radio__label {
  padding: 8px 8px 8px 40px;
}

.gn-radio--tiled .gn-radio__box {
  position: absolute;
  left: 16px;
  top: 13px;
  margin-top: 0;
}

.gn-radio--tiled.gn-radio--sm .gn-radio__box {
  left: 8px;
  top: 7px;
}

.gn-radio--tiled .gn-radio__input:checked+.gn-radio__label {
  border-color: var(--gn-color-fill-dark, #171717);
  box-shadow: inset 0px 0px 0px 1px var(--gn-color-fill-dark, #171717);
}

.gn-radio--tiled .gn-radio__input:focus-visible+.gn-radio__label {
  border-color: var(--gn-color-border-black, #171717);
  box-shadow: inset 0px 0px 0px 1px var(--gn-color-border-black, #171717), 0px 0px 0px 2px white, 0px 0px 0px 6px var(--gn-color-border-focus, #a9cfe0);
  background-color: var(--gn-color-fill-default, #ffffff);
}

.gn-radio--tiled .gn-radio__input:disabled+.gn-radio__label {
  background-color: var(--gn-color-fill-neutral-lighter, #f9f9f9);
  border-color: var(--gn-color-border-neutral-disabled, #b5b5b5);
  box-shadow: none;
}

.gn-radio--tiled.gn-radio--error .gn-radio__label {
  border-color: var(--gn-color-border-error, #d82b0f) !important;
  box-shadow: inset 0px 0px 0px 3px var(--gn-color-border-error, #d82b0f) !important;
}

/* CONDITIONAL */
.gn-radio--conditional .gn-radio__label {
  padding-bottom: 30px;
}

.gn-radio--conditional::before {
  content: "";
  position: absolute;
  left: 11px;
  top: 32px;
  bottom: 0;
  width: 2px;
  background-color: var(--gn-color-fill-dark, #171717);
  z-index: 10;
}

.gn-radio--conditional.gn-radio--sm::before {
  left: 9px;
  top: 26px;
}

/* ========================================= */
/* COMPONENT: select */
/* ========================================= */
/* ========================================= */
/* COMPONENT: SELECT                         */
/* ========================================= */

.gn-select {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-1, 4px);
  width: 100%;
}

.gn-select__label {
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-sm, 16px);
  color: var(--gn-color-text-default, #171717);
  font-weight: 500;
}

.gn-select__wrapper {
  position: relative;
  display: flex;
  width: 100%;
}

.gn-select__control {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  width: 100%;
  font-family: "Roboto", sans-serif;
  font-size: var(--gn-text-p-base, 18px);
  color: var(--gn-color-text-default, #171717);
  background-color: var(--gn-color-fill-default, #ffffff);
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-black, #171717);
  border-radius: var(--gn-radius-base, 3px);
  height: 53px;
  padding: 0 var(--spacing-4, 32px) 0 var(--gn-spacing-3, 16px);
  box-sizing: border-box;
  cursor: pointer;

  /* Chevron Down Icon */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M12 1.0752L6 7.0752L0 1.0752L1.0752 0L6 4.9248L10.9248 0L12 1.0752Z' fill='%23D82B0F'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 16px center;
  background-size: 12px;
}

.gn-select__control:focus-visible {
  outline: none;
  border-width: var(--border-focus, 2px);
  border-color: var(--gn-color-border-black, #171717);
  box-shadow: 0px 0px 0px 2px white, 0px 0px 0px 6px var(--gn-color-border-focus, #a9cfe0);
  padding-left: calc(var(--gn-spacing-3, 16px) - 1px);
}

.gn-select__control:disabled {
  background-color: var(--gn-color-fill-neutral-lighter, #f9f9f9);
  border-color: var(--gn-color-border-neutral-disabled, #b5b5b5);
  color: var(--gn-color-text-default-disabled, #737373);
  cursor: not-allowed;
  opacity: 1; /* override iOS mobile opacity */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M12 1.0752L6 7.0752L0 1.0752L1.0752 0L6 4.9248L10.9248 0L12 1.0752Z' fill='%23737373'/%3E%3C/svg%3E");
}

/* Modifiers */
.gn-select--sm .gn-select__control {
  height: 35px;
  font-size: var(--gn-text-p-sm, 16px);
  padding: 0 var(--spacing-4, 32px) 0 var(--gn-spacing-2, 8px);
  background-size: 10px;
  background-position: right 12px center;
}

.gn-select--sm .gn-select__control:focus-visible {
  padding-left: calc(var(--gn-spacing-2, 8px) - 1px);
}

.gn-select--error .gn-select__control {
  border: var(--border-error, 4px) solid var(--gn-color-border-error, #d82b0f);
}

.gn-select--error .gn-select__control:focus-visible {
  padding-left: calc(var(--gn-spacing-3, 16px) - 3px);
}

.gn-select--error.gn-select--sm .gn-select__control:focus-visible {
  padding-left: calc(var(--gn-spacing-2, 8px) - 3px);
}


/* ========================================= */
/* COMPONENT: side-navigation */
/* ========================================= */
/* ==========================================================================
   SIDE NAVIGATION COMPONENT
   ========================================================================== */

.side-navigation {
  display: block;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  width: 100%;
}

.side-navigation__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* Base link / trigger styling */
.side-navigation__link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  box-sizing: border-box;
  padding: var(--gn-spacing-3, 16px) var(--gn-spacing-3, 16px);
  
  /* The active state has a 4px left border, so we set a transparent one by default */
  border: none;
  border-left: var(--gn-border-xl, 4px) solid transparent;
  border-bottom: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-light, #e5e5e5);
  
  background-color: transparent;
  color: var(--gn-color-link-default, #171717);
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 400;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.2s ease;
}

/* Icon (Caret) */
.side-navigation__icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform 0.2s ease, color 0.2s ease;
  color: currentColor;
}

.side-navigation__icon svg {
  width: 100%;
  height: 100%;
  fill: currentColor;
}

/* Hover state */
.side-navigation__link:hover:not(:disabled):not(.side-navigation__link--disabled) {
  background-color: var(--gn-color-fill-neutral-lighter, #f9f9f9);
}

/* Active state (current page) */
.side-navigation__link--active {
  border-left-color: var(--gn-color-border-primary, #d82b0f);
  font-weight: 700;
}

/* Expanded state for expandable items */
.side-navigation__link[aria-expanded="true"] .side-navigation__icon {
  transform: rotate(180deg);
  color: var(--gn-color-border-primary, #d82b0f);
}

/* Focus visible state */
.side-navigation__link:focus-visible {
  outline: none;
  /* Use an inset shadow to avoid layout shift and clipping, standard for list items */
  box-shadow: inset 0 0 0 2px var(--gn-color-border-focus, #a9cfe0);
  background-color: var(--gn-color-info-lighter, #eaf4f8);
}

/* Disabled state */
.side-navigation__link:disabled,
.side-navigation__link--disabled {
  color: var(--gn-color-text-default-disabled, #737373);
  cursor: not-allowed;
  pointer-events: none;
}

/* ==========================================================================
   NESTED LISTS (Sublevels)
   ========================================================================== */

/* Show/hide nested lists based on the aria-expanded state of the preceding trigger */
.side-navigation__link[aria-expanded="false"] + .side-navigation__list {
  display: none;
}

.side-navigation__link[aria-expanded="true"] + .side-navigation__list {
  display: block;
}

/* Indentation logic for sublevels */
/* Level 2 */
.side-navigation__list .side-navigation__list .side-navigation__link {
  padding-left: calc(var(--gn-spacing-3, 16px) + var(--gn-spacing-5, 24px));
}

/* Level 3 */
.side-navigation__list .side-navigation__list .side-navigation__list .side-navigation__link {
  padding-left: calc(var(--gn-spacing-3, 16px) + var(--gn-spacing-5, 24px) * 2);
}

/* Level 4 */
.side-navigation__list .side-navigation__list .side-navigation__list .side-navigation__list .side-navigation__link {
  padding-left: calc(var(--gn-spacing-3, 16px) + var(--gn-spacing-5, 24px) * 3);
}


/* ========================================= */
/* COMPONENT: textarea */
/* ========================================= */
/**
 * Component: TextArea
 * Node: 197:4922
 */

.gn-textarea {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-2, 8px);
  align-items: flex-start;
  width: 100%;
  max-width: 400px;
}

.gn-textarea__control {
  box-sizing: border-box;
  display: flex;
  align-items: flex-start;
  width: 100%;
  border-radius: var(--gn-radius-base, 3px);
  overflow: hidden;
  position: relative;
  transition: all 0.2s ease;
  background-color: var(--gn-color-fill-default, #ffffff);
  border: var(--gn-border-base, 1px) solid var(--gn-color-border-black, #171717);
  height: 111px;
  padding: var(--gn-spacing-3, 16px);
}

.gn-textarea__field {
  flex: 1 0 0;
  width: 100%;
  height: 100%;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
  font-family: var(--gn-font-family-base, 'Roboto', sans-serif);
  font-style: normal;
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  font-size: var(--gn-text-p-base, 18px);
  line-height: 1.2;
  outline: none;
  resize: none; /* Desactivamos el resize nativo para usar el visual */
}

/* Permitir scroll vertical si el texto sobrepasa los 111px estáticos */
.gn-textarea__field {
  overflow-y: auto;
}

.gn-textarea__field::placeholder {
  font-style: italic;
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  opacity: 1;
}

.gn-textarea__count {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-1, 4px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  font-family: var(--gn-font-family-base, 'Roboto', sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  line-height: normal;
  white-space: nowrap;
}

/* Elemento visual para el manipulador de resize decorativo */
.gn-textarea__resize-icon {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 9px;
  height: 9px;
  pointer-events: none; /* Permitimos que el click traspase hacia el textarea */
  color: var(--gn-color-border-black, #171717);
  display: flex;
  align-items: center;
  justify-content: center;
}

.gn-textarea__resize-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* =========================================================================
   ESTADOS (FOCUS, DISABLED, ERROR)
   ========================================================================= */

.gn-textarea__control:focus-within {
  border: 2px solid var(--gn-color-border-black, #171717);
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

/* En Focus, el icono puede ajustarse un px o ser invisible, 
   se reportan las mismas propiedades pero lo ocultamos ligeramente 
   o ajustamos su anclaje según el borde interior */
.gn-textarea__control:focus-within .gn-textarea__resize-icon {
  bottom: 2px;
  right: 2px;
}

/* Disabled */
.gn-textarea--disabled .gn-textarea__control,
.gn-textarea__field:disabled {
  background-color: var(--gn-color-fill-neutral-lighter-disabled, #f9f9f9);
  border-color: var(--gn-color-border-neutral-disabled, #b5b5b5);
  cursor: not-allowed;
}

.gn-textarea__field:disabled {
  color: var(--gn-color-text-default-disabled, #737373);
}

.gn-textarea__field:disabled::placeholder {
  color: var(--gn-color-text-default-disabled, #737373);
}

.gn-textarea--disabled .gn-textarea__resize-icon {
  color: var(--gn-color-border-neutral-disabled, #b5b5b5);
}

/* Error */
.gn-textarea--error .gn-textarea__control {
  border: 3px solid var(--gn-color-border-error, #d82b0f);
}

.gn-textarea--error .gn-textarea__control:focus-within {
  border-width: 3px;
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

/* Error desplaza el icono por el borde ensanchado */
.gn-textarea--error .gn-textarea__resize-icon {
  bottom: 1px;
  right: 1px;
}

/* =========================================================================
   TAMAÑOS
   ========================================================================= */

.gn-textarea--sm {
  max-width: 264px;
}

.gn-textarea--sm .gn-textarea__control {
  height: 73px;
  padding: var(--gn-spacing-2, 8px);
}

.gn-textarea--sm .gn-textarea__field,
.gn-textarea--sm .gn-textarea__field::placeholder {
  font-size: var(--gn-text-p-sm, 16px);
}


/* ========================================= */
/* COMPONENT: toggle */
/* ========================================= */
/* ==========================================================================
   TOGGLE COMPONENT
   ========================================================================== */

.toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
  position: relative;
  cursor: pointer;
  border-radius: var(--gn-radius-base, 3px);
  transition: box-shadow 0.2s ease, background-color 0.2s ease;
}

/* Ocultamiento visual del input nativo preservando su accesibilidad */
.toggle__input {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* Foco visible del conjunto (Wrapper) activado por teclado en el input oculto */
.toggle:focus-within,
.toggle.is-focus {
  background-color: rgba(255, 255, 255, 0.01);
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

/* Carril / Track del toggle */
.toggle__control {
  position: relative;
  flex-shrink: 0;
  width: 45.33px;
  height: 24px;
  background-color: var(--gn-color-fill-neutral-base, #b5b5b5);
  border-radius: 17px;
  transition: background-color 0.2s ease;
}

/* Pulgar / Thumb del toggle */
.toggle__thumb {
  position: absolute;
  top: 1.33px;
  left: 0.98px;
  width: 21.33px;
  height: 21.33px;
  background-color: #ffffff;
  border-radius: 50%;
  transition: transform 0.2s ease;
}

/* Etiqueta asociada */
.toggle__label {
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
}

/* ==========================================================================
   ESTADOS (ON / OFF)
   ========================================================================== */

/* Estado ON: Fondo oscuro del track */
.toggle__input:checked + .toggle__control,
.toggle.is-on .toggle__control {
  background-color: var(--gn-color-fill-dark, #171717);
}

/* Estado ON: Desplazamiento del thumb */
.toggle__input:checked + .toggle__control .toggle__thumb,
.toggle.is-on .toggle__control .toggle__thumb {
  /* En Figma: pos inicial 0.98px, pos final 22.8px -> Diferencia: 21.82px */
  transform: translateX(21.82px);
}

/* ==========================================================================
   TAMAÑOS (SM)
   ========================================================================== */

.toggle--sm .toggle__control {
  width: 35.78px;
  height: 18.94px;
}

.toggle--sm .toggle__thumb {
  top: 1.05px;
  left: 0.78px;
  width: 16.84px;
  height: 16.84px;
}

.toggle--sm .toggle__input:checked + .toggle__control .toggle__thumb,
.toggle--sm.is-on .toggle__control .toggle__thumb {
  /* En Figma: pos inicial 0.78px, pos final 17.99px -> Diferencia: 17.21px */
  transform: translateX(17.21px);
}

.toggle--sm .toggle__label {
  font-size: var(--gn-text-p-sm, 16px);
}


/* ========================================= */
/* PATTERN: footer */
/* ========================================= */
/* ==========================================================================
   FOOTER PATTERN
   ========================================================================== */

.footer {
  background-color: var(--gn-color-fill-neutral-lighter, #f9f9f9);
  color: var(--gn-color-text-default, #171717);
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  position: relative;
  width: 100%;
}

.footer__container {
  max-width: var(--gn-layout-desktop-4colums-4-col, 1140px);
  margin: 0 auto;
  padding: var(--gn-spacing-7, 40px) var(--gn-spacing-4, 20px);
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-6, 28px);
}

/* ==========================================================================
   MOBILE-FIRST DEFAULT LAYOUT
   ========================================================================== */

.footer__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gn-spacing-6, 28px);
}

.footer__block {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-2, 8px);
}

.footer__title {
  margin: 0;
  font-size: var(--gn-text-h5, 18px);
  font-weight: 700;
  color: var(--gn-color-text-default, #171717);
}

.footer__text {
  margin: 0;
  font-size: var(--gn-text-p-sm, 16px);
  color: var(--gn-color-text-default, #171717);
  line-height: 1.5;
}

.footer__contact-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gn-spacing-4, 20px);
  margin-top: var(--gn-spacing-1, 4px);
}

.footer__link {
  color: var(--gn-color-link-default, #171717);
  font-size: var(--gn-text-p-sm, 16px);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.footer__link:hover {
  color: var(--gn-color-link-hover, var(--gn-color-primary, #d82b0f));
  text-decoration-color: currentColor;
}

.footer__link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
  border-radius: var(--gn-radius-base, 3px);
}

.footer__divider {
  border: none;
  border-top: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-light, #e5e5e5);
  margin: 0;
  width: 100%;
}

.footer__legal {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-4, 20px);
}

.footer__legal-link {
  color: var(--gn-color-link-default, #171717);
  font-size: var(--gn-text-p-sm, 16px);
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
}

.footer__legal-link:hover {
  color: var(--gn-color-link-hover, var(--gn-color-primary, #d82b0f));
}

.footer__legal-link:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
  border-radius: var(--gn-radius-base, 3px);
}

.footer__bottom {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-6, 28px);
}

.footer__logos {
  display: flex;
  flex-wrap: wrap;
  gap: var(--gn-spacing-5, 24px);
  align-items: center;
}

.footer__logo {
  max-width: 100%;
  height: auto;
  display: block;
}

.footer__bar {
  width: 100%;
  height: var(--gn-border-xxl, 6px);
  background-color: var(--gn-color-fill-primary, #d82b0f);
}

/* ==========================================================================
   DESKTOP RESPONSIVE (>= 768px)
   ========================================================================== */

@media (min-width: 768px) {
  .footer__container {
    gap: var(--gn-spacing-7, 40px);
  }

  .footer__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer__legal {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }
}

/* ==========================================================================
   VARIANT: CENTERED (.footer--centered)
   ========================================================================== */

.footer--centered .footer__container {
  align-items: center;
  text-align: center;
}

.footer--centered .footer__grid {
  grid-template-columns: 1fr;
}

.footer--centered .footer__block {
  align-items: center;
}

.footer--centered .footer__contact-group {
  justify-content: center;
}

.footer--centered .footer__legal {
  justify-content: center;
}

.footer--centered .footer__logos {
  justify-content: center;
}

.footer--centered .footer__bottom {
  flex-direction: column;
}

/* ==========================================================================
   VARIANT: COMPACT (.footer--compact)
   ========================================================================== */

.footer--compact .footer__grid {
  grid-template-columns: 1fr;
  gap: var(--gn-spacing-3, 16px);
}

@media (min-width: 768px) {
  .footer--compact .footer__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

.footer--compact .footer__block {
  flex-direction: row;
  align-items: center;
  flex-wrap: wrap;
}

.footer--compact .footer__title {
  margin-right: var(--gn-spacing-2, 8px);
}

.footer--compact .footer__text {
  margin: 0;
}


/* ========================================= */
/* PATTERN: header */
/* ========================================= */
/* ==========================================================================
   HEADER PATTERN
   ========================================================================== */

.header {
  display: flex;
  flex-direction: column;
  width: 100%;
  background-color: var(--gn-color-fill-default, #ffffff);
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
}

.header__container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 var(--gn-spacing-5, 24px);
  height: 100%;
}

/* Modificador Fullwidth: El contenedor ocupa todo el ancho */
.header--fullwidth .header__container {
  max-width: 100%;
}

/* ==========================================================================
   BLOQUES ESTRUCTURALES
   ========================================================================== */

/* Barra superior (Usada para Header ID Logueado en modo default) */
.header__top {
  display: flex;
  align-items: center;
  min-height: 48px;
  background-color: var(--gn-color-success-light, #c2eca8);
}

/* Barra principal (Logo, Título, Acciones) */
.header__main {
  display: flex;
  align-items: center;
  height: 67px; /* Altura estándar en Figma */
  border-bottom: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-light, #e5e5e5);
}

/* Cuando no hay navegación inferior, el borde suele ser más fuerte */
.header--no-nav .header__main {
  border-bottom-color: var(--gn-color-border-neutral-base, #959595);
}

/* Fila de navegación inferior */
.header__nav-row {
  display: flex;
  align-items: center;
  min-height: 53px;
  border-bottom: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-base, #959595);
}

/* Fila de sub-navegación (Navegación secundaria) */
.header__subnav-row {
  display: flex;
  align-items: center;
  min-height: 53px;
  border-bottom: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-base, #959595);
  background-color: var(--gn-color-fill-neutral-light, #f5f5f5); /* Un ligero contraste si es necesario */
}

/* ==========================================================================
   MARCA Y TÍTULO (Brand)
   ========================================================================== */

.header__brand {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-5, 24px);
  height: 100%;
}

.header__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 35px;
}

.header__logo img {
  height: 100%;
  width: auto;
  display: block;
}

.header__divider {
  width: 1px;
  height: 34px;
  background-color: var(--gn-color-border-neutral-base, #959595);
}

.header__title-group {
  display: flex;
  flex-direction: column;
  justify-content: center;
  white-space: nowrap;
}

.header__title {
  margin: 0;
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 500;
  color: var(--gn-color-text-default, #171717);
  line-height: 1.2;
}

.header__subtitle {
  margin: 0;
  font-size: var(--gn-text-p-xs, 12px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  line-height: 1.2;
}

/* ==========================================================================
   ACCIONES (Idioma, Login, Nav Inline)
   ========================================================================== */

.header__actions {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-3, 16px);
  height: 100%;
}

.header__lang {
  display: flex;
  align-items: center;
  height: 35px;
}

.header__login {
  display: flex;
  align-items: center;
}

/* Navegación incrustada en el main (usado en Fullwidth Compact) */
.header__nav-inline {
  display: flex;
  flex: 1;
  align-items: center;
  padding: 0 var(--gn-spacing-4, 20px);
}

/* ==========================================================================
   BLOQUE DE USUARIO (User Block)
   ========================================================================== */

.header__user-block {
  display: flex;
  align-items: center;
  height: 100%;
  background-color: var(--gn-color-success-light, #c2eca8);
}

/* Si el user block está dentro de un top bar normal, se alinea distinto */
.header__top .header__user-block {
  width: 100%;
  justify-content: space-between;
}

/* Elementos internos del user block */
.header__user-info {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
  padding: 0 var(--gn-spacing-3, 16px);
}

.header__user-avatar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  color: var(--gn-color-text-default, #171717);
}

.header__user-details {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.header__user-name {
  font-size: var(--gn-text-p-sm, 16px);
  font-weight: 700;
  color: var(--gn-color-text-default, #171717);
  margin: 0;
  line-height: 1.2;
}

.header__user-meta {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
  font-size: var(--gn-text-p-xs, 12px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  margin: 0;
  line-height: 1.2;
}

.header__user-meta-divider {
  width: 1px;
  height: 12px;
  background-color: var(--gn-color-border-neutral-base, #959595);
}

.header__user-actions {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-3, 16px);
  padding: 0 var(--gn-spacing-3, 16px);
  border-left: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-base, #959595);
  height: 100%;
}

.header__user-connection {
  font-size: var(--gn-text-p-sm, 16px);
  color: var(--gn-color-text-default, #171717);
  margin: 0;
}

/* Logout como botón iconográfico en móvil, y texto en desktop */
.header__logout-btn {
  /* Reutilizamos clases del gn-button, aquí solo ajustes finos si aplica */
}

/* ==========================================================================
   MOBILE & RESPONSIVE
   ========================================================================== */

.header__menu-toggle {
  display: none;
  background: transparent;
  border: none;
  padding: var(--gn-spacing-2, 8px);
  cursor: pointer;
  color: var(--gn-color-text-default, #171717);
  border-radius: var(--gn-radius-base, 3px);
  transition: box-shadow 0.2s ease, background-color 0.2s ease;
}

.header__menu-toggle:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

.header__menu-toggle:hover {
  background-color: var(--gn-color-fill-neutral-light, #e5e5e5);
}

.header__mobile-panel {
  display: none;
  flex-direction: column;
  width: 100%;
  background-color: var(--gn-color-fill-default, #ffffff);
  border-top: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-light, #e5e5e5);
}

/* Modificador de estado Abierto */
.header--menu-open .header__mobile-panel {
  display: flex;
}

/* Reglas móviles */
@media (max-width: 992px) {
  .header__menu-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
  /* Ocultamos navegaciones de escritorio y acciones secundarias */
  .header__nav-row,
  .header__subnav-row,
  .header__lang,
  .header__nav-inline {
    display: none;
  }
  
  /* En móvil el user block no suele ir en la barra top, va dentro del panel */
  .header__top {
    display: none;
  }
  
  .header__container {
    padding: 0 var(--gn-spacing-4, 20px);
  }
  
  /* Layout interno del panel móvil */
  .header__mobile-panel .header__user-block {
    flex-direction: column;
    align-items: stretch;
    padding: var(--gn-spacing-3, 16px);
    background-color: var(--gn-color-success-light, #c2eca8);
  }
  
  .header__mobile-panel .header__user-actions {
    border-left: none;
    border-top: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-base, #959595);
    padding: var(--gn-spacing-3, 16px) 0 0 0;
    margin-top: var(--gn-spacing-3, 16px);
    flex-direction: column;
    align-items: flex-start;
  }
}


/* ========================================= */
/* PATTERN: pagination */
/* ========================================= */
/* ==========================================================================
   PAGINATION PATTERN
   ========================================================================== */

.pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap; /* Soporte para pantallas estrechas */
  gap: var(--gn-spacing-4, 20px);
  width: 100%;
}

.pagination__nav {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-0, 2px);
}

.pagination__list {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-0, 2px);
  list-style: none;
  margin: 0;
  padding: 0;
}

.pagination__item {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Estilos base para enlaces (números) y botones (anterior/siguiente) */
.pagination__link,
.pagination__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 35px;
  padding: var(--gn-spacing-2, 8px) var(--gn-spacing-3, 16px);
  border-radius: var(--gn-radius-base, 3px);
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  background-color: transparent;
  border: none;
  cursor: pointer;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, color 0.2s ease;
}

/* Modificador para controles con texto y flecha */
.pagination__button--nav {
  min-width: auto;
  gap: var(--gn-spacing-2, 8px);
  padding-left: var(--gn-spacing-2, 8px);
  padding-right: var(--gn-spacing-3, 16px);
}
.pagination__button--nav-next {
  padding-left: var(--gn-spacing-3, 16px);
  padding-right: var(--gn-spacing-2, 8px);
}

/* Variantes solo icono (layout compacto) */
.pagination__button--icon {
  min-width: auto;
  width: 35px;
  height: 35px;
  padding: 0;
  text-decoration: none;
}

/* Estados Hover & Focus */
.pagination__link:hover:not(.pagination__link--current):not(.pagination__link--ellipsis),
.pagination__button:hover:not(:disabled) {
  background-color: rgba(23, 23, 23, 0.04);
}

.pagination__link:focus-visible,
.pagination__button:focus-visible,
.pagination__link.is-focus,
.pagination__button.is-focus {
  outline: none;
  background-color: rgba(255, 255, 255, 0.02);
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

/* Página actual */
.pagination__link--current {
  color: var(--gn-color-link-focus, #d82b0f);
  font-weight: 500;
  text-decoration: none;
  cursor: default;
}

/* Puntos suspensivos */
.pagination__link--ellipsis {
  cursor: default;
}

/* Deshabilitado */
.pagination__button:disabled {
  color: var(--gn-color-text-default-disabled, #737373);
  cursor: not-allowed;
  opacity: 0.5;
  text-decoration: none;
}

/* Textos de resumen y selectores */
.pagination__summary {
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  white-space: nowrap;
}

.pagination__controls {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-4, 20px);
  flex-wrap: wrap;
}

.pagination__selector {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
}

.pagination__selector-label {
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  white-space: nowrap;
}

/* Adaptación del select al contexto del pattern */
.pagination .gn-select__wrapper {
  min-width: 60px;
}
.pagination .gn-select__control {
  height: 35px;
  padding-top: var(--gn-spacing-1, 4px);
  padding-bottom: var(--gn-spacing-1, 4px);
  font-size: var(--gn-text-p-sm, 16px);
}


/* ========================================= */
/* PATTERN: searchbar */
/* ========================================= */
/* ==========================================================================
   SEARCHBAR PATTERN
   ========================================================================== */

.searchbar {
  display: flex;
  align-items: stretch; /* Aseguramos que input y botón ocupen el mismo alto */
  gap: var(--gn-spacing-2, 8px);
  position: relative;
  width: 100%;
  border-radius: var(--gn-radius-base, 3px);
  transition: box-shadow 0.2s ease, background-color 0.2s ease;
}

/* Variantes de Layout / Tamaños */
.searchbar--default {
  max-width: var(--gn-layout-desktop-4colums-1-col, 504px);
}

.searchbar--sm {
  max-width: var(--gn-layout-desktop-4colums-1-col, 270px);
}

/* Foco de Conjunto (Pattern Wrapper) */
.searchbar:focus-within,
.searchbar.is-focus {
  background-color: rgba(255, 255, 255, 0.02);
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
  outline: none;
}

/* Ocultar el foco nativo de los componentes base cuando están dentro del searchbar */
.searchbar:focus-within .gn-input__control,
.searchbar:focus-within .gn-input__field:focus,
.searchbar:focus-within .gn-button:focus-visible,
.searchbar.is-focus .gn-input__control,
.searchbar.is-focus .gn-input__field,
.searchbar.is-focus .gn-button {
  outline: none !important;
  box-shadow: none !important;
  border-color: inherit; /* Mantiene su borde estático y delega la percepción de foco al halo exterior */
}

/* Estilos estructurales internos */
.searchbar__input-wrapper {
  flex: 1 1 auto;
  margin: 0; /* Por si el componente base trajera margen inferior de validaciones */
  display: flex;
  flex-direction: column;
}

.searchbar__button {
  flex-shrink: 0;
  margin: 0;
}

/* Adaptaciones de altura si el input interno usa min-height por padding nativo */
/* Estas reglas aseguran que las medidas coincidan con las de Figma */
.searchbar--default .gn-input__control,
.searchbar--default .gn-button {
  min-height: 53px;
}

.searchbar--sm .gn-input__control,
.searchbar--sm .gn-button {
  min-height: 35px;
}

.searchbar--sm .gn-input__control,
.searchbar--sm .gn-button {
  padding-top: var(--gn-spacing-2, 8px);
  padding-bottom: var(--gn-spacing-2, 8px);
}

.searchbar--sm .gn-input__field,
.searchbar--sm .gn-button__label {
  font-size: var(--gn-text-p-sm, 16px);
}


/* ========================================= */
/* PATTERN: table */
/* ========================================= */
/* ==========================================================================
   TABLE PATTERN
   ========================================================================== */

.table {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-3, 16px);
  width: 100%;
}

/* ==========================================================================
   BLOCK: HEADER (Title, Hint, Actions)
   ========================================================================== */

.table__header {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--gn-spacing-4, 20px);
}

.table__label {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-1, 4px);
}

.table__title {
  margin: 0;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-base, 18px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
}

.table__hint {
  margin: 0;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  font-weight: 400;
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
}

.table__actions {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
}

/* ==========================================================================
   BLOCK: TABLE ELEMENT
   ========================================================================== */

.table__container {
  width: 100%;
  overflow-x: auto; /* Responsive by default para no romper el layout padre */
}

.table__element {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
}

/* ==========================================================================
   HEADER CELLS (TH)
   ========================================================================== */

.table__th {
  border-top: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-dark, #737373);
  border-bottom: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-dark, #737373);
  padding: var(--gn-spacing-4, 20px) var(--gn-spacing-3, 16px);
  vertical-align: top;
  font-weight: 400; /* Figma especifica Regular */
}

.table__th-content {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
  white-space: nowrap;
}

/* Botón de ordenación dentro de TH */
.table__sort-button {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  border-radius: var(--gn-radius-base, 3px);
  transition: box-shadow 0.2s ease;
}

.table__sort-button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px var(--gn-color-fill-default, #ffffff), 
              0 0 0 6px var(--gn-color-border-focus, #a9cfe0);
}

.table__sort-icon {
  width: 20px;
  height: 20px;
}

/* Zona de filtros (Searchbar, Select) incrustados en TH */
.table__filter {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-2, 8px);
  font-weight: 400;
}

/* Ajustes finos para que el searchbar encaje limpiamente dentro del cell */
.table__filter .searchbar {
  min-width: auto;
  max-width: 100%;
}

.table__filter .gn-select__wrapper {
  width: 100%;
}

/* ==========================================================================
   DATA CELLS (TD)
   ========================================================================== */

.table__td {
  border-bottom: var(--gn-border-base, 1px) solid var(--gn-color-border-neutral-base, #959595);
  padding: var(--gn-spacing-4, 20px) var(--gn-spacing-3, 16px);
  vertical-align: middle;
  font-family: var(--gn-font-family-base, "Roboto", sans-serif);
  font-size: var(--gn-text-p-sm, 16px);
  font-weight: 400;
  color: var(--gn-color-text-default, #171717);
}

/* Modificador Compact para celdas de datos */
.table--compact .table__td {
  padding: var(--gn-spacing-2, 8px) var(--gn-spacing-3, 16px);
  height: 35px;
}

/* Fondo para columnas o filas destacadas */
.table__td--fill {
  background-color: var(--gn-color-fill-neutral-light, #e5e5e5);
}

/* Agrupador de acciones por fila */
.table__actions-row {
  display: flex;
  align-items: center;
  gap: var(--gn-spacing-2, 8px);
}

/* Agrupador para celdas compuestas (Dato + Subdato) */
.table__double-data {
  display: flex;
  flex-direction: column;
  gap: var(--gn-spacing-2, 8px);
}
.table__double-data-sub {
  font-size: var(--gn-text-p-xs, 12px);
  color: var(--gn-color-text-default-light, rgba(23, 23, 23, 0.6));
}

/* Centrado explícito para columnas de checkbox */
.table__checkbox-wrapper {
  display: flex;
  align-items: center;
}

/* ==========================================================================
   ALINEACIONES
   ========================================================================== */

/* Izquierda (Por defecto) */
.table__th--left .table__th-content { justify-content: flex-start; }
.table__td--left { text-align: left; }
.table__td--left .table__actions-row { justify-content: flex-start; }
.table__td--left .table__checkbox-wrapper { justify-content: flex-start; }

/* Centro */
.table__th--center .table__th-content { justify-content: center; }
.table__td--center { text-align: center; }
.table__td--center .table__actions-row { justify-content: center; }
.table__td--center .table__checkbox-wrapper { justify-content: center; }

/* Derecha */
.table__th--right .table__th-content { justify-content: flex-end; }
.table__td--right { text-align: right; }
.table__td--right .table__actions-row { justify-content: flex-end; }
.table__td--right .table__checkbox-wrapper { justify-content: flex-end; }
