:root {
    --bg-body: #f0f2f5;
    --bg-card: #ffffff;
    --text-main: #1c1e21;
    --text-secondary: #555555;
    --text-muted: #999999;
    --accent-color: #007bff;
    --accent-hover: #0069d9;
    --border-color: #e1e4e8;
    --shadow-color: rgba(0,0,0,0.02);
    --tag-bg: #f8f9fa;
    --tag-border: #e9ecef;
    --timeline-line: #e9ecef;
    --input-bg: #f8f9fa;
    --badge-bg: rgba(255, 255, 255, 0.9);
    --badge-icon: #007bff;
    --btn-sec-bg: #e7f1ff;
    --btn-sec-text: #007bff;
    --btn-sec-hover: #dbeafe;
    --grid-color: rgba(0, 0, 0, 0.09); 
    --grid-spacing: 24px;
}
[data-theme="dark"] {
    --bg-body: #121212;
    --bg-card: #1e1e1e;
    --text-main: #e4e6eb;
    --text-secondary: #b0b3b8;
    --text-muted: #6c757d;
    --accent-color: #4dabf7; 
    --accent-hover: #339af0;
    --border-color: #2d2d2d;
    --shadow-color: rgba(0,0,0,0.2);
    --tag-bg: #2d2d2d;
    --tag-border: #333;
    --timeline-line: #333;
    --input-bg: #2d2d2d;
    --badge-bg: rgba(30, 30, 30, 0.9);
    --badge-icon: #4dabf7;
    --btn-sec-bg: #2d2d2d;
    --btn-sec-text: #4dabf7;
    --btn-sec-hover: #383838;
    --grid-color: rgba(255, 255, 255, 0.09);
}
body {
    background: var(--bg-body);
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
    margin: 0;
    padding: 40px;
    color: var(--text-main);
    transition: background 0.3s ease, color 0.3s ease;
}
script + body {
    transition: none !important;
}
.main-container {
    max-width: 1200px;
    margin: 0 auto;
}
.page-layout {
    display: flex;
    gap: 30px;
    align-items: flex-start;
}
#profile-panel {
    width: 30%;
    position: sticky;
    top: 40px;
}
.profile-card {
    background-color: var(--bg-card);
    padding: 30px;
    border-radius: 12px;
    text-align: center;
    border: 1px solid var(--border-color);
    box-shadow: 0 2px 10px var(--shadow-color);
    position: relative; 
    transition: background-color 0.3s ease, border-color 0.3s ease;
}
.theme-toggle-btn {
    position: absolute;
    top: 15px;
    right: 15px;
    background: transparent;
    border: none;
    cursor: pointer;
    color: var(--text-secondary);
    padding: 5px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
}
.theme-toggle-btn:hover {
    background-color: var(--tag-bg);
    color: var(--accent-color);
}
.theme-toggle-btn svg {
    width: 22px;
    height: 22px;
}

/* ЭФФЕКТ КОЛЬЦА ВОКРУГ АВАТАРА */
.profile-image-container {
    width: 140px;
    height: 140px;
    margin: 0 auto 20px;
    border-radius: 50%;
    position: relative;
    border: 2px solid var(--border-color); 
    padding: 4px; 
    box-sizing: border-box; 
    background-color: var(--bg-card); 
    transition: all 0.3s ease;
}
.profile-avatar {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
    display: block;
}

