/* === ОБЩИЕ МОБИЛЬНЫЕ СТИЛИ === */

@media (max-width: 768px) {
    html {
        font-size: 14px;
    }

    body {
        padding: 0;
    }

    h1 {
        font-size: clamp(24px, 5vw, 32px) !important;
        line-height: 1.3 !important;
    }

    h2 {
        font-size: clamp(20px, 4vw, 26px) !important;
        line-height: 1.3 !important;
    }

    h3 {
        font-size: clamp(18px, 3.5vw, 22px) !important;
        line-height: 1.3 !important;
    }

    .container {
        padding: 12px 16px !important;
        max-width: 100% !important;
    }

    /* Кнопки: применяем только к UI-kit кнопкам.
       ВАЖНО: не трогаем все <button> глобально — это ломало navbar и support-fab на 360px. */
    .btn,
    .btn-premium,
    a.btn,
    a.btn-premium,
    button.btn,
    button.btn-premium {
        min-height: 44px !important;
        min-width: 44px !important;
        padding: 10px 16px !important;
        font-size: 14px !important;
        border-radius: 8px !important;
        touch-action: manipulation;
    }

    /* Для остальных кнопок — только корректное поведение на touch (без принудительного размера) */
    button {
        touch-action: manipulation;
    }

    .btn--lg,
    .btn-premium[style*="padding:20px"] {
        padding: 12px 20px !important;
        font-size: 14px !important;
        min-height: 48px !important;
    }

    /* Grid адаптация */
    .grid-3,
    [style*="grid-template-columns: repeat(3"],
    [style*="grid-template-columns:repeat(3"] {
        grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)) !important;
        gap: 12px !important;
    }

    .grid-2,
    [style*="grid-template-columns: 1.2fr 1fr"],
    [style*="grid-template-columns:1fr 1fr"] {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    /* Карточки */
    .card,
    .glass {
        margin-bottom: 12px !important;
        padding: 16px !important;
    }

    .card__body,
    [style*="padding:40px"] {
        padding: 16px !important;
    }

    .feature-card {
        padding: 20px !important;
    }

    /* Формы */
    .form-control,
    .form-input,
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    textarea,
    select {
        padding: 12px !important;
        font-size: 16px !important; /* Для iOS autocorrection */
        border-radius: 8px !important;
        min-height: 44px !important;
        box-sizing: border-box !important;
        width: 100% !important;
    }

    textarea {
        min-height: 100px !important;
    }

    .form-group {
        margin-bottom: 16px !important;
    }

    .form-label,
    label {
        font-size: 12px !important;
        margin-bottom: 8px !important;
        display: block !important;
    }

    /* Модалки */
    .modal,
    .auth-container {
        padding: 16px !important;
        border-radius: 12px !important;
        max-height: 90vh !important;
        overflow-y: auto !important;
        margin: 10px !important;
        width: calc(100% - 20px) !important;
        max-width: calc(100% - 20px) !important;
    }

    /* Таблицы */
    .data-table,
    table {
        font-size: 12px !important;
        width: 100% !important;
        display: block !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .data-table td,
    .data-table th,
    td,
    th {
        padding: 8px !important;
        white-space: nowrap !important;
    }

    /* Flex layouts (для контента).
       Важно: не применяем wrap к header/nav, иначе ломается navbar на 360px. */
    [style*="display:flex"][style*="gap:"] {
        flex-wrap: wrap !important;
    }

    header [style*="display:flex"][style*="gap:"],
    header nav[style*="display:flex"],
    header .nav-menu[style*="display:flex"] {
        flex-wrap: nowrap !important;
    }

    .flex-col-mobile,
    [style*="flex-direction: row"] {
        flex-direction: column !important;
    }

    .gap-mobile {
        gap: 8px !important;
    }

    /* Hero секции */
    .hero,
    section[style*="padding-top:200px"],
    section[style*="padding-top:180px"] {
        padding-top: 120px !important;
        padding-bottom: 50px !important;
    }

    /* Специфичные стили для страниц */
    .checkout-container,
    .contact-wrapper,
    .about-grid,
    .story-box {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }

    /* Checkout: reset explicit grid placement on small screens */
    .checkout-summary,
    .checkout-form {
        grid-column: auto !important;
        grid-row: auto !important;
        position: relative !important;
        top: auto !important;
    }

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

    /* Form rows - превращаем в колонки */
    .form-row,
    [style*="display:grid"][style*="grid-template-columns: 1fr 1fr"],
    [style*="grid-template-columns:1fr 1fr"] {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    /* Footer */
    footer {
        padding: 40px 0 !important;
    }

    footer .container {
        padding: 20px 16px !important;
    }

    /* Секции */
    section[style*="padding-top:200px"],
    section[style*="padding-top:180px"],
    .about-hero,
    .contact-hero,
    .faq-section,
    .checkout-section,
    .payment-section {
        padding-top: 120px !important;
        padding-bottom: 50px !important;
    }

    /* Story box - вертикальная компоновка */
    .story-box {
        flex-direction: column !important;
        gap: 30px !important;
    }

    .story-stats {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }

    /* Checkout специфичные стили */
    .checkout-container {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }

    .checkout-summary {
        position: static !important;
        order: 0 !important;
        top: auto !important;
    }

    /* Payment methods */
    .payment-methods {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .payment-method {
        padding: 16px !important;
    }

    /* Cart panel */
    .cart-panel {
        width: 100% !important;
        right: -100% !important;
    }

    .cart-body {
        padding: 16px !important;
    }

    .cart-footer {
        padding: 20px 16px !important;
    }
}

@media (max-width: 480px) {
    .container {
        padding: 10px 12px !important;
    }

    h1 {
        font-size: 20px !important;
        line-height: 1.3 !important;
    }

    h2 {
        font-size: 18px !important;
    }

    h3 {
        font-size: 16px !important;
    }

    /* На очень узких экранах не делаем ВСЕ кнопки полноширинными (ломало navbar/support-fab).
       Полноширинные CTA оставляем через inline-width или локальные селекторы. */
    .btn,
    .btn-premium,
    a.btn,
    a.btn-premium,
    button.btn,
    button.btn-premium {
        padding: 10px 14px !important;
        font-size: 13px !important;
    }

    .grid-3,
    [style*="grid-template-columns: repeat(3"] {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    .form-control,
    .form-input,
    /* Не трогаем radio/checkbox — иначе они становятся "полями ввода" и ломают UI выбора */
    input:not([type="radio"]):not([type="checkbox"]),
    textarea,
    select {
        padding: 12px !important;
        border-radius: 6px !important;
        font-size: 16px !important; /* Важно для iOS */
        width: 100% !important;
    }

    /* Избегай горизонтальной прокрутки */
    * {
        box-sizing: border-box !important;
    }

    img,
    svg {
        max-width: 100% !important;
        height: auto !important;
    }

    /* Support FAB: оставляем круглой и компактной на очень узких экранах */
    .support-fab {
        width: 52px !important;
        height: 52px !important;
        min-width: 52px !important;
        min-height: 52px !important;
        padding: 0 !important;
        border-radius: 999px !important;
    }

    /* Таблицы на маленьких экранах */
    table:not(.data-table) {
        width: 100% !important;
        overflow-x: auto !important;
        display: block !important;
        -webkit-overflow-scrolling: touch !important;
    }

    table:not(.data-table) thead {
        display: none !important;
    }

    table:not(.data-table) tbody tr {
        display: block !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        border-radius: 8px !important;
        margin-bottom: 12px !important;
        padding: 12px !important;
    }

    table:not(.data-table) td {
        display: block !important;
        text-align: right !important;
        padding: 8px 0 !important;
        padding-left: 50% !important;
        position: relative !important;
        border: none !important;
    }

    table:not(.data-table) td:before {
        content: attr(data-label) !important;
        position: absolute !important;
        left: 8px !important;
        font-weight: 600 !important;
        text-align: left !important;
        opacity: 0.7 !important;
    }

    .hero,
    section[style*="padding-top"],
    .about-hero,
    .contact-hero,
    .faq-section,
    .checkout-section,
    .payment-section {
        padding-top: 100px !important;
        padding-bottom: 40px !important;
    }

    .card,
    .glass {
        padding: 12px !important;
    }

    /* Story stats - одна колонка на очень маленьких экранах */
    .story-stats {
        grid-template-columns: 1fr !important;
    }

    /* Form rows - всегда одна колонка */
    .form-row {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }

    /* Hero заголовки */
    h1[style*="font-size:5rem"],
    h1[style*="font-size:3rem"] {
        font-size: 24px !important;
        line-height: 1.3 !important;
    }

    /* Feature cards - одна колонка */
    [style*="grid-template-columns: repeat(auto-fit, minmax(300px, 1fr))"] {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    /* Contact wrapper */
    .contact-wrapper {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }

    .contact-method-card {
        padding: 16px !important;
        flex-direction: column !important;
        text-align: center !important;
        gap: 12px !important;
    }

    .method-icon {
        width: 40px !important;
        height: 40px !important;
        font-size: 1.2rem !important;
    }

    /* Ticket form */
    .ticket-form {
        padding: 20px !important;
    }

    /* About grid */
    .about-grid {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }

    .about-card {
        padding: 20px !important;
    }

    /* Checkout */
    .checkout-form {
        padding: 20px !important;
    }

    .checkout-summary {
        padding: 20px !important;
    }

    /* Checkout (360px): убираем лишние отступы и предотвращаем развал верстки */
    .checkout-container {
        padding: 0 !important;
    }

    .checkout-section h1 {
        margin-bottom: 24px !important;
    }

    .checkout-summary h2 {
        margin-bottom: 16px !important;
    }

    .checkout-section .summary-item {
        flex-wrap: wrap;
        gap: 8px;
    }

    .checkout-section .summary-total {
        font-size: 1.15rem !important;
        flex-wrap: wrap;
        gap: 8px;
    }

    .checkout-section .payment-method {
        padding: 14px !important;
    }

    .checkout-section .payment-method span {
        white-space: normal !important;
    }

    .toast {
        left: 12px !important;
        right: 12px !important;
        width: auto !important;
        top: 14px !important;
    }

    /* Payment card */
    .payment-card {
        padding: 24px 16px !important;
    }

    .payment-title {
        font-size: 1.8rem !important;
    }

    .payment-amount {
        font-size: 2rem !important;
    }
}

/* === ДОПОЛНИТЕЛЬНЫЕ УЛУЧШЕНИЯ === */

/* Улучшаем отзывчивость кнопок */
@media (hover: none) and (pointer: coarse) {
    /* Для тач-устройств */
    button,
    .btn,
    .btn-premium,
    a[role="button"] {
        -webkit-tap-highlight-color: rgba(138, 43, 226, 0.2);
        touch-action: manipulation;
    }

    /* На тач-устройствах :hover может "залипать" и сдвигать элементы (например, .glass:hover).
       Это особенно заметно в шапке: иконка корзины визуально "улетает" вверх.
       На тач-устройствах отключаем hover-трансформации у стеклянных блоков. */
    .glass:hover {
        transform: none !important;
    }
}

/* Предотвращаем зум при фокусе на input в iOS */
@supports (-webkit-touch-callout: none) {
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    textarea,
    select {
        font-size: 16px !important;
    }
}

/* Улучшаем скролл на мобильных */
@media (max-width: 768px) {
    body {
        -webkit-overflow-scrolling: touch;
        overflow-x: hidden;
    }

    /* Улучшаем отображение текста */
    p,
    span,
    div {
        word-wrap: break-word;
        overflow-wrap: break-word;
    }

    /* Улучшаем карточки */
    .glass,
    .card {
        word-wrap: break-word;
        overflow-wrap: break-word;
    }
}

/* === LANDSCAPE ОРИЕНТАЦИЯ === */

@media (max-height: 500px) and (orientation: landscape) {
    header,
    .navbar {
        padding: 8px 16px !important;
    }

    .navbar-logo,
    .navbar-logo svg {
        width: 36px !important;
        height: 36px !important;
    }

    .hero,
    section[style*="padding-top"] {
        padding: 24px 0 !important;
        min-height: auto !important;
    }

    .modal,
    .auth-container {
        max-height: 95vh !important;
        padding: 12px !important;
    }

    .container {
        padding: 8px 12px !important;
    }
}

@media (max-width: 1200px) {
    .container {
        padding: 0 20px;
    }
    .catalog-layout {
        grid-template-columns: 240px 1fr;
        gap: 30px;
    }
}
@media (max-width: 992px) {
    header nav {
        flex-wrap: wrap;
        gap: 15px;
    }
    header nav > div:first-child {
        font-size: 1.2rem;
    }
    header nav > div:nth-child(2),
    nav.glass > div:nth-child(2) {
        flex-wrap: wrap;
        gap: 15px;
    }
    .catalog-layout {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .catalog-layout aside {
        position: sticky;
        top: 80px;
        z-index: 100;
    }
    .product-grid {
        grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    }
    .cart-panel {
        width: 100% !important;
        right: -100%;
        z-index: 10000 !important;
    }
    
    .cart-panel.active {
        right: 0 !important;
        z-index: 10000 !important;
    }
    
    /* Улучшаем отображение корзины на мобильных */
    .cart-panel > div:first-child {
        padding: 20px !important;
    }
    
    .cart-body {
        padding: 16px 20px !important;
    }
    
    .cart-footer {
        padding: 20px !important;
    }
}
/* === МОБИЛЬНАЯ АДАПТАЦИЯ NAVBAR === */

@media (max-width: 768px) {
    header {
        top: 8px !important;
        left: 0;
        right: 0;
        width: 100%;
        padding: 0 8px;
        box-sizing: border-box;
        position: fixed !important;
        z-index: 1000;
    }
    
    header .container {
        padding: 0 !important;
        max-width: 100%;
        width: 100%;
        margin: 0;
    }
    
    header nav,
    nav.glass {
        padding: 8px 10px !important;
        gap: 6px !important;
        position: relative;
        flex-wrap: nowrap;
        min-height: 50px;
        max-height: 50px;
        align-items: center;
        width: 100%;
        box-sizing: border-box;
        justify-content: space-between;
        overflow: visible;
    }

    .navbar-logo-container {
        flex: 0 0 auto;
        min-width: 0;
        max-width: calc(100% - 140px);
        gap: 6px !important;
        order: 1;
    }

    .navbar-logo {
        width: 34px !important;
        height: 34px !important;
        flex-shrink: 0;
    }

    /* На некоторых страницах логотип не имеет класса .navbar-logo — перебиваем глобальные 50px */
    header img[src*="logo.webp"],
    nav img[src*="logo.webp"],
    header img[src*="Logo.webp"],
    nav img[src*="Logo.webp"] {
        width: 34px !important;
        height: 34px !important;
    }

    .navbar-brand {
        font-size: 12px !important;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        max-width: 100px;
        display: block;
    }

    
    /* === MOBILE HEADER CONTROLS ALIGN === */
    header nav > div:last-child {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        flex: 0 0 auto !important;
        min-width: 0 !important;
    }

    header nav > div:last-child > * {
        flex-shrink: 0 !important;
    }

    /* Cart pill */
    header #cartToggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        height: 40px !important;
        min-height: 40px !important;
        padding: 0 12px !important;
        font-size: 12px !important;
        line-height: 1 !important;
        border-radius: 12px !important;
        white-space: nowrap !important;
    }

    /* Language switch */
    header .lang-switcher {
        height: 40px !important;
        padding: 3px !important;
        border-radius: 12px !important;
    }

    header .lang-btn {
        height: 30px !important;
        min-height: 30px !important;
        min-width: 0 !important;
        width: auto !important;
        padding: 0 10px !important;
        font-size: 12px !important;
        line-height: 1 !important;
    }

    /* Profile/Login button */
    header #authBtn,
    header #authBtnHeader {
        height: 36px !important;
        min-height: 36px !important;
        min-width: 0 !important;
        width: auto !important;
        padding: 0 12px !important;
        font-size: 12px !important;
        line-height: 1 !important;
        border-radius: 12px !important;
        white-space: nowrap !important;
        max-width: 180px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    /* Hamburger */
    header .hamburger {
        width: 36px !important;
        height: 36px !important;
        min-width: 36px !important;
        min-height: 36px !important;
        padding: 0 !important;
    }

    /* Скрываем обычное меню на мобильных */
    .nav-menu {
        display: none !important;
        position: fixed !important;
        top: 70px !important;
        left: 10px !important;
        right: 10px !important;
        width: auto !important;
    }
    
    /* Показываем гамбургер кнопку */
    .hamburger {
        display: flex !important;
        flex-shrink: 0;
        order: 3;
        margin-left: 4px;
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
    }

    .nav-menu.active {
        display: flex !important;
        flex-direction: column;
        background: rgba(5, 5, 18, 0.98);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
        border: 1px solid rgba(138, 43, 226, 0.3);
        border-radius: 10px;
        padding: 8px 0;
        gap: 0;
        z-index: 9999;
        box-shadow: 0 8px 32px rgba(0, 0, 0, 0.7);
        max-height: calc(100vh - 70px);
        overflow-y: auto;
        top: 60px !important;
        left: 8px !important;
        right: 8px !important;
        width: calc(100% - 16px) !important;
    }

    .nav-menu a {
        padding: 12px 16px;
        border-radius: 0;
        display: block;
        transition: all 250ms ease;
        text-decoration: none;
        color: var(--text);
        opacity: 0.9;
        font-size: 14px;
        font-weight: 600;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    }

    .nav-menu a:last-child {
        border-bottom: none;
    }

    .nav-menu a:hover,
    .nav-menu a:active {
        background: rgba(138, 43, 226, 0.2);
        opacity: 1;
        padding-left: 24px;
    }
    
    /* Элементы в мобильном меню */
    .nav-menu .mobile-menu-section {
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        padding: 12px 0;
        margin-top: 8px;
    }
    
    .nav-menu .mobile-menu-section:first-child {
        border-top: none;
        margin-top: 0;
    }
    
    .nav-menu .mobile-menu-item {
        padding: 12px 20px;
        display: flex;
        align-items: center;
        gap: 12px;
        color: var(--text);
        text-decoration: none;
        font-size: 14px;
        font-weight: 600;
        transition: all 250ms ease;
        border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    }
    
    .nav-menu .mobile-menu-item:last-child {
        border-bottom: none;
    }
    
    .nav-menu .mobile-menu-item:hover {
        background: rgba(138, 43, 226, 0.2);
        padding-left: 24px;
    }
    
    .nav-menu .mobile-menu-item i {
        width: 20px;
        text-align: center;
        color: var(--violet-main);
    }
    
    .nav-menu .mobile-lang-switcher {
        display: flex;
        gap: 8px;
        padding: 12px 20px;
        border-top: 1px solid rgba(255, 255, 255, 0.1);
        margin-top: 8px;
    }
    
    .nav-menu .mobile-lang-btn {
        flex: 1;
        padding: 10px;
        background: rgba(255, 255, 255, 0.05);
        border: 1px solid rgba(255, 255, 255, 0.1);
        border-radius: 8px;
        color: var(--text);
        font-size: 13px;
        font-weight: 700;
        cursor: pointer;
        transition: all 250ms ease;
        text-align: center;
    }
    
    .nav-menu .mobile-lang-btn.active {
        background: rgba(138, 43, 226, 0.3);
        border-color: rgba(138, 43, 226, 0.5);
        color: var(--violet-main);
    }
    
    .nav-menu .mobile-lang-btn:hover {
        background: rgba(138, 43, 226, 0.2);
        border-color: rgba(138, 43, 226, 0.4);
    }

    .hamburger {
        display: flex !important;
        flex-direction: column;
        gap: 4px;
        cursor: pointer;
        background: rgba(255, 255, 255, 0.05);
        border: 1px solid rgba(255, 255, 255, 0.1);
        border-radius: 6px;
        color: var(--text);
        padding: 8px 6px;
        z-index: 1001;
        transition: all 250ms ease;
        flex-shrink: 0;
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
        justify-content: center;
        align-items: center;
    }

    .hamburger:hover {
        background: rgba(138, 43, 226, 0.2);
        border-color: rgba(138, 43, 226, 0.4);
    }

    .hamburger span {
        width: 20px;
        height: 2px;
        background: var(--text);
        transition: all 300ms ease;
        display: block;
        border-radius: 2px;
    }

    .hamburger.active {
        background: rgba(138, 43, 226, 0.3);
        border-color: rgba(138, 43, 226, 0.5);
    }

    .hamburger.active span:nth-child(1) {
        transform: rotate(45deg) translate(5px, 5px);
    }

    .hamburger.active span:nth-child(2) {
        opacity: 0;
        transform: translateX(-10px);
    }

    .hamburger.active span:nth-child(3) {
        transform: rotate(-45deg) translate(5px, -5px);
    }

    .nav-auth,
    nav.glass > div:last-child,
    nav.glass > div[style*="display:flex"][style*="gap:15px"] {
        display: flex !important;
        align-items: center;
        gap: 4px;
        flex-shrink: 0;
        order: 2;
        margin-left: auto;
    }
    
    /* Уменьшаем размеры элементов на мобильных, но не скрываем их */
    .lang-switcher {
        display: flex !important;
        gap: 3px;
        flex-shrink: 0;
    }
    
    .lang-btn {
        padding: 4px 6px !important;
        font-size: 0.6rem !important;
        min-width: 28px;
        height: 24px;
        line-height: 1;
    }
    
    #cartToggle {
        padding: 5px 10px !important;
        font-size: 0.65rem !important;
        display: flex !important;
        align-items: center;
        gap: 4px;
        min-height: 28px;
        flex-shrink: 0;
    }
    
    #cartToggle i {
        font-size: 0.7rem;
    }
    
    /* Показываем кнопку авторизации в навбаре на мобильных */
    .nav-auth .btn-premium,
    nav.glass > div:last-child .btn-premium,
    nav.glass > div[style*="display:flex"] .btn-premium,
    #authBtnHeader,
    #authBtn {
        display: flex !important;
        padding: 6px 12px !important;
        font-size: 0.65rem !important;
        min-width: auto;
        white-space: nowrap;
        height: 28px;
        align-items: center;
        line-height: 1;
    }
    
    /* Улучшаем контейнер навбара */
    nav.glass {
        justify-content: space-between !important;
        overflow: visible !important;
    }
    
    /* Предотвращаем переполнение */
    header .container {
        overflow: visible;
    }
    
    /* Улучшаем отображение элементов навбара */
    nav.glass > * {
        flex-shrink: 0;
    }
    
    /* Улучшаем позиционирование меню */
    .nav-menu.active {
        animation: slideDown 0.3s ease-out;
    }
    
    @keyframes slideDown {
        from {
            opacity: 0;
            transform: translateY(-10px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    .nav-user-menu {
        position: relative;
    }

    .nav-user-btn {
        padding: 8px 12px;
        font-size: 12px;
    }

    .nav-user-dropdown {
        position: absolute;
        top: 100%;
        right: 0;
        margin-top: 8px;
        background: rgba(5, 5, 18, 0.95);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
        border-radius: 8px;
        border: 1px solid rgba(138, 43, 226, 0.3);
        min-width: 180px;
        display: none;
        box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
    }

    .nav-user-dropdown.active {
        display: flex;
        flex-direction: column;
        gap: 0;
    }

    .nav-dropdown-item {
        padding: 12px 16px;
        display: block;
        text-decoration: none;
        color: var(--text);
        border-bottom: 1px solid rgba(138, 43, 226, 0.2);
        transition: all 250ms ease;
    }

    .nav-dropdown-item:last-child {
        border-bottom: none;
    }

    .nav-dropdown-item:hover {
        background: rgba(138, 43, 226, 0.15);
    }

    header nav > div:first-child {
        font-size: 1.1rem;
        width: auto;
        text-align: left;
    }
    
    header nav a {
        font-size: 0.8rem;
    }
    
    header nav button {
        padding: 10px 16px;
        font-size: 0.75rem;
    }
    
    .lang-switcher {
        display: none;
    }
    main section:first-child {
        padding-top: 150px !important;
        padding-bottom: 50px !important;
    }
    main section h1 {
        font-size: 2.5rem !important;
        line-height: 1.2 !important;
    }
    .feature-card {
        padding: 25px !important;
    }
    .catalog-layout {
        padding-top: 120px;
    }
    .product-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .filter-item {
        padding: 10px 15px;
        font-size: 0.85rem;
    }
    .auth-container {
        max-width: 95%;
        padding: 30px 20px;
    }
    .form-input {
        padding: 12px;
        font-size: 0.9rem;
    }
    .cart-panel {
        width: 100% !important;
        z-index: 10000 !important;
        max-width: 100% !important;
    }
    
    .cart-panel.active {
        right: 0 !important;
        z-index: 10000 !important;
    }
    
    /* Overlay для закрытия корзины при клике вне её */
    .cart-overlay {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        background: rgba(0, 0, 0, 0.7);
        z-index: 9999;
        display: none;
        backdrop-filter: blur(5px);
        -webkit-tap-highlight-color: transparent;
    }
    
    /* Показываем overlay когда корзина открыта */
    body.cart-open .cart-overlay,
    .cart-panel.active + .cart-overlay {
        display: block !important;
    }
    
    /* Улучшаем отображение кнопки закрытия корзины на мобильных */
    #closeCart {
        min-width: 44px !important;
        min-height: 44px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 10px !important;
    }
    
    .cart-footer {
        padding: 20px !important;
    }
    
    .cart-body {
        padding: 16px 20px !important;
        max-height: calc(100vh - 200px);
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
    }
    .profile-layout {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
        padding-top: 120px !important;
    }
    .profile-sidebar {
        position: static !important;
        max-width: 100% !important;
    }

    /* Profile stat cards - адаптивный grid */
    [style*="grid-template-columns: repeat(3, 1fr)"] {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
        gap: 12px !important;
    }

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

    .stat-card div:last-child {
        font-size: 1.4rem !important;
    }

    /* Side menu в профиле */
    .side-menu {
        position: static !important;
        padding: 20px !important;
    }

    .menu-item {
        padding: 12px 16px !important;
        font-size: 0.9rem !important;
    }

    /* Orders container */
    #ordersContainer {
        padding: 20px !important;
    }

    .order-item {
        padding: 16px !important;
        flex-direction: column !important;
        gap: 12px !important;
    }

    .order-item > div {
        width: 100% !important;
        text-align: left !important;
    }

    .order-item > div:last-child {
        text-align: left !important;
    }

    .status-badge {
        display: inline-block !important;
        margin-bottom: 8px !important;
    }
    .admin-layout {
        grid-template-columns: 1fr;
    }
    .admin-sidebar {
        position: static;
        max-width: 100%;
    }
    .admin-stats-grid {
        grid-template-columns: 1fr;
        gap: 15px;
    }
}
@media (max-width: 480px) {
    header {
        top: 5px;
        padding: 0 6px;
    }
    
    header nav,
    nav.glass {
        padding: 6px 8px !important;
        gap: 4px !important;
        min-height: 46px;
        max-height: 46px;
    }
    
    .navbar-logo-container {
        max-width: calc(100% - 90px);
        gap: 4px !important;
    }

    .navbar-logo {
        width: 30px !important;
        height: 30px !important;
    }

    .navbar-brand {
        font-size: 10px !important;
        max-width: 75px;
    }

    .hamburger {
        width: 32px !important;
        height: 32px !important;
        min-width: 32px !important;
        min-height: 32px !important;
        padding: 6px 5px;
    }
    
    .hamburger span {
        width: 18px;
        height: 2px;
    }

    .nav-auth,
    nav.glass > div:last-child,
    nav.glass > div[style*="display:flex"][style*="gap:15px"] {
        gap: 3px !important;
    }
    
    .nav-auth .btn-premium,
    nav.glass > div:last-child .btn-premium,
    nav.glass > div[style*="display:flex"] .btn-premium,
    #authBtnHeader,
    #authBtn {
        padding: 5px 10px !important;
        font-size: 0.6rem !important;
        height: 26px;
    }
    
    .lang-btn {
        padding: 3px 5px !important;
        font-size: 0.55rem !important;
        min-width: 24px;
        height: 22px;
    }
    
    #cartToggle {
        padding: 4px 8px !important;
        font-size: 0.6rem !important;
        min-height: 26px;
    }
    
    /* На очень маленьких экранах скрываем некоторые элементы в навбаре (они будут в меню) */
    .lang-switcher {
        display: none !important;
    }
    
    #cartToggle {
        display: none !important;
    }
    
    .nav-menu.active {
        top: 58px !important;
        left: 6px !important;
        right: 6px !important;
        width: calc(100% - 12px) !important;
        padding: 6px 0;
    }
    
    .nav-menu a {
        padding: 10px 14px;
        font-size: 13px;
    }
    
    .nav-menu .mobile-menu-item {
        padding: 10px 14px;
        font-size: 13px;
    }
    
    .nav-menu .mobile-lang-switcher {
        padding: 8px 14px;
        gap: 6px;
    }
    
    .nav-menu .mobile-lang-btn {
        padding: 8px;
        font-size: 12px;
    }
    
    .nav-user-btn {
        padding: 6px 10px;
        font-size: 10px;
    }

    .nav-user-balance {
        display: none;
    }
}

