/* 嘉義縣政府 OSS 版型主色系（紫色 #7f4796） */
:root {
    /* Bootstrap 5 主色（對應 cyhg-oss --theme: #7f4796） */
    --bs-primary: #7f4796;
    --bs-primary-rgb: 127, 71, 150;
    --bs-primary-bg-subtle: #f3eaf7;
    --bs-primary-border-subtle: #d4a9e8;

    /* 嘉義縣府色系 token */
    --cyhg-primary: #7f4796;
    --cyhg-primary-rgb: 127, 71, 150;
    --cyhg-primary-dark: #6a3a7e;
    --cyhg-primary-light: #CC9CF5;
    --cyhg-primary-soft: #f3eaf7;

    /* 相容舊有 token */
    --primary-orange: var(--cyhg-primary) !important;
    --primary-dark: var(--cyhg-primary-dark) !important;
    --shadow: 0 2px 8px rgba(var(--cyhg-primary-rgb), 0.15) !important;
    --shadow-hover: 0 4px 16px rgba(var(--cyhg-primary-rgb), 0.25) !important;
}

html, body {
    font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif;
}

a, .btn-link {
    color: var(--bs-primary);
}

.btn-primary {
    color: #fff;
    background-color: var(--bs-primary);
    border-color: var(--cyhg-primary-dark);
}

.btn-primary:hover, .btn-primary:focus {
    background-color: var(--cyhg-primary-dark);
    border-color: var(--cyhg-primary-dark);
}

.btn-outline-primary {
    color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.btn-outline-primary:hover {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
}

.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 rgba(var(--bs-primary-rgb), 0.5);
}

.text-primary {
    color: var(--bs-primary) !important;
}

.spinner-border.text-primary {
    border-color: var(--bs-primary);
    border-right-color: transparent;
}

.content {
    padding-top: 1.1rem;
}

/* 讓頁面內容撐滿高度，避免 footer 瞬間上跳 */
.page {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

.main-content {
    flex: 1;
}

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;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
    color: var(--bs-secondary-color);
    text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
    text-align: start;
}

/* Import photo upload styles */
@import url('css/photo-upload.css');

/* 減少 Blazor Server 連線時的閃爍 */
html {
    visibility: visible;
}

/* 平滑過渡效果 */
.auth-buttons > * {
    transition: opacity 0.15s ease-in-out;
}

/* 避免內容載入時的佈局偏移 */
.service-categories-wrapper,
.popular-grid,
.news-grid {
    min-height: 200px; /* 預留空間，避免載入時佈局跳動 */
}

/* ===== 業務單位卡片（縣府圖示風格）===== */
.unit-card-grid { margin-top: 1.5rem; }

.unit-card-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 1.25rem 0.75rem 1rem;
    border-radius: 14px;
    background: #fff;
    border: 1px solid #e4eaf2;
    text-decoration: none !important;
    color: #333 !important;
    height: 100%;
    transition: box-shadow 0.2s, transform 0.2s;
    position: relative;
}
.unit-card-btn:hover,
.unit-card-btn:focus {
    box-shadow: 0 6px 20px rgba(42, 109, 181, 0.15);
    transform: translateY(-3px);
    border-color: #a8c8f0;
    color: #1a5aa8 !important;
}

/* 無圖時：圓形彩色背景 + BI 圖示 */
.unit-card-icon-wrap {
    width: 76px;
    height: 76px;
    border-radius: 50%;
    background: linear-gradient(135deg, #dceeff 0%, #b8d9ff 100%);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 0.75rem;
    overflow: hidden;
    flex-shrink: 0;
}
.unit-card-icon-wrap i {
    font-size: 2rem;
    color: #2a6db5;
    line-height: 1;
}

/* 有圖時：完整顯示插圖，不裁切 */
.unit-card-icon-wrap.has-img {
    width: 100%;
    height: 110px;
    border-radius: 0;
    background: transparent;
    overflow: visible;
    padding: 0 0.25rem;
}
.unit-card-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    object-position: center bottom;
}
.unit-card-name {
    font-size: 0.9rem;
    font-weight: 600;
    line-height: 1.35;
    margin-bottom: 0.4rem;
    word-break: break-word;
}
.unit-card-badge {
    font-size: 0.7rem;
    letter-spacing: 0.02em;
}

@media (max-width: 575.98px) {
    .unit-card-icon-wrap { width: 60px; height: 60px; }
    .unit-card-icon-wrap i { font-size: 1.6rem; }
    .unit-card-name { font-size: 0.82rem; }
}

