/* ============================================================
   base.css — Reset + 全站基礎 + 共用元件 v0.2「俏皮版」
   ============================================================ */

*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    font-size: 16px;
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
    overflow-x: clip;
    scrollbar-gutter: stable;   /* 永遠保留滾動條空間，避免換頁時寬度跳動 */
}

/* ─── 跨頁面 View Transition｜Chrome 126+ / Safari 18+ 支援 ─── */
@view-transition { navigation: auto; }
::view-transition-old(root) {
    animation: 180ms cubic-bezier(0.4, 0, 0.2, 1) both vtFadeOut;
}
::view-transition-new(root) {
    animation: 220ms cubic-bezier(0.34, 1.56, 0.64, 1) both vtFadeIn;
}
@keyframes vtFadeOut { to { opacity: 0; } }
@keyframes vtFadeIn { from { opacity: 0; } }

body {
    font-family: var(--f-sans);
    font-weight: var(--fw-regular);
    line-height: var(--lh-normal);
    color: var(--text-primary);
    background: var(--bg-base);
    background-image:
        radial-gradient(circle at 88% 12%, rgba(var(--c-yellow-rgb), 0.14) 0%, transparent 38%),
        radial-gradient(circle at 8% 88%, rgba(var(--c-pink-rgb), 0.08) 0%, transparent 42%);
    min-height: 100vh;
    position: relative;
    overflow-x: clip;
    transition: background-color 300ms ease, color 300ms ease;
}

[data-theme="dark"] body {
    background-image:
        radial-gradient(circle at 88% 12%, rgba(var(--c-yellow-rgb), 0.10) 0%, transparent 42%),
        radial-gradient(circle at 8% 88%, rgba(var(--c-blue-rgb), 0.16) 0%, transparent 48%);
}

main { position: relative; z-index: 1; }

/* ─── SVG Icon 全域基調｜俏皮版「圓厚」icon 語系 ───
   - linecap/linejoin = round：線端圓頭，呼應 14px 圓角卡片
   - stroke-width 預設 2.25：在 4px hard shadow + 1.5px ink border 環境裡才有重量感
   - 個別 SVG 仍可用 stroke-width 屬性覆寫（如裝飾貼紙星 1.5、CTA 箭頭 2.75）
*/
svg {
    stroke-linecap: round;
    stroke-linejoin: round;
}
svg[stroke="currentColor"]:not([stroke-width]) {
    stroke-width: 2.5;
}

/* ─── Typography ─── */
h1, h2, h3, h4, h5, h6 {
    font-weight: var(--fw-bold);
    line-height: var(--lh-tight);
    color: var(--text-primary);
    letter-spacing: -0.015em;
    text-wrap: balance;   /* CJK 標題多行時平衡斷行、避免單字孤行（如「…的影/片」）；單行不受影響 */
}
h1 { font-size: var(--fs-3xl); font-weight: var(--fw-extra); letter-spacing: -0.03em; }
h2 { font-size: var(--fs-xl); }
h3 { font-size: var(--fs-lg); }

p { color: var(--text-secondary); text-wrap: pretty; }

a {
    color: var(--c-blue);
    text-decoration: none;
    font-weight: var(--fw-medium);
    transition: color var(--t-fast);
}
a:hover { color: var(--c-pink); }

.num, .mono {
    font-family: var(--f-mono);
    font-variant-numeric: tabular-nums;
    letter-spacing: -0.02em;
}

code {
    font-family: var(--f-mono);
    font-size: 0.9em;
    padding: 2px 8px;
    background: var(--c-cream-soft);
    border: 1px solid var(--border-base);
    border-radius: var(--radius-sm);
}

/* ─── Container ─── */
.container {
    width: 100%;
    max-width: var(--max-w-content);
    margin: 0 auto;
    padding: 0 var(--sec-px);
}

/* topbar 容器鎖死在 --max-w-content（1200）、不被各頁覆寫的
   全域 .container（如閱讀頁 880 / 影片庫 1100）牽連而跟著縮放。
   選擇器 .topbar > .container（0,2,0）特異度高於頁面 .container（0,1,0）、
   無論載入順序皆勝出。頁面若要窄內容欄、覆寫 main 內的 .container 即可、不波及此處。 */
