.personal-page-overlay { position: fixed; inset: 0; background: rgba(33, 24, 14, 0.55); backdrop-filter: blur(12px); display: flex; align-items: center; justify-content: center; z-index: 400; padding: 20px; transition: opacity 0.25s ease, backdrop-filter 0.25s ease; will-change: opacity, backdrop-filter; } .personal-page-card { width: min(95vw, 860px); background: #fffaf4; border-radius: 24px; border: 1px solid rgba(118, 103, 84, 0.25); box-shadow: 0 28px 60px rgba(38, 28, 18, 0.25); padding: 40px; text-align: left; color: var(--claude-text); max-height: calc(100vh - 40px); overflow: hidden; } .personal-page-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 24px; } .personal-page-actions { display: flex; gap: 10px; align-items: flex-start; } .personal-page-header h2 { font-size: 24px; margin: 0; } .personal-page-header p { margin: 6px 0 0; color: var(--claude-text-secondary); font-size: 14px; } .personal-page-close { align-self: flex-start; padding: 8px 18px; border-radius: 999px; border: none; background: linear-gradient(135deg, var(--claude-accent) 0%, var(--claude-accent-strong) 100%); color: #fffdf8; font-size: 13px; font-weight: 600; cursor: pointer; box-shadow: 0 14px 28px rgba(189, 93, 58, 0.2); transition: transform 0.2s ease, box-shadow 0.2s ease; } .personal-page-close:hover { transform: translateY(-1px); box-shadow: 0 18px 34px rgba(189, 93, 58, 0.3); } .personal-page-logout { align-self: flex-start; padding: 8px 16px; border-radius: 999px; border: 1px solid rgba(118, 103, 84, 0.35); background: rgba(255, 255, 255, 0.92); color: var(--claude-text); font-size: 13px; font-weight: 600; cursor: pointer; transition: background 0.2s ease, box-shadow 0.2s ease; } .personal-page-logout:hover { background: #fff; box-shadow: 0 12px 24px rgba(38, 28, 18, 0.12); } .personalization-body { display: flex; flex-direction: column; gap: 20px; overflow-y: auto; max-height: calc(100vh - 180px); padding-right: 6px; scrollbar-width: none; -ms-overflow-style: none; } .personalization-body::-webkit-scrollbar { display: none; } .personal-toggle { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 16px 18px; border-radius: 16px; background: rgba(255, 255, 255, 0.85); border: 1px solid rgba(118, 103, 84, 0.2); } .toggle-text { display: flex; flex-direction: column; gap: 6px; } .toggle-title { font-weight: 600; } .toggle-desc { color: var(--claude-text-secondary); font-size: 13px; } .toggle-switch { position: relative; width: 46px; height: 26px; } .toggle-switch input { opacity: 0; width: 0; height: 0; } .switch-slider { position: absolute; inset: 0; background-color: #d7d1c5; border-radius: 30px; transition: background-color 0.2s ease; } .switch-slider::before { content: ""; position: absolute; left: 4px; top: 4px; width: 18px; height: 18px; border-radius: 50%; background: #fff; transition: transform 0.2s ease; } .toggle-switch input:checked + .switch-slider { background: var(--claude-accent); } .toggle-switch input:checked + .switch-slider::before { transform: translateX(20px); } /* ========================================= */ /* 移动端面板入口 */ /* ========================================= */ .mobile-panel-trigger { position: fixed; top: 16px; left: 16px; z-index: 1500; display: flex; flex-direction: column; align-items: flex-start; gap: 10px; pointer-events: none; opacity: 1; transition: opacity 0.2s ease; } .mobile-panel-trigger.is-hidden { opacity: 0; } .mobile-panel-fab { width: 48px; height: 48px; border: none; padding: 6px; border-radius: 12px; background: transparent; color: var(--claude-accent); cursor: pointer; pointer-events: auto; display: flex; align-items: center; justify-content: center; box-shadow: none; } .mobile-panel-fab img { width: 32px; height: 32px; } .mobile-panel-menu { pointer-events: auto; display: grid; grid-auto-flow: column; gap: 8px; padding: 8px 10px; border-radius: 999px; background: rgba(255, 255, 255, 0.35); backdrop-filter: blur(10px); box-shadow: 0 12px 30px rgba(38, 28, 18, 0.15); } .mobile-menu-btn { width: 44px; height: 44px; border-radius: 50%; border: none; background: transparent; color: var(--claude-text); display: flex; align-items: center; justify-content: center; cursor: pointer; } .mobile-menu-btn img, .mobile-menu-svg { width: 26px; height: 26px; display: block; } .mobile-menu-btn--conversation .mobile-menu-svg { width: 30px; height: 30px; transition: color 0.2s ease; } .mobile-panel-menu-enter-active, .mobile-panel-menu-leave-active { transition: opacity 0.2s ease, transform 0.2s ease; } .mobile-panel-menu-enter-from, .mobile-panel-menu-leave-to { opacity: 0; transform: translateY(-8px) scale(0.95); } /* ========================================= */ /* 移动端半覆盖面板 */ /* ========================================= */ .mobile-panel-overlay { position: fixed; inset: 0; background: rgba(16, 11, 7, 0.45); backdrop-filter: blur(6px); z-index: 1400; display: flex; align-items: stretch; padding: 0; } .mobile-panel-overlay--left { justify-content: flex-start; } .mobile-panel-overlay--right { justify-content: flex-end; } .mobile-panel-sheet { width: 100%; height: 100%; background: var(--claude-left-rail); border-radius: 0; box-shadow: none; padding: 0; position: relative; overflow: hidden; display: flex; flex-direction: column; } .mobile-panel-sheet--conversation, .mobile-panel-sheet--workspace { background: var(--claude-left-rail); } .mobile-panel-sheet--focus { background: var(--claude-panel); } .mobile-overlay-close { position: absolute; top: 10px; right: 10px; width: 32px; height: 32px; border-radius: 16px; border: none; background: rgba(0, 0, 0, 0.08); color: var(--claude-text); font-size: 18px; cursor: pointer; z-index: 5; } .mobile-overlay-content { margin-top: 0; flex: 1; width: 100%; height: 100%; overflow: hidden; } .mobile-panel-sheet .conversation-sidebar, .mobile-panel-sheet .sidebar, .mobile-panel-sheet .right-sidebar { width: 100% !important; max-width: 100%; min-width: 0; height: 100%; border: none; border-radius: 0; } .mobile-panel-sheet .conversation-sidebar { height: 100%; } @media (max-width: 768px) { .mobile-panel-sheet .left-sidebar, .mobile-panel-sheet .right-sidebar { display: flex !important; flex-direction: column; } .mobile-panel-sheet .conversation-sidebar { position: relative; transform: none !important; box-shadow: none; } .mobile-panel-sheet .conversation-sidebar.collapsed { transform: none !important; } .mobile-panel-sheet .sidebar-header { position: static; border: none; padding: 12px 16px 0; } .mobile-panel-sheet .focused-files { padding-top: 8px; } } .mobile-panel-overlay-enter-active, .mobile-panel-overlay-leave-active { transition: opacity 0.25s ease; } .mobile-panel-overlay-enter-from, .mobile-panel-overlay-leave-to { opacity: 0; } .mobile-panel-overlay .mobile-panel-sheet { transform: translateX(0); transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1); } .mobile-panel-overlay--left.mobile-panel-overlay-enter-from .mobile-panel-sheet, .mobile-panel-overlay--left.mobile-panel-overlay-leave-to .mobile-panel-sheet { transform: translateX(-28px); } .mobile-panel-overlay--right.mobile-panel-overlay-enter-from .mobile-panel-sheet, .mobile-panel-overlay--right.mobile-panel-overlay-leave-to .mobile-panel-sheet { transform: translateX(28px); } .confirm-overlay { position: fixed; inset: 0; background: rgba(33, 24, 14, 0.5); backdrop-filter: blur(12px); display: flex; align-items: center; justify-content: center; padding: 20px; z-index: 2200; transition: opacity 0.25s ease, backdrop-filter 0.25s ease; will-change: opacity, backdrop-filter; } .confirm-modal { width: min(360px, 100%); background: var(--claude-bg); border: 1px solid var(--claude-border-strong, rgba(118,103,84,0.35)); border-radius: 18px; padding: 24px; box-shadow: 0 18px 40px rgba(61, 57, 41, 0.22); transition: transform 0.25s ease, opacity 0.25s ease; } .confirm-title { font-size: 16px; font-weight: 600; margin-bottom: 12px; } .confirm-message { font-size: 14px; color: var(--claude-text-secondary); } .confirm-actions { display: flex; justify-content: flex-end; gap: 12px; margin-top: 24px; } .confirm-button { border: 1px solid var(--claude-border-strong, rgba(118,103,84,0.35)); background: transparent; color: var(--claude-text); border-radius: 10px; padding: 8px 20px; font-weight: 500; cursor: pointer; } .confirm-button--primary { background: var(--claude-accent); border-color: var(--claude-accent-strong); color: #fff; } .confirm-dialog-fade-enter-active, .confirm-dialog-fade-leave-active { transition: opacity 0.25s ease, backdrop-filter 0.25s ease; } .confirm-dialog-fade-enter-from, .confirm-dialog-fade-leave-to { opacity: 0; backdrop-filter: blur(0px); } .confirm-dialog-fade-enter-active .confirm-modal, .confirm-dialog-fade-leave-active .confirm-modal { transition: transform 0.25s ease, opacity 0.25s ease; } .confirm-dialog-fade-enter-from .confirm-modal, .confirm-dialog-fade-leave-to .confirm-modal { transform: translateY(18px) scale(0.97); opacity: 0; } .personal-form { display: flex; flex-direction: column; gap: 18px; flex: 1; } .personalization-sections { display: flex; gap: 18px; align-items: flex-start; flex-wrap: nowrap; } .personal-section { flex: 1 1 0; min-width: 240px; background: rgba(255, 255, 255, 0.9); border: 1px solid rgba(118, 103, 84, 0.25); border-radius: 18px; padding: 16px 18px; display: flex; flex-direction: column; gap: 16px; } .personal-right-column { display: flex; flex-direction: column; gap: 14px; flex: 1 1 0; max-width: none; align-self: stretch; } .personal-right-column .personal-section { flex: 1 1 auto; } .personal-section.personal-considerations .personal-field { flex: 1; display: flex; flex-direction: column; } .personal-section.personal-considerations .consideration-list { max-height: 260px; min-height: 220px; flex: 1; overflow-y: auto; scrollbar-width: none; -ms-overflow-style: none; } .personal-section.personal-considerations .consideration-list::-webkit-scrollbar { display: none; } .personal-section.personal-considerations .consideration-item { background: rgba(255, 255, 255, 0.95); } @media (max-width: 1024px) { .personalization-sections { flex-direction: column; flex-wrap: wrap; } .personal-right-column { width: 100%; max-width: none; } } .personal-field { display: flex; flex-direction: column; gap: 10px; font-size: 14px; } .personal-field input { width: 100%; padding: 10px 14px; border-radius: 12px; border: 1px solid rgba(118, 103, 84, 0.4); background: rgba(255, 255, 255, 0.9); font-size: 14px; } .personal-field input:focus { outline: 2px solid rgba(189, 93, 58, 0.35); border-color: rgba(189, 93, 58, 0.6); } .tone-preset-row { display: flex; align-items: center; flex-wrap: wrap; gap: 10px; font-size: 13px; color: var(--claude-text-secondary); } .tone-preset-buttons { display: flex; flex-wrap: wrap; gap: 6px; } .tone-preset-buttons button { padding: 4px 10px; border-radius: 999px; border: 1px solid rgba(118, 103, 84, 0.4); background: #fff; font-size: 13px; cursor: pointer; } .tone-preset-buttons button:hover { border-color: var(--claude-accent); color: var(--claude-accent); } .consideration-input { display: flex; gap: 8px; align-items: center; } .consideration-input input { flex: 1; } .consideration-add { width: 38px; height: 38px; border-radius: 12px; border: none; background: var(--claude-accent); color: #fffdf8; font-size: 20px; font-weight: 600; cursor: pointer; } .consideration-add:disabled { opacity: 0.4; cursor: not-allowed; } .consideration-list { list-style: none; margin: 6px 0 0; padding: 0; display: flex; flex-direction: column; gap: 8px; } .consideration-item { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-radius: 12px; border: 1px dashed rgba(118, 103, 84, 0.5); background: rgba(255, 255, 255, 0.9); cursor: grab; } .drag-handle { font-size: 16px; color: var(--claude-text-secondary); } .consideration-text { flex: 1; font-size: 14px; color: var(--claude-text); } .consideration-remove { border: none; background: none; font-size: 18px; line-height: 1; cursor: pointer; color: #d64545; padding: 0 4px; } .consideration-hint, .consideration-limit { font-size: 13px; color: var(--claude-text-secondary); } .personal-form-actions { display: flex; align-items: center; gap: 8px; margin-top: auto; padding: 12px 0 0; justify-content: flex-end; } .personal-status-group { flex: 0 0 auto; display: flex; align-items: center; gap: 4px; min-height: 22px; } .personal-form-actions .primary { padding: 10px 20px; border: none; border-radius: 999px; background: linear-gradient(135deg, var(--claude-accent) 0%, var(--claude-accent-strong) 100%); color: #fff; font-weight: 600; cursor: pointer; } .personal-form-actions .primary:disabled { opacity: 0.6; cursor: not-allowed; } .personal-form-actions .status { font-size: 13px; } .personal-form-actions .status.success { color: #0f9d58; } .personal-form-actions .status.error { color: #d64545; } .personal-status-fade-enter-active, .personal-status-fade-leave-active { transition: opacity 0.25s ease; } .personal-status-fade-enter-from, .personal-status-fade-leave-to { opacity: 0; } .personalization-loading { padding: 32px 0; text-align: center; color: var(--claude-text-secondary); font-size: 14px; } .personal-page-fade-enter-active, .personal-page-fade-leave-active { transition: opacity 0.25s ease, backdrop-filter 0.25s ease; } .personal-page-fade-enter-from, .personal-page-fade-leave-to { opacity: 0; backdrop-filter: blur(0); } .personal-page-overlay.personal-page-fade-enter-active .personal-page-card, .personal-page-overlay.personal-page-fade-leave-active .personal-page-card { transition: transform 0.25s ease, opacity 0.25s ease; } .personal-page-overlay.personal-page-fade-enter-from .personal-page-card, .personal-page-overlay.personal-page-fade-leave-to .personal-page-card { transform: translateY(18px) scale(0.985); opacity: 0; } /* 彩蛋灌水特效 */ .easter-egg-overlay { position: fixed; inset: 0; pointer-events: none; display: flex; align-items: flex-end; justify-content: center; opacity: 0; transition: opacity 0.6s ease; z-index: 80; } .easter-egg-overlay.active { opacity: 1; } .panel-card { border-left: 1px solid var(--claude-border); padding: 0 0 0 0; } .app-loading-state { min-height: calc(var(--app-viewport, 100vh) - 160px); padding: 60px 20px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 28px; text-align: center; color: var(--claude-text); } .loading-animation { display: flex; align-items: center; justify-content: center; } .loading-copy { margin-top: 48px; } .loading-copy h2 { margin: 0; font-size: 24px; font-weight: 600; } .loading-copy p { margin: 6px 0 0; color: var(--claude-text-secondary); } .boxes { --size: 34px; --duration: 900ms; --box-primary: var(--claude-accent); --box-secondary: var(--claude-accent-strong, #d07b4c); --box-tertiary: #f8d7c0; height: calc(var(--size) * 2); width: calc(var(--size) * 3); position: relative; transform-style: preserve-3d; transform-origin: 50% 50%; margin-top: calc(var(--size) * -1.5); transform: rotateX(60deg) rotateZ(45deg) rotateY(0deg) translateZ(0px); } .boxes .box { width: var(--size); height: var(--size); top: 0; left: 0; position: absolute; transform-style: preserve-3d; } .boxes .box:nth-child(1) { transform: translate(100%, 0); animation: box1 var(--duration) linear infinite; } .boxes .box:nth-child(2) { transform: translate(0, 100%); animation: box2 var(--duration) linear infinite; } .boxes .box:nth-child(3) { transform: translate(100%, 100%); animation: box3 var(--duration) linear infinite; } .boxes .box:nth-child(4) { transform: translate(200%, 0); animation: box4 var(--duration) linear infinite; } .boxes .box > div { --background: var(--box-primary); --top: auto; --right: auto; --bottom: auto; --left: auto; --translateZ: calc(var(--size) / 2); --rotateY: 0deg; --rotateX: 0deg; position: absolute; width: 100%; height: 100%; background: var(--background); top: var(--top); right: var(--right); bottom: var(--bottom); left: var(--left); border-radius: 6px; transform: rotateY(var(--rotateY)) rotateX(var(--rotateX)) translateZ(var(--translateZ)); } .boxes .box > div:nth-child(1) { --top: 0; --left: 0; } .boxes .box > div:nth-child(2) { --background: var(--box-secondary); --right: 0; --rotateY: 90deg; } .boxes .box > div:nth-child(3) { --background: var(--box-tertiary); --rotateX: -90deg; } .boxes .box > div:nth-child(4) { --background: rgba(255, 255, 255, 0.95); --top: 0; --left: 0; --translateZ: calc(var(--size) * 3 * -1); } @keyframes box1 { 0%, 50% { transform: translate(100%, 0); } 100% { transform: translate(200%, 0); } } @keyframes box2 { 0% { transform: translate(0, 100%); } 50% { transform: translate(0, 0); } 100% { transform: translate(100%, 0); } } @keyframes box3 { 0%, 50% { transform: translate(100%, 100%); } 100% { transform: translate(0, 100%); } } @keyframes box4 { 0% { transform: translate(200%, 0); } 50% { transform: translate(200%, 100%); } 100% { transform: translate(100%, 100%); } }