/* TOGOPEPTIDE — Compliance UI · Layer 7
   Age-verification modal (21+) + TCF v2.2 cookie banner + research-use sticky.
   Loaded sitewide. Self-contained — no token dependencies (defensive). */

/* ── 21+ Age-verification modal (full overlay, blocks interaction) ── */
.age-gate{
  position:fixed;inset:0;z-index:1000;background:rgba(5,5,8,0.92);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  animation:age-fade-in 280ms cubic-bezier(0.22,1,0.36,1);
}
.age-gate[hidden]{display:none}
.age-gate__panel{
  background:#0b0b0d;border:1px solid rgba(255,255,255,0.1);border-radius:18px;
  max-width:520px;width:100%;padding:36px 32px;
  box-shadow:0 32px 80px -16px rgba(0,0,0,0.6);
  animation:age-pop-in 380ms cubic-bezier(0.34,1.56,0.64,1);
}
.age-gate__logo{width:48px;height:48px;margin:0 auto 18px;display:block}
.age-gate__eyebrow{
  font-size:11px;text-transform:uppercase;letter-spacing:0.14em;
  color:#e01b1b;text-align:center;margin:0 0 10px;font-weight:700;
}
.age-gate__title{
  font-size:24px;font-weight:700;color:#fff;text-align:center;margin:0 0 12px;
  line-height:1.2;
}
.age-gate__body{
  font-size:14.5px;color:#b8b8c0;text-align:center;line-height:1.55;
  margin:0 0 24px;
}
.age-gate__body strong{color:#fff}
.age-gate__actions{display:flex;flex-direction:column;gap:10px}
.age-gate__btn{
  display:block;width:100%;padding:14px 20px;font-size:15px;font-weight:600;
  border-radius:10px;cursor:pointer;border:1px solid transparent;
  transition:all 180ms cubic-bezier(0.22,1,0.36,1);
  font-family:inherit;text-align:center;
}
.age-gate__btn--primary{
  background:#e01b1b;color:#fff;border-color:#e01b1b;
}
.age-gate__btn--primary:hover{background:#ff3030;transform:translateY(-1px)}
.age-gate__btn--secondary{
  background:transparent;color:#a0a0a0;border-color:rgba(255,255,255,0.12);
}
.age-gate__btn--secondary:hover{
  border-color:rgba(255,255,255,0.25);color:#fff;
}
.age-gate__legal{
  font-size:11px;color:#6a6a72;text-align:center;line-height:1.5;
  margin:18px 0 0;
}
.age-gate__legal a{color:#a0a0a0;text-decoration:underline}
.age-gate__legal a:hover{color:#fff}

@keyframes age-fade-in{from{opacity:0}to{opacity:1}}
@keyframes age-pop-in{
  from{opacity:0;transform:translateY(20px) scale(0.94)}
  to  {opacity:1;transform:translateY(0)    scale(1)}
}

/* Body lock when age-gate is open */
body.age-gate-active{overflow:hidden}

/* ── Cookie banner (TCF v2.2 style — accept/reject/customize) ── */
.cookie-banner{
  /* z-index: was 120 (magic) → --z-cookie (800). Cookie banner moet
     boven FABs/install-prompt/toast, onder skiplink. */
  position:fixed;left:16px;right:16px;bottom:16px;z-index:var(--z-cookie, 800);
  background:rgba(11,11,13,0.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.12);border-radius:14px;
  box-shadow:0 16px 48px -8px rgba(0,0,0,0.5);
  padding:18px 20px;max-width:680px;margin-left:auto;margin-right:auto;
  max-height:calc(100vh - 32px);overflow-y:auto;
  transform:translateY(140%);transition:transform 380ms cubic-bezier(0.22,1,0.36,1);
  pointer-events:auto;
}
/* Make sure buttons inside the banner accept clicks even with stacking context */
.cookie-banner *{pointer-events:auto}
.cookie-banner.is-visible{transform:translateY(0)}
.cookie-banner[hidden]{display:none}
.cookie-banner__title{
  margin:0 0 8px;font-size:14px;font-weight:700;color:#fff;
  display:flex;align-items:center;gap:8px;
}
.cookie-banner__title::before{
  content:"";display:inline-block;width:6px;height:6px;background:#e01b1b;border-radius:50%;
}
.cookie-banner__body{
  margin:0 0 14px;font-size:13px;color:#b8b8c0;line-height:1.55;
}
.cookie-banner__body a{color:#fff;text-decoration:underline}
.cookie-banner__actions{display:flex;gap:8px;flex-wrap:wrap}
.cookie-banner__btn{
  flex:1;min-width:130px;padding:10px 14px;font-size:13px;font-weight:600;
  border-radius:8px;cursor:pointer;border:1px solid transparent;
  transition:all 160ms cubic-bezier(0.22,1,0.36,1);font-family:inherit;
}
.cookie-banner__btn--accept{background:#e01b1b;color:#fff;border-color:#e01b1b}
.cookie-banner__btn--accept:hover{background:#ff3030}
.cookie-banner__btn--reject{
  background:transparent;color:#fff;border-color:rgba(255,255,255,0.18);
}
.cookie-banner__btn--reject:hover{border-color:rgba(255,255,255,0.32)}
.cookie-banner__btn--customize{
  background:transparent;color:#a0a0a0;border-color:rgba(255,255,255,0.12);
}
.cookie-banner__btn--customize:hover{color:#fff;border-color:rgba(255,255,255,0.22)}

/* Cookie customize panel (expanded) */
.cookie-banner__details{
  margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.08);
  display:none;
}
.cookie-banner.is-expanded .cookie-banner__details{display:block}
.cookie-banner__category{
  display:flex;justify-content:space-between;align-items:flex-start;
  padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.04);gap:14px;
}
.cookie-banner__category:last-child{border-bottom:0}
.cookie-banner__category-info{flex:1}
.cookie-banner__category-name{
  margin:0 0 4px;font-size:13px;font-weight:600;color:#fff;
}
.cookie-banner__category-desc{
  margin:0;font-size:12px;color:#8a8a92;line-height:1.4;
}
/* Toggle switch */
.cookie-toggle{
  position:relative;width:38px;height:22px;flex-shrink:0;cursor:pointer;
}
.cookie-toggle input{opacity:0;width:0;height:0;position:absolute}
.cookie-toggle__slider{
  position:absolute;inset:0;background:rgba(255,255,255,0.1);
  border-radius:22px;transition:background 180ms ease;
}
.cookie-toggle__slider::before{
  content:"";position:absolute;left:3px;top:3px;width:16px;height:16px;
  background:#fff;border-radius:50%;transition:transform 180ms cubic-bezier(0.22,1,0.36,1);
}
.cookie-toggle input:checked + .cookie-toggle__slider{background:#e01b1b}
.cookie-toggle input:checked + .cookie-toggle__slider::before{transform:translateX(16px)}
.cookie-toggle input:disabled + .cookie-toggle__slider{
  background:rgba(255,255,255,0.05);cursor:not-allowed;
}
.cookie-toggle input:disabled + .cookie-toggle__slider::before{
  background:#666;
}

@media (max-width:480px){
  .cookie-banner{left:8px;right:8px;bottom:8px;padding:14px 16px}
  .cookie-banner__btn{flex:1 1 100%;min-width:auto}
}

/* ── Research-use sticky banner (compliance reminder) ──────── */
.research-banner{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(224,27,27,0.05);backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(224,27,27,0.18);
  padding:8px 16px;font-size:12px;color:#ddd;text-align:center;
  display:flex;align-items:center;justify-content:center;gap:10px;
  transform:translateY(-100%);transition:transform 280ms cubic-bezier(0.22,1,0.36,1);
}
.research-banner.is-visible{transform:translateY(0)}
.research-banner[hidden]{display:none}
.research-banner strong{color:#fff;font-weight:600}
.research-banner__close{
  background:transparent;border:0;color:#999;cursor:pointer;font-size:14px;
  padding:0 6px;line-height:1;
}
.research-banner__close:hover{color:#fff}
body.research-banner-active{padding-top:34px}
@media (max-width:640px){.research-banner{font-size:11px;padding:6px 14px}}
