.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#4f46e5,#7c3aed)}.auth-card{background:var(--bg);border-radius:12px;box-shadow:var(--shadow-lg);padding:40px;width:100%;max-width:420px}.auth-card h1{font-size:24px;font-weight:600;text-align:center;margin-bottom:8px;color:var(--text)}.auth-logo{display:block;margin:0 auto 8px;height:40px;width:auto}.auth-card .subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:14px}.auth-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid var(--border-light)}.auth-tabs button{flex:1;padding:12px;font-size:14px;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-2px;transition:var(--transition)}.auth-tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}.form-group input{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;transition:var(--transition);outline:none}.form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.auth-error{background:#fce8e6;color:var(--danger);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px}.auth-submit{padding:12px;background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:var(--transition)}.auth-submit:hover{background:var(--primary-hover)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-success{background:#e6f4ea;color:var(--success);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;text-align:center}.folder-tree{padding:4px 0}.folder-tree-node{-webkit-user-select:none;user-select:none}.folder-tree-node__row{display:flex;align-items:center;gap:4px;padding:6px 8px;cursor:pointer;transition:var(--transition);border-radius:0 var(--radius) var(--radius) 0;margin-right:8px}.folder-tree-node__row:hover{background:var(--bg-hover)}.folder-tree-node__row.active{background:var(--bg-selected);color:var(--primary)}.folder-tree-node__toggle{width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:10px;color:var(--text-light);flex-shrink:0;border-radius:var(--radius-sm)}.folder-tree-node__toggle:hover{background:var(--border-light)}.folder-tree-node__icon{font-size:16px;color:var(--text-secondary);flex-shrink:0}.folder-tree-node__row.active .folder-tree-node__icon{color:var(--primary)}.folder-tree-node__name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.folder-tree-node__children{padding-left:16px}.file-browser{padding:16px;min-height:100%}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.file-card{display:flex;flex-direction:column;align-items:center;padding:16px 12px;border-radius:var(--radius);cursor:pointer;transition:var(--transition);border:2px solid transparent;position:relative}.file-card:hover{background:var(--bg-hover)}.file-card.selected{background:var(--bg-selected);border-color:var(--primary)}.file-card__thumbnail{width:100%;height:100px;display:flex;align-items:center;justify-content:center;margin-bottom:8px;border-radius:var(--radius-sm);overflow:hidden}.file-card__thumbnail img{max-width:100%;max-height:100%;object-fit:cover;border-radius:var(--radius-sm)}.file-card__icon{font-size:48px;color:var(--text-secondary)}.file-card__icon--folder{color:var(--warning)}.file-card__icon--image{color:var(--primary)}.file-card__name{font-size:12px;text-align:center;word-break:break-word;line-height:1.3;max-height:2.6em;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.file-list{width:100%}.file-list__header{display:grid;grid-template-columns:1fr 100px 160px;gap:16px;padding:8px 16px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}.file-list__header span{cursor:pointer;display:flex;align-items:center;gap:4px}.file-list__header span:hover{color:var(--text)}.file-row{display:grid;grid-template-columns:1fr 100px 160px;gap:16px;padding:8px 16px;font-size:13px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--border-light);align-items:center}.file-row:hover{background:var(--bg-hover)}.file-row.selected{background:var(--bg-selected)}.file-row__name{display:flex;align-items:center;gap:10px;overflow:hidden}.file-row__name svg{flex-shrink:0;font-size:20px}.file-row__name span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-row__size,.file-row__modified{color:var(--text-secondary);font-size:12px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-light)}.empty-state__icon{font-size:64px;margin-bottom:16px;opacity:.4}.empty-state__text{font-size:16px;margin-bottom:8px}.empty-state__subtext{font-size:13px}.search-results{padding:16px}.search-results__header{font-size:13px;color:var(--text-secondary);margin-bottom:12px}.search-result-item{display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.search-result-item:hover{background:var(--bg-hover)}.search-result-item__info{overflow:hidden}.search-result-item__name{font-size:13px;font-weight:500}.search-result-item__path{font-size:11px;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-panel{padding:20px}.preview-panel__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-light);font-size:13px;text-align:center;padding:40px 20px}.preview-panel__empty svg{font-size:48px;margin-bottom:12px;opacity:.3}.preview-panel__image{width:100%;border-radius:var(--radius);overflow:hidden;margin-bottom:16px;cursor:pointer;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;min-height:200px}.preview-panel__image img{max-width:100%;max-height:300px;object-fit:contain}.preview-panel__icon{display:flex;align-items:center;justify-content:center;padding:40px;margin-bottom:16px}.preview-panel__icon svg{font-size:80px;color:var(--text-light);opacity:.5}.preview-panel__name{font-size:16px;font-weight:600;word-break:break-word;margin-bottom:16px}.preview-panel__meta{display:flex;flex-direction:column;gap:8px}.preview-panel__meta-row{display:flex;justify-content:space-between;font-size:12px}.preview-panel__meta-label{color:var(--text-light)}.preview-panel__meta-value{color:var(--text);font-weight:500}.preview-panel__actions{margin-top:20px;display:flex;flex-direction:column;gap:8px}.preview-action-btn{display:flex;align-items:center;gap:8px;padding:8px 12px;font-size:13px;color:var(--text);border-radius:var(--radius-sm);transition:var(--transition);width:100%}.preview-action-btn:hover{background:var(--bg-hover)}.image-modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;cursor:pointer}.image-modal-overlay img{max-width:90vw;max-height:90vh;object-fit:contain;cursor:default;border-radius:var(--radius)}.image-modal__close{position:absolute;top:16px;right:16px;color:#fff;font-size:24px;padding:8px;border-radius:50%;background:#ffffff1a;transition:var(--transition)}.image-modal__close:hover{background:#fff3}.toolbar{display:flex;align-items:center;gap:8px;padding:8px 16px;border-bottom:1px solid var(--border-light);background:var(--bg)}.toolbar__left{display:flex;align-items:center;gap:8px}.toolbar__right{display:flex;align-items:center;gap:8px;margin-left:auto}.toolbar-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;color:var(--text);transition:var(--transition)}.toolbar-btn:hover{background:var(--bg-hover)}.toolbar-btn--primary{background:var(--primary);color:#fff}.toolbar-btn--primary:hover{background:var(--primary-hover)}.toolbar-btn--danger{color:var(--danger)}.toolbar-btn--danger:hover{background:#fce8e6}.new-button-wrapper{position:relative}.new-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:200px;z-index:100;padding:4px 0}.new-dropdown__item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 16px;font-size:13px;color:var(--text);transition:var(--transition)}.new-dropdown__item:hover{background:var(--bg-hover)}.new-dropdown__item svg{font-size:16px;color:var(--text-secondary)}.search-bar{position:relative;width:300px}.search-bar input{width:100%;padding:8px 12px 8px 36px;border:1px solid var(--border);border-radius:24px;font-size:13px;outline:none;transition:var(--transition);background:var(--bg-secondary)}.search-bar input:focus{border-color:var(--primary);background:var(--bg);box-shadow:0 0 0 2px var(--primary-light)}.search-bar__icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-light);font-size:14px}.search-bar__clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:var(--text-light);font-size:16px;padding:2px;border-radius:50%}.search-bar__clear:hover{background:var(--bg-hover);color:var(--text)}.view-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.view-toggle button{padding:6px 10px;font-size:16px;color:var(--text-secondary);transition:var(--transition)}.view-toggle button:hover{background:var(--bg-hover)}.view-toggle button.active{background:var(--primary-light);color:var(--primary)}.breadcrumb{display:flex;align-items:center;gap:4px;padding:8px 16px;font-size:13px;color:var(--text-secondary);border-bottom:1px solid var(--border-light);background:var(--bg);flex-wrap:wrap}.breadcrumb__item{color:var(--text-secondary);padding:2px 6px;border-radius:var(--radius-sm);transition:var(--transition)}.breadcrumb__item:hover{background:var(--bg-hover);color:var(--primary)}.breadcrumb__item.current{color:var(--text);font-weight:500}.breadcrumb__separator{color:var(--text-light);font-size:12px}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:500}.modal{background:var(--bg);border-radius:12px;box-shadow:var(--shadow-lg);min-width:400px;max-width:500px;max-height:80vh;overflow-y:auto}.modal__header{padding:20px 24px 0;font-size:18px;font-weight:600}.modal__body{padding:16px 24px}.modal__footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 24px 20px}.modal-btn{padding:8px 20px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:var(--transition)}.modal-btn--cancel{color:var(--text-secondary)}.modal-btn--cancel:hover{background:var(--bg-hover)}.modal-btn--primary{background:var(--primary);color:#fff}.modal-btn--primary:hover{background:var(--primary-hover)}.modal-btn--danger{background:var(--danger);color:#fff}.modal-btn--danger:hover{background:var(--danger-hover)}.modal-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;outline:none;transition:var(--transition)}.modal-input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.delete-list{list-style:none;margin-top:8px}.delete-list li{padding:4px 0;font-size:13px;color:var(--text);display:flex;align-items:center;gap:6px}.context-menu{position:fixed;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;padding:4px 0;z-index:200}.context-menu__item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 16px;font-size:13px;color:var(--text);transition:var(--transition)}.context-menu__item:hover{background:var(--bg-hover)}.context-menu__item--danger{color:var(--danger)}.context-menu__item--danger:hover{background:#fce8e6}.context-menu__separator{height:1px;background:var(--border-light);margin:4px 0}.upload-progress{position:fixed;bottom:16px;right:16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:300px;z-index:300;max-height:300px;overflow-y:auto}.upload-progress__header{padding:12px 16px;font-size:13px;font-weight:600;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}.upload-progress__item{display:flex;align-items:center;gap:10px;padding:8px 16px}.upload-progress__name{flex:1;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-progress__bar{flex:1;height:4px;background:var(--border-light);border-radius:2px;overflow:hidden}.upload-progress__bar-fill{height:100%;background:var(--primary);border-radius:2px;transition:width .2s ease}.move-tree{max-height:300px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px}.move-tree-item{display:flex;align-items:center;gap:6px;padding:6px 8px;font-size:13px;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.move-tree-item:hover{background:var(--bg-hover)}.move-tree-item.selected{background:var(--bg-selected);color:var(--primary)}.move-tree-item__children{padding-left:20px}.notification{position:fixed;top:16px;right:16px;padding:12px 20px;border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:13px;z-index:1000;animation:slideIn .2s ease}.notification--success{background:#e6f4ea;color:var(--success);border:1px solid #ceead6}.notification--error{background:#fce8e6;color:var(--danger);border:1px solid #f5c6c0}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.dropzone-overlay{position:absolute;inset:0;background:#1a73e814;border:2px dashed var(--primary);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;z-index:50;pointer-events:none}.dropzone-overlay__text{font-size:18px;font-weight:600;color:var(--primary);padding:20px 40px;background:#ffffffe6;border-radius:var(--radius)}.app-layout{display:grid;grid-template-columns:240px 1fr 300px;grid-template-rows:auto auto 1fr;height:100vh;overflow:hidden}.app-layout.preview-closed{grid-template-columns:240px 1fr}.app-header{grid-column:1 / -1;grid-row:1;display:flex;align-items:center;justify-content:space-between;padding:8px 16px;border-bottom:1px solid var(--border);background:var(--bg);height:52px}.app-header__left{display:flex;align-items:center;gap:12px}.app-header__logo{display:flex;align-items:center}.app-header__logo-img{height:30px;width:auto}.app-header__right{display:flex;align-items:center;gap:12px}.user-menu{display:flex;align-items:center;gap:8px;padding:6px 12px;border-radius:var(--radius);cursor:pointer;transition:var(--transition)}.user-menu:hover{background:var(--bg-hover)}.user-menu__avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.user-menu__name{font-size:13px;color:var(--text)}.admin-link-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;color:var(--primary);background:var(--primary-light);border-radius:var(--radius);transition:var(--transition)}.admin-link-btn:hover{background:var(--primary);color:#fff}.logout-btn{padding:6px 12px;font-size:13px;color:var(--text-secondary);border-radius:var(--radius-sm);transition:var(--transition)}.logout-btn:hover{background:var(--bg-hover);color:var(--danger)}.app-sidebar{grid-column:1;grid-row:2 / 4;border-right:1px solid var(--border);overflow-y:auto;background:var(--bg-secondary);padding:8px 0}.app-toolbar{grid-column:2 / -1;grid-row:2}.app-layout.preview-closed .app-toolbar{grid-column:2}.app-main{grid-column:2;grid-row:3;overflow-y:auto;position:relative}.app-preview{grid-column:3;grid-row:3;border-left:1px solid var(--border);overflow-y:auto;background:var(--bg)}.app-layout.preview-closed .app-preview{display:none}.admin-page{height:100vh;display:flex;flex-direction:column;background:var(--bg-secondary)}.admin-header{display:flex;align-items:center;gap:12px;padding:12px 24px;background:var(--bg);border-bottom:1px solid var(--border);height:56px}.admin-header__back{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius);color:var(--text-secondary);transition:var(--transition)}.admin-header__back:hover{background:var(--bg-hover);color:var(--text)}.admin-header__title{font-size:18px;font-weight:600;color:var(--text)}.admin-content{flex:1;overflow-y:auto;padding:24px;max-width:960px;width:100%;margin:0 auto}.admin-section{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:20px}.admin-section__title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:16px}.admin-setting-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.admin-setting-row__label{font-size:14px;color:var(--text)}.admin-setting-row__desc{font-size:12px;color:var(--text-secondary);margin-top:2px}.toggle-switch{position:relative;width:44px;height:24px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--border);border-radius:12px;transition:var(--transition)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:var(--transition)}.toggle-switch input:checked+.toggle-slider{background:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;padding:8px 12px;border-bottom:2px solid var(--border);color:var(--text-secondary);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.admin-table td{padding:10px 12px;border-bottom:1px solid var(--border-light);color:var(--text)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-hover)}.role-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.role-badge--admin{background:#e8f0fe;color:#1a73e8}.role-badge--user{background:var(--bg-secondary);color:var(--text-secondary)}.admin-btn{padding:5px 12px;font-size:12px;border-radius:var(--radius-sm);transition:var(--transition);color:var(--primary);font-weight:500}.admin-btn:hover{background:var(--primary-light)}.admin-btn--danger{color:var(--danger)}.admin-btn--danger:hover{background:#fce8e6}.reset-password-form{display:flex;flex-direction:column;gap:12px}.reset-password-form label{font-size:13px;color:var(--text-secondary);font-weight:500}.reset-password-form input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;outline:none;transition:var(--transition)}.reset-password-form input:focus{border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-light)}.reset-password-form .hint{font-size:12px;color:var(--text-light)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.modal-actions .btn-primary{padding:8px 20px;background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:var(--transition)}.modal-actions .btn-primary:hover{background:var(--primary-hover)}.modal-actions .btn-primary:disabled{opacity:.5;cursor:not-allowed}.modal-actions .btn-cancel{padding:8px 20px;color:var(--text-secondary);border-radius:var(--radius-sm);font-size:13px;font-weight:500;transition:var(--transition)}.modal-actions .btn-cancel:hover{background:var(--bg-hover)}.admin-success{padding:8px 12px;background:#e6f4ea;color:var(--success);border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px}.admin-error{padding:8px 12px;background:#fce8e6;color:var(--danger);border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px}:root{--primary: #1a73e8;--primary-hover: #1557b0;--primary-light: #e8f0fe;--danger: #d93025;--danger-hover: #b3261e;--success: #188038;--warning: #f9ab00;--bg: #ffffff;--bg-secondary: #f8f9fa;--bg-hover: #f1f3f4;--bg-selected: #e8f0fe;--text: #202124;--text-secondary: #5f6368;--text-light: #80868b;--border: #dadce0;--border-light: #e8eaed;--shadow: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15);--radius: 8px;--radius-sm: 4px;--font: "Segoe UI", -apple-system, BlinkMacSystemFont, sans-serif;--transition: .15s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none;font-size:inherit}input,textarea{font-family:inherit;font-size:inherit}a{color:var(--primary);text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}