.topbar > .container {
    max-width: var(--max-w-content);
}

/* ─── Card｜大圓角 + hard offset shadow ─── */
.card {
    background: var(--bg-surface);
    border: 1.5px solid var(--c-ink);
    border-radius: var(--radius-lg);
    padding: var(--sp-5);
    box-shadow: var(--shadow-pop);
    transition: transform var(--t-base), box-shadow var(--t-base);
}
.card:hover {
    transform: translate(-2px, -2px);
    box-shadow: var(--shadow-pop-lg);
}

.card-soft {
    background: var(--bg-surface);
    border: 1px solid var(--border-base);
    border-radius: var(--radius-lg);
    padding: var(--sp-5);
    box-shadow: var(--shadow-soft);
}

/* ─── Button｜大圓角 + 彈跳 + hard shadow ─── */
.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--sp-2);
    padding: var(--sp-3) var(--sp-5);
    font-family: inherit;
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    line-height: 1;
    color: var(--text-primary);
    background: var(--bg-surface);
    border: 1.5px solid var(--c-ink);
    border-radius: var(--radius-pill);
    cursor: pointer;
    transition: all var(--t-fast);
    white-space: nowrap;
    text-decoration: none;
    box-shadow: var(--shadow-pop-sm);
}
.btn:hover {
    transform: translate(-1px, -1px);
    box-shadow: var(--shadow-pop);
}
.btn:active {
    transform: translate(2px, 2px);
    box-shadow: 0 0 0 var(--c-ink);
}
.btn:focus-visible {
    outline: none;
    box-shadow: var(--shadow-pop), var(--shadow-glow-yellow);
}

.btn-primary {
    background: var(--c-yellow);
    color: var(--text-on-yellow);
}
.btn-primary:hover { background: var(--c-yellow-deep); }

.btn-ink {
    background: var(--c-ink);
    color: #FFFFFF;
}
.btn-ink:hover { background: #1A2240; }

.btn-pink {
    background: var(--c-pink);
    color: var(--text-on-pink);
}

.btn-blue {
    background: var(--c-blue);
    color: var(--text-on-blue);
}

.btn-ghost {
    border-color: transparent;
    background: transparent;
    box-shadow: none;
}
.btn-ghost:hover {
    background: var(--c-cream-deep);
    transform: none;
    box-shadow: none;
}

.btn-lg {
    padding: var(--sp-4) var(--sp-6);
    font-size: var(--fs-base);
    font-weight: var(--fw-bold);
}

.btn-sm {
    padding: var(--sp-2) var(--sp-3);
    font-size: var(--fs-xs);
}

.btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    pointer-events: none;
}

/* ─── Input ─── */
.input {
    width: 100%;
    padding: var(--sp-3) var(--sp-4);
    font-family: inherit;
    font-size: var(--fs-base);
    color: var(--text-primary);
    background: var(--bg-input);
    border: 1.5px solid var(--c-ink);
    border-radius: var(--radius-md);
    transition: all var(--t-fast);
    box-shadow: var(--shadow-pop-sm);
}
.input::placeholder { color: var(--text-tertiary); }
.input:hover { transform: translate(-1px, -1px); box-shadow: var(--shadow-pop); }
.input:focus {
    outline: none;
    transform: translate(-1px, -1px);
    box-shadow: var(--shadow-pop), var(--shadow-glow-yellow);
}

.input-group {
    display: flex;
    flex-direction: column;
    gap: var(--sp-2);
}
.label {
    font-size: var(--fs-sm);
    font-weight: var(--fw-semibold);
    color: var(--text-primary);
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
}
.helper {
    font-size: var(--fs-xs);
    color: var(--text-tertiary);
}
.required::after {
    content: ' *';
    color: var(--c-pink);
}

/* ─── 數字輸入框：移除瀏覽器預設的上下微調箭頭（spinner）── 與自訂單位（NTD）/版型衝突、
   桌面與手機都會出現。保留 type=number 的手機數字鍵盤 + min/max 驗證。 */
