/* *****************************************************

    ** Custom Stylesheet **

    Any custom styling you want to apply should be
    defined here.

***************************************************** */

/* ========================================
   STICKY FOOTER FIX - FINAL SOLUTION
   ======================================== */

html {
    height: 100% !important;
    min-height: 100% !important;
}

body {
    min-height: 100% !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* All elements between body and main must pass flex */
nav.left--nav,
.left--nav {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 0 auto !important;
    min-height: 100% !important;
}

/* Top bar and navbar don't grow */
.top-bar,
.navbar,
nav.navbar {
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
}

/* Main content grows to fill space */
.x-main,
main,
main[role="main"] {
    flex: 1 0 auto !important;
}

/* Footer wrapper stays at bottom */
.footer-wrapper {
    flex-shrink: 0 !important;
    margin-top: auto !important;
    width: 100% !important;
}

/* ========================================
   Footer Text Size Fixes
   ======================================== */

.xfooter-footer-text {
    font-size: 14px !important;
    line-height: 1.6 !important;
}

.xfooter-footer-heading {
    font-size: 16px !important;
    font-weight: 700 !important;
}

.xfooter-footer-link {
    font-size: 14px !important;
}

.xfooter-footer-bottom {
    font-size: 13px !important;
}

.xfooter-footer-bottom .xfooter-footer-link,
.xfooter-footer-bottom .xfooter-footer-text {
    font-size: 13px !important;
}

/* Newsletter section (xromlbg-custom) text sizes */
.xromlbg-custom .xromltext-custom {
    font-size: 18px !important;
}

.xromlbg-custom p,
.xromlbg-custom .text-muted {
    font-size: 14px !important;
}

.xromlbg-custom .btn {
    font-size: 14px !important;
}

.xromlbg-custom input.form-control {
    font-size: 14px !important;
}

/* ========================================
   DataTables Layout Fixes
   ======================================== */

table.dataTable {
    width: 100% !important;
    border-collapse: collapse !important;
}

.dataTables_wrapper {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto;
}

.listtable {
    width: 100% !important;
}

.table-container {
    width: 100% !important;
    overflow-x: auto;
}

.panel-wrap {
    overflow: hidden;
    width: 100% !important;
}

/* Panel layout - NO gaps, tight layout */
.panel-general-wrapper {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
    width: 100% !important;
}

.panel-general-wrapper .panel-sidebar {
    display: block !important;
    visibility: visible !important;
    width: 280px !important;
    flex-shrink: 0 !important;
    padding: 30px 20px !important;
    margin: 0 !important;
    background: #fff !important;
}

.panel-general-wrapper .panel-content {
    flex: 1 !important;
    min-width: 0;
    overflow: visible !important;
    margin: 0 !important;
    padding: 0 !important;
}

table.dataTable td.ssl-info,
.panel-general-wrapper td.ssl-info,
td.ssl-info {
    background: transparent !important;
    background-image: none !important;
    min-height: auto !important;
    padding: 8px !important;
}

table.dataTable thead th:first-child,
table.dataTable tbody td:first-child {
    width: 50px !important;
    min-width: 50px !important;
    max-width: 50px !important;
    text-align: center !important;
    background: transparent !important;
}

table.dataTable thead th.responsive-edit-button,
table.dataTable tbody td.responsive-edit-button {
    display: none !important;
}

table.dataTable thead th {
    padding: 12px 15px !important;
    border-bottom: 2px solid #ddd !important;
    text-align: left !important;
    font-weight: 600;
    white-space: nowrap;
    background: #f8f8f8;
}

table.dataTable tbody td {
    padding: 12px 15px !important;
    vertical-align: middle !important;
    border-bottom: 1px solid #eee;
}

table.dataTable tbody tr:hover {
    background-color: #f5f5f5;
    cursor: pointer;
}

table.dataTable .label.status {
    display: inline-block;
    padding: 6px 12px;
    font-size: 12px;
    border-radius: 20px;
    white-space: nowrap;
}

.status-active {
    background-color: #28a745 !important;
    color: #fff !important;
    border-color: #28a745 !important;
}

table.dataTable tbody td img {
    max-width: 24px;
    max-height: 24px;
}

.dataTables_info {
    padding: 10px 0;
    font-size: 13px;
    color: #666;
}

.dataTables_paginate {
    padding: 10px 0;
}

@media screen and (max-width: 992px) {
    .panel-general-wrapper .panel-sidebar {
        width: 220px !important;
    }
}

@media screen and (max-width: 768px) {

    table.dataTable thead th,
    table.dataTable tbody td {
        padding: 8px 10px !important;
        font-size: 13px;
    }

    table.dataTable thead th:first-child,
    table.dataTable tbody td:first-child {
        width: 40px !important;
        min-width: 40px !important;
        max-width: 40px !important;
    }
}

/* ========================================
   Image Size Constraints Fix
   ======================================== */

img {
    max-width: 100% !important;
    height: auto !important;
}

.panel-content img,
.main-content img,
.x-main img,
main img {
    max-width: 100% !important;
    height: auto !important;
}

/* Specific fix for product/service logos */
.product-icon img,
.service-icon img,
.hosting-icon img,
.cpanel-logo img {
    max-width: 120px !important;
    height: auto !important;
}

/* Mega menu styles are in /assets/style/style.css - do not override here */