/**
 * Responsive Design - التصميم المتجاوب
 * Mobile First Approach
 * 
 * @package SociAir
 * @since 1.0.0
 */

/* ==========================================================================
   Large Screens (1280px+)
   ========================================================================== */

@media (min-width: 1280px) {
  .site-container {
    max-width: var(--container-2xl);
  }
  
  .dashboard-welcome h1 {
    font-size: var(--font-size-5xl);
  }
}

/* ==========================================================================
   Desktop (1024px - 1279px)
   ========================================================================== */

@media (max-width: 1279px) {
  .site-container {
    max-width: var(--container-xl);
  }
}

/* ==========================================================================
   Tablet Landscape (1024px)
   ========================================================================== */

@media (max-width: 1024px) {
  /* Typography */
  h1 { font-size: var(--font-size-4xl); }
  h2 { font-size: var(--font-size-3xl); }
  h3 { font-size: var(--font-size-2xl); }
  
  /* Container */
  .site-container {
    padding: 0 var(--spacing-4);
  }
  
  .content-wrapper {
    padding: var(--spacing-6);
  }
  
  /* Dashboard */
  .dashboard-welcome {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .welcome-actions {
    width: 100%;
  }
  
  .welcome-actions .btn {
    flex: 1;
  }
  
  .stats-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  
  /* Conversations - rely on page-specific layout, keep sidebar visible by default */
  .conversations-layout {
    grid-template-columns: 1fr;
    height: auto;
  }
  
  .conversations-sidebar {
    display: flex;
  }
  
  .conversations-sidebar.mobile-visible {
    display: flex;
  }
  
  /* Sidebar Layout */
  .page-with-sidebar {
    grid-template-columns: 1fr;
  }
  
  .sidebar {
    position: static;
  }
}

/* ==========================================================================
   Tablet Portrait (768px)
   ========================================================================== */

@media (max-width: 768px) {
  /* Typography */
  h1 { font-size: var(--font-size-3xl); }
  h2 { font-size: var(--font-size-2xl); }
  h3 { font-size: var(--font-size-xl); }
  
  /* Header */
  .header-inner {
    padding: var(--spacing-3) 0;
  }
  
  .site-name {
    font-size: var(--font-size-xl);
  }
  
  .custom-logo {
    max-height: 48px;
  }
  
  /* Footer */
  .footer-main {
    padding: var(--spacing-8) 0;
  }
  
  .footer-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-6);
  }
  
  .footer-bottom-inner {
    flex-direction: column;
    text-align: center;
    gap: var(--spacing-2);
  }
  
  /* Dashboard */
  .dashboard-container {
    padding: var(--spacing-6) 0;
  }
  
  .dashboard-header {
    margin-bottom: var(--spacing-6);
  }
  
  .dashboard-welcome h1 {
    font-size: var(--font-size-3xl);
  }
  
  .dashboard-welcome p {
    font-size: var(--font-size-base);
  }
  
  .stats-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-4);
  }
  
  .stat-card {
    padding: var(--spacing-4);
  }
  
  .stat-icon {
    width: 56px;
    height: 56px;
    font-size: var(--font-size-2xl);
  }
  
  .stat-value {
    font-size: var(--font-size-2xl);
  }
  
  /* Accounts */
  .accounts-container {
    padding: var(--spacing-6) 0;
  }
  
  .accounts-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-4);
  }
  
  .accounts-header h1 {
    font-size: var(--font-size-3xl);
  }
  
  .usage-stats {
    padding: var(--spacing-6);
  }
  
  .usage-stats-content {
    flex-direction: column;
    align-items: flex-start;
  }
  
  .usage-info h2 {
    font-size: var(--font-size-2xl);
  }
  
  .usage-info p {
    font-size: var(--font-size-base);
  }
  
  .usage-progress {
    width: 100%;
    max-width: none;
  }
  
  .accounts-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-4);
  }
  
  /* Conversations */
  .chat-header {
    padding: var(--spacing-4);
  }
  
  .chat-messages {
    padding: var(--spacing-4);
  }
  
  .chat-input-area {
    padding: var(--spacing-4);
  }
  
  .message-content {
    max-width: 75%;
  }
  
  /* Cards */
  .card {
    padding: var(--spacing-4);
  }
  
  .card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--spacing-3);
  }
  
  /* Buttons */
  .btn-group {
    flex-direction: column;
    width: 100%;
  }
  
  .btn-group .btn {
    width: 100%;
  }
  
  /* Tables */
  .table-container {
    border-radius: var(--radius-lg);
  }
  
  .table th,
  .table td {
    padding: var(--spacing-3) var(--spacing-4);
    font-size: var(--font-size-sm);
  }
  
  /* Modal */
  .modal-content {
    max-width: 95%;
  }
  
  .modal-header,
  .modal-body,
  .modal-footer {
    padding: var(--spacing-4);
  }
  
  .modal-title {
    font-size: var(--font-size-xl);
  }
  
  /* Tabs */
  .tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  .tab-item {
    padding: var(--spacing-2) var(--spacing-4);
    font-size: var(--font-size-sm);
    white-space: nowrap;
  }
  
  /* Empty State */
  .empty-state {
    padding: var(--spacing-12) var(--spacing-4);
  }
  
  .empty-state-icon {
    font-size: 60px;
  }
  
  .empty-state h2 {
    font-size: var(--font-size-2xl);
  }
  
  .empty-state p {
    font-size: var(--font-size-base);
  }
}

