:root{--crimson: #7c1f1f;--crimson-2: #5f1616;--crimson-bright: #9e2b25;--gold: #b08d57;--gold-light: #c9a877;--gold-deep: #8f6f3c;--paper: #ece3cf;--paper-2: #e4d9c1;--surface: #fdfbf5;--line: #cfc3a6;--ink: #2a241d;--text: #38312a;--muted: #7c7260;--danger: #9c2f26;--shadow: 0 1px 3px rgba(60, 40, 20, .1);--serif: "Noto Serif TC", "Songti TC", "STSong", "PingFang TC", serif;--sans: "PingFang TC", "Noto Sans TC", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--sans);background:var(--paper);color:var(--text);-webkit-font-smoothing:antialiased}h1,h2,h3,legend{font-family:var(--serif);letter-spacing:.08em;color:var(--ink)}.ruled{position:relative;padding-bottom:12px}.ruled:after{content:"";position:absolute;left:0;bottom:0;width:72px;height:3px;border-top:1px solid var(--gold);background:var(--gold);box-shadow:0 3px 0 -1px var(--gold-light)}.login{position:relative;display:grid;place-items:center;min-height:100vh;padding:16px;background:radial-gradient(1100px 560px at 50% -160px,rgba(124,31,31,.1),transparent 60%),url(/login-pattern.svg) center / 360px 360px,linear-gradient(165deg,#f4eedd,#ece2cb 55%,#ddd0b3)}.login:before{content:"";position:fixed;top:18px;right:18px;bottom:18px;left:18px;border:1px solid rgba(176,141,87,.45);pointer-events:none}.login form{position:relative;z-index:1;display:flex;flex-direction:column;gap:14px;text-align:center;background:var(--surface);padding:40px 36px 34px;width:min(372px,100%);border:1px solid var(--gold);border-top:4px double var(--gold-deep);box-shadow:0 14px 36px #462d1938}.login-field{display:flex;flex-direction:column;gap:6px;text-align:left}.login-field>span{font-size:12px;color:var(--muted);letter-spacing:.1em}.pw-wrap{position:relative;display:flex}.pw-wrap input{flex:1;padding-right:58px}.login .pw-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);margin:0;padding:6px 10px;background:transparent;color:var(--gold-deep);border:0;font-size:12px;letter-spacing:0;cursor:pointer}.login .pw-toggle:hover{color:var(--crimson);background:transparent}.login-row{display:flex;align-items:center;justify-content:space-between;font-size:13px;margin-top:2px}.remember{display:flex;align-items:center;gap:6px;color:var(--text);cursor:pointer}.remember input{width:auto;padding:0;accent-color:var(--crimson)}.login .link{margin:0;padding:0;background:transparent;color:var(--gold-deep);border:0;font-size:13px;letter-spacing:0;cursor:pointer;text-decoration:underline}.login .link:hover{color:var(--crimson);background:transparent}.login button[type=submit]:disabled{opacity:.55;cursor:default}.info{color:var(--gold-deep);font-size:13px;margin:4px 0 0}.login-crest,.crest{display:block;object-fit:contain;background:none;border:0}.login-crest{width:64px;height:64px;margin:0 auto 4px}.login h1{font-size:20px;margin:0;color:var(--crimson);line-height:1.5}.login-sub{margin:-6px 0 6px;color:var(--muted);font-size:12px;letter-spacing:.12em}.login input{padding:11px 12px;border:1px solid var(--line);font-size:15px;background:#fcfaf3}.login input:focus{outline:2px solid var(--gold-light);border-color:var(--gold)}.login button{margin-top:4px;padding:12px;background:var(--crimson);color:#fff;border:0;cursor:pointer;font-size:15px;letter-spacing:.18em}.login button:hover{background:var(--crimson-2)}.err{color:var(--danger);font-size:13px;margin:4px 0 0}.demo{margin-top:6px;border-top:1px solid var(--line);padding-top:12px}.login .demo-toggle{font-size:12px;letter-spacing:.1em;text-decoration:none}.login .demo-toggle:before{content:"▸ "}.demo-list{margin-top:10px;display:flex;flex-direction:column;gap:6px}.demo-hint{margin:0 0 2px;font-size:12px;color:var(--muted);text-align:left}.demo-hint code{font-family:var(--mono, monospace);background:#f0e8d6;border:1px solid var(--line);padding:0 4px;color:var(--crimson)}.login .demo-row{display:flex;flex-direction:column;gap:1px;align-items:flex-start;margin:0;padding:7px 10px;background:#fcfaf3;color:var(--text);border:1px solid var(--line);cursor:pointer;letter-spacing:0}.login .demo-row:hover{background:#f3ead7;border-color:var(--gold)}.demo-user{font-size:13px;font-weight:600;color:var(--crimson)}.demo-meta{font-size:11px;color:var(--muted)}.app-shell{display:flex;flex-direction:column;height:100vh}.topbar{position:relative;display:flex;align-items:center;gap:24px;background:var(--crimson);border-bottom:4px double var(--gold-light);box-shadow:inset 0 -1px #00000040;padding:0 22px;height:62px;color:#fff;flex-shrink:0}.brand{display:flex;align-items:center;gap:12px}.crest{width:40px;height:40px;font-size:15px}.brand-text h1{font-size:17px;margin:0;color:#fff;letter-spacing:.1em}.brand-sub{font-size:10px;color:var(--gold-light);letter-spacing:.16em}.tabs{display:flex;gap:2px;margin-left:14px;flex:1}.tabs button{background:transparent;color:#ecdccd;border:0;border-bottom:3px solid transparent;padding:8px 20px;font-size:15px;cursor:pointer;font-family:var(--serif);letter-spacing:.12em;margin-bottom:-4px}.tabs button:hover{color:#fff}.tabs button.active{color:#fff;border-bottom-color:var(--gold-light)}.user-chip{display:flex;flex-direction:column;align-items:flex-end;line-height:1.4}.user-chip .role{font-size:11px;color:var(--crimson);background:var(--gold-light);padding:1px 8px;letter-spacing:.05em}.user-chip .name{font-size:13px;color:#fff}.logout-btn{background:transparent;color:var(--gold-light);border:1px solid var(--gold);padding:6px 14px;font-size:13px;cursor:pointer;letter-spacing:.08em;font-family:var(--serif)}.logout-btn:hover{background:var(--gold-light);color:var(--crimson)}.content{flex:1;overflow:hidden}.browse{display:grid;grid-template-columns:240px 1fr;height:100%}.cat-rail{background:var(--paper-2);border-right:1px solid var(--line);overflow-y:auto;padding:14px 10px}.cat-group{margin-bottom:10px}.cat{display:flex;justify-content:space-between;align-items:center;width:100%;gap:8px;text-align:left;background:transparent;border:0;cursor:pointer;padding:7px 10px;font-size:14px;color:var(--text)}.cat:hover{background:#b08d5733}.cat.active{background:var(--crimson);color:#fff}.cat.main{font-family:var(--serif);font-weight:600;color:var(--crimson)}.cat.main.active{color:#fff}.cat.sub{padding-left:22px;font-size:13px;color:#5b544a}.cat .n{font-size:11px;color:var(--muted)}.cat.active .n{color:var(--gold-light)}.results{display:flex;flex-direction:column;overflow:hidden}.searchbar{display:flex;gap:10px;align-items:center;padding:16px 20px;background:var(--surface);border-bottom:1px solid var(--line)}.searchbar input{flex:1;max-width:460px;padding:10px 14px;border:1px solid var(--line);font-size:15px;background:#fcfaf3}.searchbar select{padding:10px;border:1px solid var(--line);background:#fcfaf3}.searchbar button{padding:10px 22px;background:var(--crimson);color:#fff;border:0;cursor:pointer;font-size:14px;letter-spacing:.1em}.searchbar button:hover{background:var(--crimson-2)}.searchbar .count{color:var(--muted);font-size:13px;margin-left:auto}.searchbar input:focus,.searchbar select:focus{outline:2px solid var(--gold-light)}.searchbar .new-btn{padding:10px 18px;background:var(--surface);color:var(--crimson);border:1px solid var(--gold);letter-spacing:.08em}.searchbar .new-btn:hover{background:var(--crimson);color:#fff;border-color:var(--crimson)}.grid{flex:1;overflow-y:auto;padding:20px;display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:18px;align-content:start}.card{position:relative;display:flex;flex-direction:column;text-align:left;padding:0;background:var(--surface);border:1px solid var(--line);cursor:pointer;overflow:hidden;box-shadow:var(--shadow);transition:border-color .1s,box-shadow .1s}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--crimson);opacity:0;transition:opacity .1s;z-index:1}.card:hover{border-color:var(--gold);box-shadow:0 3px 10px #3c281429}.card:hover:before{opacity:1}.review-star{position:absolute;top:6px;right:6px;z-index:2;width:30px;height:30px;padding:0;line-height:1;border:0;cursor:pointer;font-size:20px;background:#fdfbf5d9;color:var(--muted);box-shadow:0 1px 3px #3c281433}.review-star:hover{color:var(--gold-deep);background:#fff}.review-star.on{color:#c9a200;background:#fff}.card .thumb{aspect-ratio:4 / 3;background:var(--paper-2);display:grid;place-items:center;overflow:hidden}.card .thumb img{width:100%;height:100%;object-fit:cover}.card .noimg{color:var(--muted);font-size:13px}.card-body{padding:10px 12px;display:flex;flex-direction:column;gap:3px}.card-body strong{font-size:15px;color:var(--ink);font-family:var(--serif)}.card-body .code{font-size:11px;color:var(--muted);font-family:ui-monospace,monospace}.card-body .tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.card-body em{font-style:normal;font-size:11px;padding:1px 7px;background:var(--paper-2);color:#5b544a;border:1px solid var(--line)}.card-body em.grade{background:var(--crimson);color:#fff;border-color:var(--crimson)}.pager{display:flex;gap:16px;align-items:center;justify-content:center;padding:14px;border-top:1px solid var(--line);background:var(--surface)}.pager button{padding:7px 16px;border:1px solid var(--line);background:var(--surface);cursor:pointer}.pager button:disabled{opacity:.4;cursor:default}.hint{color:var(--muted);padding:40px;text-align:center;grid-column:1 / -1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e0e0e94;display:grid;place-items:center;z-index:50;padding:24px}.modal{background:var(--surface);width:min(960px,96vw);max-height:92vh;border:1px solid var(--gold);border-top:4px double var(--gold-deep);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 16px 40px #00000061}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-bottom:1px solid var(--line);background:var(--paper-2)}.modal-head h2{margin:0;font-size:20px;color:var(--crimson)}.modal-head h2 small{color:var(--muted);font-family:ui-monospace,monospace;font-size:12px;margin-left:10px}.modal-head .close{background:none;border:0;font-size:20px;cursor:pointer;color:var(--muted)}.modal-body{display:grid;grid-template-columns:1.3fr 1fr;gap:0;overflow:hidden}.modal-viewer{background:#15100e;min-height:420px}.modal-body .meta{padding:22px;overflow-y:auto}.modal-head-actions{display:flex;align-items:center;gap:12px}.edit-btn{background:var(--crimson);color:#fff;border:0;padding:7px 18px;font-size:13px;cursor:pointer;letter-spacing:1px}.edit-btn:hover{background:var(--crimson-2)}.delete-btn{background:transparent;color:var(--danger);border:1px solid var(--danger);padding:7px 16px;font-size:13px;cursor:pointer;letter-spacing:1px}.delete-btn:hover{background:var(--danger);color:#fff}.delete-btn:disabled{opacity:.55;cursor:default}.modal-edit .modal-body{display:block;overflow-y:auto}.modal-edit .field-form-wrap{padding:0;background:var(--surface)}.form-actions{display:flex;gap:12px;align-items:center}.existing-media{margin-bottom:12px}.workbench{display:grid;grid-template-columns:240px minmax(340px,1fr) minmax(420px,1.3fr);height:100%}.workbench .nav{overflow-y:auto;background:var(--paper-2);border-right:1px solid var(--line);padding:10px}.workbench .nav button{display:block;width:100%;text-align:left;padding:10px 12px;margin-bottom:4px;background:transparent;color:var(--text);border:0;cursor:pointer;font-size:13px}.workbench .nav button:hover{background:#b08d5733}.workbench .nav button.active{background:var(--crimson);color:#fff}.left-panel{padding:22px 26px;overflow-y:auto;background:var(--surface)}.left-panel h2{margin:0 0 16px;color:var(--crimson)}.left-panel h2 small{display:block;color:var(--muted);font-size:13px;font-family:ui-monospace,monospace}.meta{display:grid;grid-template-columns:84px 1fr;gap:8px 14px;font-size:14px}.meta dt{color:var(--muted)}.meta dd{margin:0;line-height:1.6}.grading{margin-top:22px;border:1px solid var(--line);padding:18px;display:flex;flex-direction:column;gap:9px;background:#fcfaf3}.grading legend{font-weight:600;padding:8px 0 2px;color:var(--crimson)}.radio{display:flex;align-items:center;gap:7px;font-size:14px}.score{display:flex;gap:8px;align-items:center}.score input{width:80px;padding:7px;border:1px solid var(--line)}.grading textarea{min-height:72px;padding:9px;border:1px solid var(--line);font-family:var(--sans)}.grading button{margin-top:6px;padding:11px;background:var(--crimson);color:#fff;border:0;cursor:pointer;font-size:14px;letter-spacing:.12em}.grading button:hover{background:var(--crimson-2)}.msg{color:var(--crimson);font-size:13px}.msg.ok{color:var(--gold-deep)}.msg:not(.ok){color:var(--danger)}.right-panel{background:#15100e;display:flex;flex-direction:column}.image-viewer{display:flex;flex-direction:column;height:100%}.image-viewer .stage{flex:1;display:grid;place-items:center;-webkit-user-select:none;user-select:none}.image-viewer .stage img{max-width:100%;max-height:100%}.image-viewer .toolbar{display:flex;gap:8px;align-items:center;padding:8px 12px;background:#221917;color:#e6d8c8}.image-viewer .toolbar button{background:#3a2a26;color:#fff;border:0;padding:6px 10px;cursor:pointer}.image-viewer .thumbs{display:flex;gap:6px;padding:8px;background:#1b1310;overflow-x:auto}.image-viewer .thumbs img{width:56px;height:56px;object-fit:cover;cursor:pointer;opacity:.6}.image-viewer .thumbs img.active{opacity:1;outline:2px solid var(--gold)}.viewer.empty{color:var(--muted);display:grid;place-items:center;height:100%}.field-form-wrap{height:100%;overflow-y:auto;padding:28px;background:var(--paper)}.field-form{max-width:880px;margin:0 auto;background:var(--surface);border:1px solid var(--line);border-top:4px double var(--gold-deep);padding:30px 34px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow)}.field-form h2{margin:0 0 6px;color:var(--crimson);text-align:center}.field-form label{display:flex;flex-direction:column;gap:5px;font-size:14px;color:var(--ink)}.field-form input,.field-form textarea,.field-form select{padding:10px 12px;border:1px solid var(--line);font-size:15px;background:#fcfaf3;font-family:var(--sans);color:var(--text)}.field-form input:focus,.field-form textarea:focus,.field-form select:focus{outline:2px solid var(--gold-light)}.field-form .row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;align-items:end}.field-form fieldset{border:1px solid var(--line);padding:14px 16px;margin:0;background:#fcfaf3}.field-form legend{font-family:var(--serif);font-weight:600;color:var(--crimson);padding:0 6px}.chips{display:flex;flex-wrap:wrap;gap:7px}.chip{padding:5px 12px;border:1px solid var(--line);background:var(--surface);cursor:pointer;font-size:13px;color:var(--text)}.chip:hover{border-color:var(--gold)}.chip.on{background:var(--crimson);color:#fff;border-color:var(--crimson)}.mat-add{display:flex;gap:8px;margin-top:10px}.mat-add input{flex:1}.mat-add button,.add-dim,.file-btn,.cam-btn{padding:8px 16px;background:var(--crimson);color:#fff;border:0;cursor:pointer;font-size:13px;white-space:nowrap}.mat-add button:hover,.add-dim:hover,.file-btn:hover,.cam-btn:hover{background:var(--crimson-2)}.picked{margin:8px 0 0;font-size:13px;color:var(--muted)}.dim-row{display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:12px;align-items:end;margin-bottom:10px}.dim-row .ghost,.cam-actions .ghost,.form-actions .ghost{background:transparent;color:var(--danger);border:1px solid var(--line);padding:8px 12px;cursor:pointer}.form-actions .ghost{color:var(--muted)}.add-dim{margin-top:4px}.photo-controls{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-start}.file-btn{display:inline-block}.file-btn input{display:none}.camera,.cam-live{display:flex;flex-direction:column;gap:8px}.cam-live video{width:320px;max-width:100%;background:#000}.cam-actions{display:flex;gap:8px}.cam-actions button:not(.ghost){padding:8px 18px;background:var(--crimson);color:#fff;border:0;cursor:pointer}.preview-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px}.thumb-x{position:relative}.thumb-x img{width:84px;height:84px;object-fit:cover;border:1px solid var(--line)}.thumb-x button{position:absolute;top:-7px;right:-7px;width:20px;height:20px;border-radius:50%;border:0;background:var(--danger);color:#fff;cursor:pointer;font-size:11px;line-height:1}.field-form button[type=submit]{margin-top:8px;padding:14px;background:var(--crimson);color:#fff;border:0;cursor:pointer;font-size:15px;letter-spacing:.16em}.field-form button[type=submit]:hover{background:var(--crimson-2)}.field-form button[type=submit]:disabled{opacity:.5}.audit{height:100%;overflow-y:auto;padding:20px 24px;background:var(--paper)}.audit h2{margin:0 0 6px;color:var(--crimson)}.audit-toolbar{display:flex;gap:10px;align-items:center;margin:12px 0;flex-wrap:wrap}.audit-toolbar input,.audit-toolbar select{padding:8px 12px;border:1px solid var(--line);background:#fcfaf3;font-size:14px}.audit-toolbar .count{color:var(--muted);font-size:13px;margin-left:auto}.audit table{width:100%;border-collapse:collapse;background:var(--surface);font-size:13px}.audit th,.audit td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}.audit th{background:var(--paper-2);color:var(--ink);font-family:var(--serif);white-space:nowrap}.audit td.t{white-space:nowrap;color:var(--muted);font-family:ui-monospace,monospace}.audit .act{display:inline-block;padding:1px 8px;font-size:12px;border:1px solid var(--line);background:var(--paper-2)}.audit .act.del{background:var(--danger);color:#fff;border-color:var(--danger)}.audit .act.login{background:var(--gold-light);color:var(--crimson);border-color:var(--gold)}.audit .pager{margin:14px 0}@media (max-width: 1024px){.content{overflow-y:auto}.workbench{grid-template-columns:1fr;height:auto}.workbench .nav{order:0;display:flex;gap:6px;overflow-x:auto;border-right:0;border-bottom:1px solid var(--line)}.workbench .nav button{width:auto;white-space:nowrap;margin-bottom:0}.workbench .right-panel{order:1;min-height:320px}.workbench .left-panel{order:2}}@media (max-width: 820px){.topbar{flex-wrap:wrap;height:auto;padding:10px 14px;gap:8px 12px}.brand{flex:1 1 auto;min-width:0;gap:10px}.brand-text h1{font-size:15px;line-height:1.3}.brand-sub{display:none}.user-chip{order:2;margin-left:auto}.logout-btn{order:3}.tabs{order:4;flex:0 0 100%;width:100%;margin:0;gap:0;overflow-x:auto;border-top:1px solid rgba(201,168,119,.35);padding-top:4px}.tabs button{margin-bottom:0;padding:10px 16px;white-space:nowrap}.browse{grid-template-columns:1fr;height:auto}.cat-rail{display:flex;gap:6px;overflow-x:auto;border-right:0;border-bottom:1px solid var(--line);padding:10px}.cat-group{display:flex;gap:6px;margin-bottom:0}.cat{white-space:nowrap;width:auto}.cat.sub{padding-left:12px}.searchbar{flex-wrap:wrap;padding:12px 14px}.searchbar input{max-width:none}.searchbar .count{width:100%;margin-left:0}.grid{padding:14px;gap:12px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.modal-overlay{padding:0}.modal{width:100%;max-width:100%;height:100%;max-height:100%;border-top-width:4px}.modal-body{grid-template-columns:1fr;overflow-y:auto}.modal-viewer{min-height:300px}.left-panel{padding:18px 16px}.field-form-wrap{padding:14px}.field-form{padding:22px 16px}.field-form .row3{grid-template-columns:1fr}.dim-row{grid-template-columns:1fr 1fr 1fr}.dim-row .ghost{grid-column:1 / -1;justify-self:start}.photo-controls{gap:8px}}