input[type="number"]::-webkit-outer-spin-button,
input[type="number"]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}
input[type="number"] {
    -moz-appearance: textfield;
    appearance: textfield;
}

/* ─── Checkbox｜全站客製、覆蓋原生醜醜的方塊 ─── */
input[type="checkbox"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    min-height: 20px;     /* 蓋過 button/input 全域 min-height: 32px */
    aspect-ratio: 1 / 1;  /* 保證永遠正方形 */
    margin: 0;
    padding: 0;
    border: 1.5px solid var(--c-ink);
    border-radius: 5px;
    background: var(--bg-surface);
    box-shadow: 2px 2px 0 var(--c-ink);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    vertical-align: middle;
    transition: all var(--t-fast);
    position: relative;
}
input[type="checkbox"]:hover {
    transform: translate(-1px, -1px);
    box-shadow: 3px 3px 0 var(--c-ink);
}
input[type="checkbox"]:active {
    transform: translate(1px, 1px);
    box-shadow: 1px 1px 0 var(--c-ink);
}
input[type="checkbox"]:focus-visible {
    outline: none;
    box-shadow: 2px 2px 0 var(--c-ink), 0 0 0 3px rgba(var(--c-pink-rgb), 0.35);
}
input[type="checkbox"]:checked {
    background: var(--c-pink);
    border-color: var(--c-ink);
}
input[type="checkbox"]:checked::after {
    content: '';
    width: 6px;
    height: 10px;
    border: solid #FFFFFF;
    border-width: 0 2.5px 2.5px 0;
    transform: rotate(45deg) translate(-1px, -1px);
}
input[type="checkbox"]:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

/* ─── Radio｜給未來頁面預備好（目前 mockup 沒用、但建立預設）─── */
input[type="radio"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 20px;
    height: 20px;
    min-height: 20px;
    aspect-ratio: 1 / 1;
    margin: 0;
    border: 1.5px solid var(--c-ink);
    border-radius: 50%;
    background: var(--bg-surface);
    box-shadow: 2px 2px 0 var(--c-ink);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    vertical-align: middle;
    transition: all var(--t-fast);
}
input[type="radio"]:hover {
    transform: translate(-1px, -1px);
    box-shadow: 3px 3px 0 var(--c-ink);
}
input[type="radio"]:focus-visible {
    outline: none;
    box-shadow: 2px 2px 0 var(--c-ink), 0 0 0 3px rgba(var(--c-pink-rgb), 0.35);
}
input[type="radio"]:checked {
    background: var(--c-yellow);
    border-color: var(--c-ink);
}
input[type="radio"]:checked::after {
    content: '';
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: var(--c-ink);
}
input[type="radio"]:disabled {
    opacity: 0.4;
    cursor: not-allowed;
    pointer-events: none;
}

/* ─── 文字選取高亮｜把瀏覽器預設藍色選取改成品牌黃 ─── */
::selection {
    background: var(--c-yellow);
    color: var(--c-ink);
}
[data-theme="dark"] ::selection {
    background: var(--c-yellow);
    color: var(--text-on-yellow);
}

/* ─── 表單錯誤態｜統一給 input / select / textarea 使用 ─── */
.input-group.has-error .input,
.input-group.has-error .input:hover,
.input-group.has-error .input:focus {
    border-color: var(--c-pink);
    box-shadow: var(--shadow-pop-sm), 0 0 0 3px rgba(var(--c-pink-rgb), 0.20);
}
.input-error {
    display: none;
    align-items: center;
    gap: 4px;
    margin-top: 6px;
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    color: var(--c-pink);
    line-height: 1.4;
}
.input-error svg {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}
.input-group.has-error .input-error { display: flex; }
.input-group.has-error .helper { display: none; }

