/* ═══════════════════════════════════════════════════════════════════════
   CHATAROT.AI Design System — Quiet Console Tokens
   ═══════════════════════════════════════════════════════════════════════ */

:root {
  /* ───────────────────────── COLOR · BACKGROUNDS ─────────────────────── */
  --bg-cosmic:      #000000;
  --bg-content:     #08090c;
  --bg-surface:     #12141a;
  --bg-surface-2:   #181b22;
  --bg-glass:       rgba(18, 20, 26, 0.72);
  --bg-glass-strong:rgba(8, 9, 12, 0.84);
  --backdrop-blur:  blur(20px) saturate(1.1);

  /* ───────────────────────── COLOR · TEXT ────────────────────────────── */
  --text-primary:   #ECE9E1;
  --text-secondary: rgba(236, 233, 225, 0.62);
  --text-subtle:    rgba(236, 233, 225, 0.38);
  --text-faint:     rgba(236, 233, 225, 0.22);
  --text-mono:      #B8BAC0;

  /* ───────────────────────── COLOR · BORDERS ─────────────────────────── */
  --border-hairline: rgba(236, 233, 225, 0.08);
  --border-subtle:   rgba(236, 233, 225, 0.16);
  --border-active:   rgba(236, 233, 225, 0.40);
  --border-strong:   rgba(236, 233, 225, 0.64);

  /* ───────────────────────── COLOR · ACCENT ──────────────────────────── */
  --accent-ivory:    #ECE9E1;
  --accent-signal:   #C9A66B;
  --accent-warning:  #D96B5C;
  --accent-success:  #8AA67A;
  --accent-link:     #ECE9E1;

  /* ───────────────────────── COLOR · GLOW ────────────────────────────── */
  --glow-subtle:  0 0 16px rgba(236, 233, 225, 0.06);
  --glow-halo:    0 0 32px rgba(236, 233, 225, 0.10);
  --glow-signal:  0 0 24px rgba(201, 166, 107, 0.18);
  --glow-warning: 0 0 24px rgba(217, 107, 92, 0.22);

  /* ───────────────────────── TYPE · FAMILIES ─────────────────────────── */
  --font-sans: 'Inter', 'Noto Sans SC', 'Noto Sans JP', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  --font-mono: 'IBM Plex Mono', 'JetBrains Mono', ui-monospace, 'SFMono-Regular', monospace;
  --font-display: 'Dancing Script', cursive;

  /* ───────────────────────── TYPE · SIZES ────────────────────────────── */
  --text-xs: 10px;
  --text-sm: 12px;
  --text-base: 14px;
  --text-md: 16px;
  --text-lg: 20px;
  --text-xl: 28px;
  --text-2xl: 36px;

  /* ───────────────────────── RADIUS ──────────────────────────────────── */
  --radius-0: 4px;
  --radius-1: 8px;
  --radius-2: 12px;
  --radius-3: 16px;
  --radius-full: 9999px;

  /* ───────────────────────── SPACING ─────────────────────────────────── */
  --space-xs: 4px;
  --space-sm: 8px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 32px;
  --space-2xl: 48px;

  /* ───────────────────────── TRANSITIONS ─────────────────────────────── */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --duration-fast: 150ms;
  --duration-normal: 300ms;
  --duration-slow: 600ms;
  --duration-glacial: 1200ms;
}

/* ───────────────────────── RESET ──────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
  color: inherit;
}

a {
  color: var(--accent-link);
  text-decoration: none;
}

textarea {
  font-family: var(--font-sans);
  resize: none;
  border: none;
  outline: none;
  background: transparent;
  color: var(--text-primary);
}

::selection {
  background: rgba(201, 166, 107, 0.3);
  color: var(--text-primary);
}

/* ═══════════════════════════════════════════════════════════════════════
   CHATAROT.AI — Main Layout Styles
   ═══════════════════════════════════════════════════════════════════════ */

html, body {
    margin: 0;
    padding: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    font-family: var(--font-sans);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background: #000;
    color: var(--text-primary);
    overscroll-behavior: none;
    touch-action: pan-x pan-y;
}

html { height: 100%; }
body { min-height: 100vh; min-height: 100dvh; }

/* ───────────────────────── 滚动条隐藏 ─────────────────────────────── */
html::-webkit-scrollbar,
body::-webkit-scrollbar { display: none; width: 0; height: 0; }

/* ───────────────────────── 3D 场景层 ───────────────────────────────── */
#three-container {
    position: fixed;
    inset: 0;
    z-index: 1;
    pointer-events: auto;
}

#three-container canvas {
    display: block;
}

/* ───────────────────────── UI 覆盖层 ───────────────────────────────── */
.ui-overlay {
    position: fixed;
    inset: 0;
    z-index: 1000;
    display: flex;
    flex-direction: column;
    align-items: center;
    pointer-events: none;
}

.ui-overlay > * {
    pointer-events: auto;
}

/* ───────────────────────── 内容包装器 ─────────────────────────────── */
.content-wrapper {
    position: fixed;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    box-sizing: border-box;
    z-index: 1001;
    padding-top: 120px;
    pointer-events: none;
}

/* ───────────────────────── 屏幕阅读器专用标题 ─────────────────────── */
.main-title {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* ───────────────────────── 启动遮罩 ───────────────────────────────── */
.start-scrim {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: #000;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    padding: 40px;
    transition: opacity var(--duration-slow) var(--ease-out);
}

.start-scrim.is-hidden {
    opacity: 0;
    pointer-events: none;
}

.start-scrim-status {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
}

.start-scrim-row {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

.start-scrim-dots {
    display: flex;
    gap: 4px;
}

.start-scrim-dots .dot {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: var(--text-faint);
    animation: dotPulse 1.4s infinite;
}

.start-scrim-dots .dot:nth-child(2) { animation-delay: 0.2s; }
.start-scrim-dots .dot:nth-child(3) { animation-delay: 0.4s; }

@keyframes dotPulse {
    0%, 60%, 100% { opacity: 0.2; }
    30% { opacity: 1; }
}

/* ───────────────────────── 区域切换 ────────────────────────────────── */
.section {
    width: 100%;
    max-width: 680px;
    display: flex;
    flex-direction: column;
    align-items: center;
    opacity: 0;
    transform: translateY(12px);
    transition: opacity var(--duration-normal) var(--ease-out),
                transform var(--duration-normal) var(--ease-out);
    pointer-events: none;
}

.section.active {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* ───────────────────────── 页脚 ────────────────────────────────────── */
.site-footer {
    position: fixed;
    bottom: 20px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1001;
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    color: var(--text-faint);
    display: flex;
    align-items: center;
    gap: var(--space-sm);
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.site-footer a {
    color: var(--text-faint);
    transition: color var(--duration-fast);
}

.site-footer a:hover { color: var(--text-secondary); }

.footer-divider { color: var(--border-hairline); }

/* ───────────────────────── 响应式 ──────────────────────────────────── */
@media (max-width: 768px) {
    .content-wrapper { padding-top: 100px; }
    .start-scrim { padding: 24px; }
    .site-footer { bottom: 12px; font-size: 10px; }
}

/* ═══════════════════════════════════════════════════════════════════════
   CHATAROT.AI — UI Components
   ═══════════════════════════════════════════════════════════════════════ */

/* ───────────────────────── 品牌标识 ────────────────────────────────── */
.brand-pill {
    position: fixed;
    top: 24px;
    left: 24px;
    z-index: 50001;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px 8px 8px;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-full);
}

.brand-logomark {
    width: 28px;
    height: 28px;
    color: var(--accent-signal);
    flex-shrink: 0;
}

.brand-wordmark {
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.12em;
    color: var(--text-primary);
    white-space: nowrap;
}

/* ───────────────────────── 状态胶囊 ────────────────────────────────── */
.top-right-bar {
    position: fixed;
    top: 24px;
    right: 24px;
    z-index: 50001;
    display: flex;
    align-items: center;
    gap: 8px;
    pointer-events: auto;
}
.hero-status.app-status-pill {
    position: relative;
    top: 30px;
    right: 24px;
    z-index: 50000;
    font-family: var(--font-mono);
    pointer-events: auto;
}

.app-status-pill-button {
    height: 32px;
    padding: 0 14px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-1);
    color: var(--text-primary);
    font-size: var(--text-sm);
    cursor: pointer;
    white-space: nowrap;
}

.app-status-pill-button .micro {
    color: var(--text-mono);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
}

.status-divider {
    color: var(--text-faint);
    font-size: 10px;
}

.app-status-pill-button .val {
    color: var(--accent-signal);
    font-weight: 500;
}

.status-suffix {
    color: var(--text-secondary);
    font-size: 11px;
}

.app-status-pill.is-warning .app-status-pill-button {
    border-color: rgba(217, 107, 92, 0.3);
}

.app-status-pill.is-warning .val {
    color: var(--accent-warning);
}

/* ───────────────────────── 用户区 ──────────────────────────────────── */
.user-corner {
    position: relative;
    z-index: 50001;
    pointer-events: auto;
}

.auth-buttons {
    display: flex;
    gap: 8px;
}

.auth-btn {
    height: 32px;
    padding: 0 14px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-1);
    color: var(--text-secondary);
    font-size: var(--text-sm);
    font-family: var(--font-mono);
    letter-spacing: 0.04em;
    transition: all var(--duration-fast);
}

.auth-btn:hover {
    border-color: var(--border-active);
    color: var(--text-primary);
}

.auth-btn i {
    font-size: 14px;
    opacity: 0.7;
}

/* ───────────────────────── 卡组信息 ────────────────────────────────── */
.hero-deck {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.16em;
    color: var(--text-mono);
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 24px;
    opacity: 0.7;
}

/* ───────────────────────── 副标题 ──────────────────────────────────── */
.subtitle {
    font-family: var(--font-sans);
    font-size: var(--text-xl);
    font-weight: 200;
    color: var(--text-primary);
    text-align: center;
    margin-bottom: 32px;
    letter-spacing: 0.02em;
    line-height: 1.35;
    max-width: 560px;
}

/* ───────────────────────── 输入容器 ────────────────────────────────── */
.input-container {
    width: 100%;
    max-width: 580px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}

.input-shell {
    width: 100%;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-2);
    padding: 16px;
    transition: border-color var(--duration-normal);
}

