/*
 * cookie-consent.css - Cookie banner + preferences modal styling.
 * Extracted from inline styles so it can be cached.
 */

#cookie-consent-banner {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1090;
  background: linear-gradient(180deg, #0f172a 0%, #111827 100%);
  color: #f9fafb;
  border-top: 1px solid #334155;
  box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.28);
  padding: 1rem;
}

#cookie-consent-banner[hidden] {
  display: none !important;
}

#cookie-consent-banner .cookie-consent-wrap {
  max-width: 1240px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

/* Let copy shrink in flex rows so buttons cannot paint over the policy links. */
#cookie-consent-banner .cookie-consent-copy {
  min-width: 0;
}

#cookie-consent-banner .cookie-consent-title {
  margin: 0;
  font-weight: 700;
  font-size: 1rem;
  line-height: 1.25;
  letter-spacing: 0.01em;
}

#cookie-consent-banner .cookie-consent-text {
  margin: 0;
  font-size: 0.9rem;
  color: #cbd5e1;
  line-height: 1.5;
}

#cookie-consent-banner .cookie-consent-text a {
  color: #bfdbfe;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 2px;
}

#cookie-consent-banner .cookie-consent-text a:hover {
  color: #dbeafe;
}

#cookie-consent-banner .cookie-consent-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
}

#cookie-consent-banner .cookie-btn {
  border: 1px solid transparent;
  border-radius: 10px;
  padding: 0.5rem 0.95rem;
  min-height: 38px;
  font-size: 0.85rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

#cookie-consent-accept {
  background: #2563eb;
  color: #fff;
  border-color: #3b82f6;
}

#cookie-consent-accept:hover {
  background: #1d4ed8;
  border-color: #2563eb;
}

#cookie-consent-reject {
  background: #1e293b;
  border-color: #475569;
  color: #fff;
}

#cookie-consent-reject:hover {
  background: #334155;
}

#cookie-consent-banner #cookie-consent-preferences {
  background: linear-gradient(180deg, #f59e0b 0%, #d97706 100%);
  border-color: #f59e0b;
  color: #fff;
  box-shadow: 0 6px 14px rgba(245, 158, 11, 0.35);
}

#cookie-consent-banner #cookie-consent-preferences:hover {
  background: linear-gradient(180deg, #fbbf24 0%, #ea580c 100%);
  border-color: #fbbf24;
  color: #fff;
}

#cookie-consent-banner #cookie-consent-preferences:focus-visible {
  color: #fff;
  outline: 2px solid #fde68a;
  outline-offset: 2px;
}

#cookie-consent-modal {
  position: fixed;
  inset: 0;
  z-index: 1095;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: rgba(0, 0, 0, 0.55);
}

#cookie-consent-modal[hidden] {
  display: none !important;
}

#cookie-consent-modal .cookie-modal-panel {
  width: min(560px, 100%);
  background: #111827;
  color: #f9fafb;
  border: 1px solid #374151;
  border-radius: 12px;
  padding: 1rem;
}

#cookie-consent-modal .cookie-modal-title {
  margin: 0 0 0.75rem;
  font-size: 1.1rem;
  font-weight: 700;
}

#cookie-consent-modal .cookie-modal-row {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  align-items: flex-start;
  margin: 0 0 0.75rem;
  padding: 0.6rem 0.65rem;
  border: 1px solid #374151;
  border-radius: 8px;
}

#cookie-consent-modal .cookie-modal-row p {
  margin: 0;
  font-size: 0.85rem;
  color: #d1d5db;
}

#cookie-consent-modal .cookie-modal-row strong {
  color: #fff;
}

#cookie-consent-modal .cookie-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-top: 0.9rem;
}

#cookie-consent-save {
  background: #2563eb;
  color: #fff;
}

#cookie-consent-close {
  background: #374151;
  color: #fff;
}

