/* 主題變量定義 - 淺色主題(默認) */
:root {
    /* 基礎顏色 */
    --taos-system-bk-color: #f4f6f9;
    --taos-system-font-color: #212529;
    --taos-system-header-height: 5.5vh;
    
    /* 主要顏色 */
    --taos-primary: #007bff;
    --taos-secondary: #6c757d;
    --taos-success: #28a745;
    --taos-info: #17a2b8;
    --taos-warning: #ffc107;
    --taos-danger: #dc3545;
    --taos-light: #f8f9fa;
    --taos-dark: #343a40;
    
    /* 卡片和元素顏色 */
    --taos-card-bg: #ffffff;
    --taos-card-shadow: 0 0 1px rgba(0,0,0,.125), 0 1px 3px rgba(0,0,0,.2);
    --taos-card-border: 1px solid rgba(0, 0, 0, 0.125);
    --taos-input-bg: #ffffff;
    --taos-input-border: #ced4da;
    --taos-input-color: #495057;
    
    /* 導航和頁頭顏色 */
    --taos-navbar-bg: #ffffff;
    --taos-navbar-color: #343a40;
    --taos-sidebar-bg: #343a40;
    --taos-sidebar-color: #c2c7d0;
    --taos-sidebar-hover: #007bff;
    
    /* 太極元素顏色 */
    --taos-taiji-dark: #000000;
    --taos-taiji-light: #ffffff;
    --taos-taiji-opacity: 0.1;
}

/* 深色主題 */
:root .dark-mode {
    /* 基礎顏色 */
    --taos-system-bk-color: #222;
    --taos-system-font-color: #f4f6f9;
    
    /* 主要顏色 - 深色模式下的顏色調整 */
    --taos-primary: #3f6791;
    --taos-secondary: #555c63;
    --taos-success: #2c7a3e;
    --taos-info: #258391;
    --taos-warning: #b38705;
    --taos-danger: #a52a37;
    
    /* SweetAlert2 深色主題變量 */
    --swal2-dark-theme-bg: #333;
    --swal2-dark-theme-color: #f4f6f9;
    --swal2-dark-theme-border: #555;
    --taos-light: #454d55;
    --taos-dark: #adb5bd;
    
    /* 卡片和元素顏色 */
    --taos-card-bg: #343a40;
    --taos-card-shadow: 0 0 1px rgba(0,0,0,.5), 0 1px 3px rgba(0,0,0,.5);
    --taos-card-border: 1px solid rgba(255, 255, 255, 0.125);
    --taos-input-bg: #454d55;
    --taos-input-border: #6c757d;
    --taos-input-color: #e9ecef;
    
    /* 導航和頁頭顏色 */
    --taos-navbar-bg: #343a40;
    --taos-navbar-color: #f8f9fa;
    --taos-sidebar-bg: #222;
    --taos-sidebar-color: #adb5bd;
    --taos-sidebar-hover: #3f6791;
    
    /* 太極元素顏色 */
    --taos-taiji-dark: #f8f9fa;
    --taos-taiji-light: #343a40;
    --taos-taiji-opacity: 0.2;

    /* FullCalendar 深色主題變量 */
    --fc-page-bg-color:cornflowerblue;
    --fc-list-event-hover-bg-color:#3f6791;
}

html{
    overflow-y: hidden;
}

body{
    background-color: var(--taos-system-bk-color) !important;
    color:var(--taos-system-font-color) !important;
    height: 100vh !important;
}

/* 登入頁面背景圖片 */
body.login-page {
    background: url('/public/assets/Image/sys_bg.jpeg') no-repeat center center fixed;
    background-size: cover;
    background-color: var(--taos-system-bk-color) !important;
}

.login-page{
    height: 100vh !important;
}

/* 登入框的基本樣式 */
.login-box {
    width: 35%;
    min-width: 360px;
}

/* 登入卡片樣式 */
.login-box .card {
    background-color: var(--taos-card-bg);
    background-color: rgba(255, 255, 255, 0.9);
    box-shadow: var(--taos-card-shadow);
    border: var(--taos-card-border);
    position: relative;
    overflow: hidden;
}

.dark-mode .login-box .card {
    background-color: rgba(52, 58, 64, 0.9);
}

/* 太極元素 */
.login-box .card::before {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: linear-gradient(to right, var(--taos-taiji-dark) 0%, var(--taos-taiji-dark) 50%, var(--taos-taiji-light) 50%, var(--taos-taiji-light) 100%);
    opacity: var(--taos-taiji-opacity);
    z-index: 0;
}

.login-box .card::after {
    content: '';
    position: absolute;
    bottom: -100px;
    left: -100px;
    width: 200px;
    height: 200px;
    border-radius: 50%;
    background: linear-gradient(to right, var(--taos-taiji-light) 0%, var(--taos-taiji-light) 50%, var(--taos-taiji-dark) 50%, var(--taos-taiji-dark) 100%);
    opacity: var(--taos-taiji-opacity);
    z-index: 0;
}

.login-box .card-header {
    background-color: transparent;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    position: relative;
    z-index: 1;
}

.dark-mode .login-box .card-header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.card-body {
    /* min-height: 35vh; */
    position: relative;
    z-index: 1;
}

.card-body .body-content {
    width: 80%;
    margin: 0 auto;
    padding: 20px 0;
    position: relative;
}

