/* ==========================================================================
   hiringbe Klaro overrides — v7
   Design system: neutral Slate palette only. No brand accents.
   Dark mode supported. Font weights aligned with design system (500/600/700).
   Minimal, professional consent UI.
   ========================================================================== */

/* --- Design tokens ------------------------------------------------------ */
.klaro {
  --hb-consent-surface: var(--surface-card);
  --hb-consent-surface-muted: var(--color-neutral-50);
  --hb-consent-surface-raised: var(--color-white);
  --hb-consent-border: var(--border);
  --hb-consent-border-strong: var(--color-neutral-400);
  --hb-consent-border-soft: var(--color-neutral-200);
  --hb-consent-button-secondary: var(--color-white);
  --hb-consent-button-secondary-hover: var(--color-neutral-50);
  --hb-consent-text: var(--content-primary);
  --hb-consent-text-muted: var(--content-secondary);
  --hb-consent-text-subtle: var(--content-secondary-soft);
  --hb-consent-strong: var(--color-neutral-950);
  --hb-consent-radius: var(--radius-lg);
  --hb-consent-radius-inner: var(--radius-md);

  /* Primary action (neutral solid) */
  --hb-consent-primary: var(--color-neutral-950);
  --hb-consent-primary-hover: var(--color-neutral-800);
  --hb-consent-primary-text: var(--color-white);

  /* Focus ring */
  --hb-consent-focus: var(--color-neutral-950);
}

/* --- Dark mode tokens --------------------------------------------------- */
html.dark .klaro {
  --hb-consent-surface: var(--color-neutral-900);
  --hb-consent-surface-muted: var(--color-neutral-800);
  --hb-consent-surface-raised: var(--color-neutral-850);
  --hb-consent-border: var(--color-neutral-700);
  --hb-consent-border-strong: var(--color-neutral-500);
  --hb-consent-border-soft: var(--color-neutral-700);
  --hb-consent-button-secondary: var(--color-neutral-900);
  --hb-consent-button-secondary-hover: var(--color-neutral-800);
  --hb-consent-text: var(--color-neutral-100);
  --hb-consent-text-muted: var(--color-neutral-400);
  --hb-consent-strong: var(--color-white);
  --hb-consent-primary: var(--color-white);
  --hb-consent-primary-hover: var(--color-neutral-100);
  --hb-consent-primary-text: var(--color-neutral-950);
  --hb-consent-focus: var(--color-white);
}

/* --- Focus ring --------------------------------------------------------- */
.klaro :focus-visible {
  outline: 2px solid var(--hb-consent-focus) !important;
  outline-offset: 2px;
}

/* ==========================================================================
   COOKIE NOTICE (Banner)
   ========================================================================== */

.klaro .cookie-notice:not(.cookie-modal-notice) {
  position: fixed;
  right: 50%;
  bottom: 1.25rem;
  left: auto;
  width: min(calc(100vw - 2.5rem), 38rem);
  max-width: min(calc(100vw - 2.5rem), 38rem);
  overflow: hidden;
  color: var(--hb-consent-text);
  border: 1px solid var(--hb-consent-border);
  border-radius: var(--hb-consent-radius);
  background: var(--hb-consent-surface);
  box-shadow: var(--shadow-card);
  isolation: isolate;
  transform: translateX(50%);
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  padding: clamp(1.25rem, 2.5vw, 1.5rem);
}

/* Notice title via ::before pseudo-element */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body::before {
  width: 100%;
  margin-bottom: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--hb-consent-strong);
  content: "Privacidad y cookies";
}

