/*
  Domaintico Cookie Consent (Add-on)
  - Replaces legacy cookie banner/component
  - Uses the new DM design tokens
*/

.dm-cookie-banner{
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: calc(env(safe-area-inset-bottom, 0px) + 16px);
  /* Keep below modal/backdrop (bootstrapless modal z-index: 2000) */
  z-index: 1985;
}

.dm-cookie-banner__inner{
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 16px;
  border-radius: 18px;
  border: 1px solid var(--dm-border-soft, rgba(2,6,23,.10));
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  box-shadow: var(--dm-shadow-lg, 0 18px 60px rgba(2,6,23,.12));
}

.dm-cookie-banner__text{
  flex: 1 1 320px;
  min-width: 0;
}

.dm-cookie-banner__title{
  font-weight: 950;
  color: var(--dm-text, #0b1220);
  font-size: 14px;
  line-height: 1.1;
}

.dm-cookie-banner__desc{
  margin-top: 6px;
  color: var(--dm-muted, rgba(15,23,42,.70));
  font-size: 13px;
  line-height: 1.45;
}

.dm-cookie-banner__link{
  display: inline-block;
  margin-top: 10px;
  font-size: 13px;
  font-weight: 900;
  color: var(--dm-primary, #2563eb);
  text-decoration: none;
}

.dm-cookie-banner__link:hover{
  text-decoration: underline;
}

.dm-cookie-banner__actions{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 10px;
  min-width: 0;
}

/* Mobile: stack content + make actions fit nicely */
@media (max-width: 520px){
  .dm-cookie-banner{
    left: 12px;
    right: 12px;
  }

  .dm-cookie-banner__inner{
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    gap: 12px;
  }

  /* In column layout, remove the desktop flex-basis (320px) so the banner
     doesn't reserve a tall empty block above the buttons. */
  .dm-cookie-banner__text{
    flex: 0 0 auto;
  }

  .dm-cookie-banner__actions{
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    justify-content: stretch;
    gap: 10px;
  }

  .dm-cookie-banner__actions .btn{
    width: 100%;
  }

  .dm-cookie-banner__actions [data-dm-cookie-action="all"]{
    grid-column: 1 / -1;
  }
}

@media (min-width: 900px){
  .dm-cookie-banner{
    left: auto;
    right: calc(env(safe-area-inset-right, 0px) + 22px);
    bottom: calc(env(safe-area-inset-bottom, 0px) + 22px);
    max-width: 560px;
  }
}

html[dir="rtl"] .dm-cookie-banner{
  left: calc(env(safe-area-inset-left, 0px) + 22px);
  right: auto;
}

/* Modal content */
.dm-cookie-modal .modal-content{
  border-radius: 20px;
  border: 1px solid var(--dm-border-soft, rgba(2,6,23,.10));
  box-shadow: var(--dm-shadow-lg, 0 18px 60px rgba(2,6,23,.12));
}

.dm-cookie-modal .modal-header{
  border-bottom: 1px solid var(--dm-border-soft, rgba(2,6,23,.10));
}

.dm-cookie-modal .modal-footer{
  border-top: 1px solid var(--dm-border-soft, rgba(2,6,23,.10));
}

.dm-cookie-modal__lead{
  margin: 0 0 14px;
  color: var(--dm-muted, rgba(15,23,42,.70));
  font-size: 14px;
  line-height: 1.55;
}

.dm-cookie-options{
  display: grid;
  gap: 10px;
}

.dm-cookie-option{
  display: grid;
  grid-template-columns: 20px 1fr;
  gap: 10px 12px;
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid var(--dm-border-soft, rgba(2,6,23,.10));
  background: rgba(2,6,23,.02);
}

.dm-cookie-option input{
  margin-top: 2px;
}

.dm-cookie-option__label{
  font-weight: 950;
  color: var(--dm-text, #0b1220);
  font-size: 14px;
  line-height: 1.2;
}

.dm-cookie-option__desc{
  grid-column: 2;
  color: var(--dm-muted, rgba(15,23,42,.70));
  font-size: 13px;
  line-height: 1.45;
}

.dm-cookie-modal__policy{
  margin-top: 14px;
}

.dm-cookie-modal__policy a{
  color: var(--dm-primary, #2563eb);
  font-weight: 900;
  text-decoration: none;
}

.dm-cookie-modal__policy a:hover{
  text-decoration: underline;
}
