/* ========================================
 * PAGES CSS - Стили для внутренних страниц
 * ========================================
 * About Us, Licenses, Contact
 */

/* ========================================
 * PAGE HERO - Заголовок страницы
 * ======================================== */

.page-content {
    padding-top: 80px;
}

.page-hero {
    padding: var(--space-16) 0 var(--space-4);
    text-align: left;
}

.page-hero__title {
    font-family: var(--font-display);
    font-size: clamp(3rem, 8vw, 5rem);
    font-weight: 900;
    line-height: 1.1;
    color: var(--color-text-primary);
}

/* ========================================
 * ABOUT INFO SECTION
 * ======================================== */

.about-info__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: center;
}

.about-info__subtitle {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-6);
    line-height: 1.4;
}

.about-info__text {
    color: var(--color-text-secondary);
    line-height: 1.8;
    margin-bottom: var(--space-4);
}

/* About Visual - 3D Cubes */
.about-visual {
    position: relative;
    width: 100%;
    height: 400px;
    perspective: 1000px;
}

.about-visual__cubes {
    position: relative;
    width: 100%;
    height: 100%;
    transform-style: preserve-3d;
    animation: rotateScene 20s linear infinite;
}

@keyframes rotateScene {
    from { transform: rotateY(0deg); }
    to { transform: rotateY(360deg); }
}

.cube {
    position: absolute;
    width: 60px;
    height: 60px;
    border: 2px solid var(--color-primary);
    background: linear-gradient(135deg, rgba(0, 163, 255, 0.1), transparent);
    border-radius: var(--radius-md);
    animation: floatCube 4s ease-in-out infinite;
}

.cube--1 { top: 20%; left: 30%; animation-delay: 0s; }
.cube--2 { top: 40%; left: 50%; animation-delay: 0.5s; width: 80px; height: 80px; }
.cube--3 { top: 60%; left: 35%; animation-delay: 1s; }
.cube--4 { top: 30%; left: 60%; animation-delay: 1.5s; width: 50px; height: 50px; }
.cube--5 { top: 55%; left: 65%; animation-delay: 2s; }
.cube--6 { top: 15%; left: 45%; animation-delay: 2.5s; width: 40px; height: 40px; }
.cube--7 { top: 70%; left: 55%; animation-delay: 3s; width: 70px; height: 70px; }
.cube--8 { top: 45%; left: 25%; animation-delay: 3.5s; width: 45px; height: 45px; }

@keyframes floatCube {
    0%, 100% { transform: translateY(0) rotateX(0deg) rotateY(0deg); }
    50% { transform: translateY(-20px) rotateX(15deg) rotateY(15deg); }
}

/* ========================================
 * STATS SECTION
 * ======================================== */

.stats-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}

.stat-card {
    padding: var(--space-8);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    text-align: left;
}

.stat-card__value {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 700;
    color: var(--color-text-primary);
    line-height: 1;
    margin-bottom: var(--space-2);
}

.stat-card__label {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* ========================================
 * VALUES SECTION
 * ======================================== */

.values-section {
    padding: var(--space-20) 0;
}

.values-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
    margin-top: var(--space-12);
}

.value-card {
    padding: var(--space-8);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    transition: all var(--transition-base);
}

.value-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-4px);
}

.value-card__icon {
    width: 48px;
    height: 48px;
    padding: var(--space-3);
    background: rgba(0, 163, 255, 0.1);
    border: 1px solid var(--color-primary);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-6);
}

.value-card__icon svg {
    width: 100%;
    height: 100%;
    color: var(--color-primary);
}

.value-card__title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-3);
}

.value-card__text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* ========================================
 * LEADERSHIP SECTION
 * ======================================== */

.leadership-section {
    padding: var(--space-20) 0;
}

.leadership-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-8);
    margin-top: var(--space-12);
}

.leader-card {
    text-align: left;
}