@media (min-width: 768px) {
  #cookie-consent-banner .cookie-consent-wrap {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
  }
  #cookie-consent-banner .cookie-consent-copy {
    flex: 1 1 17rem;
    max-width: min(70%, 100%);
    min-width: 0;
  }
  #cookie-consent-banner .cookie-consent-actions {
    flex: 0 1 auto;
    justify-content: flex-end;
    max-width: 100%;
    padding-top: 0.1rem;
  }
}

@media (max-width: 560px) {
  #cookie-consent-banner {
    padding: 0.9rem 0.8rem;
  }
  #cookie-consent-banner .cookie-consent-actions {
    width: 100%;
  }
  #cookie-consent-banner .cookie-btn {
    flex: 1 1 calc(50% - 0.55rem);
    text-align: center;
  }
  #cookie-consent-banner #cookie-consent-preferences {
    flex-basis: 100%;
  }
}

/* -------------------------------------------------------------------------- */
/* Discount promo modal — modern card (cookie-gated, after consent)           */
/* -------------------------------------------------------------------------- */
.discount-modal[hidden] {
  display: none !important;
}

.discount-modal {
  position: fixed;
  inset: 0;
  z-index: 1092;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(0.75rem, 2.5vw, 1.25rem);
  overflow-y: auto;
  overscroll-behavior: contain;
  pointer-events: none;
  visibility: hidden;
  opacity: 0;
  transition: visibility 0.25s ease, opacity 0.25s ease;
}

.discount-modal[aria-hidden="true"] {
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
}

.discount-modal.discount-modal--open,
.discount-modal[aria-hidden="false"] {
  visibility: visible;
  opacity: 1;
  pointer-events: auto;
}

.discount-modal__backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in srgb, var(--green-900, #0c2433) 35%, rgba(0, 0, 0, 0.65));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor: pointer;
}