/* ─── 表單層錯誤 / 訊息橫幅｜給後端錯誤 / 操作確認用 ─── */
.form-alert {
    display: flex;
    align-items: flex-start;
    gap: var(--sp-3);
    padding: var(--sp-3) var(--sp-4);
    border-radius: var(--radius-md);
    border: 1.5px solid;
    margin-bottom: var(--sp-4);
    font-size: var(--fs-sm);
    line-height: 1.5;
    animation: alertSlideIn 280ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.form-alert__icon {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    margin-top: 1px;
}
.form-alert__body { flex: 1; }
.form-alert__title { font-weight: var(--fw-bold); margin-bottom: 2px; }
.form-alert__close {
    background: transparent;
    border: none;
    color: inherit;
    cursor: pointer;
    padding: 4px;
    opacity: 0.6;
    flex-shrink: 0;
}
.form-alert__close:hover { opacity: 1; }
.form-alert--danger {
    background: var(--c-pink-soft);
    border-color: var(--c-pink);
    color: var(--c-ink);
}
.form-alert--danger .form-alert__icon { color: var(--c-pink); }
.form-alert--warning {
    background: rgba(var(--c-yellow-rgb), 0.12);
    border-color: var(--warning);
    color: var(--c-ink);
}
.form-alert--success {
    background: var(--success-bg);
    border-color: var(--c-mint);
    color: var(--c-ink);
}
.form-alert--info {
    background: var(--c-blue-soft);
    border-color: var(--c-blue);
    color: var(--c-ink);
}
@keyframes alertSlideIn {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
}

[data-theme="dark"] .form-alert--danger,
[data-theme="dark"] .form-alert--warning,
[data-theme="dark"] .form-alert--success,
[data-theme="dark"] .form-alert--info {
    color: var(--text-primary);
}

/* ─── Badge / Tag｜俏皮 pill ─── */
.badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    font-size: var(--fs-xs);
    font-weight: var(--fw-semibold);
    line-height: 1.3;
    border-radius: var(--radius-pill);
    border: 1.5px solid var(--c-ink);
    background: var(--bg-surface);
    box-shadow: 2px 2px 0 var(--c-ink);
    white-space: nowrap;
}
.badge-success { background: var(--c-mint); color: var(--c-ink); }
.badge-warning { background: var(--warning); color: #0F1632; border-color: var(--warning); }
.badge-danger  { background: var(--c-pink); color: #0F1632; }   /* 功能性狀態 badge（未過審/拒絕）：白字壓 pink 僅 2.7:1，深墨字 ~5.5:1 達 AA、保留品牌 pink 底 */
.badge-info    { background: var(--c-blue); color: #FFFFFF; }
.badge-neutral { background: var(--c-cream-deep); color: var(--c-ink); }

/* ─── Top Bar ─── */
.topbar {
    position: sticky;
    top: 0;
    z-index: var(--z-nav);
    height: var(--nav-h);
    background: rgba(255, 251, 240, 0.85);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1.5px solid var(--c-ink);
}
.topbar__inner {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--sp-4);
}

.topbar__brand {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-3);
    font-size: var(--fs-md);
    font-weight: var(--fw-extra);
    color: var(--c-ink);
    letter-spacing: -0.02em;
}
.topbar__brand-mark {
    width: 40px;
    height: 40px;
    background: var(--c-yellow);
    border: 1.5px solid var(--c-ink);
    border-radius: var(--radius-md);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 2px 2px 0 var(--c-ink);
    transition: transform var(--t-fast);
}
.topbar__brand:hover .topbar__brand-mark { transform: rotate(-6deg); }
.topbar__brand-mark::after {
    content: 'e';
    font-family: var(--f-sans-en);
    font-style: italic;
    font-weight: var(--fw-extra);
    font-size: 22px;
    color: var(--c-ink);
}

.topbar__center {
    display: flex;
    align-items: center;
    gap: var(--sp-1);
}
.topbar__nav-item {
    padding: var(--sp-2) var(--sp-4);
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
    color: var(--text-secondary);
    border-radius: var(--radius-pill);
    transition: all var(--t-fast);
}
.topbar__nav-item:hover {
    background: var(--c-cream-deep);
    color: var(--text-primary);
}
.topbar__nav-item.is-active {
    background: var(--c-ink);
    color: #FFFFFF;
}

.topbar__right {
    display: flex;
    align-items: center;
    gap: var(--sp-3);
}

/* ─── 信用點 pill｜中性白底、與 avatar 同高 ─── */
.credit-pill {
    display: inline-flex;
    align-items: center;
    gap: var(--sp-2);
    height: 40px;
    padding: 0 6px 0 var(--sp-4);
    background: var(--bg-surface);
    border: 1.5px solid var(--c-ink);
    border-radius: var(--radius-pill);
    font-size: var(--fs-sm);
    box-shadow: 2px 2px 0 var(--c-ink);
    transition: all var(--t-fast);
    cursor: pointer;
    color: var(--c-ink);
    text-decoration: none;
}
.credit-pill:hover { transform: translate(-1px, -1px); box-shadow: 3px 3px 0 var(--c-ink); }
.credit-pill__label {
    color: var(--text-tertiary);
    font-size: var(--fs-xs);
    font-weight: var(--fw-medium);
}
.credit-pill__value {
    font-family: var(--f-mono);
    font-weight: var(--fw-bold);
    color: var(--c-ink);
    font-variant-numeric: tabular-nums;
}
.credit-pill__cta {
    background: var(--c-ink);
    color: #FFFFFF;
    padding: 4px 10px;
    border-radius: var(--radius-pill);
    font-size: var(--fs-xs);
    font-weight: var(--fw-bold);
}

/* ─── Avatar ─── */
.avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--c-pink);
    border: 1.5px solid var(--c-ink);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--f-sans-en);
    font-size: var(--fs-sm);
    font-weight: var(--fw-bold);
    color: #FFFFFF;
    cursor: pointer;
    box-shadow: 2px 2px 0 var(--c-ink);
    transition: all var(--t-fast);
}
.avatar:hover { transform: translate(-1px, -1px); box-shadow: 3px 3px 0 var(--c-ink); }

