/* MACH/Adria theme — applied across all pages except where login.css overrides */

:root {
    --mch-bg-dark: #222f3f;
    --mch-bg-mid: #2C3E50;
    --mch-bg-light: #506375;
    --mch-bg-light-2: #778B9D;
    --mch-gold: #C6A277;
    --mch-gold-hover: rgb(193, 163, 125);
    --mch-gold-active: rgb(169, 143, 109);
    --mch-gold-light: #D6BC9B;
    --mch-danger: #D20003;
    --mch-text: #ffffff;
    --mch-radius: 4px;
}

html, body {
    background: #222f3f !important;
    background-image: none !important;
    color: var(--mch-text);
    font-family: 'Open Sans', 'Helvetica Neue', Arial, sans-serif;
    min-height: 100vh;
}

a, a:hover {
    color: var(--mch-gold);
}

/* ===== TOP NAV ===== */
.navbar.bg-dark {
    background-color: #222f3f !important;
    border-bottom: 1px solid var(--mch-bg-light);
}
.navbar-brand,
.navbar-brand:hover {
    color: #ffffff !important;
    font-family: 'Open Sans', sans-serif;
    font-weight: 700;
    letter-spacing: 0.5px;
}

/* ===== SIDEBAR (charcoal panel, copper accents, icons + section labels) ===== */
.sidebar {
    background: transparent;
    padding: 0;
    border-right: none;
    box-shadow: none;
}

.sidebar .nav-section-label {
    display: block;
    color: var(--mch-gold);
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 1.6px;
    text-transform: uppercase;
    padding: 18px 20px 8px 20px;
    opacity: 0.75;
}

.sidebar .nav-link {
    position: relative;
    display: flex;
    align-items: center;
    gap: 12px;
    color: #D8DEE9;
    background: transparent;
    border: none;
    border-radius: 0;
    text-align: left;
    font-weight: 700;
    font-size: 16px;
    padding: 7px 20px 7px 24px;
    margin: 0;
    overflow: hidden;
    transition: color 0.18s ease-in-out, padding-left 0.18s ease-in-out, background-color 0.18s ease-in-out;
}
.sidebar .nav-link::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    background-color: transparent;
    transition: background-color 0.18s ease-in-out, width 0.18s ease-in-out;
}
.sidebar .nav-link i {
    width: 18px;
    color: #8C97A8;
    font-size: 14px;
    transition: color 0.18s ease-in-out;
}
.sidebar .nav-link:hover {
    color: #FFF1DC;
    background-color: rgba(198, 162, 119, 0.07);
    padding-left: 28px;
    text-decoration: none;
}
.sidebar .nav-link:hover::before {
    background-color: var(--mch-gold);
    width: 4px;
}
.sidebar .nav-link:hover i {
    color: var(--mch-gold);
}
.sidebar .nav-link.is-active {
    color: #FFF1DC;
    background-color: rgba(198, 162, 119, 0.14);
    padding-left: 28px;
}
.sidebar .nav-link.is-active::before {
    background-color: var(--mch-gold);
    width: 4px;
}
.sidebar .nav-link.is-active i {
    color: var(--mch-gold);
}

.sidebar .sidebar-divider {
    border: 0;
    border-top: 1px solid rgba(198, 162, 119, 0.12);
    margin: 6px 16px;
}

/* Logout pinned at bottom-left */
.sidebar-logout {
    margin: 0 !important;
    margin-top: auto !important;
    padding: 14px 20px 14px 24px !important;
    color: var(--mch-text) !important;
    background-color: transparent !important;
    border-top: 1px solid rgba(255, 255, 255, 0.06) !important;
    border-radius: 0 !important;
    text-align: left !important;
    font-weight: 600 !important;
    display: flex !important;
    align-items: center;
    gap: 12px;
    transition: background-color 0.18s ease-in-out, color 0.18s ease-in-out, padding-left 0.18s ease-in-out;
}
.sidebar-logout::before {
    content: none !important;
}
.sidebar-logout i {
    color: var(--mch-danger);
    transition: color 0.18s ease-in-out;
}
.sidebar-logout:hover {
    background-color: var(--mch-danger) !important;
    color: white !important;
    text-decoration: none !important;
    padding-left: 28px !important;
}
.sidebar-logout:hover i {
    color: white !important;
}

/* ===== PAGE / CARDS ===== */
#page-wrapper {
    background: transparent;
    color: var(--mch-text);
    padding-top: 16px;
}

