/* ============================================================
   Legacy bridge — мост между новой BEM-системой и
   существующей разметкой шаблонов Bitrix.
   Цель: позволить старым/смешанным шаблонам получать новый
   визуал без полного переписывания HTML.
   При полной миграции на BEM этот файл будет постепенно
   уменьшаться, а не разрастаться.
   ============================================================ */

/* --- .vacancies-list/.item → стиль .gk-card-list/.gk-card --- */
.vacancies-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--gk-space-10);
    margin-top: var(--gk-space-10);
}

.vacancies-list .item {
    position: relative;
    background: var(--gk-color-surface);
    border-radius: var(--gk-radius-xl);
    padding: var(--gk-space-8) var(--gk-space-7);
    overflow: hidden;
    box-shadow: var(--gk-shadow-card);
    transition: all var(--gk-transition-smooth);
    display: flex;
    flex-direction: column;
}

.vacancies-list .item::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: var(--gk-gradient-stripe-active);
    z-index: 1;
}

.vacancies-list .item::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(24, 41, 104, 0.02) 0%, transparent 100%);
    opacity: 0;
    transition: opacity var(--gk-transition-smooth);
    pointer-events: none;
    border-radius: var(--gk-radius-xl);
}

.vacancies-list .item:hover {
    transform: translateY(-8px);
    box-shadow: var(--gk-shadow-card-hover);
}

.vacancies-list .item:hover::after {
    opacity: 1;
}

.vacancies-list .item .status-pill {
    display: inline-block;
    align-self: flex-start;
    padding: 6px 14px;
    border-radius: var(--gk-radius-pill);
    background: var(--gk-color-bg-pill);
    color: var(--gk-color-accent-indigo-2);
    font-size: 12px;
    font-weight: var(--gk-font-weight-semibold);
    line-height: 1.2;
    margin-bottom: 18px;
}

.vacancies-list .item .archive-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: var(--gk-radius-pill);
    background: var(--gk-color-surface-softer);
    color: var(--gk-color-text-disabled);
    font-size: var(--gk-font-size-eyebrow);
    font-weight: var(--gk-font-weight-semibold);
    line-height: 1.2;
    margin-left: var(--gk-space-2);
    vertical-align: middle;
}

.vacancies-list .item .title-wrap {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    margin-bottom: 18px;
}

.vacancies-list .item .title-wrap .img-wrap {
    width: 56px;
    height: 56px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--gk-radius-lg);
    background: var(--gk-gradient-icon-bg);
    transition: transform var(--gk-transition-default);
}

.vacancies-list .item:hover .title-wrap .img-wrap {
    transform: scale(1.05) rotate(-3deg);
}

.vacancies-list .item .title-wrap .img-wrap img {
    max-width: 60%;
    max-height: 60%;
    object-fit: contain;
}

.vacancies-list .item .title-wrap .title-text {
    flex: 1;
    min-width: 0;
    font-size: var(--gk-font-size-card-title);
    font-weight: var(--gk-font-weight-bold);
    line-height: 1.3;
    color: var(--gk-color-text-heading);
}

.vacancies-list .item .title-wrap .title-text a {
    color: inherit;
    text-decoration: none;
}

.vacancies-list .item .title-wrap .title-text a:hover {
    color: var(--gk-color-accent-blue);
}

.vacancies-list .item .subtitle {
    font-size: var(--gk-font-size-eyebrow);
    font-weight: var(--gk-font-weight-bold);
    text-transform: uppercase;
    letter-spacing: var(--gk-letter-spacing-eyebrow);
    color: var(--gk-color-text-muted);
    margin-bottom: 6px;
}

.vacancies-list .item .text {
    font-size: var(--gk-font-size-card-text);
    line-height: 1.5;
    color: var(--gk-color-text-body);
    margin: 0 0 auto;
}

.vacancies-list .item .date {
    font-size: var(--gk-font-size-meta);
    color: var(--gk-color-text-meta);
    margin-top: 18px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.vacancies-list .item .date::before {
    content: '';
    width: 14px;
    height: 14px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='4' width='18' height='18' rx='2' ry='2'/><line x1='16' y1='2' x2='16' y2='6'/><line x1='8' y1='2' x2='8' y2='6'/><line x1='3' y1='10' x2='21' y2='10'/></svg>");
    background-repeat: no-repeat;
    background-size: contain;
    flex-shrink: 0;
}

.vacancies-list .item .salary {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    padding: 14px 18px;
    margin-top: 18px;
    background: var(--gk-color-surface-soft);
    border-radius: var(--gk-radius-md);
    color: var(--gk-color-brand);
    font-size: var(--gk-font-size-body);
    font-weight: var(--gk-font-weight-medium);
    align-self: flex-start;
}

.vacancies-list .item .salary span {
    font-size: var(--gk-font-size-salary);
    font-weight: var(--gk-font-weight-bold);
}

.vacancies-list .item .more-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: space-between;
    align-items: center;
    margin-top: var(--gk-space-6);
}

