/* --- ОБЩИЕ СТИЛИ (Светлая тема) --- */
.lebedev-card {
    background: white !important;
    border: 1px solid var(--border-light) !important;
    border-radius: 24px !important;
    box-shadow: var(--shadow-soft) !important;
    padding-top: 2rem !important;
    padding-bottom: 1rem !important;
    transition: var(--transition-smooth);
}

.hero-open-section {
    padding: 2rem 0 !important;
    margin-bottom: 2rem !important;
}

.hero-title-open {
    font-size: 2.4rem !important;
    font-weight: 800 !important;
    color: var(--text-main) !important;
    letter-spacing: -0.03em !important;
    display: block !important;
}

.hero-subtitle-open {
    color: var(--text-muted);
    font-size: 1.1rem;
    font-style: italic !important;
    margin-bottom: 2rem !important;
    line-height: 1.6;
}

.hero-control-panel {
    background: rgba(255, 255, 255, 0.6) !important; 
    backdrop-filter: blur(12px) !important; 
    -webkit-backdrop-filter: blur(12px) !important;
    padding: 1.5rem !important; 
    border: 1px solid var(--border-light) !important; 
    border-radius: 20px !important;
    box-shadow: var(--shadow-soft) !important;
    transition: var(--transition-smooth);
}

/* Компактность форм */
.lebedev-card .text-center.mb-5 { margin-bottom: 2rem !important; }
.lebedev-card .mt-5 { margin-top: 2.5rem !important; }
.lebedev-card .mb-3 { margin-bottom: 1rem !important; }
.lebedev-card .form-label { margin-bottom: 0.4rem !important; letter-spacing: 0.02em; }
.lebedev-card .border-top { border-top: none !important; }

/* Поля ввода */
.lebedev-card .form-control {
    padding: 0.6rem 1rem !important;
    font-size: 0.9rem !important;
    transition: var(--transition-smooth);
    background-color: #fdfdfd !important;
    color: var(--text-main) !important;
}

.lebedev-card .form-control:focus {
    background-color: #fff !important;
    border-color: var(--accent-main) !important;
    box-shadow: 0 0 0 4px rgba(128, 137, 210, 0.1) !important;
}

/* Ссылки в формах */
.auth-link {
    color: var(--accent-main) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: var(--transition-smooth);
}
.auth-link:hover {
    color: #6B74C1 !important;
    text-decoration: underline !important;
}

/* --- ТЕМНАЯ ТЕМА --- */
body.dark-mode .lebedev-card { 
    background-color: #1E1E1E !important; 
    border-color: #2D2D2D !important; 
    box-shadow: 0 4px 20px rgba(0,0,0,0.4) !important;
}

body.dark-mode .hero-control-panel { 
    background: rgba(30, 30, 30, 0.8) !important; 
    border-color: #2D2D2D !important; 
}

body.dark-mode .form-control,
body.dark-mode .lebedev-card .form-control,
body.dark-mode .hero-control-panel .form-control {
    background-color: #2D2D2D !important; 
    border-color: #3F3F3F !important; 
    color: #FFFFFF !important;
}

body.dark-mode .form-control::placeholder { 
    color: rgba(255, 255, 255, 0.5) !important; 
    opacity: 1; 
}
body.dark-mode .form-control::-webkit-input-placeholder { 
    color: rgba(255, 255, 255, 0.5) !important; 
}
body.dark-mode .form-control::-moz-placeholder { 
    color: rgba(255, 255, 255, 0.5) !important; 
    opacity: 1; 
}
body.dark-mode .form-control:-ms-input-placeholder { 
    color: rgba(255, 255, 255, 0.5) !important; 
}

body.dark-mode .form-control:focus {
    background-color: #333 !important; 
    border-color: var(--accent-main) !important;
    color: #FFFFFF !important;
}

body.dark-mode .form-label, 
body.dark-mode .text-muted {
    color: var(--text-muted) !important;
}

body.dark-mode .auth-link,
body.dark-mode .lebedev-card a {
    color: var(--accent-main) !important;
}

body.dark-mode .form-check-input {
    background-color: #2D2D2D !important;
    border-color: #3F3F3F !important;
}

body.dark-mode .form-check-input:checked {
    background-color: var(--accent-main) !important;
    border-color: var(--accent-main) !important;
}

/* ============================================================
   COOKIE CONSENT IN REGISTER
   ============================================================ */

.cookie-consent-section {
    margin-top: 1.75rem;
    margin-bottom: 0.25rem;
}