/* ==========================================================================
   Mobile (480px)
   ========================================================================== */

@media (max-width: 480px) {
  /* Typography */
  h1 { font-size: var(--font-size-2xl); }
  h2 { font-size: var(--font-size-xl); }
  h3 { font-size: var(--font-size-lg); }
  
  /* Container */
  .site-container {
    padding: 0 var(--spacing-3);
  }
  
  .content-wrapper {
    padding: var(--spacing-4);
    border-radius: var(--radius-lg);
  }
  
  /* Header */
  .header-inner {
    padding: var(--spacing-2) 0;
  }
  
  .site-name {
    font-size: var(--font-size-lg);
  }
  
  .custom-logo {
    max-height: 40px;
  }
  
  /* Footer */
  .footer-main {
    padding: var(--spacing-6) 0;
  }
  
  .footer-widget-title {
    font-size: var(--font-size-base);
  }
  
  .footer-social {
    justify-content: center;
  }
  
  .social-link {
    width: 36px;
    height: 36px;
  }
  
  .footer-bottom {
    padding: var(--spacing-4) 0;
  }
  
  .footer-copyright,
  .footer-credits {
    font-size: var(--font-size-xs);
  }
  
  /* Dashboard */
  .dashboard-container {
    padding: var(--spacing-4) 0;
  }
  
  .dashboard-welcome h1 {
    font-size: var(--font-size-2xl);
  }
  
  .dashboard-welcome p {
    font-size: var(--font-size-sm);
  }
  
  .welcome-actions {
    flex-direction: column;
  }
  
  .welcome-actions .btn {
    width: 100%;
  }
  
  .stats-grid {
    gap: var(--spacing-3);
  }
  
  .stat-card {
    flex-direction: column;
    text-align: center;
    padding: var(--spacing-4);
  }
  
  .stat-icon {
    width: 48px;
    height: 48px;
    font-size: var(--font-size-xl);
  }
  
  .stat-value {
    font-size: var(--font-size-xl);
  }
  
  .stat-label {
    font-size: var(--font-size-xs);
  }
  
  /* Accounts */
  .accounts-container {
    padding: var(--spacing-4) 0;
  }
  
  .accounts-header h1 {
    font-size: var(--font-size-2xl);
  }
  
  .usage-stats {
    padding: var(--spacing-4);
  }
  
  .usage-info h2 {
    font-size: var(--font-size-xl);
  }
  
  .usage-info p {
    font-size: var(--font-size-sm);
  }
  
  .accounts-grid {
    gap: var(--spacing-3);
  }
  
  .account-card {
    padding: var(--spacing-4);
  }
  
  .account-platform-icon {
    width: 48px;
    height: 48px;
    font-size: var(--font-size-xl);
  }
  
  .account-info h3 {
    font-size: var(--font-size-base);
  }
  
  .account-stats {
    flex-direction: column;
    gap: var(--spacing-2);
  }
  
  .account-card-footer {
    flex-direction: column;
  }
  
  .account-card-footer .btn {
    width: 100%;
  }
  
  /* Conversations */
  .conversations-container {
    padding: var(--spacing-4) 0;
  }
  
  .chat-area {
    border-radius: var(--radius-lg);
  }
  
  .chat-header {
    padding: var(--spacing-3);
  }
  
  .chat-messages {
    padding: var(--spacing-3);
  }
  
  .chat-input-area {
    padding: var(--spacing-3);
  }
  
  .chat-input-form {
    flex-direction: column;
  }
  
  .chat-input-form .btn {
    width: 100%;
  }
  
  .message {
    margin-bottom: var(--spacing-3);
  }
  
  .message-avatar {
    width: 32px;
    height: 32px;
  }
  
  .message-content {
    max-width: 85%;
  }
  
  .message-bubble {
    padding: var(--spacing-2) var(--spacing-3);
    font-size: var(--font-size-sm);
  }
  
  /* Cards */
  .card {
    padding: var(--spacing-3);
    border-radius: var(--radius-lg);
  }
  
  .card-title {
    font-size: var(--font-size-lg);
  }
  
  /* Buttons */
  .btn {
    padding: var(--spacing-2) var(--spacing-4);
    font-size: var(--font-size-sm);
  }
  
  .btn-lg {
    padding: var(--spacing-3) var(--spacing-6);
    font-size: var(--font-size-base);
  }
  
  /* Forms */
  .form-control {
    padding: var(--spacing-2) var(--spacing-3);
    font-size: var(--font-size-sm);
  }
  
  .form-label {
    font-size: var(--font-size-sm);
  }
  
  /* Alerts */
  .alert {
    padding: var(--spacing-3) var(--spacing-4);
    font-size: var(--font-size-sm);
  }
  
  /* Modal */
  .modal {
    padding: var(--spacing-2);
  }
  
  .modal-content {
    max-width: 100%;
  }
  
  .modal-header,
  .modal-body,
  .modal-footer {
    padding: var(--spacing-3);
  }
  
  .modal-title {
    font-size: var(--font-size-lg);
  }
  
  .modal-footer {
    flex-direction: column;
  }
  
  .modal-footer .btn {
    width: 100%;
  }
  
  /* Tables - Convert to Cards on Mobile */
  .table-container {
    border-radius: var(--radius-md);
  }
  
  .table thead {
    display: none;
  }
  
  .table tbody tr {
    display: block;
    margin-bottom: var(--spacing-4);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-lg);
    padding: var(--spacing-3);
  }
  
  .table td {
    display: flex;
    justify-content: space-between;
    padding: var(--spacing-2) 0;
    border: none;
  }
  
  .table td::before {
    content: attr(data-label);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-700);
  }
  
  /* Pagination */
  .pagination {
    gap: var(--spacing-1);
  }
  
  .page-link {
    min-width: 36px;
    height: 36px;
    padding: var(--spacing-1) var(--spacing-2);
    font-size: var(--font-size-sm);
  }
  
  /* Back to Top */
  .back-to-top {
    width: 40px;
    height: 40px;
    bottom: var(--spacing-4);
    left: var(--spacing-4);
  }
  
  /* Empty State */
  .empty-state {
    padding: var(--spacing-8) var(--spacing-3);
  }
  
  .empty-state-icon {
    font-size: 48px;
  }
  
  .empty-state h2 {
    font-size: var(--font-size-xl);
  }
  
  .empty-state p {
    font-size: var(--font-size-sm);
  }
}