.vacancies-list .item .more-wrap .salary {
    margin-top: 0;
}

.vacancies-list .item .more-wrap .btn,
.vacancies-list .item .more-wrap a.detail-link {
    display: inline-flex;
    align-items: center;
    gap: var(--gk-space-2);
    padding: 0;
    height: auto;
    line-height: 1.4;
    border: none;
    background: none;
    color: var(--gk-color-accent-blue);
    font-size: var(--gk-font-size-body);
    font-weight: var(--gk-font-weight-semibold);
    text-decoration: none;
    transition: gap var(--gk-transition-default), color var(--gk-transition-default);
    box-shadow: none;
}

.vacancies-list .item .more-wrap .btn:hover,
.vacancies-list .item .more-wrap a.detail-link:hover {
    color: var(--gk-color-accent-blue-hover);
    gap: var(--gk-space-3);
    background: none;
    border: none;
}

.vacancies-list .item .more-wrap .btn svg,
.vacancies-list .item .more-wrap a.detail-link svg {
    margin: 0;
    width: 16px;
    height: 16px;
    transition: transform var(--gk-transition-default);
}

.vacancies-list .item .more-wrap .btn:hover svg,
.vacancies-list .item .more-wrap a.detail-link:hover svg {
    transform: translateX(3px);
}

.vacancies-list .item .more-wrap .btn svg path {
    fill: currentColor;
}

.vacancies-list .item .archive-notice {
    color: var(--gk-color-text-disabled);
    font-size: var(--gk-font-size-meta);
    font-weight: var(--gk-font-weight-medium);
}

.vacancies-list .item.archived::before,
.vacancies-list .item.closed-contest::before {
    background: var(--gk-gradient-stripe-archived);
}

.vacancies-list .item.archived,
.vacancies-list .item.closed-contest {
    background: var(--gk-color-surface-muted);
}

.vacancies-list .item.archived .title-wrap .img-wrap,
.vacancies-list .item.closed-contest .title-wrap .img-wrap {
    background: var(--gk-gradient-icon-bg-muted);
    filter: grayscale(1);
}

.vacancies-list .item.archived .title-wrap .title-text,
.vacancies-list .item.archived .text,
.vacancies-list .item.archived .salary,
.vacancies-list .item.closed-contest .title-wrap .title-text,
.vacancies-list .item.closed-contest .text,
.vacancies-list .item.closed-contest .salary {
    color: var(--gk-color-text-disabled);
}

.vacancies-list .item.archived .salary,
.vacancies-list .item.closed-contest .salary {
    background: var(--gk-color-surface-softer);
}

/* --- actions-wrap (управление в кабинете) --- */
.vacancies-list .item .actions-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gk-space-2);
    align-items: center;
}

.vacancies-list .item .actions-wrap .btn.p20.gray {
    display: inline-flex;
    align-items: center;
    height: var(--gk-control-height-pill);
    line-height: var(--gk-control-height-pill);
    padding: 0 14px;
    border-radius: var(--gk-radius-pill);
    font-size: var(--gk-font-size-meta);
    font-weight: var(--gk-font-weight-semibold);
    background: var(--gk-color-surface-soft);
    color: var(--gk-color-brand);
    border: none;
    text-decoration: none;
    transition: background var(--gk-transition-fast);
}

.vacancies-list .item .actions-wrap .btn.p20.gray:hover {
    background: var(--gk-color-surface-soft-hover);
    color: var(--gk-color-accent-blue-hover);
}

.vacancies-list .item .toggle-btn {
    display: inline-flex;
    align-items: center;
    height: var(--gk-control-height-pill);
    line-height: var(--gk-control-height-pill);
    padding: 0 14px;
    border-radius: var(--gk-radius-pill);
    font-size: var(--gk-font-size-meta);
    font-weight: var(--gk-font-weight-semibold);
    background: var(--gk-color-success-bg);
    color: var(--gk-color-success-text);
    cursor: pointer;
    transition: background var(--gk-transition-fast), color var(--gk-transition-fast);
    text-decoration: none;
}

.vacancies-list .item .toggle-btn .hover-text {
    display: none;
}

.vacancies-list .item .toggle-btn:hover .text {
    display: none;
}

.vacancies-list .item .toggle-btn:hover .hover-text {
    display: inline;
}

.vacancies-list .item .toggle-btn:hover {
    background: var(--gk-color-success-bg-hover);
}

.vacancies-list .item .toggle-btn.disabled {
    background: var(--gk-color-danger-bg);
    color: var(--gk-color-danger-text);
}

.vacancies-list .item .toggle-btn.disabled:hover {
    background: var(--gk-color-danger-bg-hover);
}

