:root{--accent: #b5835a;--accent-soft: #e0c3a0;--accent-bg: #f7efe5;--ink: #3a2f27;--muted: #8a8a93;--line: #ececf1;--panel: #ffffff;--bg: #ffffff;--radius: 12px;--maxw: 1520px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg);font-size:14px}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}.nav{height:56px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}.nav-inner{max-width:var(--maxw);height:100%;margin:0 auto;display:flex;align-items:center;padding:0 24px;gap:28px}.nav .logo{font-size:20px;font-weight:800;letter-spacing:1px}.nav .links{display:flex;gap:22px;align-items:center;height:100%}.nav .links a{display:flex;align-items:center;padding:7px 14px;border-radius:20px;color:var(--muted);font-weight:600;transition:background .15s,color .15s}.nav .links a:hover{background:var(--accent-bg);color:var(--accent)}.nav .links a.active{color:#fff;background:var(--accent)}.nav .links a.disabled{color:#bcbcc4;cursor:default}.nav .links .ext{display:flex;align-items:center;gap:4px}.nav .spacer{flex:1}.nav .icon-btn{background:none;border:none;color:var(--muted);padding:6px;border-radius:8px;display:flex;align-items:center}.nav .icon-btn:hover{background:var(--accent-bg);color:var(--accent)}.btn-login{background:var(--accent);color:#fff;border:none;padding:7px 18px;border-radius:8px;font-weight:600}.btn-login:hover{background:#9678cf}.nav .user-chip{display:flex;align-items:center;gap:8px}.nav .user-chip .avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.layout{display:grid;grid-template-columns:minmax(0,1004fr) minmax(0,500fr);gap:16px;padding:16px 0;align-items:flex-start;width:min(var(--maxw),100% - 32px);margin:0 auto;height:calc(100vh - 90px)}.panel{background:var(--panel);border:none;border-radius:var(--radius);height:100%;overflow:hidden;display:flex;flex-direction:column}.lib,.editor{min-width:0}.lib-tabs{display:flex;gap:24px;padding:14px 18px 0;border-bottom:1px solid var(--line)}.lib-tabs button{background:none;border:none;padding:6px 2px 12px;color:var(--muted);font-size:14px;font-weight:600;border-bottom:2px solid transparent;margin-bottom:-1px}.lib-tabs button.active{color:var(--accent);border-bottom-color:var(--accent)}.lib-body{display:flex;flex:1;overflow:hidden}.cat-side{width:92px;padding:14px 0;overflow-y:auto;border-right:1px solid var(--line);flex-shrink:0}.cat-side button{display:block;width:100%;text-align:center;background:none;border:none;padding:9px 4px;color:var(--accent);font-size:13px}.cat-side button:hover{background:var(--accent-bg)}.cat-side button.active{background:var(--accent-bg);font-weight:700}.cat-main{flex:1;overflow-y:auto;padding:16px 18px}.cat-block{margin-bottom:26px}.cat-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.cat-head h3{margin:0;font-size:15px;font-weight:700}.cat-head .add-all{width:20px;height:20px;border-radius:50%;border:1px solid var(--accent-soft);color:var(--accent);background:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;line-height:1}.cat-head .count{font-size:12px;color:var(--accent);background:var(--accent-bg);padding:2px 9px;border-radius:20px}.stamp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(112px,1fr));gap:10px}.stamp-cell{position:relative;aspect-ratio:1;border:1px solid transparent;border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;padding:8px;cursor:pointer;transition:background .15s,transform .1s}.stamp-cell:hover{background:#f6f3fc;transform:translateY(-1px)}.stamp-cell img{max-width:100%;max-height:100%;object-fit:contain;pointer-events:none}.stamp-cell .dim{position:absolute;left:0;right:0;bottom:0;background:#2b2b2bc7;color:#fff;font-size:11px;text-align:center;padding:3px 0;opacity:0;transition:opacity .15s;border-radius:0 0 9px 9px}.stamp-cell:hover .dim{opacity:1}.stamp-cell .del{position:absolute;top:-7px;right:-7px;width:20px;height:20px;border-radius:50%;background:#fff;border:1px solid var(--line);color:var(--muted);font-size:12px;display:none;align-items:center;justify-content:center}.stamp-cell:hover .del{display:flex}.upload-tile{aspect-ratio:1;border:1.5px dashed var(--accent-soft);border-radius:10px;color:var(--accent);background:var(--accent-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-size:13px}.empty-hint{color:var(--muted);padding:40px 10px;text-align:center}.editor-top{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line);align-items:center}.code-input{flex:1;border:1px solid var(--line);border-radius:8px;padding:8px 12px;font-size:13px;outline:none}.code-input:focus{border-color:var(--accent-soft)}.btn-ghost{background:#fff;border:1px solid var(--accent-soft);color:var(--accent);padding:8px 14px;border-radius:8px;font-weight:600}.btn-ghost:hover{background:var(--accent-bg)}.btn-soft{background:var(--accent-soft);border:none;color:#fff;padding:8px 16px;border-radius:8px;font-weight:600}.btn-soft:hover{background:#b6a2e6}.btn-soft:disabled{opacity:.5;cursor:not-allowed}.btn-solid{background:var(--accent);border:none;color:#fff;padding:8px 16px;border-radius:8px;font-weight:600}.btn-solid:hover{background:#9678cf}.btn-solid:disabled,.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.editor-meta{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;margin:12px 0;color:var(--muted);font-size:13px;border:1px solid var(--line);border-radius:12px;background:#fff}.editor-meta b{color:var(--ink)}.stage-wrap{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(45deg,#eee 25%,transparent 25%),linear-gradient(-45deg,#eee 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#eee 75%),linear-gradient(-45deg,transparent 75%,#eee 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;background-color:#f7f7f9}.stage-pages{display:flex;flex-direction:column;align-items:center;gap:24px;margin:auto}.page{background:#fff;box-shadow:0 6px 26px #0000001a;position:relative;flex-shrink:0}.page.current{outline:2px solid var(--accent-soft)}.page:not(.current){cursor:pointer;opacity:.96}.page-no{position:absolute;left:6px;bottom:4px;font-size:11px;color:#c9c9d2}.canvas-item{cursor:move}.canvas-item img{width:100%;height:100%;object-fit:contain;pointer-events:none;-webkit-user-select:none;user-select:none}.canvas-item.selected{outline:1.5px dashed var(--accent)}.toolbar{display:flex;align-items:center;justify-content:center;padding:14px 16px}.toolbar-pill{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:26px;padding:5px 8px;background:#fff}.toolbar-pill .size-btn{border:none;background:none;padding:6px 14px;border-radius:18px;color:var(--ink);font-weight:600;font-size:13px}.toolbar-pill .size-btn.active{background:var(--accent);color:#fff}.toolbar-pill .divider{width:1px;height:20px;background:var(--line);margin:0 6px}.circ-btn{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--muted);display:flex;align-items:center;justify-content:center}.circ-btn:hover:not(:disabled){background:var(--accent-bg);color:var(--accent);border-color:var(--accent-soft)}.circ-btn:disabled{opacity:.4;cursor:not-allowed}.pager{display:flex;justify-content:center;align-items:center;gap:9px;padding:0 0 14px}.pager .dot{width:9px;height:9px;border-radius:50%;border:none;background:#d5d5dd;padding:0;transition:background .15s,transform .15s}.pager .dot:hover{background:#b9b9c4}.pager .dot.active{background:#3b82f6;transform:scale(1.15)}.tool-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--muted);display:flex;align-items:center;justify-content:center}.tool-btn:hover:not(:disabled){background:var(--accent-bg);color:var(--accent);border-color:var(--accent-soft)}.tool-btn:disabled{opacity:.4;cursor:not-allowed}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1c2866;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:16px;width:360px;padding:26px;box-shadow:0 20px 60px #0003}.modal h2{margin:0 0 4px;font-size:18px}.modal .sub{color:var(--muted);margin:0 0 18px;font-size:13px}.field{margin-bottom:14px}.field label{display:block;font-size:13px;margin-bottom:6px;color:var(--muted)}.field input{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:14px;outline:none}.field input:focus{border-color:var(--accent-soft)}.modal .err{color:#d4495b;font-size:13px;margin:0 0 12px}.modal .full{width:100%;padding:11px;margin-top:6px}.auth-switch{margin-top:18px;color:var(--muted);font-size:13px;line-height:1.5;text-align:center;width:100%}.auth-switch button{background:none;border:none;color:var(--accent-strong, var(--accent));font-weight:800;padding:0 0 0 6px}.modal .close{float:right;background:none;border:none;font-size:20px;color:var(--muted);margin:-10px -6px 0 0}.modal .row{display:flex;gap:10px}.footer{height:34px;display:flex;align-items:center;justify-content:center;gap:24px;color:#b6b6bf;font-size:12px;border-top:1px solid var(--line);background:var(--panel)}.fab{position:fixed;right:18px;bottom:60px;background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 8px;font-size:12px;writing-mode:vertical-rl;letter-spacing:2px;box-shadow:0 6px 18px #a78bda80}.toast{position:fixed;left:50%;top:72px;transform:translate(-50%);background:var(--ink);color:#fff;padding:10px 18px;border-radius:10px;z-index:60;font-size:13px;box-shadow:0 8px 24px #00000040}.spinner{padding:40px;text-align:center;color:var(--muted)}.muted{color:var(--muted)}.crash{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.crash-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:32px;max-width:460px;text-align:center;box-shadow:0 20px 60px #503c8c1a}.crash-icon{width:44px;height:44px;border-radius:50%;background:#fbe9cf;color:#c2801f;font-size:24px;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}.crash-card h2{margin:0 0 6px;font-size:18px}.crash-detail{background:#faf7f2;border:1px solid var(--line);border-radius:8px;padding:10px 12px;font-size:12px;color:#a3563a;margin:16px 0 0;text-align:left;white-space:pre-wrap;word-break:break-word;max-height:140px;overflow:auto}.confirm-modal{width:420px;max-width:92vw}.confirm-head{display:flex;align-items:center;gap:12px}.confirm-head h2{margin:0;font-size:18px}.confirm-icon{width:26px;height:26px;border-radius:50%;background:#f5a623;color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.confirm-msg{color:#5a5a63;font-size:14px;line-height:1.7;margin:14px 0 0;padding-left:38px}.btn-confirm{background:#2f7bf6;border:none;color:#fff;padding:9px 22px;border-radius:9px;font-weight:600}.btn-confirm:hover{background:#2168e0}.code-pill{font-family:ui-monospace,Menlo,monospace;background:var(--accent-bg);color:var(--accent);padding:1px 8px;border-radius:6px;font-size:12px;letter-spacing:.5px}.editing-tag{font-style:normal;margin-left:10px;background:#fff4e3;color:#b3760f;border:1px solid #f0d6a8;padding:1px 8px;border-radius:10px;font-size:12px}.works-wrap{max-width:var(--maxw);margin:0 auto;padding:22px 24px 60px}.works-head{margin-bottom:18px}.works-head .sub{margin:12px 2px 0}.work-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:18px}.work-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .15s,transform .1s}.work-card:hover{box-shadow:0 10px 28px #503c8c1f;transform:translateY(-2px)}.work-cover{aspect-ratio:3 / 4;background:linear-gradient(45deg,#f0f0f4 25%,transparent 25%),linear-gradient(-45deg,#f0f0f4 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f4 75%),linear-gradient(-45deg,transparent 75%,#f0f0f4 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0;background-color:#fafafb;display:flex;align-items:center;justify-content:center;overflow:hidden}.work-cover img{width:100%;height:100%;object-fit:contain}.work-cover-empty{color:#c2c2cc;font-size:13px}.work-cover{position:relative}.feat-flag{position:absolute;top:8px;left:8px;background:#f5a623;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:8px}.lk-search{display:flex;gap:10px;align-items:center}.lk-input{flex:1;font-size:15px;letter-spacing:1px}.lk-dpi{border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:13px;outline:none;background:#fff}.lk-meta{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.lk-meta-row{display:flex;gap:26px;flex-wrap:wrap}.lk-meta-row>div{display:flex;flex-direction:column;gap:4px}.lk-meta-row span{font-size:12px}.lk-meta-row b{font-size:14px}.lk-meta-actions{display:flex;gap:8px}.lk-pages{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.lk-page{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.lk-canvas{width:100%;display:block;background:linear-gradient(45deg,#f0f0f4 25%,transparent 25%),linear-gradient(-45deg,#f0f0f4 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f0f0f4 75%),linear-gradient(-45deg,transparent 75%,#f0f0f4 75%);background-size:14px 14px;background-color:#fff}.lk-page-info{padding:10px 12px;display:flex;flex-direction:column;gap:8px;font-size:12px;color:var(--muted)}.lk-page-info .btn-solid{padding:6px 10px;font-size:12px}.work-body{padding:12px 14px;display:flex;flex-direction:column;gap:8px}.work-title{font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:8px}.work-title .status{font-style:normal;font-size:11px;padding:1px 8px;border-radius:10px;font-weight:600}.work-title .status.pub{background:#e6f6ec;color:#2c9c5a}.work-title .status.draft{background:#f0f0f4;color:#8a8a93}.work-title .status.feat{background:#fff3e0;color:#c2801f}.work-card.is-featured{border-color:#f3d29a;box-shadow:0 0 0 1px #f3d29a}.panel,.work-card,.kpi-card,.panel-card,.tool-card,.stat-card,.lk-page{border-radius:16px}.editor-meta{border-radius:14px}.mobile-switch{display:none}@media (max-width: 900px){.nav-inner{padding:0 12px;gap:10px}.nav .links{gap:6px}.nav .links a{padding:6px 10px;font-size:13px}.nav .logo{font-size:16px}.layout{grid-template-columns:1fr;height:auto;padding:10px;gap:10px}.mobile-switch{display:flex;gap:6px;width:200px;margin:0 auto;background:var(--accent-bg);padding:4px;border-radius:22px}.mobile-switch button{flex:1;border:none;background:none;padding:8px 0;border-radius:18px;font-weight:600;color:var(--accent)}.mobile-switch button.active{background:var(--accent);color:#fff}.lib,.editor{height:calc(100vh - 150px);min-height:420px}.layout.m-canvas .lib,.layout.m-lib .editor{display:none}.tools-wrap{padding:12px}.tools-grid{grid-template-columns:1fr;height:auto}.tool-select{order:-1}.tool-canvas{min-height:52vh}.admin-shell{flex-direction:column}.admin-sidebar{width:100%;height:auto;position:sticky;top:0;flex-direction:row;align-items:center;overflow-x:auto;padding:10px 12px;gap:8px;z-index:20}.admin-sidebar .admin-brand{padding:0 6px 0 0;white-space:nowrap}.admin-nav{flex-direction:row;flex:1;gap:6px}.nav-item{white-space:nowrap;padding:8px 12px}.admin-side-foot{display:none}.admin-main{height:auto}.admin-main-inner{padding:16px 14px 60px}.kpi-grid,.stat-grid{grid-template-columns:repeat(3,1fr)}.two-col,.lib-admin,.records{grid-template-columns:1fr}.page-head{flex-direction:column;align-items:stretch;gap:12px}.head-tools{flex-wrap:wrap}.drawer{width:100%}}@media (max-width: 560px){.editor-top{flex-wrap:wrap}.editor-top .code-input{flex:1 1 100%}.kpi-grid,.stat-grid{grid-template-columns:repeat(2,1fr)}.work-grid{grid-template-columns:repeat(2,1fr);gap:12px}.lk-pages{grid-template-columns:1fr 1fr}.fab{bottom:12px;right:12px;writing-mode:horizontal-tb;padding:8px 14px;border-radius:22px;box-shadow:0 6px 18px #b5835a80}.modal{width:94vw}.cutter-stage{min-height:300px}.nav .links a.ext span,.nav .links a.ext{font-size:0}.nav .links a.ext svg{width:18px;height:18px}.toolbar-pill{flex-wrap:wrap;justify-content:center}}.work-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--muted);gap:8px}.work-ops{display:flex;gap:6px;margin-top:2px;flex-wrap:wrap}.work-ops .btn-ghost,.work-ops .btn-solid{padding:6px 10px;font-size:12px}.work-ops .btn-ghost.danger{color:#d4495b;border-color:#f0c4cb}.modal.cutter{width:1000px;max-width:96vw}.cutter-bar{display:flex;align-items:center;gap:12px;margin:8px 0 14px;flex-wrap:wrap}.cutter-name{flex:1;min-width:200px;border:1px solid var(--line);border-radius:9px;padding:9px 12px;font-size:14px;outline:none}.cutter-name:focus{border-color:var(--accent-soft)}.cutter-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cutter-actions .btn-ghost{padding:7px 12px}.tool-seg{width:130px}.cutter-stage{display:flex;align-items:center;justify-content:center;background:#f4f4f7;border-radius:12px;padding:16px;min-height:420px;overflow:auto}.cutter-canvas{position:relative;background-size:cover;background-repeat:no-repeat;box-shadow:0 4px 18px #0000001f;-webkit-user-select:none;user-select:none}.cutter-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(80,80,120,.18) 1px,transparent 1px),linear-gradient(90deg,rgba(80,80,120,.18) 1px,transparent 1px);background-size:14% 16.6%;pointer-events:none}.region{position:absolute;border:2px solid var(--accent);background:#7896f029;box-sizing:border-box}.region.draft{border-style:dashed;background:#7896f01a}.region-x{position:absolute;top:-11px;right:-11px;width:22px;height:22px;border-radius:50%;background:#282832a6;color:#fff;border:2px solid #fff;font-size:13px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.region-poly{position:absolute;left:0;top:0;pointer-events:none;overflow:visible}.region-poly polygon{fill:#7896f029;stroke:var(--accent);stroke-width:2}.region-poly.drafting polyline{fill:none;stroke:var(--accent);stroke-width:2;stroke-dasharray:4 4}.region-poly.drafting circle{fill:var(--accent)}.region-poly foreignObject .region-x{position:static}.cutter-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px}.sel{position:relative;display:inline-block;min-width:140px}.sel.block{display:block;width:100%}.select-row .sel{flex:1;max-width:200px;min-width:0}.sel-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;background:#fff;border:1px solid var(--line);border-radius:9px;padding:9px 12px;font-size:13px;color:var(--ink);text-align:left;transition:border-color .15s,box-shadow .15s}.sel-trigger:hover{border-color:var(--accent-soft)}.sel.open .sel-trigger{border-color:var(--accent);box-shadow:0 0 0 3px #a78bda2e}.sel-trigger .ph{color:#b6b6c0}.sel-trigger span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sel-caret{color:var(--muted);flex-shrink:0;transition:transform .18s}.sel.open .sel-caret{transform:rotate(180deg);color:var(--accent)}.sel-menu{position:absolute;left:0;right:0;top:calc(100% + 6px);z-index:80;background:#fff;border:1px solid var(--line);border-radius:11px;padding:6px;box-shadow:0 12px 32px #3c2d6e29;max-height:240px;overflow-y:auto;animation:selIn .14s ease}.sel-menu.up{top:auto;bottom:calc(100% + 6px)}@keyframes selIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.sel-opt{width:100%;display:flex;align-items:center;gap:6px;background:none;border:none;padding:9px 10px;border-radius:8px;font-size:13px;color:var(--ink);text-align:left}.sel-opt:hover{background:var(--accent-bg)}.sel-opt.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.sel-check{width:14px;flex-shrink:0;color:var(--accent);font-size:12px}.fb-modal{width:560px;max-width:92vw;max-height:88vh;overflow-y:auto}.fb-modal .sub{line-height:1.7}.fb-modal .field{margin-bottom:18px}.fb-modal .counter{text-align:right;font-size:12px;color:var(--muted);margin-top:4px}.fb-modal .text-area{width:100%}.fb-modal .field input[type=text],.fb-modal .field>input{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:14px;outline:none}.fb-thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.fb-thumb{position:relative;width:64px;height:64px;border-radius:8px;overflow:hidden;border:1px solid var(--line)}.fb-thumb img{width:100%;height:100%;object-fit:cover}.fb-thumb button{position:absolute;top:0;right:0;background:#0000008c;color:#fff;border:none;width:18px;height:18px;font-size:12px;line-height:1}.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#f3eefb,#fafafb)}.admin-login-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px;width:360px;box-shadow:0 20px 60px #503c8c1f}.admin-brand{font-size:18px;font-weight:800;color:var(--ink);display:flex;align-items:baseline;gap:8px}.admin-brand span{font-size:12px;font-weight:600;color:#fff;background:var(--accent);padding:2px 8px;border-radius:6px;letter-spacing:.5px}.admin-brand.big{font-size:24px;margin-bottom:6px}.admin-shell{display:flex;min-height:100vh;background:#f6f6f9}.admin-sidebar{width:224px;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0;height:100vh}.admin-sidebar .admin-brand{padding:0 8px 18px}.admin-nav{display:flex;flex-direction:column;gap:4px;flex:1}.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border:none;background:none;border-radius:10px;color:var(--muted);font-size:14px;font-weight:500;text-align:left}.nav-item:hover{background:#f6f3fc;color:var(--ink)}.nav-item.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.nav-item .nav-badge{margin-left:auto;background:#e2574b;color:#fff;font-size:11px;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;font-style:normal}.admin-side-foot{border-top:1px solid var(--line);padding-top:14px}.admin-main{flex:1;overflow-y:auto;height:100vh}.admin-main-inner{max-width:1080px;margin:0 auto;padding:28px 32px 64px}.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:22px;gap:16px}.page-head h1{margin:0;font-size:22px}.page-head .sub{margin:4px 0 0}.head-tools{display:flex;gap:10px;align-items:center}.search{border:1px solid var(--line);border-radius:9px;padding:8px 12px;font-size:13px;outline:none;width:200px}.search:focus{border-color:var(--accent-soft)}.action-banner{width:100%;text-align:left;background:#fff5e9;border:1px solid #f5d9ad;color:#9a6213;border-radius:12px;padding:13px 16px;font-size:14px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.action-banner:hover{background:#ffefd9}.dot-warn{width:8px;height:8px;border-radius:50%;background:#e8a13a;flex-shrink:0}.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:20px}.kpi-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px}.kpi-card.warn{background:#fffaf2;border-color:#f3ddb8}.kpi-icon{width:34px;height:34px;border-radius:9px;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.kpi-card.warn .kpi-icon{background:#fbe9cf;color:#c2801f}.kpi-num{font-size:26px;font-weight:800;line-height:1}.kpi-label{font-size:12px;color:var(--muted);margin-top:6px}.panel-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;margin-bottom:18px}.card-title{font-size:14px;font-weight:700;margin-bottom:14px}.chart-card .legend{display:flex;gap:16px;font-size:12px;color:var(--muted);margin-bottom:6px}.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}.two-col .panel-card{margin-bottom:0}.gallery{display:flex;flex-wrap:wrap;gap:10px}.gal-item{width:78px}.gal-item img{width:78px;height:78px;object-fit:contain;border:1px solid var(--line);border-radius:9px;background:#fff;padding:6px}.gal-item span{display:block;font-size:11px;color:var(--muted);margin-top:4px;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mini-fb{display:flex;flex-direction:column;gap:10px}.mini-fb-item{padding:10px 12px;border:1px solid var(--line);border-radius:10px;cursor:pointer}.mini-fb-item:hover{background:#faf8fe}.mini-fb-top{font-size:13px;margin-bottom:4px}.mini-fb-text{font-size:13px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.avatar{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.avatar.sm{width:30px;height:30px;font-size:13px}.u-cell{display:flex;align-items:center;gap:10px}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th,.admin-table td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line)}.admin-table th{color:var(--muted);font-weight:600;font-size:12px}.admin-table tbody tr.clickable{cursor:pointer}.admin-table tbody tr.clickable:hover{background:#faf8fe}.admin-table .link{color:var(--accent);font-weight:600}.chips{display:flex;gap:8px;margin-bottom:16px}.chip{border:1px solid var(--line);background:#fff;border-radius:20px;padding:6px 14px;font-size:13px;color:var(--muted)}.chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.chip em{font-style:normal;opacity:.8;margin-left:2px}.fb-list{display:flex;flex-direction:column;gap:12px}.fb-item{margin-bottom:0}.fb-item.unread{border-color:var(--accent-soft)}.fb-meta{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin-bottom:10px}.fb-meta .badge{background:var(--accent);color:#fff;font-size:11px;padding:1px 7px;border-radius:10px;font-style:normal;margin-left:8px}.fb-content{font-size:14px;line-height:1.6;white-space:pre-wrap;margin-bottom:6px}.rec-list{margin:0;padding-left:18px;font-size:13px;line-height:1.9}.rec-list code{background:var(--accent-bg);color:var(--accent);padding:1px 6px;border-radius:5px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1c2859;z-index:60;display:flex;justify-content:flex-end}.drawer{width:460px;max-width:92vw;background:#fff;height:100%;overflow-y:auto;box-shadow:-10px 0 40px #0000001f;animation:slideIn .2s ease}@keyframes slideIn{0%{transform:translate(40px);opacity:.6}to{transform:none;opacity:1}}.drawer-head{display:flex;justify-content:space-between;align-items:flex-start;padding:20px;border-bottom:1px solid var(--line)}.drawer-head .u-id{display:flex;gap:12px}.drawer-stats{display:flex;padding:16px 20px;gap:12px;border-bottom:1px solid var(--line)}.drawer-stats div{flex:1;background:#faf8fe;border-radius:10px;padding:12px;text-align:center}.drawer-stats b{display:block;font-size:20px;font-weight:800;color:var(--accent)}.drawer-stats span{font-size:12px;color:var(--muted)}.drawer-body{padding:20px}.drawer-body h4{margin:0 0 12px;font-size:13px}.lib-admin{display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:start}.lib-cats{padding:14px}.lib-cat{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:10px;cursor:pointer}.lib-cat:hover{background:#f6f3fc}.lib-cat.active{background:var(--accent-bg)}.lib-cat .lc-name{flex:1;font-size:14px}.lib-cat .lc-count{font-size:12px;color:var(--accent);background:#fff;border:1px solid var(--line);border-radius:10px;padding:1px 8px}.lib-cat .lc-actions{display:none;gap:2px}.lib-cat:hover .lc-actions,.lib-cat.active .lc-actions{display:flex}.lib-cat .lc-actions button{width:24px;height:24px;border:none;background:none;border-radius:6px;color:var(--muted);font-size:12px}.lib-cat .lc-actions button:hover:not(:disabled){background:#fff;color:var(--accent)}.lib-cat .lc-actions button.danger:hover{color:#d4495b}.lib-cat .lc-actions button:disabled{opacity:.3}.lib-stamps{padding:18px}.stamp-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:14px}.sa-cell{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}.sa-img{height:110px;display:flex;align-items:center;justify-content:center;padding:12px;background:#fafafb}.sa-img img{max-width:100%;max-height:100%;object-fit:contain}.sa-name{font-size:13px;font-weight:600;padding:8px 10px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sa-dim{font-size:12px;color:var(--muted);padding:2px 10px 8px}.sa-ops{display:flex;border-top:1px solid var(--line)}.sa-ops button{flex:1;border:none;background:#fff;padding:8px;font-size:12px;color:var(--muted)}.sa-ops button:first-child{border-right:1px solid var(--line)}.sa-ops button:hover{background:var(--accent-bg);color:var(--accent)}.sa-ops button.danger:hover{background:#fdecee;color:#d4495b}.sa-add{border:1.5px dashed var(--accent-soft);border-radius:12px;background:var(--accent-bg);color:var(--accent);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;font-size:13px;min-height:180px}.sa-add span{font-size:26px}.sa-add:hover{background:#ece2fb}.tools-wrap{width:min(var(--maxw),100% - 32px);margin:0 auto;padding:18px 0 28px}.tools-header{display:flex;align-items:center;gap:16px;margin-bottom:16px}.tools-header h2{margin:0;font-size:19px}.tools-grid{display:grid;grid-template-columns:260px 1fr 372px;gap:18px;height:calc(100vh - 168px)}.tool-select{padding:16px}.tool-select-title{font-size:13px;color:var(--muted);margin-bottom:12px}.tool-card{display:flex;gap:10px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;margin-bottom:10px;align-items:flex-start}.tool-card.active{border-color:var(--accent);background:var(--accent-bg)}.tool-card .tc-icon{width:34px;height:34px;border-radius:9px;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}.tool-card .tc-text{display:flex;flex-direction:column;gap:3px}.tool-card .tc-text b{font-size:14px}.tool-card .tc-text small{font-size:12px;color:var(--muted);line-height:1.4}.tool-hint{font-size:12px;color:#b6b6bf;line-height:1.6;margin-top:8px}.tool-canvas{display:flex;flex-direction:column}.tool-canvas-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line)}.tool-canvas-head h3{margin:0;font-size:15px}.zoom-bar{position:absolute;right:16px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;background:#fff;border:1px solid var(--line);border-radius:20px;padding:8px 4px}.zoom-bar button{border:none;background:none;color:var(--muted);font-size:16px;width:24px;height:24px}.zoom-bar .vrange{writing-mode:vertical-lr;direction:rtl;width:6px;height:110px;accent-color:var(--accent)}.tool-canvas .stage-wrap{position:relative}.tool-params{display:flex;flex-direction:column}.seg{display:flex;gap:8px;padding:14px 16px;border-bottom:1px solid var(--line)}.seg button{flex:1;background:var(--accent-bg);border:none;color:var(--accent);padding:9px;border-radius:9px;font-weight:600;font-size:13px}.seg button.active{background:var(--accent);color:#fff}.seg.sm{padding:0;border:none}.seg.sm button{background:#f3f3f6;color:var(--ink);padding:7px}.seg.sm button.active{background:var(--accent);color:#fff}.seg.sm button:disabled{opacity:.5}.param-body{padding:16px;overflow-y:auto;flex:1}.param-label{font-size:13px;font-weight:600;margin:16px 0 8px}.param-label:first-child{margin-top:0}.param{margin:14px 0}.param-head{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-bottom:6px}.param-head b{color:var(--ink)}.param input[type=range],.text-area+*{width:100%}input[type=range]{width:100%;accent-color:var(--accent)}.mm-row{display:flex;gap:10px}.mm-row label{flex:1;display:flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:9px;padding:6px 10px;font-size:13px;color:var(--muted)}.mm-row input{width:100%;border:none;outline:none;font-size:14px;color:var(--ink)}.mm-row span{color:var(--muted);font-size:12px}.select-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:14px 0;font-size:13px}.select-row span{color:var(--muted);flex-shrink:0}.select-row select,.text-area{border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:13px;outline:none;background:#fff}.select-row select{flex:1;max-width:200px}.text-area{width:100%;resize:vertical;font-family:inherit}.preset-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.preset-grid button{background:#f3f3f6;border:1px solid transparent;border-radius:9px;padding:8px 4px;font-size:12px;color:var(--ink)}.preset-grid button.active{background:var(--accent-bg);border-color:var(--accent);color:var(--accent);font-weight:600}.pick-btn{width:100%;border:1.5px dashed var(--accent-soft);background:var(--accent-bg);color:var(--accent);border-radius:10px;padding:12px;margin-top:10px;font-size:13px}.pick-btn:hover{background:#ece2fb}.toggle-row{display:flex;justify-content:space-between;align-items:center}.switch{width:42px;height:24px;border-radius:20px;background:#d8d8e0;border:none;position:relative;transition:background .15s}.switch i{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .15s}.switch.on i{left:21px}.vslider-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:8px;margin:10px 0}.vslider{background:#faf9fd;border:1px solid var(--line);border-radius:12px;padding:12px 2px 10px;display:flex;flex-direction:column;align-items:center;gap:10px}.vs-val{font-size:12px;color:var(--muted);max-width:100%;overflow:hidden;text-overflow:ellipsis}.vslider .vrange{writing-mode:vertical-lr;direction:rtl;width:6px;height:124px;accent-color:var(--accent)}.vs-label{font-size:12px;color:var(--ink);text-align:center;line-height:1.3}:root{--accent: #d69a21;--accent-strong: #b97813;--accent-soft: #f1ca73;--accent-bg: #fff5dd;--ink: #3c2618;--muted: #897a6f;--line: #eadfcd;--line-strong: #dac7a8;--panel: #fffdf8;--panel-soft: #fff8eb;--bg: #fbf7ef;--sage: #82986d;--blue: #7fa1b8;--danger: #df5a4d;--radius: 12px;--maxw: 1488px}body{color:var(--ink);background:var(--bg);font-size:14px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea,select{font:inherit}button svg{flex-shrink:0}.nav{height:68px;background:#fffdf8f5;border-bottom:1px solid var(--line);box-shadow:0 1px #d69a210a;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.nav-inner{max-width:var(--maxw);padding:0 24px;gap:30px}.nav .logo{display:flex;align-items:center;gap:10px;font-size:23px;font-weight:900;color:var(--ink);letter-spacing:0;white-space:nowrap}.logo-mark{width:44px;height:44px;border:none;border-radius:14px;background:transparent;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 3px 10px #4b2b1814}.logo-mark img{width:100%;height:100%;object-fit:cover}.nav .links{height:auto;gap:12px}.nav .links a{min-width:86px;justify-content:center;padding:9px 18px;border:1px solid transparent;border-radius:999px;color:#5f4a3b;font-weight:750;letter-spacing:0}.nav .links a:hover{background:var(--accent-bg);border-color:#f3dca8;color:var(--accent-strong)}.nav .links a.active{color:var(--ink);background:#fff;border-color:var(--line-strong);box-shadow:inset 0 -3px 0 var(--accent)}.nav .links .ext{min-width:118px;gap:7px}.nav .icon-btn,.btn-login,.btn-solid,.btn-soft,.btn-ghost,.tool-btn,.tool-action{display:inline-flex;align-items:center;justify-content:center;gap:7px}.nav .icon-btn{border:1px solid transparent;color:var(--muted);padding:8px 11px;border-radius:999px;font-weight:650}.nav .icon-btn:hover{color:var(--accent-strong);border-color:var(--line);background:var(--panel-soft)}.btn-login{background:#ffd56d;color:var(--ink);border:1px solid #e1a82e;padding:9px 17px;border-radius:12px;font-weight:800;box-shadow:0 6px 18px #d69a2133}.btn-login:hover{background:#ffc94b}.nav .user-chip{position:relative;display:flex;align-items:center;gap:8px}.user-menu-btn{background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:999px;padding:5px 10px 5px 5px;display:inline-flex;align-items:center;gap:8px;font-weight:750}.nav .user-chip .avatar,.avatar{background:#f8c55d;color:var(--ink)}.nav-menu{position:absolute;right:0;top:46px;width:132px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:8px;box-shadow:0 16px 42px #53371724;z-index:40}.nav-menu .btn-ghost{width:100%;border:none}.layout{width:min(var(--maxw),100% - 32px);grid-template-columns:minmax(430px,.42fr) minmax(640px,.58fr);gap:18px;padding:18px 0;height:calc(100vh - 102px)}.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 16px 44px #48301514}.lib-tabs{padding:0 18px;height:58px;gap:28px;align-items:flex-end;background:linear-gradient(#fffdf8,#fffaf1);border-bottom-color:var(--line)}.lib-tabs button{padding:0 2px 14px;color:var(--muted);font-size:15px;font-weight:800}.lib-tabs button.active{color:var(--accent-strong);border-bottom-color:var(--accent)}.cat-side{width:112px;padding:14px 10px;background:#fffaf1;border-right-color:var(--line)}.cat-side,.cat-main{scrollbar-width:none;-ms-overflow-style:none}.cat-side::-webkit-scrollbar,.cat-main::-webkit-scrollbar{width:0;height:0;display:none}.cat-side button{min-height:38px;text-align:left;border-radius:11px;padding:9px 12px;color:#72513c;font-weight:700;line-height:1.25}.cat-side button:hover,.cat-side button.active{background:#ffefc2;color:var(--accent-strong)}.cat-side button.active{box-shadow:inset 3px 0 0 var(--accent)}.cat-main{padding:18px}.cat-block{margin-bottom:28px}.cat-head{margin-bottom:12px}.cat-head h3{font-size:16px;color:var(--ink)}.cat-head .add-all{width:26px;height:26px;border-radius:999px;border-color:#e4bc62;background:#fff8e8;color:var(--accent-strong)}.cat-head .add-all:hover{background:var(--accent);color:#fff}.cat-head .count{color:var(--accent-strong);background:var(--accent-bg);border:1px solid #f2dcaa}.stamp-grid{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:12px}.stamp-cell{border:1px solid #eadac1;border-radius:11px;background:#fffdf8;box-shadow:inset 0 0 0 1px #ffffffa6;transition:border-color .15s,background .15s,transform .12s,box-shadow .15s}.stamp-cell:hover{background:#fff8e8;border-color:#e2b75c;box-shadow:0 8px 20px #61421c1a;transform:translateY(-2px)}.stamp-cell img{max-width:78%;max-height:68%}.stamp-cell img[src^="/stamps/"]{filter:brightness(0) saturate(100%) invert(18%) sepia(30%) saturate(938%) hue-rotate(341deg) brightness(86%) contrast(93%)}.stamp-cell .dim{left:50%;right:auto;bottom:8px;width:auto;max-width:none;border-radius:999px;background:#fffdf8e0;border:1px solid #eadac1;color:#846c59;padding:1px 8px;font-size:10px;line-height:16px;opacity:0;overflow:visible;text-overflow:clip;white-space:nowrap;transform:translate(-50%,4px);transition:opacity .15s ease,transform .15s ease;z-index:1}.stamp-cell:hover .dim{opacity:1;transform:translate(-50%)}.stamp-cell .del{top:6px;right:6px;color:var(--danger);border-color:#f0c0ba}.upload-tile,.sa-add,.pick-btn{border-color:#e4bc62;color:var(--accent-strong);background:#fff6df}.upload-tile:hover,.sa-add:hover,.pick-btn:hover{background:#ffefc2}.btn-solid,.btn-soft,.btn-ghost{min-height:36px;border-radius:10px;font-weight:800;white-space:nowrap}.btn-solid{background:var(--accent);color:#fff;border:1px solid var(--accent-strong);box-shadow:0 6px 18px #d69a2129}.btn-solid:hover{background:var(--accent-strong)}.btn-soft{background:#eef5f7;border:1px solid #cbdde4;color:#4f7890}.btn-soft:hover{background:#e3f0f4}.btn-ghost{background:#fff;border:1px solid #dfcfb6;color:#71513b}.btn-ghost:hover{background:#fff6df;border-color:#e4bc62;color:var(--accent-strong)}.tool-btn,.circ-btn{border-color:#dfcfb6;background:#fffdf8;color:var(--muted)}.tool-btn:hover:not(:disabled),.circ-btn:hover:not(:disabled){background:#fff6df;color:var(--accent-strong);border-color:#e4bc62}.editor-top{padding:18px;gap:16px;justify-content:space-between;background:linear-gradient(#fffdf8,#fffaf2);border-bottom-color:var(--line)}.share-box{min-width:360px;flex:1;display:flex;align-items:center;gap:9px}.share-label{color:var(--ink);font-weight:800;white-space:nowrap}.code-input,.search,.cutter-name,.field input,.select-row select,.text-area,.fb-modal .field input[type=text],.fb-modal .field>input{border-color:#dfcfb6;background:#fff;color:var(--ink);border-radius:10px}.code-input{max-width:210px;flex:1 1 160px;min-height:36px}.code-input:focus,.search:focus,.cutter-name:focus,.field input:focus,.text-area:focus{border-color:var(--accent);box-shadow:0 0 0 3px #d69a2129}.size-group{display:inline-flex;gap:8px}.size-group button{border:1px solid #dfcfb6;background:#fff;color:var(--ink);border-radius:10px;min-width:58px;min-height:36px;padding:7px 11px;font-weight:800}.size-group button.active,.size-group button:hover{border-color:var(--accent);background:#fff4d5;color:var(--accent-strong)}.editor-sizes button{min-width:76px;min-height:54px;flex-direction:column;align-items:center;justify-content:center;display:inline-flex;gap:2px}.editor-sizes b{font-size:17px;line-height:1}.editor-sizes span{font-size:10px;color:var(--muted);font-weight:650}.editor-meta{margin:0;padding:15px 18px;border:none;border-bottom:1px solid var(--line);border-radius:0;background:#fffdf8;color:var(--muted);justify-content:flex-start;gap:18px}.bear-nudge{display:flex;align-items:center;gap:8px}.bear-nudge img{width:42px;height:42px;border-radius:13px;object-fit:cover}.bear-nudge span{position:relative;display:inline-flex;align-items:center;min-height:30px;padding:6px 12px;border:1px solid #dfcfb6;border-radius:999px;background:#fff;color:#8a5a2f;font-weight:750}.meta-copy{display:flex;align-items:center;gap:22px;flex-wrap:wrap}.meta-copy b,.editor-meta b{color:var(--ink)}.editing-tag{background:#e9f3ed;border-color:#bdd4c5;color:#5e7f63}.stage-wrap{padding:22px;background:linear-gradient(45deg,rgba(224,214,197,.55) 25%,transparent 25%),linear-gradient(-45deg,rgba(224,214,197,.55) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,rgba(224,214,197,.55) 75%),linear-gradient(-45deg,transparent 75%,rgba(224,214,197,.55) 75%);background-size:22px 22px;background-position:0 0,0 11px,11px -11px,-11px 0;background-color:#f8f1e7}.page{background:#fffdf8;box-shadow:0 18px 42px #462d1429}.page-motion-frame{will-change:transform,opacity}.page-motion-next{animation:canvasSlideNext .24s cubic-bezier(.2,.72,.2,1) both}.page-motion-prev{animation:canvasSlidePrev .24s cubic-bezier(.2,.72,.2,1) both}@keyframes canvasSlideNext{0%{opacity:.42;transform:translate(34px) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes canvasSlidePrev{0%{opacity:.42;transform:translate(-34px) scale(.985)}to{opacity:1;transform:translate(0) scale(1)}}.page.current{outline:2px solid #f0c768;outline-offset:8px}@media (prefers-reduced-motion: reduce){.page-motion-next,.page-motion-prev{animation:none}}.canvas-item.selected{outline:2px dashed #75a6c7}.toolbar{padding:14px 18px;border-top:1px solid var(--line);background:#fffdf8}.toolbar-pill{width:100%;justify-content:center;gap:0;border-color:var(--line);border-radius:14px;padding:0;overflow:hidden;box-shadow:none}.tool-action{min-width:116px;min-height:52px;border:none;border-right:1px solid var(--line);background:#fff;color:#71513b;padding:8px 18px;flex-direction:column;font-weight:750}.tool-action:last-child{border-right:none}.tool-action:hover:not(:disabled){background:#fff6df;color:var(--accent-strong)}.tool-action.danger{color:var(--danger)}.tool-action:disabled{opacity:.45;cursor:not-allowed}.pager{padding:0 0 14px;background:#fffdf8}.pager .dot{background:#d8c9af}.pager .dot.active{background:var(--accent)}.footer{height:34px;color:#ad9d88;border-top-color:var(--line);background:#fffdf8f5}.fab{background:#4f7890;border-radius:999px;padding:11px 9px;box-shadow:0 8px 22px #4f78903d;top:50%;bottom:auto;transform:translateY(-50%)}.toast{background:var(--ink);border:1px solid rgba(255,255,255,.15)}.overlay{background:#2f20155c;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal,.drawer,.admin-login-card{background:#fffdf8;border:1px solid var(--line);border-radius:16px;box-shadow:0 26px 70px #3a231238}.modal h2{color:var(--ink)}.modal .sub,.sub,.muted,.modal .close,.close{color:var(--muted)}.modal .err{color:var(--danger)}.settings-modal{position:relative;width:min(520px,calc(100vw - 32px));padding:34px 38px 40px}.settings-modal .close{position:absolute;top:22px;right:24px;float:none;width:34px;height:34px;margin:0;border-radius:50%;display:grid;place-items:center;line-height:1}.settings-modal .close:hover{background:#fff1dc;color:var(--accent-strong)}.settings-head{padding-right:42px;margin-bottom:22px}.settings-head h2{margin:0 0 8px;font-size:22px}.settings-head .sub{margin:0;font-size:14px}.settings-section{padding:18px 0;border-top:1px solid var(--line)}.settings-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:12px}.settings-section-head h3{margin:0;color:var(--ink);font-size:15px}.settings-section-head span{color:var(--muted);font-size:12px;font-weight:800}.settings-dpi-group{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.settings-dpi-group button{min-height:64px;border:1px solid #dfcfb6;border-radius:14px;background:#fffdf8;color:var(--ink);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,transform .15s ease}.settings-dpi-group button:hover{border-color:var(--accent);background:#fff6df}.settings-dpi-group button.active{border-color:var(--accent);background:#fff0c7;box-shadow:inset 0 0 0 1px #d69a212e;color:var(--accent-strong)}.settings-dpi-group b{font-size:22px;line-height:1}.settings-dpi-group span{color:var(--muted);font-size:11px;font-weight:800}.settings-options{display:grid;gap:10px}.setting-option{width:100%;min-height:58px;padding:0 14px 0 16px;border:1px solid #eadbc5;border-radius:14px;background:#fffdf8;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:16px;text-align:left}.setting-option:hover{border-color:var(--accent-soft);background:#fffaf0}.setting-copy{min-width:0;display:flex;align-items:center}.setting-copy b{font-size:15px}.setting-switch{width:48px;height:28px;padding:3px;border-radius:999px;background:#ded2c2;flex-shrink:0;transition:background .15s ease}.setting-switch i{display:block;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 2px 8px #3a231229;transition:transform .15s ease}.setting-option.is-on .setting-switch{background:var(--accent)}.setting-option.is-on .setting-switch i{transform:translate(20px)}.settings-modal .full{min-height:52px;margin-top:18px;border-radius:14px;font-size:16px}.confirm-icon,.feat-flag{background:var(--accent);color:#fff}.code-pill{background:#fff3d1;color:var(--accent-strong);border:1px solid #f0d391}.seg{border-bottom-color:var(--line)}.seg button,.chip{background:#fff6df;color:#76533a}.seg button.active,.chip.active{background:var(--accent);color:#fff}.works-wrap,.tools-wrap{width:min(var(--maxw),100% - 32px)}.works-head .sub{max-width:760px;line-height:1.7}.works-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.works-title-block{display:flex;flex-direction:column;gap:4px}.works-title-block h2{margin:0;font-size:22px;color:var(--ink)}.works-title-block span{color:var(--muted);font-size:13px}.empty-state{min-height:360px;width:min(460px,100%);margin:42px auto 0;border:1px dashed #dfcfb6;border-radius:16px;background:#fffaf1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:36px 28px}.empty-state img{width:58px;height:58px;object-fit:cover;background:transparent;border:none;border-radius:18px;padding:0}.empty-state h3{margin:0;font-size:18px}.empty-state p{margin:0 0 4px;color:var(--muted)}.work-grid .empty-state{grid-column:1 / -1}.work-card,.lk-page,.tool-card,.kpi-card,.panel-card,.stat-card,.sa-cell{border-color:var(--line);background:#fffdf8;border-radius:12px;box-shadow:0 10px 28px #4830150f}.work-card:hover{box-shadow:0 16px 38px #4830151f}.work-cover,.lk-canvas,.tool-canvas .stage-wrap,.cutter-stage{background-color:#f8f1e7}.work-title .status.pub{background:#e9f3ed;color:#5e7f63}.work-title .status.draft{background:#f4eee5;color:var(--muted)}.work-title .status.feat,.work-card.is-featured{border-color:#efc867}.tools-header{min-height:44px}.tools-header h2,.page-head h1{color:var(--ink);letter-spacing:0}.tools-grid{grid-template-columns:270px minmax(0,1fr) 380px}.tool-select-title,.param-head,.select-row span{color:var(--muted)}.tool-card{box-shadow:none;border-radius:11px}.tool-card.active{border-color:var(--accent);background:#fff6df}.tool-card .tc-icon,.kpi-icon{background:#fff0c7;color:var(--accent-strong)}.tool-card.active .tc-icon{background:var(--accent);color:#fff}.sel-trigger,.sel-menu,.mm-row label,.preset-grid button,.vslider{border-color:var(--line);background:#fffdf8}.sel.open .sel-trigger{border-color:var(--accent);box-shadow:0 0 0 3px #d69a2129}.sel-opt:hover,.sel-opt.active,.preset-grid button.active{background:#fff6df;color:var(--accent-strong)}input[type=range]{accent-color:var(--accent)}.switch.on{background:var(--accent)}.admin-login,.admin-shell{background:#fbf7ef}.admin-sidebar{background:#fffdf8;border-right-color:var(--line)}.admin-brand{color:var(--ink)}.admin-brand span,.fb-meta .badge{background:var(--accent)}.nav-item{color:var(--muted)}.nav-item:hover,.mini-fb-item:hover,.admin-table tbody tr.clickable:hover,.lib-cat:hover{background:#fff6df}.nav-item.active,.lib-cat.active{background:#fff0c7;color:var(--accent-strong)}.action-banner{background:#fff5dd;border-color:#f0d391;color:#8a5a2f}.dot-warn{background:var(--accent)}.kpi-num,.drawer-stats b,.admin-table .link{color:var(--accent-strong)}.drawer-stats div{background:#fff6df}.fb-item.unread{border-color:#efc867}.sa-img{background:#fff8eb}@media (max-width: 1100px){.layout{grid-template-columns:minmax(360px,.48fr) minmax(520px,.52fr)}.share-box{min-width:300px}.editor-sizes button{min-width:62px}}@media (max-width: 900px){.nav{height:62px}.nav-inner{padding:0 12px;gap:10px}.nav .logo{font-size:17px}.logo-mark{width:38px;height:38px}.nav .links{gap:5px}.nav .links a{min-width:auto;padding:7px 10px;font-size:13px}.nav .icon-btn span,.btn-login svg{display:none}.layout{grid-template-columns:1fr;width:100%;height:auto;padding:10px;gap:10px}.mobile-switch{display:flex;gap:6px;width:min(260px,100%);margin:0 auto;background:#fff0c7;padding:4px;border:1px solid var(--line);border-radius:999px}.mobile-switch button{flex:1;border:none;background:none;padding:8px 0;border-radius:999px;font-weight:800;color:var(--accent-strong)}.mobile-switch button.active{background:var(--accent);color:#fff}.lib,.editor{height:calc(100vh - 150px);min-height:430px}.layout.m-canvas .lib,.layout.m-lib .editor{display:none}.editor-top,.share-box,.editor-meta{flex-wrap:wrap}.share-box{min-width:0;width:100%}.editor-sizes{width:100%}.editor-sizes button{flex:1}.tools-grid{grid-template-columns:1fr;height:auto}}@media (max-width: 560px){.nav-inner{gap:8px}.nav .logo{font-size:15px;gap:7px}.logo-mark{width:36px;height:36px;border-radius:11px}.logo-mark img{width:100%;height:100%}.nav .links a{min-width:44px;padding:7px 9px;white-space:nowrap}.nav .links a.ext,.nav .icon-btn{display:none}.btn-login{padding:8px 11px}.cat-side{width:106px;padding:10px 6px}.cat-side button{padding:8px 9px;font-size:12px}.stamp-grid{grid-template-columns:repeat(auto-fill,minmax(94px,1fr))}.tool-action{min-width:76px;padding:8px 10px;font-size:12px}.works-head{align-items:stretch;flex-direction:column}.works-head .seg{max-width:none!important}.empty-state{min-height:300px;margin-top:18px}.bear-nudge img{width:34px;height:34px}.footer{gap:10px;padding:0 10px;font-size:11px}.fab{top:auto;bottom:12px;transform:none}}