/* 太極小圓元素 */
.card-body .body-content::before {
    content: '';
    position: absolute;
    top: 10px;
    right: 10px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: radial-gradient(circle at 50% 50%, var(--taos-taiji-dark) 0%, var(--taos-taiji-dark) 30%, var(--taos-taiji-light) 30%, var(--taos-taiji-light) 100%);
    opacity: var(--taos-taiji-opacity);
}

.card-body .body-content::after {
    content: '';
    position: absolute;
    bottom: 10px;
    left: 10px;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: radial-gradient(circle at 50% 50%, var(--taos-taiji-light) 0%, var(--taos-taiji-light) 30%, var(--taos-taiji-dark) 30%, var(--taos-taiji-dark) 100%);
    opacity: var(--taos-taiji-opacity);
}

/* 添加一個旋轉的太極圖標 */
.taiji-symbol {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(90deg, var(--taos-taiji-dark) 50%, var(--taos-taiji-light) 50%);
    position: relative;
    margin: 0 auto 10px;
    animation: rotate 10s linear infinite;
}

.taiji-symbol::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--taos-taiji-light);
    border: 10px solid var(--taos-taiji-dark);
}

.taiji-symbol::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--taos-taiji-dark);
    border: 10px solid var(--taos-taiji-light);
}

@keyframes rotate {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

.login-box-msg {
    text-align: center;
    margin-bottom: 20px;
    font-size: 1.1rem;
    color: var(--taos-input-color);
}

/* 登入表單元素樣式 */
.login-box input.form-control {
    background-color: var(--taos-input-bg);
    border-color: var(--taos-input-border);
    color: var(--taos-input-color);
}

.login-box .input-group-text {
    background-color: var(--taos-input-bg);
    border-color: var(--taos-input-border);
    color: var(--taos-input-color);
}

.login-box .btn-primary {
    background-color: var(--taos-primary);
    border-color: var(--taos-primary);
}

.login-box .btn-primary:hover {
    background-color: var(--taos-primary);
    filter: brightness(1.1);
}

/* SweetAlert2 深色主題樣式 */
.dark-mode .swal2-popup {
    background-color: var(--swal2-dark-theme-bg) !important;
    color: var(--swal2-dark-theme-color) !important;
    border: 1px solid var(--swal2-dark-theme-border) !important;
}

.dark-mode .swal2-title {
    color: var(--swal2-dark-theme-color) !important;
}

.dark-mode .swal2-content {
    color: var(--swal2-dark-theme-color) !important;
}

.dark-mode .swal2-container {
    color: var(--swal2-dark-theme-color) !important;
}

.dark-mode .swal2-html-container {
    color: var(--swal2-dark-theme-color) !important;
}

.dark-mode .swal2-input,
.dark-mode .swal2-textarea,
.dark-mode .swal2-select {
    background-color: #444 !important;
    color: var(--swal2-dark-theme-color) !important;
    border-color: var(--swal2-dark-theme-border) !important;
}

.dark-mode .swal2-input:focus,
.dark-mode .swal2-textarea:focus,
.dark-mode .swal2-select:focus {
    border-color: var(--taos-primary) !important;
    box-shadow: 0 0 0 3px rgba(63, 103, 145, 0.3) !important;
}

.dark-mode .swal2-validation-message {
    background-color: #444 !important;
    color: var(--swal2-dark-theme-color) !important;
}

.dark-mode .swal2-footer {
    border-top-color: var(--swal2-dark-theme-border) !important;
    color: var(--swal2-dark-theme-color) !important;
}

.dark-mode .swal2-timer-progress-bar {
    background-color: var(--taos-primary) !important;
}

/* 按鈕樣式 */
.dark-mode .swal2-confirm {
    background-color: var(--taos-primary) !important;
}

.dark-mode .swal2-cancel {
    background-color: var(--taos-secondary) !important;
}

.dark-mode .swal2-styled:focus {
    box-shadow: 0 0 0 3px rgba(63, 103, 145, 0.3) !important;
}

/* 小螢幕裝置上的登入框樣式 */
@media (max-width: 576px) {
    .login-box {
        width: 100%;
        height: 100%;
        margin: 0;
        padding: 0;
    }
    
    .login-box .card {
        height: 100vh;
        border-radius: 0;
        margin-bottom: 0;
        background-color: rgba(255, 255, 255, 0.95);
        box-shadow: none;
        display: flex;
        flex-direction: column;
    }
    
    .dark-mode .login-box .card {
        background-color: rgba(52, 58, 64, 0.95);
    }
    
    .login-box .card-body {
        flex: 1;
        /* 移除了 display: flex 和 flex-direction: column 以保持正常對齊 */
        /* 移除了 justify-content: center */
    }
    
    /* 確保登入按鈕在小螢幕上更大更易點擊 */
    .login-box .btn-block {
        padding: 10px;
        font-size: 16px;
    }
}

.content-wrapper{
    height: calc(100vh - var(--taos-system-header-height));
}

.taos_three{
    position: relative;
}

.taos_three canvas{
    position: absolute;
    top: 0;
    overflow-y: auto;
}

.Three_Context_header{
    margin:0;
}

/* FullCalendar */
.fc-col-header, .fc-timegrid-body {
    width: 100% !important;
    height: 100% !important;
}
.fc-scrollgrid-sync-table {
    width: 100% !important;
    height: 100% !important;
}
.fc-daygrid-body {
    width: 100% !important;
    height: 100% !important;
}
.fc-daygrid-body-balanced {
    width: 100% !important;
    height: 100% !important;
}

.spinner_frame{
    position: fixed;
    top: 0;
    left: 0;
}