/**
 * twCYMA Glass Design System
 * 玻璃科技風 — 全站視覺層（不影響功能邏輯）
 */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600;700&family=Noto+Sans+TC:wght@400;500;700&display=swap');

:root {
    --c-ice: #EAF4FC;
    --c-cream: #FFF6EE;
    --c-blue: #2F7FE0;
    --c-blue-deep: #155FAE;
    --c-coral: #FF8A5C;
    --c-coral-deep: #D9602F;
    --c-mint: #3FC79A;
    --c-ink: #16263D;
    --c-slate: #6B7C93;
    --glass-bg: rgba(255, 255, 255, 0.58);
    --glass-bg-strong: rgba(255, 255, 255, 0.72);
    --glass-border: rgba(255, 255, 255, 0.75);
    --glass-shadow: 0 10px 40px rgba(38, 71, 120, 0.12);
    --glass-radius: 20px;
    --glass-radius-sm: 14px;
}

/* ── 全域背景 ── */
body.twcyma-glass {
    font-family: 'Noto Sans TC', -apple-system, BlinkMacSystemFont, sans-serif;
    color: var(--c-ink);
    background: linear-gradient(160deg, var(--c-ice) 0%, var(--c-cream) 65%, var(--c-ice) 100%);
    min-height: 100vh;
    position: relative;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    margin: 0;
}

body.twcyma-glass .font-brand,
body.twcyma-glass .brand-name,
body.twcyma-glass h1.brand-title {
    font-family: 'Sora', 'Noto Sans TC', sans-serif;
}

/* 背景光暈色塊 */
.glass-blob {
    position: fixed;
    border-radius: 50%;
    filter: blur(70px);
    z-index: 0;
    pointer-events: none;
}
.glass-blob-1 { width: 420px; height: 420px; top: -120px; left: -100px; background: rgba(64, 143, 224, 0.30); }
.glass-blob-2 { width: 380px; height: 380px; bottom: -140px; right: -100px; background: rgba(255, 138, 92, 0.26); }
.glass-blob-3 { width: 260px; height: 260px; top: 42%; right: 8%; background: rgba(63, 199, 154, 0.18); }

/* ── 玻璃元件 ── */
.glass,
body.twcyma-glass .card,
body.twcyma-glass .home-card,
body.twcyma-glass .modal-content {
    background: var(--glass-bg);
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
}

body.twcyma-glass .card,
body.twcyma-glass .home-card {
    padding: 20px;
    margin-bottom: 16px;
}

/* ── Shell 版面 ── */
.glass-shell {
    position: relative;
    z-index: 1;
    display: flex;
    max-width: 1100px;
    margin: 0 auto;
    min-height: 100vh;
}
.glass-sidebar {
    display: none;
}
.glass-main {
    flex: 1;
    min-width: 0;
    padding: 28px 20px 110px;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.glass-frame {
    width: 100%;
    max-width: 380px;
}

/* 載入淡入 */
.glass-fade-children > * {
    opacity: 0;
    animation: glassFadeUp 0.5s ease forwards;
}
.glass-fade-children > *:nth-child(1) { animation-delay: 0.05s; }
.glass-fade-children > *:nth-child(2) { animation-delay: 0.1s; }
.glass-fade-children > *:nth-child(3) { animation-delay: 0.15s; }
.glass-fade-children > *:nth-child(4) { animation-delay: 0.2s; }
.glass-fade-children > *:nth-child(n+5) { animation-delay: 0.25s; }

@keyframes glassFadeUp {
    from { opacity: 0; transform: translateY(8px); }
    to { opacity: 1; transform: translateY(0); }
}

@media (prefers-reduced-motion: reduce) {
    .glass-fade-children > * { animation: none; opacity: 1; }
    .glass-status-dot { animation: none; }
}

/* ── 品牌列 ── */
.glass-brand-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
}
.glass-brand-logo {
    width: 44px;
    height: 44px;
    border-radius: 14px;
    flex-shrink: 0;
    background: linear-gradient(135deg, var(--c-blue), var(--c-mint));
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 18px rgba(47, 127, 224, 0.35);
    color: #fff;
    font-size: 22px;
}
.glass-brand-name {
    font-family: 'Sora', sans-serif;
    font-weight: 700;
    font-size: 19px;
    margin: 0;
    background: linear-gradient(90deg, var(--c-blue-deep), var(--c-coral-deep));
    background-clip: text;
    -webkit-background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
}
.glass-brand-sub { font-size: 12px; color: var(--c-slate); margin: 2px 0 0; }
.glass-live-badge {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 11px;
    color: var(--c-slate);
    flex-shrink: 0;
}
.glass-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--c-mint);
    display: inline-block;
    animation: glassPulse 2.4s infinite;
}
@keyframes glassPulse {
    0% { box-shadow: 0 0 0 0 rgba(63, 199, 154, 0.5); }
    70% { box-shadow: 0 0 0 8px rgba(63, 199, 154, 0); }
    100% { box-shadow: 0 0 0 0 rgba(63, 199, 154, 0); }
}

