/*
|--------------------------------------------------------------------------
| EasyPrintDz CRM - Mobile UI Final Polish V21
| Scope: UI/CSS only. No business logic.
|--------------------------------------------------------------------------
*/

@media (max-width: 768px) {
    html, body {
        overflow-x: hidden !important;
        max-width: 100% !important;
    }

    body {
        -webkit-font-smoothing: antialiased;
        text-rendering: optimizeLegibility;
    }

    .container,
    .container-fluid,
    .page-wrapper,
    .content-wrapper,
    main,
    .main-content {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: 10px !important;
        padding-right: 10px !important;
        overflow-x: hidden !important;
    }

    .card,
    .stat-card,
    .dashboard-card,
    .ep-card,
    .panel,
    .box {
        border-radius: 16px !important;
        margin-bottom: 12px !important;
        overflow: hidden !important;
    }

    .card-body,
    .panel-body,
    .box-body {
        padding: 12px !important;
    }

    h1, .h1 {
        font-size: 22px !important;
        line-height: 1.25 !important;
    }

    h2, .h2 {
        font-size: 19px !important;
        line-height: 1.3 !important;
    }

    h3, .h3 {
        font-size: 17px !important;
        line-height: 1.35 !important;
    }

    h4, .h4 {
        font-size: 16px !important;
    }

    p, span, div, td, th, label, input, select, textarea, button, a {
        font-size: 14px;
    }

    .small,
    small,
    .text-muted {
        font-size: 12px !important;
    }

    .btn,
    button,
    input[type="submit"] {
        min-height: 40px !important;
        border-radius: 12px !important;
        font-weight: 600 !important;
        touch-action: manipulation;
    }

    .btn-sm {
        min-height: 34px !important;
        padding: 6px 10px !important;
        font-size: 12px !important;
    }

    .btn-group,
    .actions,
    .table-actions,
    .action-buttons {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 6px !important;
    }

    input,
    select,
    textarea,
    .form-control,
    .form-select {
        min-height: 42px !important;
        border-radius: 12px !important;
        font-size: 14px !important;
    }

    .form-group,
    .mb-3 {
        margin-bottom: 10px !important;
    }

    .row {
        margin-left: -6px !important;
        margin-right: -6px !important;
    }

    .row > [class*="col-"] {
        padding-left: 6px !important;
        padding-right: 6px !important;
    }

    .table-responsive {
        width: 100% !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        border-radius: 14px !important;
    }

    table {
        white-space: nowrap;
        font-size: 13px !important;
    }

    table th,
    table td {
        padding: 8px 9px !important;
        vertical-align: middle !important;
    }

    table th {
        font-size: 12px !important;
        font-weight: 700 !important;
    }

    .badge,
    .status,
    .label {
        border-radius: 999px !important;
        padding: 5px 8px !important;
        font-size: 11px !important;
        font-weight: 700 !important;
        white-space: nowrap !important;
    }

    .navbar,
    .topbar,
    .header,
    .admin-header {
        max-width: 100% !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .navbar-nav,
    .nav,
    .tabs,
    .nav-tabs,
    .admin-nav {
        flex-wrap: nowrap !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: thin;
    }

    .navbar-nav .nav-link,
    .nav .nav-link,
    .tabs a,
    .admin-nav a {
        white-space: nowrap !important;
        padding: 8px 10px !important;
        border-radius: 999px !important;
    }

    .dropdown-menu {
        max-width: calc(100vw - 20px) !important;
        overflow-x: hidden !important;
        border-radius: 14px !important;
    }

    .alert {
        border-radius: 14px !important;
        padding: 10px 12px !important;
        font-size: 13px !important;
    }

    .modal-dialog {
        margin: 10px !important;
        max-width: calc(100% - 20px) !important;
    }

    .modal-content {
        border-radius: 18px !important;
    }

    .modal-body,
    .modal-header,
    .modal-footer {
        padding: 12px !important;
    }

    .pagination {
        flex-wrap: wrap !important;
        gap: 4px !important;
        justify-content: center !important;
    }

    .pagination .page-link {
        border-radius: 10px !important;
        min-width: 34px !important;
        text-align: center !important;
    }
}

/* Stronger phone mode */
@media (max-width: 480px) {
    .container,
    .container-fluid,
    main,
    .main-content {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    .card-body,
    .panel-body,
    .box-body {
        padding: 10px !important;
    }

    h1, .h1 {
        font-size: 20px !important;
    }

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

    .btn {
        width: auto;
    }

    .btn.full-mobile,
    .mobile-full,
    .w-mobile-100 {
        width: 100% !important;
    }

    table th,
    table td {
        padding: 7px 8px !important;
    }

    .hide-on-phone {
        display: none !important;
    }
}

/* POS comfort */
@media (max-width: 768px) {
    .pos-page .btn,
    body[class*="pos"] .btn,
    .quick-sale .btn {
        min-height: 44px !important;
    }

    .pos-page input,
    .pos-page select,
    .quick-sale input,
    .quick-sale select {
        min-height: 44px !important;
    }
}

/* Prevent long codes, emails, refs from breaking layout */
@media (max-width: 768px) {
    .key-value,
    .license-key,
    .sale-ref,
    .transaction-ref,
    .email,
    .long-text,
    code,
    pre {
        max-width: 100% !important;
        overflow-wrap: anywhere !important;
        word-break: break-word !important;
        white-space: normal !important;
    }
}
