﻿/* กัน flash หลัง login */
html.postlogin body {
    overflow: hidden;
}

#BootSplashFull {
    display: none;
}

.main-shell {
    display: block;
}

html.postlogin .main-shell {
    display: none !important;
}

html.postlogin #BootSplashFull {
    display: flex !important;
    position: fixed;
    inset: 0;
    z-index: 2147483647;
    align-items: center;
    justify-content: center;
    background: #0B1220;
}

.boot-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid rgba(255,255,255,.25);
    border-top-color: rgba(255,255,255,.9);
    border-radius: 50%;
    animation: boot-spin 1s linear infinite;
}

@keyframes boot-spin {
    to {
        transform: rotate(360deg);
    }
}

/*แถบ Error ของ Blazor ด้านล่าง*/
#blazor-error-ui {
    color-scheme: light only;
    background: lightyellow;
    bottom: 0;
    box-shadow: 0 -1px 2px rgba(0, 0, 0, 0.2);
    box-sizing: border-box;
    display: none;
    left: 0;
    padding: 0.6rem 1.25rem 0.7rem 1.25rem;
    position: fixed;
    width: 100%;
    z-index: 1000;
}

    #blazor-error-ui .dismiss {
        cursor: pointer;
        position: absolute;
        right: 0.75rem;
        top: 0.5rem;
    }

:root {
    /* สี fallback ชั่วคราว ระหว่างธีมยังโหลดไม่เสร็จ */
    --rz-primary: #196A90;
}

body {
    font-family: "Anuphan", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 12px;
    color: var(--rz-primary);
    margin: 0;
    padding: 0;
    background: linear-gradient(360deg, #1e3a8a 0%, #0891b2 50%, #06b6d4 100%); /* กำหนดสี Background แบบ Gradient */
    min-height: 100vh;
    overflow-y: auto; /* ให้ scroll แนวตั้งได้ */
    overflow-x: hidden; /* กัน scroll แนวนอน */
}

.primary-color {
    color: var(--rz-primary) !important;
}

.content {
    padding-top: 1.1rem;
}

.content-card {
    padding: var(--content-card-padding) !important; /* กำหนดระยะ padding ของ card */
    margin: var(--content-card-margin); /* กำหนดระยะ margin ของ card */
    background-color: var(--content-card-background-color) !important; /* กำหนดสี backgrouund ของ card */
    border: var(--content-card-border); /* ปรับสี border */
    border-radius: var(--content-card-border-radius) !important; /* ปรับความโค้งมนของขอบ card */
    box-shadow: var(--content-card-box-shadow) !important; /* กำหนดเงาให้ card */
    min-height: calc(100vh - var(--app-header-height) - var(--content-card-padding) * 2);
}

.content-card-mini {
    padding: var(--content-card-padding) !important; /* กำหนดระยะ padding ของ card */
    margin: var(--content-card-margin); /* กำหนดระยะ margin ของ card */
    background-color: var(--content-card-background-color) !important; /* กำหนดสี backgrouund ของ card */
    border: var(--content-card-border); /* ปรับสี border */
    border-radius: var(--content-card-border-radius) !important; /* ปรับความโค้งมนของขอบ card */
    box-shadow: var(--content-card-box-shadow) !important; /* กำหนดเงาให้ card */

}

.content-space {
    margin: 0.5rem 0rem 0.5rem 0rem;
}

.content-button-bar {
    min-width: 7.1875rem !important;
}

.layout-header {
    height: var(--app-header-height);
    border-width: 0px;
    border-block: none;
    box-shadow: none !important;
}

.layout-logo-image-container {
    height: 70px;
    width: 300px;
    display: flex;
    align-items: center;
}

.layout-user-container {
    height: 70px;
    width: 100vw;
    display: flex;
    justify-content: right;
    align-items: center;
    padding: 0 1rem;
    gap: 1rem;
}

.layout-footer {
    font-size: 12px;
    height: 25px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    padding: 1rem;
}

.layout-footer-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
}

.layout-footer-right {
    margin-left: auto;
}

.hamburger-button {
    margin: 10px 0px;
    padding: 20px;
    border: none;
    color: var(--hamburger-button-color) !important;
    background-color: transparent !important;
    filter: drop-shadow(0 0 5px rgba(0,0,0,0.7));
}

