/**
 * Brain Developer - Back-End Page Styles
 * =======================================
 * Estilos específicos para a página Back-End (Back-End.html).
 * 
 * Depende de: tokens.css, base.css, layout.css, components.css
 */

/* ==========================================
   BACKEND - HERO SECTION
   ========================================== */

.backend-hero {
    background: var(--gradient-backend);
    padding: var(--spacing-16) var(--spacing-4);
    text-align: center;
    position: relative;
    overflow: hidden;
}

.backend-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background:
        radial-gradient(circle at 20% 30%, rgba(16, 185, 129, 0.1), transparent 35%),
        radial-gradient(circle at 80% 70%, rgba(14, 165, 233, 0.08), transparent 35%);
    pointer-events: none;
}

.backend-hero__title {
    font-size: clamp(2rem, 4.5vw, 3rem);
    font-weight: var(--font-weight-extrabold);
    color: var(--color-text-inverse);
    margin-bottom: var(--spacing-4);
    position: relative;
    z-index: 1;
    line-height: var(--line-height-tight);
}

.backend-hero__title span {
    background: linear-gradient(135deg, #6ee7b7 0%, #67e8f9 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.backend-hero__subtitle {
    font-size: var(--font-size-lg);
    color: rgba(255, 255, 255, 0.9);
    max-width: 600px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
    line-height: var(--line-height-relaxed);
}

/* ==========================================
   BACKEND - CORE CONCEPTS
   ========================================== */

.backend-concepts {
    padding: var(--spacing-16) var(--spacing-6);
    background: var(--color-surface-secondary);
}

.backend-concepts__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: var(--spacing-6);
    max-width: 1200px;
    margin: 0 auto;
}

.backend-concept-card {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--spacing-6);
    transition: all var(--transition-smooth);
    position: relative;
}

.backend-concept-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--color-success-500);
    border-radius: var(--radius-xl) var(--radius-xl) 0 0;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--transition-smooth);
}

.backend-concept-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.backend-concept-card:hover::before {
    transform: scaleX(1);
}

.backend-concept-card__icon {
    width: 52px;
    height: 52px;
    background: linear-gradient(135deg, var(--color-success-500), var(--color-success-600));
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-xl);
    color: var(--color-text-inverse);
    margin-bottom: var(--spacing-4);
}

.backend-concept-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-2);
}

.backend-concept-card__description {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

/* ==========================================
   BACKEND - LANGUAGES SECTION
   ========================================== */

.backend-languages {
    padding: var(--spacing-16) var(--spacing-6);
}

.backend-languages__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: var(--spacing-6);
    max-width: 1200px;
    margin: 0 auto;
}

.backend-language-card {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--spacing-6);
    transition: all var(--transition-smooth);
}

.backend-language-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    border-color: var(--lang-color, var(--color-success-400));
}

/* Language color variants */
.backend-language-card--python {
    --lang-color: #3776ab;
}
.backend-language-card--javascript {
    --lang-color: #f7df1e;
}
.backend-language-card--java {
    --lang-color: #ed8b00;
}
.backend-language-card--csharp {
    --lang-color: #239120;
}
.backend-language-card--go {
    --lang-color: #00add8;
}
.backend-language-card--php {
    --lang-color: #777bb4;
}
.backend-language-card--ruby {
    --lang-color: #cc342d;
}
.backend-language-card--rust {
    --lang-color: #dea584;
}

.backend-language-card__header {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    margin-bottom: var(--spacing-4);
}

.backend-language-card__logo {
    width: 56px;
    height: 56px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-2xl);
    background: var(--color-success-50);
    color: var(--color-success-600);
}

.backend-language-card__info h3 {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
}

.backend-language-card__info p {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}

.backend-language-card__description {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
    margin-bottom: var(--spacing-4);
}

.backend-language-card__uses {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-2);
}

.backend-language-card__use {
    background: var(--color-success-50);
    color: var(--color-success-700);
    padding: var(--spacing-1) var(--spacing-3);
    border-radius: var(--radius-md);
    font-size: var(--font-size-xs);
    font-weight: var(--font-weight-medium);
}

/* ==========================================
   BACKEND - DATABASES SECTION
   ========================================== */

.backend-databases {
    padding: var(--spacing-16) var(--spacing-4);
    background: var(--gradient-section-green);
}

.backend-databases__intro {
    text-align: center;
    max-width: 700px;
    margin: 0 auto var(--spacing-10);
}

.backend-databases__categories {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: var(--spacing-6);
    max-width: 1200px;
    margin: 0 auto;
}

.backend-db-category {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--spacing-5);
}

.backend-db-category__header {
    display: flex;
    align-items: center;
    gap: var(--spacing-3);
    margin-bottom: var(--spacing-4);
    padding-bottom: var(--spacing-3);
    border-bottom: 1px solid var(--color-border-subtle);
}

.backend-db-category__icon {
    font-size: var(--font-size-xl);
    color: var(--color-success-500);
}

.backend-db-category__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
}

.backend-db-category__list {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-3);
}

.backend-db-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-3);
    padding: var(--spacing-3);
    background: var(--color-surface-secondary);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
}

.backend-db-item:hover {
    transform: translateX(4px);
    background: var(--color-surface-tertiary);
}

.backend-db-item__logo {
    width: 40px;
    height: 40px;
    background: var(--color-success-50);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
    color: var(--color-success-600);
    flex-shrink: 0;
}

.backend-db-item__info h4 {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-1);
}

