.cookie-consent-banner{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card, #ffffff);border-top:1px solid var(--border-color, #e5e7eb);box-shadow:0 -4px 6px -1px #0000001a,0 -2px 4px -1px #0000000f;padding:1.25rem 1.5rem;z-index:99999998;display:none;animation:slideUp .3s ease-out;transition:opacity .3s ease-out,transform .3s ease-out}.cookie-consent-banner.modal-open{opacity:0;pointer-events:none;transform:translateY(100%)}.cookie-consent-banner.show{display:block}.cookie-consent-banner.hiding{animation:slideDown .3s ease-out forwards}.dark .cookie-consent-banner{background:var(--bg-card-dark, #1e293b);border-top-color:var(--border-color-dark, #334155);color:var(--text-primary-dark, #f8fafc)}.cookie-banner-content{max-width:1280px;margin:0 auto;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.cookie-banner-icon{font-size:1.75rem;color:var(--primary, #8b5cf6);flex-shrink:0}.dark .cookie-banner-icon{color:var(--primary, #8b5cf6)}.cookie-banner-text{flex:1;min-width:250px}.cookie-banner-title{font-size:1rem;font-weight:600;color:var(--text-primary, #1e293b);margin-bottom:.5rem;line-height:1.5}.dark .cookie-banner-title{color:var(--text-primary-dark, #f8fafc)}.cookie-banner-description{font-size:.875rem;color:var(--text-secondary, #64748b);line-height:1.6}.dark .cookie-banner-description{color:var(--text-secondary-dark, #cbd5e1)}.cookie-banner-link{color:var(--primary, #8b5cf6);text-decoration:underline;transition:color .2s}.cookie-banner-link:hover{color:var(--primary-hover, #7c3aed)}.cookie-banner-actions{display:flex;gap:.75rem;flex-wrap:wrap;flex-shrink:0}.cookie-btn{padding:.625rem 1.25rem;border-radius:.5rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;white-space:nowrap;display:inline-flex;align-items:center;gap:.5rem}.cookie-btn-accept{background:var(--primary, #8b5cf6);color:#fff}.cookie-btn-accept:hover{background:var(--primary-hover, #7c3aed)}.cookie-btn-reject{background:var(--secondary-light, #f1f5f9);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e5e7eb)}.dark .cookie-btn-reject{background:var(--bg-card-dark, #1e293b);color:var(--text-primary-dark, #f8fafc);border-color:var(--border-color-dark, #334155)}.cookie-btn-reject:hover{background:var(--secondary-hover, #475569);color:#fff}.cookie-btn-customize{background:transparent;color:var(--primary, #8b5cf6);border:1px solid var(--primary, #8b5cf6)}.cookie-btn-customize:hover{background:var(--primary-light, #ede9fe)}.dark .cookie-btn-customize:hover{background:var(--bg-card-dark, #1e293b)}.cookie-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:none;align-items:center;justify-content:center;z-index:99999999;padding:1rem;animation:fadeIn .2s ease-out;opacity:0;transition:opacity .2s ease-out}.cookie-modal.show{display:flex;opacity:1}.cookie-modal-content{background:var(--bg-card, #ffffff);border-radius:.75rem;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUpModal .3s ease-out}.dark .cookie-modal-content{background:var(--bg-card-dark, #1e293b);color:var(--text-primary-dark, #f8fafc)}.cookie-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.cookie-modal-title{font-size:1.5rem;font-weight:600;color:var(--text-primary, #1e293b);display:flex;align-items:center;gap:.75rem}.dark .cookie-modal-title{color:var(--text-primary-dark, #f8fafc)}.cookie-modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-secondary, #64748b);cursor:pointer;padding:.25rem;border-radius:.25rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.cookie-modal-close:hover{background:var(--secondary-light, #f1f5f9);color:var(--text-primary, #1e293b)}.dark .cookie-modal-close:hover{background:var(--bg-card-dark, #1e293b);color:var(--text-primary-dark, #f8fafc)}.cookie-modal-description{font-size:.875rem;color:var(--text-secondary, #64748b);margin-bottom:1.5rem;line-height:1.6}.dark .cookie-modal-description{color:var(--text-secondary-dark, #cbd5e1)}.cookie-category{margin-bottom:1.5rem;padding:1rem;background:var(--secondary-light, #f1f5f9);border-radius:.5rem}.dark .cookie-category{background:var(--bg-card-dark, #1e293b)}.cookie-category-essential{border-left:4px solid var(--success, #10b981)}.cookie-category-functional{border-left:4px solid var(--info, #06b6d4)}.cookie-category-analytics{border-left:4px solid var(--warning, #f59e0b)}.cookie-category-marketing{border-left:4px solid var(--danger, #ef4444)}.cookie-category-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.cookie-category-title{font-size:1rem;font-weight:600;color:var(--text-primary, #1e293b);display:flex;align-items:center;gap:.5rem}.dark .cookie-category-title{color:var(--text-primary-dark, #f8fafc)}.cookie-category-description{font-size:.875rem;color:var(--text-secondary, #64748b);line-height:1.6;margin-bottom:.75rem}.dark .cookie-category-description{color:var(--text-secondary-dark, #cbd5e1)}.cookie-category-required{font-size:.75rem;color:var(--success, #10b981);font-weight:500}.cookie-toggle{position:relative;display:inline-block;width:3rem;height:1.5rem}.cookie-toggle input{opacity:0;width:0;height:0}.cookie-toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--secondary, #64748b);transition:.3s;border-radius:1.5rem}.cookie-toggle-slider:before{position:absolute;content:"";height:1.125rem;width:1.125rem;left:.1875rem;bottom:.1875rem;background-color:#fff;transition:.3s;border-radius:50%}.cookie-toggle input:checked+.cookie-toggle-slider{background-color:var(--primary, #8b5cf6)}.cookie-toggle input:checked+.cookie-toggle-slider:before{transform:translate(1.5rem)}.cookie-toggle input:disabled+.cookie-toggle-slider{background-color:var(--success, #10b981);cursor:not-allowed;opacity:.6}.cookie-toggle input:disabled+.cookie-toggle-slider:before{background-color:#fff}.cookie-modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color, #e5e7eb)}.dark .cookie-modal-actions{border-top-color:var(--border-color-dark, #334155)}.cookie-btn-save{background:var(--primary, #8b5cf6);color:#fff}.cookie-btn-save:hover{background:var(--primary-hover, #7c3aed)}.cookie-btn-cancel{background:var(--secondary-light, #f1f5f9);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e5e7eb)}.dark .cookie-btn-cancel{background:var(--bg-card-dark, #1e293b);color:var(--text-primary-dark, #f8fafc);border-color:var(--border-color-dark, #334155)}.cookie-btn-cancel:hover{background:var(--secondary-hover, #475569);color:#fff}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUpModal{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:640px){.cookie-consent-banner{padding:1rem}.cookie-banner-content{flex-direction:column;align-items:flex-start;gap:1rem}.cookie-banner-actions{width:100%}.cookie-btn{flex:1;justify-content:center}.cookie-modal-content{padding:1.5rem;max-height:95vh}.cookie-modal-actions{flex-direction:column}.cookie-btn-save,.cookie-btn-cancel{width:100%;justify-content:center}}.cookie-toggle:focus-within .cookie-toggle-slider{outline:2px solid var(--primary, #8b5cf6);outline-offset:2px}.cookie-btn:focus{outline:2px solid var(--primary, #8b5cf6);outline-offset:2px}body.cookie-modal-open{overflow:hidden}
