
:root {
  --cc-bg: #ffffff;
  --cc-text: #333333;
  --cc-text-secondary: #666666;
  --cc-border: rgba(0,0,0,0.1);
  --cc-primary: #1a7f7a;
  --cc-primary-hover: #156661;
  --cc-secondary: #ffffff;
  --cc-secondary-hover: #f3f4f6;
  --cc-secondary-border: #d1d5db;
  --cc-toggle-bg: #d1d5db;
  --cc-toggle-active: #1a7f7a;
  --cc-overlay: rgba(0,0,0,0.6);
  --cc-shadow: 0 -4px 20px rgba(0,0,0,0.15);
  --cc-radius: 12px;
  --cc-radius-sm: 8px;
  --cc-transition: 0.3s ease;
  --cc-z-index: 99999;
}
.cc-sr-only { position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0 }
.cc-banner { position:fixed;bottom:0;left:0;right:0;z-index:var(--cc-z-index);background:var(--cc-bg);box-shadow:var(--cc-shadow);transform:translateY(100%);opacity:0;visibility:hidden;transition:transform var(--cc-transition),opacity var(--cc-transition),visibility var(--cc-transition);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:16px;line-height:1.5;color:var(--cc-text) }
.cc-banner.cc-visible { transform:translateY(0);opacity:1;visibility:visible }
.cc-banner-container { max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.5rem }
.cc-banner-content { flex:1 1 auto;min-width:280px;max-width:700px }
.cc-title { font-size:1.125rem;font-weight:600;margin:0 0 0.5rem 0;color:var(--cc-text) }
.cc-description { margin:0;font-size:0.9375rem;color:var(--cc-text-secondary);line-height:1.6 }
.cc-link { color:var(--cc-primary);text-decoration:underline;text-underline-offset:2px }
.cc-link:hover { text-decoration:none }
.cc-banner-actions { display:flex;flex-wrap:wrap;gap:0.75rem;flex-shrink:0 }
.cc-btn { display:inline-flex;align-items:center;justify-content:center;padding:0.75rem 1.5rem;font-size:0.9375rem;font-weight:600;border-radius:var(--cc-radius-sm);cursor:pointer;transition:all var(--cc-transition);text-decoration:none;border:2px solid transparent;min-height:48px;line-height:1.2;font-family:inherit }
.cc-btn:focus-visible { outline:2px solid var(--cc-primary);outline-offset:2px }
.cc-btn-primary { background:var(--cc-primary);color:#fff;border-color:var(--cc-primary) }
.cc-btn-primary:hover { background:var(--cc-primary-hover);border-color:var(--cc-primary-hover) }
.cc-btn-secondary { background:var(--cc-secondary);color:var(--cc-text);border-color:var(--cc-secondary-border) }
.cc-btn-secondary:hover { background:var(--cc-secondary-hover);border-color:var(--cc-text) }
.cc-btn-link { background:transparent;color:var(--cc-primary);border-color:transparent;text-decoration:underline;text-underline-offset:2px }
.cc-btn-link:hover { text-decoration:none;background:rgba(26,127,122,0.1) }
.cc-settings-modal { position:fixed;inset:0;z-index:calc(var(--cc-z-index) + 1);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity var(--cc-transition),visibility var(--cc-transition);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;font-size:16px;line-height:1.5;color:var(--cc-text) }
.cc-settings-modal.cc-visible { opacity:1;visibility:visible }
.cc-settings-overlay { position:absolute;inset:0;background:var(--cc-overlay);cursor:pointer }
.cc-settings-container { position:relative;background:var(--cc-bg);border-radius:var(--cc-radius);max-width:600px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px rgba(0,0,0,0.2);transform:scale(0.95);transition:transform var(--cc-transition) }
.cc-settings-modal.cc-visible .cc-settings-container { transform:scale(1) }
.cc-settings-header { display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--cc-border) }
.cc-settings-title { font-size:1.25rem;font-weight:600;margin:0;color:var(--cc-text) }
.cc-settings-close { display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:50%;cursor:pointer;color:var(--cc-text-secondary);transition:all var(--cc-transition) }
.cc-settings-close:hover { background:var(--cc-secondary-hover);color:var(--cc-text) }
.cc-settings-body { flex:1;overflow-y:auto;padding:1.5rem }
.cc-settings-description { margin:0 0 1.5rem 0;font-size:0.9375rem;color:var(--cc-text-secondary) }
.cc-settings-footer { padding:1.5rem;border-top:1px solid var(--cc-border);display:flex;justify-content:flex-end;gap:0.75rem }
.cc-category { padding:1rem 0;border-bottom:1px solid var(--cc-border) }
.cc-category:last-child { border-bottom:none }
.cc-category-header { display:flex;align-items:flex-start;justify-content:space-between;gap:1rem }
.cc-category-info { flex:1 }
.cc-category-title { font-size:1rem;font-weight:600;margin:0 0 0.25rem 0;color:var(--cc-text) }
.cc-category-description { font-size:0.875rem;color:var(--cc-text-secondary);margin:0;line-height:1.5 }
.cc-toggle { flex-shrink:0 }
.cc-toggle input { position:absolute;opacity:0;width:0;height:0 }
.cc-toggle-label { display:block;width:52px;height:28px;background:var(--cc-toggle-bg);border-radius:14px;position:relative;cursor:pointer;transition:background var(--cc-transition) }
.cc-toggle-label::after { content:'';position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,0.15);transition:transform var(--cc-transition) }
.cc-toggle input:checked + .cc-toggle-label { background:var(--cc-toggle-active) }
.cc-toggle input:checked + .cc-toggle-label::after { transform:translateX(24px) }
.cc-toggle-disabled .cc-toggle-label { opacity:0.7;cursor:not-allowed }
.cc-footer-link { color:inherit;text-decoration:underline;text-underline-offset:2px;opacity:0.8;transition:opacity var(--cc-transition);cursor:pointer;font-size:0.875rem }
.cc-footer-link:hover { opacity:1 }
.cc-footer-separator { opacity:0.5 }
@media (max-width:768px) {
  .cc-banner-container { flex-direction:column;align-items:stretch;padding:1.25rem 1rem;gap:1.25rem }
  .cc-banner-content { max-width:100%;min-width:auto }
  .cc-banner-actions { flex-direction:column;gap:0.5rem }
  .cc-btn { width:100%;justify-content:center }
  .cc-settings-container { width:100%;max-width:100%;height:100%;max-height:100%;border-radius:0 }
  .cc-settings-body { padding:1rem }
  .cc-category-header { flex-direction:column;gap:0.75rem }
}
@media (prefers-reduced-motion:reduce) { .cc-banner,.cc-settings-modal,.cc-settings-container,.cc-btn,.cc-toggle-label,.cc-toggle-label::after,.cc-settings-close { transition:none } }