.discount-modal__box {
  position: relative;
  width: min(420px, 100%);
  max-height: min(90vh, 640px);
  max-height: calc(100dvh - clamp(1.5rem, 5vw, 2.5rem));
  overflow: hidden;
  display: flex;
  flex-direction: column;
  background: color-mix(in srgb, var(--surface-dark, #0a0a0a) 92%, var(--primary, #1a5276) 8%);
  border: 1px solid color-mix(in srgb, var(--primary) 28%, rgba(255, 255, 255, 0.12));
  border-radius: 1.25rem;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.04) inset,
    0 25px 50px -12px rgba(0, 0, 0, 0.55),
    0 0 80px -20px color-mix(in srgb, var(--primary) 45%, transparent);
  opacity: 0;
  transform: scale(0.94) translateY(14px);
  transition:
    transform 0.32s cubic-bezier(0.34, 1.2, 0.64, 1),
    opacity 0.28s ease;
}

.discount-modal.discount-modal--open .discount-modal__box,
.discount-modal[aria-hidden="false"] .discount-modal__box {
  opacity: 1;
  transform: scale(1) translateY(0);
}

.discount-modal__ribbon {
  height: 4px;
  flex-shrink: 0;
  background: linear-gradient(
    90deg,
    var(--primary, #ea4704) 0%,
    var(--accent, #7eb8d9) 45%,
    color-mix(in srgb, var(--success) 70%, var(--primary)) 100%
  );
}

.discount-modal__inner {
  position: relative;
  padding: clamp(1rem, 4vw, 1.5rem) clamp(1rem, 4vw, 1.5rem) clamp(1rem, 3.5vw, 1.35rem);
  display: flex;
  flex-direction: column;
  gap: 0;
  overflow: auto;
  flex: 1;
  min-height: 0;
  scrollbar-gutter: stable;
}

.discount-modal__close {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 2;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: color-mix(in srgb, #fff 6%, transparent);
  color: var(--text-on-dark-muted, rgba(255, 255, 255, 0.82));
  cursor: pointer;
  border-radius: 999px;
  transition: background 0.2s ease, color 0.2s ease, transform 0.15s ease;
}

.discount-modal__close:hover {
  color: var(--text-on-dark-strong, #fff);
  background: color-mix(in srgb, #fff 12%, transparent);
}

.discount-modal__close:focus-visible {
  outline: 2px solid var(--accent, #7eb8d9);
  outline-offset: 2px;
}

.discount-modal__close-lines {
  position: relative;
  display: block;
  width: 1.05rem;
  height: 1.05rem;
}

.discount-modal__close-lines::before,
.discount-modal__close-lines::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 100%;
  height: 2px;
  background: currentColor;
  border-radius: 2px;
}

.discount-modal__close-lines::before {
  transform: translate(-50%, -50%) rotate(45deg);
}

.discount-modal__close-lines::after {
  transform: translate(-50%, -50%) rotate(-45deg);
}

.discount-modal__head {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: clamp(0.85rem, 3vw, 1.25rem);
  padding-right: 3.25rem;
}

.discount-modal__badge {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.65rem;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--accent, #7eb8d9);
  background: color-mix(in srgb, var(--primary) 35%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 35%, transparent);
  border-radius: 999px;
  margin: 0;
}

.discount-modal__title {
  margin: 0;
  font-size: clamp(1.35rem, 4vw, 1.65rem);
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: 0;
  color: var(--text-on-dark-strong, rgba(255, 255, 255, 0.95));
  overflow-wrap: anywhere;
}

.discount-modal__body {
  display: flex;
  flex-direction: column;
  gap: clamp(0.8rem, 3vw, 1rem);
  margin-bottom: clamp(1rem, 3vw, 1.35rem);
  min-height: 0;
}

.discount-modal__offer {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.35rem;
  padding: clamp(0.85rem, 3.5vw, 1.1rem) 1rem clamp(0.9rem, 3.5vw, 1.15rem);
  border-radius: 1rem;
  flex-shrink: 0;
  background: linear-gradient(
    165deg,
    color-mix(in srgb, var(--success) 18%, transparent) 0%,
    color-mix(in srgb, var(--primary) 12%, transparent) 100%
  );
  border: 1px solid color-mix(in srgb, var(--success) 32%, rgba(255, 255, 255, 0.08));
}

.discount-modal__offer-label {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-on-dark-soft, rgba(255, 255, 255, 0.72));
}

.discount-modal__amount {
  margin: 0;
  font-size: clamp(1.75rem, 5.5vw, 2.35rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: 0;
  color: color-mix(in srgb, var(--success-light, var(--success)) 55%, #fff);
  text-shadow: 0 1px 18px color-mix(in srgb, var(--success) 25%, transparent);
  overflow-wrap: anywhere;
}

.discount-modal__text {
  margin: 0;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: var(--text-on-dark-90, rgba(255, 255, 255, 0.9));
  overflow-wrap: anywhere;
}

.discount-modal__text :where(p, ul, ol) {
  margin: 0 0 0.75rem;
}

.discount-modal__text :where(p, ul, ol):last-child {
  margin-bottom: 0;
}

.discount-modal__text a {
  color: var(--accent, #7eb8d9);
  font-weight: 600;
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
}

.discount-modal__text a:hover {
  color: #fff;
}

.discount-modal__actions {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-top: auto;
  padding-top: 0.15rem;
}

.discount-modal__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 3rem;
  padding: 0.65rem 1.25rem;
  font-size: 0.9375rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  white-space: normal;
  overflow-wrap: anywhere;
  border-radius: 0.75rem;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.discount-modal__btn:active {
  transform: scale(0.98);
}

.discount-modal__btn--primary {
  color: #fff;
  background: linear-gradient(180deg, color-mix(in srgb, var(--primary-hover, var(--primary)) 100%, #fff 8%) 0%, var(--primary, #1a5276) 100%);
  border-color: color-mix(in srgb, var(--accent) 40%, var(--primary));
  box-shadow: 0 4px 14px color-mix(in srgb, var(--primary) 35%, transparent);
}

.discount-modal__btn--primary:hover {
  box-shadow: 0 6px 22px color-mix(in srgb, var(--primary) 45%, transparent);
  filter: brightness(1.05);
}

.discount-modal__btn--ghost {
  color: var(--text-on-dark-muted, rgba(255, 255, 255, 0.85));
  background: transparent;
  border-color: color-mix(in srgb, #fff 22%, transparent);
}

.discount-modal__btn--ghost:hover {
  color: var(--text-on-dark-strong, #fff);
  background: color-mix(in srgb, #fff 8%, transparent);
  border-color: color-mix(in srgb, #fff 35%, transparent);
}

@media (min-width: 380px) {
  .discount-modal__actions {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .discount-modal__btn--primary {
    flex: 1 1 58%;
    min-width: 0;
  }

  .discount-modal__btn--ghost {
    flex: 1 1 38%;
    min-width: 0;
  }
}

@media (max-width: 420px), (max-height: 560px) {
  .discount-modal {
    align-items: flex-start;
  }

  .discount-modal__box {
    width: 100%;
    max-height: calc(100vh - 1.5rem);
    max-height: calc(100dvh - 1.5rem);
    border-radius: 1rem;
  }

  .discount-modal__close {
    top: 0.7rem;
    right: 0.7rem;
    width: 2.45rem;
    height: 2.45rem;
  }

  .discount-modal__head {
    padding-right: 2.9rem;
  }
}

/* Light theme */
html[data-theme="light"] .discount-modal__backdrop {
  background: rgba(15, 23, 42, 0.45);
}

html[data-theme="light"] .discount-modal__box {
  background: var(--color-bg-elevated, #ffffff);
  border-color: var(--color-border, #e2e8f0);
  box-shadow:
    0 0 0 1px rgba(15, 23, 42, 0.04) inset,
    var(--shadow-lg, 0 20px 50px rgba(15, 23, 42, 0.12));
}

html[data-theme="light"] .discount-modal__badge {
  color: var(--primary, #1a5276);
  background: color-mix(in srgb, var(--primary) 10%, #fff);
  border-color: color-mix(in srgb, var(--primary) 22%, #cbd5e1);
}

html[data-theme="light"] .discount-modal__title {
  color: var(--color-heading, #0b1220);
}

html[data-theme="light"] .discount-modal__close {
  color: var(--color-text-muted, #64748b);
  background: rgba(15, 23, 42, 0.05);
}

html[data-theme="light"] .discount-modal__close:hover {
  color: var(--color-text, #0f172a);
  background: rgba(15, 23, 42, 0.09);
}

html[data-theme="light"] .discount-modal__offer {
  background: linear-gradient(165deg, color-mix(in srgb, var(--success) 8%, #f8fafc) 0%, color-mix(in srgb, var(--primary) 6%, #f1f5f9) 100%);
  border-color: color-mix(in srgb, var(--success) 25%, #e2e8f0);
}

html[data-theme="light"] .discount-modal__offer-label {
  color: var(--color-text-muted, #64748b);
}

html[data-theme="light"] .discount-modal__amount {
  color: var(--color-heading, #0b1220);
  text-shadow: none;
}

html[data-theme="light"] .discount-modal__text {
  color: var(--color-text, #334155);
}

html[data-theme="light"] .discount-modal__text a {
  color: var(--color-link, #0d5c2e);
}

html[data-theme="light"] .discount-modal__text a:hover {
  color: var(--color-link-hover, #084422);
}

html[data-theme="light"] .discount-modal__btn--primary {
  color: #fff;
  border-color: var(--primary, #1a5276);
}

html[data-theme="light"] .discount-modal__btn--ghost {
  color: var(--color-text, #334155);
  border-color: var(--color-border, #cbd5e1);
}

html[data-theme="light"] .discount-modal__btn--ghost:hover {
  background: var(--color-bg-muted, #f8fafc);
  border-color: #94a3b8;
}