/* 首頁 main 預設灰底（all.css: main{background:#f2f2f2}）會遮住
   .index 的 bg.png 藍色背景。設為透明讓藍色透出，
   再用 ~ 選取器讓搜尋區之後的所有區塊恢復灰底。 */
.index main {
    background: transparent !important;
}
.index main > #bidInquiries ~ * {
    background-color: #f2f2f2;
    box-shadow: 0 -2rem 0 0 #f2f2f2;
}

/* ===== 熱門申辦（簡潔文字列表）===== */
.popular-simple-list {
    max-width: 860px;
    margin: 1rem auto 0;
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}
.popular-simple-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 1.1rem 1.25rem;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 1px 6px rgba(0,0,0,0.05);
    text-decoration: none !important;
    color: #333 !important;
    transition: background-color 0.2s, padding-left 0.2s, box-shadow 0.2s;
    position: relative;
}
.popular-simple-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 3px;
    border-radius: 3px 0 0 3px;
    background: var(--bs-primary, #57B0B7);
    transform: scaleY(0);
    transition: transform 0.2s;
}
.popular-simple-item:hover,
.popular-simple-item:focus {
    background-color: #f8fbff;
    padding-left: 1.5rem;
    box-shadow: 0 3px 12px rgba(0,0,0,0.08);
}
.popular-simple-item:hover::before,
.popular-simple-item:focus::before {
    transform: scaleY(1);
}
.popular-simple-name {
    font-size: 1.15rem;
    font-weight: 600;
    line-height: 1.5;
}
.popular-simple-add {
    flex-shrink: 0;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #ef6c35;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    color: #fff;
    margin-left: 1rem;
    transition: background-color 0.2s, transform 0.2s;
}
.popular-simple-item:hover .popular-simple-add {
    background: #d95a28;
    transform: scale(1.15);
}

/* ===== 最新消息區塊 ===== */
.index #latestNews {
    background-color: #fff !important;
    padding-top: 2.5rem;
    padding-bottom: 3rem;
}
.index #latestNews .news-list {
    border-bottom: 2px solid #ef6c35;
    padding: 0.9rem 0;
    transition: background-color 0.2s;
}
.index #latestNews .news-list:hover {
    background-color: rgba(255, 113, 69, 0.08);
}
.index #latestNews .news-list .info {
    font-size: 0.95rem;
    color: #666;
}
.index #latestNews .news-list .title {
    font-size: 1.25rem;
    font-weight: 500;
}
.index #latestNews .news-list .title a {
    color: #333 !important;
    text-decoration: none;
}
.index #latestNews .news-list .title a:hover {
    color: #ef6c35 !important;
}

/* 申辦流程圖區塊修正：
   hvr-grow-shadow 設了 display:inline-block 覆蓋版型 CSS 的 display:flex，
   導致 .circle（左側彩色圖示）和 .word（右側文字）無法水平排列。 */
.index #biddingProcess .btn-light.hvr-grow-shadow {
    display: flex !important;
    align-items: center;
    border-radius: 1rem;
    font-size: 1.75em;
    font-weight: 600;
    padding: 0;
    background-color: #fff;
}
.index #biddingProcess .btn-light .circle {
    flex-shrink: 0;
    width: 150px;
    height: 160px;
    border-top-left-radius: 1rem;
    border-bottom-left-radius: 1rem;
    padding: 0.5rem 1.25rem;
    display: flex;
    align-items: center;
}
.index #biddingProcess .btn-light .word {
    width: calc(100% - 150px);
    text-align: center;
}
@media (max-width: 1199.98px) {
    .index #biddingProcess .btn-light.hvr-grow-shadow { font-size: 1.5em; }
    .index #biddingProcess .btn-light .circle { width: 120px; height: 120px; padding: 0.25rem 0.5rem; border-top-left-radius: 0.5rem; border-bottom-left-radius: 0.5rem; }
    .index #biddingProcess .btn-light .word { width: calc(100% - 120px); }
}
@media (max-width: 991.98px) {
    .index #biddingProcess .btn-light.hvr-grow-shadow { font-size: 1.125em; border-radius: 0.5rem; }
    .index #biddingProcess .btn-light .circle { width: 80px; height: 80px; }
    .index #biddingProcess .btn-light .word { width: calc(100% - 80px); }
}
@media (max-width: 767.98px) {
    .index #biddingProcess .col-12 + .col-12 { margin-top: 0.5rem; }
}

/* =====================================================
   內頁共用樣式（MainLayout / cyhg-inner）
   ===================================================== */

/* 內頁改用 flexbox 黏底：footer 保持正常 flow，
   避免 sticky-footer-navbar.css 的 margin-bottom 與實際 footer 高度不符的跑版問題 */
