/* ============================================================
   PRIMEPATH — COOKIE CONSENT BANNER & PREFERENCES MODAL
   cookie-consent.css
   ============================================================
   Matches the dark/gold luxury theme using design tokens.
   ============================================================ */

/* ── BANNER ─────────────────────────────────────────────────── */
.cookie-banner{
  position:fixed;
  bottom:0;left:0;right:0;
  z-index:9999;
  background:var(--ink-1);
  border-top:1px solid var(--gold-line);
  padding:0;
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.4,0,.2,1);
  box-shadow:0 -4px 24px rgba(0,0,0,.35);
}
.cookie-banner.visible{
  transform:translateY(0);
}
.cookie-banner-inner{
  max-width:1200px;
  margin:0 auto;
  display:flex;
  align-items:center;
  gap:24px;
  padding:18px 32px;
}
.cookie-banner-icon{
  flex-shrink:0;
  width:40px;height:40px;
  display:flex;align-items:center;justify-content:center;
  background:var(--gold-dim);
  border-radius:50%;
}
.cookie-banner-icon svg{
  width:20px;height:20px;
  stroke:var(--gold);fill:none;
  stroke-width:1.8;
}
.cookie-banner-text{
  flex:1;
  font-family:'Montserrat',sans-serif;
  font-size:13px;
  color:var(--white-72);
  line-height:1.55;
}
.cookie-banner-text a{
  color:var(--gold);
  text-decoration:underline;
  text-underline-offset:2px;
}
.cookie-banner-text a:hover{
  color:var(--gold-light);
}
.cookie-banner-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}

/* ── BUTTONS ────────────────────────────────────────────────── */
.cookie-btn{
  font-family:'Montserrat',sans-serif;
  font-size:12px;
  font-weight:500;
  letter-spacing:.04em;
  text-transform:uppercase;
  border:none;
  cursor:pointer;
  border-radius:2px;
  padding:10px 20px;
  transition:background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.cookie-btn-accept{
  background:var(--gold);
  color:#1a1a1a;
}
.cookie-btn-accept:hover{
  background:var(--gold-light);
}
.cookie-btn-reject{
  background:transparent;
  color:var(--white-72);
  border:1px solid var(--line);
}
.cookie-btn-reject:hover{
  color:var(--white);
  border-color:var(--white-50);
}
.cookie-btn-prefs{
  background:transparent;
  color:var(--gold);
  border:1px solid var(--gold-line);
}
.cookie-btn-prefs:hover{
  background:var(--gold-dim);
}

/* ── PREFERENCES MODAL (OVERLAY) ────────────────────────────── */
.cookie-modal-overlay{
  position:fixed;
  inset:0;
  z-index:10000;
  background:rgba(0,0,0,.65);
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  visibility:hidden;
  transition:opacity .3s,visibility .3s;
}
.cookie-modal-overlay.visible{
  opacity:1;
  visibility:visible;
}
.cookie-modal{
  background:var(--ink-1);
  border:1px solid var(--gold-line);
  border-radius:4px;
  width:94%;
  max-width:580px;
  max-height:85vh;
  overflow-y:auto;
  transform:translateY(20px) scale(.97);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  box-shadow:0 20px 60px rgba(0,0,0,.5);
}
.cookie-modal-overlay.visible .cookie-modal{
  transform:translateY(0) scale(1);
}

/* Modal header */
.cookie-modal-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:20px 24px 16px;
  border-bottom:1px solid var(--line);
}
.cookie-modal-title{
  font-family:'Cinzel',serif;
  font-size:16px;
  font-weight:500;
  color:var(--white);
  letter-spacing:.03em;
}
.cookie-modal-close{
  background:none;border:none;
  cursor:pointer;
  padding:4px;
  color:var(--white-50);
  transition:color .2s;
}
.cookie-modal-close:hover{color:var(--white)}
.cookie-modal-close svg{
  width:18px;height:18px;
  stroke:currentColor;fill:none;
  stroke-width:2;
}