/* ─── Divider ─── */
.divider {
    border: none;
    border-top: 1px dashed var(--border-strong);
    margin: var(--sp-4) 0;
}

/* ─── Animations｜俏皮彈跳 ─── */
@keyframes popIn {
    0%   { opacity: 0; transform: translateY(12px) scale(0.96); }
    60%  { opacity: 1; transform: translateY(-2px) scale(1.01); }
    100% { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes wiggle {
    0%, 100% { transform: rotate(0); }
    25% { transform: rotate(-2deg); }
    75% { transform: rotate(2deg); }
}
@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-8px); }
}
@keyframes pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.08); }
}

[data-reveal] {
    opacity: 0;
    animation: popIn 500ms cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}
[data-reveal][data-delay="1"] { animation-delay: 60ms; }
[data-reveal][data-delay="2"] { animation-delay: 140ms; }
[data-reveal][data-delay="3"] { animation-delay: 220ms; }
[data-reveal][data-delay="4"] { animation-delay: 300ms; }
[data-reveal][data-delay="5"] { animation-delay: 380ms; }
[data-reveal][data-delay="6"] { animation-delay: 460ms; }
[data-reveal][data-delay="7"] { animation-delay: 540ms; }

.float { animation: float 4s ease-in-out infinite; }
.wiggle-hover:hover { animation: wiggle 400ms ease-in-out; }
.pulse { animation: pulse 2s ease-in-out infinite; }

@media (prefers-reduced-motion: reduce) {
    [data-reveal], .float, .pulse, .wiggle-hover {
        animation: none;
        opacity: 1;
    }
    *, *::before, *::after { transition: none !important; }
}

/* ─── Focus ring ─── */
:focus-visible {
    outline: 3px solid var(--c-yellow);
    outline-offset: 3px;
    border-radius: var(--radius-sm);
}

/* ─── Touch target ─── */
button, a, input, select, textarea, [role="button"] { min-height: 32px; }
.btn, .input { min-height: 44px; }

.sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* ============================================================
   Dark Mode 元件微調｜
   策略：一般元件用「淡邊 + subtle shadow」，狀態指示保留 hard shadow
   ============================================================ */

