/* Tavolo News — Cookie-Banner-Styles (Theme-konform, gleiche Optik wie tavolo.me). */

@keyframes tavolo-cookie-fade-in { from { opacity: 0 } to { opacity: 1 } }
@keyframes tavolo-cookie-slide-up { from { opacity: 0; transform: translateY(12px) } to { opacity: 1; transform: translateY(0) } }

.tavolo-cookie-backdrop {
  position: fixed; inset: 0; z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  background-color: rgba(26,29,31,0.55);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  animation: tavolo-cookie-fade-in 200ms ease-out;
}
.tavolo-cookie-modal {
  width: 100%; max-width: 520px; max-height: calc(100vh - 32px);
  overflow: auto;
  background-color: #fff;
  border: 1px solid var(--border);
  box-shadow: 0 32px 80px -16px rgba(26,29,31,0.32);
  animation: tavolo-cookie-slide-up 280ms cubic-bezier(0.2, 0.8, 0.2, 1);
}
.tavolo-cookie-pad-h { padding: 28px 32px 0; }
.tavolo-cookie-pad-b { padding: 24px 32px; }
.tavolo-cookie-pad-f { padding: 0 32px 28px; display: flex; flex-direction: column; gap: 10px; }
@media (max-width: 480px) {
  .tavolo-cookie-backdrop { padding: 8px; align-items: flex-end; }
  .tavolo-cookie-modal { max-height: calc(100vh - 16px); }
  .tavolo-cookie-pad-h { padding: 20px 20px 0; }
  .tavolo-cookie-pad-b { padding: 16px 20px; }
  .tavolo-cookie-pad-f { padding: 0 20px 20px; }
}

.tavolo-cookie-icon {
  width: 40px; height: 40px;
  background-color: var(--soft);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
  color: var(--terracotta);
}
.tavolo-cookie-modal h2 {
  font-family: var(--serif);
  font-size: 1.5rem; font-weight: 700; letter-spacing: -0.01em;
  margin: 0 0 6px; color: var(--charcoal);
}
.tavolo-cookie-modal p {
  font-size: 0.875rem; color: var(--slate); line-height: 1.6; margin: 0;
}
.tavolo-cookie-close {
  background: none; border: none; cursor: pointer;
  padding: 4px; color: var(--slate); flex-shrink: 0;
}

.tavolo-cookie-item {
  display: flex; align-items: flex-start; gap: 12px; padding: 10px 0;
}
.tavolo-cookie-item-bullet {
  width: 6px; height: 6px; border-radius: 50%;
  background-color: var(--terracotta);
  margin-top: 8px; flex-shrink: 0;
}
.tavolo-cookie-item-label {
  font-size: 0.875rem !important; font-weight: 600;
  color: var(--charcoal) !important; margin: 0 !important;
}
.tavolo-cookie-item-desc {
  font-size: 0.8125rem !important; color: var(--slate) !important;
  margin: 2px 0 0 !important; line-height: 1.5 !important;
}

.tavolo-cookie-cat {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 14px 0; border-bottom: 1px solid var(--border);
}
.tavolo-cookie-cat-label {
  font-size: 0.875rem !important; font-weight: 600;
  color: var(--charcoal) !important; margin: 0 !important;
}
.tavolo-cookie-cat-desc {
  font-size: 0.8125rem !important; color: var(--slate) !important;
  margin: 2px 0 0 !important; line-height: 1.5 !important;
}
.tavolo-cookie-switch {
  width: 38px; height: 22px; border-radius: 11px;
  background-color: var(--border);
  position: relative; flex-shrink: 0; cursor: pointer;
  transition: background-color 150ms;
}
.tavolo-cookie-switch.is-on { background-color: var(--terracotta); }
.tavolo-cookie-switch.is-disabled { opacity: 0.7; cursor: not-allowed; }
.tavolo-cookie-switch-knob {
  position: absolute; top: 3px; left: 3px;
  width: 16px; height: 16px; border-radius: 50%;
  background-color: #fff;
  transition: left 150ms;
}
.tavolo-cookie-switch.is-on .tavolo-cookie-switch-knob { left: 19px; }

.tavolo-cookie-legal {
  font-size: 0.75rem !important; color: var(--slate) !important;
  line-height: 1.6 !important; margin-top: 20px !important;
}
.tavolo-cookie-legal a { color: var(--terracotta); text-decoration: none; }

.tavolo-cookie-cta-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
@media (max-width: 380px) { .tavolo-cookie-cta-row { grid-template-columns: 1fr; } }

.tavolo-cookie-btn {
  width: 100%; padding: 11px 16px;
  font-family: inherit; font-size: 0.875rem; font-weight: 500;
  border: 1px solid var(--charcoal);
  cursor: pointer; border-radius: 0;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  transition: background-color 120ms, color 120ms;
}
.tavolo-cookie-btn-primary {
  background-color: var(--charcoal); color: var(--offwhite);
}
.tavolo-cookie-btn-primary:hover { background-color: var(--terracotta); border-color: var(--terracotta); }
.tavolo-cookie-btn-secondary {
  background-color: transparent; color: var(--charcoal);
}
.tavolo-cookie-btn-secondary:hover { background-color: var(--soft); }

.tavolo-cookie-link {
  background: none; border: none; cursor: pointer;
  color: var(--slate); font-size: 0.8125rem; text-decoration: underline;
  padding: 8px 0; font-family: inherit;
}