.leader-card__image {
    width: 100%;
    aspect-ratio: 4/5;
    border-radius: var(--radius-xl);
    overflow: hidden;
    margin-bottom: var(--space-4);
    filter: grayscale(100%);
    transition: filter var(--transition-base);
}

.leader-card:hover .leader-card__image {
    filter: grayscale(0%);
}

.leader-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.leader-card__name {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-1);
}

.leader-card__role {
    font-size: var(--text-sm);
    color: var(--color-primary);
}

/* ========================================
 * LICENSES PAGE
 * ======================================== */

/* License Hero Card */
.license-hero-card {
    padding: var(--space-10);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-2xl);
    display: flex;
    align-items: center;
    gap: var(--space-8);
    margin-bottom: var(--space-12);
}

.license-hero-card__icon {
    width: 80px;
    height: 80px;
    padding: var(--space-5);
    background: rgba(0, 163, 255, 0.1);
    border: 2px solid var(--color-primary);
    border-radius: 50%;
    flex-shrink: 0;
}

.license-hero-card__icon svg {
    width: 100%;
    height: 100%;
    color: var(--color-primary);
}

.license-hero-card__content {
    flex: 1;
}

.license-hero-card__title {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: var(--space-2);
}

.license-hero-card__number {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--color-primary);
    margin-bottom: var(--space-4);
}

.license-hero-card__text {
    color: var(--color-text-secondary);
    line-height: 1.6;
}

.license-hero-card__action {
    flex-shrink: 0;
}

/* Protection Cards */
.protection-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    margin-top: var(--space-12);
}

.protection-card {
    padding: var(--space-8);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
}

.protection-card__icon {
    width: 48px;
    height: 48px;
    margin-bottom: var(--space-6);
    color: var(--color-text-muted);
}

.protection-card__icon svg {
    width: 100%;
    height: 100%;
}

.protection-card__title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-3);
}

.protection-card__text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* Legal Documents */
.documents-section {
    padding: var(--space-16) 0;
}

.documents-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
    margin-top: var(--space-8);
}

.document-card {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-5) var(--space-6);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
    cursor: pointer;
}

.document-card:hover {
    border-color: var(--color-primary);
    background: var(--color-bg-tertiary);
}

.document-card__info {
    display: flex;
    align-items: center;
    gap: var(--space-4);
}

.document-card__icon {
    width: 24px;
    height: 24px;
    color: var(--color-text-muted);
}

.document-card__name {
    font-size: var(--text-base);
    color: var(--color-text-primary);
}

.document-card__action {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.document-card__action svg {
    width: 16px;
    height: 16px;
}

/* ========================================
 * CONTACT PAGE
 * ======================================== */

/* Contact Hero */
.contact-hero {
    padding-bottom: 0;
}

.contact-hero__subtitle {
    color: var(--color-text-secondary);
    font-size: var(--text-lg);
    max-width: 600px;
    margin-top: var(--space-4);
}

/* Contact Grid */
.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: var(--space-12);
    margin-top: var(--space-12);
}

/* Contact Cards */
.contact-cards {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.contact-card {
    padding: var(--space-6);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
}

.contact-card__header {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    margin-bottom: var(--space-4);
}

.contact-card__icon {
    width: 48px;
    height: 48px;
    padding: var(--space-3);
    background: rgba(0, 163, 255, 0.1);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    flex-shrink: 0;
}

.contact-card__icon svg {
    width: 100%;
    height: 100%;
    color: var(--color-primary);
}

.contact-card__title {
    font-family: var(--font-display);
    font-size: var(--text-base);
    font-weight: 600;
    color: var(--color-text-primary);
}

.contact-card__subtitle {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.contact-card__value {
    font-family: var(--font-mono);
    font-size: var(--text-base);
    color: var(--color-text-primary);
}

.contact-card__address {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: 1.6;
}

.contact-card__reg {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    margin-top: var(--space-3);
    padding-top: var(--space-3);
    border-top: 1px solid var(--color-border);
    line-height: 1.6;
}

/* Contact Form */
.contact-form-wrapper {
    padding: var(--space-8);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-2xl);
}

.contact-form__title {
    font-family: var(--font-display);
    font-size: var(--text-xl);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-6);
}