#profile-panel h1 {
    font-size: 26px;
    margin: 10px 0 5px;
    color: var(--text-main);
    letter-spacing: -0.5px;
}
.profile-title {
    color: var(--accent-color);
    font-weight: 500;
    margin: 0 0 10px;
    font-size: 15px;
}
.profile-details-list {
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: center;
}
.profile-detail-item {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    color: var(--text-secondary);
    font-size: 14px;
}
.profile-detail-item svg {
    width: 16px;
    height: 16px;
    opacity: 0.8;
}
.profile-bio {
    font-size: 14px;
    color: var(--text-secondary);
    line-height: 1.5;
    margin-bottom: 25px;
}
.social-links {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-bottom: 25px;
}
.social-btn {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background-color: var(--tag-bg);
    border: 1px solid var(--border-color);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    transition: all 0.2s;
    cursor: pointer;
    text-decoration: none;
}
.social-btn:hover {
    background-color: var(--accent-color);
    border-color: var(--accent-color);
    color: white;
    transform: translateY(-2px);
}
.social-btn svg {
    width: 20px;
    height: 20px;
}
.social-btn[title="GitHub"] svg,
.social-btn[title="Email"] svg,
.social-btn[title="Figma"] svg {
    width: 24px;
    height: 24px;
}
.action-buttons-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 10px;
}
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 24px;
    font-size: 16px;
    font-weight: 600;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.2s ease;
    border: none;
    width: 100%;
    line-height: 1.5;
    font-family: inherit;
    box-sizing: border-box;
    text-decoration: none; 
}
.btn-primary {
    background-color: var(--accent-color);
    color: white;
}
.btn-primary:hover {
    background-color: var(--accent-hover);
    box-shadow: 0 4px 12px rgba(0, 123, 255, 0.3);
    transform: translateY(-1px);
}
.btn-secondary {
    background-color: var(--btn-sec-bg);
    color: var(--btn-sec-text);
}
.btn-secondary:hover {
    background-color: var(--btn-sec-hover);
    transform: translateY(-1px);
}
#content-panel {
    width: 67%;
    display: flex;
    flex-direction: column;
    gap: 24px;
}
.content-block {
    width: 100%;
    background-color: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    box-shadow: 0 2px 10px var(--shadow-color);
    box-sizing: border-box;
    color: var(--text-secondary);
    font-size: 15px;
    overflow: hidden;
    padding-bottom: 24px;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}
.block-header {
    display: flex;
    align-items: center;
    padding: 20px 24px;
    font-weight: 700;
    font-size: 18px;
    color: var(--text-main);
    background-color: var(--bg-card);
    border-bottom: 1px solid var(--bg-body);
    margin-bottom: 20px;
    transition: background-color 0.3s ease, border-color 0.3s ease;
}
.header-icon-wrapper {
    width: 32px;
    height: 32px;
    background: var(--btn-sec-bg);
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 15px;
    color: var(--accent-color);
}
.header-icon-wrapper svg {
    width: 22px;
    height: 22px;
}
.block-content {
    padding: 0 24px;
}
.about-text p {
    margin-bottom: 15px;
    line-height: 1.6;
    color: var(--text-main);
}
.about-text p:last-child {
    margin-bottom: 0;
}
.text-highlight {
    font-weight: 750;
}
.tags-cloud {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid var(--bg-body);
}
.tag-chip {
    background-color: var(--tag-bg);
    color: var(--text-secondary);
    padding: 6px 14px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    border: 1px solid var(--tag-border);
    transition: all 0.2s ease;
    cursor: default;
}
.tag-chip:hover {
    background-color: var(--btn-sec-bg);
    color: var(--accent-color);
    border-color: var(--accent-color);
    transform: translateY(-1px);
}
.timeline {
    position: relative;
    margin-top: 10px;
}
.timeline::before {
    content: '';
    position: absolute;
    top: 5px;
    bottom: 0;
    left: 9px; 
    width: 2px;
    background-color: var(--timeline-line);
}
.timeline-item {
    position: relative;
    padding-left: 40px; 
    margin-bottom: 35px;
}
.timeline-item:last-child {
    margin-bottom: 0;
}
.timeline-marker {
    position: absolute;
    left: 0;
    top: 0; 
    width: 14px;
    height: 14px;
    background-color: var(--bg-card);
    border: 3px solid var(--accent-color);
    border-radius: 50%;
    z-index: 2;
    box-shadow: 0 0 0 4px var(--bg-card); 
}
.timeline-content {
    position: relative;
    top: -3px; 
}
.timeline-date {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    color: var(--accent-color);
    background-color: var(--btn-sec-bg);
    padding: 3px 10px;
    border-radius: 4px;
    margin-bottom: 8px;
}
.timeline-title {
    margin: 0 0 5px 0;
    font-size: 16px;
    font-weight: 700;
    color: var(--text-main);
}
.timeline-subtitle {
    font-size: 14px;
    font-weight: 600;
    color: var(--text-secondary);
    margin-bottom: 8px;
}

/* Исправленные отступы таймлайна */
.timeline-content p {
    margin: 0 0 12px 0; 
    font-size: 14px;
    line-height: 1.5;
    color: var(--text-secondary);
}
.timeline-content p:last-child {
    margin-bottom: 0;
}