.backend-db-item__info p {
    font-size: var(--font-size-xs);
    color: var(--color-text-secondary);
}

/* ==========================================
   BACKEND - APIs SECTION
   ========================================== */

.backend-apis {
    padding: var(--spacing-16) var(--spacing-4);
}

.backend-apis__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--spacing-5);
    max-width: 900px;
    margin: 0 auto;
}

.backend-api-card {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--spacing-5);
    text-align: center;
    transition: all var(--transition-smooth);
}

.backend-api-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.backend-api-card__icon {
    width: 56px;
    height: 56px;
    background: linear-gradient(135deg, var(--color-success-500), var(--color-accent-500));
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-xl);
    color: var(--color-text-inverse);
    margin: 0 auto var(--spacing-4);
}

.backend-api-card__title {
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-2);
}

.backend-api-card__description {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

/* ==========================================
   BACKEND - ARCHITECTURE SECTION
   ========================================== */

.backend-architecture {
    padding: var(--spacing-16) var(--spacing-4);
    background: var(--color-surface-secondary);
}

.backend-architecture__diagram {
    max-width: 800px;
    margin: 0 auto var(--spacing-8);
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--spacing-6);
    display: flex;
    flex-direction: column;
    gap: var(--spacing-4);
}

.backend-architecture__layer {
    display: flex;
    align-items: center;
    gap: var(--spacing-4);
    padding: var(--spacing-4);
    background: var(--color-surface-secondary);
    border-radius: var(--radius-lg);
    border-left: 3px solid var(--layer-color, var(--color-success-500));
}

.backend-architecture__layer--presentation {
    --layer-color: var(--color-accent-500);
}
.backend-architecture__layer--business {
    --layer-color: var(--color-success-500);
}
.backend-architecture__layer--data {
    --layer-color: var(--color-primary-500);
}

.backend-architecture__layer-icon {
    width: 44px;
    height: 44px;
    background: var(--color-success-50);
    border-radius: var(--radius-md);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
    color: var(--color-success-600);
}

.backend-architecture__layer-content h4 {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-1);
}

.backend-architecture__layer-content p {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
}

.backend-architecture__connector {
    text-align: center;
    color: var(--color-text-tertiary);
    font-size: var(--font-size-lg);
}

/* ==========================================
   BACKEND - SECURITY SECTION
   ========================================== */

.backend-security {
    padding: var(--spacing-16) var(--spacing-4);
}

.backend-security__grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--spacing-5);
    max-width: 1100px;
    margin: 0 auto;
}

.backend-security-card {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--spacing-5);
    transition: all var(--transition-smooth);
}

.backend-security-card:hover {
    border-color: var(--color-error-400);
    box-shadow: 0 4px 16px rgba(239, 68, 68, 0.08);
    transform: translateY(-2px);
}

.backend-security-card__icon {
    width: 48px;
    height: 48px;
    background: linear-gradient(135deg, var(--color-error-500), var(--color-error-600));
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--font-size-lg);
    color: var(--color-text-inverse);
    margin-bottom: var(--spacing-4);
}

.backend-security-card__title {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-2);
}

.backend-security-card__description {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    line-height: var(--line-height-relaxed);
}

/* ==========================================
   BACKEND - DEVOPS SECTION
   ========================================== */

.backend-devops {
    padding: var(--spacing-16) var(--spacing-4);
    background: var(--gradient-section-green);
}

.backend-devops__flow {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-3);
    flex-wrap: wrap;
    max-width: 900px;
    margin: 0 auto;
}

.backend-devops__step {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-lg);
    padding: var(--spacing-4);
    text-align: center;
    min-width: 130px;
    transition: all var(--transition-smooth);
}

.backend-devops__step:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
}

.backend-devops__step-icon {
    font-size: var(--font-size-xl);
    margin-bottom: var(--spacing-2);
    color: var(--color-success-500);
}

.backend-devops__step-name {
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-primary);
}

.backend-devops__arrow {
    font-size: var(--font-size-lg);
    color: var(--color-success-400);
}

/* ==========================================
   BACKEND - SALARY SECTION
   ========================================== */

.backend-salary {
    padding: var(--spacing-16) var(--spacing-4);
}

.backend-salary__cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: var(--spacing-5);
    max-width: 900px;
    margin: 0 auto;
}

.backend-salary-card {
    background: var(--color-bg-primary);
    border: 1px solid var(--color-border-subtle);
    border-radius: var(--radius-xl);
    padding: var(--spacing-5);
    text-align: center;
    transition: all var(--transition-smooth);
}

.backend-salary-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    border-color: var(--color-success-400);
}

.backend-salary-card__level {
    font-size: var(--font-size-base);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-primary);
    margin-bottom: var(--spacing-1);
}

.backend-salary-card__experience {
    font-size: var(--font-size-sm);
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-3);
}

.backend-salary-card__value {
    font-size: var(--font-size-2xl);
    font-weight: var(--font-weight-bold);
    background: linear-gradient(135deg, var(--color-success-400), var(--color-success-600));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.backend-salary-card__period {
    font-size: var(--font-size-xs);
    color: var(--color-text-tertiary);
}

/* ==========================================
   RESPONSIVIDADE
   ========================================== */

@media (max-width: 768px) {
    .backend-hero {
        padding: var(--spacing-12) var(--spacing-4);
    }

    .backend-databases__categories {
        grid-template-columns: 1fr;
    }

    .backend-devops__flow {
        flex-direction: column;
    }

    .backend-devops__arrow {
        transform: rotate(90deg);
    }
}