.input-shell:focus-within {
    border-color: var(--border-active);
    box-shadow: var(--glow-halo);
}

.input-shell textarea {
    width: 100%;
    min-height: 72px;
    font-size: var(--text-md);
    font-weight: 300;
    line-height: 1.6;
    color: var(--text-primary);
    background: transparent;
    border: none;
    outline: none;
    resize: none;
    caret-color: var(--accent-signal);
}

.input-shell textarea::placeholder {
    color: var(--text-faint);
}

.input-toolbar {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 4px;
}

.input-chip-anchor {
    display: flex;
    flex-wrap: wrap;
}

.top-chips-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

/* ═══════════════════════════════════════════════════════════════════════
   CHATAROT.AI — Hero Input Chips（解读师 / 牌阵 选择器）
   ═══════════════════════════════════════════════════════════════════════ */

.tarot-master-selector,
.spread-selector {
    height: 30px;
    padding: 0 10px;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all var(--duration-fast);
    white-space: nowrap;
    user-select: none;
}

.tarot-master-selector:hover,
.spread-selector:hover {
    border-color: rgba(255, 255, 255, 0.16);
    background: rgba(255, 255, 255, 0.07);
}

.hero-chip-label {
    color: var(--text-mono);
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.hero-chip-value {
    color: var(--text-primary);
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 400;
    letter-spacing: 0.03em;
    max-width: 100px;
    overflow: hidden;
    text-overflow: ellipsis;
}

.hero-chip-chevron {
    font-size: 7px;
    color: var(--text-faint);
    transition: transform var(--duration-fast);
}

.tarot-master-selector:hover .hero-chip-chevron,
.spread-selector:hover .hero-chip-chevron {
    color: var(--text-mono);
}

/* ───────────────────────── 输入元数据 ──────────────────────────────── */
.input-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 0 4px;
}

.input-charcount {
    display: flex;
    align-items: center;
    gap: 4px;
    font-family: var(--font-mono);
    font-size: 10px;
}

.meta-label {
    color: var(--text-mono);
    letter-spacing: 0.12em;
    font-weight: 500;
}

.meta-dot {
    color: var(--text-faint);
    font-size: 8px;
}

.meta-count {
    color: var(--text-primary);
    font-weight: 500;
}

.meta-max {
    color: var(--text-faint);
}

.input-shortcut {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--text-faint);
    letter-spacing: 0.04em;
}

/* ───────────────────────── CTA 按钮 ────────────────────────────────── */
.cta-button {
    height: 48px;
    padding: 0 32px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--accent-ivory);
    color: #000;
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    border-radius: var(--radius-full);
    transition: all var(--duration-fast);
    cursor: pointer;
    border: none;
}

.cta-button:hover {
    background: rgba(236, 233, 225, 0.88);
    box-shadow: var(--glow-halo);
    transform: translateY(-1px);
}

.cta-button:active {
    transform: translateY(0);
}

.cta-button i {
    font-size: 14px;
}

.cta-button.secondary {
    background: transparent;
    color: var(--text-primary);
    border: 1px solid var(--border-subtle);
}

.cta-button.secondary:hover {
    background: var(--bg-glass);
    border-color: var(--border-active);
}

/* ───────────────────────── 洗牌动画 ────────────────────────────────── */
.shuffle-message {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 32px;
    margin-top: 40px;
}

.shuffle-animation {
    display: flex;
    gap: 16px;
    perspective: 600px;
}

.shuffle-card {
    width: 60px;
    height: 96px;
    background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
    border: 1px solid var(--border-subtle);
    border-radius: 8px;
    animation: shuffleFloat 1.5s infinite ease-in-out;
}

@keyframes shuffleFloat {
    0%, 100% { transform: translateY(0) rotateY(0deg); }
    25% { transform: translateY(-20px) rotateY(30deg); }
    75% { transform: translateY(10px) rotateY(-30deg); }
}

.shuffle-text {
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: 300;
    color: var(--text-secondary);
    text-align: center;
    letter-spacing: 0.04em;
}

/* Done-shuffle button fade-in */
#doneShuffleBtn.visible {
    display: flex !important;
    animation: fadeInUp 0.4s ease-out;
}

@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(12px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ───────────────────────── 选牌提示 ────────────────────────────────── */
#pickSection.active {
    pointer-events: none !important;
    transform: none;
}

.pick-message {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-top: 40px;
    text-align: center;
    pointer-events: none;
}

.pick-text {
    font-family: var(--font-sans);
    font-size: var(--text-xl);
    font-weight: 300;
    color: var(--text-primary);
}

.pick-subtext {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    color: var(--text-mono);
    letter-spacing: 0.08em;
}

.pick-progress {
    display: inline-flex;
    align-items: baseline;
    gap: 6px;
    min-width: 72px;
    justify-content: center;
    font-family: var(--font-mono);
    font-size: 12px;
    letter-spacing: 0.12em;
    color: var(--accent-signal);
    font-variant-numeric: tabular-nums;
}

.pick-progress-divider {
    color: var(--text-faint);
}