/* 一般大型容器卡片 — 在 dark 改 subtle，避免高對比邊框 + 硬陰影壓眼 */
[data-theme="dark"] .card,
[data-theme="dark"] .card-soft {
    border-color: var(--border-strong);
}
[data-theme="dark"] .card { box-shadow: var(--shadow-pop-sm); }
[data-theme="dark"] .card:hover { box-shadow: var(--shadow-pop); transform: none; }

/* 表單元素 — 邊降為淡白 */
[data-theme="dark"] .input { border-color: var(--border-strong); box-shadow: none; }
[data-theme="dark"] .input:hover { transform: none; box-shadow: 0 0 0 1px var(--border-strong); }
[data-theme="dark"] .input:focus { transform: none; box-shadow: 0 0 0 2px var(--c-yellow), var(--shadow-pop-sm); }

/* 一般按鈕 — 邊降為淡白、不再 hard offset */
[data-theme="dark"] .btn {
    border-color: var(--border-strong);
    background: var(--bg-elevated);
    box-shadow: none;
}
[data-theme="dark"] .btn:hover { transform: none; box-shadow: 0 0 0 1px var(--c-ink); }
[data-theme="dark"] .btn:active { transform: none; box-shadow: none; }
[data-theme="dark"] .btn-ghost { background: transparent; }
[data-theme="dark"] .btn-ghost:hover { background: var(--bg-elevated); box-shadow: none; }

/* 「狀態指示」級別按鈕 — 保留招牌 hard shadow（亮色） */
[data-theme="dark"] .btn-primary {
    border-color: var(--c-yellow);
    background: var(--c-yellow);
    color: var(--text-on-yellow);
    box-shadow: 4px 4px 0 rgba(var(--c-yellow-rgb), 0.35);
}
[data-theme="dark"] .btn-primary:hover {
    background: var(--c-yellow-deep);
    border-color: var(--c-yellow-deep);
    transform: translate(-1px, -1px);
    box-shadow: 5px 5px 0 rgba(var(--c-yellow-rgb), 0.40);
}
[data-theme="dark"] .btn-pink {
    background: var(--c-pink);
    border-color: var(--c-pink);
    box-shadow: 4px 4px 0 rgba(255, 107, 137, 0.35);
}
[data-theme="dark"] .btn-blue {
    background: var(--c-blue);
    border-color: var(--c-blue);
    box-shadow: 4px 4px 0 rgba(91, 123, 255, 0.30);
}
[data-theme="dark"] .btn-ink {
    background: var(--bg-elevated);
    border-color: var(--border-strong);
    color: var(--text-primary);
    box-shadow: none;
}

/* Topbar 品牌 mark / 信用點 pill / avatar — 維持 hard shadow（品牌 / 狀態） */
[data-theme="dark"] .topbar { background: rgba(10, 15, 31, 0.85); }
[data-theme="dark"] .credit-pill {
    background: var(--bg-elevated);
    border-color: var(--border-strong);
    box-shadow: 2px 2px 0 rgba(240, 242, 248, 0.20);
}
[data-theme="dark"] .credit-pill__label { color: var(--text-tertiary); }
[data-theme="dark"] .credit-pill__cta {
    background: var(--c-yellow);
    color: var(--text-on-yellow);
}
[data-theme="dark"] .avatar { box-shadow: 2px 2px 0 rgba(240, 242, 248, 0.20); }
[data-theme="dark"] .topbar__brand-mark {
    box-shadow: 2px 2px 0 rgba(var(--c-yellow-rgb), 0.40);
}
[data-theme="dark"] .topbar__brand-mark::after { color: var(--text-on-yellow); }

/* Topbar nav active — 在 dark 改用黃色 sticker（避免 c-ink 翻光導致看不見）*/
[data-theme="dark"] .topbar__nav-item:hover { background: var(--bg-elevated); color: var(--text-primary); }
[data-theme="dark"] .topbar__nav-item.is-active {
    background: var(--c-yellow);
    color: var(--text-on-yellow);
}

