/* Mobile Responsiveness Fixes */

/* Prevent horizontal scrolling */
html, body {
    overflow-x: hidden !important;
    max-width: 100% !important;
}

/* Container responsiveness */
.container, .container-fluid {
    max-width: 100% !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
}

/* Ensure all elements stay within viewport */
* {
    max-width: 100% !important;
    box-sizing: border-box !important;
}

/* Fix wide elements */
.row {
    margin-left: 0 !important;
    margin-right: 0 !important;
}

.col, [class*="col-"] {
    padding-left: 8px !important;
    padding-right: 8px !important;
}

/* Navigation fixes */
.navbar {
    max-width: 100% !important;
}

.navbar-collapse {
    max-width: 100% !important;
}

/* Design tool mobile fixes */
@media (max-width: 768px) {
    /* Design tool container */
    .designer-lightbox {
        width: 100vw !important;
        height: 100vh !important;
        position: fixed !important;
        top: 0 !important;
        left: 0 !important;
        padding: 10px !important;
        overflow: auto !important;
    }

    .designer-container {
        max-width: 100% !important;
        height: 100% !important;
        padding: 10px !important;
    }

    /* Canvas area */
    .canvas-container {
        width: 100% !important;
        max-width: 350px !important;
        margin: 0 auto !important;
        overflow: hidden !important;
    }

    #design-canvas {
        width: 100% !important;
        max-width: 300px !important;
        height: auto !important;
        max-height: 300px !important;
    }

    /* Sidebar mobile layout */
    .designer-sidebar {
        width: 100% !important;
        margin-top: 20px !important;
        padding: 10px !important;
    }

    /* Mobile controls */
    .mobile-controls {
        position: fixed !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        background: white !important;
        padding: 15px !important;
        border-top: 1px solid #ddd !important;
        z-index: 1000 !important;
    }

    /* Upload notification positioning */
    .upload-notification,
    .alert-success,
    .alert-info,
    .alert-warning,
    .alert-danger {
        position: fixed !important;
        top: 60px !important;
        left: 10px !important;
        right: 10px !important;
        width: auto !important;
        max-width: calc(100vw - 20px) !important;
        z-index: 9999 !important;
        margin: 0 !important;
    }

    /* Ensure notifications don't overlap canvas */
    .position-fixed.alert {
        top: 60px !important;
        left: 10px !important;
        right: 10px !important;
        width: auto !important;
    }

    /* Fix button sizing */
    .btn {
        max-width: 100% !important;
    }

    /* Fix form inputs */
    .form-control, .form-select {
        max-width: 100% !important;
    }

    /* Fix images */
    img {
        max-width: 100% !important;
        height: auto !important;
    }

    /* Fix tables */
    .table-responsive {
        border: none !important;
    }

    /* Fix cards */
    .card {
        max-width: 100% !important;
    }

    /* Fix modals */
    .modal-dialog {
        max-width: calc(100vw - 20px) !important;
        margin: 10px !important;
    }
}

/* Extra small devices */
@media (max-width: 576px) {
    .container, .container-fluid {
        padding-left: 10px !important;
        padding-right: 10px !important;
    }

    .designer-lightbox {
        padding: 5px !important;
    }

    #design-canvas {
        max-width: 280px !important;
        max-height: 280px !important;
    }

    .upload-notification {
        font-size: 14px !important;
        padding: 10px !important;
    }
}

/* Prevent zoom issues */
@viewport {
    width: device-width;
    zoom: 1.0;
}

/* Fix webkit mobile issues */
-webkit-text-size-adjust: 100% !important;
-moz-text-size-adjust: 100% !important;
-ms-text-size-adjust: 100% !important;
text-size-adjust: 100% !important;