/* Professional Legal Theme - Cordoba Legal Group */
/* Строгая юридическая цветовая палитра */

:root {
    /* Primary Colors - Navy & Dark Gray */
    --primary-navy: #1a2332;
    --primary-navy-light: #2d3748;
    --primary-navy-dark: #0f1419;
    
    /* Secondary Colors - Blue */
    --secondary-blue: #2c5282;
    --secondary-blue-light: #3182ce;
    --secondary-blue-dark: #1a365d;
    
    /* Accent Colors - Gold */
    --accent-gold: #c49b5c;
    --accent-gold-light: #d4af6a;
    --accent-gold-dark: #a07d44;
    
    /* Neutral Colors */
    --neutral-white: #ffffff;
    --neutral-gray-50: #f7fafc;
    --neutral-gray-100: #edf2f7;
    --neutral-gray-200: #e2e8f0;
    --neutral-gray-300: #cbd5e0;
    --neutral-gray-400: #a0aec0;
    --neutral-gray-500: #718096;
    --neutral-gray-600: #4a5568;
    --neutral-gray-700: #2d3748;
    --neutral-gray-800: #1a202c;
    --neutral-gray-900: #171923;
    
    /* Semantic Colors */
    --success-green: #2f855a;
    --warning-amber: #d69e2e;
    --error-red: #c53030;
    --info-blue: #2c5282;
}

/* Typography - Professional & Formal */
body {
    color: var(--primary-navy);
    letter-spacing: -0.011em;
}

h1, h2, h3, h4, h5, h6 {
    font-weight: 700;
    letter-spacing: -0.025em;
}

/* Buttons - Corporate Style */
.btn-professional {
    background-color: var(--primary-navy);
    color: var(--neutral-white);
    border: 2px solid var(--primary-navy);
    padding: 0.875rem 2rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    font-size: 0.875rem;
    transition: all 0.3s ease;
}

.btn-professional:hover {
    background-color: var(--primary-navy-light);
    border-color: var(--primary-navy-light);
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(26, 35, 50, 0.2);
}

.btn-professional-outline {
    background-color: transparent;
    color: var(--primary-navy);
    border: 2px solid var(--primary-navy);
}

.btn-professional-outline:hover {
    background-color: var(--primary-navy);
    color: var(--neutral-white);
}

.btn-accent {
    background-color: var(--accent-gold);
    color: var(--primary-navy);
    border: 2px solid var(--accent-gold);
}

.btn-accent:hover {
    background-color: var(--accent-gold-dark);
    border-color: var(--accent-gold-dark);
}

/* Cards - Professional Borders */
.card-professional {
    background-color: var(--neutral-white);
    border: 1px solid var(--neutral-gray-200);
    box-shadow: 0 4px 16px rgba(26, 35, 50, 0.08);
    transition: all 0.3s ease;
}

.card-professional:hover {
    border-color: var(--accent-gold);
    box-shadow: 0 8px 24px rgba(26, 35, 50, 0.12);
    transform: translateY(-4px);
}

.card-professional-accent {
    border-left: 4px solid var(--accent-gold);
}

/* Forms - Clean & Corporate */
.form-professional input,
.form-professional textarea,
.form-professional select {
    border: 1px solid var(--neutral-gray-300);
    background-color: var(--neutral-gray-50);
    color: var(--primary-navy);
    padding: 0.875rem 1rem;
    font-size: 0.9375rem;
}

.form-professional input:focus,
.form-professional textarea:focus,
.form-professional select:focus {
    outline: none;
    border-color: var(--primary-navy);
    background-color: var(--neutral-white);
    box-shadow: 0 0 0 3px rgba(44, 82, 130, 0.1);
}

/* Badges - Professional Tags */
.badge-professional {
    background-color: var(--neutral-gray-100);
    color: var(--primary-navy);
    padding: 0.375rem 0.875rem;
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border: 1px solid var(--neutral-gray-200);
}

.badge-gold {
    background-color: var(--accent-gold);
    color: var(--primary-navy);
    border-color: var(--accent-gold-dark);
}

.badge-success {
    background-color: var(--success-green);
    color: var(--neutral-white);
    border-color: var(--success-green);
}