.pick-actions {
    position: fixed;
    left: 50%;
    bottom: calc(24px + env(safe-area-inset-bottom, 0px));
    z-index: 50010;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 10px;
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-2);
    background: rgba(8, 8, 12, 0.82);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    transform: translateX(-50%);
    pointer-events: auto;
}

.pick-action-btn,
.pick-confirm-btn {
    min-height: 42px;
    padding: 0 16px;
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-1);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.06em;
    transition: color var(--duration-fast),
                border-color var(--duration-fast),
                background-color var(--duration-fast),
                opacity var(--duration-fast),
                transform var(--duration-fast);
}

.pick-action-btn {
    color: var(--text-secondary);
    background: rgba(255, 255, 255, 0.025);
}

.pick-action-btn:not(:disabled) {
    color: var(--text-primary);
    border-color: var(--border-subtle);
    background: rgba(255, 255, 255, 0.055);
}

.pick-confirm-btn {
    min-width: 148px;
    color: #08080c;
    background: var(--accent-ivory);
    border-color: var(--accent-ivory);
}

.pick-action-btn:not(:disabled):hover {
    color: var(--text-primary);
    border-color: var(--border-active);
    background: rgba(255, 255, 255, 0.06);
}

.pick-confirm-btn:not(:disabled):hover {
    transform: translateY(-1px);
    background: #fff;
}

.pick-action-btn:focus-visible,
.pick-confirm-btn:focus-visible {
    outline: 2px solid var(--accent-signal);
    outline-offset: 3px;
}

.pick-action-btn:disabled,
.pick-confirm-btn:disabled {
    cursor: not-allowed;
    opacity: 0.32;
}

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

body.card-selection-active .top-right-bar,
body.card-selection-active .site-footer {
    opacity: 0;
    pointer-events: none;
}

/* ───────────────────────── 解读结果 ────────────────────────────────── */
.reading-container {
    width: 100%;
    max-width: 600px;
    max-height: calc(100dvh - 140px);
    padding: 20px 16px;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-2);
    display: flex;
    flex-direction: column;
    gap: 0;
    scrollbar-width: none;
    margin: 0 8px;
    overflow: hidden;
}

.reading-container::-webkit-scrollbar { display: none; }

.reading-scroll {
    flex: 1 1 auto;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding-bottom: 8px;
    scrollbar-width: none;
    min-height: 0;
}

.reading-header {
    text-align: center;
}

.reading-question-label,
.reading-cards-label,
.reading-interpretation-label {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--text-faint);
    margin-bottom: 4px;
}

.reading-question {
    font-family: var(--font-sans);
    font-size: var(--text-lg);
    font-weight: 400;
    color: var(--text-primary);
    margin-bottom: 4px;
    line-height: 1.5;
}

.reading-meta {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--text-mono);
    letter-spacing: 0.06em;
}

.reading-divider {
    width: 100%;
    height: 1px;
    background: var(--border-hairline);
    margin: 4px 0;
}

.reading-cards-display {
    display: flex;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
    padding: 4px 0;
}

.reading-card-item {
    width: 72px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.reading-card-img {
    width: 72px;
    height: 115px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--border-subtle);
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.reading-card-item.reversed .reading-card-img {
    transform: rotate(180deg);
}

.reading-card-item .card-name {
    font-family: var(--font-mono);
    font-size: 9px;
    color: var(--text-mono);
    text-align: center;
    line-height: 1.3;
    letter-spacing: 0.02em;
    max-width: 72px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.reading-interpretation {
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: 300;
    line-height: 1.8;
    color: var(--text-secondary);
    min-height: 60px;
}

.reading-interpretation h2,
.reading-interpretation h3 {
    font-family: var(--font-sans);
    font-weight: 500;
    color: var(--text-primary);
    margin: 12px 0 6px;
    font-size: var(--text-base);
}

.reading-interpretation strong {
    color: var(--accent-signal);
    font-weight: 500;
}

.reading-interpretation em {
    color: var(--text-subtle);
    font-style: italic;
}

.reading-interpretation ul,
.reading-interpretation ol {
    padding-left: 16px;
    margin: 6px 0;
}

.reading-interpretation li {
    margin-bottom: 4px;
}

.reading-interpretation p {
    margin-bottom: 8px;
}

.reading-interpretation code {
    font-family: var(--font-mono);
    font-size: var(--text-sm);
    background: var(--bg-surface-2);
    padding: 2px 6px;
    border-radius: 4px;
}

.reading-btn-row {
    display: flex;
    gap: 8px;
    width: 100%;
    flex-shrink: 0;
    padding-top: 8px;
    border-top: 1px solid var(--border-hairline);
    margin-top: 0;
}

.reading-btn-row .cta-button {
    flex: 1;
    font-size: 11px;
    height: 40px;
    padding: 0 12px;
    white-space: nowrap;
}

.reading-btn-row .cta-button.secondary {
    flex: 1;
}

.interpretation-loading {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 20px 0;
}

.interpretation-loading .loading-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--text-faint);
    animation: dotPulse 1.4s infinite;
}

.follow-up-panel {
    display: none;
    padding-top: 8px;
    border-top: 1px solid var(--border-hairline);
    flex-shrink: 0;
}

.follow-up-panel.is-visible {
    display: block;
}

.follow-up-thread {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-bottom: 10px;
}

.follow-up-message {
    padding: 10px 12px;
    border-radius: var(--radius-1);
    font-size: var(--text-sm);
    line-height: 1.65;
}

.follow-up-message.user {
    margin-left: 18%;
    background: rgba(201, 166, 107, 0.1);
    border: 1px solid rgba(201, 166, 107, 0.18);
    color: var(--text-primary);
}

.follow-up-message.assistant {
    margin-right: 8%;
    background: var(--bg-surface-2);
    border: 1px solid var(--border-hairline);
    color: var(--text-secondary);
}

.follow-up-form {
    display: flex;
    gap: 8px;
}

.follow-up-input {
    flex: 1;
    min-width: 0;
    height: 40px;
    padding: 0 12px;
    border-radius: var(--radius-1);
    border: 1px solid var(--border-subtle);
    background: var(--bg-surface-2);
    color: var(--text-primary);
    font-family: var(--font-sans);
    outline: none;
}

.follow-up-input:focus {
    border-color: rgba(201, 166, 107, 0.45);
}

.follow-up-submit {
    height: 40px;
    padding: 0 14px;
    border-radius: var(--radius-1);
    border: 1px solid var(--border-subtle);
    background: var(--text-primary);
    color: #000;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.06em;
    flex-shrink: 0;
}

.follow-up-submit:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}

.interpretation-loading .loading-dot:nth-child(2) { animation-delay: 0.2s; }
.interpretation-loading .loading-dot:nth-child(3) { animation-delay: 0.4s; }

/* ───────────────────────── 输入验证动画 ────────────────────────────── */
@keyframes shake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-6px); }
    40% { transform: translateX(6px); }
    60% { transform: translateX(-4px); }
    80% { transform: translateX(4px); }
}

/* ───────────────────────── 语言选择器 ──────────────────────────────── */
.language-selector {
    position: fixed;
    bottom: 20px;
    right: 24px;
    z-index: 50001;
}

.language-button {
    height: 32px;
    padding: 0 12px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-full);
    color: var(--text-secondary);
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.06em;
    transition: all var(--duration-fast);
}

.language-button:hover {
    border-color: var(--border-subtle);
    color: var(--text-primary);
}

.language-dropdown {
    position: absolute;
    bottom: 40px;
    right: 0;
    background: var(--bg-glass-strong);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-1);
    padding: 4px;
    min-width: 160px;
}

.lang-option {
    padding: 8px 12px;
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--text-secondary);
    cursor: pointer;
    border-radius: var(--radius-0);
    transition: all var(--duration-fast);
}