/* Modal body */
.cookie-modal-body{
  padding:20px 24px;
}
.cookie-modal-intro{
  font-size:12px;
  color:var(--white-50);
  line-height:1.6;
  margin-bottom:20px;
}
.cookie-modal-intro a{
  color:var(--gold);
  text-decoration:underline;
  text-underline-offset:2px;
}

/* ── CATEGORY ROW ───────────────────────────────────────────── */
.cookie-category{
  border:1px solid var(--line);
  border-radius:3px;
  padding:16px 18px;
  margin-bottom:12px;
  background:rgba(255,255,255,.02);
}
.cookie-category:last-child{
  margin-bottom:0;
}
.cookie-category-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
}
.cookie-category-info{
  flex:1;
}
.cookie-category-name{
  font-family:'Montserrat',sans-serif;
  font-size:13px;
  font-weight:600;
  color:var(--white);
  margin-bottom:3px;
  display:flex;align-items:center;gap:8px;
}
.cookie-category-name .badge-required{
  font-size:9px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  background:var(--gold-dim);
  color:var(--gold);
  padding:2px 7px;
  border-radius:2px;
}
.cookie-category-desc{
  font-size:11px;
  color:var(--white-50);
  line-height:1.5;
}

/* ── TOGGLE SWITCH ──────────────────────────────────────────── */
.cookie-toggle{
  position:relative;
  width:44px;
  height:24px;
  flex-shrink:0;
}
.cookie-toggle input{
  opacity:0;
  width:0;height:0;
  position:absolute;
}
.cookie-toggle-track{
  position:absolute;inset:0;
  background:var(--ink-4);
  border-radius:12px;
  cursor:pointer;
  transition:background .25s;
}
.cookie-toggle-track::after{
  content:'';
  position:absolute;
  top:3px;left:3px;
  width:18px;height:18px;
  background:var(--white-50);
  border-radius:50%;
  transition:transform .25s,background .25s;
}
.cookie-toggle input:checked + .cookie-toggle-track{
  background:var(--gold);
}
.cookie-toggle input:checked + .cookie-toggle-track::after{
  transform:translateX(20px);
  background:#1a1a1a;
}
.cookie-toggle input:disabled + .cookie-toggle-track{
  opacity:.6;
  cursor:not-allowed;
}
.cookie-toggle input:focus-visible + .cookie-toggle-track{
  outline:2px solid var(--gold-light);
  outline-offset:2px;
}

/* ── MODAL FOOTER ───────────────────────────────────────────── */
.cookie-modal-footer{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:16px 24px 20px;
  border-top:1px solid var(--line);
}
.cookie-modal-footer .cookie-btn{
  padding:11px 22px;
}

/* ── FOOTER COOKIE LINK ─────────────────────────────────────── */
.footer-cookie-link{
  display:inline-flex;
  align-items:center;
  gap:5px;
  color:var(--white-50);
  font-size:12px;
  text-decoration:none;
  transition:color .2s;
}
.footer-cookie-link:hover{
  color:var(--gold);
}
.footer-cookie-link svg{
  width:14px;height:14px;
  stroke:currentColor;fill:none;
  stroke-width:1.6;
}

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:768px){
  .cookie-banner-inner{
    flex-direction:column;
    text-align:center;
    padding:16px 20px;
    gap:14px;
  }
  .cookie-banner-icon{display:none}
  .cookie-banner-actions{
    flex-wrap:wrap;
    justify-content:center;
  }
  .cookie-modal{
    width:100%;
    max-width:100%;
    max-height:100vh;
    border-radius:0;
    margin:0;
  }
  .cookie-modal-overlay{
    align-items:flex-end;
  }
  .cookie-modal-footer{
    flex-direction:column;
  }
  .cookie-modal-footer .cookie-btn{
    width:100%;
    text-align:center;
  }
}
