/* Override conflicting styles and ensure fluid layout */
.container,
.container-fluid,
.tm-container,
.tm-page-wrap,
.tm-content-container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: var(--container-padding, 15px) !important;
    padding-right: var(--container-padding, 15px) !important;
    overflow-x: hidden;
}

/* Container padding responsive adjustments */
:root {
    --container-padding: 15px;
}

@media (min-width: 768px) {
    :root {
        --container-padding: 30px;
    }
}

@media (min-width: 1200px) {
    :root {
        --container-padding: 60px;
    }
    .container,
    .container-fluid,
    .tm-container {
        max-width: 1920px !important;
        margin: 0 auto;
    }
}

/* Fix templatemo video container conflicts */
#tm-video-container {
    width: 100% !important;
    overflow: hidden;
}

#tm-video {
    width: 100% !important;
    height: auto;
    object-fit: cover;
}

/* Fix gallery grid layout */
.tm-catalog-item-list {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 20px !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 20px !important;
    margin: 0 auto !important;
}

/* Row fixes */
.row {
    margin-left: calc(var(--container-padding) * -1) !important;
    margin-right: calc(var(--container-padding) * -1) !important;
    width: auto !important;
}

/* Image responsiveness */
img,
video,
iframe {
    max-width: 100%;
    height: auto;
}

/* Override fixed widths */
[class*="col-"] {
    padding-left: var(--container-padding) !important;
    padding-right: var(--container-padding) !important;
}

/* Fix overflow issues */
html, 
body {
    overflow-x: hidden;
    width: 100%;
    max-width: 100%;
}