.lang-option:hover {
    background: var(--bg-surface-2);
    color: var(--text-primary);
}

.lang-option.active {
    color: var(--accent-signal);
}

/* ───────────────────────── 卡牌皮肤按钮 ────────────────────────────── */
.card-skin-toggle {
    position: fixed;
    bottom: 20px;
    right: 140px;
    z-index: 50001;
}

.card-skin-btn {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-hairline);
    border-radius: 50%;
    color: var(--text-secondary);
    font-size: 14px;
    transition: all var(--duration-fast);
}

.card-skin-btn:hover {
    border-color: var(--border-subtle);
    color: var(--accent-signal);
}

/* ───────────────────────── 内容导航按钮 ────────────────────────────── */
.content-nav-toggle {
    position: fixed;
    bottom: 68px;
    right: 24px;
    z-index: 50001;
}

.content-nav-btn {
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--bg-glass);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-hairline);
    border-radius: 50%;
    color: var(--text-secondary);
    font-size: 14px;
    transition: all var(--duration-fast);
}

.content-nav-btn:hover {
    border-color: var(--border-subtle);
    color: var(--text-primary);
}

/* ───────────────────────── 响应式 ──────────────────────────────────── */
@media (max-width: 768px) {
    .brand-pill { top: 16px; left: 16px; padding: 6px 12px 6px 6px; }
    .brand-wordmark { font-size: 11px; }
    .brand-logomark { width: 24px; height: 24px; }
    .hero-status.app-status-pill { }
    .user-corner { }
    .top-right-bar { top: 16px; right: 16px; }
    .subtitle { font-size: var(--text-lg); margin-bottom: 24px; padding: 0 16px; }
    .input-container { padding: 0 16px; }
    .language-selector { bottom: 12px; right: 16px; }
    .card-skin-toggle { bottom: 12px; right: 120px; }

    .pick-message {
        margin-top: 12px;
        padding: 0 20px;
    }

    .pick-actions {
        width: calc(100% - 24px);
        position: relative;
        left: auto;
        bottom: auto;
        display: grid;
        grid-template-columns: 0.85fr 1.1fr 1.4fr;
        gap: 6px;
        padding: 6px;
        transform: none;
    }

    .pick-action-btn,
    .pick-confirm-btn {
        width: 100%;
        min-width: 0;
        min-height: 38px;
        padding: 0 7px;
        gap: 5px;
        font-size: 10px;
        letter-spacing: 0.02em;
        white-space: nowrap;
    }

    .pick-confirm-btn {
        grid-column: auto;
    }
}

/* ═══════════════════════════════════════════════════════════════════════
   CHATAROT.AI — Panels (牌阵 / 解读师 / 模态)
   ═══════════════════════════════════════════════════════════════════════ */

/* ───────────────────────── 通用面板 ────────────────────────────────── */
.spread-list-panel,
.master-list-panel {
    position: fixed;
    inset: 0;
    z-index: 6000;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--duration-normal);
}

.spread-list-panel.is-open,
.master-list-panel.is-open {
    opacity: 1;
    pointer-events: auto;
}

.spread-list-content,
.master-list-content {
    background: var(--bg-glass-strong);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-2);
    padding: 24px;
    max-width: 520px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: var(--glow-halo);
}

.spread-list-title,
.master-list-title {
    font-family: var(--font-mono);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--text-primary);
    text-transform: uppercase;
    margin-bottom: 20px;
    text-align: center;
}

/* ───────────────────────── 卡片容器 ────────────────────────────────── */
.spread-cards-wrapper,
.master-cards-wrapper {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* 解读师与牌阵使用完整 3:2 视觉图，桌面两列展示 */
.spread-list-content,
.master-list-content {
    max-width: 960px;
}

.spread-cards-wrapper,
.master-cards-wrapper {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* ───────────────────────── 通用卡片 (竖排: 图上文下) ───────────────── */
.spread-card,
.master-card {
    display: flex;
    flex-direction: column;
    background: var(--bg-surface);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-2);
    padding: 0;
    cursor: pointer;
    overflow: hidden;
    transition: all var(--duration-fast);
}

.spread-card,
.master-card {
    position: relative;
    display: block;
    aspect-ratio: 1535 / 1024;
    background: transparent;
    isolation: isolate;
}

.spread-card:hover,
.master-card:hover {
    border-color: var(--border-active);
    background: var(--bg-surface-2);
    box-shadow: var(--glow-subtle);
}

.spread-card.is-selected,
.master-card.is-selected {
    border-color: var(--accent-signal);
    box-shadow: var(--glow-signal);
}

/* ───────────────────────── 图片占位区 (上图) ────────────────────────── */
.master-card-img,
.spread-card-img {
    width: 100%;
    height: 120px;
    background: var(--bg-surface-2);
    border-bottom: 1px solid var(--border-hairline);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-mono);
    font-size: 11px;
    letter-spacing: 0.1em;
    flex-shrink: 0;
    transition: border-color var(--duration-fast);
}

.spread-card-img,
.master-card-img {
    height: 100%;
    aspect-ratio: 1535 / 1024;
    border-bottom: 0;
    background: transparent;
}

.spread-card-img::after,
.master-card-img::after {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    background: linear-gradient(
        180deg,
        transparent 38%,
        rgba(3, 4, 7, 0.18) 55%,
        rgba(3, 4, 7, 0.76) 100%
    );
}

.spread-card:hover .master-card-img,
.spread-card:hover .spread-card-img,
.master-card:hover .master-card-img,
.master-card:hover .spread-card-img {
    background: var(--bg-surface-3);
}

.spread-card.is-selected .master-card-img,
.spread-card.is-selected .spread-card-img,
.master-card.is-selected .master-card-img,
.master-card.is-selected .spread-card-img {
    background: var(--bg-surface-3);
}

.master-card-img img,
.spread-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.spread-card-img img,
.master-card-img img {
    display: block;
    object-fit: contain;
}

/* ───────────────────────── 卡片文字区 (下文) ────────────────────────── */
.master-card-info,
.spread-card-info {
    padding: 14px 16px 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.spread-card-info,
.master-card-info {
    position: absolute;
    inset: auto 0 0;
    z-index: 2;
    padding: 20px;
    background: transparent;
    pointer-events: none;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.95);
}

/* ───────────────────────── Master 卡片 ─────────────────────────────── */
.master-card-name {
    font-family: var(--font-sans);
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
    line-height: 1.3;
}

.master-card-role {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--text-mono);
    letter-spacing: 0.08em;
}

.master-card-style {
    font-family: var(--font-sans);
    font-size: 12px;
    color: rgba(255, 255, 255, 0.78);
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ───────────────────────── Spread 卡片 ─────────────────────────────── */
.spread-card-name {
    font-family: var(--font-sans);
    font-size: 16px;
    font-weight: 600;
    color: var(--text-primary);
}

.spread-card-meta {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--text-mono);
    letter-spacing: 0.06em;
}

.spread-card-desc {
    font-family: var(--font-sans);
    font-size: 12px;
    color: rgba(255, 255, 255, 0.78);
    line-height: 1.6;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* ───────────────────────── 模态弹窗 ────────────────────────────────── */
.content-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 3000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--duration-normal), visibility var(--duration-normal);
}

.content-modal-overlay.is-open {
    opacity: 1;
    visibility: visible;
}

.content-modal {
    background: var(--bg-glass-strong);
    backdrop-filter: var(--backdrop-blur);
    -webkit-backdrop-filter: var(--backdrop-blur);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-2);
    padding: 24px;
    width: 90%;
    max-width: 480px;
    max-height: 80vh;
    overflow-y: auto;
    box-shadow: var(--glow-halo);
}

.content-modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}