.projects-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(min(100%, 340px), 1fr)); 
    gap: 20px;
}
.project-card {
    border: 1px solid var(--border-color);
    border-radius: 10px;
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s, background-color 0.3s;
    background: var(--bg-card);
    display: flex;       
    flex-direction: column; 
}
.project-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 20px var(--shadow-color);
    border-color: var(--accent-color);
}
.project-thumb {
    width: 100%;
    aspect-ratio: 3 / 2;
    background-color: var(--tag-bg);
    position: relative; 
}
.project-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.project-info {
    padding: 15px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex-grow: 1;
}

/* Жестко задаем блочное отображение, чтобы убить любой случайный flexbox на заголовке */
.project-info h4 {
    display: block !important; 
    margin: 0 0 12px 0;
    font-size: 16px; 
    color: var(--text-main); 
    font-weight: 600;
}

/* Класс для склейки последнего слова и стрелки */
.title-nowrap {
    white-space: nowrap;
}

.project-link-icon {
    display: inline-block; 
    width: 16px; 
    height: 16px;
    margin-left: 6px; 
    color: var(--text-muted); 
    vertical-align: middle; 
    position: relative;
    top: 0px; 
    transition: all 0.2s ease; 
}
.project-card:hover .project-link-icon {
    color: var(--accent-color); 
    transform: translateX(5px); 
}
.project-tags-row {
    display: flex;
    flex-wrap: wrap;
    gap: 6px; 
}
.project-tag { 
    font-size: 11px; 
    color: var(--accent-color); 
    background: var(--btn-sec-bg); 
    padding: 4px 10px; 
    border-radius: 20px; 
    font-weight: 600;
    display: inline-block;
    white-space: nowrap;
}

.modal-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.7);
    backdrop-filter: blur(4px);
    display: flex;
    justify-content: center;
    align-items: center; 
    z-index: 1000;
    padding: 20px 12px 20px 12px; 
    box-sizing: border-box; 
}
.modal-content {
    background-color: var(--bg-card);
    border-radius: 16px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.3);
    width: 100%; 
    max-width: 1024px;
    max-height: 90vh; 
    display: flex;
    flex-direction: column; 
    padding: 0; 
    overflow: hidden; 
    animation: slideUp 0.3s ease;
    box-sizing: border-box;
    position: relative;
    color: var(--text-main);
}
@keyframes slideUp {
    from { transform: translateY(20px); opacity: 0; }
    to { transform: translateY(0); opacity: 1; }
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 30px 30px 20px 30px;
    flex-shrink: 0;
}

#modal-title {
    margin: 0;
    padding: 0; 
    font-size: 22px;
    line-height: 1.3;
    color: var(--text-main);
}
.modal-body-content {
    margin: 0;
    padding: 0 30px 10px 30px; 
    overflow-y: auto; 
    flex-grow: 1; 
    scrollbar-width: thin;
    scrollbar-color: var(--accent-color) var(--tag-bg);
}





/* --- НАДЕЖНЫЙ СИНИЙ СКРОЛЛБАР (БЕЗ КОНФЛИКТОВ) --- */

/* 1. Настройки скролла ТОЛЬКО для Firefox (где нет поддержки webkit) */
@supports not (selector(::-webkit-scrollbar)) {
    #project-modal .modal-content {
        scrollbar-width: thin;
        scrollbar-color: var(--badge-icon) transparent;
    }
}

/* 2. Общие настройки контейнера модалки */
#project-modal .modal-content {
    overflow-y: auto;
    overflow-x: hidden;
    /* Хак для WebKit: заставляет браузер обрезать контент строго по border-radius */
    -webkit-mask-image: -webkit-radial-gradient(white, black); 
}

/* 3. НАСТРОЙКИ ДЛЯ CHROME / SAFARI / EDGE (ДЕСКТОП) */
@media (min-width: 769px) {
    #project-modal .modal-content::-webkit-scrollbar {
        width: 6px; /* Ширина синей линии */
    }

    /* Полностью убираем стрелочки (теперь это сработает на 100%!) */
    #project-modal .modal-content::-webkit-scrollbar-button {
        display: none !important;
        height: 0 !important;
        width: 0 !important;
    }

    /* Прозрачный трек с отступом от краев */
    #project-modal .modal-content::-webkit-scrollbar-track {
        background: transparent;
        margin: 16px 0; /* Отступ от скруглений модалки */
    }

    /* Синий ползунок */
    #project-modal .modal-content::-webkit-scrollbar-thumb {
        background-color: var(--badge-icon);
        border-radius: 10px;
    }
}






