/* ===========================================================
   ShiftPress — Cookie consent banner
   Self-contained styles (uses site design tokens when present,
   with literal fallbacks so it also works in isolation).
   =========================================================== */

.sp-cc,
.sp-cc *{box-sizing:border-box}

/* hidden until the script decides to show it (avoids flash) */
.sp-cc[hidden]{display:none !important}

/* ---- bottom banner ---- */
.sp-cc-banner{
  position:fixed;
  left:0;right:0;bottom:0;
  z-index:10000;
  display:flex;
  align-items:center;
  gap:22px;
  flex-wrap:wrap;
  padding:20px 28px;
  background:var(--cream,#FBF9F2);
  border-top:1px solid var(--line-strong,rgba(30,64,52,.28));
  box-shadow:0 -2px 4px rgba(21,33,27,.06), 0 -22px 50px -28px rgba(21,33,27,.30);
  font-family:var(--sans,"Hanken Grotesk",system-ui,sans-serif);
  color:var(--ink,#15211B);
  animation:sp-cc-rise .4s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes sp-cc-rise{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
@media (prefers-reduced-motion:reduce){.sp-cc-banner{animation:none}}

.sp-cc-banner .sp-cc-copy{flex:1 1 360px;min-width:260px}
.sp-cc-banner h2{
  font-family:var(--serif,"Fraunces",Georgia,serif);
  font-weight:600;font-size:1.12rem;line-height:1.15;
  letter-spacing:-.02em;color:var(--ink,#15211B);margin:0 0 .35em;
}
.sp-cc-banner p{font-size:.92rem;line-height:1.55;color:var(--ink-soft,#3C4B43);margin:0}
.sp-cc-banner p a{color:var(--moss,#2E5E4E);text-decoration:underline;text-underline-offset:2px}

.sp-cc-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* ---- buttons (accept & reject share equal visual weight) ---- */
.sp-cc-btn{
  font-family:var(--sans,"Hanken Grotesk",system-ui,sans-serif);
  font-weight:600;font-size:.95rem;
  border-radius:100px;
  padding:.7em 1.5em;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .2s,background .2s,border-color .2s,color .2s;
  white-space:nowrap;
}
.sp-cc-btn:hover{transform:translateY(-2px)}
.sp-cc-btn:focus-visible{outline:2px solid var(--gold,#C8983A);outline-offset:2px}

.sp-cc-btn.is-primary{background:var(--pine,#1E4034);color:var(--cream,#FBF9F2)}
.sp-cc-btn.is-secondary{background:transparent;color:var(--ink,#15211B);border-color:var(--line-strong,rgba(30,64,52,.28))}
.sp-cc-btn.is-secondary:hover{border-color:var(--moss,#2E5E4E)}

/* "Preferences" link-style trigger — visually lighter, still clearly clickable */
.sp-cc-link{
  background:none;border:none;cursor:pointer;
  font-family:var(--sans,"Hanken Grotesk",system-ui,sans-serif);
  font-weight:500;font-size:.9rem;
  color:var(--ink-soft,#3C4B43);
  text-decoration:underline;text-underline-offset:3px;
  padding:.5em .4em;
}
.sp-cc-link:hover{color:var(--moss,#2E5E4E)}
.sp-cc-link:focus-visible{outline:2px solid var(--gold,#C8983A);outline-offset:2px;border-radius:6px}

/* ---- preferences modal ---- */
.sp-cc-overlay{
  position:fixed;inset:0;z-index:10001;
  display:flex;align-items:center;justify-content:center;
  padding:24px;
  background:rgba(21,33,27,.45);
  -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
  animation:sp-cc-fade .25s ease both;
}
@keyframes sp-cc-fade{from{opacity:0}to{opacity:1}}
@media (prefers-reduced-motion:reduce){.sp-cc-overlay{animation:none}}

.sp-cc-modal{
  width:100%;max-width:540px;max-height:90vh;overflow-y:auto;
  background:var(--paper,#F3EFE5);
  border:1px solid var(--line,rgba(30,64,52,.14));
  border-radius:var(--r,18px);
  box-shadow:var(--shadow-lg,0 2px 4px rgba(21,33,27,.08),0 30px 60px -22px rgba(21,33,27,.30));
  padding:32px;
  font-family:var(--sans,"Hanken Grotesk",system-ui,sans-serif);
  color:var(--ink,#15211B);
}
.sp-cc-modal h2{
  font-family:var(--serif,"Fraunces",Georgia,serif);
  font-weight:600;font-size:1.5rem;line-height:1.1;letter-spacing:-.02em;margin:0 0 .35em;
}
.sp-cc-modal > p{font-size:.94rem;color:var(--ink-soft,#3C4B43);margin:0 0 22px}
.sp-cc-modal > p a{color:var(--moss,#2E5E4E);text-decoration:underline;text-underline-offset:2px}

.sp-cc-cat{
  display:flex;gap:16px;
  padding:18px 0;
  border-top:1px solid var(--line,rgba(30,64,52,.14));
}
.sp-cc-cat .sp-cc-cat-text{flex:1}
.sp-cc-cat h3{
  font-family:var(--sans,"Hanken Grotesk",system-ui,sans-serif);
  font-weight:600;font-size:1rem;color:var(--ink,#15211B);margin:0 0 .25em;
}
.sp-cc-cat p{font-size:.86rem;line-height:1.5;color:var(--ink-soft,#3C4B43);margin:0}

/* ---- toggle switch ---- */
.sp-cc-switch{position:relative;flex:0 0 auto;width:46px;height:26px;align-self:center}
.sp-cc-switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
.sp-cc-switch .sp-cc-track{
  position:absolute;inset:0;border-radius:100px;
  background:var(--line-strong,rgba(30,64,52,.28));
  transition:background .2s;pointer-events:none;
}
.sp-cc-switch .sp-cc-track::before{
  content:"";position:absolute;top:3px;left:3px;
  width:20px;height:20px;border-radius:50%;
  background:var(--cream,#FBF9F2);
  box-shadow:0 1px 2px rgba(21,33,27,.3);
  transition:transform .2s;
}
.sp-cc-switch input:checked + .sp-cc-track{background:var(--moss,#2E5E4E)}
.sp-cc-switch input:checked + .sp-cc-track::before{transform:translateX(20px)}
.sp-cc-switch input:focus-visible + .sp-cc-track{outline:2px solid var(--gold,#C8983A);outline-offset:2px}
.sp-cc-switch input:disabled{cursor:not-allowed}
.sp-cc-switch input:disabled + .sp-cc-track{background:var(--moss,#2E5E4E);opacity:.55}

.sp-cc-modal-actions{
  display:flex;gap:10px;flex-wrap:wrap;
  margin-top:26px;padding-top:22px;
  border-top:1px solid var(--line,rgba(30,64,52,.14));
}
.sp-cc-modal-actions .sp-cc-btn{flex:1 1 auto;text-align:center}

@media (max-width:560px){
  .sp-cc-banner{padding:18px 20px;gap:16px}
  .sp-cc-actions{width:100%}
  .sp-cc-actions .sp-cc-btn{flex:1 1 auto;text-align:center}
  .sp-cc-modal{padding:24px}
}