.card {
    background: #37495B !important;
    background-image: none !important;
    border: none !important;
    color: var(--mch-text);
    border-radius: 12px;
}
.card-header {
    background: transparent !important;
    background-image: none !important;
    color: var(--mch-text);
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.card-body {
    background: transparent !important;
    background-image: none !important;
    color: var(--mch-text);
}

/* ===== TABLES ===== */
.table {
    color: var(--mch-text);
}
.table thead th {
    border-bottom: 2px solid var(--mch-gold);
    color: var(--mch-gold);
}
.table td, .table th {
    border-top-color: rgba(255, 255, 255, 0.08);
    vertical-align: middle;
}
.table tbody tr:hover {
    background-color: rgba(198, 162, 119, 0.08);
}

/* ===== INPUTS ===== */
.form-control,
input[type="text"].form-control,
input[type="password"].form-control,
input[type="email"].form-control,
textarea.form-control,
select.form-control {
    background-color: var(--mch-bg-light);
    color: var(--mch-text);
    border: 1px solid var(--mch-bg-light-2);
    border-radius: var(--mch-radius);
}
.form-control:focus {
    background-color: var(--mch-bg-light);
    color: var(--mch-text);
    border-color: var(--mch-gold);
    box-shadow: 0 0 0 0.15rem rgba(198, 162, 119, 0.25);
}
.form-control::placeholder {
    color: rgba(255, 255, 255, 0.5);
}

/* ===== BUTTONS — unified shape ===== */
.btn,
.btn-primary,
.btn-light,
.btn-danger,
.btn-secondary,
.btn-info,
.btn-success,
.btn-outline-primary {
    border: none;
    font-weight: 600;
    border-radius: var(--mch-radius);
    padding: 6px 14px;
    line-height: 1.4;
}
.btn-sm {
    padding: 4px 10px;
    font-size: 0.85rem;
    border-radius: var(--mch-radius);
}

.btn-primary {
    background-image: linear-gradient(to right, var(--mch-gold), var(--mch-gold-light));
    color: white;
}
.btn-primary:hover {
    background-image: none;
    background-color: var(--mch-gold-hover);
    color: white;
}
.btn-primary:active,
.btn-primary:focus {
    background-image: none;
    background-color: var(--mch-gold-active) !important;
    box-shadow: none !important;
    color: white;
}

.btn-light {
    background-color: var(--mch-bg-light);
    color: var(--mch-text);
}
.btn-light:hover {
    background-color: var(--mch-bg-light-2);
    color: var(--mch-text);
}

.btn-info {
    background-color: var(--mch-bg-light-2);
    color: white;
}
.btn-info:hover {
    background-color: var(--mch-bg-light);
    color: white;
}

.btn-secondary {
    background-color: var(--mch-bg-light);
    color: var(--mch-text);
}
.btn-secondary:hover {
    background-color: var(--mch-bg-light-2);
    color: var(--mch-text);
}

.btn-danger {
    background-color: var(--mch-danger);
    color: white;
}
.btn-danger:hover {
    background-color: #a30002;
    color: white;
}

.btn-outline-primary {
    background-color: transparent;
    color: var(--mch-gold);
    border: 1px solid var(--mch-gold) !important;
}
.btn-outline-primary:hover {
    background-color: var(--mch-gold);
    color: white;
}

/* Sort caret on table headers */
.table thead th .fa-caret-up,
.table thead th .fa-caret-down {
    color: var(--mch-gold);
}

/* ===== MODAL (dark themed so text is readable) ===== */
.modal-content {
    background-color: var(--mch-bg-mid);
    color: var(--mch-text);
    border: 1px solid var(--mch-bg-light);
    border-radius: var(--mch-radius);
}
.modal-header {
    border-bottom: 1px solid var(--mch-bg-light);
}
.modal-footer {
    border-top: 1px solid var(--mch-bg-light);
}
.modal-title {
    color: var(--mch-text);
}
.modal .text-muted {
    color: rgba(255, 255, 255, 0.6) !important;
}
.modal .badge-info {
    background-color: var(--mch-gold);
    color: var(--mch-bg-mid);
}
.modal .close,
.modal .close span {
    color: var(--mch-text);
    text-shadow: none;
    opacity: 0.85;
}
.modal .close:hover {
    opacity: 1;
}

/* Modal footer buttons — same shape, same height */
.modal-footer .btn {
    height: 36px;
    min-width: 110px;
    border-radius: var(--mch-radius);
}

/* Recolor native range slider blue -> gold (keeps native look) */
input[type="range"] {
    accent-color: var(--mch-gold);
}

/* ===== TOAST ===== */
#mch-toast-container {
    position: fixed;
    top: 76px;
    right: 20px;
    z-index: 11000;
    display: flex;
    flex-direction: column;
    gap: 10px;
    pointer-events: none;
}
.mch-toast {
    pointer-events: auto;
    min-width: 280px;
    max-width: 420px;
    padding: 12px 18px;
    border-radius: 6px;
    background-color: #37495B;
    color: white;
    border-left: 4px solid var(--mch-gold);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.35);
    font-weight: 500;
    opacity: 0;
    transform: translateX(20px);
    transition: opacity 0.22s ease-out, transform 0.22s ease-out;
}
.mch-toast.show {
    opacity: 1;
    transform: translateX(0);
}
.mch-toast-success {
    border-left-color: #28a745;
}
.mch-toast-error {
    border-left-color: var(--mch-danger);
    background-color: #4a2326;
}
.mch-toast-info {
    border-left-color: var(--mch-gold);
}

/* ===== CONFIRM DIALOG ===== */
.mch-confirm-overlay {
    position: fixed;
    inset: 0;
    z-index: 12000;
    background-color: rgba(0, 0, 0, 0.55);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.18s ease-out;
}
.mch-confirm-overlay.show {
    opacity: 1;
}
.mch-confirm-modal {
    background-color: #37495B;
    color: white;
    border-radius: 8px;
    width: 440px;
    max-width: calc(100% - 32px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.45);
    transform: translateY(-8px);
    transition: transform 0.18s ease-out;
}
.mch-confirm-overlay.show .mch-confirm-modal {
    transform: translateY(0);
}
.mch-confirm-header {
    padding: 16px 20px;
    font-weight: 700;
    font-size: 17px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.mch-confirm-body {
    padding: 18px 20px;
    line-height: 1.5;
}
.mch-confirm-footer {
    padding: 12px 20px 16px 20px;
    display: flex;
    justify-content: flex-end;
    gap: 8px;
}
.mch-confirm-footer .btn {
    min-width: 100px;
}
