.seo-hidden-content{opacity:0;width:1px;height:1px;position:absolute;top:-9999px;left:-9999px;overflow:hidden}.app-grid-shell{width:100%}.app-loading{z-index:1000;background-color:var(--theme-bg-page);width:100vw;height:100vh;color:var(--ui-text-tertiary);box-sizing:border-box;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0;overflow:hidden}.app-loading.is-exiting{animation:.28s forwards loadingScreenFadeOut}.loading-backdrop{filter:blur(2px);background:radial-gradient(circle at 18% 22%,#ffc3002e,#0000 55%),radial-gradient(circle at 80% 76%,#ff814224,#0000 52%),linear-gradient(135deg,#fffdf5 0%,#fff8e5 45%,#fffdf8 100%);animation:7s ease-in-out infinite loadingBackdropFloat;position:absolute;inset:-20%}.loading-panel{-webkit-backdrop-filter:blur(10px);background:#ffffffd1;border:1px solid #ffc3003d;border-radius:24px;width:min(460px,100vw - 40px);padding:24px 22px;animation:.52s cubic-bezier(.22,1,.36,1) both loadingPanelIn;position:relative;box-shadow:0 24px 60px #8b451324}.loading-kicker{letter-spacing:.12em;text-transform:uppercase;color:#8b4513b8;margin:0;font-size:.78rem;font-weight:600}.loading-title{color:var(--ui-text-primary);margin:8px 0 12px;font-size:clamp(1.4rem,3.5vw,1.85rem);line-height:1.2}.loading-progress{background:#ffc30024;border-radius:999px;width:100%;height:9px;position:relative;overflow:hidden}.loading-progress-bar{border-radius:inherit;background:linear-gradient(90deg,#ffc300 0%,#ffb000 55%,#ff8f3f 100%);width:40%;height:100%;animation:1.3s ease-in-out infinite loadingProgressSweep;display:block;box-shadow:0 0 18px #ffa60073}.loading-subtitle{color:var(--ui-text-secondary);margin:12px 0 0;font-size:.92rem}.loading-tip{color:var(--ui-text-tertiary);min-height:1.2em;margin:12px 0 0;font-size:.84rem;line-height:1.4}.loading-tip-text{color:#8b4513db;animation:.22s ease-out loadingTipReveal;display:inline-block}.loading-dots:after{content:"...";text-align:left;width:1.1em;animation:1.15s steps(4,end) infinite loadingDots;display:inline-block}@keyframes loadingBackdropFloat{0%,to{transform:translate(0,0)scale(1)}50%{transform:translate(-2%,-2%)scale(1.04)}}@keyframes loadingPanelIn{0%{opacity:0;transform:translateY(14px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes loadingProgressSweep{0%{transform:translate(-130%)}50%{transform:translate(95%)}to{transform:translate(235%)}}@keyframes loadingDots{0%{clip-path:inset(0 100% 0 0)}25%{clip-path:inset(0 66% 0 0)}50%{clip-path:inset(0 33% 0 0)}75%,to{clip-path:inset(0)}}@keyframes loadingTipReveal{0%{opacity:0;transform:translateY(2px)}to{opacity:1;transform:translateY(0)}}@keyframes loadingScreenFadeOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.01)}}@media (width<=640px){.app-loading{padding:16px}.loading-panel{border-radius:20px;padding:20px 16px}}@media (prefers-reduced-motion:reduce){.loading-backdrop,.loading-panel,.loading-progress-bar,.loading-dots:after{animation:none!important}.app-loading.is-exiting{opacity:0;animation:none!important}.loading-tip-text{animation:none!important}}.error-boundary-root{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;font-family:system-ui,sans-serif;display:flex}.error-boundary-title{margin-bottom:.5rem}.error-boundary-message{color:#666;max-width:400px;margin-bottom:1.5rem}.error-boundary-btn{border-radius:var(--radius-xs);cursor:pointer;color:inherit;background:0 0;border:1px solid;padding:.5rem 1.25rem}.error-boundary-btn-primary{margin-right:.75rem}.action-button.delete-action-btn{background-color:var(--delete-red);color:#fff;border-radius:var(--radius-full);cursor:pointer;z-index:10;opacity:0;pointer-events:none;width:24px;height:24px;transition:opacity var(--transition-base) ease-in-out, transform var(--transition-base) ease-in-out, box-shadow var(--transition-base) ease-in-out;border:none;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:8px;right:8px;transform:scale(.8)}.action-button.delete-action-btn.is-visible{opacity:1;pointer-events:auto;transform:scale(1)}.action-button.delete-action-btn:hover{background-color:var(--delete-red-hover);transform:scale(1.1);box-shadow:0 0 10px 3px #ef444480}.card-delete-btn{justify-self:end;position:relative;top:auto;right:auto}.block-delete-btn{width:24px;height:24px;top:8px;right:8px}.tag-delete-btn{width:20px;height:20px;top:0;right:0;translate:65% -65%}.floating-dock-container{bottom:var(--space-l);width:auto;z-index:var(--z-dock);transition:all var(--transition-base) cubic-bezier(.16, 1, .3, 1);pointer-events:none;position:fixed;left:50%;transform:translate(-50%)}.floating-dock{-webkit-backdrop-filter:var(--backdrop-blur);pointer-events:auto;background-color:#ffffffbf;border:1px solid #fff9;border-radius:100px;align-items:center;gap:8px;padding:8px 12px;display:flex;box-shadow:0 10px 40px -10px #00000026,0 1px 3px #0000000d,inset 0 1px #fffc}body[data-theme=dark] .floating-dock{background-color:#1e1e20cc;border:1px solid #ffffff1a;box-shadow:0 10px 40px -10px #00000080,inset 0 1px #ffffff1a}.dock-btn{width:auto;min-width:64px;height:60px;color:var(--ui-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;gap:4px;padding:0 8px;transition:all .4s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative}.dock-btn:hover{color:var(--ui-text-primary);background-color:#0000000d;transform:translateY(-4px)scale(1.05)}.dock-btn:active{transition-duration:.1s;transform:translateY(0)scale(.95)}body[data-theme=dark] .dock-btn:hover{background-color:#ffffff1a}.dock-btn.active{color:var(--ui-text-primary);background-color:#00000014}body[data-theme=dark] .dock-btn.active{background-color:#ffffff26}.dock-btn-label{opacity:.85;white-space:nowrap;font-size:.65rem;font-weight:600}.dock-btn-primary{color:var(--theme-text-strong)}.dock-btn-primary:hover{color:var(--theme-text-strong);background-color:#ffc30026}body[data-theme=dark] .dock-btn-primary:hover{background-color:#ffc30033}.dock-btn-magic{color:#8a2be2}.dock-btn-magic:hover{color:#9370db;background-color:#8a2be21a}.dock-divider{background-color:#00000026;border-radius:1px;width:1px;height:32px;margin:0 4px}body[data-theme=dark] .dock-divider{background-color:#ffffff26}.dock-popover-wrapper{position:relative}.dock-popover-wrapper .popover-menu{transform-origin:bottom;top:auto;bottom:calc(100% + 16px);left:50%;transform:translate(-50%)translateY(0)}.dock-preferences-menu{background-color:var(--ui-bg-card);border:1px solid var(--ui-border-default);border-radius:var(--radius-m);box-shadow:var(--shadow-xl);width:240px;z-index:var(--z-popover);transform-origin:bottom;padding:8px;animation:.3s cubic-bezier(.16,1,.3,1) forwards dockPopUp;position:absolute;bottom:calc(100% + 16px);left:50%;transform:translate(-50%)translateY(0)}@keyframes dockPopUp{0%{opacity:0;transform:translate(-50%)translateY(20px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.pref-row{border-radius:var(--radius-s);color:var(--ui-text-secondary);align-items:center;gap:12px;padding:12px 14px;font-size:.9rem;font-weight:500;display:flex}.pref-action{cursor:pointer;transition:background-color var(--transition-fast);text-decoration:none}button.pref-action{appearance:none;font:inherit;text-align:left;width:100%;padding:inherit;background:0 0;border:none}.pref-action:hover{background-color:var(--hover-bg-color);color:var(--ui-text-primary)}.pref-icon{color:var(--ui-text-tertiary)}.pref-row.pref-action:hover .pref-icon{color:var(--ui-text-primary)}.pref-divider{background-color:var(--ui-border-default);height:1px;margin:6px 0}.pref-select{appearance:none;border:1px solid var(--ui-border-default);color:var(--ui-text-primary);cursor:pointer;text-overflow:ellipsis;background:url("data:image/svg+xml;utf8,<svg fill=\"%2386868b\" height=\"12\" viewBox=\"0 0 20 20\" width=\"12\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M7.293 8.293a1 1 0 011.414 0L10 9.586l1.293-1.293a1 1 0 111.414 1.414l-2 2a1 1 0 01-1.414 0l-2-2a1 1 0 010-1.414z\"/></svg>") right 8px center no-repeat;border-radius:6px;max-width:100px;margin-left:auto;padding:4px 24px 4px 10px;font-size:.85rem}.pref-select:focus{border-color:var(--theme-accent);outline:none;box-shadow:0 0 0 2px #ffc30033}.popover-appearance{width:280px;padding:16px}.popover-export{width:220px}.pref-header{color:var(--ui-text-primary);align-items:center;gap:6px;margin-bottom:16px;font-size:1rem;font-weight:700;display:flex}.pref-group-title{color:var(--ui-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin:8px 0 4px 6px;font-size:.75rem;font-weight:700}.pref-card{background-color:var(--hover-bg-color);border-radius:var(--radius-m);flex-direction:column;gap:8px;margin-bottom:12px;padding:12px;display:flex}body[data-theme=dark] .pref-card{background-color:#ffffff0d}.pref-card-title{color:var(--ui-text-secondary);font-size:.8rem;font-weight:600}.color-picker-container{align-items:center;gap:12px;display:flex}.pref-color-input-big{border:2px solid var(--ui-border-default);cursor:pointer;background:0 0;border-radius:50%;width:36px;height:36px;padding:2px}.color-hex-value{color:var(--ui-text-primary);background:var(--ui-bg-card);border-radius:var(--radius-s);border:1px solid var(--ui-border-default);padding:4px 8px;font-family:monospace;font-size:.9rem}.theme-selector-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.theme-selector-btn{appearance:none;background:var(--ui-bg-card);border:1px solid var(--ui-border-default);border-radius:var(--radius-s);color:var(--ui-text-secondary);cursor:pointer;transition:all var(--transition-fast);padding:8px;font-size:.85rem}.theme-selector-btn:hover{border-color:var(--theme-accent)}.theme-selector-btn.selected{background:var(--theme-accent);color:var(--button-text-on-accent);border-color:var(--theme-accent);font-weight:600}.text-red{color:var(--delete-red)!important}.pref-row.pref-action:hover .text-red{color:var(--delete-red-hover)!important}.dock-btn-star{position:relative;overflow:visible}.star-icon{color:#ffb300;filter:drop-shadow(0 0 2px #ffb30066)}.star-pulse-bg{z-index:-1;background-color:#ffb30033;border-radius:50%;width:32px;height:32px;animation:2s cubic-bezier(.16,1,.3,1) infinite starPulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}body[data-theme=dark] .star-pulse-bg{background-color:#ffb3004d}@keyframes starPulse{0%{opacity:1;transform:translate(-50%,-50%)scale(.8)}to{opacity:0;transform:translate(-50%,-50%)scale(2)}}.dock-btn-star:hover .bouncy{animation:.5s cubic-bezier(.175,.885,.32,1.275) bounce}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.2)translateY(-2px)}}.branding-header{pointer-events:none;z-index:1000;position:fixed;top:24px;left:24px}.branding-logo{letter-spacing:-.03em;background:linear-gradient(135deg, var(--theme-accent) 0%, #ff9500 100%);-webkit-text-fill-color:transparent;text-transform:uppercase;-webkit-background-clip:text;font-size:1.25rem;font-weight:800}@media (width<=768px){.floating-dock-container{width:100%;padding:0 16px 24px;bottom:0}.floating-dock{border-radius:30px;justify-content:space-around;width:100%;padding:6px 8px}.dock-btn{width:64px;height:56px}.dock-divider{display:none}.dock-preferences-menu,.dock-popover-wrapper .popover-menu{width:calc(100% - 32px);max-width:360px;position:fixed;bottom:95px;left:50%;transform:translate(-50%)translateY(0)}}@media (prefers-reduced-motion:reduce){.floating-dock,.dock-btn{transition:none}.dock-btn:hover,.dock-btn:active{transform:none}.dock-preferences-menu,.star-pulse-bg,.star-icon.bouncy{animation:none}}.ai-panel-overlay{z-index:var(--z-dropdown);-webkit-backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;animation:.2s ease-out ai-overlay-in;display:flex;position:fixed;inset:0}@keyframes ai-overlay-in{0%{opacity:0}to{opacity:1}}.ai-panel{background:var(--ui-bg-card);border-radius:var(--radius-l);border:1px solid var(--ui-border-default);width:90vw;max-width:560px;height:85vh;max-height:700px;box-shadow:var(--shadow-xl);flex-direction:column;animation:.25s cubic-bezier(.16,1,.3,1) ai-panel-in;display:flex;overflow:hidden}@keyframes ai-panel-in{0%{opacity:0;transform:scale(.95)translateY(10px)}to{opacity:1;transform:scale(1)translateY(0)}}.ai-panel-header{padding:var(--space-m) var(--space-l);border-bottom:1px solid var(--ui-border-default);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.ai-panel-header-left{align-items:center;gap:var(--space-s);display:flex}.ai-panel-icon{color:var(--theme-accent)}.ai-panel-title{color:var(--ui-text-primary);margin:0;font-size:1rem;font-weight:600}.ai-panel-phase{background:var(--hover-bg-color);color:var(--theme-text-strong);border-radius:999px;padding:2px 8px;font-size:.75rem;font-weight:500}.ai-panel-header-right{align-items:center;gap:var(--space-xs);display:flex}.ai-panel-header-btn{border-radius:var(--radius-s);width:32px;height:32px;color:var(--ui-text-tertiary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.ai-panel-header-btn:hover{background:var(--hover-bg-color);color:var(--ui-text-primary)}.ai-panel-settings{padding:var(--space-m) var(--space-l);border-bottom:1px solid var(--ui-border-default);background:var(--theme-bg-page);flex-shrink:0;animation:.2s ease-out ai-settings-slide}@keyframes ai-settings-slide{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:300px}}.ai-settings-grid{gap:var(--space-s);grid-template-columns:1fr 1fr;display:grid}.ai-settings-field{flex-direction:column;gap:4px;display:flex}.ai-settings-field span{color:var(--ui-text-tertiary);text-transform:uppercase;letter-spacing:.03em;font-size:.75rem;font-weight:500}.ai-settings-field input,.ai-settings-field select{border:1px solid var(--ui-border-default);border-radius:var(--radius-xs);background:var(--ui-bg-card);color:var(--ui-text-primary);transition:border-color var(--transition-fast);outline:none;padding:6px 10px;font-size:.875rem}.ai-settings-field input:focus,.ai-settings-field select:focus{border-color:var(--theme-accent)}.ai-settings-status{margin-top:var(--space-s);color:var(--ui-text-tertiary);align-items:center;gap:var(--space-xs);font-size:.75rem;display:flex}.ai-settings-status code{background:var(--toolbar-button-active-bg);border-radius:4px;padding:1px 6px;font-size:.7rem}.ai-panel-chat{padding:var(--space-m) var(--space-l);gap:var(--space-m);flex-direction:column;flex:1;display:flex;overflow-y:auto}.ai-welcome-card{text-align:center;padding:var(--space-l) 0;align-items:center;gap:var(--space-m);flex-direction:column;display:flex}.ai-welcome-icon{border-radius:var(--radius-m);background:linear-gradient(135deg, var(--theme-accent), #ff9500);color:#fff;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.ai-welcome-text{color:var(--ui-text-secondary);max-width:400px;margin:0;font-size:.95rem;line-height:1.6}.ai-welcome-actions{gap:var(--space-xs);flex-direction:column;width:100%;max-width:360px;display:flex}.ai-quick-start-btn{align-items:center;gap:var(--space-s);border:1px solid var(--ui-border-default);border-radius:var(--radius-s);background:var(--ui-bg-card);color:var(--ui-text-primary);cursor:pointer;transition:all var(--transition-fast);text-align:left;padding:10px 14px;font-size:.875rem;display:flex}.ai-quick-start-btn:hover{border-color:var(--theme-accent);background:var(--hover-bg-color)}.ai-quick-start-btn:disabled{opacity:.5;cursor:not-allowed}.ai-quick-start-arrow{color:var(--ui-text-tertiary);margin-left:auto}.ai-welcome-hint{align-items:center;gap:var(--space-xs);color:var(--ui-text-tertiary);padding:var(--space-s) var(--space-m);background:var(--toolbar-button-active-bg);border-radius:var(--radius-s);border:1px dashed var(--ui-border-default);cursor:pointer;transition:all var(--transition-fast);margin:0;font-family:inherit;font-size:.8rem;display:flex}.ai-welcome-hint:hover{border-color:var(--theme-accent);color:var(--theme-text-strong)}.ai-msg{animation:.2s ease-out ai-msg-in;display:flex}@keyframes ai-msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ai-msg-user{justify-content:flex-end}.ai-msg-assistant{justify-content:flex-start}.ai-msg-bubble{word-break:break-word;border-radius:16px;max-width:85%;padding:10px 14px;font-size:.9rem;line-height:1.6}.ai-msg-user .ai-msg-bubble{background:var(--theme-accent);color:var(--button-text-on-accent);border-bottom-right-radius:4px}.ai-msg-assistant .ai-msg-bubble{background:var(--toolbar-button-active-bg);color:var(--ui-text-primary);border-bottom-left-radius:4px}.ai-typing{align-items:center;gap:4px;padding:12px 16px;display:flex}.ai-typing-dot{background:var(--ui-text-tertiary);border-radius:50%;width:6px;height:6px;animation:1.2s infinite ai-typing-bounce}.ai-typing-dot:nth-child(2){animation-delay:.2s}.ai-typing-dot:nth-child(3){animation-delay:.4s}@keyframes ai-typing-bounce{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.ai-panel-error{padding:var(--space-s) var(--space-l);color:var(--delete-red);background:#ef444414;flex-shrink:0;justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.ai-panel-error button{color:var(--delete-red);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.2rem}.ai-panel-success{padding:var(--space-s) var(--space-l);color:var(--success-green);background:#10b98114;flex-shrink:0;font-size:.8rem}.ai-panel-input-area{padding:var(--space-m) var(--space-l);border-top:1px solid var(--ui-border-default);flex-shrink:0}.ai-suggestion-chips{gap:var(--space-xs);margin-bottom:var(--space-s);-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.ai-chip{border:1px solid var(--ui-border-default);background:var(--ui-bg-card);color:var(--ui-text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);border-radius:999px;align-items:center;gap:4px;padding:6px 12px;font-size:.8rem;display:flex}.ai-chip:hover{border-color:var(--theme-accent);background:var(--hover-bg-color)}.ai-chip:disabled{opacity:.5;cursor:not-allowed}.ai-input-row{gap:var(--space-s);align-items:flex-end;display:flex}.ai-input{border:1px solid var(--ui-border-default);border-radius:var(--radius-m);background:var(--ui-bg-card);color:var(--ui-text-primary);resize:none;transition:border-color var(--transition-fast);outline:none;flex:1;padding:10px 14px;font-family:inherit;font-size:.9rem;line-height:1.5}.ai-input:focus{border-color:var(--theme-accent)}.ai-input::placeholder{color:var(--ui-text-tertiary)}.ai-send-btn{border-radius:var(--radius-s);background:var(--theme-accent);width:40px;height:40px;color:var(--button-text-on-accent);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ai-send-btn:hover:not(:disabled){filter:brightness(.9)}.ai-send-btn:disabled{opacity:.4;cursor:not-allowed}@media (width<=640px){.ai-panel{border-radius:0;width:100vw;max-width:none;height:100vh;max-height:none}.ai-settings-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){.ai-panel-overlay,.ai-panel,.ai-msg,.ai-settings-slide{animation:none}.ai-typing-dot{opacity:.6;animation:none}}:root{--theme-accent:#ffc300;--theme-tag-bg:#fff5cc;--theme-tag-bg-alt:#ffe082;--theme-bg-page:#fffdf5;--theme-text-strong:#8b4513;--theme-divider:#d4a017;--theme-tag-hover-bg:#ffe082;--hover-bg-color:#ffc3001a;--qr-code-fg-color:var(--theme-text-strong);--ui-text-primary:#1d1d1f;--ui-text-secondary:#333;--ui-text-tertiary:#86868b;--ui-bg-card:#fff;--ui-border-default:#e5e5e5;--delete-red:#ef4444;--delete-red-hover:#dc2626;--button-text-on-accent:#fff;--toolbar-bg:#fff;--toolbar-border:#dbdbdb;--toolbar-button-active-bg:#f0f0f0;--success-green:#10b981;--space-xs:4px;--space-s:8px;--space-m:16px;--space-l:24px;--space-xl:32px;--radius-xs:6px;--radius-s:8px;--radius-m:12px;--radius-l:20px;--radius-full:50%;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 12px #0000000d;--shadow-lg:0 8px 24px #00000014;--shadow-xl:0 10px 30px #0003;--transition-fast:.15s;--transition-base:.2s;--transition-slow:.3s;--backdrop-blur:blur(30px) saturate(190%);--z-dock:1002;--z-popover:1003;--z-dropdown:2000}body[data-theme=dark]{--theme-bg-page:#1a1a1c;--hover-bg-color:#ffc30014;--ui-text-primary:#f5f5f7;--ui-text-secondary:#a1a1a6;--ui-text-tertiary:#6e6e73;--ui-bg-card:#2c2c2e;--ui-border-default:#38383a;--toolbar-bg:#2c2c2e;--toolbar-border:#38383a;--toolbar-button-active-bg:#3a3a3c;--shadow-sm:0 1px 2px #0003;--shadow-md:0 4px 12px #0003;--shadow-lg:0 8px 24px #0000004d;--shadow-xl:0 10px 30px #00000080}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--theme-bg-page);transition:background-color var(--transition-slow) ease-in-out;margin:0;padding-top:0;padding-bottom:140px;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,SF Pro SC,SF Pro Display,SF Pro Icons,Helvetica Neue,Helvetica,Arial,Inter,sans-serif}html[data-locale=zh-CN] body{font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,微软雅黑,Hiragino Sans GB,Source Han Sans SC,Noto Sans CJK SC,sans-serif}html[data-locale=ja-JP] body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Kaku Gothic ProN,ヒラギノ角ゴ ProN,Yu Gothic,游ゴシック,Meiryo,メイリオ,Source Han Sans JP,Noto Sans CJK JP,sans-serif}html[data-locale=ko-KR] body{font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Malgun Gothic,맑은 고딕,Nanum Gothic,나눔고딕,Source Han Sans KR,Noto Sans CJK KR,sans-serif}html[data-locale=en-US] body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Segoe UI,Helvetica Neue,Arial,Inter,sans-serif}main#profileCardContainer{box-sizing:border-box;width:100%;max-width:1024px;padding:var(--space-xl) var(--space-m);margin:0 auto}.grid-container{gap:var(--space-l);grid-template-columns:1fr;width:100%;display:grid}@media (width>=768px){.grid-container{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width>=1024px){.grid-container{grid-template-columns:repeat(3,minmax(0,1fr))}}.profile-card-span,.about-me-card-span,.oshi-card-span,.full-width-card-span{grid-column:span 1}@media (width>=768px){.about-me-card-span,.oshi-card-span,.full-width-card-span{grid-column:span 2}}@media (width>=1024px){.oshi-card-span,.full-width-card-span{grid-column:span 3}}.main-header-container{margin-top:2rem;margin-bottom:var(--space-xl);text-align:center}.main-title{color:var(--ui-text-primary);margin-bottom:var(--space-s);font-size:2.8rem;font-weight:700}.subtitle{color:var(--ui-text-tertiary);font-size:1.2rem;font-weight:500}.page-footer{text-align:center;color:var(--ui-text-tertiary);margin-top:4rem;padding-bottom:2rem;font-size:.875rem}.ui-card{background-color:var(--ui-bg-card);border-radius:var(--radius-l);border:1px solid var(--ui-border-default);box-shadow:var(--shadow-md);transition:box-shadow var(--transition-base) ease-in-out, top var(--transition-base) ease-in-out, background-color var(--transition-base) ease-in-out;padding:0 var(--space-l) var(--space-m) var(--space-l);flex-direction:column;height:100%;display:flex;position:relative;top:0;overflow:visible}.card-inner-content{box-sizing:border-box;flex-direction:column;width:100%;height:auto;display:flex}.card-top-controls{opacity:0;pointer-events:none;min-height:32px;transition:opacity var(--transition-base);grid-template-columns:1fr auto 1fr;align-items:center;margin-top:10px;margin-bottom:6px;display:grid}.card-top-controls.is-visible{opacity:1;pointer-events:auto}.ui-card:hover{box-shadow:var(--shadow-lg);top:-2px}.section-title-container{margin-top:var(--space-s)}h2.section-title{color:var(--ui-text-primary);margin:0 0 var(--space-s) 0;padding-bottom:var(--space-m);border-bottom:1px solid var(--ui-border-default);font-size:1.3rem;font-weight:600}.card-content-wrapper{margin-top:var(--space-s)}.content-text{color:var(--ui-text-secondary);margin-bottom:var(--space-s);font-size:.9375rem;line-height:1.7}.content-text:last-child{margin-bottom:0}.content-text strong{color:var(--ui-text-primary);font-weight:500}.action-button-text-with-icon{border:1px dashed var(--ui-border-default);border-radius:var(--radius-m);color:var(--ui-text-tertiary);justify-content:center;align-items:center;gap:var(--space-s);cursor:pointer;transition:all var(--transition-base);margin-top:var(--space-m);background-color:#0000;width:100%;padding:12px;display:flex}.action-button-text-with-icon:hover{border-color:var(--theme-accent);background-color:var(--hover-bg-color);color:var(--theme-text-strong)}[contenteditable]{cursor:text;transition:background-color var(--transition-base) ease-in-out, box-shadow var(--transition-base) ease-in-out;border-radius:var(--radius-xs);border:1px solid #0000;outline:none;margin:-2px -4px;padding:2px 4px}[contenteditable]:hover{background-color:var(--hover-bg-color)}[contenteditable].is-focused{background-color:var(--hover-bg-color);box-shadow:0 0 0 2px var(--theme-accent);border-color:var(--theme-accent)}.rich-text-toolbar{z-index:1001;background-color:var(--toolbar-bg);border:1px solid var(--toolbar-border);border-radius:var(--radius-s);padding:var(--space-xs);align-items:center;gap:var(--space-xs);transition:opacity var(--transition-fast) ease-in-out, transform var(--transition-fast) ease-in-out;opacity:0;pointer-events:none;display:flex;position:absolute;transform:translateY(10px)scale(.95);box-shadow:0 8px 16px #00000026}.rich-text-toolbar.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.rich-text-toolbar button{border-radius:var(--radius-xs);cursor:pointer;width:32px;height:32px;color:var(--ui-text-secondary);transition:background-color var(--transition-base) ease;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.rich-text-toolbar button:hover{background-color:var(--toolbar-button-active-bg)}.rich-text-toolbar button.is-active{background-color:var(--theme-tag-bg);color:var(--theme-text-strong)}.toolbar-separator{background-color:var(--toolbar-border);width:1px;height:20px;margin:0 4px}.rich-text-toolbar .toolbar-input{border:1px solid var(--toolbar-border);border-radius:var(--radius-xs);background-color:var(--ui-bg-card);color:var(--ui-text-primary);transition:border-color var(--transition-base) ease;padding:4px 6px;font-size:14px}.rich-text-toolbar .toolbar-input:focus{border-color:var(--theme-accent);outline:none}.rich-text-toolbar .toolbar-input.font-size-input{width:45px}.rich-text-toolbar .toolbar-input.font-family-input{width:120px}.rich-text-toolbar label{color:var(--ui-text-tertiary);margin-left:4px;margin-right:2px;font-size:13px}.action-button{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--ui-border-default);cursor:pointer;border-radius:var(--radius-full);width:28px;height:28px;transition:all var(--transition-base);color:var(--ui-text-secondary);background:#ffffffb3;justify-content:center;align-items:center;padding:4px;display:inline-flex}.action-button:hover{background-color:var(--hover-bg-color);transform:scale(1.1)}.is-deleting{box-shadow:inset 0 0 0 1px var(--delete-red), var(--shadow-lg);background-color:#ef44440d!important}.tag-wrapper.is-deleting{box-shadow:none}.tag-wrapper.is-deleting>span{box-shadow:inset 0 0 0 1px var(--delete-red);background-color:#ef44441a!important}.element-container{padding:var(--space-s) 0;border-radius:var(--radius-s);transition:background-color var(--transition-base) ease-in-out, box-shadow var(--transition-base) ease-in-out;position:relative}.tag-wrapper{border-radius:var(--radius-s);display:inline-block;position:relative}.tag,.oshi-tag,.oshi-meta-tag{border-radius:var(--radius-s);transition:all var(--transition-base) ease;margin:.25rem;padding:.3rem .8rem;font-size:.8125rem;font-weight:500;display:inline-block;position:relative}.tag{background-color:var(--theme-tag-bg);color:var(--theme-text-strong)}.oshi-tag{background-color:var(--theme-tag-bg-alt);color:var(--theme-text-strong)}.oshi-meta-tag{color:var(--theme-text-strong);border:1px dashed var(--theme-accent);background-color:#0000;font-style:italic}.tag-wrapper:hover .tag,.tag-wrapper:hover .oshi-tag,.tag-wrapper:hover .oshi-meta-tag{transform:translateY(-1px);box-shadow:0 2px 5px #0000001a}.add-tag-button-container{align-items:center;gap:5px;margin-top:.5rem;display:flex}.add-tag-input{border-radius:var(--radius-xs);border:1px solid var(--ui-border-default);transition:border-color var(--transition-base);flex-grow:1;margin-left:8px;padding:6px 10px;font-size:.85rem}.add-tag-input:focus{border-color:var(--theme-accent);outline:none}.profile-section-layout{gap:var(--space-m);grid-template:"avatar""info""qrcode"/1fr;justify-items:center;display:grid}.avatar-container{border-radius:var(--radius-full);border:3px solid var(--theme-accent);cursor:pointer;background-color:#eee;flex-shrink:0;grid-area:avatar;width:100px;height:100px;position:relative;overflow:hidden;box-shadow:0 2px 6px #0000001a}.profile-info-text{text-align:left;grid-area:info;align-self:center;max-width:300px}.hidden-file-input{display:none}.profile-item-row{align-items:baseline;gap:4px;display:flex;position:relative}.profile-item-label{white-space:nowrap;flex-shrink:0;align-items:center;font-weight:700;display:flex}.profile-item-colon{margin-left:2px}.profile-item-value{word-break:break-word}.delete-item-btn{opacity:0;width:24px;height:24px;transition:opacity var(--transition-base);z-index:10;padding:4px;position:absolute;top:0;right:-28px}.profile-item-row:hover .delete-item-btn{opacity:1}.add-item-button-container{justify-content:center;margin-top:8px;display:flex}.add-item-btn{border-radius:12px;width:auto;height:auto;padding:4px 12px;font-size:12px}.icon-inline-left{margin-right:4px}.qr-code-wrapper{margin-top:var(--space-m);flex-direction:column;flex-shrink:0;grid-area:qrcode;justify-self:center;align-items:center;gap:5px;display:flex}.avatar-container img{object-fit:cover;width:100%;height:100%}.avatar-container:hover:after{content:var(--avatar-click-text,"点击更换");color:#fff;text-align:center;background:#00000080;width:100%;padding:4px 0;font-size:.7rem;position:absolute;bottom:0;left:0}.qr-code-container{border-radius:var(--radius-m);background:var(--ui-bg-card);padding:4px;overflow:hidden}.qr-code-link-input{border:1px solid var(--ui-border-default);border-radius:var(--radius-xs);box-sizing:border-box;text-align:center;max-width:180px;margin-top:.5rem;padding:4px;font-size:.8rem}.qr-code-wrapper .text-sm{color:var(--ui-text-tertiary);margin-top:.25rem;font-size:.8rem}.card-content-subheading{color:var(--ui-text-primary);margin:var(--space-s) 0;padding-bottom:var(--space-s);border-bottom:1px solid var(--toolbar-button-active-bg);font-size:1.125rem;font-weight:600}.tag-group-container,.music-game-category,.oshi-tag-container{gap:var(--space-s);margin-bottom:var(--space-m);flex-wrap:wrap;align-items:center;display:flex}.music-game-label{color:var(--ui-text-primary);margin-right:var(--space-s);margin-left:var(--space-xs);font-size:.95rem;font-weight:500}.oshi-tag-container{align-items:baseline}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background-color:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{padding:var(--space-l);border-radius:var(--radius-l);box-shadow:var(--shadow-xl);background:#fff;flex-direction:column;width:90%;max-width:600px;max-height:80vh;display:flex}@media (width<=976px){.modal-content{width:70%}}.modal-header{border-bottom:1px solid var(--ui-border-default);padding-bottom:var(--space-m);margin-bottom:var(--space-l);justify-content:space-between;align-items:center;display:flex}.modal-title{color:var(--ui-text-primary);margin:0;font-size:1.5rem;font-weight:600}.modal-close-btn{cursor:pointer;color:var(--ui-text-tertiary);padding:var(--space-s);border-radius:var(--radius-full);transition:background-color var(--transition-base);background:0 0;border:none}.modal-close-btn:hover{background-color:var(--toolbar-button-active-bg)}.modal-body{overflow-y:auto}.modal-intro-text{margin-bottom:var(--space-m);color:var(--ui-text-secondary);opacity:.8}.modal-actions{justify-content:flex-end;gap:var(--space-m);margin-top:var(--space-l);display:flex}.modal-button-secondary,.modal-button-primary{padding:var(--space-s) var(--space-m);border-radius:var(--radius-s);border:1px solid var(--ui-border-default);cursor:pointer;transition:all var(--transition-base) ease;background-color:#0000;font-size:.9rem;font-weight:500}.modal-button-secondary{color:var(--ui-text-secondary)}.modal-button-secondary:hover{background-color:var(--toolbar-button-active-bg)}.modal-button-primary{background-color:var(--theme-accent);color:var(--button-text-on-accent);border-color:var(--theme-accent)}.modal-button-primary:hover{opacity:.85;box-shadow:0 2px 8px #0000001a}.modal-button-danger{background-color:var(--delete-red);border-color:var(--delete-red)}.confirm-dialog-message{color:var(--ui-text-secondary);margin:0;font-size:1rem;line-height:1.6}.confirm-dialog-message.is-dangerous{color:var(--delete-red)}.template-grid{gap:var(--space-m);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));padding-top:2px;display:grid}.template-option{border:1px solid var(--ui-border-default);border-radius:var(--radius-m);padding:var(--space-m);cursor:pointer;transition:all var(--transition-base) ease-in-out}.template-option:hover{border-color:var(--theme-accent);transform:translateY(-2px);box-shadow:0 4px 15px #00000014}.template-name{margin:0 0 var(--space-s) 0;color:var(--ui-text-primary);font-size:1.1rem;font-weight:600}.template-description{color:var(--ui-text-tertiary);margin:0;font-size:.9rem}.react-grid-item.react-grid-placeholder{border-radius:var(--radius-l)!important;opacity:.5!important;background:#ffc30033!important}.react-grid-item{transition:transform var(--transition-fast) ease, box-shadow var(--transition-fast) ease}.react-grid-item.react-draggable-dragging,.react-grid-item.resizing{z-index:40}.react-grid-item.react-draggable-dragging .ui-card,.react-grid-item.resizing .ui-card{box-shadow:var(--shadow-xl)}.react-resizable-handle{cursor:se-resize!important;background-image:none!important;width:20px!important;height:20px!important;bottom:5px!important;right:5px!important}.popover-container{align-items:center;display:inline-flex;position:relative}.popover-menu{-webkit-backdrop-filter:blur(40px)saturate(200%);z-index:2000;transform-origin:100% 0;background-color:#ffffffbf;border:.5px solid #0000001a;border-radius:12px;flex-direction:column;gap:2px;width:200px;padding:6px;animation:.3s cubic-bezier(.16,1,.3,1) appleMenuIn;display:flex;position:absolute;top:calc(100% + 10px);right:0;box-shadow:0 10px 40px #00000026}body[data-theme=dark] .popover-menu{background-color:#2c2c2ed1;border-color:#ffffff1a}.popover-item{color:var(--ui-text-primary);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;font-size:.85rem;font-weight:500;transition:background-color .15s;display:flex}.popover-item:hover{background-color:#0000000d}body[data-theme=dark] .popover-item:hover{background-color:#ffffff1a}@keyframes appleMenuIn{0%{opacity:0;transform:scale(.96)translateY(-8px)}to{opacity:1;transform:scale(1)translateY(0)}}.react-resizable-handle:after{content:"";border-right:2px solid var(--ui-text-tertiary);border-bottom:2px solid var(--ui-text-tertiary);width:8px;height:8px;position:absolute;bottom:3px;right:3px}.drag-handle{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;z-index:10;color:var(--ui-text-tertiary);justify-self:center;padding:4px 8px;position:relative;top:auto;left:auto;transform:none}.drag-handle:active{cursor:grabbing}.width-control-container{z-index:20;justify-self:start;position:relative;top:auto;left:auto}.width-control-btn{border-radius:var(--radius-s);color:var(--ui-text-tertiary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.width-control-btn:hover{color:var(--ui-text-primary);background-color:#0000000d}.width-dropdown{background-color:var(--ui-bg-card);border:1px solid var(--ui-border-default);border-radius:var(--radius-s);box-shadow:var(--shadow-lg);z-index:50;min-width:120px;margin-top:4px;padding:4px;display:none;position:absolute;top:100%;left:0}.width-dropdown:before{content:"";width:100%;height:10px;position:absolute;top:-10px;left:0}.width-control-container:hover .width-dropdown,.width-control-container.is-open .width-dropdown{display:block}.width-dropdown-item{text-align:left;cursor:pointer;width:100%;color:var(--ui-text-secondary);border-radius:var(--radius-xs);background:0 0;border:none;padding:6px 12px;font-size:.85rem;display:block}.width-dropdown-item:hover{color:var(--ui-text-primary);background-color:#0000000d}.width-dropdown-item.is-active{background-color:var(--hover-bg-color);color:var(--theme-text-strong);font-weight:600}@media (hover:none){.card-top-controls{opacity:1;pointer-events:auto}}@media print{.delete-item-btn,.add-item-btn{display:none!important}}
