.fd-wrap{position:relative;display:inline-flex}.fd-pop{position:absolute;top:calc(100% + 8px);right:0;width:340px;background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-md);z-index:30;display:flex;flex-direction:column;max-height:min(70vh,560px)}.fd-h{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line)}.fd-h h3{margin:0;font-size:15px;font-weight:600}.fd-clear{font-size:12px;color:var(--purple);font-weight:500;background:none;border:none;cursor:pointer;padding:4px 6px}.fd-clear:hover{color:var(--purple-strong)}.fd-clear[disabled]{color:var(--ink-3);cursor:default}.fd-body{overflow-y:auto;flex:1;padding:4px 0}.fd-row{border-bottom:1px solid var(--line)}.fd-row:last-child{border-bottom:none}.fd-row-head{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;-webkit-user-select:none;user-select:none}.fd-row-head:hover{background:var(--purple-25)}.fd-row-label{font-size:13px;font-weight:500;color:var(--ink)}.fd-row-val{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--ink-2)}.fd-row-val.is-set{color:var(--purple);font-weight:500}.fd-row-chev{transition:transform .15s;color:var(--ink-3)}.fd-row.is-open .fd-row-chev{transform:rotate(180deg)}.fd-options{display:flex;flex-direction:column;padding:4px 0 8px;background:var(--purple-25)}.fd-opt{display:flex;align-items:center;gap:10px;padding:8px 16px 8px 28px;font-size:13px;color:var(--ink);cursor:pointer;transition:background .15s}.fd-opt:hover{background:var(--purple-50)}.fd-opt.is-selected{color:var(--purple);font-weight:500}.fd-opt-radio{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--line-2);flex-shrink:0;position:relative;transition:border-color .15s}.fd-opt.is-selected .fd-opt-radio{border-color:var(--purple)}.fd-opt.is-selected .fd-opt-radio:after{content:"";position:absolute;top:2px;right:2px;bottom:2px;left:2px;border-radius:50%;background:var(--purple)}.fd-f{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px;border-top:1px solid var(--line)}.fd-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;background:transparent}.fd-chips{display:flex;flex-wrap:wrap;gap:8px;padding:4px 24px 8px}.fd-chip{display:inline-flex;align-items:center;gap:8px;padding:4px 12px;border-radius:6px;background:var(--purple-50);color:var(--purple);font-size:12px;font-weight:500;line-height:16px}.fd-chip-x{display:inline-grid;place-items:center;width:14px;height:14px;border:none;background:none;color:var(--ink-3);cursor:pointer;padding:0;border-radius:3px}.fd-chip-x:hover{color:var(--ink);background:#0000000a}.od2{display:flex;flex-direction:column;gap:16px}.od2-head{display:flex;align-items:flex-start;gap:12px;padding-bottom:4px}.od2-head-back{width:32px;height:32px;display:grid;place-items:center;border:1px solid var(--line);background:var(--card);border-radius:8px;cursor:pointer;color:var(--ink-2)}.od2-head-back:hover{color:var(--ink);border-color:var(--line-2)}.od2-head-title{font-size:20px;font-weight:600;color:var(--ink);line-height:28px}.od2-head-sub{font-size:12px;color:var(--ink-2);margin-top:2px}.od2-head-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.od2-grid{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:24px;align-items:start}@media (max-width: 1100px){.od2-grid{grid-template-columns:1fr}}.od2-col{display:flex;flex-direction:column;gap:20px;min-width:0}.od2-card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px 24px}.od2-card h3{margin:0 0 16px;font-size:15px;font-weight:600;color:var(--ink);display:flex;align-items:center;justify-content:space-between;gap:8px}.od2-prod{display:flex;gap:16px;padding-top:4px}.od2-prod+.od2-prod{border-top:1px solid var(--line);margin-top:16px;padding-top:20px}.od2-prod-img{width:82px;height:82px;border-radius:6px;background:var(--purple-25) no-repeat center / cover;flex-shrink:0;border:1px solid var(--line)}.od2-prod-body{flex:1;display:flex;gap:32px;min-width:0}.od2-prod-main{flex:1;min-width:0}.od2-prod-name{font-size:14px;font-weight:600;color:var(--ink);line-height:20px;margin-bottom:4px}.od2-prod-desc{font-size:12px;color:var(--ink-2);line-height:18px;margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.od2-prod-meta{display:grid;grid-template-columns:auto 1fr;gap:6px 12px;font-size:12px}.od2-prod-meta dt{color:var(--ink-2);white-space:nowrap}.od2-prod-meta dd{margin:0;color:var(--ink);font-weight:500}.od2-prod-side{text-align:right;font-size:12px;flex-shrink:0;min-width:88px}.od2-prod-qty{color:var(--ink);font-weight:500;margin-bottom:6px}.od2-prod-qty del{color:var(--ink-3);font-weight:400;margin-left:4px}.od2-prod-price{color:var(--ink-2)}.od2-prod-price .v{color:var(--ink);font-weight:500}.od2-alert{display:flex;gap:10px;background:var(--purple-50);color:var(--purple);padding:10px 14px;border-radius:8px;font-size:12px;line-height:18px;margin-bottom:16px}.od2-alert svg{flex-shrink:0;margin-top:1px}.od2-sum{display:flex;flex-direction:column;gap:10px}.od2-sum-row{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:baseline;font-size:13px}.od2-sum-row .l{color:var(--ink)}.od2-sum-row .s{color:var(--ink-2);font-size:12px}.od2-sum-row .v{color:var(--ink);text-align:right;font-variant-numeric:tabular-nums}.od2-sum-row.is-strong .l,.od2-sum-row.is-strong .v{font-weight:600}.od2-sum-row.is-neg .v{color:var(--coral, #eb5a5a)}.od2-sum-divider{border-top:1px solid var(--line);margin:4px 0}.od2-sum-title{font-size:14px;font-weight:600;color:var(--ink);margin-top:4px}.od2-timeline{display:flex;flex-direction:column;gap:0}.od2-tl-item{display:grid;grid-template-columns:20px 1fr;gap:12px;padding-bottom:16px;position:relative}.od2-tl-item:last-child{padding-bottom:0}.od2-tl-item .dot{width:10px;height:10px;border-radius:50%;background:var(--purple);margin-top:4px;margin-left:5px;position:relative;z-index:1}.od2-tl-item:before{content:"";position:absolute;left:9px;top:14px;bottom:0;width:2px;background:var(--purple-50)}.od2-tl-item:last-child:before{display:none}.od2-tl-body{font-size:13px;color:var(--ink);line-height:20px}.od2-tl-body .time{display:block;color:var(--ink-2);font-size:11px;margin-top:2px;font-variant-numeric:tabular-nums}.od2-kv{display:flex;flex-direction:column;gap:14px}.od2-kv-row{display:flex;flex-direction:column;gap:4px;font-size:13px}.od2-kv-row .k{color:var(--ink);font-weight:500;font-size:12px}.od2-kv-row .v{color:var(--ink-2);line-height:20px}.od2-kv-row .v.addr{white-space:pre-line}.od2-cust-head{display:flex;align-items:center;gap:10px;margin-bottom:14px}.od2-cust-head img,.od2-cust-head .fallback{width:32px;height:32px;border-radius:50%;object-fit:cover;background:var(--purple-50);color:var(--purple);display:grid;place-items:center;font-size:12px;font-weight:600}.od2-cust-head .name{font-size:14px;font-weight:600;color:var(--ink)}.od2-card h3 .btn{margin-left:auto}.od2-note-input{width:100%;min-height:72px;resize:vertical;padding:10px 12px;border:1px solid var(--line);border-radius:8px;font:inherit;font-size:13px;color:var(--ink);background:var(--card);box-sizing:border-box}.od2-note-input:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px var(--purple-50)}.od2-note-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:10px}.od2-note-list{margin-top:16px}.od2-note-entry .meta{color:var(--ink-3);font-size:11px;margin-top:2px}.fd-options.pl2-tree{max-height:280px;overflow-y:auto}.fd-row-val-text{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fd-options.pl2-tree .fd-opt.is-branch{cursor:default;color:var(--ink-3);font-size:12px}.fd-options.pl2-tree .fd-opt.is-branch:hover{background:transparent}.pl2-table td{vertical-align:middle}.pl2-cover{width:48px;height:48px;border-radius:3px;background:var(--purple-25) no-repeat center / cover;border:1px solid var(--line)}.pl2-name{font-size:13px;font-weight:500;color:var(--ink);line-height:20px;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pl2-subid{font-size:11px;color:var(--ink-3);margin-top:2px}.pl2-chips{display:flex;flex-wrap:wrap;gap:8px;max-width:340px}.pl2-chip{background:#fff;border:1px solid var(--line);border-radius:6px;padding:3px 10px;font-size:12px;font-weight:500;color:var(--ink);white-space:nowrap}.pl2-toggle{width:32px;height:18px;border-radius:999px;background:var(--line-2);border:none;padding:0;position:relative;cursor:pointer;transition:background .15s}.pl2-toggle.on{background:var(--purple)}.pl2-toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .15s}.pl2-toggle.on .pl2-toggle-thumb{left:16px}.btn-purple{background:var(--purple);color:#fff}.btn-purple:hover{background:var(--purple-strong)}.pd-title-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:24px}.pd-title-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}.pd-title-text{min-width:0;flex:1;overflow:hidden;max-width:480px}.pd-back{width:32px;height:32px;border-radius:8px;border:1px solid var(--line);background:#fff;color:var(--ink);display:grid;place-items:center;cursor:pointer;transition:background .15s;padding:0;flex-shrink:0}.pd-back:hover{background:var(--bg)}.pd-title{font-size:22px;font-weight:700;letter-spacing:-.01em;margin:0;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pd-title-sub{font-size:12px;color:var(--ink-3);margin-top:2px;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-primary-purple{background:var(--purple);color:#fff}.btn-primary-purple:hover{background:var(--purple-strong)}.btn-edit-sm{background:var(--purple);color:#fff;height:28px;padding:0 14px;border-radius:8px;font-size:12px;font-weight:500;cursor:pointer;transition:background .15s;display:inline-flex;align-items:center;gap:4px;border:0}.btn-edit-sm:hover{background:var(--purple-strong)}.btn-edit-sm[disabled]{opacity:.5;cursor:default}.btn-sm{height:28px;padding:0 12px;border-radius:8px;font-size:12px}.pd-grid{display:grid;grid-template-columns:1fr 380px;gap:24px;align-items:flex-start}.pd-col-left,.pd-col-right{display:flex;flex-direction:column;gap:24px;min-width:0}@media (max-width: 1100px){.pd-grid{grid-template-columns:1fr}}.pd-card{background:#fff;border:1px solid var(--line);border-radius:12px}.pd-card-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;gap:12px;border-bottom:1px solid var(--line)}.pd-card-title{font-size:14px;font-weight:600;color:var(--ink);display:flex;align-items:baseline;gap:12px;flex-wrap:wrap}.pd-card-meta{font-size:12px;color:var(--ink-2);font-weight:400}.pd-card-body{padding:18px;display:flex;flex-direction:column;gap:16px}.pd-card-body:empty{display:none}.pd-card-head:has(+.pd-card-body:empty){border-bottom:0}.pd-req{color:var(--coral)}.pd-field{display:flex;flex-direction:column;gap:6px}.pd-label{font-size:11px;color:var(--ink-2);font-weight:500;margin-bottom:0}.pd-text{font-size:13px;color:var(--ink);padding:10px 0;line-height:1.45;white-space:pre-wrap}.pd-text.empty{color:var(--ink-3)}.pd-card-body .pd-field:not(:first-child){padding-top:4px}.pd-view .form-input,.pd-modal .form-input{height:44px;border-radius:10px;padding:0 14px}.pd-view .form-input.multiline{padding:12px 14px;height:auto;resize:vertical;min-height:80px;line-height:1.5}.pd-suffix{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--ink-3);pointer-events:none}.pd-select{display:flex;width:100%;align-items:center;justify-content:space-between;height:44px;border:1px solid var(--line);border-radius:10px;padding:0 14px;font-size:13px;color:var(--ink);background:#fff;cursor:pointer}.pd-select:hover{border-color:var(--purple)}.pd-select-wrap{position:relative}.pd-select-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;max-height:280px;overflow-y:auto;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow-md);z-index:20;padding:4px 0}.pd-scrim{position:fixed;top:0;right:0;bottom:0;left:0;z-index:15;background:transparent}.pd-select-item{padding:8px 12px;font-size:13px;color:var(--ink);cursor:pointer}.pd-select-item:hover{background:var(--purple-25)}.pd-select-item.is-selected{color:var(--purple);font-weight:500;background:var(--purple-50)}.pd-select-item.is-header{color:var(--ink-3);cursor:default;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.04em}.pd-select-item.is-header:hover{background:transparent}.pd-cover-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.pd-cover-cell{aspect-ratio:1}.pd-cover-img{position:relative;width:100%;height:100%;border-radius:10px;overflow:hidden;background:#ece4d6 no-repeat center / cover;border:1px solid var(--line)}.pd-cover-img[draggable=true]{cursor:grab}.pd-cover-img[draggable=true]:active{cursor:grabbing}.pd-cover-x{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:var(--purple);color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 1px 3px #0003;border:0;padding:0}.pd-cover-x:hover{background:var(--purple-strong)}.pd-cover-empty{width:100%;height:100%;border:1.5px dashed var(--purple);border-radius:10px;background:var(--purple-25);color:var(--purple);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;font-size:11px;font-weight:500;transition:background .15s;padding:0}.pd-cover-empty:hover{background:var(--purple-50)}.pd-cover-empty[disabled]{opacity:.6;cursor:wait}.pd-vtable{display:flex;flex-direction:column;gap:8px}.pd-vrow{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:12px}.pd-vrow:hover{border-color:var(--purple-50);background:var(--purple-25)}.pd-vcell{color:var(--ink)}.pd-vcell.r{text-align:right}.pd-vcell-act{flex:0 0 auto;width:24px;display:grid;place-items:center}.pd-trash{width:24px;height:24px;border-radius:6px;color:var(--coral);display:grid;place-items:center;cursor:pointer;background:transparent;border:0;padding:0}.pd-trash:hover{background:#ffebea}.pd-sub-h{display:flex;align-items:baseline;gap:12px;padding:8px 0 12px;font-size:13px}.pd-empty{padding:8px 0;color:var(--ink-3);font-size:13px}.pd-live-sub{padding:12px 0;border-bottom:1px solid var(--line)}.pd-live-sub:first-child{padding-top:4px}.pd-live-sub:last-child{border-bottom:0;padding-bottom:0}.pd-live-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.pd-add-btn{width:32px;height:32px;border-radius:8px;background:var(--purple);color:#fff;border:0;display:grid;place-items:center;cursor:pointer;transition:filter .12s;padding:0}.pd-add-btn:hover{filter:brightness(1.05)}.pd-ship-row{padding:14px 0;border-bottom:1px solid var(--line)}.pd-ship-row:first-child{padding-top:4px}.pd-ship-row:last-child{border-bottom:0;padding-bottom:0}.pd-ship-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.pd-ship-title{font-size:14px;font-weight:600;color:var(--ink)}.pd-ai-recognizing{display:inline-flex;align-items:center;gap:8px;margin-top:8px;font-size:13px;font-weight:600;background:linear-gradient(90deg,#d34eea,#657fed);-webkit-background-clip:text;background-clip:text;color:transparent}.pd-ai-spinner{display:inline-block;width:14px;height:14px;border-radius:999px;border:2px solid rgba(138,100,235,.25);border-top-color:var(--purple);animation:pd-ai-spin .8s linear infinite}@keyframes pd-ai-spin{to{transform:rotate(360deg)}}.pd-ship-line{font-size:13px;color:var(--ink);margin-top:8px}.pd-ship-line.empty{color:var(--ink-3)}.pd-ship-line--with-action{display:flex;align-items:center;gap:8px}.pd-switch{width:36px;height:20px;border-radius:999px;background:#dcdee4;position:relative;transition:background .15s;flex-shrink:0;cursor:pointer;border:0;padding:0}.pd-switch:after{content:"";position:absolute;left:2px;top:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.pd-switch.on{background:var(--teal)}.pd-switch.on:after{transform:translate(16px)}.pd-switch[disabled]{opacity:.7;cursor:default}.pd-tag-input{position:relative;margin-bottom:12px}.pd-tag-input .form-input{padding-right:44px}.pd-input-add{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:32px;height:32px;border-radius:8px;background:var(--purple);color:#fff;display:grid;place-items:center;cursor:pointer;border:0;padding:0}.pd-input-add:hover{background:var(--purple-strong)}.pd-input-add[disabled]{opacity:.5;cursor:default}.pd-tags{display:flex;flex-wrap:wrap;gap:6px}.pd-tag-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--purple-50);color:var(--purple);border-radius:6px;font-size:11px;font-weight:500}.pd-tag-chip button{background:transparent;color:var(--purple);display:grid;place-items:center;cursor:pointer;padding:0;opacity:.6;border:0}.pd-tag-chip button:hover{opacity:1}.pd-qty-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:#fff;margin-top:8px}.pd-stepper{display:flex;align-items:center;gap:6px}.pd-step-btn{width:28px;height:28px;border-radius:8px;border:0;background:var(--purple-50);color:var(--purple);display:grid;place-items:center;cursor:pointer;transition:background .12s,opacity .12s;padding:0}.pd-step-btn:hover:not(:disabled){background:#8a64eb2e}.pd-step-btn:disabled{opacity:.55;cursor:default}.pd-step-val{min-width:24px;text-align:center;font-size:14px;font-weight:500;color:var(--ink);font-variant-numeric:tabular-nums}.pd-menu-wrap{position:relative}.pd-menu{position:absolute;top:calc(100% + 6px);right:0;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow-md);z-index:10;min-width:180px;padding:4px}.pd-menu-item{display:block;width:100%;text-align:left;padding:8px 12px;border-radius:6px;border:none;background:transparent;cursor:pointer;font-size:13px;color:var(--ink)}.pd-menu-item:hover{background:var(--purple-25)}.pd-menu-danger{color:var(--coral)}.pd-menu-danger:hover{background:#ff605e14}.pd-row-warn{font-size:11px;color:var(--purple);line-height:14px;margin-top:4px}.pd-banner{padding:10px 14px;border-radius:8px;font-size:13px;line-height:18px}.pd-banner-err{background:#ff605e14;color:var(--coral);border:1px solid rgba(255,96,94,.3)}.pd-banner-warn{background:#ebad3214;color:#a8710a;border:1px solid rgba(235,173,50,.3)}.pd-inline-err{margin-top:10px;padding:8px 12px;background:#ff605e14;color:var(--coral);border-radius:6px;font-size:12px}.pd-hint{font-size:12px;color:var(--ink-3);line-height:16px}.pd-modal-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#14122173;display:grid;place-items:center;z-index:200;padding:24px}.pd-modal{background:#fff;border-radius:18px;box-shadow:0 24px 60px #14122140;width:min(600px,100%);max-height:calc(100vh - 48px);overflow:auto}.pd-modal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;gap:12px}.pd-modal-title{font-size:18px;font-weight:600;color:var(--ink)}.pd-modal-actions{display:flex;gap:8px}.pd-modal-body{padding:0 22px 22px}.pd-modal-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px;display:flex;flex-direction:column;gap:12px}.pd-modal-row{display:flex;align-items:center;gap:12px}.pd-modal-cell{position:relative}.pd-modal-input{width:100%;height:44px;padding:0 16px;border:1px solid var(--line);border-radius:10px;font:inherit;color:var(--ink);background:#fff;outline:none;transition:border-color .12s}.pd-modal-input:focus{border-color:var(--purple)}.pd-modal-ph{position:absolute;left:16px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--ink-3);font-size:14px}.pd-modal-ph .pd-req{color:var(--coral)}.pd-modal-trash{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);color:var(--coral);display:grid;place-items:center;cursor:pointer;background:#fff;flex-shrink:0;padding:0}.pd-modal-trash:hover{background:#ffebea;border-color:var(--coral)}.pd-modal-trash[disabled]{opacity:.5;cursor:default}.pd-modal-add{align-self:flex-start;padding:10px 18px;border:1px solid var(--purple);color:var(--purple);background:#fff;border-radius:10px;font:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:background .12s}.pd-modal-add:hover{background:var(--purple-50)}.pd-pickup-add-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 16px;border:1.5px dashed var(--purple);color:var(--purple);background:#fff;border-radius:10px;font:inherit;font-weight:600;font-size:14px;cursor:pointer;transition:background .12s}.pd-pickup-add-btn:hover{background:var(--purple-50)}.pd-pickup-row{display:flex;align-items:center;gap:8px;padding:4px 0}.pd-pickup-row-main{flex:1;min-width:0;display:flex;align-items:center;gap:12px;padding:8px 4px;background:transparent;border:0;cursor:pointer;text-align:left;color:var(--ink)}.pd-pickup-row-text{flex:1;min-width:0;font-size:14px;line-height:20px;word-break:break-word}.pd-pickup-row-actions{display:flex;gap:4px;flex-shrink:0}.pd-icon-btn{width:32px;height:32px;border-radius:8px;border:0;background:transparent;color:var(--ink-2);display:grid;place-items:center;cursor:pointer;padding:0;transition:background .12s,color .12s}.pd-icon-btn:hover{background:var(--purple-50);color:var(--purple)}.pd-icon-btn--danger:hover{background:#ffebea;color:var(--coral)}.pd-icon-btn[disabled]{opacity:.5;cursor:default}.btn-disabled{background:#e1deeb;color:#9b96aa;cursor:not-allowed}.btn-cancel-outline{background:#fff;color:var(--purple);border:1px solid var(--purple)}.btn-cancel-outline:hover{background:var(--purple-50)}.pd-modal-pill{display:inline-block;padding:8px 16px;background:var(--purple);color:#fff;border-radius:999px;font-size:13px;font-weight:500}.pd-modal-grid{display:flex;flex-direction:column;gap:12px}.pd-modal-grid-row{display:flex;gap:12px}.pd-channel-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.pd-channel-tab{padding:6px 14px;border:1px solid var(--purple);color:var(--purple);background:#fff;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .12s}.pd-channel-tab:hover{background:var(--purple-50)}.pd-channel-tab.is-on{background:var(--purple);color:#fff}.pd-channel-tab.has-err{border-color:var(--coral);color:var(--coral)}.pd-channel-tab.has-err.is-on{background:var(--coral);color:#fff;border-color:var(--coral)}.pd-modal-cell--labeled.has-err,.pd-modal-input.has-err{border-color:var(--coral)}.pd-modal-cell-err{font-size:11px;color:var(--coral);margin-top:4px;padding-left:4px;line-height:14px}.pd-modal-switch-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;gap:12px}.pd-modal-switch-label{font-size:14px;color:var(--ink)}.pd-modal-switch{width:44px;height:24px;border-radius:999px;border:0;padding:2px;background:#e1deeb;position:relative;cursor:pointer;transition:background .15s;flex-shrink:0}.pd-modal-switch.is-on{background:#8a64eb59}.pd-modal-switch-knob{display:block;width:20px;height:20px;border-radius:999px;background:#c8b6ff;transition:transform .15s,background .15s}.pd-modal-switch.is-on .pd-modal-switch-knob{transform:translate(20px);background:var(--purple)}.pd-modal-radio-group{display:flex;flex-direction:column;gap:4px}.pd-modal-radio-row{display:flex;align-items:center;gap:12px;padding:10px 4px;background:transparent;border:0;cursor:pointer;text-align:left;width:100%}.pd-modal-radio{width:20px;height:20px;border-radius:999px;border:1.5px solid rgb(200,196,210);background:#fff;display:grid;place-items:center;cursor:pointer;flex-shrink:0;padding:0}.pd-modal-radio.is-on{border-color:var(--purple)}.pd-modal-radio-dot{width:10px;height:10px;border-radius:999px;background:var(--purple);display:block}.pd-modal-radio-label{font-size:14px;color:var(--ink)}.pd-modal-cell--labeled{display:flex;flex-direction:column;gap:2px;padding:10px 14px;border:1px solid var(--line);border-radius:12px;background:#fff}.pd-modal-cell-label{font-size:12px;color:var(--ink-3)}.pd-modal-input--labeled{border:0!important;padding:0!important;height:auto!important;font-size:16px;background:transparent}.pd-modal-select-cell{position:relative;padding:0!important}.pd-modal-select{width:100%;padding:16px 40px 16px 16px;border:1px solid var(--line);border-radius:12px;background:#fff;font-size:14px;color:var(--ink);-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer}.pd-modal-select:focus{outline:none;border-color:var(--purple)}.pd-modal-select-caret{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--purple);pointer-events:none;display:grid;place-items:center}.pd-confirm-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c1c1c66;display:grid;place-items:center;z-index:250;padding:20px}.pd-confirm{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:100%;box-shadow:var(--shadow-md)}.pd-confirm-title{margin:0 0 8px;font-size:16px;font-weight:600;color:var(--ink)}.pd-confirm-body{margin:0 0 20px;font-size:13px;color:var(--ink-2);line-height:20px}.pd-confirm-actions{display:flex;justify-content:flex-end;gap:8px}.btn.btn-danger{background:var(--coral);color:#fff}.btn.btn-danger:hover{background:#eb4c4a}.login-root{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(-45deg,var(--teal-20) 0%,rgba(138,100,235,.8) 100%);overflow:auto;display:flex;justify-content:center;align-items:center;padding:40px}.login-stage{position:relative;width:1440px;height:900px;max-width:100%;flex-shrink:0}.login-left{position:absolute;left:70px;top:305px;width:604px}.login-logo{display:block;color:var(--ink)}.login-headline{margin:40px 0 0;font-weight:700;font-size:56px;line-height:76px;color:#2b2b2b;letter-spacing:-.5px}.login-card{position:absolute;left:760px;top:174px;width:440px;background:var(--card);border-radius:16px;box-shadow:var(--shadow-md);display:flex;flex-direction:column}.login-card-head{padding:36px 24px 8px;text-align:center;font-weight:700;font-size:24px;line-height:32px;color:var(--ink)}.login-card-body{padding:24px 32px 32px;display:flex;flex-direction:column;gap:16px}.login-card-foot{background:var(--bg);border-radius:0 0 16px 16px;padding:16px 8px;display:flex;justify-content:center;align-items:center;gap:8px;font-size:13px;line-height:20px}.login-foot-link{color:var(--purple);font-weight:600;cursor:pointer;background:none;border:none;padding:0;font-family:inherit;font-size:inherit;line-height:inherit;transition:color .15s}.login-foot-link:hover{color:var(--purple-strong)}.login-foot-or{color:var(--ink-3);font-weight:400}.login-phone-row{display:flex;gap:8px}.login-phone-row .login-cc{width:84px;flex-shrink:0}.login-phone-row .login-pn{flex:1;min-width:0}.login-submit{margin-top:8px;height:44px;width:100%;justify-content:center;font-size:14px;font-weight:600}.login-submit[disabled]{background:var(--bg);color:var(--ink-3)}:root{--bg: rgb(245,246,247);--card: #ffffff;--line: rgb(232,233,237);--line-2: rgb(217,217,217);--ink: rgb(28,28,28);--ink-2: rgb(97,98,104);--ink-3: rgb(154,158,167);--ink-4: rgb(166,173,180);--purple: rgb(138,100,235);--purple-strong: rgb(151,71,255);--purple-50: rgb(235,232,253);--purple-25: rgb(251,250,255);--teal: rgb(100,231,221);--teal-50: rgb(199,236,233);--teal-20: rgba(100,232,222,.4);--coral: rgb(255,96,94);--coral-50: rgb(235,213,209);--yellow: rgb(251,198,12);--shadow-sm: 0 0 2px 0 rgba(0,0,0,.08);--shadow-md: 0 1px 3px 0 rgba(153,155,168,.12), 0 4px 12px -2px rgba(153,155,168,.12);--topbar-grad: linear-gradient(90deg, rgb(155,133,230) 0%, rgb(199,236,233) 100%)}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.4;-webkit-font-smoothing:antialiased}button{font-family:inherit;border:none;background:none;cursor:pointer;color:inherit;padding:0}a{color:inherit;text-decoration:none}.mono{font-family:JetBrains Mono,ui-monospace,Menlo,monospace;font-size:12.5px;letter-spacing:-.01em}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#9a9ea74d;border-radius:10px;border:2px solid transparent;background-clip:padding-box}::-webkit-scrollbar-track{background:transparent}.topbar{height:52px;background:var(--topbar-grad);display:flex;align-items:center;padding:0 24px;gap:24px;position:sticky;top:0;z-index:40}.logo{display:flex;align-items:center;color:#fff;min-width:88px}.logo-mark{display:block;height:24px;width:auto;filter:drop-shadow(0 1px 2px rgba(0,0,0,.08))}.topbar-search{flex:0 1 515px;margin:0 auto;position:relative}.topbar-search input{width:100%;height:40px;border-radius:999px;border:none;background:#fff;padding:0 16px 0 44px;font-family:inherit;font-size:14px;color:var(--ink);outline:none;box-shadow:0 1px 2px #0000000a}.topbar-search input::placeholder{color:var(--ink-3)}.topbar-search>svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--ink-3)}.topbar-right{display:flex;align-items:center;gap:20px;margin-left:auto}.tb-icon{width:28px;height:28px;display:grid;place-items:center;color:#3b2e6b;border-radius:8px;position:relative;cursor:pointer;transition:background .15s}.tb-icon:hover{background:#ffffff59}.tb-badge{position:absolute;top:2px;right:2px;width:7px;height:7px;border-radius:50%;background:var(--coral);border:1.5px solid var(--teal-50)}.tb-user{display:flex;align-items:center;gap:10px;padding:4px 10px 4px 4px;border-radius:999px;cursor:pointer;transition:background .15s}.tb-user:hover{background:#ffffff4d}.tb-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#8a64eb,#64e7dd);display:grid;place-items:center;color:#fff;font-weight:600;font-size:12px;overflow:hidden;flex-shrink:0}.tb-name{line-height:1.1;font-size:13px;font-weight:600;color:var(--ink)}.tb-role{line-height:1.1;font-size:10.5px;color:var(--ink-2);margin-top:2px}.shell{display:grid;grid-template-columns:64px 1fr;min-height:calc(100vh - 52px)}.sidebar{background:#fff;padding:18px 10px 18px 0;display:flex;flex-direction:column;gap:8px;border-right:1px solid var(--line);position:sticky;top:52px;height:calc(100vh - 52px);align-self:start}.nav-item{height:44px;width:54px;border-radius:0 10px 10px 0;display:grid;grid-template-rows:20px 12px;place-items:center;gap:3px;color:var(--ink-3);font-size:9px;font-weight:500;transition:all .15s;cursor:pointer;padding-top:4px}.nav-item:hover{color:var(--ink);background:var(--purple-25)}.nav-item.active{color:var(--purple);background:var(--purple-50)}.nav-item svg{width:20px;height:20px}.nav-item.divider{height:1px;background:var(--line);padding:0;border-radius:0;margin:4px 8px;flex-shrink:0}.nav-icon-wrap{position:relative;width:20px;height:20px;display:grid;place-items:center}.nav-badge{position:absolute;top:-8px;left:100%;transform:translate(-6px);min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--coral);color:#fff;font-size:9px;font-weight:600;line-height:16px;text-align:center;border:1.5px solid #fff;box-sizing:content-box;pointer-events:none;white-space:nowrap}.main{padding:40px 40px 80px;width:100%;flex:1;min-width:0}.back-to-top{position:fixed;right:24px;bottom:24px;width:40px;height:40px;border-radius:999px;background:var(--purple);color:#fff;border:0;padding:0;display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 16px #1412212e;opacity:0;transform:translateY(8px);pointer-events:none;transition:opacity .18s,transform .18s,background .15s;z-index:300}.back-to-top:hover{background:var(--purple-strong)}.back-to-top.is-on{opacity:1;transform:translateY(0);pointer-events:auto}.page-title{font-size:26px;font-weight:700;letter-spacing:-.02em;margin:0 0 24px;display:flex;align-items:center;gap:10px}.page-title .count{color:var(--ink-3);font-weight:500}.card{background:#fff;border-radius:16px;box-shadow:var(--shadow-sm)}.stat{background:#fff;border-radius:12px;padding:14px 16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:4px;min-width:0}.stat .label{font-size:12px;color:var(--ink-2);display:flex;align-items:center;gap:4px}.stat .label .q{width:14px;height:14px;border-radius:50%;border:1px solid var(--ink-3);color:var(--ink-3);font-size:9px;display:inline-grid;place-items:center;cursor:help}.stat .value{font-size:20px;font-weight:700;letter-spacing:-.01em}.stat .value.purple{color:var(--purple)}.stat .pill{align-self:flex-start;padding:6px 10px;border-radius:8px;background:var(--purple-50);color:var(--purple);font-size:12px;font-weight:500;font-variant-numeric:tabular-nums}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:0 14px;height:36px;border-radius:10px;font-size:13px;font-weight:500;transition:all .15s;white-space:nowrap}.btn svg{width:14px;height:14px}.btn-primary{background:var(--teal);color:var(--ink)}.btn-primary:hover{background:#78f0e6}.btn-light{background:var(--purple-50);color:var(--purple)}.btn-light:hover{background:#e1dcfd}.btn-ghost{background:transparent;color:var(--ink-2)}.btn-ghost:hover{background:var(--bg);color:var(--ink)}.btn-outline{background:#fff;color:var(--ink);border:1px solid var(--line)}.btn-outline:hover{background:var(--bg)}.btn-danger{background:#ffebea;color:var(--coral)}.btn[disabled]{opacity:.5;pointer-events:none}.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;font-size:11px;font-weight:500;line-height:1.5;font-variant-numeric:tabular-nums}.tag-purple{background:var(--purple-50);color:var(--purple)}.tag-purple-strong{background:var(--purple);color:#fff}.tag-teal{background:var(--teal-50);color:#1e8c82}.tag-coral{background:#ffebea;color:var(--coral)}.tag-yellow{background:#fef6d7;color:#b48200}.tag-gray{background:var(--bg);color:var(--ink-2)}.tag-green{background:#def7ec;color:#14825a}.tag-dark{background:#eeecfa;color:#5a3cb4}.badge-live{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--coral);color:#fff;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-live:before{content:"";width:6px;height:6px;border-radius:50%;background:#fff;animation:pulse 1.4s ease-in-out infinite}@keyframes pulse{50%{opacity:.35;transform:scale(.7)}}.form-row{display:flex;flex-direction:column;gap:6px}.form-row label{font-size:12px;color:var(--ink-2);font-weight:500}.form-input{height:40px;border:1px solid var(--line);border-radius:10px;padding:0 12px;font-family:inherit;font-size:14px;outline:none;background:#fff;transition:border-color .15s,box-shadow .15s;width:100%;color:var(--ink)}.form-input:focus{border-color:var(--purple);box-shadow:0 0 0 3px var(--purple-50)}.form-input.error{border-color:var(--coral)}.form-input[disabled]{background:var(--bg);color:var(--ink-3)}.form-help{font-size:12px;color:var(--ink-2)}.form-help.error{color:var(--coral)}.tabs{display:flex;gap:24px;border-bottom:1px solid var(--line);padding:0 24px}.tab{padding:12px 0;font-size:14px;color:var(--ink-2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;font-weight:500;transition:all .15s}.tab:hover{color:var(--ink)}.tab.active{color:var(--purple);border-bottom-color:var(--purple);font-weight:600}.search-field{position:relative;display:inline-flex;align-items:center}.search-field input{height:36px;border-radius:10px;border:1px solid var(--line);background:#fff;padding:0 32px 0 36px;font-family:inherit;font-size:13px;color:var(--ink);outline:none;width:280px;transition:border-color .15s}.search-field input:focus{border-color:var(--purple)}.search-field input::placeholder{color:var(--ink-3)}.search-field>svg{position:absolute;left:12px;width:14px;height:14px;color:var(--ink-3);pointer-events:none}.search-clear{position:absolute;right:8px;width:20px;height:20px;display:grid;place-items:center;border-radius:50%;color:var(--ink-3);cursor:pointer;transition:background .15s,color .15s}.search-clear:hover{background:var(--bg);color:var(--ink)}.search-clear svg{width:12px;height:12px}.checkbox{width:16px;height:16px;border:1.5px solid var(--line-2);border-radius:4px;cursor:pointer;display:inline-grid;place-items:center;transition:all .15s;background:#fff;flex-shrink:0}.checkbox.checked{background:var(--purple);border-color:var(--purple)}.checkbox.checked:after{content:"";width:8px;height:5px;border-left:2px solid #fff;border-bottom:2px solid #fff;transform:rotate(-45deg);margin-top:-2px}table{width:100%;border-collapse:separate;border-spacing:0}thead th{font-size:12px;font-weight:500;color:var(--ink-2);text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);background:#fff;white-space:nowrap}thead th.sortable{cursor:pointer}thead th.sortable:after{content:" ⇅";color:var(--ink-3);font-size:10px}tbody td{padding:14px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}tbody tr{transition:background .1s;cursor:pointer}tbody tr:hover{background:var(--purple-25)}tbody tr.selected{background:var(--purple-50)}.pagination{display:flex;justify-content:center;align-items:center;gap:4px;padding:16px}.page-num{min-width:28px;height:28px;border-radius:6px;display:grid;place-items:center;font-size:13px;color:var(--ink-2);cursor:pointer;padding:0 6px;transition:background .15s,color .15s}.page-num:hover{background:var(--bg);color:var(--ink)}.page-num.active{background:var(--purple-50);color:var(--purple);font-weight:600}.page-num.active:hover{background:var(--purple-50);color:var(--purple)}.page-num.page-ellipsis{cursor:default;color:var(--ink-3)}.page-num.page-ellipsis:hover{background:transparent;color:var(--ink-3)}.page-nav{display:inline-flex;align-items:center;gap:4px;padding:0 10px;height:28px;color:var(--ink-2);cursor:pointer;font-size:13px;border-radius:6px;transition:background .15s,color .15s}.page-nav:hover{background:var(--bg);color:var(--ink)}.page-nav.disabled{color:var(--ink-4);cursor:not-allowed}.page-nav.disabled:hover{background:transparent;color:var(--ink-4)}.home-banner{border-radius:16px;padding:28px 32px;background:linear-gradient(120deg,var(--purple-25) 0%,rgb(240,253,251) 100%);overflow:hidden;position:relative;display:flex;gap:24px;align-items:center}.home-banner:after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:var(--teal-20);filter:blur(20px);opacity:.7}.home-banner:before{content:"";position:absolute;right:120px;bottom:-80px;width:240px;height:240px;border-radius:50%;background:#8a64eb1f;filter:blur(10px)}.tweaks{position:fixed;right:16px;bottom:16px;width:280px;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;padding:16px;z-index:100;display:none}.tweaks.on{display:block}.tweaks h3{margin:0 0 12px;font-size:13px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.tweaks h3 button{font-size:16px;color:var(--ink-3)}.tweaks-row{margin-bottom:10px}.tweaks-row label{font-size:11px;color:var(--ink-2);display:block;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}.swatches{display:flex;gap:6px}.sw{width:24px;height:24px;border-radius:6px;cursor:pointer;border:2px solid transparent}.sw.on{border-color:var(--ink)}.seg{display:inline-flex;background:var(--bg);padding:2px;border-radius:8px}.seg button{padding:4px 10px;border-radius:6px;font-size:12px;color:var(--ink-2)}.seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 2px #00000014}.avatar-sq{width:40px;height:40px;border-radius:6px;background:#eee;overflow:hidden;flex-shrink:0;position:relative;background-size:cover;background-position:center}.avatar-sq.sm{width:28px;height:28px;border-radius:4px}.avatar-sq:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(45deg,rgba(0,0,0,.04) 0 4px,transparent 4px 8px)}.avatar-sq.has-image:after{content:none}.customer-av{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--bg)}.customer-av-fallback{width:24px;height:24px;font-size:10px;flex-shrink:0}.chart{height:260px;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.fade-in{animation:slideIn .3s ease both}.live-grid{display:grid;grid-template-columns:1fr 340px;gap:20px}.stream-preview{aspect-ratio:16/9;border-radius:16px;background:linear-gradient(135deg,#1a1a2e,#0f0f1e);position:relative;overflow:hidden;color:#fff}.stream-preview:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(45deg,rgba(255,255,255,.02) 0 12px,transparent 12px 24px)}.stream-ph{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;color:#fff6;font-family:JetBrains Mono,monospace;font-size:12px;letter-spacing:.1em}.chat{background:#fff;border-radius:16px;padding:0;display:flex;flex-direction:column;height:520px}.chat-h{padding:16px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}.chat-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:12px}.chat-msg{display:flex;gap:8px;font-size:13px}.chat-msg .av{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#a88fe8,#64e7dd);flex-shrink:0;color:#fff;display:grid;place-items:center;font-size:10px;font-weight:600}.chat-msg .u{font-weight:600}.chat-input{border-top:1px solid var(--line);padding:12px 16px;display:flex;gap:8px}.chat-input input{flex:1;border:1px solid var(--line);border-radius:10px;height:36px;padding:0 12px;font-family:inherit;font-size:13px;outline:none}.chat-input input:focus{border-color:var(--purple)}.live-stat{background:#fff;border-radius:12px;padding:12px 14px;box-shadow:var(--shadow-sm)}.live-stat .l{font-size:11px;color:var(--ink-2);text-transform:uppercase;letter-spacing:.05em}.live-stat .v{font-size:22px;font-weight:700;margin-top:2px;font-variant-numeric:tabular-nums}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200;display:none;align-items:center;justify-content:center;padding:24px}.modal-backdrop.on{display:flex}.modal{background:#fff;border-radius:16px;padding:0;max-width:600px;width:100%;box-shadow:0 20px 60px #0003;max-height:90vh;overflow-y:auto}.modal-h{padding:20px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}.modal-h h3{margin:0;font-size:16px;font-weight:600}.modal-b{padding:24px}.modal-f{padding:16px 24px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.view{display:none}.view.on{display:block}.row-between{display:flex;justify-content:space-between;align-items:center;gap:12px}.row{display:flex;align-items:center;gap:8px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.grid-6{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.grid-7{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}.user-detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;align-items:start}.user-detail-col{display:flex;flex-direction:column;gap:20px;min-width:0}@media (max-width: 1100px){.user-detail-grid{grid-template-columns:1fr}}.od-grid{display:grid;grid-template-columns:1fr 340px;gap:20px}.timeline{list-style:none;padding:0;margin:0}.timeline li{position:relative;padding-left:24px;padding-bottom:18px}.timeline li:before{content:"";position:absolute;left:4px;top:4px;width:10px;height:10px;border-radius:50%;background:var(--purple)}.timeline li:after{content:"";position:absolute;left:8px;top:14px;bottom:0;width:2px;background:var(--line)}.timeline li:last-child{padding-bottom:0}.timeline li:last-child:after{display:none}.timeline li.done:before{background:var(--teal)}.timeline li.pending:before{background:var(--line-2)}.kv{display:grid;grid-template-columns:120px 1fr;gap:12px 16px;font-size:13px}.kv dt{color:var(--ink-2)}.kv dd{margin:0}.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.product-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .15s,box-shadow .15s}.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.product-card .ph{aspect-ratio:1;background:repeating-linear-gradient(45deg,#f0f0f3 0,#f0f0f3 8px,#f6f6f9 8px,#f6f6f9 16px);position:relative}.product-card .ph .tag{position:absolute;top:8px;left:8px}.product-card .body{padding:10px 12px}.product-card .title{font-size:13px;font-weight:500;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;height:34px}.product-card .price{font-weight:700;font-size:14px;margin-top:6px}.product-card .meta{font-size:11px;color:var(--ink-2);margin-top:2px;font-variant-numeric:tabular-nums}.sec-h{padding:18px 20px 10px;display:flex;justify-content:space-between;align-items:center}.sec-h h4{margin:0;font-size:15px;font-weight:600}.switch{width:36px;height:20px;border-radius:999px;background:#dcdee4;position:relative;transition:background .15s;flex-shrink:0}.switch:after{content:"";position:absolute;left:2px;top:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px #0003;transition:transform .2s}.switch.on{background:var(--teal)}.switch.on:after{transform:translate(16px)}.switch.disabled{opacity:.7}.finished-stats{background:#fff;border-radius:16px;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:repeat(5,1fr)}.finished-stat{padding:18px 20px;display:flex;flex-direction:column;gap:6px;border-right:1px solid var(--line);min-width:0}.finished-stat:nth-child(5n){border-right:none}.finished-stat .label{font-size:12px;color:var(--ink-2);display:flex;align-items:center;gap:4px}.finished-stat .label .q{width:14px;height:14px;border-radius:50%;border:1px solid var(--ink-3);color:var(--ink-3);font-size:9px;display:inline-grid;place-items:center;cursor:help}.finished-stat .label .q:before{content:"?"}.finished-stat .value{font-size:20px;font-weight:700;letter-spacing:-.01em;font-variant-numeric:tabular-nums}.finished-stat .value.purple{color:var(--purple)}.playback-pop{position:fixed;top:92px;right:32px;width:320px;background:#fff;border-radius:14px;box-shadow:0 12px 40px #1c1c1c2e,0 0 0 1px #e8e9edb3;z-index:60;overflow:hidden;animation:popIn .2s ease both}.playback-pop-h{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--line)}.playback-stage{position:relative;aspect-ratio:9/14;background:linear-gradient(160deg,#d8c9b3,#b89884 60%,#8a6f5e)}.playback-bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(120% 80% at 30% 30%,rgba(255,255,255,.45),transparent 55%),repeating-linear-gradient(45deg,rgba(0,0,0,.03) 0 4px,transparent 4px 10px)}.playback-time{position:absolute;top:12px;left:12px;background:#00000073;color:#fff;padding:4px 8px;border-radius:6px;font-size:11px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.playback-ctrl{position:absolute;bottom:12px;left:12px;right:12px;display:flex;align-items:center;gap:10px}.pb-play{width:32px;height:32px;border-radius:50%;background:#ffffffe6;color:var(--ink);display:grid;place-items:center;flex-shrink:0}.pb-track{flex:1;height:4px;background:#ffffff4d;border-radius:999px;overflow:hidden}.pb-fill{height:100%;width:40%;background:var(--purple);border-radius:999px}.screen-reader{position:absolute;left:-9999px}.user-pop{position:absolute;top:56px;right:24px;min-width:240px;background:#fff;border-radius:12px;box-shadow:0 12px 40px #1c1c1c24,0 0 0 1px #e8e9edb3;z-index:50;padding:8px;animation:popIn .16s ease both}.user-pop-item{display:block;width:100%;padding:10px 14px;border:0;background:transparent;text-align:left;font-size:14px;color:var(--ink);border-radius:8px;cursor:pointer;transition:background .12s;font-family:inherit}.user-pop-item:hover{background:var(--bg)}.user-pop-sep{height:1px;background:var(--line);margin:6px 8px}.user-pop-item--logout{color:var(--ink)}.confirm-back{position:fixed;top:0;right:0;bottom:0;left:0;background:#14122173;display:grid;place-items:center;z-index:100;animation:popIn .16s ease both}.confirm-card{width:380px;max-width:calc(100vw - 32px);background:#fff;border-radius:16px;box-shadow:0 24px 60px #1c1c1c2e;padding:24px}.confirm-title{margin:0 0 8px;font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}.confirm-msg{margin:0 0 20px;font-size:13.5px;line-height:1.5;color:var(--ink-2)}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.confirm-actions .btn-logout{background:#e13448;color:#fff}.confirm-actions .btn-logout:hover{background:#c8283c}.notif-pop{position:absolute;top:52px;right:90px;width:680px;background:#fff;border-radius:14px;box-shadow:0 12px 40px #1c1c1c24,0 0 0 1px #e8e9edb3;z-index:50;animation:popIn .18s ease both}.notif-pop:before{content:"";position:absolute;top:-7px;right:var(--arrow-x, 34px);width:14px;height:14px;background:#fff;transform:rotate(45deg);border-top:1px solid rgba(232,233,237,.7);border-left:1px solid rgba(232,233,237,.7)}@keyframes popIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.notif-h{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--line)}.notif-h h3{margin:0;font-size:16px;font-weight:700;letter-spacing:-.01em}.notif-h-right{display:flex;align-items:center;gap:10px}.notif-mark{height:32px;padding:0 14px;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:13px;color:var(--ink);font-weight:500;cursor:pointer;transition:all .15s}.notif-mark:hover{background:var(--bg)}.notif-close{width:32px;height:32px;border-radius:8px;background:var(--purple-50);color:var(--purple);display:grid;place-items:center;cursor:pointer;transition:all .15s}.notif-close:hover{background:#e1dcfd}.notif-b{padding:0;text-align:left;max-height:560px;overflow-y:auto}.notif-b .t{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:10px;text-align:center;padding-top:40px}.notif-b .d{font-size:13px;color:var(--ink-2);line-height:1.6;max-width:560px;margin:0 auto;text-align:center;padding-bottom:44px}.notif-list{display:flex;flex-direction:column}.notif-toolbar{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--line)}.notif-tb-l{font-size:13px;font-weight:600;color:var(--ink)}.notif-tb-r{display:flex;gap:8px}.notif-sel{display:inline-flex;align-items:center;gap:6px;height:28px;padding:0 10px;border:1px solid var(--line);border-radius:8px;background:#fff;font-size:12px;color:var(--ink-2);cursor:pointer}.notif-sel:hover{background:var(--bg)}.notif-sel svg{color:var(--ink-3)}.notif-group{padding:8px 0;border-bottom:1px solid var(--line)}.notif-group:last-child{border-bottom:none}.notif-date{font-size:12px;color:var(--ink-3);padding:8px 20px;font-weight:500}.n-row{display:flex;align-items:center;gap:10px;padding:6px 20px;font-size:13px}.n-row:hover{background:var(--purple-25)}.n-dot{width:6px;height:6px;border-radius:50%;background:var(--coral);flex-shrink:0}.n-dot.read{background:transparent}.n-row-body{display:flex;align-items:center;gap:8px;flex:1;min-width:0;flex-wrap:wrap}.n-primary{color:var(--ink);font-weight:500}.n-sub{color:var(--ink-2);font-size:12.5px}.n-link{color:var(--ink-2);text-decoration:underline;font-size:12.5px}.n-link:hover{color:var(--purple)}.n-av{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,#c7b8ec,#a4e0d8);flex-shrink:0}.n-thumb{width:36px;height:36px;border-radius:6px;background:repeating-linear-gradient(45deg,#e8d7cc 0,#e8d7cc 6px,#dac8bc 6px,#dac8bc 12px);flex-shrink:0}.n-live-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notif-b::-webkit-scrollbar{width:8px}.toast-container{position:fixed;top:24px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:400;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:10px;background:#fff;color:var(--ink);box-shadow:0 8px 24px #1412212e;font-size:14px;min-width:240px;max-width:480px;pointer-events:auto;animation:toast-in .18s ease-out;border:1px solid var(--line)}.toast-success{border-color:#289b6466;color:#14784b;background:#eefaf3}.toast-error{border-color:#eb5a5a66;color:var(--coral);background:#fef0f0}.toast-info{border-color:#8a64eb66;color:var(--purple);background:var(--purple-50)}.toast-icon{display:grid;place-items:center;flex-shrink:0}.toast-msg{flex:1;min-width:0;word-break:break-word}@keyframes toast-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dp-trigger{display:inline-flex;align-items:center;gap:8px;height:44px;padding:0 14px;background:#fff;border:1px solid var(--line);border-radius:10px;font-size:13px;color:var(--ink);cursor:pointer;transition:all .15s}.dp-trigger:hover:not(:disabled){border-color:var(--purple)}.dp-trigger:focus-visible{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px var(--purple-50)}.dp-trigger svg:last-child{color:var(--ink-3)}.dp-trigger--field{width:100%}.dp-trigger--disabled,.dp-trigger:disabled{background:var(--bg);cursor:not-allowed;opacity:.6}.dp-card{display:inline-flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 8px 32px #1412212e,0 2px 8px #14122114;padding:16px;width:304px}.dp-card--popover{animation:dp-pop .14s ease-out}@keyframes dp-pop{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}.dp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dp-title{font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.01em}.dp-nav{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;background:none;border:0;color:var(--ink-2);cursor:pointer;transition:all .12s}.dp-nav:hover{background:var(--bg);color:var(--ink)}.dp-week{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px}.dp-wk{font-size:11px;font-weight:500;color:var(--ink-3);text-align:center;padding:4px 0}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.dp-day{height:36px;border:0;background:none;font-size:13px;color:var(--ink);border-radius:8px;cursor:pointer;font-variant-numeric:tabular-nums;transition:all .1s;position:relative}.dp-day:hover{background:var(--purple-25)}.dp-day.dp-out{color:var(--ink-3);opacity:.5}.dp-day.dp-today{box-shadow:inset 0 0 0 1px var(--purple);color:var(--purple);font-weight:600}.dp-day.dp-sel{background:var(--purple);color:#fff;font-weight:600}.dp-day.dp-sel:hover{background:var(--purple-strong)}.dp-foot{display:flex;align-items:center;gap:8px;padding-top:12px;border-top:1px solid var(--line);margin-top:8px}.tp-pop{display:inline-flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 8px 32px #1412212e,0 2px 8px #14122114;padding:16px;width:256px;animation:dp-pop .14s ease-out}.tp-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;height:220px}.tp-col{overflow-y:auto;scroll-behavior:smooth;padding:4px 2px;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin}.tp-col::-webkit-scrollbar{width:6px}.tp-col::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.tp-col::-webkit-scrollbar-track{background:transparent}.tp-row{padding:8px 0;border:0;background:none;font-size:13px;color:var(--ink-2);border-radius:8px;cursor:pointer;font-variant-numeric:tabular-nums;transition:all .1s;text-align:center;flex-shrink:0;font-family:inherit}.tp-row:hover{background:var(--purple-25);color:var(--ink)}.tp-row.tp-sel{background:var(--purple);color:#fff;font-weight:600}.tp-row.tp-sel:hover{background:var(--purple-strong)}@keyframes tb-skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.tb-skeleton{background:linear-gradient(90deg,#ffffff59 25%,#ffffffbf,#ffffff59 75%);background-size:200% 100%;animation:tb-skeleton-shimmer 1.4s ease-in-out infinite;border-radius:6px}.tb-avatar.is-loading{background:linear-gradient(90deg,#ffffff59 25%,#ffffffbf,#ffffff59 75%);background-size:200% 100%;animation:tb-skeleton-shimmer 1.4s ease-in-out infinite}.tb-skel-name{width:86px;height:10px}.tb-skel-username{width:60px;height:8px;margin-top:4px}