.modal-buttons {
    display: flex;
    gap: 15px;
    justify-content: flex-end;
    padding: 20px 30px 30px 30px; 
    flex-shrink: 0; 
    background-color: var(--bg-card); 
    border-top: 1px solid var(--border-color); 
    z-index: 2;
}

/* ========================================= */
/* SKELETON ANIMATION & IMAGES               */
/* ========================================= */

@keyframes skeleton-pulse {
    0% { background-color: var(--tag-bg); }
    50% { background-color: var(--border-color); }
    100% { background-color: var(--tag-bg); }
}

/* Базовые стили для главной обложки модалки */
#modal-image {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    border-radius: 8px;
    margin-bottom: 20px;
    background-color: var(--tag-bg);
    display: block;
    box-shadow: none; /* Убрали грязную тень */
    border: 1px solid var(--border-color); /* Чистая флэт-рамка */
}

/* Стили для галереи (если включена) */
.splide__slide img {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    object-fit: cover;
    border-radius: 8px;
    display: block;
    background-color: var(--tag-bg);
}

/* Единый класс для всех картинок внутри текстов кейсов */
.content-img {
    width: 100%;
    height: auto;
    border-radius: 8px;
    border: 1px solid var(--border-color); /* Чистая флэт-рамка */
    box-shadow: none; /* Убрали грязную тень */
    display: block;
    margin: 0; /* Отступы теперь контролируются через flex-gap */
    color: transparent; 
    background-color: var(--tag-bg);
}

/* Скелетон включается, пока нет класса .loaded */
#modal-image:not(.loaded),
.splide__slide img:not(.loaded),
.content-img:not(.loaded) {
    animation: skeleton-pulse 1.5s infinite ease-in-out;
    color: transparent;
}

/* Кастомная обложка только для CRM */
#project-modal[data-project="crm"] #modal-image {
    border-radius: 8px;
    border: 1px solid var(--border-color); /* Такая же флэт-рамка */
    box-shadow: none; /* Убрали тень */
}
/* ========================================= */

@media (max-width: 480px) {
    /* Возвращаем кнопкам формы контактов 50/50 ширину на мобильных */
    #contact-modal .modal-buttons .btn {
        width: 100% !important;
        flex: 1;
    }
    #contact-modal .modal-buttons{
        padding: 15px 0px 20px 0px !important;
    }
    
    .modal-content {
        margin: 0 auto;
        max-height: 90vh;
        padding: 0 !important;
    }
    .modal-header { padding: 20px 20px 10px 20px !important; }
    #modal-title { padding: 0 !important; }
    .modal-body-content { padding: 0 20px 10px 20px !important; }
    .modal-buttons { padding: 15px 20px 20px 20px !important; flex-direction: row !important; flex-wrap: nowrap; gap: 10px !important; }
    .modal-buttons .btn { width: auto !important; margin-left: 0; }
    .modal-buttons a.btn { order: 1; }
    #close-modal-btn { display: none; }
    
    #contact-modal .contact-form { padding: 0 20px 20px 20px !important; }
    .modal-body-content > * { margin-right: 0 !important; }
    
    #project-github-btn { width: 48px !important; height: 48px !important; padding: 0 !important; font-size: 0 !important; gap: 0 !important; order: 2; background-color: var(--tag-bg); color: var(--text-main); flex-shrink: 0; }
    #project-figma-btn { width: 48px !important; height: 48px !important; padding: 0 !important; font-size: 0 !important; gap: 0 !important; order: 1; background-color: var(--tag-bg); color: var(--text-main); flex-shrink: 0; }
    #project-link-btn { flex-grow: 1; order: 3; }
    #project-github-btn svg, #project-figma-btn svg { width: 24px; height: 24px; margin: 0; }
    .footer-row { flex-direction: column; gap: 5px; }
    .site-footer { text-align: center; align-items: center; padding-bottom: 20px; }
}

#gallery-container:not(.is-active) { visibility: hidden; }