.content-modal-title {
    font-family: var(--font-mono);
    font-size: 14px;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: var(--text-primary);
    text-transform: uppercase;
}

.content-modal-close {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    color: var(--text-secondary);
    transition: all var(--duration-fast);
}

.content-modal-close:hover {
    background: var(--bg-surface-2);
    color: var(--text-primary);
}

/* ───────────────────────── 登录/注册表单 ───────────────────────────── */
.auth-form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.auth-form-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.auth-form-label {
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: 0.1em;
    color: var(--text-mono);
    text-transform: uppercase;
}

.auth-form-input {
    height: 40px;
    padding: 0 12px;
    background: var(--bg-surface);
    border: 1px solid var(--border-hairline);
    border-radius: var(--radius-0);
    color: var(--text-primary);
    font-family: var(--font-sans);
    font-size: var(--text-base);
    outline: none;
    transition: border-color var(--duration-fast);
}

.auth-form-input:focus {
    border-color: var(--border-active);
}

.auth-form-submit {
    height: 44px;
    background: var(--accent-ivory);
    color: #000;
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border-radius: var(--radius-1);
    cursor: pointer;
    transition: all var(--duration-fast);
    margin-top: 8px;
}

.auth-form-submit:hover {
    background: rgba(236, 233, 225, 0.88);
}

.auth-form-toggle {
    text-align: center;
    font-family: var(--font-sans);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}

.auth-form-toggle a {
    color: var(--accent-signal);
    cursor: pointer;
}

/* ───────────────────────── 响应式 ──────────────────────────────────── */
@media (max-width: 768px) {
    .spread-list-content,
    .master-list-content {
        padding: 16px;
        width: 95%;
    }

    .spread-cards-wrapper,
    .master-cards-wrapper {
        gap: 12px;
    }

    .spread-cards-wrapper,
    .master-cards-wrapper {
        grid-template-columns: 1fr;
    }

    .spread-card-info,
    .master-card-info {
        padding: 16px;
    }

    .master-card-name,
    .spread-card-name {
        font-size: 14px;
    }
    .reading-container{margin:0 4px;padding:16px 12px;max-height:calc(100dvh - 120px);gap:12px}
    .reading-question{font-size:var(--text-md)}
    .reading-interpretation{font-size:var(--text-sm);line-height:1.65}
    .reading-card-img{width:60px;height:96px}
    .reading-card-item{width:60px}
    .reading-card-item .card-name{max-width:60px;font-size:8px}
    .reading-btn-row .cta-button{font-size:10px;height:36px;padding:0 10px}
}

@media (max-width: 359px) {
    .brand-wordmark { display: none; }
    .brand-pill { padding-right: 6px; }
    .app-status-pill-button { padding: 0 9px; gap: 4px; }
    .status-suffix { display: none; }
}

/* ═══════════════════════════════════════════════════════════════════════
   Page System (replaces .section for multi-page)
   ═══════════════════════════════════════════════════════════════════════ */

.page{position:absolute;top:0;left:0;width:100%;height:100%;display:none;flex-direction:column;overflow-x:hidden;overflow-y:auto}
.page.active{display:flex;z-index:10}

/* ═══════════════════════════════════════════════════════════════════════
   Login Page Styles
   ═══════════════════════════════════════════════════════════════════════ */

.login-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;pointer-events:auto}
.login-card{width:90%;max-width:360px;padding:40px 30px;background:var(--bg-glass-strong);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--border-subtle);border-radius:var(--radius-3);text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;box-shadow:var(--glow-halo)}
.login-logo{width:100px;height:100px;object-fit:contain;margin-bottom:4px}
.login-logo.pulse-anim{animation:logoPulse 1.8s infinite ease-in-out}
@keyframes logoPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:0.85}}
.login-title{font-family:var(--font-mono);font-size:var(--text-lg);font-weight:500;letter-spacing:0.1em;color:var(--text-primary);text-transform:uppercase}
.login-tip{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-secondary);line-height:1.6}
.login-tip.error{color:var(--accent-warning)}
.login-sub{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);letter-spacing:0.04em}

/* ═══════════════════════════════════════════════════════════════════════
   Detail Page Styles (Quiet Console version)
   ═══════════════════════════════════════════════════════════════════════ */

.detail-container{display:flex;flex-direction:column;height:100%;overflow-y:auto;overflow-x:hidden;width:100%;background:#000;pointer-events:auto}
.detail-header-row{display:flex;align-items:center;gap:12px;padding:16px 16px 0;flex-shrink:0}
.back-btn{background:none;border:none;color:var(--accent-signal);font-family:var(--font-mono);font-size:var(--text-sm);cursor:pointer;padding:8px 0;letter-spacing:0.04em}
.detail-header-label{color:var(--text-mono);font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:0.08em;text-transform:uppercase}
.solution-group{background:var(--bg-glass);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--border-subtle);border-radius:var(--radius-2);display:block;margin-top:20px;padding:24px;width:100%}
.solution-group .solution-group-header{display:flex;justify-content:space-between;margin-bottom:12px}
.solution-group .solution-group-title{color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-sm);font-weight:500;letter-spacing:0.1em;text-transform:uppercase;flex:1}
.solution-item{width:100%;margin-bottom:20px}
.solution-item:last-child{margin-bottom:0}
.solution-item .solution-item-title{color:var(--text-primary);font-family:var(--font-sans);font-size:var(--text-base);font-weight:500;line-height:1.5}
.solution-item .solution-item-content{color:var(--text-secondary);font-family:var(--font-sans);font-size:var(--text-sm);line-height:1.7;margin-top:8px}

/* ── Detail Card Display ── */
.detail{padding:0 16px 16px}
.detail .tarot-detail-header{padding:16px 0 8px;width:100%;text-align:center}
.detail .tarot-detail-question{color:var(--text-primary);font-size:var(--text-md);font-weight:300;line-height:1.5;margin-bottom:6px}
.detail .tarot-detail-time{color:var(--text-faint);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:0.04em}
.detail .card-group{display:flex;flex-wrap:wrap;justify-content:center;margin:0 auto;padding-top:20px;width:100%;max-width:360px;gap:0}
.detail .card-group.center{justify-content:center}
.detail .card-group.column{flex-direction:column}
.detail .card-group-label{color:var(--text-mono);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:0.1em;text-transform:uppercase;margin-bottom:16px;text-align:center;width:100%;padding-top:4px}
.detail .card-item-list{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;width:100%}
.detail .card-item-list .card-item .card-item-inner{width:88px;height:138px}
.detail .card-item-list .card-item .card-item-img{height:138px;width:88px}
.detail .card-group .card-item-line{display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.detail .card-group .card-item-line.between{justify-content:space-between;gap:8px}
.detail .card-group .card-item-line:last-child{margin-bottom:0}
.detail .card-group .card-item-line .card-item .card-item-inner{width:72px;height:112px}
.detail .card-group .card-item-line .card-item .card-item-img{height:112px;width:72px}
.detail .card-group .card-item-line .card-item .card-item-desc{font-size:10px}

.detail .card-item .card-item-inner{position:relative;width:100px;height:156px;transform-style:preserve-3d;transition:transform 0.8s cubic-bezier(0.23,1,0.32,1)}
.detail .card-item .card-item-inner.flipped{transform:rotateY(180deg)}
.detail .card-item .card-item-front,.detail .card-item .card-item-back{position:absolute;top:0;left:0;width:100%;height:100%;backface-visibility:hidden;border-radius:8px;overflow:hidden;border:1px solid var(--border-hairline)}
.detail .card-item .card-item-front img,.detail .card-item .card-item-back img{width:100%;height:100%;object-fit:cover}
.detail .card-item .card-item-back{transform:rotateY(180deg)}
.detail .card-item .card-item-desc{color:var(--text-mono);font-family:var(--font-mono);font-size:var(--text-xs);letter-spacing:0.04em;margin-top:8px;text-align:center;line-height:1.4}
.detail .card-item .card-item-back.orientation img{transform:rotate(180deg)}

/* ── Detail Bottom Actions ── */
.detail-btn-group{display:flex;align-items:center;justify-content:space-between;margin:24px 16px calc(24px + env(safe-area-inset-bottom,0));position:relative;flex-shrink:0;gap:12px}
.detail-btn-group .cta-button{flex-shrink:0}
.detail-btn-group-controls{display:flex;align-items:center;gap:8px}
.share-btn,.save-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;width:44px;height:44px;cursor:pointer;gap:4px;border-radius:var(--radius-1);transition:background var(--duration-fast)}
.share-btn:active,.save-btn:active{background:rgba(255,255,255,0.06)}
.share-btn .share-btn-text,.save-btn .save-btn-text{color:var(--text-faint);font-family:var(--font-mono);font-size:9px;letter-spacing:0.04em}
.share-btn svg,.save-btn svg{color:var(--accent-signal);width:20px;height:20px}

