:root {
    font-size: 16px;
}

html {
    scroll-behavior: smooth;
}

body {
    min-height: 100vh;
    overflow-x: hidden;
    text-rendering: optimizeLegibility;
}

img,
picture,
video,
iframe,
svg,
object,
embed {
    max-width: 100%;
    height: auto;
    display: block;
}

button,
input,
select,
textarea {
    min-width: 0;
    max-width: 100%;
}

input,
textarea,
select {
    width: 100%;
}

.container,
.main,
.content,
.card,
.section-padding,
.page-intro,
.document-card,
.metric-card,
.step-card,
.feature-card,
.quick-card,
.stats,
.metrics-grid,
.features-grid,
.steps-grid,
.quick__grid,
.document-list {
    box-sizing: border-box;
}

.table-responsive,
.slider-viewport,
.document-list,
.steps-grid,
.features-grid,
.metrics-grid,
.quick__grid {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

table {
    width: 100%;
    border-collapse: collapse;
}

th,
td {
    word-break: break-word;
}

.app {
    width: 100%;
}

@media (max-width: 1024px) {
    .container {
        padding-left: 20px;
        padding-right: 20px;
    }

    .header,
    .topbar,
    .public-header,
    .search-bar-container,
    .hero,
    .section-header,
    .feature-card,
    .document-card,
    .card,
    .metric-card,
    .step-card,
    .quick-card,
    .page-intro {
        width: 100%;
        max-width: 100%;
    }

    .header,
    .topbar,
    .public-header,
    .search-bar-container,
    .hero-buttons,
    .counter-box,
    .header-actions,
    .topbar__left,
    .topbar__right,
    .card-actions {
        flex-wrap: wrap;
        justify-content: center;
        gap: 12px;
    }

    .hero-buttons,
    .card-actions,
    .btn,
    .btn-dark,
    .btn-light,
    .btn-primary,
    .btn-secondary,
    .btn-submit {
        width: 100%;
        max-width: 100%;
    }

    .grid,
    .row,
    .cols,
    .stats,
    .cards-grid,
    .filters-grid {
        display: grid;
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .search-input-wrapper,
    .filter-dropdown,
    .input-group,
    .form-row,
    .form-section {
        width: 100%;
    }

    .app {
        flex-direction: row;
        overflow-x: hidden;
        min-height: 100vh;
    }

    .sidebar {
        position: fixed !important;
        left: 0 !important;
        top: 0 !important;
        bottom: 0 !important;
        width: 250px !important;
        transform: translateX(-100%);
        transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
        z-index: 10001 !important;
        background: var(--sidebar) !important;
        display: flex !important;
        flex-direction: column;
    }

    .sidebar--active {
        transform: translateX(0) !important;
    }

    .overlay {
        position: fixed !important;
        inset: 0 !important;
        background: rgba(0, 0, 0, 0.5) !important;
        z-index: 10000 !important;
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease;
    }

    .overlay--active {
        opacity: 1 !important;
        visibility: visible !important;
    }

    .main {
        width: 100% !important;
        margin-left: 0 !important;
        flex: 1 !important;
    }

    .burger {
        display: block !important;
    }

    .sidebar__close {
        display: block !important;
    }
}

@media (max-width: 768px) {

    .container {
        padding-left: 16px;
        padding-right: 16px;
    }

    .header,
    .topbar,
    .public-header,
    .search-bar-container,
    .hero,
    .section-header,
    .feature-card,
    .document-card,
    .card,
    .metric-card,
    .step-card,
    .quick-card {
        margin: 0 auto;
    }

    .header,
    .topbar,
    .public-header,
    .search-bar-container {
        align-items: stretch;
        text-align: center;
    }

    .topbar__left,
    .topbar__right,
    .header-actions,
    .hero-buttons,
    .counter-box {
        width: 100%;
        justify-content: center;
    }

    .topbar__right {
        gap: 8px;
    }

    /* Видимость баланса в шапке на мобилках */
    #site-balance {
        display: block !important;
        order: -1; /* Баланс перед иконкой профиля */
    }

    .balance-container {
        padding: 4px 10px !important;
        gap: 6px !important;
        background: rgba(255, 255, 255, 0.15) !important;
        border-radius: 50px !important;
    }

    #header-balance {
        font-size: 0.8rem !important;
    }

    .coin-icon {
        width: 18px !important;
        height: 18px !important;
        font-size: 10px !important;
    }

    .balance-add-btn {
        width: 20px !important;
        height: 20px !important;
        font-size: 14px !important;
    }

    .hero-content h1,
    .section-header h2,
    .trends-title,
    .cta-title {
        font-size: clamp(1.75rem, 4vw, 2.5rem);
    }

    .subtitle,
    .section-header p,
    .step-description,
    .counter-text span,
    .metric-title,
    .metric-value,
    .card-desc {
        font-size: 0.95rem;
    }

    .slide,
    .main-slide,
    .side-slide {
        position: relative;
        top: auto;
        left: auto;
        transform: none !important;
        width: 100%;
        height: auto;
    }

    .nav-btn {
        display: none;
    }

    .slider-viewport {
        padding: 0;
        position: relative;
        height: auto !important; /* Убираем фиксированную высоту 550px */
        margin: 20px auto !important; /* Уменьшаем отступы */
    }

    .slider-track {
        display: flex;
        gap: 16px;
        width: auto;
        transform: none !important;
        transition: none !important;
        overflow-x: auto;
        overflow-y: hidden;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }

    .slider-track::-webkit-scrollbar {
        display: none;
    }

    /* Блок Создатель бренда - принудительный воздух */
    .builder-header {
        margin-bottom: 40px !important;
        padding: 24px !important;
    }

    /* Дизайн табов в Создателе бренда */
    .tabs {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
        background: rgba(65, 48, 40, 0.05) !important;
        padding: 8px !important;
        border-radius: 16px !important;
        margin-bottom: 32px !important;
    }

    .tab-btn {
        flex: none !important;
        width: 100% !important;
        padding: 12px 8px !important;
        font-size: 13px !important;
        font-weight: 600 !important;
        border-radius: 10px !important;
        text-align: center !important;
        background: transparent !important;
        color: #413028 !important;
        border: 1px solid rgba(65, 48, 40, 0.1) !important;
        transition: all 0.2s ease !important;
    }

    .tab-btn.active {
        background: #413028 !important;
        color: #fff !important;
        border-color: #413028 !important;
        box-shadow: 0 4px 12px rgba(65, 48, 40, 0.2) !important;
    }

    .builder__grid {
        gap: 48px !important;
    }

    .builder__right {
        margin-bottom: 40px !important;
    }

    .form-section {
        margin-bottom: 32px !important;
        padding: 24px 20px !important;
    }

    .input-group {
        margin-bottom: 24px !important;
    }

    .palette-grid, .fonts-list {
        gap: 20px !important;
    }

    .slide {
        flex: 0 0 min(85vw, 320px);
        min-width: min(85vw, 320px);
        height: 200px !important;
        scroll-snap-align: start;
        box-shadow: 0 12px 28px rgba(0, 0, 0, 0.08);
        border-radius: 20px;
        overflow: hidden;
        opacity: 1 !important;
        visibility: visible !important;
        background-color: var(--card-bg) !important; /* Убираем белый фон, используем цвет карточек */
    }

    /* Личный кабинет - адаптив */
    .profile-card__header {
        flex-direction: column !important;
        text-align: center !important;
        gap: 16px !important;
    }

    .profile-avatar {
        width: 100px !important;
        height: 100px !important;
        font-size: 40px !important;
    }

    .profile-details {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .detail-item {
        padding: 12px !important;
        background: rgba(65, 48, 40, 0.03) !important;
        border-radius: 12px !important;
        align-items: center !important;
    }

    .sub-timeline {
        width: 100% !important;
        justify-content: center !important;
    }

    .setting-item {
        padding: 12px 0 !important;
    }

    .setting-item span {
        font-size: 14px !important;
        max-width: 70% !important;
    }

    .brands-count-wrapper {
        padding: 16px 0 !important;
    }

    .count-value {
        font-size: 32px !important;
    }

    .brands-summary, 
    .support-card,
    .account-actions {
        margin-bottom: 32px !important; /* Добавили воздух между нижними блоками */
    }

    /* Страница партнеров - адаптив */
    .partners-layout {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
    }

    .partners-sidebar {
        order: -1; /* Фильтры сверху на мобилках */
    }

    .filters-card {
        padding: 16px !important;
    }

    .category-list {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 8px !important;
    }

    .category-item {
        padding: 8px 12px !important;
        font-size: 13px !important;
    }

    .checkbox-group {
        display: grid !important;
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px 8px !important;
    }

    .partners-controls {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
    }

    .search-mode-toggle {
        margin-left: 0 !important;
        justify-content: space-between !important;
        padding: 8px 12px !important;
        background: rgba(65, 48, 40, 0.05) !important;
        border-radius: 8px !important;
    }

    .partners-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }

    .factory-image-container {
        height: 180px !important;
    }

    .factory-specs {
        grid-template-columns: 1fr !important;
        gap: 8px !important;
        padding: 12px 0 !important;
    }

    .spec-item {
        flex-direction: row !important;
        justify-content: space-between !important;
        align-items: center !important;
    }

    .spec-label {
        font-size: 12px !important;
    }

    .spec-value {
        font-size: 12px !important;
    }

    .factory-footer-btns {
        gap: 8px !important;
    }

    .factory-info {
        padding: 15px !important;
    }

    /* Страница транзакций - адаптив */
    .transactions-container {
        padding: 16px !important;
    }

    .page-header {
        margin-bottom: 24px !important;
        text-align: center !important;
    }

    .transactions-card {
        padding: 0 !important;
        background: transparent !important;
        box-shadow: none !important;
        border: none !important;
    }

    .transactions-table thead {
        display: none !important; /* Скрываем заголовки таблицы */
    }

    .transactions-table, 
    .transactions-table tbody, 
    .transactions-table tr, 
    .transactions-table td {
        display: block !important;
        width: 100% !important;
    }

    .transactions-table tr {
        background: var(--card) !important;
        border-radius: 16px !important;
        margin-bottom: 16px !important;
        padding: 16px !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    .transactions-table td {
        padding: 8px 0 !important;
        border: none !important;
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
    }

    .transactions-table td::before {
        content: attr(data-label); /* Используем data-label для названий полей */
        font-size: 12px !important;
        font-weight: 700 !important;
        color: var(--muted) !important;
        text-transform: uppercase !important;
    }

    .date-cell {
        order: 1 !important;
    }

    .transactions-table td:nth-child(2) { /* Операция */
        order: 0 !important;
        justify-content: flex-start !important;
        margin-bottom: 8px !important;
    }

    .transactions-table td:nth-child(2)::before {
        display: none !important;
    }

    .op-name {
        width: 100% !important;
    }

    .op-type {
        font-size: 16px !important;
    }

    .status-badge {
        font-size: 11px !important;
        padding: 2px 10px !important;
    }

    .amount-positive, .amount-negative {
        font-size: 16px !important;
    }

    /* Авторизация - адаптив */
    .auth-wrapper {
        padding: 10px !important;
        width: 100% !important;
        display: flex !important;
        justify-content: center !important;
    }

    .auth-card {
        padding: 24px 16px !important;
        width: 100% !important;
        max-width: 400px !important;
        margin: 0 auto !important;
        backdrop-filter: blur(15px) !important;
        background: rgba(158, 132, 117, 0.7) !important;
        box-sizing: border-box !important;
    }

    .auth-header h2 {
        font-size: 22px !important;
        line-height: 1.2 !important;
    }

    .auth-tabs {
        margin-bottom: 24px !important;
        width: 100% !important;
        display: flex !important;
    }

    .tab-btn {
        padding: 10px 2px !important;
        font-size: 13px !important;
        flex: 1 !important;
        text-align: center !important;
        white-space: nowrap !important;
        letter-spacing: -0.3px !important;
    }

    .form-group input {
        padding: 12px 14px !important;
        font-size: 15px !important;
    }

    .btn-auth {
        padding: 14px !important;
        font-size: 15px !important;
        width: 100% !important;
        margin-top: 10px !important;
    }

    /* Кнопки в шапке (публичной) для мобилок */
    .header-actions {
        display: flex !important;
        flex-wrap: wrap !important; /* Позволяем перенос, если не влезает */
        width: 100% !important;
        justify-content: center !important;
        gap: 8px !important;
        margin-top: 8px !important;
    }

    #site-balance {
        width: 100% !important; /* Баланс на отдельную строку сверху */
        display: flex !important;
        justify-content: center !important;
        margin-bottom: 8px !important;
    }

    .public-header .login-link {
        padding: 8px 12px !important;
        font-size: 13px !important;
        background: rgba(255, 255, 255, 0.1) !important;
        border-radius: 50px !important;
        flex: 1 1 40% !important; /* Занимает примерно половину */
        min-width: 120px !important;
        text-align: center !important;
        white-space: nowrap !important;
    }

    .public-header .btn-dark {
        padding: 8px 12px !important;
        font-size: 13px !important;
        flex: 1 1 40% !important; /* Занимает примерно половину */
        min-width: 120px !important;
        text-align: center !important;
        justify-content: center !important;
        display: flex !important;
        align-items: center !important;
        white-space: nowrap !important;
    }

    .slide img {
        width: 100%;
        height: 100% !important;
        object-fit: cover !important; /* Растягиваем на весь прямоугольник */
        padding: 0 !important; /* Убираем лишний "воздух" */
        box-sizing: border-box;
        border-radius: inherit;
        display: block;
    }

    .features-grid,
    .how-it-works .steps-grid,
    .tariffs-grid {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        justify-content: flex-start !important; /* Обеспечиваем начало с первого элемента */
        overflow-x: auto !important;
        overflow-y: hidden;
        scroll-snap-type: x mandatory;
        gap: 16px;
        padding: 20px 0;
        scrollbar-width: none;
        -webkit-overflow-scrolling: touch;
    }

    .features-grid::-webkit-scrollbar,
    .how-it-works .steps-grid::-webkit-scrollbar,
    .tariffs-grid::-webkit-scrollbar {
        display: none;
    }

    .feature-card,
    .how-it-works .step-item,
    .tariffs-grid .tariff-card {
        flex: 0 0 280px;
        min-width: 280px;
        scroll-snap-align: start;
    }

    /* Общий визуальный индикатор прокрутки */
    .slider-viewport,
    .features-grid,
    .how-it-works .steps-grid,
    .tariffs-grid,
    .metrics-grid,
    .quick__grid,
    .document-list {
        position: relative;
    }

    .slider-viewport::after,
    .features-grid::after,
    .how-it-works .steps-grid::after,
    .tariffs-grid::after,
    .metrics-grid::after,
    .quick__grid::after,
    .document-list::after {
        content: 'Листайте →';
        position: absolute;
        right: 10px;
        bottom: 5px; /* Переносим вниз, чтобы не мешать кнопкам сверху если они есть */
        padding: 4px 12px;
        background: rgba(65, 48, 40, 0.9);
        color: white;
        border-radius: 20px;
        font-size: 11px;
        font-weight: 500;
        pointer-events: none;
        z-index: 10;
        box-shadow: 0 4px 10px rgba(0,0,0,0.1);
        opacity: 0.8;
        animation: hintSlide 2s infinite;
    }

    @keyframes hintSlide {
        0%, 100% { transform: translateX(0); }
        50% { transform: translateX(5px); }
    }
}