.slide-caption {
    margin-top: 10px;
    font-size: 14px;
    color: var(--text-secondary);
    text-align: center;
    background: var(--tag-bg);
    padding: 8px 12px;
    border-radius: 6px;
    line-height: 1.4;
}
.splide__pagination__page.is-active { background: var(--accent-color) !important; transform: scale(1.2); }
.splide__pagination__page { background: var(--text-muted) !important; opacity: 1 !important; }
.splide__arrows { position: absolute; top: 0; left: 0; width: 100%; height: 0; padding-bottom: 66.666%; pointer-events: none; z-index: 1; }
.splide__arrow { top: 50% !important; transform: translateY(-50%) !important; background: var(--badge-bg) !important; opacity: 1 !important; box-shadow: 0 2px 5px rgba(0,0,0,0.1); pointer-events: auto; }
.splide__arrow svg { fill: var(--badge-icon) !important; }
.gallery-badge { position: absolute; top: 10px; right: 10px; background-color: var(--badge-bg); color: var(--badge-icon); width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center; box-shadow: 0 2px 8px rgba(0,0,0,0.15); z-index: 2; transition: transform 0.2s ease; }
.project-card:hover .gallery-badge { transform: scale(1.1); }
.gallery-badge svg { width: 18px; height: 18px; }
.splide__pagination { position: relative !important; bottom: auto !important; margin-top: 15px !important; padding: 0 !important; }
#gallery-container { padding-bottom: 10px; overflow: visible !important; }
.contact-form { display: flex; flex-direction: column; gap: 15px; }
.form-group { width: 100%; }
.form-input { width: 100%; padding: 14px; border: 1px solid var(--border-color); background-color: var(--input-bg); border-radius: 10px; font-family: inherit; font-size: 15px; color: var(--text-main); outline: none; transition: all 0.2s ease; box-sizing: border-box; resize: none; }
.form-input:focus { border-color: var(--accent-color); background-color: var(--bg-card); box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1); }
.form-input::placeholder { color: var(--text-muted); }
#modal-description p { margin-bottom: 10px; line-height: 1.6; }
#modal-description ul { margin-bottom: 15px; list-style-type: disc; }
#modal-description li { margin-bottom: 5px; color: var(--text-secondary); line-height: 1.5; }
#modal-description b { font-weight: 600; color: var(--text-main); }
.policy-text { font-size: 13px; color: var(--text-muted); margin-top: 10px; text-align: center; line-height: 1.3; }
.policy-text a { color: var(--text-muted); text-decoration: underline; transition: color 0.2s; }
.policy-text a:hover { color: var(--accent-color); }
.site-footer { margin-top: 20px; padding-top: 20px; border-top: 1px solid var(--border-color); color: var(--text-muted); font-size: 13px; display: flex; flex-direction: column; gap: 8px; }
.footer-row { display: flex; gap: 20px; flex-wrap: wrap; }
@media (max-width: 900px) { body { padding: 20px; } .page-layout { flex-direction: column; gap: 20px; } #profile-panel { width: 100%; position: static; margin-bottom: 10px; } #content-panel { width: 100%; } .project-card:hover { transform: none; } }
.useful-links-accordion { margin-top: 30px; border-top: 1px solid var(--border-color); padding-top: 20px; }
.accordion-summary { display: flex; align-items: center; justify-content: space-between; cursor: pointer; list-style: none; padding: 10px 0; font-weight: 600; color: var(--text-main); transition: color 0.2s; }
.accordion-summary::-webkit-details-marker { display: none; }
.accordion-summary:hover { color: var(--accent-color); }
.summary-content { display: flex; align-items: center; gap: 10px; }
.summary-icon { width: 20px; height: 20px; color: var(--accent-color); }
.chevron-icon { width: 18px; height: 18px; transition: transform 0.3s ease; color: var(--text-muted); }
details[open] .chevron-icon { transform: rotate(180deg); }
.links-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 15px; margin-top: 15px; animation: slideDown 0.3s ease-out; }
@keyframes slideDown { from { opacity: 0; transform: translateY(-10px); } to { opacity: 1; transform: translateY(0); } }
.link-card { display: flex; align-items: flex-start; gap: 12px; padding: 15px; background-color: var(--tag-bg); border: 1px solid var(--border-color); border-radius: 10px; text-decoration: none; transition: all 0.2s ease; }
.link-card:hover { background-color: var(--bg-card); border-color: var(--accent-color); transform: translateY(-2px); box-shadow: 0 4px 12px var(--shadow-color); }
.link-icon-wrapper { font-size: 24px; line-height: 1; flex-shrink: 0; }
.link-img { width: 24px; height: 24px; object-fit: contain; }
.link-info h4 { margin: 0 0 4px 0; font-size: 14px; font-weight: 700; color: var(--text-main); }
.link-info p { margin: 0; font-size: 12px; line-height: 1.4; color: var(--text-secondary); }
.icon-sun { display: none; }
.icon-moon { display: block; }
[data-theme="dark"] .icon-sun { display: block; }
[data-theme="dark"] .icon-moon { display: none; }
#contact-modal .contact-form { padding: 0 30px 30px 30px; overflow-y: auto; flex-grow: 1; scrollbar-width: thin; scrollbar-color: var(--accent-color) var(--tag-bg); }
#contact-modal .contact-form::-webkit-scrollbar { width: 6px; }
#contact-modal .contact-form::-webkit-scrollbar-track { background: var(--tag-bg); border-radius: 3px; }
#contact-modal .contact-form::-webkit-scrollbar-thumb { background-color: var(--text-secondary); border-radius: 10px; opacity: 0.5; }
#contact-modal .modal-buttons { padding: 20px 0px 15px 0px; }
.social-btn { position: relative; }
.copy-tooltip { position: absolute; bottom: 125%; left: 50%; transform: translateX(-50%) translateY(10px); background-color: var(--text-main); color: var(--bg-card); padding: 6px 12px; border-radius: 6px; font-size: 12px; font-weight: 600; white-space: nowrap; pointer-events: none; opacity: 0; visibility: hidden; transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55); box-shadow: 0 4px 10px rgba(0,0,0,0.1); z-index: 10; }
.copy-tooltip::after { content: ''; position: absolute; top: 100%; left: 50%; margin-left: -5px; border-width: 5px; border-style: solid; border-color: var(--text-main) transparent transparent transparent; }
.social-btn.copied .copy-tooltip { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(0); }
.modal-close-icon { background: transparent; border: none; cursor: pointer; color: var(--text-muted); padding: 5px; margin: -5px -5px 0 15px; z-index: 10; transition: color 0.2s; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.modal-close-icon:hover { color: var(--text-main); }
.modal-close-icon svg { width: 24px; height: 24px; padding-top: 4px; }
.stack-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; margin-bottom: 20px; }
.stack-card { background-color: var(--tag-bg); border: 1px solid var(--border-color); border-radius: 12px; padding: 16px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; transition: all 0.2s ease; cursor: default; text-align: center; }
.stack-card:hover { background-color: var(--bg-card); border-color: var(--accent-color); transform: translateY(-3px); box-shadow: 0 4px 12px var(--shadow-color); }
.stack-icon-wrapper { width: 42px; height: 42px; display: flex; align-items: center; justify-content: center; border-radius: 10px; padding: 6px; }
.stack-card img { width: 100%; height: 100%; object-fit: contain; }
.stack-name { font-size: 13px; font-weight: 600; color: var(--text-main); line-height: 1.3; }
@media (max-width: 400px) { .stack-grid { grid-template-columns: repeat(2, 1fr); } }
.link-card .stack-icon { width: 32px; height: 32px; object-fit: contain; flex-shrink: 0; }


