/* ============================================================
   RESPONSIVE — все медиазапросы сайта
   От большого экрана к маленькому
   ============================================================ */

/* ============================================================
   1024px — планшет горизонтальный
   ============================================================ */
@media (max-width: 1024px) {
    :root {
        --container-padding: var(--space-6);
        --hero-gap:          var(--space-12);
        --edu-grid-gap:      var(--space-7);
    }

    /* Портфолио — 2 колонки */
    .portfolio-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .portfolio-card--featured {
        grid-column: 1 / -1;
        flex-direction: column;
    }

    .portfolio-card--featured .portfolio-card-image {
        width: 100%;
        min-width: 0;
        aspect-ratio: 16 / 9;
        margin-right: 0;
        margin-bottom: var(--space-5);
    }
}

/* ============================================================
   768px — планшет вертикальный / крупный телефон
   ============================================================ */
@media (max-width: 768px) {
    :root {
        --container-padding: var(--space-5);
        --section-padding-y: var(--space-16);
        --hero-padding-y:    var(--space-12);
        --hero-gap:          var(--space-10);
        --footer-gap:        var(--space-8);
        --form-padding:      var(--space-8) var(--space-6);
        --modal-padding:     var(--space-9) var(--space-7);
        --fixed-offset:      var(--space-5);
    }

    /* Типографика */
    h2 { margin-bottom: var(--space-10); }

    /* Hero */
    .hero {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .hero-image {
        max-width: 320px;
        margin: 0 auto;
    }

    .hero-description { font-size: 1rem; }

    .btn-primary { justify-content: center; }

    /* Навигация */
    .nav-toggle { display: flex; }

    .nav-links {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: var(--color-bg-card);
        border-bottom: 1px solid rgba(0, 0, 0, 0.08);
        padding: var(--space-4) var(--space-5);
        flex-direction: column;
        gap: var(--space-1);
        box-shadow: var(--shadow-md);
        z-index: 999;
    }

    .nav-links.open { display: flex; }

    .nav-links li { width: 100%; }

    .nav-links a {
        display: block;
        padding: var(--space-3) var(--space-2);
        font-size: 1rem;
        border-radius: 10px;
    }

    .nav-links a:hover,
    .nav-links a.active { background: var(--color-accent-light); }

    .nav-links a::after { display: none; }

    .header { position: sticky; }
    .nav { position: relative; flex-wrap: nowrap; }
    .controls { margin-left: auto; }

    /* Telegram-баннер */
    .tg-banner {
        flex-wrap: wrap;
        gap: var(--space-4);
        padding: var(--space-6) var(--space-6) var(--space-6) var(--space-9);
    }

    .tg-banner-avatar {
        width: 72px;
        height: 72px;
        flex-shrink: 0;
    }

    .tg-banner-body {
        flex: 1;
        min-width: 0;
    }

    .tg-banner-desc {
        flex-basis: 100%;
        margin-top: calc(-1 * var(--space-2));
    }

    .tg-banner-btn {
        width: 100%;
        justify-content: center;
        flex-basis: 100%;
    }

    /* Баннер "не нашли услугу" */
    .service-cta {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-5);
        padding: var(--space-7) var(--space-7) var(--space-7) var(--space-9);
    }

    .service-cta-btn {
        width: 100%;
        justify-content: center;
    }

    /* Технологии */
    .tech-row { grid-template-columns: 1fr; }

    .tech-row-label {
        border-right: none;
        border-bottom: 1px solid rgba(0, 0, 0, 0.06);
        padding: var(--space-4) var(--space-6);
    }

    body.dark .tech-row-label {
        border-bottom-color: rgba(255, 255, 255, 0.06);
    }

    .tech-row-items {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 0;
        padding: var(--space-4) var(--space-3);
    }

    .tech-cell {
        padding: var(--space-4) var(--space-3);
        min-width: 0;
        width: 100%;
    }

    .tech-cell-icon {
        width: 52px !important;
        height: 52px !important;
        border-radius: 12px;
    }

    .tech-cell-icon svg,
    .tech-cell-icon > * {
        width: 28px !important;
        height: 28px !important;
    }

    /* Тултип технологий — снизу на мобильном */
    .tech-item { font-size: 0.8rem; padding: var(--space-2) var(--space-3); }
    .tech-item-icon { width: 16px; height: 16px; }
    .tech-item-icon svg { width: 16px; height: 16px; }

    .tech-item-tooltip {
        bottom: auto;
        top: calc(100% + 8px);
        font-size: 0.72rem;
    }

    .tech-item-tooltip::after {
        top: auto;
        bottom: 100%;
        border-top-color: transparent;
        border-bottom-color: var(--color-dark);
    }

    body.dark .tech-item-tooltip::after {
        border-bottom-color: #F2EEE9;
    }

    /* Образование */
    .education-grid { grid-template-columns: 1fr; }
    .edu-list, .courses-list { padding: var(--space-5); }

    /* Портфолио */
    .portfolio-grid { grid-template-columns: 1fr; }

    .portfolio-card--featured { grid-column: auto; }

    .portfolio-num { font-size: 3rem; }

    /* Форма */
    .form-container { border-radius: 24px; }

    /* Модальное окно */
    .modal-buttons { flex-direction: column; }
    .modal-btn { width: 100%; justify-content: center; }

    /* Футер */
    .footer-content { display: flex; flex-direction: column; }
    .footer-links   { grid-template-columns: repeat(3, 1fr); }
    .footer-logo p  { max-width: 100%; }

    .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--space-3);
    }

    /* Toast */
    .toast {
        bottom: 88px;
        right: var(--space-4);
        left: var(--space-4);
        max-width: none;
        border-radius: 20px;
    }

    /* Cookie */
    .cookie-banner-inner {
        flex-direction: column;
        align-items: stretch;
        gap: var(--space-4);
        padding: var(--space-4) 0;
    }

    .cookie-banner-text {
        padding-right: 0;
        border-right: none;
        border-bottom: 1px solid rgba(0, 0, 0, 0.08);
        padding-bottom: var(--space-4);
    }

    body.dark .cookie-banner-text {
        border-bottom-color: rgba(255, 255, 255, 0.08);
    }

    .cookie-banner-actions { justify-content: flex-end; }
}

