:root {
    --cookie-bg: #ffffff;
    --cookie-text: #1a1a1a;
    --cookie-text-secondary: #666666;
    --cookie-border: #e5e7eb;
    --cookie-primary: #184bb1;
    --cookie-primary-hover: #3a67c1;
    --cookie-link: #184bb1;
    --cookie-shadow: 0 -2px 24px rgba(0, 0, 0, 0.08);
    --cookie-modal-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
    --cookie-backdrop: rgba(0, 0, 0, 0.5);
    --cookie-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
    --cookie-radius: 3px;
}

.legat-cookie-banner {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 9999;
    background: var(--cookie-bg);
    color: var(--cookie-text);
    box-shadow: var(--cookie-shadow);
    font-family: var(--cookie-font);
    padding: 20px 24px;
    border-top: 1px solid var(--cookie-border);
    display: none;
}
.legat-cookie-banner.is-visible { display: block; animation: slideUp 0.3s ease-out; }

@keyframes slideUp {
    from { transform: translateY(100%); }
    to { transform: translateY(0); }
}

.legat-cookie-banner__inner {
    max-width: 1200px; margin: 0 auto;
    display: flex; align-items: center; gap: 24px;
    flex-wrap: wrap;
}
.legat-cookie-banner__icon {
    font-size: 32px; flex-shrink: 0;
}
.legat-cookie-banner__content {
    flex: 1 1 400px; min-width: 0;
}
.legat-cookie-banner__title {
    font-size: 16px; font-weight: 600; margin: 0 0 6px;
}
.legat-cookie-banner__text {
    font-size: 14px; line-height: 1.5; color: var(--cookie-text-secondary); margin: 0;
}
.legat-cookie-banner__text a {
    color: var(--cookie-link); text-decoration: none;
}
.legat-cookie-banner__text a:hover { text-decoration: underline; }
.legat-cookie-banner__actions {
    display: flex; gap: 8px; flex-shrink: 0; flex-wrap: wrap;
}

.legat-cookie-btn {
    font-family: var(--cookie-font);
    font-size: 14px;
    font-weight: 500;
    padding: 10px 20px;
    border-radius: var(--cookie-radius);
    cursor: pointer;
    border: 1px solid transparent;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
    white-space: nowrap;
}
.legat-cookie-btn--primary {
    background: var(--cookie-primary); color: white;
}
.legat-cookie-btn--primary:hover { background: var(--cookie-primary-hover); }
.legat-cookie-btn--secondary {
    background: white; color: var(--cookie-text); border-color: var(--cookie-border);
}
.legat-cookie-btn--secondary:hover { background: #f9fafb; }
.legat-cookie-btn--text {
    background: transparent; color: var(--cookie-link); border-color: transparent;
}
.legat-cookie-btn--text:hover { text-decoration: underline; }

/* ===== МОДАЛКА (Settings) ===== */
.legat-cookie-modal {
    position: fixed; inset: 0; z-index: 10000;
    background: var(--cookie-backdrop);
    display: none; align-items: center; justify-content: center;
    padding: 16px;
}
.legat-cookie-modal.is-visible { display: flex; animation: fadeIn 0.2s ease-out; }
@keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
}
.legat-cookie-modal__dialog {
    background: var(--cookie-bg);
    border-radius: 12px;
    box-shadow: var(--cookie-modal-shadow);
    max-width: 600px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    font-family: var(--cookie-font);
    color: var(--cookie-text);
    animation: scaleIn 0.2s ease-out;
}
@keyframes scaleIn {
    from { transform: scale(0.95); opacity: 0; }
    to { transform: scale(1); opacity: 1; }
}
.legat-cookie-modal__header {
    padding: 20px 24px;
    border-bottom: 1px solid var(--cookie-border);
    display: flex; justify-content: space-between; align-items: center;
}
.legat-cookie-modal__title {
    font-size: 18px; font-weight: 600; margin: 0;
}
.legat-cookie-modal__close {
    background: transparent; border: none; cursor: pointer;
    font-size: 24px; color: var(--cookie-text-secondary); line-height: 1;
    padding: 4px 8px;
}
.legat-cookie-modal__body {
    padding: 20px 24px;
}
.legat-cookie-modal__intro {
    font-size: 14px; line-height: 1.5; color: var(--cookie-text-secondary); margin: 0 0 20px;
}
.legat-cookie-modal__intro a { color: var(--cookie-link); text-decoration: none; }
.legat-cookie-modal__intro a:hover { text-decoration: underline; }

.legat-cookie-category {
    border: 1px solid var(--cookie-border);
    border-radius: var(--cookie-radius);
    padding: 16px 20px;
    margin-bottom: 12px;
}
.legat-cookie-category__header {
    display: flex; justify-content: space-between; align-items: center;
    gap: 12px;
}
.legat-cookie-category__title {
    font-size: 15px; font-weight: 600; margin: 0;
}
.legat-cookie-category__desc {
    font-size: 13px; line-height: 1.5; color: var(--cookie-text-secondary);
    margin: 10px 0 0;
}
.legat-cookie-category__locked {
    font-size: 13px; font-weight: 500; color: #2a7a4e;
    display: flex; align-items: center; gap: 4px;
}

/* Tумблер */
.legat-cookie-toggle {
    position: relative; display: inline-block;
    width: 44px; height: 24px;
}
.legat-cookie-toggle input {
    opacity: 0; width: 0; height: 0;
}
.legat-cookie-toggle__slider {
    position: absolute; cursor: pointer; inset: 0;
    background: #cbd5e1; border-radius: 24px;
    transition: background 0.2s;
}
.legat-cookie-toggle__slider:before {
    content: ""; position: absolute;
    height: 18px; width: 18px;
    left: 3px; bottom: 3px;
    background: white; border-radius: 50%;
    transition: transform 0.2s;
    box-shadow: 0 1px 3px rgba(0,0,0,0.15);
}
.legat-cookie-toggle input:checked + .legat-cookie-toggle__slider {
    background: var(--cookie-primary);
}
.legat-cookie-toggle input:checked + .legat-cookie-toggle__slider:before {
    transform: translateX(20px);
}

.legat-cookie-modal__footer {
    padding: 16px 24px;
    border-top: 1px solid var(--cookie-border);
    display: flex; justify-content: flex-end; gap: 8px;
    flex-wrap: wrap;
}

/* Адаптив */
@media (max-width: 640px) {
    .legat-cookie-banner__inner { flex-direction: column; align-items: stretch; gap: 16px; }
    .legat-cookie-banner__icon { display: none; }
    .legat-cookie-banner__actions { flex-direction: column; }
    .legat-cookie-btn { width: 100%; text-align: center; }
    .legat-cookie-modal__footer { flex-direction: column-reverse; }
    .legat-cookie-modal__footer .legat-cookie-btn { width: 100%; }
}