:root{--bg-base:#0b0d11;--bg-surface:#12151c;--bg-elevated:#1a1e28;--bg-hover:#222736;--bg-active:#2a3044;--bg-overlay:#0009;--accent:#f6821f;--accent-hover:#ff9640;--accent-subtle:#f6821f1f;--accent-muted:#f6821f40;--text-primary:#f0f2f5;--text-secondary:#8b92a5;--text-muted:#5a6178;--text-inverse:#0b0d11;--border:#1f2333;--border-hover:#2e3450;--border-accent:#f6821f66;--success:#34d399;--warning:#fbbf24;--error:#f87171;--info:#60a5fa;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #f6821f26;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs:.6875rem;--font-sm:.75rem;--font-base:.875rem;--font-md:1rem;--font-lg:1.25rem;--font-xl:1.5rem;--font-2xl:2rem;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--sidebar-width:260px;--header-height:56px;--transition-fast:.12s ease;--transition-base:.2s ease;--transition-slow:.35s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-base);height:100%;color:var(--text-primary);font-family:var(--font-family);font-size:var(--font-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;overflow:hidden}#app{flex-direction:column;height:100%;display:flex}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;color:inherit;font-family:inherit;font-size:inherit;background:0 0;border:none}input,textarea{font-family:inherit;font-size:inherit;color:var(--text-primary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);transition:border-color var(--transition-fast);outline:none}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.auth-container{background:radial-gradient(ellipse at 30% 20%, #f6821f0f 0%, transparent 60%), radial-gradient(ellipse at 70% 80%, #f6821f0a 0%, transparent 60%), var(--bg-base);justify-content:center;align-items:center;height:100vh;display:flex}.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:420px;padding:var(--space-10);box-shadow:var(--shadow-lg)}.auth-logo{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);display:flex}.auth-logo svg{width:40px;height:40px}.auth-logo-text{font-size:var(--font-xl);color:var(--text-primary);font-weight:700}.auth-logo-text span{color:var(--accent)}.auth-title{font-size:var(--font-lg);margin-bottom:var(--space-2);font-weight:600}.auth-subtitle{color:var(--text-secondary);font-size:var(--font-base);margin-bottom:var(--space-6)}.auth-form{gap:var(--space-4);flex-direction:column;display:flex}.auth-google-btn{justify-content:center;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);color:var(--text-primary);border:1px solid var(--border);background:0 0;font-weight:500;display:flex}.auth-google-btn:hover{background:var(--bg-hover);border-color:var(--border-hover)}.auth-divider{text-align:center;margin-bottom:var(--space-4);color:var(--text-muted);font-size:var(--font-sm);align-items:center;display:flex}.auth-divider:before,.auth-divider:after{content:"";border-bottom:1px solid var(--border);flex:1}.auth-divider span{padding:0 var(--space-3)}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-group label{font-size:var(--font-sm);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.form-group input{padding:var(--space-3) var(--space-4);font-size:var(--font-base)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);border-radius:var(--radius-md);font-weight:500;font-size:var(--font-base);transition:all var(--transition-fast);cursor:pointer;border:1px solid #0000;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--accent);color:var(--text-inverse)}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;padding:0}.btn-full{width:100%;padding:var(--space-3) var(--space-5)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--font-md)}.auth-divider{align-items:center;gap:var(--space-4);margin:var(--space-4) 0;color:var(--text-muted);font-size:var(--font-sm);display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--border);flex:1;height:1px}.auth-switch{text-align:center;margin-top:var(--space-6);color:var(--text-secondary);font-size:var(--font-base)}.auth-switch a{font-weight:600}.auth-error{border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);color:var(--error);font-size:var(--font-sm);background:#f871711a;border:1px solid #f8717140;display:none}.auth-error.visible{display:block}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border);height:100vh;transition:transform var(--transition-slow);flex-direction:column;display:flex;overflow-y:auto}.sidebar-header{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border);min-height:var(--header-height);display:flex}.sidebar-logo{flex-shrink:0;width:32px;height:32px}.sidebar-brand{font-size:var(--font-md);font-weight:700}.sidebar-brand span{color:var(--accent)}.sidebar-new-btn{margin:var(--space-4) var(--space-4) var(--space-3);padding:var(--space-3) var(--space-5);background:var(--accent);color:var(--text-inverse);border-radius:var(--radius-full);font-weight:600;font-size:var(--font-base);align-items:center;gap:var(--space-2);transition:all var(--transition-fast);box-shadow:var(--shadow-sm);display:flex}.sidebar-new-btn:hover{background:var(--accent-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.sidebar-new-btn svg{width:20px;height:20px}.sidebar-nav{padding:var(--space-2) var(--space-3);flex:1}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-base);transition:all var(--transition-fast);cursor:pointer;text-align:left;width:100%;font-weight:400;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--accent-subtle);color:var(--accent);font-weight:500}.nav-item svg{opacity:.7;flex-shrink:0;width:20px;height:20px}.nav-item.active svg{opacity:1}.nav-section-title{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);padding:var(--space-5) var(--space-4) var(--space-2);font-weight:600}.sidebar-storage{padding:var(--space-4) var(--space-5);border-top:1px solid var(--border)}.storage-bar{background:var(--bg-hover);border-radius:var(--radius-full);height:4px;margin-bottom:var(--space-2);overflow:hidden}.storage-bar-fill{background:var(--accent);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.storage-text{font-size:var(--font-xs);color:var(--text-muted)}.main-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.toolbar{align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-5);min-height:var(--header-height);border-bottom:1px solid var(--border);background:var(--bg-surface);display:flex}.toolbar-search{flex:1;max-width:720px;position:relative}.toolbar-search svg{left:var(--space-4);width:18px;height:18px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.toolbar-search input{width:100%;padding:var(--space-2) var(--space-4) var(--space-2) 42px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-full);font-size:var(--font-base);transition:all var(--transition-fast)}.toolbar-search input:focus{background:var(--bg-hover);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.toolbar-actions{align-items:center;gap:var(--space-2);margin-left:auto;display:flex}.view-toggle{background:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border);padding:2px;display:flex}.view-toggle button{padding:var(--space-2);border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition-fast);justify-content:center;align-items:center;display:flex}.view-toggle button:hover{color:var(--text-primary)}.view-toggle button.active{background:var(--bg-hover);color:var(--accent)}.view-toggle svg{width:18px;height:18px}.user-avatar{border-radius:var(--radius-full);background:var(--accent);width:32px;height:32px;color:var(--text-inverse);font-weight:600;font-size:var(--font-sm);cursor:pointer;transition:box-shadow var(--transition-fast);justify-content:center;align-items:center;display:flex}.user-avatar:hover{box-shadow:0 0 0 2px var(--accent-muted)}.breadcrumb{align-items:center;gap:var(--space-1);padding:var(--space-3) var(--space-5);font-size:var(--font-base);display:flex}.breadcrumb-item{color:var(--text-secondary);cursor:pointer;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.breadcrumb-item:hover{background:var(--bg-hover);color:var(--text-primary)}.breadcrumb-item.current{color:var(--text-primary);cursor:default;font-weight:500}.breadcrumb-item.current:hover{background:0 0}.breadcrumb-separator{color:var(--text-muted);font-size:var(--font-sm)}.file-area{padding:var(--space-4) var(--space-5);flex:1;overflow-y:auto}.file-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.file-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:all var(--transition-base);align-items:center;gap:var(--space-3);flex-direction:column;display:flex;position:relative}.file-card:hover{background:var(--bg-hover);border-color:var(--border-hover);box-shadow:var(--shadow-md);transform:translateY(-2px)}.file-card.selected{border-color:var(--accent);background:var(--accent-subtle)}.file-card-icon{border-radius:var(--radius-lg);flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.file-card-icon svg{width:32px;height:32px}.file-card-icon.folder{color:#60a5fa;background:#60a5fa1f}.file-card-icon.image{color:#34d399;background:#34d3991f}.file-card-icon.pdf{color:#f87171;background:#f871711f}.file-card-icon.doc{color:#60a5fa;background:#60a5fa1f}.file-card-icon.video{color:#a78bfa;background:#a78bfa1f}.file-card-icon.audio{color:#fbbf24;background:#fbbf241f}.file-card-icon.code{color:#34d399;background:#34d3991f}.file-card-icon.other{color:#8b92a5;background:#8b92a51f}.file-card-name{font-size:var(--font-sm);text-align:center;text-overflow:ellipsis;white-space:nowrap;width:100%;color:var(--text-primary);font-weight:500;overflow:hidden}.file-card-meta{font-size:var(--font-xs);color:var(--text-muted);text-align:center}.file-card-star{top:var(--space-2);right:var(--space-2);padding:var(--space-1);border-radius:var(--radius-sm);color:var(--text-muted);opacity:0;transition:all var(--transition-fast);position:absolute}.file-card:hover .file-card-star{opacity:1}.file-card-star.starred{opacity:1;color:var(--warning)}.file-card-star:hover{background:var(--bg-active)}.file-list{width:100%}.file-list-header{gap:var(--space-4);padding:var(--space-2) var(--space-4);font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);grid-template-columns:1fr 120px 160px 60px;font-weight:600;display:grid}.file-list-row{gap:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);grid-template-columns:1fr 120px 160px 60px;align-items:center;display:grid}.file-list-row:hover{background:var(--bg-hover)}.file-list-row.selected{background:var(--accent-subtle)}.file-list-name{align-items:center;gap:var(--space-3);font-weight:400;display:flex;overflow:hidden}.file-list-name svg{flex-shrink:0;width:22px;height:22px}.file-list-name span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.file-list-size,.file-list-modified,.file-list-actions{font-size:var(--font-sm);color:var(--text-secondary)}.empty-state{height:100%;padding:var(--space-12);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{border-radius:var(--radius-xl);background:var(--accent-subtle);width:80px;height:80px;margin-bottom:var(--space-6);justify-content:center;align-items:center;display:flex}.empty-state-icon svg{width:40px;height:40px;color:var(--accent)}.empty-state h2{font-size:var(--font-lg);margin-bottom:var(--space-2);font-weight:600}.empty-state p{color:var(--text-secondary);max-width:360px;margin-bottom:var(--space-6)}.upload-overlay{z-index:1000;opacity:0;pointer-events:none;transition:opacity var(--transition-base);background:#0b0d11d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.upload-overlay.active{opacity:1;pointer-events:all}.upload-zone{width:480px;padding:var(--space-12);border:2px dashed var(--accent);border-radius:var(--radius-xl);background:var(--bg-surface);text-align:center;animation:2s infinite uploadPulse}@keyframes uploadPulse{0%,to{border-color:var(--accent)}50%{border-color:var(--accent-hover);box-shadow:var(--shadow-glow)}}.upload-zone-icon{width:64px;height:64px;margin:0 auto var(--space-4);color:var(--accent)}.upload-zone h3{font-size:var(--font-lg);margin-bottom:var(--space-2);font-weight:600}.upload-zone p{color:var(--text-secondary)}.upload-progress-panel{bottom:var(--space-5);right:var(--space-5);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:380px;box-shadow:var(--shadow-lg);z-index:900;display:none;position:fixed;overflow:hidden}.upload-progress-panel.visible{animation:slideUp .3s var(--transition-slow);display:block}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.upload-progress-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);font-weight:500;font-size:var(--font-sm);justify-content:space-between;align-items:center;display:flex}.upload-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);display:flex}.upload-item:last-child{border-bottom:none}.upload-item-name{font-size:var(--font-sm);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.upload-item-progress{background:var(--bg-hover);border-radius:var(--radius-full);width:60px;height:4px;overflow:hidden}.upload-item-progress-bar{background:var(--accent);border-radius:var(--radius-full);height:100%;transition:width .15s linear}.upload-item-status{font-size:var(--font-xs);color:var(--text-muted);text-align:right;width:40px}.context-menu{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-1);min-width:200px;box-shadow:var(--shadow-lg);z-index:1100;display:none;position:fixed}.context-menu.visible{animation:.12s fadeScale;display:block}@keyframes fadeScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--text-secondary);text-align:left;width:100%;transition:all var(--transition-fast);display:flex}.context-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.context-menu-item svg{opacity:.7;width:16px;height:16px}.context-menu-item.danger{color:var(--error)}.context-menu-divider{background:var(--border);height:1px;margin:var(--space-1) 0}.modal-overlay{background:var(--bg-overlay);z-index:1200;opacity:0;pointer-events:none;transition:opacity var(--transition-base);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.visible{opacity:1;pointer-events:all}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--space-6);width:100%;max-width:440px;box-shadow:var(--shadow-lg);animation:.2s modalIn}@keyframes modalIn{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-title{font-size:var(--font-lg);margin-bottom:var(--space-4);font-weight:600}.modal-actions{justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-6);display:flex}.toast-container{top:var(--space-5);right:var(--space-5);z-index:1300;gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-5);font-size:var(--font-sm);box-shadow:var(--shadow-md);align-items:center;gap:var(--space-3);min-width:260px;animation:.3s toastIn;display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--error)}.toast.info{border-left:3px solid var(--info)}@keyframes toastIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.user-menu{top:52px;right:var(--space-5);background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2);min-width:220px;box-shadow:var(--shadow-lg);z-index:1100;display:none;position:fixed}.user-menu.visible{animation:.12s fadeScale;display:block}.user-menu-header{padding:var(--space-3) var(--space-3);border-bottom:1px solid var(--border);margin-bottom:var(--space-1)}.user-menu-name{font-weight:600;font-size:var(--font-base)}.user-menu-email{font-size:var(--font-xs);color:var(--text-muted);margin-top:2px}.user-menu-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-sm);color:var(--text-secondary);text-align:left;width:100%;transition:all var(--transition-fast);display:flex}.user-menu-item:hover{background:var(--bg-hover);color:var(--text-primary)}.user-menu-item.danger:hover{color:var(--error)}.modal.preview-mode{border-radius:var(--radius-lg);background:#000;width:90vw;max-width:90vw;max-height:90vh;padding:0;overflow:hidden}.preview-modal{flex-direction:column;height:90vh;max-height:90vh;display:flex}.preview-header{padding:var(--space-3) var(--space-4);background:var(--bg-surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.preview-title{align-items:center;gap:var(--space-3);min-width:0;display:flex}.preview-name{font-size:var(--font-base);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;max-width:400px;font-weight:500;overflow:hidden}.preview-size{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap}.preview-actions{align-items:center;gap:var(--space-2);flex-shrink:0;display:flex}.preview-actions .btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--font-xs);align-items:center;gap:var(--space-1);text-decoration:none;display:inline-flex}.preview-actions .btn-sm svg{width:14px;height:14px}.preview-body{padding:var(--space-4);background:#000;flex:1;justify-content:center;align-items:center;display:flex;overflow:auto}.preview-image{object-fit:contain;border-radius:var(--radius-md);max-width:100%;max-height:calc(90vh - 80px);box-shadow:0 8px 32px #0006}.preview-video{border-radius:var(--radius-md);background:#000;max-width:100%;max-height:calc(90vh - 80px)}.preview-pdf,.preview-code{border-radius:var(--radius-md);background:#fff;border:none;width:100%;height:calc(90vh - 80px)}.preview-code{background:var(--bg-surface)}.preview-audio-wrapper{align-items:center;gap:var(--space-4);padding:var(--space-8);flex-direction:column;display:flex}.preview-audio-icon{width:80px;height:80px;color:var(--accent)}.preview-audio-icon svg{width:80px;height:80px}.preview-audio-name{font-size:var(--font-lg);color:var(--text-primary);font-weight:500}.preview-audio{width:400px;max-width:90vw}.share-content{padding:var(--space-4) 0}.share-loading{padding:var(--space-6);justify-content:center;display:flex}.form-label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-2);font-weight:600;display:block}.share-link-row{gap:var(--space-2);display:flex}.share-url-input{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);color:var(--text-primary);font-size:var(--font-sm);flex:1;font-family:Inter,monospace}.share-url-input:focus{outline:2px solid var(--accent);outline-offset:-1px}.share-hint{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-2)}@media (width<=768px){.modal.preview-mode{border-radius:0;width:100vw;max-width:100vw;max-height:100vh}.preview-modal{height:100vh;max-height:100vh}.preview-name{max-width:180px}.preview-body{padding:var(--space-2)}.preview-audio{width:100%}}
