@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";
:root{--bg-app:#f4f4f8;--bg-sidebar:#fff;--bg-card:#fff;--bg-input:#efeff3;--bg-hover:#e8e8ee;--bg-selected:#ebf2ff;--bg-overlay:#0006;--accent:#0062ff;--accent-light:#ebf2ff;--accent-text:#004bbf;--accent-dark:#004dd6;--success:#1da462;--success-bg:#e8f7ef;--success-border:#a3dfbf;--warning:#e08a00;--warning-bg:#fff4e0;--warning-border:#f5cc80;--danger:#d93025;--danger-bg:#fdecea;--danger-border:#f5a8a4;--info:#0d7ec4;--info-bg:#e5f3fb;--info-border:#90c8e8;--text-1:#141416;--text-2:#3d3d44;--text-3:#8a8a94;--text-4:#b0b0ba;--border:#e2e2ea;--border-strong:#c8c8d4;--shadow-sm:none;--shadow-md:none;--shadow-lg:none;--sidebar-w:260px;--r-sm:8px;--r-md:12px;--r-lg:16px;--r-xl:20px;--r-full:9999px;--t-fast:.15s ease;--t-base:.25s ease}[data-theme=dark]{--bg-app:#0f1117;--bg-sidebar:#161b27;--bg-card:#1c2130;--bg-input:#232a3b;--bg-hover:#252c3e;--bg-selected:#1a2e50;--bg-overlay:#0009;--accent:#4d8bff;--accent-light:#1a2e50;--accent-text:#7aadff;--accent-dark:#3a78f0;--success:#2dd47a;--success-bg:#0d2e1e;--success-border:#1a5c38;--warning:#f5a623;--warning-bg:#2e2108;--warning-border:#6b4a12;--danger:#f25c54;--danger-bg:#2e0d0b;--danger-border:#6b1f1b;--info:#38b6f5;--info-bg:#0a2130;--info-border:#174766;--text-1:#f0f2f8;--text-2:#bcc3d6;--text-3:#7a8299;--text-4:#4e5670;--border:#252c3e;--border-strong:#343d56}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--bg-app);color:var(--text-1);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:15px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}.icon{letter-spacing:normal;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;vertical-align:middle;direction:ltr;flex-shrink:0;font-family:Material Symbols Outlined;font-size:22px;font-style:normal;font-weight:400;line-height:1;display:inline-block}.icon-sm{font-size:18px}.icon-lg{font-size:28px}.icon-xl{font-size:40px}
.w-full{width:100%}.h-full{height:100%}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full)}.desktop-only{display:block}.mobile-only{display:none}@media (max-width:768px){.desktop-only{display:none!important}.mobile-only{display:block!important}}.spinner{border:2px solid #0000001f;border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.65s linear infinite spin}.spinner-sm{width:15px;height:15px}.spinner-lg{border-width:3px;width:32px;height:32px}.spinner-white{border-color:#fff #ffffff4d #ffffff4d}.loading-full{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:14px;min-height:360px;display:flex}.loading-text{color:var(--text-3);font-size:.875rem}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:11px;padding:60px 24px;display:flex}.empty-icon{color:var(--text-4);margin-bottom:4px}.empty-title{color:var(--text-1);font-size:1rem;font-weight:600}.empty-desc{color:var(--text-3);max-width:320px;font-size:.85rem}.flex{display:flex}.flex-center{justify-content:center;align-items:center;display:flex}
.app-layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.page-container{flex:1;width:100%;max-width:1600px;padding:48px 56px}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-logo{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:22px 20px;display:flex}.sidebar-logo-icon{background:var(--accent);border-radius:var(--r-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.sidebar-logo-text{color:var(--text-1);font-size:.95rem;font-weight:700;line-height:1.2}.sidebar-logo-sub{color:var(--text-3);margin-top:1px;font-size:.72rem;font-weight:400}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px;display:flex;overflow-y:auto}.sidebar-section-label{text-transform:uppercase;letter-spacing:.09em;color:var(--text-4);padding:14px 8px 5px;font-size:.65rem;font-weight:700}.nav-item{border-radius:var(--r-md);color:var(--text-3);transition:background-color var(--t-fast),color var(--t-fast);text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:10px 14px;font-size:.88rem;font-weight:500;text-decoration:none;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-1)}.nav-item.active{background:var(--bg-selected);color:var(--accent);font-weight:600}.nav-item.active .nav-icon{color:var(--accent)}.sidebar-footer{border-top:1px solid var(--border);padding:14px}.user-card{border-radius:var(--r-md);background:var(--bg-hover);align-items:center;gap:10px;padding:10px 12px;display:flex}.user-avatar{border-radius:var(--r-full);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.72rem;font-weight:700;display:flex}.user-info{flex:1;min-width:0}.user-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;overflow:hidden}.user-role{color:var(--text-4);margin-top:1px;font-size:.7rem}.logout-btn{color:var(--text-4);border-radius:var(--r-sm);transition:color var(--t-fast);background:0 0;border:none;align-items:center;padding:5px;display:flex}.logout-btn:hover{color:var(--danger)}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title-group{min-width:0}.page-title{color:var(--text-1);letter-spacing:-.035em;margin-bottom:6px;font-size:2.2rem;font-weight:800;line-height:1.1}.page-subtitle{color:var(--text-3);margin-top:4px;font-size:1rem;line-height:1.5}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:24px;display:flex}.toolbar-filters{align-items:center;gap:8px;display:flex}.search-wrap{flex:1;min-width:200px;position:relative}.search-icon-el{color:var(--text-4);pointer-events:none;z-index:1;position:absolute;top:50%;left:13px;transform:translateY(-50%);font-size:18px!important}.search-input{height:42px;padding-left:40px!important}.grid-2{grid-template-columns:1fr 1fr;gap:20px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.bottom-nav{background:var(--bg-sidebar);border-top:1px solid var(--border);z-index:1000;height:64px;padding-bottom:env(safe-area-inset-bottom);display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-container{justify-content:space-around;align-items:center;height:100%;display:flex}.bottom-nav-item{color:var(--text-3);transition:all var(--t-fast);flex-direction:column;align-items:center;gap:4px;min-width:60px;padding:8px;font-size:.64rem;font-weight:500;text-decoration:none;display:flex}.bottom-nav-item .icon{font-size:24px}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-item.active .icon{font-variation-settings:"FILL" 1}@media (max-width:900px){.grid-2,.grid-3,.form-row{grid-template-columns:1fr}}@media (max-width:768px){:root{--sidebar-w:0px}.sidebar{display:none}.bottom-nav{height:calc(64px + env(safe-area-inset-bottom));display:block}.main-content{padding-bottom:calc(70px + env(safe-area-inset-bottom));width:100vw;margin-left:0;overflow-x:hidden}.page-container{max-width:100%;padding:18px 16px}.page-header{flex-direction:column;align-items:stretch;gap:16px}.page-header .btn{justify-content:center;width:100%}.page-title{font-size:1.4rem}.toolbar{flex-direction:column;align-items:stretch;gap:12px}.toolbar>.btn{justify-content:center;width:100%}.toolbar-filters{scrollbar-width:none;gap:10px;padding:2px 0 6px;display:flex;overflow-x:auto;-webkit-mask-image:linear-gradient(90deg,#000 85%,#0000 100%);mask-image:linear-gradient(90deg,#000 85%,#0000 100%)}.toolbar-filters::-webkit-scrollbar{display:none}.mobile-list{flex-direction:column;gap:12px;padding:4px;display:flex}.mobile-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);transition:background-color var(--t-fast);flex-direction:column;gap:14px;padding:16px;display:flex}.mobile-card:active{background:var(--bg-hover)}.mobile-card-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.mobile-card-main{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.mobile-card-title{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.mobile-card-sub{color:var(--text-4);margin-top:2px;font-size:.75rem}.mobile-card-stats{background:var(--bg-app);border-radius:var(--r-md);gap:16px;padding:10px 12px;display:flex}.mobile-stat-item{flex-direction:column;gap:2px;display:flex}.mobile-stat-label{text-transform:uppercase;color:var(--text-4);letter-spacing:.05em;font-size:.62rem;font-weight:700}.mobile-stat-value{color:var(--text-2);font-size:.8rem;font-weight:600}.search-wrap{width:100%}.modal{border-radius:0;max-width:100%;height:100%;max-height:100%;margin:0;animation:.3s slideUp}.modal-overlay{padding:0}.modal-header{border-radius:0;padding:16px 20px}.modal-body{padding:16px 20px}.modal-footer{padding:16px 20px 24px}.info-grid{grid-template-columns:1fr;gap:12px}.stat-card{gap:12px;padding:16px}.stat-value{font-size:1.4rem}.table-wrapper{border-left:none;border-right:none;border-radius:0;margin:0 -16px}.version-badge{padding:2px 6px;font-size:.7rem}.badge{padding:2px 8px;font-size:.72rem}.tabs{-webkit-overflow-scrolling:touch;white-space:nowrap;scrollbar-width:none;gap:0;overflow-x:auto;padding:0 16px!important}.tabs::-webkit-scrollbar{display:none}.tab-btn{flex-shrink:0;padding:12px 16px;font-size:.82rem}.grid-3{grid-template-columns:1fr!important;gap:16px!important}.preview-strip{padding-bottom:8px}.preview-thumb-wrap{width:100px;height:180px}.btn{padding:10px 16px;font-size:.85rem}.btn-sm{padding:8px 12px}.form-group{margin-bottom:20px}}@media (max-width:480px){.page-title{font-size:1.25rem}.modal-subtitle{font-size:.75rem}.card{border-radius:var(--r-lg)}.card>div{padding:16px!important}.table th:nth-child(6),.table td:nth-child(6),.table th:nth-child(7),.table td:nth-child(7){display:none}.app-icon{width:28px;height:28px}}
.ripple{position:relative;overflow:hidden}.ripple:after{content:"";opacity:0;pointer-events:none;border-radius:inherit;background:currentColor;transition:opacity .4s;position:absolute;inset:0}.ripple:active:after{opacity:.08;transition:opacity}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);transition:border-color var(--t-fast),background-color var(--t-fast);align-items:center;gap:18px;padding:22px 24px;display:flex}.stat-card:hover{border-color:var(--border-strong);background-color:var(--bg-hover)}.stat-icon{border-radius:var(--r-md);background:var(--bg-hover);width:48px;height:48px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.stat-value{color:var(--text-1);letter-spacing:-.02em;margin-top:4px;font-size:2rem;font-weight:700;line-height:1.1}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden}.card-header{border-bottom:1px solid var(--bg-hover);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.card-title{color:var(--text-1);font-size:1.05rem;font-weight:600}.card-subtitle{color:var(--text-3);margin-top:4px;font-size:.82rem}.btn{border-radius:var(--r-md);transition:background-color var(--t-fast),color var(--t-fast),border-color var(--t-fast);white-space:nowrap;-webkit-user-select:none;user-select:none;cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;display:inline-flex}.btn:active{opacity:.85}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dark)}.btn-secondary{background:var(--bg-card);color:var(--text-2);border-color:var(--border-strong)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-1)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-ghost{color:var(--text-3);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-1)}.btn-sm{padding:8px 18px;font-size:.82rem}.btn-icon{aspect-ratio:1;border-radius:var(--r-full);flex-shrink:0;padding:10px}.table td .btn{padding-left:12px;padding-right:12px}.table td .btn-icon{width:34px;height:34px;padding:8px}.btn:disabled{opacity:.45;cursor:not-allowed}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);border-bottom:2px solid var(--bg-hover);background:var(--bg-app);white-space:nowrap;padding:14px 20px;font-size:.75rem;font-weight:700}.table td{border-bottom:1px solid var(--bg-hover);color:var(--text-1);vertical-align:middle;padding:16px 20px;font-size:.9rem}.table tr:last-child td{border-bottom:none}.table tbody tr{cursor:pointer;transition:background-color var(--t-fast)}.table tbody tr:hover td{background:var(--bg-hover)}.badge{border-radius:var(--r-full);letter-spacing:.02em;white-space:nowrap;text-transform:uppercase;border:1px solid #0000;align-items:center;gap:4px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-neutral{background:var(--bg-hover);color:var(--text-2)}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-2);font-size:.82rem;font-weight:600}.form-required{color:var(--danger);margin-left:2px}.form-input,.form-select,.form-textarea{background:var(--bg-input);color:var(--text-1);transition:border-color var(--t-fast),background-color var(--t-fast),box-shadow var(--t-fast);border:1.5px solid #0000;border-radius:14px;outline:none;width:100%;padding:13px 16px;font-family:inherit;font-size:.95rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent);background:var(--bg-card)}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-4)}.form-select{cursor:pointer}.form-textarea{resize:vertical;min-height:84px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-hint{color:var(--text-4);margin-top:2px;font-size:.74rem}.form-error{color:var(--danger);margin-top:2px;font-size:.74rem}.toggle-wrapper{align-items:center;gap:11px;display:flex}.toggle{flex-shrink:0;width:42px;height:24px;position:relative}.toggle input{opacity:0;width:0;height:0}.toggle-track{background:var(--border-strong);border-radius:var(--r-full);cursor:pointer;transition:background var(--t-base);border:1px solid var(--border-strong);position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--accent);border-color:var(--accent)}.toggle-track:after{content:"";border-radius:var(--r-full);width:16px;height:16px;transition:transform var(--t-base);background:#fff;position:absolute;top:50%;left:3px;transform:translateY(-50%)}.toggle input:checked+.toggle-track:after{transform:translate(18px,-50%)}.toggle-label{color:var(--text-1);font-size:.875rem;font-weight:500}.modal-overlay{background:var(--bg-overlay);z-index:1000;justify-content:center;align-items:center;padding:24px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:scale(.95)translateY(20px)}50%{opacity:1}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:scale(.95)translateY(-20px)}50%{opacity:1}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;width:100%;max-width:580px;min-height:200px;max-height:90vh;animation:.2s slideUp;display:flex;overflow:hidden}.modal-lg{max-width:780px}.modal-sm{max-width:420px}.modal-header{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:10;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;position:sticky;top:0}.modal-title{color:var(--text-1);font-size:1.05rem;font-weight:700}.modal-subtitle{color:var(--text-3);margin-top:2px;font-size:.78rem}.modal-close{background:var(--bg-hover);border-radius:var(--r-md);cursor:pointer;width:32px;height:32px;color:var(--text-3);transition:all var(--t-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--border);color:var(--text-1)}.modal-body{flex-direction:column;gap:20px;padding:24px 28px;display:flex}.modal-footer{border-top:1px solid var(--border);background:var(--bg-card);z-index:10;justify-content:flex-end;align-items:center;gap:10px;padding:18px 28px 22px;display:flex;position:sticky;bottom:0}.confirm-dialog{max-width:400px}.confirm-icon{border-radius:var(--r-full);justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;display:flex}.confirm-icon-danger{background:var(--danger-bg);color:var(--danger)}.confirm-icon-warning{background:var(--warning-bg);color:var(--warning)}.confirm-text{text-align:center}.confirm-text h3{color:var(--text-1);margin-bottom:6px;font-size:1.05rem;font-weight:700}.confirm-text p{color:var(--text-3);font-size:.875rem}.toast-container{z-index:2000;pointer-events:none;flex-direction:column;gap:9px;display:flex;position:fixed;top:22px;right:22px}.toast{border-radius:var(--r-lg);border:1px solid var(--border);background:var(--bg-card);pointer-events:auto;align-items:flex-start;gap:12px;min-width:290px;max-width:400px;padding:14px 18px;animation:.25s slideDown;display:flex}.toast-success{border-color:var(--success-border);background:var(--success-bg)}.toast-error{border-color:var(--danger-border);background:var(--danger-bg)}.toast-icon{flex-shrink:0;margin-top:1px;font-size:20px}.toast-icon-success{color:var(--success)}.toast-icon-error{color:var(--danger)}.toast-content{flex:1}.toast-title{color:var(--text-1);font-size:.875rem;font-weight:600}.toast-message{color:var(--text-3);margin-top:2px;font-size:.8rem}.app-icon{border-radius:var(--r-md);object-fit:cover;background:var(--bg-hover);border:1px solid var(--border);flex-shrink:0;width:42px;height:42px}.app-icon-lg{border-radius:var(--r-lg);width:60px;height:60px}.app-icon-xl{border-radius:var(--r-xl);width:84px;height:84px}.app-icon-placeholder{color:var(--text-4);justify-content:center;align-items:center;display:flex}.progress-bar{background:var(--bg-hover);border-radius:var(--r-full);width:100%;height:6px;overflow:hidden}.progress-fill{background:var(--accent);border-radius:var(--r-full);height:100%;transition:width .3s}.tabs{background:var(--bg-input);border-radius:var(--r-full);scrollbar-width:none;border-bottom:none;gap:6px;width:fit-content;max-width:100%;margin-bottom:24px;padding:4px;display:flex;overflow-x:auto}.tabs::-webkit-scrollbar{display:none}.tab-btn{color:var(--text-3);border-radius:var(--r-full);cursor:pointer;transition:background-color var(--t-fast),color var(--t-fast),box-shadow var(--t-fast);white-space:nowrap;background:0 0;border:none;flex-shrink:0;align-items:center;gap:7px;padding:9px 20px;font-family:inherit;font-size:.875rem;font-weight:500;display:flex}.tab-btn:hover{color:var(--text-1);background:#0000000d}.tab-btn.active{color:var(--text-1);background:var(--bg-card);font-weight:600}.version-badge{background:var(--accent-light);color:var(--accent-text);border-radius:var(--r-sm);white-space:nowrap;flex-shrink:0;padding:4px 10px;font-family:SF Mono,Fira Code,monospace;font-size:.72rem;font-weight:700}.info-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.preview-strip{gap:10px;padding-bottom:6px;display:flex;overflow-x:auto}.preview-thumb-wrap{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-hover);transition:border-color var(--t-fast);flex-shrink:0;position:relative;overflow:hidden}.preview-thumb-wrap:hover{border-color:var(--border-strong)}.preview-thumb{object-fit:cover;width:90px;height:160px;display:block}.preview-thumb-del{color:#fff;cursor:pointer;opacity:0;width:24px;height:24px;transition:opacity var(--t-fast);background:#dc2626e6;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:4px;right:4px}.preview-thumb-wrap:hover .preview-thumb-del{opacity:1}.dropzone{border:1.5px dashed var(--border-strong);border-radius:var(--r-lg);text-align:center;cursor:pointer;transition:all var(--t-base);background:var(--bg-input);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:30px;display:flex}.dropzone:hover,.dropzone.drag-over{border-color:var(--accent);background:var(--accent-light)}.dropzone-title{color:var(--text-1);font-size:.875rem;font-weight:600}.dropzone-subtitle{color:var(--text-3);font-size:.78rem}.status-button-group{grid-template-columns:1fr 1fr;gap:10px;display:grid}.status-select-btn{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-2);text-align:left;transition:all var(--t-fast);padding:12px 16px;font-size:.875rem;font-weight:600}.status-select-btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}.status-select-btn.active{border-width:2px}.status-pending.active{border-color:var(--text-4);color:var(--text-1);background:var(--bg-hover)}.status-todo.active{border-color:var(--warning);color:var(--warning);background:var(--warning-bg)}.status-progress.active{border-color:var(--info);color:var(--info);background:var(--info-bg)}.status-done.active{border-color:var(--success);color:var(--success);background:var(--success-bg)}.detail-modal .detail-hero{padding:36px 40px 24px!important}.detail-modal .detail-title{font-size:1.6rem!important;font-weight:800!important}
@media (max-width:768px){.login-hero{display:none}.login-panel{width:100%!important;box-shadow:none!important;padding:48px 28px!important}}.login-logo{align-items:center;gap:12px;margin-bottom:32px;display:flex}.login-logo-icon{background:var(--accent);border-radius:var(--r-lg);color:#fff;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.detail-modal{background:var(--bg-card)!important;border-radius:var(--r-xl)!important;flex-direction:column!important;max-width:900px!important;padding:0!important;display:flex!important;overflow:hidden!important}.detail-hero{background:var(--bg-card);border-bottom:1px solid var(--border);padding:40px 44px 32px;position:relative}.detail-close{top:20px;right:20px;background:var(--bg-app)!important;border:none!important;border-radius:50%!important;width:36px!important;height:36px!important;position:absolute!important}.detail-hero-content{justify-content:space-between;align-items:center;gap:32px;display:flex}.detail-app-info{flex:1;align-items:center;gap:28px;display:flex}.detail-meta{flex:1}.detail-title{color:var(--text-1);letter-spacing:-.035em;margin-bottom:6px;font-size:2.2rem;font-weight:800;line-height:1.1}.detail-badge-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.detail-actions{gap:12px;display:flex}.detail-tabs{background:var(--bg-card);border-bottom:1px solid var(--border);margin-bottom:0!important;padding:0 40px!important}.detail-tabs .tab-btn{padding:18px 20px;font-size:.9rem;font-weight:600}.detail-body{flex-direction:column;flex:1;display:flex;overflow:hidden;padding:0!important}.detail-scrollable{flex:1;padding:40px;overflow-y:auto}.detail-section{margin-bottom:40px}.detail-section-title{color:var(--text-4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:16px;font-size:.72rem;font-weight:800}.detail-desc{color:var(--text-2);white-space:pre-wrap;font-size:1rem;line-height:1.75}.detail-grid{background:var(--bg-app);border-radius:var(--r-xl);grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:32px;margin:40px 0;padding:28px 32px;display:grid}.detail-kv{flex-direction:column;gap:6px;display:flex}.detail-kv-label{color:var(--text-4);text-transform:uppercase;letter-spacing:.05em;font-size:.65rem;font-weight:700}.detail-kv-value{color:var(--text-1);font-size:1rem;font-weight:700}.simple-list{flex-direction:column;display:flex}.simple-list-item{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:20px;padding:18px 0;display:flex}.simple-list-item:last-child{border-bottom:none}.simple-list-main{flex:1;min-width:0}.simple-list-title{align-items:baseline;gap:8px;margin-bottom:2px;display:flex}.simple-list-sub{color:var(--text-3);font-size:.82rem;font-weight:500}.text-sm{font-size:.82rem}@media (max-width:768px){.detail-hero{padding:32px 24px 28px}.detail-hero-content{flex-direction:column;align-items:stretch;gap:32px}.detail-app-info{text-align:center;flex-direction:column;align-items:center;gap:20px}.detail-badge-row{justify-content:center}.detail-actions{flex-direction:column;gap:12px}.detail-scrollable{padding:32px 24px}.detail-grid{grid-template-columns:1fr 1fr;gap:20px;padding:24px}}.kanban-board{gap:20px;min-height:calc(100vh - 280px);padding-bottom:24px;display:flex;overflow-x:auto}.kanban-column{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);flex-direction:column;flex:1;gap:16px;min-width:300px;padding:20px;display:flex}.kanban-column-header{justify-content:space-between;align-items:center;padding:4px 8px 8px;display:flex}.kanban-column-title{color:var(--text-2);text-transform:uppercase;letter-spacing:.07em;font-size:.9rem;font-weight:700}.kanban-column-count{color:var(--text-3);background:var(--bg-hover);border-radius:var(--r-full);padding:3px 10px;font-size:.72rem;font-weight:800}.kanban-column-content{flex-direction:column;flex:1;gap:12px;display:flex;overflow-y:auto}.kanban-empty{text-align:center;color:var(--text-4);border:2px dashed var(--border-strong);border-radius:var(--r-lg);padding:32px;font-size:.82rem}.feedback-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:background-color var(--t-fast),border-color var(--t-fast);flex-direction:column;gap:10px;padding:14px 16px;display:flex}.feedback-card:hover{background-color:var(--bg-selected);border-color:var(--accent)}.feedback-card-header{justify-content:space-between;align-items:center;display:flex}.feedback-card-time{color:var(--text-4);font-size:.7rem;font-weight:500}.feedback-card-title{color:var(--text-1);-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;margin-bottom:0;font-size:.9rem;font-weight:700;display:-webkit-box;overflow:hidden}.feedback-card-preview{color:var(--text-3);-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;margin-bottom:4px;font-size:.82rem;line-height:1.4;display:-webkit-box;overflow:hidden}.feedback-card-footer{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.feedback-card-user{color:var(--text-3);align-items:center;gap:6px;font-size:.75rem;font-weight:500;display:flex}.feedback-card-attachments{color:var(--accent);align-items:center;gap:4px;font-size:.75rem;font-weight:600;display:flex}.feedback-message-box{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-lg);color:var(--text-1);white-space:pre-wrap;padding:20px;font-size:.95rem;line-height:1.6}.feedback-screenshot-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;display:grid}.feedback-screenshot-item{aspect-ratio:9/16;border-radius:var(--r-sm);border:1px solid var(--border);transition:opacity var(--t-fast),border-color var(--t-fast);overflow:hidden}.feedback-screenshot-item:hover{opacity:.9;border-color:var(--accent)}.feedback-screenshot-item img{object-fit:cover;width:100%;height:100%}.info-kv-grid{background:var(--bg-input);border-radius:var(--r-lg);border:1px solid var(--border);grid-template-columns:1fr 1fr;gap:16px;padding:16px;display:grid}.info-kv{flex-direction:column;gap:2px;display:flex}.info-label{color:var(--text-4);text-transform:uppercase;font-size:.65rem;font-weight:700}.info-value{color:var(--text-2);font-size:.85rem;font-weight:600}.contact-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);flex-direction:column;gap:12px;padding:16px;display:flex}.contact-item{align-items:flex-start;gap:12px;display:flex}.contact-item .icon{color:var(--accent);margin-top:2px}.contact-label{color:var(--text-4);text-transform:uppercase;font-size:.65rem;font-weight:700}.contact-value{color:var(--text-1);font-size:.875rem;font-weight:600}@media (max-width:1200px){.kanban-board{flex-wrap:wrap}.kanban-column{min-width:45%}}@media (max-width:768px){.kanban-column{min-width:100%}.detail-grid{grid-template-columns:1fr;gap:32px}}.db-grid-main{grid-template-columns:2fr 1fr;gap:24px;margin-top:24px;display:grid}@media (max-width:1100px){.db-grid-main{grid-template-columns:1fr}}.trend-up{background:var(--success-bg);color:var(--success)}.trend-down{background:var(--danger-bg);color:var(--danger)}.activity-feed{flex-direction:column;display:flex}.activity-item{border-bottom:1px solid var(--border);transition:background var(--t-fast);gap:16px;padding:18px 24px;display:flex}.activity-item:hover{background:var(--bg-hover)}.activity-icon{background:var(--bg-app);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.activity-content{flex:1;min-width:0}.activity-text{color:var(--text-1);font-size:.875rem;line-height:1.4}.activity-text b{font-weight:600}.activity-time{color:var(--text-4);margin-top:4px;font-size:.75rem;display:block}.chart-container-large{justify-content:space-between;align-items:flex-end;gap:12px;height:320px;padding:24px;display:flex}.large-chart-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;gap:12px;height:100%;display:flex}.large-chart-bar{background:var(--accent);border-radius:var(--r-sm)var(--r-sm)0 0;opacity:1;width:100%;max-width:44px;transition:opacity var(--t-fast);position:relative}.large-chart-bar:hover{opacity:.75}.large-chart-bar:after{content:attr(data-value);color:var(--text-2);opacity:0;font-size:.7rem;font-weight:700;transition:opacity .2s;position:absolute;top:-24px;left:50%;transform:translate(-50%)}.large-chart-bar:hover:after{opacity:1}.large-chart-label{color:var(--text-4);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}
*,:before,:after{transition:background-color .2s,border-color .2s,color .15s,box-shadow .2s}[data-theme=dark] table tr:hover td{background:var(--bg-hover)!important}[data-theme=dark] .sidebar{border-right-color:var(--border)}