/* ── 狀態卡 / 登入卡 ── */
.glass-status-card,
body.twcyma-glass .login-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    margin-bottom: 8px;
    border: 1px solid var(--glass-border) !important;
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border-radius: var(--glass-radius) !important;
    box-shadow: var(--glass-shadow) !important;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    text-align: left;
    width: 100%;
}
.glass-status-card:hover,
body.twcyma-glass .login-card:hover,
body.twcyma-glass .card-hover:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 48px rgba(38, 71, 120, 0.16) !important;
}
.glass-avatar {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--c-blue-deep);
}
.glass-pill-row { display: flex; flex-wrap: wrap; gap: 6px; }
.glass-pill {
    font-size: 11px;
    padding: 3px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.65);
    color: var(--c-blue-deep);
    font-weight: 500;
}

/* ── 功能區塊 ── */
.glass-section-label {
    font-size: 12px;
    font-weight: 500;
    color: var(--c-slate);
    margin: 24px 0 10px;
    padding: 0 4px;
}
.glass-func-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

/* 首頁 quick-link 玻璃化 */
body.twcyma-glass .quick-links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}
body.twcyma-glass .quick-link-item {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: flex-start;
    justify-content: center;
    min-height: auto;
    padding: 16px;
    border-radius: 18px;
    text-decoration: none;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
body.twcyma-glass .quick-link-item .emoji { font-size: 24px; margin: 0 !important; }
body.twcyma-glass .quick-link-item .link-text {
    font-size: 13px !important;
    font-weight: 500;
    color: var(--c-ink) !important;
}
body.twcyma-glass .quick-link-item:nth-child(4n+1),
body.twcyma-glass .quick-link-item:nth-child(4n+2) {
    background: rgba(47, 127, 224, 0.14);
    border: 1px solid rgba(47, 127, 224, 0.22);
    box-shadow: 0 4px 20px rgba(47, 127, 224, 0.18);
}
body.twcyma-glass .quick-link-item:nth-child(4n+3),
body.twcyma-glass .quick-link-item:nth-child(4n+4) {
    background: rgba(255, 138, 92, 0.16);
    border: 1px solid rgba(255, 138, 92, 0.25);
    box-shadow: 0 4px 20px rgba(255, 138, 92, 0.20);
}
body.twcyma-glass .quick-link-item:hover {
    transform: translateY(-2px);
    background: rgba(255, 255, 255, 0.28);
}

/* chip-sm 次要功能 */
.glass-chip-sm {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.45);
    border: 1px solid rgba(255, 255, 255, 0.6);
    text-decoration: none;
    color: var(--c-ink);
    font-size: 12.5px;
    transition: background 0.2s ease;
}
.glass-chip-sm:hover { background: rgba(255, 255, 255, 0.65); }

/* ── 側欄導覽 ── */
.glass-nav-label {
    font-size: 11px;
    font-weight: 500;
    color: var(--c-slate);
    margin: 0 0 8px;
    padding: 0 6px;
}
.glass-nav-list { display: flex; flex-direction: column; gap: 2px; margin-bottom: 18px; }
.glass-nav-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 10px;
    border-radius: 12px;
    font-size: 13px;
    color: var(--c-ink);
    text-decoration: none;
    transition: background 0.2s ease;
}
.glass-nav-item:hover { background: rgba(255, 255, 255, 0.5); }
.glass-nav-divider { height: 1px; background: rgba(255, 255, 255, 0.6); margin: 4px 0 16px; }

