/* ===========================================================
   Cape Cavez International — Cookie Consent Styles
   Banner, preferences modal, toggle switches
   =========================================================== */

/* ===== Cookie banner (slides up from bottom) ===== */
.cc-banner{
  position:fixed;left:20px;right:20px;bottom:20px;z-index:1000;
  background:var(--ink);color:var(--paper);
  padding:28px 32px;border-radius:8px;
  box-shadow:0 25px 60px rgba(0,0,0,.4);
  border:1px solid rgba(255,255,255,.08);
  max-width:1240px;margin:0 auto;
  display:none;align-items:center;gap:32px;flex-wrap:wrap;
  animation:cc-slide-up .5s cubic-bezier(.2,.8,.2,1);
}
.cc-banner.show{display:flex}
@keyframes cc-slide-up{
  from{transform:translateY(40px);opacity:0}
  to{transform:translateY(0);opacity:1}
}
.cc-banner-content{flex:1;min-width:280px}
.cc-banner-title{
  font-family:"Fraunces",serif;font-size:1.3rem;font-weight:500;
  margin-bottom:8px;letter-spacing:-.01em;
}
.cc-banner-text{
  font-size:.9rem;color:rgba(247,243,236,.78);line-height:1.5;
}
.cc-banner-text a{color:#f4a261;text-decoration:underline}
.cc-banner-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.cc-btn{
  padding:11px 22px;border-radius:999px;
  font-family:"Manrope",sans-serif;font-size:.85rem;font-weight:600;
  cursor:pointer;border:0;transition:all .25s;white-space:nowrap;
}
.cc-btn-primary{background:var(--accent);color:#fff}
.cc-btn-primary:hover{background:#9c3309;transform:translateY(-1px)}
.cc-btn-secondary{background:rgba(255,255,255,.08);color:var(--paper);border:1px solid rgba(255,255,255,.18)}
.cc-btn-secondary:hover{background:rgba(255,255,255,.14)}
.cc-btn-ghost{background:transparent;color:rgba(247,243,236,.7);text-decoration:underline;padding:11px 8px}
.cc-btn-ghost:hover{color:#fff}

/* ===== Preferences modal ===== */
.cc-modal-overlay{
  position:fixed;inset:0;z-index:1100;
  background:rgba(11,29,42,.72);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;
  padding:20px;animation:cc-fade-in .25s ease;
}
.cc-modal-overlay.show{display:flex}
@keyframes cc-fade-in{from{opacity:0}to{opacity:1}}

.cc-modal{
  background:var(--paper);border-radius:8px;
  max-width:680px;width:100%;max-height:88vh;overflow-y:auto;
  box-shadow:0 40px 80px rgba(0,0,0,.4);
  animation:cc-pop .35s cubic-bezier(.2,.8,.2,1);
}
@keyframes cc-pop{
  from{transform:scale(.94);opacity:0}
  to{transform:scale(1);opacity:1}
}
.cc-modal-head{
  padding:32px 36px 24px;border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:flex-start;gap:20px;
}
.cc-modal-head h3{
  font-family:"Fraunces",serif;font-weight:400;font-size:1.7rem;
  letter-spacing:-.015em;line-height:1.1;
}
.cc-modal-head h3 em{color:var(--accent);font-style:italic}
.cc-modal-close{
  background:transparent;border:0;font-size:1.6rem;cursor:pointer;
  color:var(--ink-soft);width:36px;height:36px;border-radius:6px;
  display:grid;place-items:center;flex-shrink:0;
}
.cc-modal-close:hover{background:var(--paper-2);color:var(--ink)}

.cc-modal-body{padding:24px 36px}
.cc-modal-intro{color:var(--ink-soft);font-size:.95rem;margin-bottom:24px}

.cc-cat{
  border:1px solid var(--line);border-radius:6px;
  padding:20px 22px;margin-bottom:14px;background:var(--paper-2);
}
.cc-cat-head{display:flex;justify-content:space-between;align-items:center;gap:18px;margin-bottom:8px}
.cc-cat-name{
  font-family:"Fraunces",serif;font-size:1.1rem;font-weight:500;
}
.cc-cat-required{
  font-family:"JetBrains Mono",monospace;font-size:.66rem;
  letter-spacing:.14em;color:var(--accent-2);text-transform:uppercase;
  background:rgba(14,124,102,.1);padding:4px 10px;border-radius:999px;
}
.cc-cat-desc{font-size:.88rem;color:var(--ink-soft);line-height:1.5}

/* Toggle switch */
.cc-toggle{
  position:relative;display:inline-block;
  width:46px;height:26px;flex-shrink:0;
}
.cc-toggle input{opacity:0;width:0;height:0}
.cc-toggle-slider{
  position:absolute;cursor:pointer;inset:0;
  background:#cbd5d1;border-radius:999px;transition:.25s;
}
.cc-toggle-slider:before{
  content:"";position:absolute;height:20px;width:20px;
  left:3px;top:3px;background:#fff;border-radius:50%;
  transition:.25s;box-shadow:0 2px 4px rgba(0,0,0,.15);
}
.cc-toggle input:checked + .cc-toggle-slider{background:var(--accent-2)}
.cc-toggle input:checked + .cc-toggle-slider:before{transform:translateX(20px)}
.cc-toggle input:disabled + .cc-toggle-slider{background:var(--accent-2);opacity:.5;cursor:not-allowed}

.cc-modal-foot{
  padding:24px 36px 32px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;
  gap:14px;flex-wrap:wrap;background:var(--paper-2);
  border-radius:0 0 8px 8px;
}
.cc-modal-foot-actions{display:flex;gap:10px;flex-wrap:wrap}
.cc-modal-foot .cc-btn-primary{background:var(--ink);color:var(--paper)}
.cc-modal-foot .cc-btn-primary:hover{background:var(--accent)}
.cc-modal-foot .cc-btn-secondary{background:transparent;color:var(--ink);border:1px solid var(--line)}
.cc-modal-foot .cc-btn-secondary:hover{background:var(--paper)}
.cc-modal-foot-link a{color:var(--accent);font-size:.86rem;text-decoration:underline}

/* ===== Cookie settings re-open button (persistent floating) ===== */
.cc-reopen{
  position:fixed;left:20px;bottom:20px;z-index:90;
  width:44px;height:44px;border-radius:50%;
  background:var(--ink);color:var(--paper);border:0;cursor:pointer;
  box-shadow:0 8px 24px rgba(0,0,0,.2);
  display:none;align-items:center;justify-content:center;
  font-size:1.1rem;transition:transform .25s;
}
.cc-reopen.show{display:flex}
.cc-reopen:hover{transform:scale(1.08)}

/* ===== Form consent checkbox ===== */
.consent-check{
  display:flex;gap:12px;align-items:flex-start;
  margin:18px 0;padding:16px;background:var(--paper-2);
  border-radius:4px;border-left:3px solid var(--accent);
}
.consent-check input[type=checkbox]{
  width:18px;height:18px;margin-top:2px;flex-shrink:0;
  accent-color:var(--accent);cursor:pointer;
}
.consent-check label{
  font-size:.86rem;color:var(--ink-soft);line-height:1.5;cursor:pointer;
  font-family:"Manrope",sans-serif;letter-spacing:0;text-transform:none;
}
.consent-check label a{color:var(--accent);text-decoration:underline}

/* ===== Form success popup ===== */
.cc-popup-overlay{
  position:fixed;inset:0;z-index:1200;
  background:rgba(11,29,42,.72);backdrop-filter:blur(8px);
  display:none;align-items:center;justify-content:center;padding:20px;
}
.cc-popup-overlay.show{display:flex;animation:cc-fade-in .3s}
.cc-popup{
  background:var(--paper);border-radius:8px;
  max-width:480px;width:100%;padding:48px 40px;text-align:center;
  box-shadow:0 40px 80px rgba(0,0,0,.4);
  animation:cc-pop .35s cubic-bezier(.2,.8,.2,1);
}
.cc-popup-icon{
  width:72px;height:72px;border-radius:50%;
  background:rgba(14,124,102,.12);color:var(--accent-2);
  display:grid;place-items:center;margin:0 auto 24px;
  font-size:2.2rem;
}
.cc-popup h3{
  font-family:"Fraunces",serif;font-weight:400;font-size:1.8rem;
  margin-bottom:14px;letter-spacing:-.015em;
}
.cc-popup p{color:var(--ink-soft);margin-bottom:28px;font-size:.95rem}
.cc-popup .cc-btn-primary{background:var(--ink);color:var(--paper)}
.cc-popup .cc-btn-primary:hover{background:var(--accent)}

/* Responsive */
@media (max-width:640px){
  .cc-banner{padding:22px;flex-direction:column;align-items:stretch}
  .cc-banner-actions{justify-content:flex-start}
  .cc-modal-head,.cc-modal-body,.cc-modal-foot{padding-left:24px;padding-right:24px}
  .cc-modal-foot{flex-direction:column;align-items:stretch}
  .cc-modal-foot-actions{flex-direction:column}
  .cc-modal-foot-actions .cc-btn{width:100%}
  .cc-popup{padding:36px 28px}
}