/* ═══════════════════════════════════════════════════════════════════════
   Mine Page Styles (Quiet Console version)
   ═══════════════════════════════════════════════════════════════════════ */

.mine-container{flex:1;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;min-height:0;background:#000;padding-bottom:calc(20px + env(safe-area-inset-bottom,0));pointer-events:auto}
.page-top-bar{display:flex;align-items:center;padding:16px 20px 0;flex-shrink:0}
.page-top-bar .back-btn{background:none;border:none;color:var(--accent-signal);font-family:var(--font-mono);font-size:var(--text-sm);cursor:pointer;padding:8px 0;letter-spacing:0.04em}
.mine-header{position:relative;margin:20px 20px 0;padding:24px 20px 22px;background:var(--bg-glass);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--border-subtle);border-radius:var(--radius-3);display:flex;align-items:flex-start;gap:16px}
.mine-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent-signal),var(--accent-ivory));display:flex;align-items:center;justify-content:center;font-size:22px;color:#000;flex-shrink:0}
.mine-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.mine-info{flex:1;min-width:0}
.mine-nickname{color:var(--text-primary);font-size:var(--text-md);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}
.mine-sub{color:var(--text-faint);font-family:var(--font-mono);font-size:var(--text-xs);margin-top:4px}
.mine-badge{display:inline-block;margin-top:6px;padding:2px 10px;background:rgba(201,166,107,0.15);border:1px solid rgba(201,166,107,0.25);border-radius:var(--radius-full);color:var(--accent-signal);font-family:var(--font-mono);font-size:10px;font-weight:500}
.mine-stats{display:flex;gap:10px;margin:16px 20px 0}
.mine-stat-card{flex:1;background:var(--bg-glass);border:1px solid var(--border-hairline);border-radius:var(--radius-2);padding:16px 12px 14px;text-align:center}
.mine-stat-val{color:var(--text-primary);font-family:var(--font-mono);font-size:20px;font-weight:600;line-height:1}
.mine-stat-label{color:var(--text-faint);font-family:var(--font-mono);font-size:10px;margin-top:6px;letter-spacing:0.08em;text-transform:uppercase}
.mine-menu{padding:0 20px;margin-top:16px}
.mine-menu-item{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-glass);border:1px solid var(--border-hairline);border-radius:var(--radius-2);cursor:pointer;transition:all 0.2s}
.mine-menu-item:active{background:var(--bg-glass-strong);transform:scale(0.98)}
.mine-menu-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-1);background:rgba(201,166,107,0.1);color:var(--accent-signal);flex-shrink:0}
.mine-menu-text{flex:1;font-size:var(--text-base);color:var(--text-primary);font-weight:500}
.mine-menu-arrow{color:var(--text-faint);flex-shrink:0}
.mine-logout{padding:10px 20px 20px;margin-top:auto}
.mine-logout-btn{width:100%;padding:14px;border:1px solid var(--border-subtle);border-radius:var(--radius-2);background:transparent;color:var(--text-subtle);font-family:var(--font-mono);font-size:var(--text-sm);cursor:pointer;text-align:center}

/* ═══════════════════════════════════════════════════════════════════════
   Toast & Confirm Styles
   ═══════════════════════════════════════════════════════════════════════ */

.toast{position:fixed;left:50%;bottom:88px;z-index:500;max-width:calc(100vw - 40px);padding:10px 16px;border-radius:var(--radius-full);color:var(--text-primary);background:var(--bg-glass-strong);backdrop-filter:blur(18px);border:1px solid var(--border-subtle);font-size:var(--text-sm);opacity:0;transform:translate(-50%,10px);pointer-events:none;transition:opacity 0.2s,transform 0.2s}
.toast.show{opacity:1;transform:translate(-50%,0)}
.confirm-overlay{position:fixed;inset:0;z-index:400;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.5);backdrop-filter:blur(6px)}
.confirm-overlay.hidden{display:none}
.confirm-card{width:min(320px,90vw);background:var(--bg-glass-strong);border:1px solid var(--border-subtle);border-radius:var(--radius-3);padding:28px 24px 20px;text-align:center}
.confirm-title{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0 0 8px}
.confirm-desc{font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 20px;line-height:1.5}
.confirm-actions{display:flex;gap:10px}
.confirm-btn{flex:1;min-height:44px;border:1px solid var(--border-subtle);border-radius:var(--radius-2);font-family:var(--font-mono);font-size:var(--text-sm);cursor:pointer}
.confirm-btn.cancel{background:transparent;color:var(--text-primary)}
.confirm-btn.danger{background:var(--accent-warning);color:#fff;border-color:var(--accent-warning)}

/* ═══════════════════════════════════════════════════════════════════════
   Device Manager & Auth Modal Styles
   ═══════════════════════════════════════════════════════════════════════ */

.device-manager-container{padding:20px 16px;min-height:100%;pointer-events:auto}
.device-manager-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.device-manager-title{font-family:var(--font-mono);font-size:var(--text-md);font-weight:500;color:var(--text-primary);flex:1}
.device-manager-desc{color:var(--text-secondary);font-size:var(--text-sm);margin-bottom:20px;line-height:1.5}
.device-item{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-glass);border:1px solid var(--border-hairline);border-radius:var(--radius-2);margin-bottom:10px}
.device-self{border-color:rgba(201,166,107,0.35);background:rgba(201,166,107,0.08)}
.device-icon-wrap{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-1);background:rgba(255,255,255,0.08);color:var(--accent-signal);position:relative}
.device-dot{position:absolute;bottom:0;right:0;width:8px;height:8px;border-radius:50%;border:2px solid #000;background:var(--accent-success)}
.device-dot.offline{background:var(--text-faint)}
.device-info{flex:1;min-width:0}
.device-name{font-size:var(--text-base);color:var(--text-primary);font-weight:600}
.device-meta{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-subtle);margin-top:4px}
.device-badge{display:inline-flex;align-items:center;height:20px;padding:0 8px;border-radius:999px;font-family:var(--font-mono);font-size:10px;font-weight:600}
.device-badge.master{background:rgba(201,166,107,0.2);color:var(--accent-signal)}
.device-badge.current{background:rgba(138,166,122,0.15);color:var(--accent-success)}
.device-action-btn{background:rgba(255,255,255,0.1);border:1px solid var(--border-subtle);border-radius:var(--radius-0);color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-xs);padding:6px 12px;cursor:pointer}
.device-action-btn.danger{border-color:rgba(217,107,92,0.3);color:var(--accent-warning)}
.device-empty{text-align:center;color:var(--text-subtle);padding:40px 0}