.cookie-consent-title {
    font-size: 0.92rem;
    font-weight: 700;
    color: var(--text-main, #1a1a1a);
    margin-bottom: 0.3rem;
    display: flex;
    align-items: center;
    gap: 0.4rem;
}

.cookie-consent-title .cookie-icon {
    font-size: 1.05rem;
}

.cookie-consent-desc {
    font-size: 0.8rem;
    color: var(--text-muted, #888);
    line-height: 1.55;
    margin-bottom: 0.85rem;
}

.cookie-consent-desc a {
    color: var(--accent-main, #8089D2);
    text-decoration: underline;
    text-decoration-color: rgba(128, 137, 210, 0.4);
    text-underline-offset: 2px;
    transition: all 0.2s ease;
}

.cookie-consent-desc a:hover {
    color: #6B74C1;
    text-decoration-color: #6B74C1;
}

/* --- Карточки выбора (3 кнопки) --- */

.cookie-choice-label {
    cursor: pointer;
    width: 100%;
    position: relative;
    display: block;
}

.cookie-choice-radio {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    opacity: 0;
}

.cookie-choice-card {
    padding: 0.7rem 0.65rem;
    border-radius: 14px;
    border: 1.5px solid var(--border-light, #e0e0e0);
    background: #FFFFFF !important;
    transition: all 0.2s ease;
    text-align: center;
    user-select: none;
}

.cookie-choice-card:hover {
    border-color: var(--accent-main, #8089D2);
    background: rgba(128, 137, 210, 0.03) !important;
}

.cookie-choice-text {
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--text-main, #1a1a1a);
    display: block;
}

.cookie-choice-hint {
    font-size: 0.72rem;
    color: var(--text-muted, #888);
    line-height: 1.3;
    margin-top: 0.15rem;
    display: block;
}

/* Выбрано — accent-main обводка + фон */
.cookie-choice-radio:checked + .cookie-choice-card {
    border-color: var(--accent-main, #8089D2) !important;
    background-color: rgba(128, 137, 210, 0.08) !important;
}

/* Выбрано «Отклонить все» — красная обводка */
.cookie-choice-radio:checked + .cookie-choice-card.cookie-choice-danger {
    border-color: #dc3545 !important;
    background-color: rgba(220, 53, 69, 0.06) !important;
}

.cookie-choice-radio:checked + .cookie-choice-card.cookie-choice-danger .cookie-choice-text {
    color: #dc3545;
}

.cookie-choice-radio:checked + .cookie-choice-card.cookie-choice-danger .cookie-choice-hint {
    color: #dc3545;
    opacity: 0.8;
}

/* --- Ошибка при «Отклонить все» --- */

.cookie-reject-error {
    display: none;
    margin-top: 0.75rem;
    padding: 0.6rem 0.9rem;
    background: rgba(220, 53, 69, 0.08);
    border: 1px solid rgba(220, 53, 69, 0.2);
    border-radius: 12px;
    color: #dc3545;
    font-size: 0.82rem;
    line-height: 1.5;
}

.cookie-reject-error.visible {
    display: block;
    animation: cookieShake 0.4s ease;
}

@keyframes cookieShake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-6px); }
    50% { transform: translateX(6px); }
    75% { transform: translateX(-4px); }
}

/* --- Раскрывающийся блок «Настроить» --- */

.cookie-customize-section {
    display: none; /* Скрыто по умолчанию */
    margin-top: 0.85rem;
    padding-top: 0.85rem;
    border-top: 1px solid var(--border-light, #e0e0e0);
}

.cookie-customize-section.open {
    display: block !important; /* Показывается, когда JS добавил класс .open */
    animation: cookieFadeIn 0.25s ease;
}

@keyframes cookieFadeIn {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}

.cookie-customize-title {
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--text-muted, #888);
    margin-bottom: 0.6rem;
}

/* --- Карточки отдельных cookie-типов (узкие, с CSS-галочками) --- */

.cookie-type-label {
    cursor: pointer;
    width: 100%;
    position: relative;
    display: block;
}

.cookie-type-checkbox {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
    opacity: 0;
}

.cookie-type-card {
    padding: 0.55rem 0.7rem;
    border-radius: 12px;
    border: 1.5px solid var(--border-light, #e0e0e0);
    background: #FFFFFF !important;
    transition: all 0.2s ease;
    display: flex;
    align-items: center;
    gap: 0.55rem;
    user-select: none;
}

.cookie-type-card:hover {
    border-color: var(--accent-main, #8089D2);
    background: rgba(128, 137, 210, 0.03) !important;
}

.cookie-type-checkbox:checked + .cookie-type-card {
    border-color: var(--accent-main, #8089D2) !important;
    background-color: rgba(128, 137, 210, 0.08) !important;
}

.cookie-type-card.cookie-type-disabled {
    opacity: 0.6;
    cursor: default;
}

.cookie-type-card.cookie-type-disabled:hover {
    border-color: var(--border-light, #e0e0e0);
    background: #FFFFFF !important;
}

.cookie-type-card.cookie-type-disabled.cookie-type-checked {
    border-color: var(--accent-main, #8089D2) !important;
    background-color: rgba(128, 137, 210, 0.08) !important;
    opacity: 0.7;
}

/* CSS-галочка: квадрат с закруглением → при checked заливается + галочка через ::after */

.cookie-type-check-icon {
    width: 18px;
    height: 18px;
    border-radius: 5px;
    border: 1.5px solid #c0c0c0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.2s ease;
    position: relative;
    background: #fff;
}

.cookie-type-checkbox:checked + .cookie-type-card .cookie-type-check-icon,
.cookie-type-card.cookie-type-checked .cookie-type-check-icon {
    background: var(--accent-main, #8089D2);
    border-color: var(--accent-main, #8089D2);
}

/* Галочка рисуется через ::after — белая «птичка» из двух границ */
.cookie-type-checkbox:checked + .cookie-type-card .cookie-type-check-icon::after,
.cookie-type-card.cookie-type-checked .cookie-type-check-icon::after {
    content: '';
    position: absolute;
    width: 5px;
    height: 9px;
    border: solid #fff;
    border-width: 0 1.8px 1.8px 0;
    transform: rotate(45deg);
    top: 1.5px;
}

.cookie-type-info {
    flex: 1;
    min-width: 0;
}

.cookie-type-name {
    font-size: 0.82rem;
    font-weight: 600;
    color: var(--text-main, #1a1a1a);
    line-height: 1.25;
}

.cookie-type-desc {
    font-size: 0.72rem;
    color: var(--text-muted, #888);
    line-height: 1.35;
    margin-top: 0.05rem;
}

/* --- ТЁМНАЯ ТЕМА для cookie-секции --- */

body.dark-mode .cookie-consent-title {
    color: #FFFFFF;
}

body.dark-mode .cookie-consent-desc {
    color: #A0A0A0;
}

body.dark-mode .cookie-consent-desc a {
    color: var(--accent-main, #8089D2);
}

body.dark-mode .cookie-consent-desc a:hover {
    color: #9CA3E0;
}

body.dark-mode .cookie-choice-card {
    background-color: #2D2D2D !important;
    border-color: #3F3F3F;
}

body.dark-mode .cookie-choice-card:hover {
    border-color: var(--accent-main, #8089D2);
    background: rgba(128, 137, 210, 0.06) !important;
}

body.dark-mode .cookie-choice-text {
    color: #E0E0E0;
}

body.dark-mode .cookie-choice-hint {
    color: #888;
}

body.dark-mode .cookie-choice-radio:checked + .cookie-choice-card {
    background-color: rgba(128, 137, 210, 0.12) !important;
}

body.dark-mode .cookie-choice-radio:checked + .cookie-choice-card.cookie-choice-danger {
    background-color: rgba(220, 53, 69, 0.1) !important;
    border-color: #dc3545 !important;
}

body.dark-mode .cookie-reject-error {
    background: rgba(220, 53, 69, 0.12);
    border-color: rgba(220, 53, 69, 0.3);
    color: #f56565;
}

body.dark-mode .cookie-customize-section {
    border-top-color: #3F3F3F;
}

body.dark-mode .cookie-type-card {
    background-color: #2D2D2D !important;
    border-color: #3F3F3F;
}

body.dark-mode .cookie-type-card:hover {
    border-color: var(--accent-main, #8089D2);
    background: rgba(128, 137, 210, 0.06) !important;
}

body.dark-mode .cookie-type-checkbox:checked + .cookie-type-card {
    background-color: rgba(128, 137, 210, 0.12) !important;
}

body.dark-mode .cookie-type-name {
    color: #E0E0E0;
}

body.dark-mode .cookie-type-desc {
    color: #888;
}

body.dark-mode .cookie-type-check-icon {
    background: #2D2D2D;
    border-color: #555;
}

body.dark-mode .cookie-type-checkbox:checked + .cookie-type-card .cookie-type-check-icon {
    background: var(--accent-main, #8089D2);
    border-color: var(--accent-main, #8089D2);
}

body.dark-mode .cookie-type-card.cookie-type-disabled:hover {
    border-color: #3F3F3F;
    background: #2D2D2D !important;
}

/* --- RESPONSIVE --- */

@media (max-width: 576px) {
    .cookie-choice-card {
        padding: 0.6rem 0.55rem;
    }
    .cookie-choice-text {
        font-size: 0.82rem;
    }
    .cookie-choice-hint {
        font-size: 0.7rem;
    }
    .cookie-type-card {
        padding: 0.5rem 0.6rem;
    }
}