html[lang^="en"] .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body::before {
  content: "Privacy and cookies";
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body p,
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body span,
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body strong,
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body a {
  color: var(--hb-consent-text);
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body > p:first-child {
  width: 100%;
  margin: 0;
  margin-bottom: 0.5rem;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--hb-consent-text-muted);
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok,
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0;
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn {
  margin-top: 0;
}

/* --- Notice: Customize link (secondary outline) ------------------------ */
.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-learn-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  padding: 0.72rem 1.05rem;
  margin: 0;
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--hb-consent-strong);
  text-decoration: none;
  border: 1px solid var(--hb-consent-border);
  border-radius: var(--hb-consent-radius-inner);
  background: var(--hb-consent-button-secondary);
  transition:
    color 160ms ease,
    border-color 160ms ease,
    background-color 160ms ease;
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-learn-more:hover {
  color: var(--hb-consent-strong);
  border-color: var(--hb-consent-border-strong);
  background-color: var(--hb-consent-button-secondary-hover);
}

/* --- Shared button base ------------------------------------------------- */
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn,
.klaro .cookie-modal .cm-btn,
.klaro .hb-consent-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.65rem;
  padding: 0.72rem 1.05rem;
  margin-right: 0;
  font-family: var(--font-display);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: var(--type-button-letter-spacing);
  border: 1px solid transparent;
  border-radius: var(--hb-consent-radius-inner);
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    color 160ms ease;
  cursor: pointer;
}

/* --- Secondary actions: reject / configure / close ---------------------- */
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cn-decline,
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cm-btn-danger,
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cm-btn-info,
.klaro .cookie-modal .cm-btn.cm-btn-decline,
.klaro .cookie-modal .cm-btn.cm-btn-danger,
.klaro .cookie-modal .cm-btn.cm-btn-info,
.klaro .cookie-modal .cm-btn.cm-btn-accept:not(.cm-btn-accept-all),
.klaro .cookie-modal .cm-btn.cm-btn-close,
.klaro .hb-consent-action--secondary {
  color: var(--hb-consent-strong) !important;
  border-color: var(--hb-consent-border) !important;
  background: var(--hb-consent-button-secondary) !important;
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cn-decline:hover,
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cm-btn-danger:hover,
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cm-btn-info:hover,
.klaro .cookie-modal .cm-btn.cm-btn-decline:hover,
.klaro .cookie-modal .cm-btn.cm-btn-danger:hover,
.klaro .cookie-modal .cm-btn.cm-btn-info:hover,
.klaro .cookie-modal .cm-btn.cm-btn-accept:not(.cm-btn-accept-all):hover,
.klaro .cookie-modal .cm-btn.cm-btn-close:hover,
.klaro .hb-consent-action--secondary:hover {
  color: var(--hb-consent-strong) !important;
  border-color: var(--hb-consent-border-strong) !important;
  background: var(--hb-consent-button-secondary-hover) !important;
}

/* --- Accept all (primary — solid neutral, most prominent) ----------------- */
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cm-btn-success,
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cn-ok,
.klaro .cookie-notice:not(.cookie-modal-notice) .hb-consent-action--primary,
.klaro .cookie-modal .cm-btn.cm-btn-accept-all,
.klaro .cookie-modal .cm-btn.cm-btn-success-var,
.klaro .cookie-modal .hb-consent-action--primary {
  color: var(--hb-consent-primary-text) !important;
  border-color: transparent !important;
  background: var(--hb-consent-primary) !important;
}

.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cm-btn-success:hover,
.klaro .cookie-notice:not(.cookie-modal-notice) .cm-btn.cn-ok:hover,
.klaro .cookie-notice:not(.cookie-modal-notice) .hb-consent-action--primary:hover,
.klaro .cookie-modal .cm-btn.cm-btn-accept-all:hover,
.klaro .cookie-modal .cm-btn.cm-btn-success-var:hover,
.klaro .cookie-modal .hb-consent-action--primary:hover {
  background: var(--hb-consent-primary-hover) !important;
}

/* --- Privacy link styling ----------------------------------------------- */
.klaro .cookie-notice a,
.klaro .cookie-modal a {
  color: var(--hb-consent-strong);
  text-decoration: underline;
  text-underline-offset: 0.18em;
  transition: opacity 160ms ease;
}

.klaro .cookie-notice a:hover,
.klaro .cookie-modal a:hover {
  opacity: 0.78;
}

/* ==========================================================================
   COOKIE MODAL
   ========================================================================== */

.klaro .cookie-modal {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  box-sizing: border-box;
  padding: clamp(0.75rem, 2vw, 1.25rem);
}

.klaro .cookie-modal .cm-bg {
  background: color-mix(in srgb, var(--color-neutral-950) 60%, transparent);
}

html.dark .klaro .cookie-modal .cm-bg {
  background: color-mix(in srgb, var(--color-black) 72%, transparent);
}

.klaro .cookie-modal .cm-modal.cm-klaro {
  position: relative;
  inset: auto;
  width: min(calc(100vw - 1.5rem), 48rem);
  max-width: min(calc(100vw - 1.5rem), 48rem);
  max-height: min(84vh, 45rem);
  margin: 0 auto;
  overflow: auto;
  color: var(--hb-consent-text);
  border: 1px solid var(--hb-consent-border);
  border-radius: var(--hb-consent-radius);
  background: var(--hb-consent-surface);
  box-shadow: var(--shadow-card);
  transform: none;
  scrollbar-width: thin;
}

/* --- Close button ------------------------------------------------------- */
.klaro .cookie-modal .cm-modal .hide {
  top: 1.15rem;
  right: 1.15rem;
  display: grid;
  place-items: center;
  width: 2.25rem;
  height: 2.25rem;
  border: 1px solid var(--hb-consent-border-soft);
  border-radius: 999px;
  background: var(--hb-consent-surface-muted);
  transition: border-color 160ms ease;
}

.klaro .cookie-modal .cm-modal .hide:hover {
  border-color: var(--hb-consent-border-strong);
}

.klaro .cookie-modal .cm-modal .hide svg {
  width: 0.9rem;
  height: 0.9rem;
  stroke: var(--hb-consent-text-muted);
}

/* --- Header ------------------------------------------------------------- */
.klaro .cookie-modal .cm-modal .cm-header {
  padding: clamp(1.25rem, 2.2vw, 1.7rem) clamp(1.15rem, 2.4vw, 1.65rem) 1.05rem;
  border-bottom: 1px solid var(--hb-consent-border-soft);
}

.klaro .cookie-modal .cm-modal .cm-header h1,
.klaro .cookie-modal .cm-modal .cm-header h1.title {
  margin: 0;
  padding-right: 3.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.32rem, 2.2vw, 1.72rem);
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: -0.025em;
  color: var(--hb-consent-strong);
}