.glass-input {
    width: 100%;
    height: 38px;
    border-radius: 14px;
    outline: none;
    border: 1px solid rgba(255, 255, 255, 0.7);
    background: rgba(255, 255, 255, 0.5);
    padding: 0 14px;
    font-size: 13px;
    color: var(--c-ink);
    font-family: 'Noto Sans TC', sans-serif;
    margin-bottom: 18px;
}
.glass-input::placeholder { color: var(--c-slate); }
.glass-input:focus {
    border-color: rgba(47, 127, 224, 0.5);
    box-shadow: 0 0 0 3px rgba(47, 127, 224, 0.15);
}

/* ── 底部導覽（手機） ── */
.glass-bottom-nav {
    position: fixed;
    bottom: 18px;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 32px);
    max-width: 360px;
    display: flex;
    justify-content: space-around;
    padding: 10px 8px;
    z-index: 50;
}
.glass-bnav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 3px;
    text-decoration: none;
    color: var(--c-slate);
    font-size: 11px;
    padding: 6px 14px;
    border-radius: 14px;
    transition: background 0.2s ease, color 0.2s ease;
}
.glass-bnav-item.active {
    color: var(--c-blue-deep);
    background: rgba(47, 127, 224, 0.14);
}

/* ── 支援卡 ── */
.glass-support-card { margin-top: 28px; padding: 18px 20px; }
.glass-support-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
    font-size: 13px;
}
.glass-support-row:last-child { border-bottom: none; }
.glass-support-value { font-weight: 500; color: var(--c-blue-deep); flex-shrink: 0; }

/* ── 打卡區塊 ── */
body.twcyma-glass .clock-card {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--glass-radius) !important;
    color: var(--c-ink);
}
body.twcyma-glass .clock-card .text-white,
body.twcyma-glass .clock-card span { color: var(--c-ink) !important; }
body.twcyma-glass .clock-card .text-white\/60,
body.twcyma-glass .clock-card .text-white\/50,
body.twcyma-glass .clock-card .text-white\/40,
body.twcyma-glass .clock-card .text-white\/70 { color: var(--c-slate) !important; }

/* ── 訪客提示 / Footer ── */
body.twcyma-glass #guest-login-tip {
    background: rgba(47, 127, 224, 0.1) !important;
    border: 1px solid rgba(47, 127, 224, 0.2);
    color: var(--c-ink) !important;
}
body.twcyma-glass #guest-login-tip a { color: var(--c-coral-deep) !important; }
body.twcyma-glass .glass-footer { text-align: center; margin-top: 32px; color: var(--c-slate); font-size: 12px; }

/* ── 分隔線 ── */
body.twcyma-glass .glass-divider span { color: var(--c-slate) !important; background: transparent !important; }
body.twcyma-glass .glass-divider .border-t { border-color: rgba(255, 255, 255, 0.5) !important; }