/* --- .searching-hero/.bg-wrap → стиль .gk-hero --- */
.bg-wrap.searching-hero {
    position: relative;
    height: auto;
    min-height: 500px;
    margin-top: -201px;
    padding-top: 280px;
    padding-bottom: var(--gk-space-22);
    overflow: hidden;
    color: var(--gk-color-brand);
    background:
        var(--gk-gradient-hero-glow-1),
        var(--gk-gradient-hero-glow-2),
        var(--gk-gradient-hero-base);
}

/* compact-variant — для подстраниц без отрицательного margin */
.bg-wrap.searching-hero.searching-hero--compact {
    margin-top: var(--gk-space-6);
    padding-top: var(--gk-space-8);
    padding-bottom: var(--gk-space-8);
    min-height: auto;
    border-radius: var(--gk-radius-xl);
    box-shadow: var(--gk-shadow-card-soft);
}

.searching-hero--compact .searching-hero__icon {
    width: 96px;
    height: 96px;
    border-radius: var(--gk-radius-xl);
}

.searching-hero--compact .searching-hero__icon svg {
    width: 64px;
    height: 64px;
}

.searching-hero__decor {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    filter: blur(70px);
    opacity: 0.7;
}

.searching-hero__decor--1 {
    width: 460px;
    height: 460px;
    top: -100px;
    right: -120px;
    background: radial-gradient(circle, var(--gk-color-bg-blob-violet) 0%, transparent 70%);
}

.searching-hero__decor--2 {
    width: 380px;
    height: 380px;
    bottom: -140px;
    left: 5%;
    background: radial-gradient(circle, var(--gk-color-bg-blob-blue) 0%, transparent 70%);
}

.searching-hero__grid {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(24, 41, 104, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(24, 41, 104, 0.05) 1px, transparent 1px);
    background-size: 48px 48px;
    mask-image: radial-gradient(ellipse at center, #000 25%, transparent 70%);
    -webkit-mask-image: radial-gradient(ellipse at center, #000 25%, transparent 70%);
    pointer-events: none;
}

.bg-wrap.searching-hero .content-wrap {
    position: relative;
    z-index: 2;
}

.searching-hero__content {
    display: flex;
    align-items: center;
    gap: 36px;
    flex-wrap: wrap;
}

.searching-hero__icon {
    width: 132px;
    height: 132px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.65);
    border: 1px solid rgba(255, 255, 255, 0.9);
    border-radius: var(--gk-radius-2xl);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    box-shadow: var(--gk-shadow-hero-icon);
    transition: transform var(--gk-transition-smooth);
}

.bg-wrap.searching-hero:hover .searching-hero__icon {
    transform: translateY(-4px) rotate(-2deg);
}

.searching-hero__icon svg {
    width: 88px;
    height: 88px;
}

.searching-hero__text {
    flex: 1;
    min-width: 280px;
    max-width: 620px;
}

.searching-hero__eyebrow {
    display: inline-block;
    padding: 6px 14px;
    border-radius: var(--gk-radius-pill);
    background: var(--gk-color-bg-pill);
    border: 1px solid var(--gk-color-bg-pill-border);
    color: var(--gk-color-accent-indigo-2);
    font-size: 12px;
    font-weight: var(--gk-font-weight-bold);
    letter-spacing: 0.5px;
    text-transform: uppercase;
    margin-bottom: var(--gk-space-4);
}

.searching-hero__subtitle {
    font-size: clamp(16px, 1.4vw, 18px);
    line-height: 1.55;
    color: var(--gk-color-text-body);
    margin: 0;
    width: auto;
    max-width: 580px;
}

@media (max-width: 900px) {
    .bg-wrap.searching-hero {
        min-height: 420px;
        padding-top: 240px;
        padding-bottom: var(--gk-space-15);
    }
    .searching-hero__icon {
        width: 108px;
        height: 108px;
    }
    .searching-hero__icon svg {
        width: 72px;
        height: 72px;
    }
}

@media (max-width: 600px) {
    .bg-wrap.searching-hero {
        min-height: auto;
        padding-top: 220px;
        padding-bottom: 50px;
    }
    .searching-hero__content {
        gap: 22px;
    }
    .searching-hero__icon {
        width: 84px;
        height: 84px;
        border-radius: var(--gk-radius-xl);
    }
    .searching-hero__icon svg {
        width: 56px;
        height: 56px;
    }
    .searching-hero__decor--1,
    .searching-hero__decor--2 {
        opacity: 0.4;
    }
}

/* --- Заголовки страничных блоков --- */
.vacancy-block .page-subtitle,
.contests-block .block-title-wrap,
.profile-page .block-title {
    font-size: clamp(28px, 3vw, 36px);
    font-weight: 800;
    color: var(--gk-color-brand);
    margin-bottom: 28px;
    line-height: 1.15;
}
