:root{--sidebar-w: 220px;--header-h: 56px;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--r-xl: 14px;--z-sidebar: 100;--z-modal: 200;--ease: cubic-bezier(.16,1,.3,1)}[data-theme=dark]{--bg: #0d0a07;--bg-grid: rgba(61,46,30,.22);--surface: #1a1410;--surface-2: #231a12;--surface-3: #2c2016;--border: #3d2e1e;--border-glow: rgba(200,168,80,.2);--gold: #c8a850;--gold-r: 200;--gold-g: 168;--gold-b: 80;--gold-dim: rgba(200,168,80,.5);--gold-bg: rgba(200,168,80,.08);--text: #f0e6cc;--text-2: #a09070;--text-3: #5a4830;--overlay: rgba(0,0,0,.78);--success:#5cba80;--success-bg:rgba(46,125,79,.15);--success-bd:#2e7d4f;--success-solid:#1e6040;--warning:#f0a040;--warning-bg:rgba(184,96,0,.15);--warning-bd:#c07010;--info: #a888f0;--info-bg:rgba(96,64,176,.15);--info-bd:#6040b0;--danger: #e05050;--danger-strong:#c03030;--danger-bg:rgba(200,50,50,.14);--danger-bd:rgba(200,50,50,.4);--neutral:#8a7a5a;--neutral-bg:var(--surface-2);--neutral-bd:var(--border);--scr:var(--success);--scr-bg:var(--success-bg);--sip:var(--warning);--sip-bg:var(--warning-bg);--spr:var(--info);--spr-bg:var(--info-bg);--sc: var(--success);--sc-bg: var(--success-bg);--se: var(--neutral);--se-bg: var(--neutral-bg);--diff-lo: #8a8a8a;--diff-mid: #5580e0;--diff-hi: #9955d8;--diff-ex: #c8a020;--diff-lg: #ff6600}[data-theme=light]{--bg: #fdfaf4;--bg-grid: rgba(180,150,100,.1);--surface: #ffffff;--surface-2: #fffbf5;--surface-3: #fff8ee;--border: #e8d8c0;--border-glow: rgba(122,82,48,.22);--gold: #c8a850;--gold-r: 122;--gold-g: 82;--gold-b: 48;--gold-dim: rgba(122,82,48,.5);--gold-bg: rgba(122,82,48,.07);--text: #2c1a0a;--text-2: #795548;--text-3: #a08060;--overlay: rgba(0,0,0,.52);--success:#2e7d4f;--success-bg:rgba(46,125,79,.1);--success-bd:#2e7d4f;--success-solid:#2e7d4f;--warning:#b86000;--warning-bg:rgba(184,96,0,.1);--warning-bd:#b86000;--info: #6040b0;--info-bg:rgba(96,64,176,.08);--info-bd:#6040b0;--danger: #c0392b;--danger-strong:#a02020;--danger-bg:rgba(192,48,48,.08);--danger-bd:rgba(192,48,48,.3);--neutral:#8a7355;--neutral-bg:var(--surface-2);--neutral-bd:var(--border);--scr:var(--success);--scr-bg:var(--success-bg);--sip:var(--warning);--sip-bg:var(--warning-bg);--spr:var(--info);--spr-bg:var(--info-bg);--sc: var(--success);--sc-bg: var(--success-bg);--se: var(--neutral);--se-bg: var(--neutral-bg);--diff-lo: #606060;--diff-mid: #3360c0;--diff-hi: #7733b0;--diff-ex: #a01818;--diff-lg: #cc3300}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:15px}body{font-family:Noto Sans TC,system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;transition:background .3s ease,color .3s ease;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background-image:linear-gradient(var(--bg-grid) 1px,transparent 1px),linear-gradient(90deg,var(--bg-grid) 1px,transparent 1px);background-size:28px 28px}#root{position:relative;z-index:1}button{cursor:pointer;font-family:inherit;border:none;background:none}input,select,textarea{font-family:inherit}input[type=checkbox]{accent-color:var(--gold)}a{text-decoration:none;color:inherit}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}:root{--dock-h:80px}.app-shell{display:flex;flex-direction:column;min-height:100vh}.top-bar{position:sticky;top:0;z-index:var(--z-sidebar);height:var(--header-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:0;padding:0 24px;transition:background .3s ease;flex-shrink:0}.tb-brand{display:flex;align-items:center;gap:10px;cursor:pointer;flex-shrink:0;padding-right:20px;border-right:1px solid var(--border);transition:opacity .15s ease}.tb-brand:hover{opacity:.8}.tb-brand-mark{color:var(--gold)}.tb-brand-name{font-family:Cinzel,serif;font-size:11.5px;font-weight:700;color:var(--gold);letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.tb-breadcrumb{flex:1;display:flex;align-items:center;gap:6px;padding:0 20px;overflow:hidden;min-width:0}.tb-crumb{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:none;border:none;font-family:inherit;cursor:default;padding:0}.tb-crumb-link{color:var(--text-3);cursor:pointer;transition:color .15s ease}.tb-crumb-link:hover{color:var(--text-2)}.tb-crumb-active{color:var(--text)}.tb-crumb-sep{color:var(--text-3);font-size:11px;flex-shrink:0}.tb-right{display:flex;align-items:center;gap:6px;flex-shrink:0}.tb-icon-btn{position:relative;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-2);background:none;border:none;cursor:pointer;transition:all .15s ease}.tb-icon-btn:hover{color:var(--text);background:var(--surface-2)}.tb-badge{position:absolute;top:3px;right:3px;background:var(--danger-strong);color:#fff;font-size:9px;font-weight:700;min-width:15px;height:15px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none}.tb-avatar{width:34px;height:34px;border-radius:50%;background:var(--surface-2);border:1.5px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:13px;font-weight:700;color:var(--gold);cursor:pointer;flex-shrink:0;transition:border-color .15s ease,box-shadow .15s ease}.tb-avatar:hover{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-bg)}.main-content{flex:1;overflow-y:auto;min-height:0;padding-bottom:calc(var(--dock-h) + 28px)}.page-header{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:10;transition:background .3s ease}.ph-left{display:flex;align-items:center;gap:12px}.ph-back{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-3);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .15s ease;background:none;border:none;font-family:inherit}.ph-back:hover{color:var(--text-2);background:var(--surface-2)}.ph-title{font-family:Cinzel,serif;font-size:18px;font-weight:700;color:var(--text);letter-spacing:.04em;display:flex;align-items:center;gap:10px}.ph-title svg{width:18px;height:18px;color:var(--gold)}.page-content{padding:24px 28px}.page-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:22px}.page-title{font-family:Cinzel,serif;font-size:18px;font-weight:700;color:var(--text);letter-spacing:.04em;display:flex;align-items:center;gap:10px;min-width:0}.page-title svg{width:18px;height:18px;color:var(--gold);flex-shrink:0}.eyebrow{font-family:Cinzel,serif;font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3)}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:14px}.room-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:20px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;position:relative;overflow:hidden;animation:cardIn .4s cubic-bezier(.16,1,.3,1) forwards;animation-delay:calc(var(--i,0)*60ms)}.room-card:before{content:"";position:absolute;top:0;right:0;width:70px;height:70px;background:radial-gradient(circle at top right,var(--gold-bg),transparent 70%)}.room-card:hover{transform:translateY(-4px);border-color:var(--border-glow);box-shadow:0 14px 40px -8px #0006,0 0 0 1px var(--border-glow)}.room-card-urgent{border-color:#b4282873!important;animation:cardIn .45s cubic-bezier(.16,1,.3,1) forwards,urgentRoomPulse 2.8s 1s ease-in-out infinite}.room-card-urgent:before{background:radial-gradient(circle at top right,rgba(180,40,40,.12),transparent 70%)!important}.room-card-urgent:hover{border-color:#c83232b3!important;box-shadow:0 14px 40px -8px #0006,0 0 0 1px #c8323280,0 0 20px -4px #c8323233!important}.rc-urgent-bar{display:flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;letter-spacing:.04em;color:var(--danger-strong);background:#b428281a;border:1px solid rgba(180,40,40,.25);border-radius:5px;padding:4px 9px;margin-bottom:12px;animation:urgentPulse 2.5s ease-in-out infinite}[data-theme=light] .rc-urgent-bar{color:var(--danger-strong);background:#b4282812}@keyframes urgentRoomPulse{0%,to{box-shadow:0 4px 16px #00000026}50%{box-shadow:0 4px 24px -2px #b4282840,0 0 0 1px #b4282833}}.rc-name{font-family:Cinzel,serif;font-size:15px;font-weight:700;color:var(--text);margin-bottom:7px;line-height:1.3}.rc-desc{font-size:12px;color:var(--text-3);margin-bottom:12px;line-height:1.4}.rc-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.rc-stat{font-size:11px;color:var(--text-2);display:flex;align-items:center;gap:4px}.rc-stat svg{width:12px;height:12px}.rc-hearth{display:flex;align-items:center;gap:7px;margin-top:13px;padding-top:11px;border-top:1px solid var(--border)}.rc-hearth-label{font-family:Cinzel,serif;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}.rc-hearth-tier{font-size:11.5px;font-weight:600;color:var(--text-2)}.hearth-tier-l4{color:var(--gold)}.hearth{flex-shrink:0}.copy-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;padding:0;flex-shrink:0;background:none;border:none;border-radius:5px;cursor:pointer;color:var(--text-3);transition:color .15s ease,background .15s ease}.copy-btn:hover{color:var(--text);background:var(--surface-2)}.copy-btn.is-copied{color:var(--success)}.copy-btn.is-failed{color:var(--danger)}.room-hearth-chip{display:inline-flex;align-items:center;gap:5px;padding:2px 9px 2px 4px;border:1px solid var(--border);border-radius:999px;background:var(--surface-2);font-weight:400}.hearth-flames{animation:hearthFlicker 1.6s ease-in-out infinite}.hearth-l4 .hearth-flames{animation-duration:1.05s}.hearth-l3 .hearth-flames{animation-duration:1.25s}.hearth-l1 .hearth-flames{animation-duration:2.1s}.hearth-flame-inner{animation:hearthFlicker .9s ease-in-out infinite reverse;transform-origin:16px 20px}.hearth-glow{animation:hearthGlowPulse 2.4s ease-in-out infinite}.hearth-ember{animation:hearthGlowPulse 2.8s ease-in-out infinite}.hearth-spark{animation:hearthSpark 1.8s ease-in-out infinite}@keyframes hearthFlicker{0%,to{transform:scaleY(1) scaleX(1) skew(0);opacity:.92}28%{transform:scaleY(1.08) scaleX(.96) skew(2.5deg);opacity:1}55%{transform:scaleY(.96) scaleX(1.04) skew(-2deg);opacity:.85}78%{transform:scaleY(1.05) scaleX(.98) skew(1.5deg);opacity:1}}@keyframes hearthGlowPulse{0%,to{opacity:.55}50%{opacity:1}}@keyframes hearthSpark{0%{opacity:0;transform:translateY(2px) scale(.6)}30%{opacity:1}to{opacity:0;transform:translateY(-7px) scale(1)}}@media (prefers-reduced-motion: reduce){.hearth-flames,.hearth-flame-inner,.hearth-glow,.hearth-ember,.hearth-spark{animation:none}}.board-panel{position:relative;overflow:hidden;padding:0;cursor:pointer;border-radius:var(--r-md);border:2px solid var(--border-glow);box-shadow:0 0 0 1px var(--border),inset 0 0 0 1px var(--border),0 6px 20px #00000040;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;animation:cardIn .4s cubic-bezier(.16,1,.3,1) forwards;animation-delay:calc(var(--i,0)*60ms);background:linear-gradient(160deg,var(--surface-3) 0%,var(--surface) 40%,var(--surface-2) 100%)}.board-panel:hover{transform:translateY(-5px);border-color:var(--gold-dim);box-shadow:0 0 0 1px var(--gold-dim),inset 0 0 0 1px #c8a85026,0 16px 40px -6px #00000073,0 0 24px -6px #c8a85033}.bp-stud{position:absolute;width:9px;height:9px;background:var(--gold-dim);transform:rotate(45deg);transition:background .2s ease;z-index:1}.board-panel:hover .bp-stud{background:var(--gold)}.bp-stud-tl{top:7px;left:7px}.bp-stud-tr{top:7px;right:7px}.bp-stud-bl{bottom:7px;left:7px}.bp-stud-br{bottom:7px;right:7px}.bp-ribbon{position:absolute;top:16px;right:-24px;background:var(--danger-strong);color:#ffe0d0;font-size:9px;font-weight:700;letter-spacing:.06em;font-family:Cinzel,serif;text-transform:uppercase;padding:3px 28px;transform:rotate(35deg);display:flex;align-items:center;gap:4px;white-space:nowrap;pointer-events:none;animation:urgentPulse 2.5s ease-in-out infinite;box-shadow:0 2px 8px #0006;z-index:2}.bp-urgent{border-color:#b428288c!important;box-shadow:0 0 0 1px #b428284d,inset 0 0 0 1px #b4282826,0 6px 20px #00000040,0 0 20px -4px #b4282833!important;animation:cardIn .4s cubic-bezier(.16,1,.3,1) forwards,urgentRoomPulse 2.8s 1s ease-in-out infinite}.bp-hd{display:flex;align-items:center;gap:8px;padding:14px 18px 10px;border-bottom:1px solid var(--border);background:var(--surface-2)}.bp-name{font-family:Cinzel,serif;font-size:13.5px;font-weight:700;color:var(--text);letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bp-div{display:flex;align-items:center;gap:8px;padding:8px 18px 6px}.bp-divline{flex:1;height:1px;background:var(--border)}.bp-stats{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:8px 18px 6px}.bp-stat{display:flex;align-items:center;gap:4px;font-size:11.5px;color:var(--text-2);font-weight:500}.bp-stat svg{flex-shrink:0}.bp-stat-open{color:var(--scr);font-weight:700}.bp-stat-urgent{color:var(--danger-strong);font-weight:700}.bp-enter{display:flex;align-items:center;justify-content:flex-end;gap:4px;padding:8px 18px 12px;font-size:10.5px;font-weight:600;letter-spacing:.06em;color:var(--text-3);text-transform:uppercase;font-family:Cinzel,serif;transition:color .15s ease}.board-panel:hover .bp-enter{color:var(--gold)}.board-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:16px;cursor:pointer;overflow:hidden;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;animation:cardIn .4s cubic-bezier(.16,1,.3,1) forwards;animation-delay:calc(var(--i,0)*50ms)}.board-card:hover{transform:translateY(-3px);border-color:var(--border-glow);box-shadow:0 8px 24px -4px #0000004d}.board-urgent-banner{margin-bottom:22px;border:1.5px solid rgba(200,50,50,.35);border-left:4px solid var(--danger-strong);border-radius:var(--r-md);overflow:hidden;animation:cardIn .4s ease}[data-theme=dark] .board-urgent-banner{background:#b428280f}[data-theme=light] .board-urgent-banner{background:#fff0f0b3}.bub-hd{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid rgba(200,50,50,.18);font-family:Cinzel,serif;font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--danger-strong);text-transform:uppercase}[data-theme=dark] .bub-hd{background:#b428281f}[data-theme=light] .bub-hd{background:#dc3c3c14}.bub-hd-sub{font-family:"Noto Serif TC",serif;font-size:11px;font-weight:400;color:var(--text-3);letter-spacing:0;text-transform:none;margin-left:4px}.bub-list{padding:10px 14px;display:flex;flex-direction:column;gap:8px}.bub-item{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--surface);border:1px solid rgba(200,50,50,.15);border-radius:var(--r-sm);cursor:pointer;transition:border-color .15s ease,background .15s ease}.bub-item:hover{border-color:#c8323280;background:var(--surface-2)}.bub-item-info{flex:1;min-width:0;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.bub-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bub-by{font-size:11.5px;color:var(--text-3);white-space:nowrap;flex-shrink:0}.bc-name{font-family:"Noto Serif TC",serif;font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px;display:flex;align-items:center;gap:6px}.bc-name svg{width:14px;height:14px;color:var(--gold)}.quest-highlighted{animation:questHighlight 2.2s ease forwards!important}.qc-menu{position:absolute;right:0;bottom:calc(100% + 6px);background:var(--surface-3);border:1px solid var(--border-glow);border-radius:var(--r-md);box-shadow:0 8px 24px #0006;min-width:160px;z-index:50;overflow:hidden;animation:fadeIn .12s ease}.qc-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:9px 14px;font-size:12.5px;font-weight:500;color:var(--text-2);background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;transition:background .12s ease}.qc-menu-item:hover{background:var(--surface-2);color:var(--text)}.qc-menu-danger{color:var(--danger)!important}.qc-menu-danger:hover{background:#c832321a!important}@keyframes questHighlight{0%{box-shadow:0 0 0 3px var(--gold),0 0 24px -4px var(--gold);border-color:var(--gold)!important}60%{box-shadow:0 0 0 3px var(--gold),0 0 24px -4px var(--gold);border-color:var(--gold)!important}to{box-shadow:none;border-color:var(--border)}}.quest-list{display:flex;flex-direction:column;gap:14px}.quest-card{position:relative;overflow:hidden;background:linear-gradient(155deg,var(--surface-3) 0%,var(--surface) 55%,var(--surface-2) 100%);border:1px solid var(--border);border-radius:var(--r-md);padding:22px 24px 17px;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;animation:cardIn .45s cubic-bezier(.16,1,.3,1) forwards;animation-delay:calc(var(--i,0)*70ms)}.quest-card:before{display:none}[data-theme=dark] .quest-card{box-shadow:0 3px 12px #00000080}[data-theme=light] .quest-card{box-shadow:0 2px 8px #00000017}.quest-card:hover{transform:translateY(-4px);border-color:var(--border-glow);box-shadow:0 14px 40px -8px #00000073,0 0 0 1px var(--border-glow)}.qc-c{position:absolute;width:15px;height:15px;border-color:var(--gold-dim);border-style:solid;pointer-events:none;opacity:.45;transition:opacity .22s ease}.quest-card:hover .qc-c{opacity:.9}.qc-tl{top:8px;left:8px;border-width:1.5px 0 0 1.5px}.qc-tr{top:8px;right:8px;border-width:1.5px 1.5px 0 0}.qc-bl{bottom:8px;left:8px;border-width:0 0 1.5px 1.5px}.qc-br{bottom:8px;right:8px;border-width:0 1.5px 1.5px 0}.qc-urgent-ribbon{position:absolute;top:0;right:26px;background:var(--danger-strong);color:#ffc8b0;font-size:9px;font-weight:700;letter-spacing:.1em;padding:4px 10px 3px;font-family:Cinzel,serif;text-transform:uppercase;border-radius:0 0 5px 5px;display:inline-flex;align-items:center;gap:4px;animation:urgentPulse 2.5s ease-in-out infinite}.qc-type-hd{display:flex;align-items:center;gap:10px;margin-bottom:14px}.qc-type-label{font-family:Cinzel,serif;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--text-3);white-space:nowrap;flex-shrink:0}.qc-div-line{flex:1;height:1px;background:var(--border)}.qc-headline{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.qc-title{font-family:"Noto Serif TC",serif;font-size:18px;font-weight:700;color:var(--text);line-height:1.35;flex:1;min-width:0;text-wrap:pretty}.qc-content{font-family:"Noto Serif TC",serif;font-size:12.5px;color:var(--text-2);line-height:1.7;margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;text-wrap:pretty}.qc-divider{display:flex;align-items:center;gap:8px;margin:10px 0 14px}.qc-info-row{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:14px}.qc-info-col{display:flex;flex-direction:column;gap:4px}.qc-info-item{font-size:11.5px;color:var(--text-3);font-family:"Noto Serif TC",serif;display:flex;align-items:center;gap:4px}.qc-reject{color:var(--warning)!important}.qc-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.qc-actions{margin-left:auto;display:flex;gap:6px;flex-wrap:wrap}.quest-card.urgent{animation:cardIn .45s both,urgentGlow 2.5s .6s ease-in-out infinite;border-color:#c832324d!important}.quest-card.expired{opacity:.48;filter:saturate(.3)}.diff-seal{display:inline-flex;align-items:center;justify-content:center;filter:drop-shadow(0 0 6px var(--dg,rgba(212,160,23,.4)));transition:filter .2s ease,transform .2s ease;cursor:default;flex-shrink:0}.diff-seal:hover{filter:drop-shadow(0 0 12px var(--dg,rgba(212,160,23,.7)));transform:scale(1.08) rotate(3deg)}[data-theme=light] .diff-seal svg polygon:first-child{opacity:1}.quest-card .diff-badge{display:none}.qc-diff-seal{flex-shrink:0;padding-top:0}.d-f{--dc:#8a8a8a;--db:#1e1e1e;--dg:rgba(138,138,138,.35)}.d-e{--dc:#3db870;--db:#0a1e12;--dg:rgba(61,184,112,.35)}.d-d{--dc:#3aaac8;--db:#081e28;--dg:rgba(58,170,200,.35)}.d-c{--dc:#5580e0;--db:#0c1430;--dg:rgba(85,128,224,.35)}.d-b{--dc:#9955d8;--db:#180a30;--dg:rgba(153,85,216,.35)}.d-a{--dc:#ff6600;--db:#280e00;--dg:rgba(255,102,0,.45)}.d-s{--dc:#c8a020;--db:#201600;--dg:rgba(200,160,32,.55)}.d-ss{--dc:#f5d000;--db:#281e00;--dg:rgba(245,208,0,.65)}.d-sss{--dc:#e03535;--db:#280808;--dg:rgba(224,53,53,.75)}[data-theme=light] .d-f{--dc:#5e5e5e;--db:#ededed}[data-theme=light] .d-e{--dc:#1f8a52;--db:#e2f4ea}[data-theme=light] .d-d{--dc:#1f7e98;--db:#e0f1f6}[data-theme=light] .d-c{--dc:#3a5fc0;--db:#e7ecfb}[data-theme=light] .d-b{--dc:#7a3cc0;--db:#f0e7fb}[data-theme=light] .d-a{--dc:#cc5200;--db:#ffe9da}[data-theme=light] .d-s{--dc:#9a7a00;--db:#faf2d6}[data-theme=light] .d-ss{--dc:#a98a00;--db:#fbf4cf}[data-theme=light] .d-sss{--dc:#c01f1f;--db:#fce2e2}.status-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 10px 4px 8px;border-radius:100px;border:1.5px solid;letter-spacing:.04em;white-space:nowrap;flex-shrink:0;position:relative}.status-pulse{width:7px;height:7px;border-radius:50%;flex-shrink:0;animation:statusPulse 1.8s ease-in-out infinite}@keyframes statusPulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.6)}}.s-recruiting{color:var(--success);border-color:var(--success-bd);background:var(--success-bg)}.s-recruiting .status-pulse{background:var(--success);box-shadow:0 0 0 3px var(--success-bg)}.s-in_progress{color:var(--warning);border-color:var(--warning-bd);background:var(--warning-bg)}.s-in_progress .status-pulse{background:var(--warning);box-shadow:0 0 0 3px var(--warning-bg)}.s-pending{color:var(--info);border-color:var(--info-bd);background:var(--info-bg)}.s-completed{color:#fff;border-color:var(--success-bd);background:var(--success-solid)}.s-expired{color:var(--text-3);border-color:var(--border);background:var(--surface-2);opacity:.7}.s-cancelled{color:var(--danger);border-color:#c832324d;background:#c8323214}.urgent-badge{display:inline-flex;align-items:center;gap:3px;font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:100px;background:#c8323224;color:var(--danger);border:1px solid rgba(200,50,50,.35);animation:urgentPulse 2.5s ease-in-out infinite}.role-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:2px 8px;border-radius:100px;border:1px solid}.r-master{color:var(--gold);border-color:var(--gold-dim);background:var(--gold-bg)}.r-admin{color:#5a9ad0;border-color:#5a9ad059;background:#5a9ad014}.r-member{color:var(--text-2);border-color:var(--border);background:var(--surface-2)}.affinity-badge{font-size:10px;font-weight:600;padding:2px 7px;border-radius:100px;border:1px solid}.aff-stranger{color:var(--text-3);border-color:var(--border);background:var(--surface-2)}.aff-acquaintance{color:#6a8a5a;border-color:#6a8a5a59;background:#6a8a5a14}.aff-comrade{color:#4a7aaa;border-color:#4a7aaa59;background:#4a7aaa14}.aff-partner{color:var(--gold);border-color:var(--gold-dim);background:var(--gold-bg)}.aff-soulbound{color:#c06080;border-color:#c0608059;background:#c0608014}.type-tag{font-size:11px;font-weight:600;padding:2px 8px;border-radius:4px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-2)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:6px 14px;border-radius:var(--r-sm);font-size:12px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:all .15s ease;border:1px solid transparent;white-space:nowrap;line-height:1;font-family:inherit}.btn-primary{background:var(--gold);color:#1a1208;border-color:var(--gold)}.btn-primary:hover{filter:brightness(1.12);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-2);border-color:var(--border)}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-success{background:var(--sc-bg);color:var(--sc);border-color:var(--success-bd)}.btn-success:hover{background:var(--success-bg);filter:brightness(1.08)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:var(--danger-bd)}.btn-danger:hover{background:var(--danger-bg);filter:brightness(1.08)}.btn-sm{padding:4px 10px;font-size:11px}.btn-xs{padding:3px 8px;font-size:10.5px;display:inline-flex;align-items:center;gap:3px}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;filter:none!important}.btn svg{width:13px;height:13px}.fab{position:fixed;bottom:28px;right:28px;width:52px;height:52px;border-radius:50%;background:var(--gold);color:#1a1208;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #c8a85059,0 2px 8px #0006;transition:transform .2s ease,box-shadow .2s ease;z-index:50}.fab:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 8px 30px #c8a85073,0 4px 12px #0006}.fab svg{width:22px;height:22px}.form-group{display:flex;flex-direction:column;gap:4px}.form-label{font-size:11.5px;font-weight:600;color:var(--text-2);letter-spacing:.03em}.req{color:var(--danger);margin-left:2px}.input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:8px 12px;font-size:13px;color:var(--text);transition:border-color .15s ease,box-shadow .15s ease;outline:none;width:100%}.input:focus{border-color:var(--gold-dim);box-shadow:0 0 0 3px var(--gold-bg)}.input::-moz-placeholder{color:var(--text-3)}.input::placeholder{color:var(--text-3)}select.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23a09070'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.quest-scroll{position:relative;width:100%;max-width:560px;max-height:92vh;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border-glow);border-radius:var(--r-lg);box-shadow:0 32px 80px #000000a6,0 0 0 1px var(--border-glow),0 0 60px -10px #c8a8501a;animation:scrollUnfurl .4s cubic-bezier(.16,1,.3,1) forwards;overflow:hidden}@keyframes scrollUnfurl{0%{opacity:0;transform:translateY(24px) scaleY(.94)}to{opacity:1;transform:none}}.qs-scroll-top,.qs-scroll-bot{flex-shrink:0;padding:0 0 4px;background:linear-gradient(to bottom,var(--surface-3),var(--surface));border-bottom:1px solid var(--border);position:relative;overflow:hidden}.qs-scroll-bot{background:linear-gradient(to top,var(--surface-3),var(--surface));border-bottom:none;border-top:1px solid var(--border);padding:4px 0 0}.qs-rod{height:16px;margin:0 -1px;background:linear-gradient(to bottom,var(--surface-3) 0%,var(--gold-dim) 45%,var(--surface-2) 55%,var(--surface-3) 100%);border-top:1px solid var(--gold-dim);border-bottom:1px solid var(--gold-dim);opacity:.6}.qs-rod-shadow{height:6px;background:linear-gradient(to bottom,rgba(0,0,0,.25),transparent)}.qs-hd{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--border);background:var(--surface-2)}.qs-hd-inner{display:flex;align-items:center;gap:12px}.qs-hd-title{font-family:Cinzel,serif;font-size:15px;font-weight:700;color:var(--gold);letter-spacing:.06em}.qs-hd-sub{font-size:10.5px;color:var(--text-3);margin-top:1px;letter-spacing:.03em}.qs-stepper{flex-shrink:0;display:flex;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border);background:var(--surface)}.qs-snode{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}.qs-snode-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:12px;font-weight:700;border:2px solid var(--border);background:var(--surface-2);color:var(--text-3);transition:all .25s ease}.qs-snode-label{font-size:10px;font-weight:600;letter-spacing:.04em;color:var(--text-3);white-space:nowrap;transition:color .25s ease}.qs-snode.current .qs-snode-circle{border-color:var(--gold);background:var(--gold);color:#1a1208;box-shadow:0 0 0 4px var(--gold-bg)}.qs-snode.current .qs-snode-label{color:var(--gold);font-weight:700}.qs-snode.done .qs-snode-circle{border-color:var(--gold-dim);background:var(--gold-bg);color:var(--gold)}.qs-snode.done .qs-snode-label{color:var(--text-2)}.qs-sline{flex:1;height:2px;background:var(--border);margin:0 8px 18px;transition:background .25s ease}.qs-sline.done{background:var(--gold-dim)}.qs-body{flex:1;overflow-y:auto;padding:22px 24px;min-height:0}.qs-label{display:block;font-family:Cinzel,serif;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);margin-bottom:7px}.qs-input{width:100%;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:9px 13px;font-size:13.5px;font-family:"Noto Serif TC",serif;color:var(--text);outline:none;transition:border-color .15s ease,box-shadow .15s ease;box-sizing:border-box}.qs-input:focus{border-color:var(--gold-dim);box-shadow:0 0 0 3px var(--gold-bg)}.qs-textarea{resize:vertical;min-height:80px;line-height:1.6}.qs-counter{font-size:10px;color:var(--text-3);text-align:right;display:block;margin-top:3px}.qs-err{font-size:11px;color:var(--danger);display:block;margin-top:4px}.qs-hint{font-size:12px;color:var(--text-3);margin:-4px 0 10px}.qs-warn{display:flex;align-items:flex-start;gap:6px;font-size:11.5px;color:#c07020;background:#c070201a;border:1px solid rgba(192,112,32,.3);border-radius:var(--r-md);padding:8px 12px;margin-top:4px}.qs-chips{display:flex;flex-wrap:wrap;gap:7px}.qs-chip{padding:5px 14px;border-radius:100px;font-size:12.5px;font-weight:600;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);cursor:pointer;transition:all .15s ease;font-family:inherit}.qs-chip:hover{border-color:var(--border-glow);color:var(--text)}.qs-chip.active{border-color:var(--gold);background:var(--gold-bg);color:var(--gold)}.diff-picker{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.diff-option{background:none;border:2px solid transparent;border-radius:6px;padding:6px;cursor:pointer;transition:all .18s ease;display:flex;align-items:center;justify-content:center}.diff-option:hover{background:var(--surface-2)}.diff-option.active{border-color:var(--gold-dim);background:var(--gold-bg);box-shadow:0 0 0 1px var(--gold-dim)}.qs-divider-line{display:flex;align-items:center;gap:10px;margin:4px 0}.qs-divider-line:before,.qs-divider-line:after{content:"";flex:1;height:1px;background:var(--border)}.qs-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border);cursor:pointer;transition:border-color .15s ease}.qs-toggle-row:hover{border-color:var(--border-glow)}.qs-toggle-label{font-size:13px;font-weight:600;color:var(--text)}.qs-toggle-desc{font-size:11px;color:var(--text-3);margin-top:1px}.qs-toggle{width:40px;height:22px;border-radius:11px;background:var(--surface-3);border:1px solid var(--border);position:relative;flex-shrink:0;transition:all .2s ease}.qs-toggle.on{background:var(--gold);border-color:var(--gold)}.qs-toggle-thumb{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0000004d;transition:transform .2s ease}.qs-toggle.on .qs-toggle-thumb{transform:translate(18px)}.dtp-wrap{display:flex;flex-direction:column;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;transition:border-color .15s ease,box-shadow .15s ease}.dtp-wrap:focus-within{border-color:var(--gold-dim);box-shadow:0 0 0 3px var(--gold-bg)}.dtp-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.dtp-section-label{font-family:Cinzel,serif;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);min-width:28px}.dtp-sel{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:5px 8px;font-size:13px;font-family:"Noto Serif TC",serif;color:var(--text);cursor:pointer;outline:none;transition:border-color .15s ease;-webkit-appearance:none;-moz-appearance:none;appearance:none;text-align:center}.dtp-sel:focus{border-color:var(--gold-dim)}.dtp-sel-wide{min-width:52px}.dtp-unit{font-size:12px;color:var(--text-3);font-family:"Noto Serif TC",serif;flex-shrink:0}.dtp-divider{width:1px;height:20px;background:var(--border);flex-shrink:0;margin:0 2px}.assignee-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:9px}.assignee-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);font-family:Cinzel,serif;padding:2px 0;text-align:center}.assignee-chip{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 10px;border-radius:var(--r-lg);background:var(--surface-2);border:1.5px solid var(--border);cursor:pointer;transition:all .18s ease;font-family:inherit}.assignee-chip:hover{border-color:var(--border-glow);background:var(--surface-3)}.assignee-chip.active{border-color:var(--gold);background:var(--gold-bg);box-shadow:0 0 0 1px var(--gold-dim)}.ac-avatar{width:40px;height:40px;border-radius:50%;background:var(--surface-3);border:1.5px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:16px;font-weight:700;color:var(--gold);transition:all .18s ease}.assignee-chip.active .ac-avatar{border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-bg)}.ac-open{background:var(--surface-2);color:var(--text-3)}.ac-self{background:var(--gold-bg);color:var(--gold);border-color:var(--gold)}.ac-type-open{border-style:dashed!important;border-color:#4a9a5a80!important}.ac-type-open:hover{background:#4a9a5a12!important;border-color:var(--scr)!important}.ac-type-open.active{border-color:var(--scr)!important;background:#4a9a5a1a!important;box-shadow:0 0 0 1px var(--scr)!important}.ac-type-open.active .ac-avatar{border-color:var(--scr);box-shadow:0 0 0 3px #4a9a5a26}.ac-type-self{border-color:var(--gold-dim)!important}.ac-type-self:hover{border-color:var(--gold)!important;background:var(--gold-bg)!important}.ac-type-self.active{border-color:var(--gold)!important;background:var(--gold-bg)!important;box-shadow:0 0 0 1px var(--gold)!important}.ac-name{font-size:13px;font-weight:600;color:var(--text);text-align:center}.ac-role{font-size:10.5px;color:var(--text-3);text-align:center}.qs-footer{flex-shrink:0;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-top:1px solid var(--border);background:var(--surface-2)}.qs-footer-left{min-width:90px}.qs-submit{letter-spacing:.03em}.qs-quick{color:var(--gold-dim);border-color:var(--gold-dim);letter-spacing:.02em}.qs-quick:hover:not(:disabled){background:var(--surface);color:var(--gold);border-color:var(--gold)}@media (max-width:560px){.qs-footer{flex-wrap:wrap;gap:8px;padding:12px 16px}.qs-footer-left{min-width:0}.qs-footer>div:last-child{flex-wrap:wrap;justify-content:flex-end}.qs-footer .btn{white-space:nowrap}}.qs-preview-row{display:flex;align-items:center;gap:9px}.qs-preview-val{font-size:14px;color:var(--text);font-weight:600}.qs-editlink{background:none;border:none;cursor:pointer;padding:0;margin-left:2px;color:var(--gold-dim);font-size:12px;letter-spacing:.02em}.qs-editlink:hover{color:var(--gold);text-decoration:underline}.qs-mini-toggles{display:flex;flex-wrap:wrap;gap:10px 22px;padding-top:2px}.qs-mini-toggle{display:flex;align-items:center;gap:7px}.qs-mini-label{font-size:13px;color:var(--text-2)}.qs-info-btn{display:inline-flex;background:none;border:none;cursor:pointer;padding:0;color:var(--text-3)}.qs-info-btn:hover{color:var(--gold)}.qs-info-pop{margin-top:8px;padding:7px 11px;border:1px solid var(--border);border-radius:8px;background:var(--surface-2);color:var(--text-2);font-size:12px;line-height:1.5}.modal-ov{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:16px;animation:fadeIn .15s ease}.modal-box{background:var(--surface);border:1px solid var(--border-glow);border-radius:var(--r-xl);width:100%;max-width:480px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalIn .28s cubic-bezier(.16,1,.3,1);box-shadow:0 24px 64px #0009,0 0 0 1px var(--border-glow)}.modal-hd{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;border-bottom:1px solid var(--border);background:var(--surface-2)}.modal-title{font-family:"Noto Serif TC",serif;font-size:14px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:7px}.modal-title svg{color:var(--gold);width:16px;height:16px}.modal-close{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-3);transition:all .15s ease;cursor:pointer;background:transparent;border:none}.modal-close:hover{background:var(--surface-3);color:var(--text)}.modal-close svg{width:16px;height:16px}.modal-bd{padding:20px;overflow-y:auto;flex:1}.modal-bd .form-group+.form-group{margin-top:13px}.modal-ft{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:13px 20px;border-top:1px solid var(--border);background:var(--surface-2)}.sec-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.sec-title{font-family:"Noto Serif TC",serif;font-size:13.5px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.sec-title svg{width:15px;height:15px;color:var(--gold)}.sec-ct{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;font-size:11px;font-weight:600;line-height:1;color:var(--text-3);background:var(--surface-2);border:1px solid var(--border);padding:0 7px;border-radius:100px}.divider{border:none;border-top:1px solid var(--border);margin:18px 0}.stack{display:flex;flex-direction:column;gap:8px}.stack-s{display:flex;flex-direction:column;gap:5px}.stack-l{display:flex;flex-direction:column;gap:16px}.row{display:flex;align-items:center;gap:8px}.g2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.profile-wrap{max-width:560px}.profile-avatar-row{display:flex;align-items:center;gap:18px}.pf-avatar{width:88px;height:88px;border-radius:50%;flex-shrink:0;background:var(--surface-2);border:2px solid var(--gold-dim);overflow:hidden;display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:34px;font-weight:700;color:var(--gold)}.pf-avatar img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.pf-avatar-actions{display:flex;flex-direction:column;align-items:flex-start;gap:6px}.pf-hint{font-size:11px;color:var(--text-3)}.gender-row{display:flex;flex-wrap:wrap;gap:7px}.char-count{font-size:10px;color:var(--text-3);text-align:right;display:block;margin-top:3px}.save-row{display:flex;align-items:center;gap:12px}.save-ok{font-size:12px;color:var(--success);font-weight:600;display:inline-flex;align-items:center;gap:4px}.profile-grid{display:grid;grid-template-columns:344px 1fr;gap:22px;align-items:start}@media (max-width:880px){.profile-grid{grid-template-columns:1fr}}.profile-view{max-width:380px;margin:2px auto 0}.char-card{position:relative;overflow:hidden;text-align:center;background:linear-gradient(155deg,var(--surface-3) 0%,var(--surface) 55%,var(--surface-2) 100%);border:1px solid var(--border-glow);border-radius:var(--r-md);padding:24px 22px 20px}[data-theme=dark] .char-card{box-shadow:0 3px 14px #00000080}[data-theme=light] .char-card{box-shadow:0 2px 10px #00000014}.char-card .qc-c{opacity:.55}.char-toplabel{display:flex;align-items:center;justify-content:center;gap:8px}.char-toplabel .bp-divline{max-width:46px}.char-portrait-wrap{position:relative;width:118px;height:118px;margin:16px auto 0;cursor:pointer;border-radius:50%}.char-portrait{width:118px;height:118px;border-radius:50%;overflow:hidden;background:var(--surface-2);border:2px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:46px;font-weight:700;color:var(--gold);box-shadow:0 0 0 4px var(--gold-bg),inset 0 0 14px #00000038}.char-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.char-portrait-ring{position:absolute;top:-7px;right:-7px;bottom:-7px;left:-7px;border-radius:50%;border:1px solid var(--gold-dim);opacity:.45;pointer-events:none}.char-portrait-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;gap:4px;background:#0000008c;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10.5px;font-weight:600;opacity:0;transition:opacity .18s ease}.char-portrait-wrap:hover .char-portrait-overlay{opacity:1}.char-name{font-family:Cinzel,serif;font-size:23px;font-weight:700;color:var(--text);letter-spacing:.04em;margin-top:15px;line-height:1.2}.char-role-row{display:flex;justify-content:center;flex-wrap:wrap;gap:6px;margin-top:9px}.char-divider{display:flex;align-items:center;gap:8px;margin:16px 2px 14px}.char-block{text-align:left}.char-block+.char-block{margin-top:13px}.char-id{font-family:monospace;font-size:13px;color:var(--text-2);margin-top:4px;display:flex;align-items:center;gap:6px}.char-meta{display:grid;grid-template-columns:1fr 1fr;gap:13px}.char-meta-val{font-family:"Noto Serif TC",serif;font-size:14px;color:var(--text);margin-top:4px}.char-meta-val.muted{color:var(--text-3)}.char-bio{font-family:"Noto Serif TC",serif;font-size:12.5px;color:var(--text-2);line-height:1.85;font-style:italic;text-align:left;margin-top:6px;background:var(--gold-bg);border-left:3px solid var(--gold-dim);border-radius:0 8px 8px 0;padding:10px 14px;text-wrap:pretty}.char-bio.empty{color:var(--text-3);font-style:normal}.char-stats{display:flex;align-items:stretch;justify-content:space-around;gap:10px;margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}.char-stat{text-align:center;flex:1}.char-stat-num{font-family:Cinzel,serif;font-size:21px;font-weight:700;color:var(--gold);line-height:1}.char-stat-label{font-size:9.5px;color:var(--text-3);margin-top:5px;letter-spacing:.06em;text-transform:uppercase;font-family:Cinzel,serif;font-weight:700}.char-stat-div{width:1px;background:var(--border)}.profile-form{max-width:560px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:22px 22px 24px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:40px 20px;border:1px dashed var(--border);border-radius:var(--r-lg);color:var(--text-3)}.empty-icon{opacity:.45}.empty-text{font-size:12.5px;text-align:center;line-height:1.5}.board-empty .empty-text{font-size:14px;color:var(--text-2)}.board-empty-hint{font-size:12px;color:var(--text-3);text-align:center}.commission-band{padding:14px 28px;border-bottom:1px solid var(--border)}.commission{border:1px solid var(--gold-dim);border-radius:14px;background:linear-gradient(180deg,var(--gold-bg),transparent 60%),var(--surface-2);padding:13px 15px 15px}.commission-head{display:flex;align-items:center;gap:11px;margin-bottom:11px}.commission-mark{flex-shrink:0;width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--gold);background:var(--gold-bg);border:1px solid var(--gold-dim)}.commission-title{font-family:Cinzel,serif;font-size:15px;font-weight:700;color:var(--text);letter-spacing:.01em}.commission-sub{font-size:12px;color:var(--text-3);margin-top:2px}.commission-row{display:flex;gap:8px;align-items:center}.commission-input{flex:1;width:auto;background:var(--surface)}.commission-btn{flex-shrink:0;white-space:nowrap}.commission-mic{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;background:var(--surface);border:1px solid var(--border);color:var(--text-2)}.commission-mic:hover{color:var(--text);border-color:var(--text-3)}.commission-mic.is-recording{background:var(--danger-bg, #fdecec);border-color:var(--danger, #d44);color:var(--danger, #d44);animation:commission-mic-pulse 1.3s ease-in-out infinite}.commission-mic-sec{font-size:12px;font-variant-numeric:tabular-nums}.commission-interim{display:flex;align-items:center;gap:7px;margin-top:8px;font-size:13px;color:var(--text-3);line-height:1.5;min-height:20px}.commission-interim-dot{flex-shrink:0;width:7px;height:7px;border-radius:50%;background:var(--danger, #d44);animation:commission-mic-pulse 1.3s ease-in-out infinite}@keyframes commission-mic-pulse{0%,to{box-shadow:0 0 #d4444459}50%{box-shadow:0 0 0 4px #d4444400}}@media (max-width:560px){.commission-band{padding:12px 16px}.commission-row{flex-wrap:wrap;align-items:stretch}.commission-input{flex:1 1 100%;box-sizing:border-box;min-width:0}.commission-mic{flex:3 1 0;min-width:0;justify-content:center}.commission-btn{flex:7 1 0;min-width:0;justify-content:center}}.alert-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--warning-bg);border-bottom:1px solid var(--warning-bd);font-size:12px;color:var(--warning)}.alert-bar svg{width:15px;height:15px;flex-shrink:0}.link-btn{margin-left:auto;font-size:11px;font-weight:700;text-decoration:underline;cursor:pointer;background:none;border:none;color:var(--warning);font-family:inherit}.error-msg{font-size:11.5px;color:var(--danger);background:#c8323214;border:1px solid rgba(200,50,50,.25);border-radius:var(--r-sm);padding:8px 12px}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;--bg:#0d0a07;--surface:#1a1410;--surface-2:#231a12;--surface-3:#2c2016;--border:#3d2e1e;--border-glow:rgba(200,168,80,.2);--gold:#c8a850;--gold-dim:rgba(200,168,80,.5);--gold-bg:rgba(200,168,80,.08);--text:#f0e6cc;--text-2:#a09070;--text-3:#7c6242;background:linear-gradient(155deg,#160f08,#1a1410 60%,#120d07)}.login-story{display:flex;flex-direction:column;justify-content:center;padding:64px 52px;position:relative;overflow:hidden;isolation:isolate;border-right:1px solid #3d2e1e;background:radial-gradient(120% 85% at 20% 4%,#2c2016 0%,transparent 56%),radial-gradient(95% 90% at 100% 100%,#231a12 0%,transparent 52%),linear-gradient(155deg,#0d0a07,#1a1410 48%,#0d0a07)}.login-story:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(34% 30% at 24% 26%,rgba(200,168,80,.26),transparent 70%),radial-gradient(26% 24% at 80% 74%,rgba(240,160,64,.16),transparent 72%);mix-blend-mode:screen;animation:tavernFlame 6s ease-in-out infinite}.login-story:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(135% 115% at 46% 42%,transparent 38%,rgba(0,0,0,.58) 100%);animation:tavernAmbient 9s ease-in-out infinite}.login-story>*{position:relative;z-index:1}@keyframes tavernFlame{0%{opacity:.7;transform:scale(1)}22%{opacity:.92;transform:scale(1.022)}38%{opacity:.8}54%{opacity:1;transform:scale(1.045)}72%{opacity:.85;transform:scale(1.02)}to{opacity:.7;transform:scale(1)}}@keyframes tavernAmbient{0%,to{opacity:.82}50%{opacity:1}}@media (prefers-reduced-motion: reduce){.login-story:before,.login-story:after{animation:none}}.ls-brand{font-family:Cinzel,serif;font-size:40px;font-weight:700;color:var(--gold);letter-spacing:.1em;margin-bottom:20px;text-shadow:0 0 22px rgba(200,168,80,.35),0 1px 1px rgba(0,0,0,.5)}.login-emblem{width:64px;height:64px;margin-bottom:16px;position:relative;display:flex;align-items:center;justify-content:center;filter:drop-shadow(0 0 14px rgba(200,168,80,.45));animation:emberBreath 4.5s ease-in-out infinite}@keyframes emberBreath{0%,to{filter:drop-shadow(0 0 10px rgba(200,168,80,.35));transform:scale(1)}50%{filter:drop-shadow(0 0 20px rgba(240,160,64,.6));transform:scale(1.04)}}@media (prefers-reduced-motion: reduce){.login-emblem{animation:none}}.ls-divider{display:flex;align-items:center;gap:10px;margin-bottom:36px}.ls-line{flex:1;height:1px;background:var(--border)}.ls-badge{font-family:Cinzel,serif;font-size:9.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-3);white-space:nowrap}.ls-quote{margin:0;padding:0;border:none}.ls-quote p{font-family:"Noto Serif TC",serif;font-size:14px;color:var(--text-2);line-height:1.9;margin-bottom:20px;font-style:italic}.ls-highlight{font-style:normal!important;font-weight:700!important;color:var(--text)!important;margin-bottom:0!important;padding:13px 16px;border-left:3px solid var(--gold-dim);background:var(--gold-bg);border-radius:0 8px 8px 0}.login-form-panel{display:flex;flex-direction:column;justify-content:center;padding:52px 48px;width:100%;position:relative;isolation:isolate;background:radial-gradient(120% 70% at 78% 20%,rgba(200,168,80,.06) 0%,transparent 55%)}.login-form-inner{max-width:380px;margin:0 auto;width:100%}.lc-npc{display:flex;gap:12px;margin-bottom:24px;align-items:flex-start}.lc-npc-avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;background:var(--gold-bg);border:1.5px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:13px;font-weight:700;color:var(--gold)}.lc-npc-bubble{background:var(--surface-2);border:1px solid var(--border);border-radius:0 12px 12px;padding:11px 15px;font-size:13px;color:var(--text-2);line-height:1.65;font-family:"Noto Serif TC",serif;position:relative}.lc-npc-bubble:before{content:"";position:absolute;top:13px;left:-7px;border:6px solid transparent;border-right-color:var(--border)}.lc-npc-bubble:after{content:"";position:absolute;top:14px;left:-5px;border:5px solid transparent;border-right-color:var(--surface-2)}.login-tabs{display:flex;border-bottom:1px solid var(--border)}.login-tab{flex:1;padding:12px;text-align:center;font-size:12.5px;font-weight:600;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease;background:none;border-top:none;border-left:none;border-right:none;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:6px}.login-tab:hover{color:var(--text-2)}.login-tab.active{color:var(--gold);border-bottom-color:var(--gold)}.login-bd{padding:22px 0}.login-bd .form-group+.form-group{margin-top:13px}@media (max-width:768px){.login-page{grid-template-columns:1fr}.login-story{padding:40px 28px;border-right:none;border-bottom:1px solid var(--border)}.ls-brand{font-size:30px}.ls-quote p{font-size:13px}.login-form-panel{padding:32px 24px}}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:20px}.tab{padding:9px 16px;font-size:12.5px;font-weight:600;color:var(--text-3);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s ease;background:none;border-top:none;border-left:none;border-right:none;display:flex;align-items:center;gap:6px;font-family:inherit}.tab:hover{color:var(--text-2)}.tab.active{color:var(--gold);border-bottom-color:var(--gold)}.tab svg{width:14px;height:14px}.type-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.type-filter{padding:3px 11px;border-radius:100px;font-size:11px;font-weight:600;background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);cursor:pointer;transition:all .15s ease;font-family:inherit}.type-filter:hover,.type-filter.active{border-color:var(--gold-dim);color:var(--gold);background:var(--gold-bg)}.sort-bar{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:-8px 0 20px}.sort-bar-label{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--text-3);letter-spacing:.04em}.sort-seg{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden;background:var(--surface-2)}.sort-seg button{padding:4px 12px;font-size:11px;font-weight:600;background:none;border:none;color:var(--text-2);cursor:pointer;font-family:inherit;transition:all .15s ease}.sort-seg button+button{border-left:1px solid var(--border)}.sort-seg button:hover{color:var(--gold)}.sort-seg button.active{background:var(--gold-bg);color:var(--gold)}.member-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);gap:10px;animation:cardIn .35s cubic-bezier(.16,1,.3,1) forwards;animation-delay:calc(var(--i,0)*40ms)}.m-info{display:flex;align-items:center;gap:10px}.m-avatar{width:32px;height:32px;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:Cinzel,serif;font-size:12px;font-weight:700;color:var(--text-2);flex-shrink:0}.m-name{font-size:13px;font-weight:600;color:var(--text)}.m-id{font-size:10px;color:var(--text-3);font-family:monospace}.friend-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--r-sm);transition:background .15s ease}.friend-item:hover{background:var(--surface-2)}.af-result{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:9px 11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-sm);animation:cardIn .3s cubic-bezier(.16,1,.3,1) forwards}.af-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px 0;color:var(--text-3);font-size:12.5px}.af-tag{font-size:11px;color:var(--text-3);font-weight:600}.cd-urgent{color:var(--danger)!important}.cd-warn{color:var(--warning)!important}.cd-ok{color:var(--success)!important}.cd-long{color:var(--text-3)!important}.bottom-dock{position:fixed;bottom:20px;left:50%;transform:translate(-50%);z-index:var(--z-sidebar);background:var(--surface);border:1px solid var(--border);border-radius:100px;box-shadow:0 8px 32px #0000004d,0 2px 8px #0003;padding:8px 10px}[data-theme=dark] .bottom-dock{background:#1a1410e6;box-shadow:0 8px 32px #0009,0 0 0 1px #c8a8501f,0 2px 8px #0006;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.bd-inner{display:flex;align-items:center;gap:2px}.bd-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:9px 18px;border-radius:80px;cursor:pointer;color:var(--text-3);background:none;border:none;font-family:inherit;transition:all .2s ease;position:relative;min-width:68px}.bd-item:hover{color:var(--text-2);background:var(--surface-2)}.bd-item.active{color:var(--gold);background:var(--gold-bg);box-shadow:0 0 0 1px var(--gold-dim)}.bd-icon-wrap{position:relative;display:flex}.bd-dot{position:absolute;top:-5px;right:-9px;background:var(--danger-strong);color:#fff;border-radius:50%;width:16px;height:16px;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center}.bd-label{font-size:10px;font-weight:600;letter-spacing:.04em;white-space:nowrap}@keyframes cardIn{0%{transform:translateY(14px)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{transform:scale(.95) translateY(10px)}to{transform:scale(1) translateY(0)}}@keyframes pageIn{0%{transform:translate(18px)}to{transform:translate(0)}}@keyframes urgentGlow{0%,to{box-shadow:0 0 #c8323200}50%{box-shadow:0 0 0 7px #c832321f}}@keyframes urgentPulse{0%,to{opacity:1}50%{opacity:.65}}.page-in{animation:pageIn .35s cubic-bezier(.16,1,.3,1) forwards}.chat-modal{display:flex;flex-direction:column;height:520px}.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px;background:var(--surface-2)}.chat-bubble-wrap{display:flex}.chat-bubble-wrap.mine{justify-content:flex-end}.chat-bubble{max-width:75%;background:var(--surface);border:1px solid var(--border);border-radius:12px 12px 12px 3px;padding:9px 13px}.chat-bubble.mine{background:var(--gold-bg);border-color:var(--gold-dim);border-radius:12px 12px 3px}.chat-content{font-size:13.5px;color:var(--text);line-height:1.5;white-space:pre-wrap;word-break:break-word}.chat-time{font-size:10px;color:var(--text-3);text-align:right;margin-top:3px;display:flex;align-items:center;justify-content:flex-end;gap:2px}.chat-input-row{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);background:var(--surface)}.chat-input{flex:1;min-width:0;background:var(--surface-2);border:1px solid var(--border);border-radius:100px;padding:8px 14px;font-size:13px;font-family:inherit;color:var(--text);outline:none;transition:border-color .15s ease}.chat-input:focus{border-color:var(--gold-dim)}.notif-item{display:flex;align-items:flex-start;gap:12px;padding:13px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);transition:background .15s ease,border-color .15s ease,opacity .2s ease}.notif-item:not(.is-read){box-shadow:inset 3px 0 0 var(--gold)}.notif-item.is-read{opacity:.7}.notif-item.is-read .notif-title{font-weight:500;color:var(--text-3)}.notif-item.is-read .notif-body{color:var(--text-3)}.notif-item.is-read .notif-dot{background:var(--surface-3);border-color:var(--border)}.notif-item.is-clickable{cursor:pointer}.notif-item.is-clickable:hover{background:var(--surface-2);border-color:var(--border-glow)}.notif-item.is-clickable:hover svg{color:var(--text-2)!important}.notif-dot{width:9px;height:9px;border-radius:50%;border:1.5px solid;flex-shrink:0;margin-top:4px;background:var(--gold);border-color:var(--gold-dim)}.notif-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}.notif-body{font-size:12px;color:var(--text-2)}.journal-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 16px;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.journal-item:hover{transform:translateY(-2px);border-color:var(--border-glow);box-shadow:0 6px 20px #0003}@keyframes spin{to{transform:rotate(360deg)}}.door-reveal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;display:flex;pointer-events:none;perspective:1200px;perspective-origin:50% 50%;overflow:hidden}.door-reveal .door-glow{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(ellipse 60% 75% at 50% 48%,rgba(var(--gold-r),var(--gold-g),var(--gold-b),.45),rgba(var(--gold-r),var(--gold-g),var(--gold-b),0) 70%);opacity:0;transition:opacity .9s ease .35s}.door-reveal.is-open .door-glow{opacity:1}.door-panel{position:relative;z-index:1;flex:0 0 50%;height:100%;background:repeating-linear-gradient(90deg,rgba(0,0,0,.32) 0 1px,transparent 1px 4px),repeating-linear-gradient(90deg,transparent 0 78px,rgba(0,0,0,.4) 78px 80px),linear-gradient(90deg,#3a2917,#4a3520 28%,#56401f,#4a3520 72%,#34230f);box-shadow:inset 0 0 120px #0000008c;transform-style:preserve-3d;transition:transform 1s cubic-bezier(.22,.61,.36,1),filter .5s ease;backface-visibility:hidden;will-change:transform}.door-left{transform-origin:left center;border-right:2px solid rgba(0,0,0,.5)}.door-right{transform-origin:right center;border-left:1px solid rgba(var(--gold-r),var(--gold-g),var(--gold-b),.25)}.door-panel:before{content:"";position:absolute;top:26px;right:26px;bottom:26px;left:26px;border:2px solid rgba(var(--gold-r),var(--gold-g),var(--gold-b),.55);border-radius:4px;box-shadow:inset 0 0 0 6px #00000040,inset 0 0 30px #0006}.door-panel:after{content:"";position:absolute;top:46px;right:46px;bottom:46px;left:46px;border:1px solid rgba(0,0,0,.45);border-radius:3px;box-shadow:inset 0 0 40px #00000080,inset 0 1px #ffdc960f}.door-stud{position:absolute;width:11px;height:11px;border-radius:50%;z-index:2;background:radial-gradient(circle at 35% 30%,#8a7a5a,#2a2018 70%);box-shadow:0 1px 2px #0009}.door-stud.s1{top:36px;left:36px}.door-stud.s2{top:36px;right:36px}.door-stud.s3{bottom:36px;left:36px}.door-stud.s4{bottom:36px;right:36px}.door-seal{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;color:rgba(var(--gold-r),var(--gold-g),var(--gold-b),.78);filter:drop-shadow(0 2px 3px rgba(0,0,0,.6))}.door-left .door-seal{transform:translate(-50%,-50%)}.door-handle{position:absolute;top:50%;width:26px;height:26px;z-index:2;border:4px solid #b8a060;border-radius:50%;background:radial-gradient(circle at 40% 35%,rgba(255,235,180,.5),transparent 60%);box-shadow:0 2px 5px #0009,inset 0 0 6px #0006;transform:translateY(-50%)}.door-left .door-handle{right:34px}.door-right .door-handle{left:34px}.door-reveal.is-open .door-left{transform:translate(-96%) rotateY(58deg)}.door-reveal.is-open .door-right{transform:translate(96%) rotateY(-58deg)}.door-reveal.is-open{animation:doorFadeOut .3s ease .72s forwards}@keyframes doorFadeOut{to{opacity:0;visibility:hidden}}@media (max-width:768px){.door-seal svg{width:84px;height:84px}.door-panel:before{top:18px;right:18px;bottom:18px;left:18px}.door-panel:after{top:34px;right:34px;bottom:34px;left:34px}}@media (prefers-reduced-motion:reduce){.door-panel{transition:opacity .4s ease}.door-reveal.is-open .door-left,.door-reveal.is-open .door-right{transform:none;opacity:0;filter:none}}@media (max-width:768px){.top-bar{padding:0 14px}.tb-brand-name{display:none}.tb-breadcrumb{padding:0 10px}.main-content{padding-bottom:calc(var(--dock-h) + 32px)}.page-content{padding:14px 16px}.page-header{padding:13px 16px;flex-direction:column;align-items:stretch;gap:10px}.page-header>div:last-child{flex-wrap:wrap}.ph-back{white-space:nowrap}.ph-title{font-size:14px}input,select,textarea,.input,.chat-input,.qs-input,.qs-textarea{font-size:16px}input[type=datetime-local]{-webkit-appearance:none;-moz-appearance:none;appearance:none;min-width:0;max-width:100%;box-sizing:border-box}.room-grid{grid-template-columns:1fr}.g2{grid-template-columns:1fr;gap:10px}.bd-item{min-width:56px;padding:9px 12px}.bd-label{font-size:9.5px}}.ach-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:100px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-3);cursor:pointer;font:inherit;text-align:left;transition:transform .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease),background .18s var(--ease)}.ach-badge:hover{transform:translateY(-2px);border-color:var(--gold-dim)}.ach-badge:active{transform:translateY(0)}.ach-badge.is-unlocked{color:var(--gold);border-color:var(--gold-dim);background:var(--gold-bg)}.ach-badge.is-unlocked:hover{box-shadow:0 0 0 3px var(--border-glow),0 4px 14px -6px rgba(var(--gold-r),var(--gold-g),var(--gold-b),.5)}.ach-badge.is-open{border-color:var(--gold);box-shadow:0 0 0 2px var(--border-glow)}.ach-badge-icon{flex-shrink:0}.ach-badge-text{display:inline-flex;flex-direction:column;line-height:1.25}.ach-badge-name{font-size:13px;font-weight:600}.ach-badge-sub{font-size:11px;opacity:.8;font-variant-numeric:tabular-nums}.ach-pop-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:calc(var(--z-modal) - 1)}.ach-pop{position:fixed;z-index:var(--z-modal);width:272px;max-width:calc(100vw - 24px);padding:16px;border-radius:var(--r-lg);background:linear-gradient(160deg,var(--surface-3),var(--surface));border:1px solid var(--gold-dim);box-shadow:0 18px 48px -16px #0009,0 0 0 1px var(--border-glow) inset;transform-origin:top left;animation:achPopIn .26s var(--ease) both}.ach-pop.place-above{transform-origin:bottom left}@keyframes achPopIn{0%{opacity:0;transform:scale(.94) translateY(-6px)}to{opacity:1;transform:scale(1) translateY(0)}}.ach-pop.place-above{animation-name:achPopInUp}@keyframes achPopInUp{0%{opacity:0;transform:scale(.94) translateY(6px)}to{opacity:1;transform:scale(1) translateY(0)}}.ach-pop-arrow{position:absolute;width:11px;height:11px;rotate:45deg;background:var(--surface-3);border:1px solid var(--gold-dim)}.ach-pop:not(.place-above) .ach-pop-arrow{top:-6px;border-right:none;border-bottom:none}.ach-pop.place-above .ach-pop-arrow{bottom:-6px;border-left:none;border-top:none}.ach-pop-head{display:flex;align-items:center;gap:12px}.ach-pop-medal{flex-shrink:0;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;border:1.5px dashed var(--border);color:var(--text-3);background:var(--surface)}.ach-pop-medal svg{width:22px;height:22px}.ach-pop-medal.is-unlocked{border:1.5px solid var(--gold);color:var(--gold);background:radial-gradient(circle at 50% 35%,var(--gold-bg),transparent 70%);box-shadow:0 0 0 4px var(--border-glow),0 6px 16px -8px rgba(var(--gold-r),var(--gold-g),var(--gold-b),.55)}.ach-pop-medal.is-unlocked:after{content:"";position:absolute;width:46px;height:46px;border-radius:50%;box-shadow:0 0 rgba(var(--gold-r),var(--gold-g),var(--gold-b),.35);animation:achMedalPulse 2.4s var(--ease) infinite}@keyframes achMedalPulse{0%,to{box-shadow:0 0 rgba(var(--gold-r),var(--gold-g),var(--gold-b),.32)}50%{box-shadow:0 0 0 7px rgba(var(--gold-r),var(--gold-g),var(--gold-b),0)}}.ach-pop-titlewrap{min-width:0}.ach-pop-category{font-size:10px;font-weight:600;letter-spacing:.08em;color:var(--text-3);margin-bottom:1px}.ach-pop-name{font-family:"Noto Serif TC",serif;font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px}.ach-pop-lv{font-size:10px;font-weight:700;letter-spacing:.04em;padding:1px 7px;border-radius:100px;color:var(--gold);background:var(--gold-bg);border:1px solid var(--gold-dim)}.ach-pop-desc{margin-top:2px;font-size:12px;color:var(--text-3);line-height:1.4}.ach-pop-ladder{display:flex;align-items:flex-start;gap:4px;margin-top:14px}.ach-pop-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;position:relative}.ach-pop-step:before{content:"";position:absolute;top:5px;left:-50%;width:100%;height:2px;background:var(--border)}.ach-pop-step:first-child:before{display:none}.ach-pop-step.reached:before{background:var(--gold)}.ach-pop-pip{width:11px;height:11px;border-radius:50%;z-index:1;background:var(--surface);border:2px solid var(--border);transition:all .2s var(--ease)}.ach-pop-step.reached .ach-pop-pip{background:var(--gold);border-color:var(--gold)}.ach-pop-step.current .ach-pop-pip{border-color:var(--gold);background:var(--surface);box-shadow:0 0 0 3px var(--border-glow);animation:achPipPulse 1.6s var(--ease) infinite}@keyframes achPipPulse{0%,to{box-shadow:0 0 0 2px var(--border-glow)}50%{box-shadow:0 0 0 5px rgba(var(--gold-r),var(--gold-g),var(--gold-b),.05)}}.ach-pop-step-label{font-size:9.5px;color:var(--text-3);font-variant-numeric:tabular-nums}.ach-pop-step.reached .ach-pop-step-label{color:var(--gold);font-weight:600}.ach-pop-bar{margin-top:14px;height:7px;border-radius:100px;background:var(--surface);overflow:hidden;border:1px solid var(--border)}.ach-pop-bar-fill{height:100%;border-radius:100px;background:linear-gradient(90deg,var(--gold-dim),var(--gold));position:relative;transition:width .5s var(--ease)}.ach-pop-bar-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);animation:achShimmer 1.8s linear infinite}.ach-pop-foot{margin-top:8px;display:flex;align-items:center;justify-content:space-between;gap:8px}.ach-pop-hint{font-size:11.5px;color:var(--text-3)}.ach-pop-hint.done{color:var(--gold);font-weight:600}.ach-pop-count{font-size:11.5px;color:var(--text-2);font-variant-numeric:tabular-nums;font-weight:600}@keyframes achShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media (prefers-reduced-motion: reduce){.ach-pop,.ach-pop-medal.is-unlocked:after,.ach-pop-step.current .ach-pop-pip,.ach-pop-bar-fill:after{animation:none}}.toast-loader{position:relative;display:grid;place-items:center;width:var(--toast-sz,64px);height:var(--toast-sz,64px)}.toast-loader .tl-glow{position:absolute;top:12%;right:12%;bottom:12%;left:12%;border-radius:50%;background:radial-gradient(circle,var(--gold-bg) 0%,transparent 64%);animation:toastGlow 1.9s ease-in-out infinite}.toast-loader svg{position:relative;width:62%;height:62%;overflow:visible}.tl-cup{transform-box:fill-box;transform-origin:center bottom}.tl-cup-l{animation:toastClinkL 1.9s ease-in-out infinite}.tl-cup-r{animation:toastClinkR 1.9s ease-in-out infinite}.tl-draw{animation:toastDraw 1.9s ease-in-out infinite}.tl-foot{opacity:.4}@keyframes toastGlow{0%,to{opacity:.32;transform:scale(.88)}38%{opacity:1;transform:scale(1.18)}52%{opacity:.78;transform:scale(1.06)}}@keyframes toastSpark{0%,30%{opacity:0;transform:scale(.3)}40%{opacity:1;transform:scale(1.35)}55%{opacity:.95;transform:scale(1)}72%{opacity:.4;transform:scale(.9)}to{opacity:0;transform:scale(.3)}}@keyframes toastRipple{0%,34%{opacity:0;transform:scale(.2)}42%{opacity:.7;transform:scale(.7)}72%{opacity:0;transform:scale(1.9)}to{opacity:0}}@keyframes toastDraw{0%{stroke-dashoffset:var(--len)}38%{stroke-dashoffset:0}74%{stroke-dashoffset:0}to{stroke-dashoffset:var(--len)}}@keyframes toastClinkL{0%{transform:translate(-7px) rotate(-5deg)}38%{transform:translate(0) rotate(0)}46%{transform:translate(2px) rotate(2deg)}60%{transform:translate(0) rotate(0)}74%{transform:translate(-7px) rotate(-5deg)}to{transform:translate(-7px) rotate(-5deg)}}@keyframes toastClinkR{0%{transform:translate(7px) rotate(5deg)}38%{transform:translate(0) rotate(0)}46%{transform:translate(-2px) rotate(-2deg)}60%{transform:translate(0) rotate(0)}74%{transform:translate(7px) rotate(5deg)}to{transform:translate(7px) rotate(5deg)}}.tl-spark{transform-box:fill-box;transform-origin:center;animation:toastSpark 1.9s ease-in-out infinite}.tl-ripple{transform-box:fill-box;transform-origin:center;animation:toastRipple 1.9s ease-out infinite}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:150;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.loading-overlay.is-action{background:var(--overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-overlay.is-page{background:var(--bg)}.loading-inner{display:flex;flex-direction:column;align-items:center;gap:14px;color:var(--text-2);font-family:Cinzel,serif;font-size:13px;letter-spacing:.04em}.tavern-spinner{display:inline-block;color:var(--gold);animation:spin 1s linear infinite;vertical-align:middle}.skeleton{position:relative;overflow:hidden;display:block;background:var(--surface-2);border-radius:8px}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(var(--gold-r),var(--gold-g),var(--gold-b),.07),transparent);animation:achShimmer 1.5s ease-in-out infinite}@media (prefers-reduced-motion: reduce){.toast-loader .tl-glow,.tl-cup-l,.tl-cup-r,.tl-draw,.tl-spark,.tl-ripple,.tavern-spinner,.skeleton:after{animation:none}.tl-draw{stroke-dashoffset:0}.tl-spark{opacity:1}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.visible{visibility:visible}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-50{z-index:50}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.contents{display:contents}.hidden{display:none}.h-1\.5{height:.375rem}.h-12{height:3rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-full{height:100%}.w-12{width:3rem}.w-24{width:6rem}.w-3\.5{width:.875rem}.w-32{width:8rem}.w-4{width:1rem}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity, 1))}.bg-amber-600{--tw-bg-opacity: 1;background-color:rgb(217 119 6 / var(--tw-bg-opacity, 1))}.bg-parchment-200{--tw-bg-opacity: 1;background-color:rgb(239 235 233 / var(--tw-bg-opacity, 1))}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.uppercase{text-transform:uppercase}.text-parchment-500{--tw-text-opacity: 1;color:rgb(121 85 72 / var(--tw-text-opacity, 1))}.text-parchment-700{--tw-text-opacity: 1;color:rgb(93 64 55 / var(--tw-text-opacity, 1))}.text-parchment-900{--tw-text-opacity: 1;color:rgb(62 39 35 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.underline{text-decoration-line:underline}.opacity-30{opacity:.3}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.blur{--tw-blur: blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}html,body,#root{height:100%}
