/**
 * Bohio MAG — Responsive Utilities
 * Global responsive fixes for ALL pages and ALL roles.
 * Loaded by includes/header.php after style.css — no design changes, only layout fixes.
 * Version: 1.0  |  23 février 2026
 */

/* ═══════════════════════════════════════════════
   1. TABLE RESPONSIVE WRAPPER
   Auto-injected by main.js initResponsiveTables()
   ═══════════════════════════════════════════════ */

.table-responsive {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    width: 100%;
    scrollbar-width: thin;
    scrollbar-color: var(--primary, #8b5a2b) transparent;
}

.table-responsive::-webkit-scrollbar {
    height: 4px;
}

.table-responsive::-webkit-scrollbar-track {
    background: transparent;
}

.table-responsive::-webkit-scrollbar-thumb {
    background-color: var(--primary, #8b5a2b);
    border-radius: 2px;
}

/* Ensure wrapped tables keep full layout */
.table-responsive > table {
    margin-bottom: 0;
}

/* ═══════════════════════════════════════════════
   2. DASHBOARD — ADMIN / AUTHOR / EDITOR
   ═══════════════════════════════════════════════ */

/* Columns marked as non-essential on mobile */
.hide-mob {
    /* shown on desktop, hidden below 768px */
}

@media (max-width: 900px) {
    /* Stats / KPI grids: 3 cols → 2 cols */
    .stats-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 768px) {
    /* Hide non-essential table columns */
    .hide-mob {
        display: none !important;
    }

    /* Data tables — minimum width so columns don't squash */
    table.data-table,
    table.table,
    table.chapters-table,
    table.works-table {
        min-width: 560px;
    }

    /* KPI / stats: 2-column grid */
    .stats-grid,
    .kpi-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: var(--spacing-sm, 0.5rem) !important;
    }

    /* Dashboard layout: sidebar + content → stacked */
    .dashboard-layout {
        flex-direction: column !important;
    }

    .dashboard-sidebar {
        width: 100% !important;
        min-width: unset !important;
        max-width: unset !important;
    }

    /* Dashboard action button rows → wrap */
    .dashboard-actions,
    .header-actions {
        flex-wrap: wrap;
        gap: var(--spacing-sm, 0.5rem);
    }

    .dashboard-actions .btn,
    .header-actions .btn {
        flex: 1 1 auto;
        min-width: 120px;
    }

    /* Admin/Editor - smaller action buttons in tables */
    td .btn-sm,
    th .btn-sm {
        padding: 3px 8px !important;
        font-size: 0.7rem !important;
        white-space: nowrap;
    }

    /* Breadcrumbs wrap */
    .breadcrumb {
        flex-wrap: wrap;
    }

    /* Tab navigation: horizontal scroll */
    .tabs,
    .tab-nav,
    .nav-tabs {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
        flex-wrap: nowrap !important;
        scrollbar-width: none;
        padding-bottom: 2px;
    }

    .tabs::-webkit-scrollbar,
    .tab-nav::-webkit-scrollbar,
    .nav-tabs::-webkit-scrollbar {
        display: none;
    }

    /* Page/section titles — fluid size */
    .page-title,
    .section-title {
        font-size: clamp(1rem, 3.5vw, 1.4rem) !important;
    }
}

@media (max-width: 480px) {
    /* KPI → single column on tiny screens */
    .stats-grid,
    .kpi-grid {
        grid-template-columns: 1fr !important;
    }

    /* Score circles — reduced */
    .score-circle {
        width: 36px !important;
        height: 36px !important;
        font-size: 0.72rem !important;
    }

    /* Card padding reduction */
    .card {
        padding: var(--spacing-md, 1rem) !important;
    }

    /* Section headers — stack label + link */
    .section-header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-xs, 0.25rem);
    }
}

/* ═══════════════════════════════════════════════
   3. FORMS — RESPONSIVE
   ═══════════════════════════════════════════════ */

