/* ============================================
   Адаптивность
   ============================================ */

/* ============================================
   Large Screens (Desktop) - Lighter weights
   ============================================ */

@media (min-width: 768px) {
    .btn {
        font-weight: 400;
        padding: 12px 20px;
        font-size: 0.95rem;
    }

    .btn-header {
        padding: 10px 20px;
        font-size: 0.85rem;
    }

    .card-title {
        font-weight: 500;
    }

}

@media (max-width: 1024px) {
    .view {
        padding: 16px 0 24px;
    }
    
    .main {
        padding-left: clamp(14px, 3vw, 24px);
        padding-right: clamp(14px, 3vw, 24px);
    }
}

@media (max-width: 768px) {
    /* Header стили перенесены в header.css */
    
    .card {
        padding: 16px 18px;
    }
    
}

@media (max-width: 520px) {
    .card {
        padding: 16px 18px;
    }
}

@media (max-width: 420px) {
    body {
        overflow-x: hidden;
    }
    
    /* Header стили перенесены в header.css */

    #mastersGrid,
    #favoritesGrid,
    .masters-grid {
        display: grid !important;
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important;
        gap: 10px !important;
    }

    .master-content {
        padding: 8px;
        gap: 4px;
    }

    .master-name {
        font-size: 0.85rem;
    }

    .master-specialization {
        font-size: 0.7rem;
    }

    .master-price {
        font-size: 0.75rem;
    }
}

/* ============================================
   Accessibility
   ============================================ */

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ============================================
   Utility Classes
   ============================================ */

.hidden {
    display: none !important;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}