/* Badge — hard shadow 維持，色調對深底重新校準 */
[data-theme="dark"] .badge {
    background: var(--bg-elevated);
    border-color: var(--border-strong);
    box-shadow: 2px 2px 0 rgba(240, 242, 248, 0.20);
    color: var(--text-primary);
}
[data-theme="dark"] .badge-success { background: var(--c-mint); color: #0F1632; border-color: var(--c-mint); }
[data-theme="dark"] .badge-warning { background: var(--warning); color: #0F1632; border-color: var(--warning); }
[data-theme="dark"] .badge-danger { background: var(--c-pink); color: #0F1632; border-color: var(--c-pink); }
[data-theme="dark"] .badge-info { background: var(--c-blue); color: #FFFFFF; border-color: var(--c-blue); }

/* ============================================================
   Theme Toggle｜晝夜切換鈕
   - 主要 .theme-toggle--inline：小型無框 icon、嵌在 topbar 帳號頭像左側（桌面+手機統一）
   - 後援 .theme-toggle--fab：右下角浮動圓鈕、只給無 topbar 的頁面（登入 / 忘記密碼 / 重設密碼）
   ============================================================ */
.theme-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all var(--t-fast);
    color: var(--c-ink);
    padding: 0;
    background: none;
    border: none;
}
.theme-toggle svg {
    width: 20px;
    height: 20px;
}
/* 顯示控制只用 class 規則（避免 svg 的 display 把 __sun 的 display:none 壓過、
   導致亮色模式月亮+太陽同時出現）。亮色：月亮顯示、太陽隱藏；暗色於下方反轉。 */
.theme-toggle__moon { display: block; }
.theme-toggle__sun { display: none; }
[data-theme="dark"] .theme-toggle__moon { display: none; }
[data-theme="dark"] .theme-toggle__sun { display: block; }
[data-theme="dark"] .theme-toggle { color: var(--text-primary); }

/* ── 主要：topbar 內聯型（小、無框、頭像左側）── */
.theme-toggle--inline {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    border-radius: var(--radius-md);
    color: var(--text-secondary);
}
.theme-toggle--inline:hover { background: var(--c-cream-deep); color: var(--text-primary); }
[data-theme="dark"] .theme-toggle--inline:hover { background: var(--bg-elevated); color: var(--text-primary); }

/* ── 後援：右下角浮動圓鈕（僅無 topbar 的頁面）── */
.theme-toggle--fab {
    position: fixed;
    bottom: 24px;
    right: 24px;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--bg-surface);
    border: 1.5px solid var(--c-ink);
    box-shadow: 3px 3px 0 var(--c-ink);
    z-index: var(--z-nav);
}
.theme-toggle--fab svg { width: 22px; height: 22px; }
.theme-toggle--fab:hover { transform: translate(-2px, -2px); box-shadow: 5px 5px 0 var(--c-ink); }
.theme-toggle--fab:active { transform: translate(1px, 1px); box-shadow: 1px 1px 0 var(--c-ink); }
[data-theme="dark"] .theme-toggle--fab {
    background: var(--bg-elevated);
    border-color: var(--border-strong);
    box-shadow: 3px 3px 0 rgba(240, 242, 248, 0.20);
}
[data-theme="dark"] .theme-toggle--fab:hover { box-shadow: 5px 5px 0 rgba(240, 242, 248, 0.25); }

/* ─── 手機漢堡導覽抽屜（桌面隱藏、≤768px 顯示）─── */
.topbar__burger {
    display: none; /* 桌面用水平 nav；≤768px 於 RWD 區改 inline-flex */
    flex-direction: column; justify-content: center; align-items: center; gap: 4px;
    width: 44px; height: 44px; padding: 0; margin-right: -6px;
    background: none; border: none; cursor: pointer; border-radius: var(--radius-md);
    -webkit-tap-highlight-color: transparent;
}
.topbar__burger span { display: block; width: 20px; height: 2.5px; border-radius: 2px; background: var(--text-primary); }
.topbar__scrim { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.5); z-index: 1000; opacity: 0; transition: opacity 0.2s ease; }
.topbar__scrim.is-open { opacity: 1; }
.topbar__drawer {
    position: fixed; top: 0; right: 0; bottom: 0; width: min(82vw, 300px); z-index: 1001;
    background: var(--bg-surface); border-left: 1.5px solid var(--c-ink);
    transform: translateX(100%); transition: transform 0.25s ease-out;
    display: flex; flex-direction: column; padding: var(--sp-3); overflow-y: auto;
}
.topbar__drawer.is-open { transform: translateX(0); }

/* 內嵌模式（在 iframe 內、如投放頁的條款 bottom-sheet）：隱藏 topbar 與返回鈕、
   讓 iframe 只顯示內容、不出現巢狀導覽列。.embedded 由 layout 早期 inline script 加在 <html>。 */
html.embedded .topbar { display: none; }
html.embedded .back-link { display: none !important; }
html.embedded .page-h__crumb { display: none; }   /* 麵包屑與 bottom-sheet 標題重複、內嵌時隱藏 */
.topbar__drawer-head { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-2) var(--sp-2) var(--sp-3); }
.topbar__drawer-title { font-weight: var(--fw-extra); font-size: var(--fs-md); }
.topbar__drawer-close { width: 44px; height: 44px; border: none; background: none; cursor: pointer; font-size: 24px; line-height: 1; color: var(--text-secondary); border-radius: var(--radius-md); }
.topbar__drawer-close:hover { background: var(--bg-elevated); color: var(--text-primary); }
.topbar__drawer-credit { display: flex; align-items: center; gap: var(--sp-2); min-height: 44px; padding: var(--sp-3); margin-bottom: var(--sp-3); background: var(--c-ink); color: #FFFFFF; border-radius: var(--radius-md); text-decoration: none; }
.topbar__drawer-credit__label { font-size: var(--fs-xs); color: rgba(255, 255, 255, 0.6); }
.topbar__drawer-credit__value { font-size: var(--fs-lg); font-weight: var(--fw-extra); margin-left: auto; }
.topbar__drawer-credit__cta { font-size: var(--fs-xs); font-weight: var(--fw-bold); background: var(--c-yellow); color: var(--text-on-yellow); padding: 4px 10px; border-radius: 999px; }
/* Dark：.topbar__drawer-credit 原 background:var(--c-ink) 在 dark 翻成淺色 #F0F2F8、配寫死白字 → 白底白字（對比 1.07）。
   改用 bg-elevated 深色表面、白字/白 0.6 label/cyan CTA 即可讀（與其他 ink 底元件 dark override 一致）。 */
[data-theme="dark"] .topbar__drawer-credit { background: var(--bg-elevated); }
.topbar__drawer-nav { display: flex; flex-direction: column; gap: 2px; }
.topbar__drawer-link { display: flex; align-items: center; min-height: 48px; padding: 0 var(--sp-3); border-radius: var(--radius-md); text-decoration: none; color: var(--text-primary); font-weight: var(--fw-semibold); font-size: var(--fs-base); }
.topbar__drawer-link:hover { background: var(--bg-elevated); }
.topbar__drawer-link.is-active { background: var(--c-yellow); color: var(--text-on-yellow); }
@media (min-width: 769px) { .topbar__drawer, .topbar__scrim, .topbar__burger { display: none !important; } }

/* 浮動後援鈕（--fab）若出現在有底部動作條的頁面時上移避讓 CTA。
   註：主要 toggle 已內聯進 topbar、不再浮動；--fab 僅出現在無 topbar 的登入類頁（無 action-bar），
   此規則保留為防衛性、實務上不會觸發。 */
body:has(.action-bar) .theme-toggle--fab {
    bottom: calc(var(--sp-4) + 60px + var(--sp-3));
}

/* RWD */
@media (max-width: 768px) {
    :root {
        --sec-px: 1rem;
        --fs-3xl: 2.25rem;
        --fs-2xl: 1.75rem;
    }
    .topbar__center { display: none; }
    .topbar__burger { display: inline-flex; }
    .topbar .credit-pill { display: none; } /* 信用點移入抽屜頭部、避免 topbar 擁擠 */
    .topbar__brand span:not(:first-child) { font-size: var(--fs-sm); }
    .theme-toggle--fab { bottom: 16px; right: 16px; width: 44px; height: 44px; }
}
