html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.card {
    transition: all 0.2s ease-in-out;
}

.card:active {
    background-color: #f8f9fa; /* 手機點擊時的反饋色 */
}

.content {
    padding-top: 1.1rem;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

.cert-div {
    width: 100px;
    word-wrap: break-word; /* 或 overflow-wrap: break-word; */
}

.spinner {
    border: 4px solid rgba(0, 0, 0, 0.1);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border-left-color: #09f;
    animation: spin 1s ease infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* 確保 page 是彈性佈局 */
.page {
    display: flex;
    flex-direction: row;
}

/* 使用 !important 強制覆蓋 Blazor 預設樣式 */

/* 1. 側邊欄基礎：移除預設 padding 以免擠壓圖示 */
.sidebar {
    width: 250px !important;
    transition: width 0.3s ease !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    display: flex;
    flex-direction: column;
}

    /* 2. 當縮小時，強制寬度並確保內容居中 */
    .sidebar.sidebar-mini {
        width: 70px !important; /* 你可以根據 icon 大小調整，通常 60-80px */
    }

/* 3. 讓 NavMenu 內部的 Link 居中 */
.sidebar-mini .nav-link {
    justify-content: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

    /* 4. 隱藏文字並讓 Icon 保持適當大小 */
    .sidebar-mini .nav-link span:last-child {
        display: none !important;
    }

    .sidebar-mini .nav-link span:first-child {
        margin-right: 0 !important; /* 移除圖示右邊的間距 */
        font-size: 1.5rem; /* 稍微放大圖示，視覺更平衡 */
    }

/* 3. 修正右側主內容區域的位移 (這是最關鍵的一步) */
/* Blazor 預設會在桌面版給 main 一個 250px 的左邊距，我們必須把它改成自動 */
@media (min-width: 641px) {
    .page {
        display: flex !important;
    }

    main {
        flex: 1 !important;
        margin-left: 0 !important; /* 移除固定左邊距 */
    }
}

/* Sidebar Header 容器 */
.sidebar-header {
    height: 3.5rem; /* 與 top-row 等高，保持視覺對齊 */
    display: flex;
    align-items: center;
    background-color: rgba(0,0,0,0.1); /* 稍微區隔頂部 */
    margin-bottom: 0.5rem;
}


/* 調整 Label 容器 */
.toggle-label {
    display: flex;
    align-items: center;
    padding: 0.5rem 1rem;
    cursor: pointer;
    color: white;
}

/* 當側邊欄縮小時 */
.sidebar-mini .toggle-label {
    justify-content: center !important;
    padding: 0.5rem 0 !important;
}

    /* 縮小時，將 SVG 的 margin-right 移除以保持置中 */
    .sidebar-mini .toggle-label svg {
        margin-right: 0 !important;
    }

/* 縮小時，隱藏文字 */
.sidebar-mini .nav-text {
    display: none !important;
}


    .toggle-label:hover {
        background-color: rgba(255,255,255,0.1);
    }

    /* 圖示樣式 (bi-list 是漢堡選單圖示) */
    .toggle-label .bi {
        font-size: 1.5rem;
        width: 2rem;
        display: flex;
        justify-content: center;
    }



/* 修正：確保 bi-list 圖示在縮小時也是置中的 */
.sidebar-mini .sidebar-header {
    justify-content: center;
}

dialog {
    min-width: 350px; /* 設定最小寬度 */
    max-width: 500px; /* 順便設定最大寬度，避免在寬螢幕上太長 */
    border: none; /* 移除預設的邊框 */
    border-radius: 12px; /* 圓角化更現代 */
    padding: 1.5rem; /* 增加內距，讓內容不擁擠 */
    box-shadow: 0 10px 30px rgba(0,0,0,0.3); /* 增加陰影感 */
}

    /* 設定對話框背景（遮罩層）的樣式 */
    dialog::backdrop {
        background-color: rgba(0, 0, 0, 0.4);
    }



/* 建立一個覆蓋全螢幕的容器 */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.5); /* 遮罩調暗一點，更有懸浮感 */

    display: flex;
    flex-direction: column;
    justify-content: center; /* 垂直置中 */
    align-items: center; /* 水平置中 */

    z-index: 9999;
}

/* 這裡名稱改為 .progress-container 與你的 HTML 對應 */
.progress-container {
    width: 350px;
    padding: 30px;
    background: white; /* 進度條後面的小盒子背景 */
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}