/* ИНТЕРАКТИВНЫЙ СЛАЙДЕР ДО/ПОСЛЕ */
img-comparison-slider {
    outline: none;
    
    /* Делаем линию-разделитель нейтральной белой с легкой прозрачностью */
    --divider-width: 2px;
    --divider-color: var(--accent-color);
    
    /* Стилизуем родной аккуратный ползунок (поддерживает Dark Mode) */
    --default-handle-color: var(--text-main); /* Цвет стрелочек */
    --default-handle-bg-color: var(--bg-card);     /* Цвет кружка */
    --default-handle-width: 44px;                  /* Размер кружка */
    --default-handle-shadow: 0 4px 16px rgba(0, 0, 0, 0.15); /* Мягкая тень */
    
    width: 100%;
    border-radius: 8px;
    border: 1px solid var(--border-color);
    box-shadow: none;
    display: block;
    margin: 0;
    background-color: var(--tag-bg);
}

img-comparison-slider img {
    width: 100%;
    height: auto;
    display: block;
}

@media (max-width: 768px) {
    /* Скрываем стрелки для Fancybox v4 и v5 на мобильных */
    .fancybox__nav,
    .carousel__button.is-prev,
    .carousel__button.is-next,
    .f-button.is-prev,
    .f-button.is-next {
        display: none !important;
    }
}