@media (max-width: 360px) {
    .navbar-brand {
        display: none !important;
    }
    
    .navbar-logo-container {
        max-width: calc(100% - 90px);
    }
    
    .nav-auth .btn-premium,
    nav.glass > div:last-child .btn-premium,
    nav.glass > div[style*="display:flex"] .btn-premium,
    #authBtnHeader,
    #authBtn {
        padding: 4px 8px !important;
        font-size: 0.55rem !important;
        height: 24px;
    }
    main section:first-child {
        padding-top: 120px !important;
    }
    main section h1 {
        font-size: 2rem !important;
    }
    .btn-premium {
        padding: 15px 25px !important;
        font-size: 0.85rem !important;
    }
    .feature-card {
        padding: 20px !important;
    }
    .feature-card i {
        font-size: 1.5rem !important;
    }
    .auth-container {
        padding: 25px 15px;
    }
    .form-input {
        padding: 10px;
        font-size: 0.85rem;
    }
    .product-grid .card {
        padding: 20px;
    }
    .price-tag {
        font-size: 1.5rem;
    }
}

/* === РАСШИРЕННАЯ МОБИЛЬНАЯ ОПТИМИЗАЦИЯ === */
@media (max-width: 480px) {
    /* Ultra-small phones */
    html {
        font-size: 12px;
    }
    
    h1 {
        font-size: 18px !important;
    }
    
    .container {
        padding: 8px 12px !important;
    }
    
    /* Navbar optimization for small screens */
    header nav {
        flex-wrap: wrap;
        gap: 8px;
    }
    
    header nav a {
        font-size: 11px;
        padding: 6px 10px !important;
    }
    
    /* Cart in header */
    .cart-badge {
        font-size: 10px;
        width: 20px;
        height: 20px;
        min-width: 20px;
        min-height: 20px;
    }
    
    /* Product grid on ultra-small screens */
    .product-grid,
    [style*="grid"] {
        grid-template-columns: 1fr !important;
    }
    
    /* Better spacing for forms (не трогаем radio/checkbox) */
    input:not([type="radio"]):not([type="checkbox"]),
    textarea,
    select {
        font-size: 16px !important; /* Prevent zoom on iOS */
        padding: 12px 10px !important;
    }
    
    /* Modal adjustments */
    .modal,
    .auth-container {
        width: calc(100% - 16px) !important;
        max-width: calc(100% - 16px) !important;
        margin: 8px !important;
        padding: 12px !important;
    }
}

