/* CantikSalud Legal & Cookies — frontend */
:root{ --cantik-cc-accent:#A9165E; }

/* El atributo [hidden] debe ganar sobre los display:flex de los modales.
   Sin esto, display:flex anula el comportamiento nativo de [hidden]. */
.cantik-legal-modal[hidden],
.cantik-cc-prefs[hidden],
.cantik-cc-banner[hidden]{display:none !important;}

.cantik-cc-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:99990}

/* BANNER */
.cantik-cc-banner{position:fixed;z-index:99992;background:#fff;color:#1a1216;
  box-shadow:0 -4px 24px rgba(0,0,0,.16);border-top:3px solid var(--cantik-cc-accent);
  padding:18px 22px;display:flex;gap:18px;align-items:center;justify-content:space-between;
  flex-wrap:wrap;font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif}
.cantik-cc-pos-bottom{left:0;right:0;bottom:0}
.cantik-cc-pos-bottom-left{left:20px;bottom:20px;max-width:420px;border-radius:14px;border-top:none;border-left:3px solid var(--cantik-cc-accent)}
.cantik-cc-pos-bottom-right{right:20px;bottom:20px;max-width:420px;border-radius:14px;border-top:none;border-left:3px solid var(--cantik-cc-accent)}
/* Caja estrecha centrada en pantalla (con velo detrás). */
.cantik-cc-pos-center{left:50%;top:50%;transform:translate(-50%,-50%);
  max-width:440px;width:calc(100% - 40px);border-radius:16px;border-top:none;
  border-top:4px solid var(--cantik-cc-accent);flex-direction:column;align-items:stretch;
  text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.cantik-cc-pos-center .cantik-cc-banner-actions{justify-content:center}
/* Velo de fondo cuando el banner está centrado (se inyecta siempre que se
   usa la posición center, no solo en modo bloqueo). */
.cantik-cc-center-veil{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99991}
.cantik-cc-banner-body{flex:1;min-width:240px}
.cantik-cc-banner-body h3{margin:0 0 6px;font-size:1.05rem}
.cantik-cc-banner-body p{margin:0;font-size:.9rem;color:#555;line-height:1.5}
.cantik-cc-banner-actions{display:flex;gap:10px;flex-wrap:wrap}

.cantik-cc-btn{cursor:pointer;border:1px solid #ddd !important;background:#f6f6f7 !important;color:#333 !important;
  padding:10px 18px;border-radius:8px;font-size:.88rem;font-weight:600;transition:filter .15s,background .15s;
  text-decoration:none !important;box-shadow:none !important;line-height:1.2}
.cantik-cc-btn:hover{background:#ececee !important;color:#333 !important;filter:none}
.cantik-cc-accent{background:var(--cantik-cc-accent) !important;border-color:var(--cantik-cc-accent) !important;color:#fff !important}
.cantik-cc-accent:hover{background:var(--cantik-cc-accent) !important;color:#fff !important;filter:brightness(1.08)}
.cantik-cc-config{background:#fff !important}
.cantik-cc-config:hover{background:#f6f6f7 !important;color:#333 !important}

/* PANEL PREFERENCIAS */
.cantik-cc-prefs{position:fixed;inset:0;z-index:99995;display:flex;align-items:center;
  justify-content:center;background:rgba(0,0,0,.5);padding:20px;font-family:system-ui,sans-serif}
.cantik-cc-prefs-inner{background:#fff;max-width:520px;width:100%;border-radius:16px;
  max-height:85vh;display:flex;flex-direction:column;overflow:hidden}
.cantik-cc-prefs-head{display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;border-bottom:1px solid #eee}
.cantik-cc-prefs-head h3{margin:0;font-size:1.15rem}
.cantik-cc-x,.cantik-legal-x{background:transparent !important;border:none !important;
  font-size:1.8rem;line-height:1;cursor:pointer;color:#888 !important;
  box-shadow:none !important;padding:4px 10px;border-radius:8px;text-decoration:none !important;
  transition:background .15s,color .15s}
.cantik-cc-x:hover,.cantik-legal-x:hover{background:#f0f0f0 !important;color:#333 !important}
.cantik-cc-x:focus,.cantik-legal-x:focus{outline:none;box-shadow:0 0 0 2px rgba(0,0,0,.1) !important}
.cantik-cc-prefs-body{padding:8px 22px;overflow-y:auto}
.cantik-cc-cat{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 0;border-bottom:1px solid #f0f0f0}
.cantik-cc-cat-txt strong{display:block;font-size:.95rem}
.cantik-cc-cat-txt small{color:#777;font-size:.8rem;line-height:1.4}
.cantik-cc-toggle{width:20px;height:20px;accent-color:var(--cantik-cc-accent);cursor:pointer}
.cantik-cc-toggle:disabled{opacity:.5;cursor:not-allowed}
.cantik-cc-prefs-actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 22px;
  border-top:1px solid #eee}

/* FAB */
.cantik-cc-fab{position:fixed;z-index:99997;width:46px;height:46px;border-radius:50%;
  border:none;cursor:pointer;background:var(--cantik-cc-accent) !important;color:#fff !important;
  box-shadow:0 4px 14px rgba(0,0,0,.2);display:flex;align-items:center;justify-content:center;padding:0}
.cantik-cc-fab svg{fill:#fff !important;width:22px;height:22px;display:block}
.cantik-cc-fab:hover{filter:brightness(1.08)}
.cantik-cc-fab-bottom-left{left:18px;bottom:18px}
.cantik-cc-fab-bottom-right{right:18px;bottom:18px}

/* MODAL LEGAL */
.cantik-legal-modal{position:fixed;inset:0;z-index:99996;display:flex;align-items:center;
  justify-content:center;padding:20px;font-family:system-ui,sans-serif}
.cantik-legal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.cantik-legal-dialog{position:relative;background:#fff;max-width:760px;width:100%;
  border-radius:16px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden}
.cantik-legal-head{display:flex;align-items:center;justify-content:space-between;
  border-bottom:1px solid #eee;padding:10px 16px;gap:12px}
.cantik-legal-tabs{display:flex;gap:4px;overflow-x:auto}
.cantik-legal-tab{background:transparent !important;border:none !important;cursor:pointer;
  padding:10px 14px;font-size:.85rem;font-weight:600;color:#777 !important;border-radius:8px;
  white-space:nowrap;box-shadow:none !important;text-decoration:none !important;transition:background .15s,color .15s}
.cantik-legal-tab:hover{background:#f3f3f3 !important;color:#444 !important}
.cantik-legal-tab.is-active{color:var(--cantik-cc-accent) !important;background:rgba(169,22,94,.10) !important}
.cantik-legal-tab.is-active:hover{background:rgba(169,22,94,.16) !important}
.cantik-legal-tab:focus{outline:none;box-shadow:0 0 0 2px rgba(169,22,94,.2) !important}
.cantik-legal-body{padding:24px 28px;overflow-y:auto;line-height:1.6;color:#333}
.cantik-legal-body h2{margin-top:0}
.cantik-legal-body h3{color:var(--cantik-cc-accent);font-size:1.05rem;margin:18px 0 6px}
.cantik-legal-panel{display:none}
.cantik-legal-panel.is-active{display:block}

@media(max-width:560px){
  .cantik-cc-banner{flex-direction:column;align-items:stretch}
  .cantik-cc-banner-actions{justify-content:stretch}
  .cantik-cc-banner-actions .cantik-cc-btn{flex:1}
}

/* BARRA LEGAL EN FOOTER */
.cantik-legal-bar{background:#f4f1f3;border-top:1px solid #e6dde2;
  font-family:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;font-size:.82rem;padding:12px 16px}
.cantik-legal-bar-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;
  justify-content:space-between;gap:12px;flex-wrap:wrap}
.cantik-legal-bar-text{color:#888}
.cantik-legal-bar-links{display:flex;gap:6px 18px;flex-wrap:wrap}
.cantik-legal-bar-links a{color:#666 !important;text-decoration:none !important;border-bottom:1px dotted transparent;box-shadow:none !important;background:transparent !important}
.cantik-legal-bar-links a:hover{color:var(--cantik-cc-accent) !important;border-bottom-color:var(--cantik-cc-accent)}
@media(max-width:560px){
  .cantik-legal-bar-inner{justify-content:center;text-align:center}
}