/* Переносим скролл на всё окно проекта, чтобы кнопки ушли в самый низ */
#project-modal .modal-content {
    overflow-y: auto;
    overflow-x: hidden;
}

/* Фиксируем шапку, чтобы крестик всегда был под рукой */
#project-modal .modal-header {
    position: sticky;
    top: 0;
    background-color: var(--bg-card); /* Чтобы контент не просвечивал при скролле */
    z-index: 20; 
}

/* Убираем внутренний скролл у текста */
#project-modal .modal-body-content {
    overflow-y: visible;
}

/* Убираем жесткую линию у кнопок, так как теперь они органичное продолжение текста */
#project-modal .modal-buttons {
    border-top: none;
    padding-top: 10px;
}
/* ========================================= */
/* NOTION-STYLE LAYOUT ДЛЯ КЕЙСОВ            */
/* ========================================= */

.case-wrapper {
    display: flex;
    flex-direction: column;
    gap: 32px;
    padding-top: 10px;
}

.case-section {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Заголовки с легкой линией снизу (как в Notion) */
.case-h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--text-main);
    margin: 16px 0 0 0;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--border-color);
}

.case-p {
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-secondary);
    margin: 0;
}

/* Callout-блоки (выделенный фон с иконкой) */
.case-callout {
    display: flex;
    gap: 14px;
    padding: 16px 20px;
    background-color: var(--tag-bg);
    border-radius: 8px;
    border: 1px solid var(--border-color);
    font-size: 15px;
    line-height: 1.6;
    color: var(--text-secondary);
}

.case-callout-icon {
    font-size: 20px;
    line-height: 1.2;
    flex-shrink: 0;
}

/* Цитаты с цветной полоской слева */
.case-quote {
    padding-left: 16px;
    border-left: 3px solid var(--accent-color);
    font-style: italic;
    color: var(--text-secondary);
    font-size: 15px;
    margin: 0;
    background: transparent;
}

/* Списки */
.case-list {
    margin: 0;
    padding-left: 20px;
    color: var(--text-secondary);
    line-height: 1.6;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* Сетка метрик (базовая для десктопа) */
.case-metrics-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
}

.case-metric-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 12px;
    padding: 20px;
    text-align: center;
    box-shadow: 0 2px 8px var(--shadow-color);
}

.case-metric-val {
    font-size: 28px;
    font-weight: 800;
    color: var(--accent-color);
    line-height: 1;
}

.case-metric-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--text-secondary);
    margin-top: 8px;
    line-height: 1.4;
}

/* Адаптив для мобильных */
@media (max-width: 600px) {
    /* По дефолту для 3-х карточек: 2 сверху, 1 снизу */
    .case-metrics-grid {
        grid-template-columns: repeat(2, 1fr); 
    }
    
    .case-metric-card:last-child {
        grid-column: span 2; 
    }

    /* УМНАЯ СЕТКА: Если в контейнере ровно 2 карточки (Quantity Query) */
    .case-metrics-grid:has(.case-metric-card:nth-child(2):last-child) {
        grid-template-columns: 1fr; /* Выстраиваем строго в 1 колонку */
    }
    
    /* Сбрасываем растягивание для последней карточки в сетке из 2-х элементов */
    .case-metrics-grid:has(.case-metric-card:nth-child(2):last-child) .case-metric-card:last-child {
        grid-column: span 1; 
    }
}

/* Подписи к картинкам (серые, по центру) */
.case-caption {
    font-size: 13px;
    color: var(--text-muted);
    text-align: center;
    margin: -8px 0 0 0;
}

/* Переопределяем отступы у картинок внутри кейсов, так как gap делает это за нас */
.case-wrapper .content-img {
    margin: 0;
}

.case-divider {
    height: 1px;
    background-color: var(--border-color);
    border: none;
    margin: 0;
}

/* ========================================= */
/* FIGMA-ПАСХАЛКИ И ПОДСВЕТКА СЕТКИ           */
/* ========================================= */

.interactive-layer {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: -1;
    pointer-events: none;
    -webkit-mask-image: radial-gradient(350px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), black 0%, transparent 100%);
    mask-image: radial-gradient(350px circle at var(--mouse-x, 50%) var(--mouse-y, 50%), black 0%, transparent 100%);
}

.bg-grid {
    position: absolute;
    width: 100%;
    height: 100%;
    background-image: radial-gradient(var(--grid-color) 1.5px, transparent 1.5px);
    background-size: var(--grid-spacing) var(--grid-spacing);
}

