:root{--c-bg:#fff;--c-bg-2:#f8f8f6;--c-bg-3:#f2f1ee;--c-text:#1a1a1a;--c-text-2:#444;--c-text-3:#888;--c-border:#e4e4e0;--c-border-2:#ebebeb;--c-accent:#1a1a1a;--c-accent-2:#8b7355;--c-blue:#0071e3;--c-green:#1a7f4b;--c-red:#d93025;--c-amber:#c77b00;--c-sidebar:#fafaf9;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--sp-16:64px;--sidebar-w:224px;--header-h:52px;--content-max:1320px;--content-px:clamp(16px, 3vw, 40px);--content-py:clamp(20px, 3vh, 36px);--f-sans:"Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, system-ui, sans-serif;--f-mono:"Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, system-ui, sans-serif;--fs-xs:11px;--lh-xs:1.4;--fs-sm:12px;--lh-sm:1.4;--fs-base:13px;--lh-base:1.5;--fs-md:15px;--lh-md:1.4;--fs-lg:18px;--lh-lg:1.3;--fs-xl:24px;--lh-xl:1.2;--fs-2xl:32px;--lh-2xl:1.1;--fs-3xl:44px;--lh-3xl:1.05;--r-sm:6px;--r:10px;--r-lg:14px;--r-xl:20px;--r-full:999px;--sh-xs:0 1px 2px #0000000d;--sh-sm:0 1px 4px #0000000f, 0 1px 2px #0000000a;--sh:0 2px 10px #00000012, 0 1px 3px #0000000a;--sh-md:0 4px 20px #00000014, 0 2px 6px #0000000a;--sh-lg:0 12px 40px #0000001a, 0 4px 12px #0000000d;--sh-xl:0 24px 64px #0000001f, 0 8px 20px #0000000f;--ease:cubic-bezier(.25,.1,.25,1);--ease-out:cubic-bezier(0,0,.2,1);--t-fast:.12s;--t:.2s;--t-slow:.32s}.fs-xs{font-size:var(--fs-xs);line-height:var(--lh-xs)}.fs-sm{font-size:var(--fs-sm);line-height:var(--lh-sm)}.fs-base{font-size:var(--fs-base);line-height:var(--lh-base)}.fs-md{font-size:var(--fs-md);line-height:var(--lh-md)}.fs-lg{font-size:var(--fs-lg);line-height:var(--lh-lg)}.fs-xl{font-size:var(--fs-xl);line-height:var(--lh-xl)}@media (max-width:1199px){:root{--sidebar-w:200px}}@media (max-width:899px){:root{--sidebar-w:0px}}
*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--f-sans);background:var(--c-bg-2);color:var(--c-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.55}a{color:inherit;text-decoration:none}button{font-family:var(--f-sans);cursor:pointer;background:0 0;border:none}img{max-width:100%;display:block}input,select,textarea{font-family:var(--f-sans)}.app-shell{min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-w);min-height:100vh;transition:margin var(--t) var(--ease);flex-direction:column;flex:1;display:flex;overflow-x:hidden}.sidebar{width:var(--sidebar-w);z-index:200;background:var(--c-sidebar);border-right:1px solid var(--c-border);transition:transform var(--t-slow) var(--ease-out);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar-logo{border-bottom:1px solid var(--c-border);flex-shrink:0;align-items:center;gap:10px;padding:18px 16px 14px;display:flex}.sidebar-logo-mark{border-radius:var(--r-sm);background:var(--c-text);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.sidebar-logo-mark svg{color:#fff;width:14px;height:14px}.sidebar-logo-name{color:var(--c-text);letter-spacing:-.1px;font-size:13px;font-weight:600}.sidebar-logo-sub{color:var(--c-text-3);margin-top:1px;font-size:10px}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:0}.nav-group-label{font-size:var(--fs-xs);color:var(--c-text-3);letter-spacing:.08em;text-transform:uppercase;padding:12px 8px 4px;font-weight:600}.nav-item{border-radius:var(--r-sm);font-size:var(--fs-base);color:var(--c-text-2);cursor:pointer;transition:background var(--t-fast), color var(--t-fast);white-space:nowrap;align-items:center;gap:8px;padding:7px 10px;display:flex;overflow:hidden}.nav-item:hover{color:var(--c-text);background:#0000000a}.nav-item.active{color:var(--c-text);background:#0000000f;font-weight:500}.nav-item svg{opacity:.6;flex-shrink:0;width:14px;height:14px}.nav-item.active svg{opacity:1}.nav-badge{font-size:var(--fs-xs);color:var(--c-text-3);font-variant-numeric:tabular-nums;margin-left:auto}.nav-portal-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.sidebar-footer{border-top:1px solid var(--c-border);flex-shrink:0;padding:10px 12px}.sidebar-user{border-radius:var(--r-sm);cursor:pointer;transition:background var(--t-fast);align-items:center;gap:9px;padding:7px 8px;display:flex}.sidebar-user:hover{background:#0000000a}.u-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:10px;font-weight:700;display:flex}.u-name{color:var(--c-text);font-size:12px;font-weight:500}.u-email{color:var(--c-text-3);font-size:10px}.app-header{height:var(--header-h);-webkit-backdrop-filter:blur(20px)saturate(160%);border-bottom:1px solid var(--c-border);padding:0 var(--content-px);z-index:100;background:#ffffffd9;flex-shrink:0;align-items:center;gap:12px;display:flex;position:sticky;top:0}.header-search{background:var(--c-bg-3);border-radius:var(--r-full);max-width:340px;transition:all var(--t);flex:1;align-items:center;gap:7px;padding:6px 14px;display:flex}.header-search:focus-within{background:#fff;box-shadow:0 0 0 3px #0071e32e}.header-search svg{width:13px;height:13px;color:var(--c-text-3);flex-shrink:0}.header-search input{font-size:var(--fs-base);width:100%;color:var(--c-text);background:0 0;border:none;outline:none}.header-search input::placeholder{color:var(--c-text-3)}.header-right{align-items:center;gap:6px;margin-left:auto;display:flex}.lang-sw{background:var(--c-bg-3);border-radius:8px;gap:1px;padding:2px;display:flex}.lang-btn{color:var(--c-text-3);transition:all var(--t-fast);letter-spacing:.04em;border-radius:6px;padding:3px 8px;font-size:11px;font-weight:600}.lang-btn.on{color:var(--c-text);box-shadow:var(--sh-xs);background:#fff}.lang-btn:hover:not(.on){color:var(--c-text-2)}.ibtn{width:30px;height:30px;color:var(--c-text-2);transition:background var(--t-fast), color var(--t-fast);border-radius:8px;justify-content:center;align-items:center;display:flex;position:relative}.ibtn:hover{color:var(--c-text);background:#0000000f}.ibtn svg{width:15px;height:15px}.ibtn-badge{background:var(--c-red);color:#fff;border:1.5px solid var(--c-bg);border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:8px;font-weight:700;display:flex;position:absolute;top:-3px;right:-3px}.mob-menu{display:none}.pw{width:100%;max-width:var(--content-max);padding:var(--content-py) var(--content-px);flex:1;margin:0 auto}.ph{margin-bottom:var(--sp-8);justify-content:space-between;align-items:flex-end;gap:var(--sp-4);flex-wrap:wrap;display:flex}.ph-eyebrow{font-size:var(--fs-xs);color:var(--c-text-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--sp-1);font-weight:600}.ph-title{font-size:var(--fs-2xl);letter-spacing:-.5px;color:var(--c-text);font-weight:700;line-height:1.1}.ph-sub{font-size:var(--fs-base);color:var(--c-text-2);margin-top:var(--sp-1)}.section{margin-bottom:var(--sp-8)}.section+.section{margin-top:0}.g2{gap:var(--sp-4);grid-template-columns:1fr 1fr;display:grid}.g3{gap:var(--sp-4);grid-template-columns:repeat(3,1fr);display:grid}.g4{gap:var(--sp-4);grid-template-columns:repeat(4,1fr);display:grid}.card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden}.card-pad{padding:var(--sp-6)}.card-title{font-size:var(--fs-xs);color:var(--c-text-3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--sp-4);font-weight:600}.tbl{border-collapse:collapse;width:100%;font-size:var(--fs-base)}.tbl th{text-align:left;font-size:var(--fs-xs);color:var(--c-text-3);letter-spacing:.07em;text-transform:uppercase;background:var(--c-bg-2);border-bottom:1px solid var(--c-border);white-space:nowrap;padding:10px 16px;font-weight:600}.tbl td{border-bottom:1px solid var(--c-border-2);color:var(--c-text-2);vertical-align:middle;padding:11px 16px}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:#00000005}.tbl .tc{color:var(--c-text);font-weight:500}.tbl .tm{font-family:var(--f-mono);font-size:var(--fs-xs);color:var(--c-text-3)}.div{background:var(--c-border);height:1px;margin:var(--sp-6) 0}@media (max-width:1199px){.g4{grid-template-columns:repeat(2,1fr)}}@media (max-width:899px){.app-main{margin-left:0}.sidebar{transform:translate(-100%)}.sidebar.open{box-shadow:var(--sh-xl);transform:none}.mob-menu{display:flex!important}.g2,.g3,.g4{grid-template-columns:1fr}.pw{padding:16px 14px}.ph-title{font-size:var(--fs-xl)}}@media (max-width:599px){.ph{flex-direction:column;align-items:flex-start}.lang-sw{display:none}}html,body{height:100%}.app-shell{height:100vh;overflow:hidden}.app-main{height:100vh;overflow-y:auto}.app-header{z-index:100;position:sticky;top:0}#page-area{flex:1}.card{overflow-x:auto}.tbl-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.tbl{min-width:600px}.thumb-sm{background:var(--c-bg-3);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:28px;display:flex;overflow:hidden}.thumb-sm img{object-fit:cover;width:100%;height:100%}.thumb-sm svg{width:14px;height:14px;color:var(--c-text-3)}.action-cell{justify-content:flex-end;gap:4px;display:flex}
.btn{font-size:var(--fs-base);transition:all var(--t-fast) var(--ease);white-space:nowrap;cursor:pointer;font-weight:500;font-family:var(--f-sans);border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 18px;display:inline-flex}.btn svg{flex-shrink:0;width:13px;height:13px}.btn-sm{font-size:var(--fs-sm);padding:5px 12px}.btn-lg{font-size:var(--fs-md);padding:11px 24px}.btn-block{width:100%}.btn-primary{background:var(--c-text);color:#fff}.btn-primary:hover{background:#333}.btn-secondary{color:var(--c-text);border-color:var(--c-border);background:#fff}.btn-secondary:hover{border-color:#aaa}.btn-ghost{color:var(--c-text-2)}.btn-ghost:hover{color:var(--c-text);background:#0000000d}.btn-blue{background:var(--c-blue);color:#fff}.btn-blue:hover{background:#06c}.btn-danger{color:var(--c-red);border-color:#d9302533}.btn-danger:hover{background:#d930250f}.fg{margin-bottom:var(--sp-4)}.fg-row{gap:var(--sp-3);grid-template-columns:1fr 1fr;display:grid}.label{font-size:var(--fs-xs);color:var(--c-text-2);letter-spacing:.03em;margin-bottom:5px;font-weight:600;display:block}.input,select.input,textarea.input{border:1px solid var(--c-border);border-radius:var(--r-sm);width:100%;font-size:var(--fs-base);font-family:var(--f-sans);color:var(--c-text);transition:border-color var(--t-fast), box-shadow var(--t-fast);background:#fff;padding:9px 12px}.input:focus,select.input:focus,textarea.input:focus{border-color:var(--c-blue);outline:none;box-shadow:0 0 0 3px #0071e324}.input::placeholder{color:var(--c-text-3)}select.input{cursor:pointer}.input-mono{font-family:var(--f-mono);font-size:var(--fs-sm)}.check-row{font-size:var(--fs-base);color:var(--c-text);cursor:pointer;align-items:center;gap:8px;display:flex}.check-row input[type=checkbox]{accent-color:var(--c-blue);width:15px;height:15px}.checkbox-g{grid-template-columns:1fr 1fr;gap:6px;display:grid}.drop-zone{border:1.5px dashed var(--c-border);border-radius:var(--r);padding:var(--sp-10) var(--sp-6);text-align:center;background:var(--c-bg-2);cursor:pointer;transition:border-color var(--t), background var(--t)}.drop-zone:hover,.drop-zone.over{border-color:var(--c-blue);background:#0071e308}.drop-zone svg{width:28px;height:28px;color:var(--c-text-3);margin:0 auto var(--sp-3);display:block}.drop-zone-text{font-size:var(--fs-base);color:var(--c-text-2);font-weight:500}.drop-zone-sub{font-size:var(--fs-xs);color:var(--c-text-3);margin-top:var(--sp-1)}.overlay{-webkit-backdrop-filter:blur(8px);z-index:500;padding:var(--sp-5);animation:fadeIn var(--t) var(--ease);background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{border-radius:var(--r-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--sh-xl);animation:slideUp var(--t-slow) var(--ease-out);background:#fff;overflow:auto}.modal-lg{max-width:780px}.modal-sm{max-width:380px}.modal-hdr{justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 22px 0;display:flex}.modal-title{font-size:var(--fs-lg);letter-spacing:-.2px;color:var(--c-text);font-weight:700}.modal-sub{font-size:var(--fs-sm);color:var(--c-text-2);margin-top:3px}.modal-body{padding:var(--sp-5) 22px}.modal-footer{padding:var(--sp-3) 22px var(--sp-5);justify-content:flex-end;gap:var(--sp-2);border-top:1px solid var(--c-border-2);display:flex}.modal-div{background:var(--c-border-2);height:1px;margin:var(--sp-5) -22px}.tabs{background:var(--c-bg-3);border-radius:9px;gap:2px;padding:2px;display:flex}.tab{font-size:var(--fs-sm);color:var(--c-text-3);transition:all var(--t-fast);text-align:center;cursor:pointer;border-radius:7px;flex:1;padding:7px 12px;font-weight:500}.tab.on{color:var(--c-text);box-shadow:var(--sh-xs);background:#fff}.tab:hover:not(.on){color:var(--c-text-2)}.chips{gap:var(--sp-2);flex-wrap:wrap;display:flex}.chip{border-radius:var(--r-full);font-size:var(--fs-sm);border:1px solid var(--c-border);color:var(--c-text-2);cursor:pointer;transition:all var(--t-fast);background:#fff;padding:5px 13px;font-weight:500}.chip:hover{border-color:var(--c-text-3);color:var(--c-text)}.chip.on{background:var(--c-text);color:#fff;border-color:var(--c-text)}.view-sw{background:var(--c-bg-3);border-radius:8px;gap:1px;padding:2px;display:flex}.view-btn{width:28px;height:28px;color:var(--c-text-3);transition:all var(--t-fast);cursor:pointer;border-radius:6px;justify-content:center;align-items:center;display:flex}.view-btn.on{color:var(--c-text);box-shadow:var(--sh-xs);background:#fff}.view-btn svg{width:13px;height:13px}.tag{border-radius:var(--r-full);font-size:var(--fs-xs);align-items:center;gap:4px;padding:2px 9px;font-weight:500;display:inline-flex}.tag-neutral{background:var(--c-bg-3);color:var(--c-text-2)}.tag-blue{color:#0060c7;background:#0071e31a}.tag-green{color:var(--c-green);background:#1a7f4b1a}.tag-red{color:var(--c-red);background:#d930251a}.tag-amber{color:var(--c-amber);background:#c77b001a}.sdot{border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-right:6px;display:inline-block}.sdot-green{background:#34c759}.sdot-blue{background:var(--c-blue)}.sdot-gray{background:var(--c-text-3)}.sdot-red{background:var(--c-red)}.sdot-amber{background:var(--c-amber)}.toast{z-index:900;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;border-radius:var(--r-full);font-size:var(--fs-base);box-shadow:var(--sh-xl);white-space:nowrap;animation:toastIn var(--t-slow) var(--ease-out);background:#1a1a1aeb;align-items:center;gap:8px;padding:10px 18px;font-weight:500;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast svg{color:#34c759;width:14px;height:14px}.kpi{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:var(--sp-5) var(--sp-6)}.kpi-label{font-size:var(--fs-xs);color:var(--c-text-3);letter-spacing:.07em;text-transform:uppercase;margin-bottom:var(--sp-2);font-weight:600}.kpi-value{color:var(--c-text);letter-spacing:-1px;font-size:36px;font-weight:700;line-height:1}.kpi-change{font-size:var(--fs-sm);color:var(--c-text-3);margin-top:var(--sp-2)}.kpi-change.up{color:var(--c-green)}.asset-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(220px,1fr));display:grid}.asset-card{background:var(--c-bg);border:1px solid var(--c-border);border-radius:var(--r-lg);cursor:pointer;transition:box-shadow var(--t), transform var(--t), border-color var(--t);overflow:hidden}.asset-card:hover{box-shadow:var(--sh-md);border-color:#0000;transform:translateY(-2px)}.asset-thumb{aspect-ratio:4/3;background:var(--c-bg-3);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.asset-thumb-img{object-fit:cover;width:100%;height:100%;transition:transform .4s var(--ease);position:absolute;inset:0}.asset-card:hover .asset-thumb-img{transform:scale(1.03)}.asset-thumb-icon{color:#0000001f;z-index:1;width:32px;height:32px;position:relative}.asset-thumb-fmt{text-transform:uppercase;letter-spacing:.06em;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border-radius:var(--r-full);color:var(--c-text-2);background:#ffffffe0;padding:2px 7px;font-size:10px;font-weight:600;position:absolute;bottom:8px;left:8px}.asset-thumb-status{border:1.5px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:9px;right:9px}.asset-thumb-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);justify-content:center;align-items:center;gap:var(--sp-2);opacity:0;transition:opacity var(--t);background:#00000047;display:flex;position:absolute;inset:0}.asset-card:hover .asset-thumb-overlay{opacity:1}.ov-btn{width:34px;height:34px;box-shadow:var(--sh);transition:transform var(--t-fast);color:var(--c-text);cursor:pointer;background:#fff;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.ov-btn:hover{transform:scale(1.12)}.ov-btn svg{width:13px;height:13px}.asset-name{color:var(--c-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:13px;font-weight:500;overflow:hidden}.asset-meta{font-size:var(--fs-xs);color:var(--c-text-3);align-items:center;gap:6px;display:flex}.asset-dl{margin-left:auto}.asset-list{border:1px solid var(--c-border);border-radius:var(--r-lg);background:#fff;overflow:hidden}.alist-hdr,.alist-row{grid-template-columns:44px 1fr 90px 80px 80px 64px 60px;align-items:center;gap:12px;padding:10px 16px;display:grid}.alist-hdr{font-size:var(--fs-xs);color:var(--c-text-3);letter-spacing:.07em;text-transform:uppercase;background:var(--c-bg-2);border-bottom:1px solid var(--c-border);font-weight:600}.alist-row{font-size:var(--fs-base);color:var(--c-text-2);border-bottom:1px solid var(--c-border-2);cursor:pointer;transition:background var(--t-fast)}.alist-row:last-child{border-bottom:none}.alist-row:hover{background:#00000005}.alist-thumb{background:var(--c-bg-3);border-radius:5px;justify-content:center;align-items:center;width:38px;height:28px;display:flex;overflow:hidden}.alist-thumb img{object-fit:cover;width:100%;height:100%}.alist-thumb svg{width:13px;height:13px;color:var(--c-text-3)}#dd-overlay{z-index:800;opacity:0;pointer-events:none;transition:opacity var(--t);background:#0071e30f;border:3px dashed #0071e359;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}#dd-overlay.on{opacity:1;pointer-events:all}#dd-inner{flex-direction:column;align-items:center;gap:10px;display:flex}#dd-inner svg{width:48px;height:48px;color:var(--c-blue)}#dd-title{font-size:var(--fs-lg);color:var(--c-blue);font-weight:600}#dd-sub{font-size:var(--fs-sm);color:var(--c-text-2)}.sa-list{border:1px solid var(--c-border);border-radius:var(--r-sm);max-height:190px;overflow-y:auto}.sa-row{border-bottom:1px solid var(--c-border-2);cursor:pointer;transition:background var(--t-fast);align-items:center;gap:10px;padding:8px 12px;display:flex}.sa-row:last-child{border-bottom:none}.sa-row:hover,.sa-row.on{background:#0071e30a}.sa-row input[type=checkbox]{accent-color:var(--c-blue);flex-shrink:0}.sa-ico{background:var(--c-bg-2);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:20px;display:flex}.sa-ico svg{width:11px;height:11px;color:var(--c-text-3)}.sa-name{font-size:var(--fs-sm);color:var(--c-text);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sa-fmt{text-transform:uppercase;color:var(--c-text-3);background:var(--c-bg-3);border-radius:var(--r-full);flex-shrink:0;padding:1px 6px;font-size:10px;font-weight:600}.lb-drawer{-webkit-backdrop-filter:blur(20px);border-left:1px solid var(--c-border);z-index:300;width:290px;box-shadow:var(--sh-xl);transition:transform var(--t-slow) var(--ease-out);background:#fffffff2;flex-direction:column;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}.lb-drawer.open{transform:none}.lb-hdr{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.lb-ttl{color:var(--c-text);font-size:13px;font-weight:600}.lb-list{flex:1;padding:8px;overflow-y:auto}.lb-item{border-radius:var(--r-sm);transition:background var(--t-fast);align-items:center;gap:9px;padding:7px;display:flex}.lb-item:hover{background:var(--c-bg-2)}.lb-ico{background:var(--c-bg-2);border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:28px;display:flex}.lb-ico svg{width:12px;height:12px;color:var(--c-text-3)}.lb-name{font-size:var(--fs-sm);color:var(--c-text);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.lb-foot{border-top:1px solid var(--c-border);padding:12px 14px}.lb-empty{text-align:center;color:var(--c-text-3);font-size:var(--fs-base);padding:36px 20px}.col-grid{gap:var(--sp-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.col-card{border:1px solid var(--c-border);border-radius:var(--r-lg);cursor:pointer;transition:box-shadow var(--t), transform var(--t);background:#fff;overflow:hidden}.col-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}.col-thumbs{background:var(--c-border);grid-template-columns:1fr 1fr;gap:1px;display:grid}.col-th{aspect-ratio:16/9;background:var(--c-bg-3);justify-content:center;align-items:center;display:flex;overflow:hidden}.col-th img{object-fit:cover;width:100%;height:100%}.col-th svg{width:18px;height:18px;color:var(--c-text-3)}.col-info{padding:12px 14px}.col-name{color:var(--c-text);font-size:13.5px;font-weight:600}.col-meta{font-size:var(--fs-sm);color:var(--c-text-3);margin-top:2px}.portal-hero{min-height:380px;padding:48px var(--content-px);align-items:flex-end;display:flex;position:relative;overflow:hidden}.portal-hero-bg{object-fit:cover;object-position:center 30%;width:100%;height:100%;position:absolute;inset:0}.portal-hero-overlay{background:linear-gradient(#0000 0%,#00000026 40%,#0000008c 100%);position:absolute;inset:0}.portal-hero-content{z-index:1;color:#fff;max-width:640px;position:relative}.portal-hero-eye{font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;opacity:.8;margin-bottom:var(--sp-2);font-weight:600}.portal-hero-title{letter-spacing:-1px;margin-bottom:var(--sp-2);font-size:clamp(28px,5vw,48px);font-weight:700;line-height:1.05}.portal-hero-sub{font-size:var(--fs-md);opacity:.8}.portal-hero-search{margin-top:var(--sp-6);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--r-full);background:#ffffff2e;border:1px solid #ffffff4d;align-items:center;gap:10px;max-width:460px;padding:12px 20px;display:flex}.portal-hero-search input{font-size:var(--fs-md);color:#fff;background:0 0;border:none;outline:none;flex:1}.portal-hero-search input::placeholder{color:#fff9}.portal-hero-search svg{color:#ffffffb3;width:16px;height:16px}.login-shell{grid-template-columns:1fr 420px;min-height:100vh;display:grid}.login-visual{position:relative;overflow:hidden}.login-visual-bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.login-visual-overlay{background:linear-gradient(135deg,#0006 0%,#00000026 100%);position:absolute;inset:0}.login-visual-content{z-index:1;color:#fff;flex-direction:column;justify-content:flex-end;height:100%;padding:40px 48px;display:flex;position:relative}.login-visual-tag{font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;opacity:.75;margin-bottom:var(--sp-3);font-weight:600}.login-visual-title{letter-spacing:-.8px;max-width:480px;font-size:clamp(28px,4vw,44px);font-weight:700;line-height:1.1}.login-visual-sub{font-size:var(--fs-md);opacity:.75;margin-top:var(--sp-3);max-width:400px}.login-form-side{border-left:1px solid var(--c-border);background:#fff;justify-content:center;align-items:center;padding:48px 40px;display:flex}.login-form-box{width:100%;max-width:340px}.login-form-logo{background:var(--c-text);width:32px;height:32px;margin-bottom:var(--sp-6);border-radius:9px;justify-content:center;align-items:center;display:flex}.login-form-logo svg{color:#fff;width:16px;height:16px}.login-form-title{letter-spacing:-.4px;color:var(--c-text);margin-bottom:5px;font-size:26px;font-weight:700}.login-form-sub{font-size:var(--fs-base);color:var(--c-text-2);margin-bottom:var(--sp-8)}.login-form-box .input{font-size:var(--fs-md);padding:11px 14px}.login-form-box .btn-primary{font-size:var(--fs-md);padding:12px}.login-error{border-radius:var(--r-sm);font-size:var(--fs-sm);color:var(--c-red);margin-bottom:var(--sp-3);background:#d9302512;padding:9px 12px}.login-forgot{font-size:var(--fs-sm);color:var(--c-blue);text-align:center;margin-top:var(--sp-4);cursor:pointer}.login-local{margin-top:var(--sp-6);background:var(--c-bg-2);border-radius:var(--r-sm);font-size:var(--fs-sm);color:var(--c-text-2);text-align:center;padding:12px 14px;line-height:1.9}.cms-shell{background:#f0f0ee;min-height:100vh;display:flex}.cms-sidebar{background:#1a1a1a;flex-direction:column;flex-shrink:0;width:200px;display:flex}.cms-logo{border-bottom:1px solid #ffffff14;padding:20px 16px}.cms-logo-name{color:#fff;letter-spacing:.1em;text-transform:uppercase;font-size:13px;font-weight:700}.cms-logo-sub{color:#ffffff59;margin-top:2px;font-size:10px}.cms-nav{flex:1;padding:8px;overflow-y:auto}.cms-nav-item{color:#ffffff8c;cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:8px 10px;font-size:12.5px;transition:all .15s;display:flex}.cms-nav-item:hover{color:#fff;background:#ffffff0f}.cms-nav-item.on{color:#fff;background:#ffffff1a}.cms-nav-item svg{flex-shrink:0;width:13px;height:13px}.cms-nav-label{color:#ffffff40;letter-spacing:.1em;text-transform:uppercase;padding:12px 10px 4px;font-size:10px;font-weight:600}.cms-main{flex:1;overflow:auto}.cms-hdr{background:#fff;border-bottom:1px solid #e4e4e0;justify-content:space-between;align-items:center;padding:14px 28px;display:flex}.cms-hdr-title{color:#1a1a1a;letter-spacing:-.2px;font-size:16px;font-weight:700}.cms-content{padding:24px 28px}.cms-table-wrap{background:#fff;border:1px solid #e4e4e0;border-radius:10px;overflow:hidden}.bar-chart{align-items:flex-end;gap:3px;height:60px;display:flex}.bar{background:var(--c-bg-3);transition:background var(--t-fast);border-radius:3px 3px 0 0;flex:1}.bar.hi{background:var(--c-text)}.bar:hover{background:#00000059}.top-row{border-bottom:1px solid var(--c-border-2);align-items:center;gap:10px;padding:8px 0;display:flex}.top-row:last-child{border-bottom:none}.top-n{font-size:var(--fs-xs);color:var(--c-text-3);text-align:right;width:18px;font-weight:600}.top-ico{background:var(--c-bg-3);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:18px;display:flex}.top-ico svg{width:10px;height:10px;color:var(--c-text-3)}.top-name{font-size:var(--fs-base);color:var(--c-text);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.top-val{font-size:var(--fs-base);color:var(--c-blue);font-variant-numeric:tabular-nums;font-weight:600}.chart-row{align-items:center;gap:10px;margin-bottom:10px;display:flex}.chart-lbl{font-size:var(--fs-base);color:var(--c-text);flex-shrink:0;width:100px}.chart-trk{background:var(--c-bg-3);border-radius:var(--r-full);flex:1;height:5px;overflow:hidden}.chart-fil{border-radius:var(--r-full);height:5px;transition:width .7s var(--ease-out)}.chart-num{font-size:var(--fs-sm);color:var(--c-text-2);text-align:right;font-variant-numeric:tabular-nums;width:28px;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.fade-in{animation:fadeIn .25s var(--ease)}@media (max-width:899px){.asset-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.alist-hdr,.alist-row{grid-template-columns:36px 1fr 60px 50px}.alist-hdr>:nth-child(n+5),.alist-row>:nth-child(n+5){display:none}.modal{border-radius:var(--r-xl) var(--r-xl) 0 0;max-height:82vh}.overlay{align-items:flex-end;padding:0}.fg-row{grid-template-columns:1fr;gap:0}.login-shell{grid-template-columns:1fr}.login-visual{display:none}.login-form-side{border:none}.portal-hero{min-height:260px}}@media (max-width:599px){.asset-grid{grid-template-columns:1fr 1fr;gap:8px}.col-grid{grid-template-columns:1fr}.kpi-value{font-size:28px}.portal-hero-title{font-size:26px}}@media (min-width:1600px){:root{--sidebar-w:248px;--content-max:1560px}.asset-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}}#upload-progress{top:0;left:var(--sidebar-w);z-index:600;pointer-events:none;height:3px;transition:left var(--t) var(--ease);background:0 0;position:fixed;right:0}#upload-progress-bar{background:var(--c-blue);width:0;height:3px;transition:width .3s var(--ease-out);border-radius:0 2px 2px 0}#upload-progress-label{z-index:601;color:#fff;border-radius:var(--r-full);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;padding:3px 10px;font-size:11px;font-weight:600;display:none;position:fixed;top:8px;right:16px}.file-chips{flex-wrap:wrap;gap:6px;display:flex}.file-chip{border-radius:var(--r-full);background:var(--c-bg-2);border:1px solid var(--c-border);cursor:pointer;transition:all var(--t-fast);align-items:center;gap:5px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.file-chip:hover{border-color:var(--c-blue);color:var(--c-blue)}.file-chip.primary{background:var(--c-blue);color:#fff;border-color:var(--c-blue)}.file-chip svg{width:10px;height:10px}.dl-file-row{border-bottom:1px solid var(--c-border-2);cursor:pointer;transition:background var(--t-fast);align-items:center;gap:10px;padding:9px 12px;display:flex}.dl-file-row:last-child{border-bottom:none}.dl-file-row:hover{background:#0071e30a}.dl-file-row input[type=checkbox]{accent-color:var(--c-blue);flex-shrink:0}.dl-file-ext{text-transform:uppercase;background:var(--c-bg-2);border-radius:var(--r-full);color:var(--c-text-2);text-align:center;flex-shrink:0;width:48px;padding:2px 7px;font-size:10px;font-weight:700}.dl-file-name{color:var(--c-text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13px;overflow:hidden}.dl-file-size{color:var(--c-text-3);flex-shrink:0;font-size:11px}.convert-row{border-bottom:1px solid var(--c-border-2);align-items:center;gap:10px;padding:10px 0;display:flex}.convert-row:last-child{border-bottom:none}.convert-orig{color:var(--c-text);width:90px;font-size:12px;font-weight:600}.convert-arrow{color:var(--c-text-3);font-size:14px}.convert-targets{flex-wrap:wrap;gap:5px;display:flex}.convert-target{border-radius:var(--r-full);border:1px solid var(--c-border);color:var(--c-text-2);cursor:pointer;transition:all var(--t-fast);background:#fff;padding:3px 10px;font-size:11px;font-weight:600}.convert-target.on{background:var(--c-blue);color:#fff;border-color:var(--c-blue)}.convert-target:hover:not(.on){border-color:var(--c-text-3)}.fn-highlight{border:1px solid var(--c-border);border-radius:var(--r-lg);background:var(--c-bg);transition:box-shadow var(--t);box-shadow:0 0 #0000}.fn-highlight:focus-within,.fn-highlight.focus{border-color:#0071e340;box-shadow:0 0 0 3px #0071e31a}.asset-thumb-img{object-fit:contain;width:100%;height:100%;transition:transform .4s var(--ease);background:#fff;padding:8px;position:absolute;inset:0}.asset-thumb-img.cover{object-fit:cover;padding:0}.pw .card,.pw .asset-list,.pw .col-grid>.col-card,.pw .asset-grid>.asset-card{transition:box-shadow var(--t), transform var(--t), border-color var(--t)}.pw .section:has(.chips){border-radius:var(--r-lg);padding:var(--sp-3) var(--sp-3) var(--sp-2);margin-left:calc(-1 * var(--sp-3));margin-right:calc(-1 * var(--sp-3));background:linear-gradient(#0071e305,#0000)}.drop-zone{transition:border-color var(--t), background var(--t), box-shadow var(--t)}.drop-zone:hover{box-shadow:0 0 0 4px #0071e314}.asset-info{padding:12px 14px}.asset-info .file-chips{margin-top:6px}@media (min-width:1400px){.asset-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}}.tbl th,.tbl td{min-width:80px}.tbl th:first-child,.tbl td:first-child{min-width:60px}.tbl{table-layout:auto}.tbl td:has(.tag){white-space:nowrap}.bar-chart{align-items:flex-end;padding-bottom:20px;position:relative;height:88px!important}.bar-chart>div{flex-direction:column;align-items:center;display:flex}.bar-chart>div>div{width:100%;min-height:4px}.bar-chart>div>span{color:var(--c-text-3);white-space:nowrap;font-size:9px;position:absolute;bottom:0}.chart-trk,.chart-fil{border-radius:4px;height:8px!important}.chart-lbl{width:80px!important;font-size:12px!important}#catm-name:focus,#subm-name:focus{box-shadow:0 0 0 3px #0071e326}.rc-cat,.rc-sub{accent-color:var(--c-blue)}.action-cell{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:6px;display:inline-flex}.action-cell .btn-sm svg{width:12px;height:12px}.portal-maintenance{background:var(--c-bg);justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.portal-maintenance-card{text-align:center;border:1px solid var(--c-border);border-radius:var(--r-lg);width:100%;max-width:520px;box-shadow:var(--sh);background:#fff;padding:44px 34px}.portal-maintenance-card h1{color:var(--c-text);margin:0 0 12px;font-size:24px}.portal-maintenance-card p{color:var(--c-text-2);margin:0;font-size:14px;line-height:1.6}.scroll-box,.cms-table-wrap,.card.section{max-width:100%;overflow-x:auto}.modal-body,.cms-content,#page-area{min-width:0}.tbl{width:100%}.action-cell{flex-wrap:wrap;justify-content:flex-end;gap:6px;display:inline-flex}.portal-cat-block input,.portal-subcat-group input{flex-shrink:0}
body{min-height:100vh}#splash{z-index:9999;background:#fff;justify-content:center;align-items:center;transition:opacity .4s;display:flex;position:fixed;inset:0}#splash.out{opacity:0;pointer-events:none}#splash-inner{flex-direction:column;align-items:center;gap:16px;display:flex}#splash-mark{background:#1a1a1a;border-radius:12px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}#splash-mark svg{color:#fff;width:22px;height:22px}#splash-name{font-family:var(--f-sans);color:#1a1a1a;letter-spacing:-.1px;font-size:15px;font-weight:600}#splash-bar{background:#eee;border-radius:2px;width:140px;height:2px;overflow:hidden}#splash-fill{background:#1a1a1a;border-radius:2px;height:100%;animation:.6s ease-out forwards splashLoad}@keyframes splashLoad{0%{width:0}to{width:100%}}.overlay{justify-content:center!important;align-items:center!important;overflow:hidden!important}.modal{flex-direction:column!important;max-height:min(92vh,920px)!important;display:flex!important;overflow:hidden!important}.modal.modal-lg{max-height:min(92vh,920px)!important}.modal-hdr,.modal-footer{flex:none!important}.modal-body{overscroll-behavior:contain!important;scrollbar-gutter:stable!important;flex:auto!important;min-height:0!important;overflow:hidden auto!important}.modal-body .scroll-box,.modal-body [data-scroll-box=true]{overscroll-behavior:contain!important;max-height:min(330px,38vh)!important;overflow:auto!important}