@media (max-width: 640px) {
    /* Small phones - tablet portrait */
    .catalog-layout {
        grid-template-columns: 1fr !important;
    }
    
    .filter-panel {
        margin-bottom: 20px;
    }
    
    /* Product card optimization */
    .product-card,
    [style*="border"][style*="padding"] {
        padding: 12px !important;
        border-radius: 8px;
    }
    
    /* Price display */
    .product-price,
    .price-tag {
        font-size: 16px !important;
    }
    
    /* Footer menu */
    footer {
        columns: 1 !important;
    }
    
    /* Profile sections */
    .profile-section,
    .profile-card {
        margin-bottom: 12px !important;
    }
    
    /* Tabs for mobile */
    [role="tab"],
    .tab {
        font-size: 12px;
        padding: 8px 12px !important;
    }
}

@media (max-width: 768px) {
    /* Tablet/small screens */
    .checkout-container {
        grid-template-columns: 1fr !important;
    }
    
    /* Better scrolling for tables */
    .data-table {
        font-size: 11px !important;
    }
    
    .data-table td,
    .data-table th {
        padding: 6px !important;
    }
    
    /* Sticky footer action button */
    .sticky-bottom-action {
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: linear-gradient(to top, rgba(10, 15, 35, 0.98), transparent);
        padding: 12px 16px 16px;
        z-index: 90;
    }
    
    /* Reduce padding in dense layouts */
    .dense-layout {
        padding: 8px !important;
    }
}