/* ==========================================================================
   Extra Small Mobile (320px)
   ========================================================================== */

@media (max-width: 360px) {
  /* Ensure minimum usability on very small screens */
  .site-container {
    padding: 0 var(--spacing-2);
  }
  
  .content-wrapper {
    padding: var(--spacing-3);
  }
  
  h1 { font-size: var(--font-size-xl); }
  h2 { font-size: var(--font-size-lg); }
  h3 { font-size: var(--font-size-base); }
  
  .btn {
    padding: var(--spacing-2) var(--spacing-3);
    font-size: var(--font-size-xs);
  }
  
  .stat-card {
    padding: var(--spacing-3);
  }
  
  .stat-icon {
    width: 40px;
    height: 40px;
    font-size: var(--font-size-lg);
  }
  
  .stat-value {
    font-size: var(--font-size-lg);
  }
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
  /* Hide non-essential elements */
  .site-header,
  .site-footer,
  .back-to-top,
  .mobile-menu-toggle,
  .btn,
  .alert-close,
  .modal-close {
    display: none !important;
  }
  
  /* Optimize for printing */
  body {
    background: white;
    color: black;
  }
  
  .content-wrapper {
    box-shadow: none;
    border: 1px solid #ddd;
  }
  
  a {
    text-decoration: underline;
  }
  
  /* Page breaks */
  .card,
  .stat-card {
    page-break-inside: avoid;
  }
}

/* ==========================================================================
   Accessibility - High Contrast Mode
   ========================================================================== */

@media (prefers-contrast: high) {
  .btn {
    border-width: 3px;
  }
  
  .form-control:focus {
    outline: 3px solid var(--color-primary);
    outline-offset: 2px;
  }
  
  a:focus-visible {
    outline-width: 3px;
  }
}

/* ==========================================================================
   Reduced Motion
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  
  .btn:hover,
  .card:hover,
  .stat-card:hover {
    transform: none;
  }
}