/* Dividers - Subtle Separators */
.divider-professional {
    height: 1px;
    background: linear-gradient(to right, transparent, var(--neutral-gray-200), transparent);
}

.divider-accent {
    height: 2px;
    background: linear-gradient(to right, transparent, var(--accent-gold), transparent);
}

/* Icons - Corporate Styling */
.icon-professional {
    color: var(--accent-gold);
    font-size: 1.5rem;
}

.icon-circle {
    width: 3rem;
    height: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--neutral-gray-100);
    border: 2px solid var(--neutral-gray-200);
}

.icon-circle-accent {
    background-color: var(--accent-gold);
    border-color: var(--accent-gold-dark);
    color: var(--primary-navy);
}

/* Sections - Professional Backgrounds */
.section-light {
    background-color: var(--neutral-gray-50);
}

.section-white {
    background-color: var(--neutral-white);
}

.section-dark {
    background-color: var(--primary-navy);
    color: var(--neutral-white);
}

.section-gradient {
    background: linear-gradient(135deg, var(--primary-navy) 0%, var(--primary-navy-light) 100%);
}

/* Shadows - Professional Depth */
.shadow-professional {
    box-shadow: 0 4px 20px rgba(26, 35, 50, 0.1);
}

.shadow-professional-lg {
    box-shadow: 0 8px 30px rgba(26, 35, 50, 0.15);
}

/* Borders - Clean Lines */
.border-professional {
    border-color: var(--neutral-gray-200);
}

.border-accent {
    border-color: var(--accent-gold);
}

/* Text Colors - Professional Hierarchy */
.text-professional-primary {
    color: var(--primary-navy);
}

.text-professional-secondary {
    color: var(--neutral-gray-600);
}

.text-professional-accent {
    color: var(--accent-gold);
}

/* Hover Effects - Subtle & Professional */
.hover-lift {
    transition: all 0.3s ease;
}

.hover-lift:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(26, 35, 50, 0.12);
}

/* Legal Document Style */
.legal-text {
    font-size: 0.9375rem;
    line-height: 1.7;
    color: var(--neutral-gray-700);
}

.legal-heading {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--primary-navy);
    margin-top: 2rem;
    margin-bottom: 1rem;
    padding-bottom: 0.5rem;
    border-bottom: 2px solid var(--accent-gold);
}

/* Stats & Numbers - Bold & Clear */
.stat-number {
    font-size: 3rem;
    font-weight: 800;
    color: var(--accent-gold);
    line-height: 1;
}

.stat-label {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--neutral-gray-600);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

/* Testimonials - Professional Quotes */
.testimonial-quote {
    font-style: normal;
    color: var(--neutral-gray-700);
    border-left: 3px solid var(--accent-gold);
    padding-left: 1.5rem;
}

/* Timeline - Corporate Style */
.timeline-item::before {
    background-color: var(--accent-gold);
    border: 3px solid var(--neutral-white);
    box-shadow: 0 0 0 2px var(--accent-gold);
}

/* Progress Bars - Clean & Modern */
.progress-professional {
    background-color: var(--neutral-gray-200);
    height: 3px;
}

.progress-professional-fill {
    background: linear-gradient(90deg, var(--secondary-blue), var(--accent-gold));
    height: 100%;
}

/* Tables - Corporate Data Display */
.table-professional {
    border-collapse: separate;
    border-spacing: 0;
}

.table-professional th {
    background-color: var(--neutral-gray-100);
    color: var(--primary-navy);
    font-weight: 600;
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    padding: 1rem;
    border-bottom: 2px solid var(--neutral-gray-200);
}

.table-professional td {
    padding: 1rem;
    border-bottom: 1px solid var(--neutral-gray-200);
    color: var(--neutral-gray-700);
}

.table-professional tr:hover {
    background-color: var(--neutral-gray-50);
}

/* Animations - Subtle & Professional */
@keyframes professionalFadeIn {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.animate-professional {
    animation: professionalFadeIn 0.6s ease-out;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
    .stat-number {
        font-size: 2rem;
    }
    
    .btn-professional {
        padding: 0.75rem 1.5rem;
        font-size: 0.8125rem;
    }
}