/* === LANDSCAPE ORIENTATION === */
@media (max-width: 768px) and (orientation: landscape) {
    header {
        min-height: 50px;
    }
    
    header nav {
        overflow-x: auto;
        overflow-y: hidden;
        white-space: nowrap;
        -webkit-overflow-scrolling: touch;
    }
    
    header nav a {
        flex-shrink: 0;
    }
    
    main section {
        padding: 10px 0 !important;
    }
}

@media (max-width: 768px) and (orientation: portrait) {
    header {
        position: relative;
        top: 0;
        margin-bottom: 20px;
    }
    main section:first-child {
        padding-top: 50px !important;
    }
    
    /* Full-width inputs in forms */
    input:focus,
    textarea:focus,
    select:focus {
        outline: 2px solid #00d9ff;
        outline-offset: 2px;
    }
}
@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .glass {
        backdrop-filter: blur(25px);
    }
}
@media print {
    header,
    footer,
    .cart-panel,
    .auth-container {
        display: none !important;
    }
    body {
        background: white;
        color: black;
    }
}
@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}
@media (prefers-color-scheme: light) {
}

/* === MOBILE HEADER WIDTH OVERRIDE (480) === */
@media (max-width: 480px) {
    header .btn,
    header .btn-premium,
    header button,
    header #cartToggle {
        width: auto !important;
        max-width: none !important;
    }
}