.figma-easter-egg {
    position: absolute;
    width: 160px;
    height: 136px;
    padding: 26px 14px 10px 14px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-align: center;
    box-sizing: border-box;

    /* Использование твоей идеальной SVG-рамки Figma */
    background-image: url("data:image/svg+xml,%3Csvg id='_Слой_1' xmlns='http://www.w3.org/2000/svg' version='1.1' viewBox='0 0 160 136'%3E%3Cdefs%3E%3Cstyle%3E.st0%7Bfill:%239747ff;%7D%3C/style%3E%3C/defs%3E%3Cpath class='st0' d='M145,1h-10V0h10v1ZM130,1h-10V0h10v1ZM115,1h-10V0h10v1ZM100,1h-10V0h10v1ZM85,1h-10V0h10v1ZM70,1h-10V0h10v1ZM55,1h-10V0h10v1ZM40,1h-10V0h10v1ZM25,1h-10V0h10v1Z'/%3E%3Cpath class='st0' d='M145,136h-10v-1h10v1ZM130,136h-10v-1h10v1ZM115,136h-10v-1h10v1ZM100,136h-10v-1h10v1ZM85,136h-10v-1h10v1ZM70,136h-10v-1h10v1ZM55,136h-10v-1h10v1ZM40,136h-10v-1h10v1ZM25,136h-10v-1h10v1Z'/%3E%3Cg%3E%3Crect class='st0' y='15.58' width='1' height='10.52'/%3E%3Crect class='st0' y='31.3' width='1' height='10.52'/%3E%3Crect class='st0' y='47.02' width='1' height='10.52'/%3E%3Crect class='st0' y='62.75' width='1' height='10.52'/%3E%3Crect class='st0' y='78.47' width='1' height='10.52'/%3E%3Crect class='st0' y='94.19' width='1' height='10.52'/%3E%3Crect class='st0' y='109.91' width='1' height='10.52'/%3E%3C/g%3E%3Cg%3E%3Crect class='st0' x='159' y='15.58' width='1' height='10.52'/%3E%3Crect class='st0' x='159' y='31.3' width='1' height='10.52'/%3E%3Crect class='st0' x='159' y='47.02' width='1' height='10.52'/%3E%3Crect class='st0' x='159' y='62.75' width='1' height='10.52'/%3E%3Crect class='st0' x='159' y='78.47' width='1' height='10.52'/%3E%3Crect class='st0' x='159' y='94.19' width='1' height='10.52'/%3E%3Crect class='st0' x='159' y='109.91' width='1' height='10.52'/%3E%3C/g%3E%3Cpath class='st0' d='M9.86,136h-4.97c-2.7,0-4.89-2.19-4.89-4.89v-5.41h.96v5.41c0,2.16,1.76,3.92,3.93,3.92h4.97v.96Z'/%3E%3Cpath class='st0' d='M150.14,136h4.97c2.7,0,4.89-2.19,4.89-4.89v-5.41s-.96,0-.96,0v5.41c0,2.16-1.76,3.92-3.93,3.92h-4.97s0,.96,0,.96Z'/%3E%3Cpath class='st0' d='M9.86,0h-4.97C2.19,0,0,2.19,0,4.89v5.41h.96v-5.41C.96,2.72,2.72.96,4.89.96h4.97v-.96Z'/%3E%3Cpath class='st0' d='M150.14,0h4.97c2.7,0,4.89,2.19,4.89,4.89v5.41h-.96v-5.41c0-2.16-1.76-3.92-3.93-3.92h-4.97v-.96Z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    
    /* Деликатная заливка 2% фирменным пурпурным */
    background-color: rgba(151, 71, 255, 0.02);
}

.figma-easter-egg::before {
    content: attr(data-name);
    position: absolute;
    top: -20px;
    left: 0;
    color: #9747FF;
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.2px;
    white-space: nowrap;
}

.figma-easter-egg svg {
    width: 44px;
    height: 44px;
    display: block;
    flex-shrink: 0;
}

.figma-easter-egg .cute-text {
    font-size: 12px;
    color: var(--text-secondary);
    line-height: 1.4;
    font-weight: 400;
}

/* Скрываем пасхалки на экранах уже 1200px (мобильные/планшеты), 
   чтобы они физически не накладывались на основное тело резюме */
@media (max-width: 1200px) {
    .interactive-layer {
        display: none;
    }
}