/* ── Device Auth Modal ── */
.device-auth-overlay{position:fixed;inset:0;z-index:1100;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.7);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);animation:fadeIn 0.3s ease}
.device-auth-overlay.hidden{display:none}
.device-auth-card{width:min(100% - 40px,380px);background:var(--bg-glass-strong);backdrop-filter:var(--backdrop-blur);-webkit-backdrop-filter:var(--backdrop-blur);border:1px solid var(--border-subtle);border-radius:var(--radius-3);padding:36px 28px;text-align:center;box-shadow:0 0 80px rgba(0,0,0,0.5),0 0 40px rgba(201,166,107,0.04);animation:slideUp 0.4s var(--ease-out)}
.da-icon-wrap{width:72px;height:72px;margin:0 auto 20px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;background:rgba(201,166,107,0.06)}
.da-icon-wrap::before{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid transparent;border-top-color:var(--accent-signal);border-right-color:rgba(201,166,107,0.2);animation:spin 1.2s linear infinite}
.da-icon-wrap svg{position:relative;z-index:1;width:32px;height:32px;color:var(--accent-signal)}
.da-icon-wrap.success{background:rgba(138,166,122,0.08)}
.da-icon-wrap.success::before{border-top-color:var(--accent-success);border-right-color:rgba(138,166,122,0.2)}
.da-icon-wrap.success svg{color:var(--accent-success)}
.da-icon-wrap.danger{background:rgba(217,107,92,0.06)}
.da-icon-wrap.danger::before{border-top-color:var(--accent-warning);border-right-color:rgba(217,107,92,0.2);animation:none}
.da-icon-wrap.danger svg{color:var(--accent-warning)}
@keyframes spin{to{transform:rotate(360deg)}}
.da-title{font-family:var(--font-sans);font-size:var(--text-lg);font-weight:600;color:var(--text-primary);margin:0 0 8px;line-height:1.3}
.da-message{font-family:var(--font-sans);font-size:var(--text-sm);color:var(--text-secondary);margin:0 0 20px;line-height:1.6}
.da-device-name{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-surface-2);border:1px solid var(--border-hairline);border-radius:var(--radius-full);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-mono);letter-spacing:0.04em;margin-bottom:16px}
.da-device-name i{color:var(--accent-signal);font-size:11px}
.da-countdown-wrap{margin:12px 0 4px}
.da-countdown{font-family:var(--font-mono);font-size:36px;font-weight:600;color:var(--accent-signal);letter-spacing:0.08em;font-variant-numeric:tabular-nums;text-shadow:0 0 24px rgba(201,166,107,0.15)}
.da-countdown-label{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-faint);letter-spacing:0.06em;margin-top:6px}
.da-actions{display:flex;gap:10px;justify-content:center;margin-top:24px}
.da-btn{min-height:44px;border:none;border-radius:var(--radius-full);font-family:var(--font-mono);font-size:var(--text-xs);font-weight:500;letter-spacing:0.1em;text-transform:uppercase;padding:0 24px;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:inline-flex;align-items:center;gap:6px;touch-action:manipulation}
.da-btn:active{transform:scale(0.97)}
.da-btn-primary{background:var(--accent-ivory);color:#000}
.da-btn-primary:hover{background:rgba(236,233,225,0.88);box-shadow:var(--glow-halo)}
.da-btn-danger{background:transparent;color:var(--accent-warning);border:1px solid rgba(217,107,92,0.25)}
.da-btn-danger:hover{background:rgba(217,107,92,0.08);border-color:var(--accent-warning)}
.da-btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-subtle)}
.da-btn-secondary:hover{border-color:var(--border-active);color:var(--text-primary)}

/* ═══════════════════════════════════════════════════════════════════════
   Profile Popup Styles
   ═══════════════════════════════════════════════════════════════════════ */