/* === STEP 1 (v4) — HOTFIX: выравнивание элементов моб. навбара + мобильные фильтры каталога === */

@media (max-width: 768px) {
    /* --- Navbar: одинаковые размеры контролов справа (корзина / языки / профиль / бургер) --- */
    header nav > div:last-child {
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
        flex: 0 0 auto !important;
    }

    /* Корзина в шапке */
    #cartToggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        height: 40px !important;
        min-height: 40px !important;
        padding: 0 12px !important;
        border-radius: 12px !important;
        font-size: 12px !important;
        line-height: 1 !important;
        white-space: nowrap !important;
    }

    /* Переключатель языка */
    .lang-switcher {
        display: inline-flex !important;
        align-items: center !important;
        height: 40px !important;
        padding: 3px !important;
        border-radius: 12px !important;
    }

    .lang-btn {
        height: 30px !important;
        min-height: 30px !important;
        min-width: 0 !important;
        width: auto !important;
        padding: 0 10px !important;
        font-size: 12px !important;
        border-radius: 10px !important;
        line-height: 1 !important;
    }

    /* Кнопка профиля/входа */
    #authBtn,
    #authBtnHeader {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        height: 40px !important;
        min-height: 40px !important;
        padding: 0 12px !important;
        font-size: 12px !important;
        border-radius: 12px !important;
        white-space: nowrap !important;
        max-width: 180px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    /* Гамбургер */
    .hamburger {
        width: 40px !important;
        height: 40px !important;
        min-width: 40px !important;
        min-height: 40px !important;
        padding: 0 !important;
        border-radius: 12px !important;
    }

    /* --- Catalog: мобильная фиксированная панель поиска + выдвижные категории --- */
    .catalog-mobile-bar {
        position: fixed;
        top: 66px;
        left: 8px;
        right: 8px;
        z-index: 900;
        padding: 10px;
        display: flex;
        align-items: center;
        gap: 10px;
        border: 1px solid rgba(138, 43, 226, 0.22);
        background: rgba(10, 10, 20, 0.55);
        backdrop-filter: blur(18px);
        -webkit-backdrop-filter: blur(18px);
        border-radius: 16px;
    }

    .catalog-mobile-bar .form-input {
        height: 40px !important;
        min-height: 40px !important;
        padding: 0 14px !important;
        border-radius: 14px !important;
        font-size: 15px !important;
    }

    /* Скрываем лейбл в поиске на мобилке, чтобы было компактно */
    #catalogSearchBlock label {
        display: none !important;
    }

    .catalog-mobile-cat-btn {
        height: 40px;
        min-height: 40px;
        padding: 0 12px;
        border-radius: 14px;
        border: 1px solid rgba(255,255,255,0.10);
        background: rgba(255,255,255,0.03);
        color: rgba(255,255,255,0.92);
        display: inline-flex;
        align-items: center;
        gap: 10px;
        font-weight: 800;
        font-size: 13px;
        cursor: pointer;
        white-space: nowrap;
    }

    .catalog-mobile-cat-btn i {
        color: var(--violet-main);
    }

    .catalog-mobile-overlay {
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0.55);
        backdrop-filter: blur(4px);
        -webkit-backdrop-filter: blur(4px);
        opacity: 0;
        pointer-events: none;
        transition: opacity 220ms ease;
        z-index: 2000;
    }

    .catalog-mobile-overlay.active {
        opacity: 1;
        pointer-events: auto;
    }

    .catalog-mobile-drawer {
        position: fixed;
        top: 0;
        right: -100%;
        width: min(92vw, 380px);
        height: 100dvh;
        z-index: 2100;
        background: rgba(10, 10, 20, 0.92);
        border-left: 1px solid rgba(255,255,255,0.08);
        backdrop-filter: blur(22px);
        -webkit-backdrop-filter: blur(22px);
        transition: right 260ms cubic-bezier(0.4, 0, 0.2, 1);
        display: flex;
        flex-direction: column;
    }

    .catalog-mobile-drawer.active {
        right: 0;
    }

    .catalog-mobile-drawer .drawer-head {
        padding: 18px 18px 12px;
        display: flex;
        align-items: center;
        justify-content: space-between;
        border-bottom: 1px solid rgba(255,255,255,0.06);
    }

    .catalog-mobile-drawer .drawer-title {
        font-weight: 900;
        letter-spacing: 0.5px;
        font-size: 14px;
        opacity: 0.95;
    }

    .catalog-mobile-drawer .drawer-close {
        width: 36px;
        height: 36px;
        min-width: 36px;
        min-height: 36px;
        border-radius: 12px;
        border: 1px solid rgba(255,255,255,0.10);
        background: rgba(255,255,255,0.03);
        color: rgba(255,255,255,0.85);
        cursor: pointer;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .catalog-mobile-drawer .drawer-body {
        padding: 14px 14px 18px;
        overflow: auto;
    }

    /* Чтобы контент каталога не уезжал под фиксированную панель поиска */
    .catalog-layout {
        padding-top: 170px !important;
    }

    /* На мобилке фильтры открываются через drawer, поэтому sidebar скрываем */
    body.catalog-mobile-ui .catalog-layout aside {
        display: none !important;
    }
}