@media (max-width: 768px) {
    /* Multi-column form grids → 1 column */
    .form-grid,
    .form-row.cols-2,
    .form-row.cols-3 {
        grid-template-columns: 1fr !important;
        flex-direction: column !important;
    }

    /* All inputs full width */
    .form-control,
    input[type="text"],
    input[type="email"],
    input[type="password"],
    input[type="number"],
    input[type="date"],
    input[type="datetime-local"],
    input[type="url"],
    select,
    textarea {
        width: 100%;
        box-sizing: border-box;
        max-width: 100%;
    }

    /* Tag / checkbox grids → 2 cols */
    .tags-grid,
    .checkbox-grid,
    .genre-checkboxes {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 480px) {
    /* Tags → 1 col on tiny phones */
    .tags-grid,
    .checkbox-grid,
    .genre-checkboxes {
        grid-template-columns: 1fr !important;
    }
}

/* ═══════════════════════════════════════════════
   4. MODALS — RESPONSIVE
   ═══════════════════════════════════════════════ */

@media (max-width: 768px) {
    .modal,
    .modal-content {
        width: 95vw !important;
        max-width: 95vw !important;
        margin: auto !important;
        max-height: 90dvh;
        overflow-y: auto;
    }

    .modal-footer,
    .modal-actions {
        flex-direction: column;
        gap: var(--spacing-sm, 0.5rem);
    }

    .modal-footer .btn,
    .modal-actions .btn {
        width: 100%;
    }
}

/* ═══════════════════════════════════════════════
   5. BUTTON GROUPS & ACTION ROWS
   ═══════════════════════════════════════════════ */

@media (max-width: 640px) {
    .btn-group,
    .action-buttons,
    .button-row {
        flex-direction: column;
        width: 100%;
        gap: var(--spacing-sm, 0.5rem);
    }

    .btn-group .btn,
    .action-buttons .btn,
    .button-row .btn {
        width: 100%;
        text-align: center;
    }
}

/* ═══════════════════════════════════════════════
   6. IMAGES — LAZY & COVER FIXES
   ═══════════════════════════════════════════════ */

/* Prevent cover image overflow in any container */
.work-cover img,
.cover-img,
img.work-cover-img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* Avatars always cover their circle */
.user-avatar img,
.avatar img,
img.avatar {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

/* ═══════════════════════════════════════════════
   7. SIDEBAR — TOUCH IMPROVEMENTS
   ═══════════════════════════════════════════════ */

@media (max-width: 768px) {
    /* Larger tap targets for sidebar links */
    .sidebar .nav-link,
    .sidebar-nav a,
    .sidebar-menu a {
        min-height: 44px;
        display: flex;
        align-items: center;
    }

    /* Smooth sidebar slide */
    #sidebar,
    .sidebar {
        transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1) !important;
    }
}

/* ═══════════════════════════════════════════════
   8. WALLET & PROFILE PAGES
   ═══════════════════════════════════════════════ */

@media (max-width: 600px) {
    .wallet-summary,
    .profile-stats {
        flex-direction: column;
        gap: var(--spacing-md, 1rem);
    }

    .wallet-balance-card,
    .stat-card {
        width: 100%;
        min-width: unset;
    }
}

/* ═══════════════════════════════════════════════
   9. WORK PAGE — CHAPTER LIST
   ═══════════════════════════════════════════════ */

@media (max-width: 768px) {
    /* Chapter list purchase badges */
    .chapter-item {
        flex-wrap: wrap;
        gap: var(--spacing-xs, 0.25rem);
    }

    .chapter-meta {
        font-size: 0.75rem;
    }

    /* Work header → stack */
    .work-header {
        flex-direction: column;
    }

    .work-cover-container {
        width: 100%;
        max-width: 220px;
        margin: 0 auto;
    }
}

/* ═══════════════════════════════════════════════
   10. READER PAGE — mobile typography
   ═══════════════════════════════════════════════ */

@media (max-width: 600px) {
    .reader-container {
        padding: var(--spacing-sm, 0.5rem) !important;
    }

    .reader-nav {
        flex-wrap: nowrap;
        overflow-x: auto;
        gap: var(--spacing-sm, 0.5rem);
        scrollbar-width: none;
    }

    .reader-nav::-webkit-scrollbar {
        display: none;
    }

    .reader-chapter-title {
        font-size: clamp(1rem, 4vw, 1.4rem);
    }
}

/* ═══════════════════════════════════════════════
   12. ADMIN — USERS PAGE
   ═══════════════════════════════════════════════ */

/* Default: show/hide helpers already defined (.hide-mob toggles at 768px)  */
.show-mob { display: none; }

/* Action buttons container in table rows */
.actions-btn-group {
    display: flex;
    gap: 0.25rem;
    flex-wrap: wrap;
    align-items: center;
}

/* Filter bar: search + role select + button on one row */
.users-filter-grid {
    display: grid;
    grid-template-columns: 2fr 1fr auto;
    gap: 1rem;
    align-items: end;
}

/* Keep table scrollable without squashing */
.table-users {
    min-width: 520px;
}

/* Email col: break long addresses instead of stretching the column */
.table-users td:nth-child(3) {
    word-break: break-all;
    max-width: 180px;
}

/* Actions column: min-width so buttons don't overflow into adjacent cells */
.table-users .actions-cell {
    min-width: 140px;
}

@media (max-width: 900px) {
    .users-filter-grid {
        grid-template-columns: 1fr 1fr;
    }
    .users-filter-grid button[type="submit"] {
        grid-column: 1 / -1;
        width: 100%;
    }
}

@media (max-width: 768px) {
    /* Reveal inline email on mobile (inside user cell) */
    .show-mob { display: block !important; }

    /* Actions buttons: stack vertically for readability */
    .actions-btn-group {
        flex-direction: column;
        align-items: stretch;
        gap: 0.3rem;
        min-width: 100px;
    }

    .actions-btn-group form {
        width: 100%;
    }

    .actions-btn-group .btn-xs {
        width: 100%;
        text-align: center;
        padding: 0.3rem 0.5rem !important;
        font-size: 0.72rem !important;
    }

    /* Suspend form: stack number + button */
    .actions-btn-group form[style*="inline-flex"] {
        display: flex !important;
        flex-direction: column;
        gap: 0.2rem;
    }

    .actions-btn-group input[type="number"] {
        width: 100% !important;
        box-sizing: border-box;
    }

    .users-filter-grid {
        grid-template-columns: 1fr;
    }

    .users-filter-grid button[type="submit"] {
        width: 100%;
    }
}

@media (max-width: 480px) {
    /* Create user form: single column on phones */
    #create-user-panel > div > form > div[style*="grid"] {
        grid-template-columns: 1fr !important;
    }
}



@media print {
    #sidebar,
    .sidebar,
    .header,
    .navbar,
    .btn,
    .modal-overlay,
    .carousel-btn,
    .notification-badge {
        display: none !important;
    }

    .dashboard-content,
    main {
        margin: 0 !important;
        padding: 0 !important;
    }

    table {
        page-break-inside: avoid;
        font-size: 11pt;
    }
}