.profile-popup-overlay{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,0.75);display:flex;align-items:center;justify-content:center}
.profile-popup-overlay.hidden{display:none}
.profile-popup-card{background:linear-gradient(180deg,rgba(22,20,27,0.98),rgba(9,10,13,0.99));border:1px solid rgba(236,233,225,0.10);border-radius:20px;padding:36px 28px 28px;width:calc(100vw - 48px);max-width:368px;display:flex;flex-direction:column;align-items:center;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.profile-popup-title{font-family:var(--font-mono);font-size:var(--text-md);font-weight:500;letter-spacing:0.1em;color:var(--text-primary);text-transform:uppercase}
.profile-popup-desc{color:var(--text-secondary);font-size:var(--text-sm);margin-top:8px;margin-bottom:24px}
.profile-popup-name{width:100%;margin-bottom:22px}
.profile-popup-name-title{color:var(--text-mono);font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:8px}
.profile-popup-name-input-wrap{display:flex;align-items:stretch;border:1px solid rgba(236,233,225,0.10);border-radius:var(--radius-2);overflow:hidden;background:rgba(255,255,255,0.03);transition:border-color var(--duration-fast) var(--ease-out)}
.profile-popup-name-input-wrap:focus-within{border-color:var(--accent-signal);background:rgba(201,166,107,0.06)}
.profile-popup-name-at{display:flex;align-items:center;justify-content:center;width:44px;flex-shrink:0;font-family:var(--font-mono);font-size:var(--text-md);color:var(--accent-signal);font-weight:500;border-right:1px solid rgba(236,233,225,0.08)}
.profile-popup-name-input{flex:1;height:48px;padding:0 16px 0 0;border:none;border-radius:0;background:transparent;color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-lg);font-weight:500;letter-spacing:0.18em;text-align:center;outline:none}
.profile-popup-name-input::placeholder{color:var(--text-faint);font-weight:400;letter-spacing:0.12em}
.profile-popup-name-tip{margin-top:7px;color:var(--text-faint);font-size:11px;text-align:center}
.profile-popup-birth{width:100%}
.profile-popup-birth-title{color:var(--text-mono);font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:8px}
.profile-popup-date-input{width:100%;height:48px;padding:0 16px;border:1px solid rgba(236,233,225,0.10);border-radius:var(--radius-2);background:rgba(255,255,255,0.03);color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-base);letter-spacing:0.08em;text-align:center;outline:none;transition:border-color var(--duration-fast) var(--ease-out);-webkit-appearance:none;color-scheme:dark}
.profile-popup-date-input:focus{border-color:var(--accent-signal);background:rgba(201,166,107,0.06)}
.profile-popup-date-input::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer;opacity:0.85}
.profile-popup-date-input::-webkit-datetime-edit-fields-wrapper{padding:0}
.profile-popup-sex{width:100%;margin-top:20px}
.profile-popup-sex-title{color:var(--text-mono);font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:8px}
.sex-container{display:flex;align-items:center;margin-top:12px}
.sex-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:var(--radius-1);height:60px;width:78px;cursor:pointer;border:1px solid var(--border-hairline);color:var(--text-secondary)}
.sex-wrapper:not(:last-child){margin-right:24px}
.sex-wrapper.selected{background:rgba(201,166,107,0.1);border-color:var(--accent-signal);color:var(--accent-signal)}
.profile-popup-btn{width:100%;height:48px;background:var(--accent-ivory);color:#000;border:none;border-radius:var(--radius-2);font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;cursor:pointer;margin-top:28px;transition:opacity var(--duration-fast) var(--ease-out)}
.profile-popup-btn:active{opacity:0.85;transform:scale(0.98)}
.profile-popup-skip{width:100%;height:40px;background:transparent;color:var(--text-subtle);border:none;font-size:var(--text-sm);cursor:pointer;margin-top:8px}

/* ═══════════════════════════════════════════════════════════════════════
   Share Panel Styles
   ═══════════════════════════════════════════════════════════════════════ */

.share-panel{position:fixed;inset:0;z-index:300;display:flex;align-items:flex-end;justify-content:center;padding-top:24px}
.share-panel.hidden{display:none}
.share-panel-overlay{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(10px)}
.share-panel-card{position:relative;width:min(100%,520px);max-height:calc(100dvh - 24px);overflow:auto;overscroll-behavior:contain;background:linear-gradient(180deg,rgba(22,20,27,.98),rgba(9,10,13,.99));border:1px solid rgba(236,233,225,.12);border-bottom:0;border-radius:24px 24px 0 0;padding:22px 20px calc(22px + env(safe-area-inset-bottom));box-shadow:0 -26px 80px rgba(0,0,0,.55)}
.share-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:17px}
.share-panel-kicker{font:600 10px/1 var(--font-mono);letter-spacing:.18em;color:var(--accent-signal);margin-bottom:8px}
.share-panel-title{font-size:20px;line-height:1.2;font-weight:520;color:var(--text-primary)}
.share-panel-close{display:grid;place-items:center;width:36px;height:36px;flex:0 0 36px;border:1px solid var(--border-subtle);border-radius:50%;background:rgba(255,255,255,.03);color:var(--text-secondary);font-size:24px;line-height:1;cursor:pointer}
.share-poster-wrap{position:relative;width:min(100%,310px);aspect-ratio:4/5;margin:0 auto 14px;border:1px solid rgba(236,233,225,.13);border-radius:15px;overflow:hidden;background:#07080b;box-shadow:0 18px 42px rgba(0,0,0,.38)}
.share-poster-preview{display:block;width:100%;height:100%;object-fit:cover;-webkit-touch-callout:default;user-select:auto}
.share-poster-wrap.is-empty .share-poster-preview{visibility:hidden}
.share-poster-loading{position:absolute;inset:0;display:none;align-items:center;justify-content:center;gap:7px;color:var(--text-faint)}
.share-panel.is-loading .share-poster-loading,.share-poster-wrap.is-empty .share-poster-loading{display:flex}
.share-poster-loading span{width:5px;height:5px;border-radius:50%;background:var(--accent-signal);animation:sharePulse 1.1s infinite}
.share-poster-loading span:nth-child(2){animation-delay:.16s}.share-poster-loading span:nth-child(3){animation-delay:.32s}
.share-poster-loading small{position:absolute;top:calc(50% + 22px);font:500 9px/1 var(--font-mono);letter-spacing:.14em}
@keyframes sharePulse{0%,70%,100%{opacity:.25;transform:translateY(0)}35%{opacity:1;transform:translateY(-5px)}}
.share-status{min-height:20px;margin:0 2px 10px;color:var(--text-faint);font-size:11px;line-height:1.55;text-align:center}
.share-qr-card{display:flex;align-items:center;gap:12px;margin:0 0 12px;padding:12px;border:1px solid rgba(201,166,107,.22);border-radius:15px;background:rgba(201,166,107,.07)}
.share-qr-card.hidden{display:none}
.share-qr-image{width:116px;height:116px;flex:0 0 116px;padding:8px;border-radius:12px;background:#fff;image-rendering:pixelated}
.share-qr-copy{min-width:0;text-align:left}
.share-qr-title{margin-bottom:7px;color:var(--text-primary);font-size:13px;font-weight:560}
.share-qr-desc{color:var(--text-faint);font-size:11px;line-height:1.6}
.share-link-row{display:flex;gap:8px;margin-bottom:16px}
.share-url-input{min-width:0;flex:1;height:42px;border:1px solid var(--border-subtle);border-radius:11px;background:rgba(255,255,255,.035);padding:0 13px;color:var(--text-secondary);font:400 11px/1 var(--font-mono);outline:none}
.share-url-input:focus{border-color:rgba(201,166,107,.5)}
.share-link-copy{height:42px;flex:0 0 62px;border:1px solid rgba(201,166,107,.38);border-radius:11px;background:rgba(201,166,107,.1);color:var(--accent-signal);font-size:12px;cursor:pointer}
.share-panel-options{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:13px}
.share-option{appearance:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-width:0;min-height:88px;padding:10px 4px;border:1px solid var(--border-subtle);border-radius:14px;background:rgba(255,255,255,.025);cursor:pointer}
.share-option:active{background:rgba(255,255,255,.07)}
.share-option:disabled,.share-link-copy:disabled{opacity:.36;cursor:wait}
.share-option-icon{width:34px;height:34px;border-radius:11px;display:flex;align-items:center;justify-content:center}
.share-option-icon.native{background:rgba(201,166,107,.13);color:var(--accent-signal)}
.share-option-icon.save{background:rgba(123,158,186,.13);color:#a9c6dd}
.share-option-icon.revoke{background:rgba(204,104,94,.12);color:#d9857c}
.share-option-label{font-size:11px;color:var(--text-secondary);white-space:nowrap}
.share-privacy-note{padding-top:12px;border-top:1px solid rgba(236,233,225,.08);color:var(--text-faint);font-size:10px;line-height:1.6;text-align:center}
body.share-open{overflow:hidden}
@media(min-width:700px){.share-panel{align-items:center;padding:24px}.share-panel-card{border-bottom:1px solid rgba(236,233,225,.12);border-radius:24px;max-height:calc(100dvh - 48px)}}
@media(max-height:760px){.share-poster-wrap{width:220px}.share-panel-card{padding-top:16px}.share-panel-head{margin-bottom:12px}}

/* ═══════════════════════════════════════════════════════════════════════
   History List Styles
   ═══════════════════════════════════════════════════════════════════════ */

.history-list-container{flex:1;display:flex;flex-direction:column;overflow-y:auto;pointer-events:auto}
.history-list-header{display:flex;align-items:center;gap:12px;padding:20px 20px 16px;flex-shrink:0}
.history-list-title{color:var(--text-primary);font-family:var(--font-mono);font-size:var(--text-md);font-weight:500}
.history-list-content{flex:1;padding:0 16px 24px}
.mine-history-item{background:var(--bg-glass);border:1px solid var(--border-hairline);border-radius:var(--radius-2);padding:16px;margin-bottom:10px;cursor:pointer}
.mine-history-item .mhi-q{color:var(--text-primary);font-size:var(--text-base);font-weight:500;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mine-history-item .mhi-row{display:flex;align-items:center;justify-content:space-between;margin-top:10px}
.mine-history-item .mhi-time{color:var(--text-faint);font-family:var(--font-mono);font-size:10px}
.mine-history-item .mhi-tag{font-family:var(--font-mono);font-size:10px;padding:2px 8px;background:rgba(201,166,107,0.1);border-radius:var(--radius-full);color:var(--accent-signal)}
.mine-history-item .mhi-reply{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.5;margin-top:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.mine-empty{text-align:center;padding:48px 20px}
.mine-empty-text{color:var(--text-subtle);font-size:var(--text-base)}
.mine-meta-row{display:flex;gap:8px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border-hairline)}
.mine-meta-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:rgba(255,255,255,0.04);border:1px solid var(--border-hairline);border-radius:var(--radius-full);color:var(--text-subtle);font-family:var(--font-mono);font-size:10px;cursor:pointer}
.mine-menu-badge{color:var(--text-faint);font-family:var(--font-mono);font-size:var(--text-xs);flex-shrink:0;margin-right:4px}
.mine-recent-preview{display:flex;flex-direction:column;padding:0 20px}
.mine-recent-item{padding:10px 12px;border-bottom:1px solid var(--border-hairline);cursor:pointer}
.mine-recent-item:last-child{border-bottom:0}
.mine-recent-q{color:var(--text-primary);font-size:var(--text-sm);line-height:1.4;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}
.mine-recent-time{color:var(--text-faint);font-family:var(--font-mono);font-size:10px;margin-top:4px}
