/* Alessandro CMP – Frontend Styles */
:root {
  --acmp-accent: #2563eb;
  --acmp-bg: #fff;
  --acmp-text: #111827;
  --acmp-muted: #6b7280;
  --acmp-border: #e5e7eb;
  --acmp-shadow: 0 20px 60px rgba(0,0,0,.18);
  --acmp-radius: 16px;
  --acmp-transition: .22s cubic-bezier(.4,0,.2,1);
}

/* Dark theme */
[data-acmp-theme="dark"] {
  --acmp-bg: #1f2937;
  --acmp-text: #f9fafb;
  --acmp-muted: #9ca3af;
  --acmp-border: #374151;
}

/* ── Banner ──────────────────────────────────────────────────── */
.acmp-banner {
  position: fixed;
  z-index: 999999;
  left: 0; right: 0; bottom: 0;
  display: flex;
  justify-content: center;
  padding: 12px 16px 20px;
  background: linear-gradient(to top, rgba(0,0,0,.07), transparent);
}
.acmp-banner[data-pos="top"]          { bottom: auto; top: 0; }
.acmp-banner[data-pos="bottom-left"]  { right: auto; max-width: 420px; }
.acmp-banner[data-pos="bottom-right"] { left: auto;  max-width: 420px; }

.acmp-banner__inner {
  background: var(--acmp-bg);
  color: var(--acmp-text);
  border-radius: var(--acmp-radius);
  box-shadow: var(--acmp-shadow);
  padding: 28px 32px 24px;
  max-width: 780px;
  width: 100%;
  border: 1px solid var(--acmp-border);
}

.acmp-banner__header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
#acmp-banner-logo img {
  height: 36px;
  width: auto;
  object-fit: contain;
}
.acmp-banner__title {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 0;
  line-height: 1.3;
  color: var(--acmp-text);
}
.acmp-banner__description {
  font-size: .93rem;
  color: var(--acmp-muted);
  margin: 0 0 18px;
  line-height: 1.6;
}

/* ── Buttons ─────────────────────────────────────────────────── */
.acmp-banner__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 14px;
}
.acmp-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 20px;
  border-radius: 8px;
  font-size: .9rem;
  font-weight: 600;
  cursor: pointer;
  border: 2px solid transparent;
  transition: var(--acmp-transition);
  white-space: nowrap;
}
.acmp-btn--primary {
  background: var(--acmp-accent);
  color: #fff;
  border-color: var(--acmp-accent);
}
.acmp-btn--primary:hover {
  filter: brightness(1.12);
}
.acmp-btn--outline {
  background: transparent;
  color: var(--acmp-accent);
  border-color: var(--acmp-accent);
}
.acmp-btn--outline:hover {
  background: var(--acmp-accent);
  color: #fff;
}
.acmp-btn--ghost {
  background: transparent;
  color: var(--acmp-muted);
  border-color: var(--acmp-border);
}
.acmp-btn--ghost:hover {
  border-color: var(--acmp-accent);
  color: var(--acmp-accent);
}

/* ── Footer ──────────────────────────────────────────────────── */
.acmp-banner__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: .78rem;
  color: var(--acmp-muted);
}
.acmp-banner__footer a {
  color: var(--acmp-accent);
  text-decoration: none;
}
.acmp-banner__footer a:hover { text-decoration: underline; }
.acmp-banner__powered strong { color: var(--acmp-text); }

/* ── Preferences panel ───────────────────────────────────────── */
.acmp-preferences {
  background: var(--acmp-border);
  border-radius: 10px;
  padding: 16px;
  margin-bottom: 18px;
}
.acmp-categories { display: flex; flex-direction: column; gap: 12px; }
.acmp-cat {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: var(--acmp-bg);
  border-radius: 8px;
  padding: 12px 14px;
}
.acmp-cat__toggle {
  position: relative;
  flex-shrink: 0;
  width: 42px;
  height: 24px;
}
.acmp-cat__toggle input { opacity: 0; width: 0; height: 0; }
.acmp-cat__slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background: #d1d5db;
  border-radius: 24px;
  transition: var(--acmp-transition);
}
.acmp-cat__slider:before {
  content: '';
  position: absolute;
  height: 18px; width: 18px;
  left: 3px; bottom: 3px;
  background: #fff;
  border-radius: 50%;
  transition: var(--acmp-transition);
}
.acmp-cat__toggle input:checked + .acmp-cat__slider { background: var(--acmp-accent); }
.acmp-cat__toggle input:checked + .acmp-cat__slider:before { transform: translateX(18px); }
.acmp-cat__toggle input:disabled + .acmp-cat__slider { opacity: .6; cursor: not-allowed; }

.acmp-cat__info { flex: 1; min-width: 0; }
.acmp-cat__label {
  font-size: .9rem;
  font-weight: 600;
  color: var(--acmp-text);
  display: flex;
  align-items: center;
  gap: 6px;
}
.acmp-cat__locked {
  font-size: .7rem;
  background: #f3f4f6;
  color: var(--acmp-muted);
  padding: 1px 6px;
  border-radius: 4px;
}
.acmp-cat__desc {
  font-size: .82rem;
  color: var(--acmp-muted);
  margin-top: 2px;
}

/* ── Re-open button ──────────────────────────────────────────── */
.acmp-reopen {
  position: fixed;
  bottom: 20px; left: 20px;
  z-index: 999998;
  background: var(--acmp-accent);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 46px; height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 18px rgba(0,0,0,.2);
  transition: var(--acmp-transition);
}
.acmp-reopen:hover { filter: brightness(1.15); transform: scale(1.07); }
.acmp-reopen svg { width: 22px; height: 22px; }

/* ── Utilities ───────────────────────────────────────────────── */
.acmp-hidden { display: none !important; }

/* Animate in */
@keyframes acmpSlideUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
.acmp-banner:not(.acmp-hidden) { animation: acmpSlideUp .32s var(--acmp-transition) both; }

/* Responsive */
@media (max-width: 600px) {
  .acmp-banner__inner { padding: 20px 18px 18px; }
  .acmp-banner__actions { flex-direction: column; }
  .acmp-btn { width: 100%; }
}