/* ── 主色按鈕覆寫 ── */
body.twcyma-glass .btn-primary,
body.twcyma-glass button.bg-blue-600,
body.twcyma-glass button.bg-blue-500 {
    background: var(--c-blue-deep) !important;
    border-color: #0f4a8a !important;
}
body.twcyma-glass button.bg-indigo-600 { background: var(--c-blue-deep) !important; }
body.twcyma-glass button.bg-teal-600 { background: #2a9d7a !important; }
body.twcyma-glass button.bg-green-600 { background: var(--c-mint) !important; }

/* ── Modal ── */
body.twcyma-glass .modal-overlay {
    background: rgba(22, 38, 61, 0.35);
    backdrop-filter: blur(4px);
}

/* ── 桌面版：側欄 + 寬內容 ── */
@media (min-width: 900px) {
    .glass-sidebar {
        display: flex;
        flex-direction: column;
        width: 240px;
        flex-shrink: 0;
        margin: 32px 0 32px 32px;
        padding: 20px;
        position: sticky;
        top: 32px;
        align-self: flex-start;
        max-height: calc(100vh - 64px);
        overflow-y: auto;
    }
    .glass-main { padding: 32px 40px 40px; align-items: flex-start; }
    .glass-frame { max-width: 720px; }
    body.twcyma-glass .quick-links { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .glass-func-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
    .glass-bottom-nav { display: none; }
}

@media (min-width: 640px) and (max-width: 899px) {
    body.twcyma-glass .quick-links { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 480px) {
    body.twcyma-glass .quick-links { grid-template-columns: repeat(2, 1fr); }
    .glass-main { padding: 20px 16px 110px; }
}

/* ══════════════════════════════════════════
   轉銜入口 referral-portal 覆寫
   ══════════════════════════════════════════ */
body.referral-portal-page {
    font-family: 'Noto Sans TC', sans-serif;
    color: var(--c-ink);
    background: linear-gradient(160deg, var(--c-ice) 0%, var(--c-cream) 65%, var(--c-ice) 100%) !important;
    min-height: 100vh;
    margin: 0;
}

body.referral-portal-page .portal-header {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border-bottom: 1px solid var(--glass-border);
    box-shadow: 0 4px 24px rgba(38, 71, 120, 0.08);
    color: var(--c-ink) !important;
    padding: 16px 20px;
}
body.referral-portal-page .portal-header h1 {
    font-family: 'Sora', sans-serif;
    color: var(--c-blue-deep) !important;
    background: linear-gradient(90deg, var(--c-blue-deep), var(--c-coral-deep));
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}
body.referral-portal-page .portal-header .text-blue-200,
body.referral-portal-page .portal-header .text-blue-100,
body.referral-portal-page .portal-header a.text-blue-200 {
    color: var(--c-slate) !important;
}
body.referral-portal-page .portal-header a:hover { color: var(--c-blue-deep) !important; }
body.referral-portal-page .portal-header button,
body.referral-portal-page .portal-header #header-admin-link {
    background: rgba(47, 127, 224, 0.15) !important;
    color: var(--c-blue-deep) !important;
    border: 1px solid rgba(47, 127, 224, 0.25) !important;
}

body.referral-portal-page .tab-bar {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
    padding: 8px 12px;
    gap: 6px;
}
body.referral-portal-page .tab-btn {
    background: rgba(255, 255, 255, 0.45) !important;
    color: var(--c-slate) !important;
    border: 1px solid rgba(255, 255, 255, 0.6) !important;
    border-radius: 12px !important;
    font-weight: 500;
}
body.referral-portal-page .tab-btn.active {
    background: rgba(47, 127, 224, 0.18) !important;
    color: var(--c-blue-deep) !important;
    border-color: rgba(47, 127, 224, 0.35) !important;
    box-shadow: 0 4px 16px rgba(47, 127, 224, 0.15);
}
body.referral-portal-page .tab-btn:hover:not(.active) {
    background: rgba(255, 255, 255, 0.65) !important;
    color: var(--c-ink) !important;
}

body.referral-portal-page .card {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--glass-radius) !important;
    box-shadow: var(--glass-shadow) !important;
}

body.referral-portal-page .tab-pane {
    animation: glassFadeUp 0.4s ease;
}

body.referral-portal-page .modal-content {
    background: var(--glass-bg-strong) !important;
    backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--glass-radius) !important;
    box-shadow: var(--glass-shadow) !important;
}

body.referral-portal-page .modal-overlay {
    background: rgba(22, 38, 61, 0.35);
    backdrop-filter: blur(4px);
}

body.referral-portal-page .field-attendance-panel {
    background: transparent !important;
}
body.referral-portal-page .field-attendance-panel h2 { color: var(--c-blue-deep) !important; }
body.referral-portal-page .field-attendance-panel .bg-gray-800 {
    background: var(--glass-bg) !important;
    border-color: var(--glass-border) !important;
    color: var(--c-ink) !important;
}
body.referral-portal-page .field-attendance-panel .text-white,
body.referral-portal-page .field-attendance-panel .text-gray-300,
body.referral-portal-page .field-attendance-panel .text-gray-400 {
    color: var(--c-ink) !important;
}

body.referral-portal-page .equipment-pick-card {
    background: rgba(255, 255, 255, 0.5) !important;
    border: 2px solid rgba(255, 255, 255, 0.7) !important;
    border-radius: 14px !important;
}
body.referral-portal-page .equipment-pick-card.selected {
    border-color: var(--c-blue-deep) !important;
    background: rgba(47, 127, 224, 0.12) !important;
}
body.referral-portal-page .equipment-pick-grid {
    background: rgba(255, 255, 255, 0.35) !important;
    border-color: rgba(255, 255, 255, 0.6) !important;
}