.contact-form__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}

.form-group {
    margin-bottom: var(--space-5);
}

.form-group__label {
    display: block;
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: var(--space-2);
}

.form-group__input,
.form-group__textarea {
    width: 100%;
    padding: var(--space-4);
    background: var(--color-bg-tertiary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    color: var(--color-text-primary);
    font-size: var(--text-base);
    transition: all var(--transition-fast);
}

.form-group__input:focus,
.form-group__textarea:focus {
    outline: none;
    border-color: var(--color-primary);
    box-shadow: 0 0 0 3px rgba(0, 163, 255, 0.1);
}

.form-group__textarea {
    min-height: 150px;
    resize: vertical;
}

.contact-form__submit {
    width: 100%;
    margin-top: var(--space-4);
}

/* ========================================
 * SUPPORT SECTION - Часы работы поддержки
 * ======================================== */

.support-section {
    padding: var(--space-16) 0;
}

.support-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-6);
}

.support-card {
    padding: var(--space-8);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    text-align: center;
    transition: all var(--transition-base);
}

.support-card:hover {
    border-color: var(--color-border-hover);
    transform: translateY(-4px);
}

.support-card--highlight {
    border-color: var(--color-primary);
    background: rgba(0, 163, 255, 0.03);
}

.support-card__icon {
    width: 56px;
    height: 56px;
    margin: 0 auto var(--space-5);
    padding: var(--space-3);
    background: rgba(0, 163, 255, 0.1);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.support-card__icon svg {
    width: 100%;
    height: 100%;
    color: var(--color-primary);
}

.support-card__title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-2);
}

.support-card__hours {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: var(--space-2);
}

.support-card__desc {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    margin-bottom: 0;
}

/* FAQ Section */
.faq-section {
    padding: var(--space-16) 0;
}

.faq-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
    margin-top: var(--space-8);
    max-width: 800px;
    margin-left: auto;
    margin-right: auto;
}

/* Wide FAQ list - 1200px */
.faq-list--wide {
    max-width: 1200px;
}

/* Wide container for FAQ section */
.container--wide {
    max-width: 1200px;
}

.faq-item {
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.faq-item__question {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-5) var(--space-6);
    background: none;
    border: none;
    color: var(--color-text-primary);
    font-size: var(--text-base);
    font-weight: 500;
    text-align: left;
    cursor: pointer;
    transition: all var(--transition-fast);
}

.faq-item__question:hover {
    color: var(--color-primary);
}

.faq-item__icon {
    width: 24px;
    height: 24px;
    color: var(--color-text-muted);
    transition: transform var(--transition-fast);
}

.faq-item.active .faq-item__icon {
    transform: rotate(180deg);
}

.faq-item__answer {
    padding: 0 var(--space-6) var(--space-5);
    color: var(--color-text-secondary);
    line-height: 1.6;
    display: none;
}

.faq-item.active .faq-item__answer {
    display: block;
}

/* ========================================
 * LEGAL PAGES - Privacy, Terms, etc.
 * ======================================== */

.legal-content {
    max-width: 1200px;
    margin: 0 auto;
    padding: var(--space-8) 0;
}

.legal-content__section {
    margin-bottom: var(--space-10);
}

.legal-content__section h2 {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: var(--space-4);
    padding-bottom: var(--space-3);
    border-bottom: 1px solid var(--color-border);
}

.legal-content__section h3 {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-top: var(--space-6);
    margin-bottom: var(--space-3);
}

.legal-content__section p {
    color: var(--color-text-secondary);
    line-height: 1.8;
    margin-bottom: var(--space-4);
}

.legal-content__section ul,
.legal-content__section ol {
    color: var(--color-text-secondary);
    line-height: 1.8;
    margin-bottom: var(--space-4);
    padding-left: var(--space-6);
}