@media (max-width: 480px) {
    /* Не растягиваем кнопки в шапке на 100% */
    header .btn,
    header .btn-premium,
    header button,
    header #cartToggle {
        width: auto !important;
        max-width: none !important;
    }

    /* По запросу: в мобильном navbar убираем переключатель языка и профиль (они доступны в hamburger-меню). */
    header .lang-switcher,
    header #authBtn,
    header #authBtnHeader {
        display: none !important;
    }

    /* Фикс: иконка корзины не должна "улетать" вверх — принудительно центрируем контент. */
    header #cartToggle,
    header [data-action="toggle-cart"]#cartToggle {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        line-height: 1 !important;
        box-sizing: border-box;
        transform: none !important;
    }

    header #cartToggle i {
        display: block;
        margin-right: 0 !important;
        line-height: 1 !important;
    }
}

@media (min-width: 769px) {
    /* Каталог: мобильные элементы должны быть скрыты на ПК */
    .catalog-mobile-bar,
    .catalog-mobile-overlay,
    .catalog-mobile-drawer {
        display: none !important;
    }
}

/* === EXTRA COMPACT (360–420px): navbar + catalog bar === */
@media (max-width: 420px) {
    header {
        padding: 0 6px;
    }

    /* Checkout: на 360–420px убираем двойные отступы и предотвращаем переполнение */
    .checkout-section {
        padding-top: 100px !important;
        padding-bottom: 40px !important;
    }

    .checkout-container {
        padding: 0 !important;
        gap: 16px !important;
    }

    .checkout-form,
    .checkout-summary {
        padding: 16px !important;
        border-radius: 16px !important;
    }

    .payment-method {
        padding: 12px !important;
    }

    .summary-total {
        font-size: 1.1rem !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
    }

    /* Toast на мобилке не должен вылезать за экран */
    .toast {
        left: 12px !important;
        right: 12px !important;
        top: 14px !important;
        width: auto !important;
        max-width: calc(100% - 24px) !important;
    }


    header nav,
    nav.glass {
        padding: 6px 8px !important;
        min-height: 46px;
        max-height: 46px;
    }

    header nav > div:last-child {
        gap: 6px !important;
    }

    .navbar-logo {
        width: 32px !important;
        height: 32px !important;
    }

    header img[src*="logo.webp"],
    nav img[src*="logo.webp"],
    header img[src*="Logo.webp"],
    nav img[src*="Logo.webp"] {
        width: 32px !important;
        height: 32px !important;
    }

    /* На 360–420 лучше освободить место под контролы справа */
    .navbar-brand {
        display: none !important;
    }

    header #cartToggle {
        height: 34px !important;
        min-height: 34px !important;
        padding: 0 10px !important;
        font-size: 11px !important;
    }

    header .lang-switcher {
        height: 34px !important;
        padding: 3px !important;
    }

    header .lang-btn {
        height: 26px !important;
        min-height: 26px !important;
        padding: 0 8px !important;
        font-size: 11px !important;
    }

    header #authBtn,
    header #authBtnHeader {
        height: 34px !important;
        min-height: 34px !important;
        padding: 0 10px !important;
        font-size: 11px !important;
        max-width: 130px !important;
    }

    header .hamburger {
        width: 34px !important;
        height: 34px !important;
        min-width: 34px !important;
        min-height: 34px !important;
    }

    /* Catalog bar чуть компактнее */
    .catalog-mobile-bar {
        top: 60px;
        padding: 8px;
        gap: 8px;
        border-radius: 14px;
    }

    .catalog-mobile-bar .form-input {
        height: 36px !important;
        min-height: 36px !important;
        padding: 0 12px !important;
        font-size: 14px !important;
    }

    .catalog-mobile-cat-btn {
        height: 36px;
        min-height: 36px;
        padding: 0 10px;
        border-radius: 13px;
        font-size: 12px;
        gap: 8px;
    }
}