#wrapper.cyhg-inner {
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}
#wrapper.cyhg-inner .main-content {
    flex: 1;
}
#wrapper.cyhg-inner .footer {
    position: static;
    width: 100%;
}

/* --- 內頁 page-header 標題區 --- */
.page-header {
    background: #fff;
    border-bottom: 4px solid var(--bs-primary, var(--cyhg-primary));
    padding: 2.5rem 0;
    margin-bottom: 0;
    box-shadow: 0 2px 8px rgba(var(--cyhg-primary-rgb), 0.08);
}
.page-header .container { max-width: 1200px; }

.page-header .breadcrumb {
    background: transparent;
    padding: 0;
    margin-bottom: 1rem;
}
.page-header .breadcrumb-item a {
    color: #6b6b6b;
    text-decoration: none;
    transition: color 0.3s;
}
.page-header .breadcrumb-item a:hover {
    color: var(--bs-primary, var(--cyhg-primary));
}
.page-header .breadcrumb-item.active {
    color: #3e3e3e;
}
.page-header .breadcrumb-item + .breadcrumb-item::before {
    color: #6b6b6b;
}

.page-header h1 {
    color: #0b0b0b;
    font-weight: 700;
    font-size: 2rem;
    padding-left: 1rem;
    border-left: 5px solid var(--bs-primary, var(--cyhg-primary));
    margin-bottom: 0.75rem;
    display: flex;
    align-items: center;
    gap: 0.5rem;
}
.page-header h1 i {
    color: var(--bs-primary, var(--cyhg-primary));
}

.page-header .page-description {
    color: #3e3e3e;
    font-size: 1rem;
    padding-left: 1.75rem;
    margin-bottom: 0;
    line-height: 1.6;
}

@media (max-width: 768px) {
    .page-header { padding: 2rem 0; }
    .page-header h1 { font-size: 1.5rem; }
}

/* --- 內頁通用卡片 --- */
.main-content .card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06);
    transition: box-shadow 0.3s, transform 0.3s;
}
.main-content .card:hover {
    box-shadow: 0 4px 20px rgba(0,0,0,0.10);
}

/* --- 內頁分頁 --- */
.main-content .pagination .page-link {
    color: var(--bs-primary, var(--cyhg-primary));
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    margin: 0 0.25rem;
    padding: 0.6rem 1rem;
    font-weight: 500;
    transition: all 0.3s;
}
.main-content .pagination .page-link:hover {
    background: rgba(var(--cyhg-primary-rgb), 0.1);
    border-color: var(--bs-primary, var(--cyhg-primary));
    color: var(--bs-primary, var(--cyhg-primary));
}
.main-content .pagination .page-item.active .page-link {
    background: var(--bs-primary, var(--cyhg-primary));
    border-color: var(--bs-primary, var(--cyhg-primary));
    color: #fff;
    font-weight: 600;
}
.main-content .pagination .page-item.disabled .page-link {
    background: #f8f9fa;
    border-color: #e0e0e0;
    color: #cbd5e0;
}

/* --- 內頁按鈕融合 --- */
.main-content .btn-primary {
    background: var(--bs-primary, var(--cyhg-primary));
    border-color: var(--cyhg-primary-dark, #6a3a7e);
    border-radius: 10px;
    font-weight: 600;
    transition: all 0.3s;
}
.main-content .btn-primary:hover {
    background: var(--cyhg-primary-dark, #6a3a7e);
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(var(--cyhg-primary-rgb), 0.3);
}
.main-content .btn-outline-primary {
    border: 2px solid var(--bs-primary, var(--cyhg-primary));
    color: var(--bs-primary, var(--cyhg-primary));
    border-radius: 10px;
    font-weight: 600;
    transition: all 0.3s;
}
.main-content .btn-outline-primary:hover {
    background: var(--bs-primary, var(--cyhg-primary));
    color: #fff;
}

/* --- 內頁 alert 融合 --- */
.main-content .alert-info {
    background: var(--cyhg-primary-soft, #f3eaf7);
    border-left: 4px solid var(--bs-primary, var(--cyhg-primary));
    color: #3e3e3e;
    border-radius: 8px;
}
.main-content .alert-info i {
    color: var(--bs-primary, var(--cyhg-primary));
}

/* --- 內頁 text-primary 融合 --- */
.main-content .text-primary {
    color: var(--bs-primary, var(--cyhg-primary)) !important;
}

/* --- 內頁內容容器 --- */
.main-content .container {
    max-width: 1200px;
}

/* --- 確保內頁 section 有適當間距 --- */
.main-content section + section,
.main-content .container.py-4,
.main-content .container.py-5 {
    background: #f5f5f5;
}