.legal-content__section li {
    margin-bottom: var(--space-2);
}

.legal-content__section strong {
    color: var(--color-text-primary);
}

.legal-content__section a {
    color: var(--color-primary);
    text-decoration: underline;
}

.legal-content__section a:hover {
    text-decoration: none;
}

.legal-meta {
    display: flex;
    gap: var(--space-6);
    margin-bottom: var(--space-8);
    padding: var(--space-4) var(--space-6);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
}

.legal-meta__item {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.legal-meta__label {
    font-size: var(--text-xs);
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.legal-meta__value {
    font-size: var(--text-sm);
    color: var(--color-text-primary);
    font-weight: 500;
}

/* API Documentation Styles */
.api-card {
    padding: var(--space-6);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    margin-bottom: var(--space-6);
}

.api-card__header {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin-bottom: var(--space-4);
}

.api-card__icon {
    width: 48px;
    height: 48px;
    padding: var(--space-3);
    background: rgba(0, 163, 255, 0.1);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    flex-shrink: 0;
}

.api-card__icon svg {
    width: 100%;
    height: 100%;
    color: var(--color-primary);
}

.api-card__title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text-primary);
}

.api-card__text {
    color: var(--color-text-secondary);
    line-height: 1.6;
}

.api-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
}

.code-block {
    background: var(--color-bg-tertiary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-4);
    overflow-x: auto;
}

.code-block code {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--color-primary);
}

/* Security Page Styles */
.security-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
}

.security-card {
    padding: var(--space-6);
    background: var(--color-bg-secondary);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    transition: all var(--transition-base);
}

.security-card:hover {
    border-color: var(--color-primary);
    transform: translateY(-2px);
}

.security-card__icon {
    width: 56px;
    height: 56px;
    padding: var(--space-3);
    background: rgba(0, 163, 255, 0.1);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    margin-bottom: var(--space-4);
}

.security-card__icon svg {
    width: 100%;
    height: 100%;
    color: var(--color-primary);
}

.security-card__title {
    font-family: var(--font-display);
    font-size: var(--text-lg);
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: var(--space-3);
}

.security-card__text {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: 1.6;
}

/* ========================================
 * RESPONSIVE - Адаптив для страниц
 * ======================================== */

@media (max-width: 1024px) {
    .about-info__grid {
        grid-template-columns: 1fr;
        gap: var(--space-8);
    }
    
    .about-visual {
        height: 300px;
    }
    
    .values-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .leadership-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .protection-grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .contact-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 768px) {
    .page-hero__title {
        font-size: clamp(2.5rem, 10vw, 3.5rem);
    }
    
    .stats-grid {
        grid-template-columns: 1fr;
    }
    
    .values-grid {
        grid-template-columns: 1fr;
    }
    
    .leadership-grid {
        grid-template-columns: 1fr;
    }
    
    .protection-grid {
        grid-template-columns: 1fr;
    }
    
    .documents-grid {
        grid-template-columns: 1fr;
    }
    
    .license-hero-card {
        flex-direction: column;
        text-align: center;
    }
    
    .contact-form__row {
        grid-template-columns: 1fr;
    }
    
    .api-grid {
        grid-template-columns: 1fr;
    }
    
    .security-grid {
        grid-template-columns: 1fr;
    }
    
    .legal-meta {
        flex-direction: column;
        gap: var(--space-4);
    }
    
    .map-legend {
        flex-direction: column;
        align-items: center;
    }
    
    .europe-map {
        height: 300px;
    }
}

/* ========================================
 * AUTH PAGES - Login / Register
 * ======================================== */

.auth-page {
    min-height: 100vh;
    display: flex;
    align-items: stretch;
}

.auth-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
    min-height: 100vh;
}

/* Left Side - Branding */
.auth-branding {
    display: flex;
    flex-direction: column;
    padding: var(--space-10);
    position: relative;
    z-index: 2;
}

.auth-branding__logo {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    color: var(--color-text-primary);
    text-decoration: none;
    font-size: var(--text-lg);
    font-family: var(--font-display);
}