body.referral-portal-page .badge-published { background: rgba(47, 127, 224, 0.15); color: var(--c-blue-deep); }
body.referral-portal-page .badge-accepted { background: rgba(63, 199, 154, 0.18); color: #1a7a5c; }
body.referral-portal-page .badge-inprogress { background: rgba(255, 138, 92, 0.16); color: var(--c-coral-deep); }

@media (min-width: 900px) {
    body.referral-portal-page {
        display: grid;
        grid-template-columns: 240px 1fr;
        grid-template-rows: auto 1fr;
        grid-template-areas:
            "header header"
            "nav content";
    }
    body.referral-portal-page .portal-header { grid-area: header; }
    body.referral-portal-page .tab-bar {
        grid-area: nav;
        flex-direction: column;
        align-items: stretch;
        height: calc(100vh - 72px);
        position: sticky;
        top: 0;
        overflow-y: auto;
        border-bottom: none;
        border-right: 1px solid rgba(255, 255, 255, 0.5);
        padding: 16px 12px;
        margin: 0;
    }
    body.referral-portal-page .tab-btn {
        width: 100%;
        text-align: left;
        padding: 12px 14px !important;
    }
    body.referral-portal-page .tab-pane {
        grid-area: content;
        max-width: none;
    }
}

/* ══════════════════════════════════════════
   登入頁
   ══════════════════════════════════════════ */
body.twcyma-glass-login .gradient-bg,
body.twcyma-glass-login.glass-login-page {
    background: linear-gradient(160deg, var(--c-ice) 0%, var(--c-cream) 65%, var(--c-ice) 100%) !important;
    min-height: 100vh;
}
body.twcyma-glass-login .glass-card {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--glass-radius) !important;
    box-shadow: var(--glass-shadow) !important;
}
body.twcyma-glass-login .login-btn {
    background: linear-gradient(135deg, var(--c-blue-deep), var(--c-blue)) !important;
}

/* ══════════════════════════════════════════
   base.css 橋接：全站 card / badge
   ══════════════════════════════════════════ */
html.twcyma-glass-enabled body {
    background: linear-gradient(160deg, var(--c-ice) 0%, var(--c-cream) 65%, var(--c-ice) 100%);
    color: var(--c-ink);
}

html.twcyma-glass-enabled .card {
    background: var(--glass-bg);
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
}

html.twcyma-glass-enabled .btn-primary {
    background: var(--c-blue-deep) !important;
}

html.twcyma-glass-enabled .badge-info {
    background: rgba(47, 127, 224, 0.14);
    color: var(--c-blue-deep);
}
html.twcyma-glass-enabled .badge-success {
    background: rgba(63, 199, 154, 0.18);
    color: #1a7a5c;
}
html.twcyma-glass-enabled .badge-warning {
    background: rgba(255, 138, 92, 0.16);
    color: var(--c-coral-deep);
}

/* ══════════════════════════════════════════
   轉銜後台 referral-admin
   ══════════════════════════════════════════ */
body.twcyma-glass .bg-white,
body.twcyma-glass .rounded-xl.border {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border-color: var(--glass-border) !important;
    box-shadow: var(--glass-shadow);
}
body.twcyma-glass .modal-overlay .bg-white,
body.twcyma-glass .modal-content {
    background: var(--glass-bg-strong) !important;
    backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--glass-radius) !important;
}
body.twcyma-glass .bg-gray-100 { background: rgba(255, 255, 255, 0.35) !important; }
body.twcyma-glass button.bg-blue-600,
body.twcyma-glass button.bg-green-600 {
    border-radius: 12px;
}

/* ══════════════════════════════════════════
   全站 App 頁面通用覆寫（cases / approval / portal 等）
   ══════════════════════════════════════════ */
