/* ==========================================================================
   Anonimark · Consentimiento de cookies
   Componente aislado (prefijo cc-). Usa los tokens de styles.css.
   No redefine :root ni body. Se puede plegar dentro de styles.css tal cual.
   ========================================================================== */

/* ---------- Botones del componente (aislados de .btn del sitio) ---------- */
.cc-btn{
  font-family:var(--font-sans); font-size:14px; font-weight:600; cursor:pointer;
  padding:11px 18px; border-radius:9px; border:1px solid transparent; line-height:1;
  transition:transform .12s ease, background .15s ease, border-color .15s ease;
}
.cc-btn:active{transform:translateY(1px);}
.cc-btn-primary{background:var(--ink-900); color:#fff;}
.cc-btn-primary:hover{background:var(--ink-700);}
.cc-btn-ghost{background:transparent; color:var(--ink-900); border-color:var(--ink-100);}
.cc-btn-ghost:hover{border-color:var(--ink-300); background:var(--paper);}

/* ---------- Banner ---------- */
.cc-banner{
  position:fixed; left:0; right:0; bottom:0; z-index:800;
  display:flex; justify-content:center; padding:18px;
  transform:translateY(120%); transition:transform .42s cubic-bezier(.16,1,.3,1);
}
.cc-banner.is-open{transform:translateY(0);}
.cc-slip{
  width:min(760px,100%); background:var(--paper);
  border:1px solid var(--ink-100); border-top:3px solid var(--coral-500);
  border-radius:14px; box-shadow:var(--shadow-xl); overflow:hidden;
}
.cc-slip-body{padding:22px 24px 20px;}
.cc-ref{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-mono); font-size:10.5px; font-weight:600; letter-spacing:.09em;
  color:var(--ink-500); text-transform:uppercase; margin-bottom:12px;
}
.cc-ref .m{width:5px; height:5px; background:var(--coral-500); display:inline-block;}
.cc-title{font-family:var(--font-sans); font-size:19px; font-weight:600; letter-spacing:-.01em; margin:0 0 8px; color:var(--ink-900);}
.cc-text{font-size:14px; line-height:1.62; color:var(--ink-700); margin:0 0 4px; max-width:62ch;}
.cc-text a{color:var(--coral-600); text-decoration:none; border-bottom:1px solid var(--coral-100);}
.cc-text a:hover{border-color:var(--coral-500);}
.cc-actions{
  display:flex; gap:10px; align-items:center; flex-wrap:wrap;
  padding:16px 24px; border-top:1px solid var(--ink-100); background:var(--paper-dossier);
}
.cc-actions .cc-spacer{flex:1 1 auto;}
/* Rechazar y Aceptar comparten peso visual (exigencia AEPD) */
.cc-actions .cc-btn-primary,.cc-actions .cc-btn-ghost{min-width:132px; justify-content:center;}
.cc-config{
  font-family:var(--font-mono); font-size:12px; font-weight:600; color:var(--ink-500);
  background:none; border:0; cursor:pointer; padding:8px 4px; letter-spacing:.02em;
  text-decoration:underline; text-underline-offset:3px;
}
.cc-config:hover{color:var(--ink-900);}

/* ---------- Scrim + panel de preferencias ---------- */
.cc-scrim{
  position:fixed; inset:0; z-index:900; background:rgba(0,12,50,.42);
  opacity:0; visibility:hidden; transition:opacity .3s ease, visibility .3s ease;
}
.cc-scrim.is-open{opacity:1; visibility:visible;}
.cc-panel{
  position:fixed; top:0; right:0; bottom:0; z-index:950; width:min(440px,100%);
  background:var(--paper); box-shadow:var(--shadow-xl);
  transform:translateX(100%); transition:transform .42s cubic-bezier(.16,1,.3,1);
  display:flex; flex-direction:column;
}
.cc-panel.is-open{transform:translateX(0);}
.cc-panel-head{
  padding:22px 24px 16px; border-bottom:1px solid var(--ink-100);
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
}
.cc-panel-head .cc-ref{margin-bottom:8px;}
.cc-panel-head h2{font-family:var(--font-sans); font-size:20px; font-weight:600; letter-spacing:-.01em; margin:0; color:var(--ink-900);}
.cc-x{
  background:none; border:1px solid var(--ink-100); border-radius:8px; width:34px; height:34px;
  cursor:pointer; color:var(--ink-500); font-size:18px; line-height:1; flex-shrink:0;
}
.cc-x:hover{border-color:var(--ink-300); color:var(--ink-900);}
.cc-panel-body{padding:8px 24px; overflow-y:auto; flex:1;}

.cc-cat{padding:18px 0; border-bottom:1px dashed var(--ink-100);}
.cc-cat-top{display:flex; align-items:center; justify-content:space-between; gap:14px;}
.cc-cat-name{display:flex; align-items:center; gap:9px; font-size:15px; font-weight:600; color:var(--ink-900);}
.cc-cat-name .m{width:5px; height:5px; background:var(--coral-500); display:inline-block; flex-shrink:0;}
.cc-cat-desc{font-size:13px; line-height:1.55; color:var(--ink-500); margin:9px 0 0; max-width:46ch;}
.cc-cat-tag{font-family:var(--font-mono); font-size:10px; font-weight:600; letter-spacing:.06em; text-transform:uppercase; padding:3px 8px; border-radius:5px;}
.cc-cat-tag.locked{color:var(--success-700); background:var(--success-050);}

/* Toggle */
.cc-tgl{position:relative; width:44px; height:26px; flex-shrink:0;}
.cc-tgl input{position:absolute; opacity:0; width:100%; height:100%; margin:0; cursor:pointer;}
.cc-tgl-track{position:absolute; inset:0; background:var(--ink-100); border-radius:20px; transition:background .2s ease;}
.cc-tgl-thumb{
  position:absolute; top:3px; left:3px; width:20px; height:20px; background:#fff; border-radius:50%;
  box-shadow:var(--shadow-md); transition:transform .22s cubic-bezier(.16,1,.3,1);
}
.cc-tgl input:checked ~ .cc-tgl-track{background:var(--success);}
.cc-tgl input:checked ~ .cc-tgl-thumb{transform:translateX(18px);}
.cc-tgl input:focus-visible ~ .cc-tgl-track{outline:2px solid var(--coral-500); outline-offset:2px;}

.cc-panel-foot{
  padding:16px 24px; border-top:1px solid var(--ink-100); background:var(--paper-dossier);
  display:flex; gap:10px; flex-wrap:wrap;
}
.cc-panel-foot .cc-btn{flex:1 1 auto; min-width:120px; justify-content:center;}

@media (max-width:560px){
  .cc-actions{flex-direction:column; align-items:stretch;}
  .cc-actions .cc-spacer{display:none;}
  .cc-actions .cc-btn-primary,.cc-actions .cc-btn-ghost{min-width:0; width:100%;}
  .cc-config{text-align:center;}
}
@media (prefers-reduced-motion:reduce){
  .cc-banner,.cc-scrim,.cc-panel,.cc-tgl-track,.cc-tgl-thumb,.cc-btn{transition:none !important;}
}