/* --- Body --------------------------------------------------------------- */
.klaro .cookie-modal .cm-modal .cm-body {
  padding: 1rem clamp(1.15rem, 2.4vw, 1.65rem) 0.85rem;
}

.klaro .cookie-modal p,
.klaro .cookie-modal li,
.klaro .cookie-modal strong,
.klaro .cookie-modal span {
  color: var(--hb-consent-text);
}

.klaro .cookie-modal .cm-modal .cm-body > p {
  max-width: 40rem;
  color: var(--hb-consent-text-muted);
  font-size: 0.94rem;
  line-height: 1.6;
}

/* --- Service cards ------------------------------------------------------ */
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes {
  display: grid;
  gap: 0.68rem;
  margin-top: 1.05rem;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-service {
  position: relative;
  min-height: 5.15rem;
  padding: 1rem 5rem 1rem 1.05rem;
  margin-top: 0;
  border: 1px solid var(--hb-consent-border-soft);
  border-radius: var(--hb-consent-radius-inner);
  background: var(--hb-consent-surface);
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service.cm-toggle-all,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-service.cm-toggle-all {
  display: none;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service p,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-service p {
  margin: 0;
  color: var(--hb-consent-text-muted);
  line-height: 1.5;
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service span.cm-list-title,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-service span.cm-list-title {
  display: block;
  margin-bottom: 0.25rem;
  font-family: var(--font-display);
  font-size: clamp(0.98rem, 1.3vw, 1.08rem);
  font-weight: 600;
  letter-spacing: -0.015em;
  color: var(--hb-consent-strong);
}

.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service span.cm-opt-out,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service span.cm-required,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-service span.cm-opt-out,
.klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-service span.cm-required {
  color: var(--hb-consent-text-muted);
}

/* --- Toggle switches ---------------------------------------------------- */
.klaro .cookie-modal .cm-list-label {
  right: 1.05rem;
  left: auto;
}

.klaro .cookie-modal .cm-modal .cm-list-label .cm-switch {
  right: 1.05rem;
  left: auto;
  width: 3rem;
  height: 1.72rem;
}

.klaro .cookie-modal .cm-list-label .slider {
  width: 2.8rem;
  height: 1.5rem;
  border: 1px solid var(--color-neutral-300) !important;
  border-radius: 999px;
  background: var(--color-neutral-200) !important;
  box-shadow: none !important;
  transition: background-color 0.2s ease, border-color 0.2s ease !important;
}

html.dark .klaro .cookie-modal .cm-list-label .slider {
  border-color: var(--color-neutral-600) !important;
  background: var(--color-neutral-700) !important;
}

.klaro .cookie-modal .cm-modal .cm-list-label .slider::before {
  width: 1.1rem;
  height: 1.1rem;
  bottom: 0.15rem;
  left: 0.2rem;
  background: var(--color-white) !important;
  border: none !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15) !important;
  transition: transform 0.2s ease !important;
}

/* Toggle active: neutral solid */
.klaro .cookie-modal .cm-modal .cm-list-input:checked + .cm-list-label .slider {
  border-color: var(--hb-consent-primary) !important;
  background: var(--hb-consent-primary) !important;
}

.klaro .cookie-modal .cm-modal .cm-list-input:focus + .cm-list-label .slider {
  outline: 2px solid var(--hb-consent-focus);
  outline-offset: 2px;
}

/* --- Footer ------------------------------------------------------------- */
.klaro .cookie-modal .cm-modal .cm-footer {
  padding: 1rem clamp(1.15rem, 2.4vw, 1.65rem) clamp(1.1rem, 2vw, 1.35rem);
  border-top: 1px solid var(--hb-consent-border-soft);
  background: color-mix(in srgb, var(--hb-consent-surface) 84%, var(--hb-consent-surface-muted) 16%);
}

.klaro .cookie-modal .cm-modal .cm-footer-buttons {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.75rem;
}

.klaro .cookie-modal .cm-modal .cm-footer .cm-powered-by {
  display: none;
}

/* ==========================================================================
   RESPONSIVE — Mobile (< 768px)
   ========================================================================== */

@media (max-width: 767px) {
  .klaro .cookie-notice:not(.cookie-modal-notice) {
    right: 50%;
    bottom: 0.75rem;
    width: calc(100vw - 1.5rem);
    max-width: none;
    border-radius: var(--hb-consent-radius);
  }

  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body {
    flex-direction: column;
    align-items: flex-start;
  }

  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons {
    width: 100%;
    flex-direction: column;
  }

  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-ok button,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-buttons button.cm-btn,
  .klaro .cookie-notice:not(.cookie-modal-notice) .cn-body .cn-learn-more {
    width: 100%;
    justify-content: center;
    text-align: center;
  }

  .klaro .cookie-modal {
    padding: 0.75rem;
  }

  .klaro .cookie-modal .cm-modal.cm-klaro {
    width: 100%;
    max-width: none;
    max-height: calc(100vh - 1.5rem);
    border-radius: var(--hb-consent-radius);
  }

  /* Keep toggle right-aligned on mobile — no position swap */
  .klaro .cookie-modal .cm-modal .cm-body ul.cm-services li.cm-service,
  .klaro .cookie-modal .cm-modal .cm-body ul.cm-purposes li.cm-service {
    padding: 1rem 5rem 1rem 1.05rem;
  }

  .klaro .cookie-modal .cm-list-label {
    top: 50%;
    right: 1.05rem;
    left: auto;
    transform: translateY(-50%);
  }

  .klaro .cookie-modal .cm-modal .cm-footer-buttons {
    flex-direction: column;
    align-items: stretch;
  }

  .klaro .cookie-modal .cm-modal .cm-footer-buttons button,
  .klaro .cookie-modal .cm-modal .cm-footer-buttons a {
    width: 100%;
    justify-content: center;
  }
}

/* ==========================================================================
   REDUCED MOTION
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  .klaro .cookie-modal .cm-list-label .slider,
  .klaro .cookie-modal .cm-modal .cm-list-label .slider::before {
    transition: none !important;
  }
}