@media (max-width: 360px) {
    /* На 360px убираем лишний текст у кнопки категорий */
    .catalog-mobile-cat-btn span {
        display: none;
    }

    header #authBtn,
    header #authBtnHeader {
        max-width: 110px !important;
    }
}


/* === STEP 28: client mobile release pass === */
@media (max-width: 768px) {
    .orders-page {
        margin-top: 84px !important;
    }

    .orders-toolbar {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 12px !important;
        margin-bottom: 20px !important;
    }

    .orders-search {
        width: 100% !important;
        min-width: 0 !important;
    }

    .orders-list .order-item,
    #ordersList .order-item {
        align-items: flex-start !important;
        gap: 14px !important;
        border-radius: 18px !important;
    }

    .orders-list .order-item h4,
    #ordersList .order-item h4 {
        line-height: 1.45 !important;
        word-break: break-word !important;
    }

    .payment-container {
        padding-top: 0 !important;
    }

    .payment-card {
        padding: 28px 18px !important;
    }

    .payment-methods {
        grid-template-columns: 1fr !important;
    }

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

    .payment-details,
    #orderCompletedDetails {
        padding: 16px !important;
    }

    #paymentDetailsContent > div[style*="display:flex"],
    #orderCompletedContent > div[style*="display:flex"] {
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 10px !important;
    }

    .tos-checkbox label {
        line-height: 1.5 !important;
    }

    .profile-stat-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 12px !important;
    }

    .profile-card {
        max-width: 100% !important;
        padding: 24px 18px !important;
    }

    .profile-inline-row {
        display: flex !important;
        flex-direction: column !important;
        align-items: stretch !important;
        gap: 10px !important;
    }

    .profile-inline-row .btn-premium {
        width: 100% !important;
        height: auto !important;
        min-height: 46px !important;
        padding: 12px 16px !important;
    }

    .status-main-nav {
        padding: 10px 14px !important;
    }

    .status-card {
        padding: 28px 18px !important;
    }

    .status-details {
        text-align: left !important;
    }
}

@media (max-width: 480px) {
    .orders-page {
        margin-top: 76px !important;
    }

    .orders-page > .glass,
    .orders-page .glass {
        padding: 18px 14px !important;
    }

    .orders-list .order-item,
    #ordersList .order-item {
        padding: 16px 14px !important;
    }

    .payment-card {
        padding: 22px 14px !important;
    }

    .payment-title {
        font-size: 1.55rem !important;
        line-height: 1.2 !important;
    }

    .payment-amount {
        font-size: 1.8rem !important;
        line-height: 1.15 !important;
    }

    .payment-method-card {
        border-radius: 16px !important;
    }

    .payment-link-btn {
        width: 100% !important;
        justify-content: center !important;
        text-align: center !important;
    }

    .profile-stat-grid {
        grid-template-columns: 1fr !important;
    }

    .profile-card {
        padding: 18px 14px !important;
        border-radius: 16px !important;
    }

    .menu-item {
        padding: 12px 14px !important;
    }

    .status-main-nav {
        padding: 8px 10px !important;
        border-radius: 16px !important;
    }

    .status-card {
        padding: 22px 14px !important;
        border-radius: 18px !important;
    }
}