.loading-spinner {
    width: 2rem;
    height: 2rem;
    border: 0.25rem solid transparent;
    border-top-color: var(--rz-primary);
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

.image-loading-spinner {
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.circle-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    text-align: center;
    border-radius: 50%;
    border: var(--circle-icon-border);
    box-shadow: var(--circle-icon-box-shadow);
    color: var(--circle-icon-color);
    background-color: var(--circle-icon-background-color);
}

    .circle-icon i {
        font-size: 20px;
        width: auto;
        height: auto;
    }

.change-password-icon {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100px;
    height: 100px;
    text-align: center;
    border-radius: 50%;
    border: var(--change-password-icon-border);
    box-shadow: var(--change-password-icon-box-shadow);
    color: var(--change-password-icon-color);
    background-color: var(--change-password-icon-background-color);
}

    .change-password-icon i {
        font-size: 50px;
        width: auto;
        height: auto;
    }

.icon-info {
    color: var(--icon-info);
}

.icon-warning {
    color: var(--icon-warning);
}

.icon-error {
    color: var(--icon-error);
}

/* Notification Button */
.notification-button {
    position: relative;
    border: none;
    background: transparent;
    cursor: pointer;
    overflow: visible; /* กันไม่ให้ตัด badge เวลาเลยออกนอกปุ่ม */
}

    .notification-button .badge {
        position: absolute;
        top: -4px;
        right: -4px;
        min-width: 18px;
        height: 18px;
        padding: 0 6px;
        border-radius: 999px;
        font-size: 11px;
        font-weight: 600;
        line-height: 18px;
        text-align: center;
        background: #e74c3c; /* สี background ของ badge */
        color: #fff; /* สีตัวอักษรของ badge */
        box-shadow: 0 0 0 2px var(--rz-body-background, #ffffff);
        z-index: 10;
        display: flex;
        align-items: center;
        justify-content: center;
    }

/* Notification Panel Styles */
.notification-panel {
    position: fixed;
    top: 0;
    right: 0;
    width: 400px;
    max-width: 100vw;
    height: 100%;
    padding: 0px;
    z-index: 99999 !important;
}

.notification-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--rz-border, #d6d6d6);
    background: linear-gradient(90deg, var(--rz-primary), color-mix(in srgb, var(--rz-primary) 75%, white));
    color: var(--rz-on-primary, #fff);
}

.notification-header-left {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.notification-header-right {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.notification-title {
    font-weight: 600;
    font-size: 0.95rem;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.notification-count {
    font-size: 0.75rem;
    opacity: 0.9;
}

.notification-close-button {
    border: none;
    background-color: transparent !important;
    color: var(--rz-on-primary) !important;
    min-width: 24px;
    width: 24px;
    min-height: 24px;
    height: 24px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.notification-clear-all-button {
    color: var(--rz-on-primary) !important;
    font-size: 0.8rem;
    text-decoration: underline;
}

.notification-body {
    padding: 0.5rem 0.5rem 0.75rem 1rem;
    height: calc(100% - 58px);
    overflow-y: auto;
    background: var(--rz-on-primary, white);
}

/* Empty Notification */
.notification-empty {
    margin-top: 2rem;
    text-align: center;
    color: var(--noti-empty-color, #6b7280);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
}

.notification-empty-title {
    font-weight: 600;
    font-size: 0.95rem;
}

.notification-empty-text {
    font-size: 0.8rem;
    max-width: 260px;
}

/* Notification Item */
.notification-item {
    display: flex;
    align-items: stretch;
    gap: 0rem;
    margin-bottom: 0;
    padding: 0.55rem 0.55rem 0.55rem 0;
}

.notification-item-main {
    flex: 1;
    background: black;
    border-radius: 0.5rem;
    padding: 0.6rem 0.8rem;
    box-shadow: 0 1px 4px rgba(15, 23, 42, 0.12);
    border-left: 3px solid transparent;
    cursor: pointer;
    transition: background 0.15s ease, box-shadow 0.15s ease, transform 0.05s ease;
}

    .notification-item-main:hover {
        box-shadow: 0 3px 10px rgba(15, 23, 42, 0.18);
        transform: translateY(-1px);
    }

.notification-item-remove-button {
    border: none;
    color : black !important;
    background-color: transparent !important;
    color: var(--rz-on-primary) !important;
    min-width: 20px;
    width: 20px;
    min-height: 20px;
    height: 20px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

/* สี icon ของปุ่มลบ notification */
.notification-item-remove-icon{
    color: var(--noti-remove-item-icon, #000000) !important;
}

/* สีพื้นตาม Severity (ใช้ทั้ง read/unread) */
.notification-item-info {
    border-left-color: var(--noti-info-color, #2196f3);
    color: var(--noti-info-color, #2196f3);
    background: #d3eafd;
}

.notification-item-success {
    border-left-color: var(--noti-success-color, #4caf50);
    color: var(--noti-success-color, #4caf50);
    background: #e2f2e3;
}

.notification-item-warning {
    border-left-color: var(--noti-warning-color, #ff9800);
    color: var(--noti-warning-color, #ff9800);
    background: #ffeacc;
}

.notification-item-error {
    border-left-color: var(--noti-error-color, #f44336);
    color: var(--noti-error-color, #f44336);
    background: #fdd9d7;
}

    /* read/unread ใช้สีเดียวกัน แต่ read จางลงเล็กน้อย */
    .noti-item.read .noti-item-main {
        opacity: 0.75;
    }

.notification-item-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin-bottom: 0.2rem;
}

.notification-item-header-left {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

.notification-item-icon {
    width: 24px;
    height: 24px;
    background: transparent;
    background-color: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.9rem;
}

.notification-item-title {
    font-weight: 600;
    font-size: 0.9rem;
    color: #111827;
}

.notification-item-time {
    font-size: 0.75rem;
    color: #6b7280;
    white-space: nowrap;
}

.notification-item-message {
    font-size: 0.8rem;
    color: #374151;
    margin-bottom: 0.35rem;
}

.notification-item-footer {
    display: flex;
    align-items: center;
    gap: 0.3rem;
    font-size: 0.7rem;
}

.notification-badge-new {
    background: #ff0066;
    color: #ffffff;
    padding: 0.1rem 0.45rem;
    border-radius: 999px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.9);
}

.notification-badge-link {
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
    padding: 0.1rem 0.4rem;
    border-radius: 999px;
    background: #e5f3ff;
    color: #1d4ed8;
}

@media (max-width: 600px) {
    .noti-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.4rem;
    }

    .notification-item {
        padding-right: 0;
    }
}

.rz-dialog {
    background-color: var(--dialog-background-color) !important; /* กำหนดสี background ของ dialog */
    border: var(--dialog-border); /* กำหนดสี border ของ dialog */
    border-radius: var(--dialog-border-radius) !important; /* ปรับความโค้งมนของขอบ dialog */
    box-shadow: var(--dialog-box-shadow) !important; /* กำหนดเงาให้ dialog */
    overflow: hidden; /* ป้องกันการ overflow ของ dialog */
}

.rz-dialog-content {
    height: 100%;
}

.rz-dialog-titlebar {
    background-color: var(--rz-dialog-background-color);
    padding: 20px;
}

    .rz-dialog-titlebar > .rz-dialog-title {
        text-align: center;
        color: var(--rz-dialog-header-color);
        font-weight: bold;
    }

.rz-dialog-titlebar-close > .rzi-times {
    color: var(--rz-dialog-close-button-color);
}

/* กัน scroll แนวนอนใน sidebar */
.rz-sidebar,
.rz-sidebar .rz-sidebar-content,
.rz-sidebar .rz-panel-menu {
    overflow-x: hidden !important;
}

.login-page-background {
    position: relative;
    background-image: var(--login-bg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    min-height: 100vh;
    display: flex; /* ทำให้เป็น flex container */
    justify-content: center; /* จัดกลางแนวนอน */
    align-items: center; /* จัดกลางแนวตั้ง */
}

    .login-page-background::before {
        content: "";
        position: absolute;
        inset: 0;
        /*background: rgba(25,106,144, .7); /* ฟิล์มสีโปร่งใส */
        z-index: 0;
    }

    .login-page-background > * {
        position: relative;
        z-index: 1;
    }

.login-text-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: 1rem;
}

.login-card {
    padding: var(--content-card-padding) !important; /* กำหนดระยะ padding ของ card */
    margin: var(--content-card-margin); /* กำหนดระยะ margin ของ card */
    background-color: var(--content-card-background-color) !important; /* กำหนดสี backgrouund ของ card */
    border-radius: var(--content-card-border-radius) !important; /* ปรับความโค้งมนของขอบ card */
    box-shadow: var(--content-card-box-shadow) !important; /* กำหนดเงาให้ card */
    width: 500px;
}

.login-link {
    font-size: 16px !important;
    font-weight: bold;
    color: var(--rz-link-color);
    text-decoration: underline;
}

    .login-link:hover {
        color: var(--rz-link-hover-color);
        text-decoration: underline;
    }

.profile-popup {
    display: none;
    position: absolute;
    overflow: hidden;
    width: 480px;
    height: auto;
    border: var(--rz-panel-border);
    background-color: var(--rz-panel-background-color);
    box-shadow: var(--rz-panel-shadow);
    /* border-radius: var(--rz-border-radius); */
    border-radius: 15px;
    z-index: 1000;
}

    .profile-popup .rz-popup,
    .profile-popup {
        margin-top: 13px; /* กำหนดให้ห่างจาก Profile Button */
    }

.device-container .device-secret {
    width: 130px;
    font-size: 20px;
    font-weight: bold;
    letter-spacing: 2px;
}

.device-container .device-button {
    transform: translateX(-125%);
    border: none;
    background: none;
}

.field-fullwidth {
    display: flex;
    width: 100%;
}

.validate-message {
    color: var(--validate-color1);
    font-size: 12px;
    padding-top: 5px;
    padding-left: 5px;
    min-height: 25px;
    display: block;
}

/*.readonly-textbox {
    color: var(--readonly-textbox-color);
    background-color: var(--readonly-textbox-background-color);
    border: var(--readonly-textbox-border);
    cursor: not-allowed;
}*/

.readonly-textbox {
    color: red !important;
    background-color: transparent !important;
    border: none !important;
    cursor: not-allowed;
}

.column-inactive {
    color: var(--column-inactive-color);
}

.hide-file-list .rz-fileupload-files {
    display: none !important;
}

.primary-color {
    color: rgb(25, 106, 144) !important;
}

.disable-color {
    background-color: rgb(243, 243, 243) !important;
}

#display-none {
    display: none !important;
}