.auth-branding__logo-icon {
    width: 36px;
    height: 36px;
    color: var(--color-primary);
}

.auth-branding__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: 500px;
}

.auth-branding__title {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 5vw, 3.5rem);
    font-weight: 900;
    line-height: 1.1;
    margin-bottom: var(--space-6);
}

.auth-branding__desc {
    font-size: var(--text-lg);
    color: var(--color-text-secondary);
    line-height: 1.6;
    margin-bottom: var(--space-10);
}

.auth-branding__stats {
    display: flex;
    gap: var(--space-8);
}

.auth-stat {
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
}

.auth-stat__value {
    font-family: var(--font-display);
    font-size: var(--text-2xl);
    font-weight: 700;
    color: var(--color-primary);
}

.auth-stat__label {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
}

.auth-branding__footer {
    color: var(--color-text-muted);
    font-size: var(--text-sm);
}

/* Right Side - Form */
.auth-form-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--space-10);
    background: var(--color-bg-secondary);
    position: relative;
    overflow-y: auto;
}

.auth-form {
    width: 100%;
    max-width: 420px;
}

/* Register form - wider */
.auth-form--register {
    max-width: 520px;
}

.auth-form__header {
    text-align: center;
    margin-bottom: var(--space-8);
}

.auth-form__title {
    font-family: var(--font-display);
    font-size: var(--text-3xl);
    font-weight: 700;
    color: var(--color-text-primary);
    margin-bottom: var(--space-2);
}

.auth-form__subtitle {
    color: var(--color-text-secondary);
}

/* Form Row Grid - for side by side fields */
.form-row-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4);
}

/* Input with toggle button (password fields) */
.input-with-toggle {
    position: relative;
}

.input-with-toggle .form-group__input {
    padding-right: var(--space-12);
}

.password-toggle {
    position: absolute;
    right: var(--space-4);
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    color: var(--color-text-muted);
    cursor: pointer;
    padding: var(--space-2);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: color var(--transition-fast);
}

.password-toggle:hover {
    color: var(--color-text-primary);
}

/* Form Row - for checkbox and links */
.form-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: var(--space-6);
}

.checkbox-wrapper {
    display: flex;
    align-items: flex-start;
    gap: var(--space-2);
    cursor: pointer;
}

.checkbox {
    width: 18px;
    height: 18px;
    accent-color: var(--color-primary);
    cursor: pointer;
    flex-shrink: 0;
    margin-top: 2px;
}

.checkbox-label {
    font-size: var(--text-sm);
    color: var(--color-text-secondary);
    line-height: 1.4;
}

.form-link {
    font-size: var(--text-sm);
    color: var(--color-text-muted);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.form-link:hover {
    color: var(--color-primary);
}

.form-link--accent {
    color: var(--color-primary);
    font-weight: 500;
}

/* Optional field label */
.form-optional {
    color: var(--color-text-muted);
    font-weight: 400;
}

.btn-block {
    width: 100%;
}

/* Footer */
.auth-form__footer {
    text-align: center;
    margin-top: var(--space-6);
    color: var(--color-text-secondary);
    font-size: var(--text-sm);
}

/* Back Link (Mobile) */
.auth-back {
    display: none;
    align-items: center;
    gap: var(--space-2);
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: var(--text-sm);
    margin-top: var(--space-6);
    transition: color var(--transition-fast);
}

.auth-back:hover {
    color: var(--color-primary);
}

/* Auth Page Responsive */
@media (max-width: 991px) {
    .auth-container {
        grid-template-columns: 1fr;
    }
    
    .auth-branding {
        display: none;
    }
    
    .auth-back {
        display: flex;
    }
}

@media (max-width: 575px) {
    .auth-form-wrapper {
        padding: var(--space-6);
    }
    
    .auth-form__title {
        font-size: var(--text-2xl);
    }
    
    .form-row-grid {
        grid-template-columns: 1fr;
    }
}