/* ============================================================
   480px — телефон
   ============================================================ */
@media (max-width: 480px) {
    /* Контейнер */
    .container { padding: 0 var(--space-4); }

    /* Секции */
    section { padding: var(--space-12) 0; }

    /* Hero */
    .hero { padding-top: var(--space-8); padding-bottom: var(--space-8); }
    .hero-image { border-radius: 24px; }

    /* Кнопки */
    .btn-primary { width: 100%; justify-content: center; }

    /* Карточки */
    .about-grid,
    .services-grid { grid-template-columns: 1fr; }

    .about-card,
    .service-card { padding: var(--space-5); border-radius: 20px; }

    /* Портфолио */
    .portfolio-card { padding: var(--space-5); border-radius: 20px; }
    .portfolio-num  { font-size: 2.5rem; }

    /* Форма */
    .form-container { padding: var(--space-6) var(--space-5); }

    /* Футер */
    .footer-links {
        grid-template-columns: 1fr 1fr;
        gap: var(--space-6);
    }

    .footer-links .footer-column:last-child {
        grid-column: 1 / -1;
        text-align: center;
    }

    .footer-links .footer-column:last-child .social-links {
        justify-content: center;
    }

    .footer-bottom {
        flex-direction: row;
        flex-wrap: wrap;
        align-items: center;
        justify-content: center;
        gap: var(--space-3);
        text-align: center;
    }

    .footer-bottom > p { width: 100%; text-align: center; }

    .footer-legal-links { justify-content: center; flex-wrap: wrap; }

    .footer-legal-links .footer-privacy-link {
        padding: 0 var(--space-2);
        font-size: 0.75rem;
    }
}

/* ============================================================
   400px — очень маленький телефон
   ============================================================ */
@media (max-width: 400px) {
    .tech-row-items {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* ============================================================
   prefers-reduced-motion — доступность
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
    .animate-on-scroll {
        opacity: 1 !important;
        transform: none !important;
        transition: none !important;
    }
}
