:root{--bg-deep:#f0f4f9;--bg-base:#f7f9fc;--bg-surface:#fff;--bg-elevated:#f4f6fb;--bg-hover:#edf1f8;--accent:#3b6de0;--accent-hover:#2f5bc7;--accent-soft:#3b6de014;--accent-medium:#3b6de026;--accent-glow:#3b6de00d;--accent-text:#2c5cc5;--text-primary:#1a2332;--text-secondary:#5a6a7e;--text-tertiary:#94a3b8;--text-inverse:#fff;--success:#16a34a;--success-soft:#16a34a14;--danger:#dc2626;--danger-soft:#dc262612;--info:#2563eb;--info-soft:#2563eb14;--border:#e2e8f0;--border-subtle:#f1f5f9;--border-accent:#3b6de033;--shadow-sm:0 1px 2px #0f172a0a;--shadow-md:0 4px 16px #0f172a0f;--shadow-lg:0 12px 40px #0f172a1a;--shadow-xl:0 20px 60px #0f172a1f;--font-display:"Crimson Pro", "Noto Serif SC", Georgia, serif;--font-body:"Outfit", "Noto Sans SC", system-ui, sans-serif;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-spring:cubic-bezier(.34, 1.56, .64, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px}body{font-family:var(--font-body);background:var(--bg-deep);color:var(--text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}::selection{background:var(--accent-medium);color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes dropzonePulse{0%,to{border-color:var(--accent);background:#3b6de00a}50%{border-color:var(--accent-hover);background:#3b6de014}}.container{max-width:1060px;margin:0 auto;padding:24px 32px}input[type=checkbox]{appearance:none;border:2px solid var(--border);background:var(--bg-surface);cursor:pointer;width:18px;height:18px;transition:all .2s var(--ease-out);border-radius:5px;flex-shrink:0;position:relative}input[type=checkbox]:hover{border-color:var(--accent)}input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}input[type=checkbox]:checked:after{content:"";border:solid var(--text-inverse);border-width:0 2px 2px 0;width:5px;height:10px;position:absolute;top:1px;left:4.5px;transform:rotate(45deg)}.btn{border-radius:var(--radius-md);font-size:13px;font-family:var(--font-body);cursor:pointer;transition:all .2s var(--ease-out);letter-spacing:.01em;border:none;align-items:center;gap:6px;padding:10px 20px;font-weight:500;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent);color:var(--text-inverse);box-shadow:0 2px 8px #3b6de040}.btn-primary:hover{background:var(--accent-hover);box-shadow:0 4px 16px #3b6de04d}.btn-secondary{background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-elevated);border-color:#cbd5e1}.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 8px #dc262633}.btn-danger:hover{background:#b91c1c}.btn-success{background:var(--success);color:var(--text-inverse);box-shadow:0 2px 8px #16a34a33}.btn-success:hover{background:#15803d}.btn-sm{border-radius:var(--radius-sm);padding:7px 14px;font-size:12.5px}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);margin-bottom:8px;font-size:13px;font-weight:500;display:block}.form-group input[type=text],.form-group input[type=password],.form-group input:not([type=checkbox]):not([type=file]){border:1px solid var(--border);border-radius:var(--radius-md);width:100%;font-size:14px;font-family:var(--font-body);color:var(--text-primary);background:var(--bg-surface);transition:all .2s var(--ease-out);padding:11px 14px}.form-group input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.form-group input::placeholder{color:var(--text-tertiary)}.error-msg{color:var(--danger);text-align:center;background:var(--danger-soft);border-radius:var(--radius-sm);animation:fadeIn .3s var(--ease-out);margin-top:10px;padding:8px 12px;font-size:13px}.login-page{background:linear-gradient(160deg,#e8f0fe 0%,#f0f4f9 40%,#faf5ff 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#3b6de014 0%,#0000 70%);border-radius:50%;width:700px;height:700px;position:absolute;top:-300px;right:-200px}.login-page:after{content:"";pointer-events:none;background:radial-gradient(circle,#8b5cf60d 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;bottom:-200px;left:-100px}.login-card{background:var(--bg-surface);border-radius:var(--radius-xl);border:1px solid var(--border);box-shadow:var(--shadow-xl);width:400px;max-width:90vw;animation:fadeInScale .6s var(--ease-out);padding:48px 40px;position:relative}.login-card:before{content:"";background:linear-gradient(90deg, transparent, var(--accent), transparent);border-radius:2px;width:60px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%)}.login-card .login-icon{justify-content:center;margin-bottom:24px;display:flex}.login-card .login-icon svg{width:48px;height:48px;color:var(--accent)}.login-card h1{text-align:center;color:var(--text-primary);font-family:var(--font-display);margin-bottom:8px;font-size:28px;font-weight:600}.login-card .subtitle{text-align:center;color:var(--text-tertiary);margin-bottom:32px;font-size:13px}.login-card .btn-primary{justify-content:center;width:100%;margin-top:8px;padding:13px;font-size:14px;font-weight:600}.admin-header{background:var(--bg-surface);border-bottom:1px solid var(--border);z-index:100;height:60px;box-shadow:var(--shadow-sm);animation:slideDown .4s var(--ease-out);justify-content:space-between;align-items:center;padding:0 32px;display:flex;position:sticky;top:0}.admin-header .logo{align-items:center;gap:12px;display:flex}.admin-header .logo svg{width:28px;height:28px;color:var(--accent)}.admin-header h1{color:var(--text-primary);font-size:17px;font-weight:600;font-family:var(--font-body)}.admin-header .actions{align-items:center;gap:4px;display:flex}.tabs{background:var(--bg-deep);border-radius:var(--radius-md);gap:2px;padding:3px;display:flex}.tab{cursor:pointer;font-size:13px;font-family:var(--font-body);color:var(--text-secondary);border-radius:var(--radius-sm);transition:all .2s var(--ease-out);background:0 0;border:none;padding:7px 18px;font-weight:500}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--text-inverse);background:var(--accent);box-shadow:0 2px 8px #3b6de033}.breadcrumb{animation:fadeIn .4s var(--ease-out);flex-wrap:wrap;align-items:center;gap:2px;padding:16px 0 8px;font-size:13.5px;display:flex}.breadcrumb a{color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s var(--ease-out);padding:4px 8px;text-decoration:none}.breadcrumb a:hover{color:var(--accent);background:var(--accent-soft)}.breadcrumb .sep{color:var(--text-tertiary);-webkit-user-select:none;user-select:none;margin:0 2px;font-size:11px}.breadcrumb strong{color:var(--text-primary);padding:4px 8px;font-weight:600}.toolbar{animation:fadeIn .4s var(--ease-out) 50ms both;flex-wrap:wrap;align-items:center;gap:8px;padding:12px 0 16px;display:flex}.toolbar .spacer{flex:1}.toolbar .selection-info{color:var(--accent-text);background:var(--accent-soft);border-radius:var(--radius-sm);border:1px solid var(--border-accent);padding:6px 14px;font-size:12.5px;font-weight:500}.file-table{border-collapse:separate;border-spacing:0;background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);width:100%;box-shadow:var(--shadow-sm);animation:fadeIn .4s var(--ease-out) .1s both;overflow:hidden}.file-table th{text-align:left;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;background:var(--bg-elevated);border-bottom:1px solid var(--border);padding:12px 16px;font-size:11.5px;font-weight:600}.file-table td{border-bottom:1px solid var(--border-subtle);padding:0 16px}.file-table tbody tr:last-child td{border-bottom:none}.file-table tbody tr{height:52px;transition:background .15s}.file-table tbody tr:hover{background:var(--bg-hover)}.file-table tbody tr.is-selected{background:var(--accent-soft)}.file-table .file-name{cursor:default;color:var(--text-primary);align-items:center;gap:12px;font-size:14px;font-weight:400;display:flex}.file-table .file-name.is-folder{cursor:pointer;color:var(--accent-text);font-weight:500}.file-table .file-name.is-folder:hover{color:var(--accent)}.file-table .file-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.file-table .file-icon.folder-icon{color:var(--accent);background:#3b6de014}.file-table .file-icon.file-icon-default{background:var(--bg-elevated);color:var(--text-tertiary)}.file-table .file-size,.file-table .file-date{color:var(--text-tertiary);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:12.5px}.file-table .col-check{width:48px}.file-table .col-name{min-width:240px}.file-table .col-size{width:100px}.file-table .col-date{width:170px}.file-table tbody tr{animation:fadeIn .35s var(--ease-out) both}.file-table tbody tr:first-child{animation-delay:30ms}.file-table tbody tr:nth-child(2){animation-delay:60ms}.file-table tbody tr:nth-child(3){animation-delay:90ms}.file-table tbody tr:nth-child(4){animation-delay:.12s}.file-table tbody tr:nth-child(5){animation-delay:.15s}.file-table tbody tr:nth-child(6){animation-delay:.18s}.file-table tbody tr:nth-child(7){animation-delay:.21s}.file-table tbody tr:nth-child(8){animation-delay:.24s}.file-table tbody tr:nth-child(n+9){animation-delay:.27s}.file-table tbody tr{cursor:default;-webkit-user-select:none;user-select:none}.file-table tbody tr input[type=checkbox]{cursor:pointer}.empty-state{text-align:center;color:var(--text-tertiary);animation:fadeIn .5s var(--ease-out);padding:80px 20px;font-size:14px}.empty-state .empty-icon{opacity:.35;margin-bottom:16px}.empty-state .empty-icon svg{width:56px;height:56px;color:var(--text-tertiary)}.empty-state p{color:var(--text-tertiary)}.drop-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:900;pointer-events:none;background:#3b6de00f;justify-content:center;align-items:center;animation:.15s overlayIn;display:flex;position:fixed;inset:0}.drop-zone{border:2.5px dashed var(--accent);border-radius:var(--radius-xl);text-align:center;background:#3b6de00a;width:460px;max-width:80vw;padding:56px 40px;animation:1.5s ease-in-out infinite dropzonePulse}.drop-zone svg{width:52px;height:52px;color:var(--accent);opacity:.7;margin-bottom:16px}.drop-zone h3{color:var(--accent-text);margin-bottom:6px;font-size:18px;font-weight:600}.drop-zone p{color:var(--text-secondary);font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f172a4d;justify-content:center;align-items:center;animation:.2s overlayIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:500px;max-width:92vw;max-height:85vh;box-shadow:var(--shadow-xl);animation:fadeInScale .3s var(--ease-out);padding:28px;overflow-y:auto}.modal h2{color:var(--text-primary);align-items:center;gap:10px;margin-bottom:20px;font-size:18px;font-weight:600;display:flex}.modal h2 svg{width:20px;height:20px;color:var(--accent)}.modal-actions{border-top:1px solid var(--border-subtle);justify-content:flex-end;gap:8px;margin-top:24px;padding-top:16px;display:flex}.share-link-box{background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-accent);align-items:center;gap:8px;margin-top:16px;padding:12px 14px;display:flex}.share-link-box input{color:var(--accent-text);background:0 0;border:none;outline:none;flex:1;padding:0;font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:13px}.upload-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:999;background:#0f172a40;justify-content:center;align-items:center;animation:.2s overlayIn;display:flex;position:fixed;inset:0}.upload-box{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-xl);animation:fadeInScale .3s var(--ease-out);padding:40px 48px}.upload-progress-ring{width:80px;height:80px;margin:0 auto 16px;position:relative}.upload-progress-ring svg{width:100%;height:100%}.upload-progress-text{color:var(--accent);justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex;position:absolute;inset:0}.upload-box p{color:var(--text-secondary);font-size:14px}.share-page{background:var(--bg-deep);min-height:100vh}.share-header{text-align:center;border-bottom:1px solid var(--border);background:linear-gradient(160deg,#dbeafe 0%,#ede9fe 50%,#fce7f3 100%);padding:56px 24px 48px;position:relative;overflow:hidden}.share-header:before{content:"";pointer-events:none;background:radial-gradient(#3b6de01a 0%,#0000 70%);width:600px;height:400px;position:absolute;top:-80px;left:50%;transform:translate(-50%)}.share-header .share-badge{color:var(--accent-text);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff9;border:1px solid #3b6de026;border-radius:20px;align-items:center;gap:6px;margin-bottom:16px;padding:6px 14px;font-size:12px;font-weight:500;display:inline-flex}.share-header .share-badge svg{width:14px;height:14px}.share-header h1{font-family:var(--font-display);color:var(--text-primary);margin-bottom:8px;font-size:30px;font-weight:600;position:relative}.share-header p{color:var(--text-secondary);font-size:13px;position:relative}.share-content{max-width:720px;margin:0 auto;padding:28px 20px}.share-actions{justify-content:center;gap:10px;margin-bottom:24px;display:flex}.share-file-list{background:var(--bg-surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.share-file-item{border-bottom:1px solid var(--border-subtle);align-items:center;gap:14px;padding:14px 20px;transition:background .15s;display:flex}.share-file-item:last-child{border-bottom:none}.share-file-item:hover{background:var(--bg-hover)}.share-file-item.select-all{background:var(--bg-elevated);border-bottom:1px solid var(--border)}.share-file-item .file-type-icon{background:var(--bg-elevated);border-radius:var(--radius-sm);width:36px;height:36px;color:var(--text-tertiary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.share-file-item .name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:13.5px;overflow:hidden}.share-file-item .size{color:var(--text-tertiary);font-variant-numeric:tabular-nums;white-space:nowrap;font-size:12.5px}.share-manager-title{color:var(--text-primary);animation:fadeIn .4s var(--ease-out);align-items:center;gap:10px;margin-bottom:20px;font-size:17px;font-weight:600;display:flex}.share-manager-title svg{width:20px;height:20px;color:var(--accent)}.share-list-item{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .2s var(--ease-out);animation:fadeIn .35s var(--ease-out) both;box-shadow:var(--shadow-sm);align-items:center;gap:16px;margin-bottom:10px;padding:16px 20px;display:flex}.share-list-item:hover{box-shadow:var(--shadow-md);border-color:#cbd5e1}.share-list-item .share-icon{background:var(--accent-soft);border-radius:var(--radius-sm);width:40px;height:40px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.share-list-item .share-icon.inactive{background:var(--bg-elevated);color:var(--text-tertiary)}.share-list-item .info{flex:1;min-width:0}.share-list-item .info .name{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:2px;font-size:14px;font-weight:500;display:flex}.share-list-item .info .name .status-badge{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:500}.share-list-item .info .name .status-badge.closed{background:var(--danger-soft);color:var(--danger)}.share-list-item .info .meta{color:var(--text-tertiary);font-size:12px}.share-list-item .share-actions-group{flex-shrink:0;gap:6px;display:flex}.share-list-item .inactive-label{color:var(--text-tertiary);font-size:12px;font-style:italic}.move-tree{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-elevated);max-height:320px;padding:6px;overflow-y:auto}.move-tree-item{cursor:pointer;border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:10px;padding:10px 14px;font-size:13.5px;transition:all .15s;display:flex}.move-tree-item:hover{background:var(--bg-hover);color:var(--text-primary)}.move-tree-item.selected{background:var(--accent);color:var(--text-inverse)}.move-tree-item svg{flex-shrink:0;width:18px;height:18px}.move-hint{color:var(--text-tertiary);margin-top:10px;font-size:12px}.move-error{color:var(--danger);margin-top:6px;font-size:12px}.loading-state{animation:fadeIn .4s var(--ease-out);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 20px;display:flex}.loading-state .spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}.loading-state p{color:var(--text-tertiary);font-size:13px}.share-error-page{background:var(--bg-deep);min-height:100vh;animation:fadeIn .5s var(--ease-out);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.share-error-page svg{width:56px;height:56px;color:var(--text-tertiary);opacity:.4}.share-error-page h2{color:var(--text-primary);font-size:20px;font-weight:600}.share-error-page p{color:var(--text-tertiary);font-size:14px}.share-path-list{margin-top:8px;list-style:none}.share-path-list li{background:var(--bg-elevated);border-radius:var(--radius-sm);color:var(--text-secondary);align-items:center;gap:8px;margin-bottom:4px;padding:6px 12px;font-family:SF Mono,Cascadia Code,Consolas,monospace;font-size:13px;display:flex}.share-path-list li svg{width:14px;height:14px;color:var(--accent);flex-shrink:0}.success-msg{background:var(--success-soft);border-radius:var(--radius-sm);color:var(--success);align-items:center;gap:8px;margin-bottom:12px;padding:10px 14px;font-size:13.5px;font-weight:500;display:flex}.success-msg svg{flex-shrink:0;width:18px;height:18px}@media (width<=768px){.admin-header{padding:0 16px}.container{padding:16px}.file-table .col-date{display:none}.login-card{padding:36px 28px}.modal{margin:16px;padding:24px 20px}}