body.twcyma-glass nav.bg-white,
body.twcyma-glass .bg-white.shadow-sm,
body.twcyma-glass .bg-white.rounded-xl,
body.twcyma-glass .bg-white.rounded-lg,
body.twcyma-glass main .bg-white {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    -webkit-backdrop-filter: blur(18px) saturate(180%);
    border-color: var(--glass-border) !important;
}
body.twcyma-glass .shadow-sm { box-shadow: var(--glass-shadow) !important; }
body.twcyma-glass .border-gray-200,
body.twcyma-glass .border-b.border-gray-200 {
    border-color: rgba(255, 255, 255, 0.55) !important;
}
body.twcyma-glass .tab-active,
body.twcyma-glass .text-purple-600 { color: var(--c-blue-deep) !important; }
body.twcyma-glass .bg-purple-600 { background: var(--c-blue-deep) !important; }
body.twcyma-glass .hover\:bg-purple-700:hover { background: var(--c-blue) !important; }
body.twcyma-glass .focus\:ring-purple-500:focus { --tw-ring-color: rgba(47, 127, 224, 0.45) !important; }
body.twcyma-glass input.border-gray-300,
body.twcyma-glass select.border-gray-300,
body.twcyma-glass textarea.border-gray-300 {
    background: rgba(255, 255, 255, 0.55) !important;
    border-color: rgba(255, 255, 255, 0.75) !important;
    border-radius: 14px !important;
}
body.twcyma-glass .modal-overlay,
body.twcyma-glass #missed-punch-modal {
    background: rgba(22, 38, 61, 0.35) !important;
    backdrop-filter: blur(4px);
}
body.twcyma-glass .modal-overlay .bg-white,
body.twcyma-glass #missed-punch-modal > div {
    background: var(--glass-bg-strong) !important;
    backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--glass-radius) !important;
}

/* 登入頁（login.html） */
body.twcyma-glass-login-page .gradient-bg,
body.twcyma-glass.twcyma-glass-login-page {
    background: linear-gradient(160deg, var(--c-ice) 0%, var(--c-cream) 65%, var(--c-ice) 100%) !important;
}
body.twcyma-glass-login-page .bg-white {
    background: var(--glass-bg) !important;
    backdrop-filter: blur(18px) saturate(180%);
    border: 1px solid var(--glass-border) !important;
    border-radius: var(--glass-radius) !important;
    box-shadow: var(--glass-shadow) !important;
}

/* 外勤／深色操作介面（保留深色內容區、玻璃背景） */
body.twcyma-glass-dark {
    background: linear-gradient(160deg, #0f1c2e 0%, #16263D 55%, #1a2d44 100%) !important;
    color: #e8eef5;
}
body.twcyma-glass-dark .glass-blob-1 { background: rgba(64, 143, 224, 0.18); }
body.twcyma-glass-dark .glass-blob-2 { background: rgba(255, 138, 92, 0.14); }
body.twcyma-glass-dark .glass-blob-3 { background: rgba(63, 199, 154, 0.12); }
body.twcyma-glass-dark .bg-gray-900,
body.twcyma-glass-dark .bg-gray-800 {
    background: rgba(15, 28, 46, 0.72) !important;
    backdrop-filter: blur(16px) saturate(160%);
    border-color: rgba(255, 255, 255, 0.12) !important;
}
body.twcyma-glass-dark header,
body.twcyma-glass-dark nav {
    background: rgba(15, 28, 46, 0.65) !important;
    backdrop-filter: blur(18px) saturate(180%);
    border-color: rgba(255, 255, 255, 0.1) !important;
}

body.twcyma-glass .tab-container {
    background: rgba(255, 255, 255, 0.4) !important;
    border: 1px solid rgba(255, 255, 255, 0.55);
    border-radius: 14px !important;
    padding: 4px !important;
}
body.twcyma-glass .tab-container .tab-btn.active {
    background: rgba(255, 255, 255, 0.75) !important;
    color: var(--c-blue-deep) !important;
    box-shadow: 0 2px 12px rgba(47, 127, 224, 0.15) !important;
}
body.twcyma-glass .tab-container .tab-btn {
    color: var(--c-slate) !important;
    border-radius: 10px !important;
}

/* 工具／測試頁 */
body.twcyma-glass.tools-page .card,
body.twcyma-glass .tools-card {
    background: var(--glass-bg);
    backdrop-filter: blur(18px) saturate(180%);
    border: 1px solid var(--glass-border);
    border-radius: var(--glass-radius);
    box-shadow: var(--glass-shadow);
}
