.sidebar{width:260px;background:var(--card-bg);border-right:1px solid var(--border-color);display:flex;flex-direction:column;height:100vh;color:var(--text-primary)}.sidebar-header{padding:24px 20px;border-bottom:1px solid var(--border-color)}.logo-title{display:flex;align-items:center;gap:12px;margin-bottom:8px}.sidebar-logo{width:32px;height:32px;object-fit:contain}.sidebar-header h1{font-size:24px;font-weight:700;color:#06c;margin-bottom:0}.sidebar-header p{font-size:13px;color:var(--text-secondary)}.sidebar-section{flex:1;overflow-y:auto;padding:16px 0}.section-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px 12px}.section-header h3{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.icon-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.icon-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.new-folder-form{padding:0 20px 12px;display:flex;gap:8px}.new-folder-form input{flex:1;padding:8px 12px;border:2px solid #0066cc;border-radius:6px;font-size:13px;outline:none;background:var(--input-bg);color:var(--text-primary);transition:all .2s}.new-folder-form input:focus{border-color:#06c;background:var(--card-bg);box-shadow:0 0 0 3px #0066cc1a}.new-folder-form input::placeholder{color:var(--text-secondary)}.folder-list{display:flex;flex-direction:column}.folder-item{display:flex;align-items:center;gap:12px;padding:10px 20px;cursor:pointer;transition:background .2s;color:var(--text-primary);position:relative}.folder-item:hover{background:var(--hover-bg)}.folder-item.active{background:rgba(0,102,204,.1);color:#06c;font-weight:500}.folder-item span{font-size:14px}.folder-rename-form{display:flex;width:100%}.folder-rename-form input{flex:1;padding:4px 8px;border:1px solid #0066cc;border-radius:4px;font-size:13px;outline:none;background:var(--input-bg);color:var(--text-primary)}.context-menu-overlay-sidebar{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1600;pointer-events:auto}.context-menu-sidebar{position:fixed;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px var(--shadow-color);padding:8px;z-index:1602;min-width:160px}.context-menu-sidebar button{width:100%;display:flex;align-items:center;gap:10px;padding:8px 12px;background:none;border:none;border-radius:6px;cursor:pointer;font-size:13px;color:var(--text-primary);text-align:left;transition:background .2s}.context-menu-sidebar button:hover{background:var(--hover-bg)}.context-menu-sidebar button.danger{color:#ff3b30}.context-menu-sidebar button.danger:hover{background:#ffebee}.sidebar-footer{padding:20px;border-top:1px solid var(--border-color)}.storage-info p{font-size:13px;color:var(--text-secondary);margin-bottom:8px}.storage-bar{height:6px;background:#e5e5e7;border-radius:3px;overflow:hidden;margin-bottom:8px}.storage-used{height:100%;background:linear-gradient(90deg,#0066cc,#00aaff);transition:width .3s}.storage-bar.storage-loading .storage-used{width:100%!important;background:linear-gradient(90deg,#f5f5f7 0%,#e5e5e7 50%,#f5f5f7 100%);background-size:200% 100%;animation:storageShimmer 1.1s ease-in-out infinite}.storage-text{font-size:12px;color:#1d1d1f;font-weight:500}.storage-subtext{font-size:11px;color:#86868b;margin-top:4px}@keyframes storageShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 768px){.sidebar{position:fixed;left:-260px;top:0;z-index:1500;transition:left .3s ease;box-shadow:2px 0 10px #0000001a}.sidebar.mobile-open{left:0}}.user-menu{position:relative}.user-avatar{background:none;border:none;cursor:pointer;padding:0}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;transition:transform .2s}.avatar:hover{transform:scale(1.05)}.avatar.large{width:48px;height:48px;font-size:18px}.menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #e5e5e7;border-radius:12px;box-shadow:0 8px 24px #00000026;padding:8px;min-width:240px;z-index:1000}.user-info{display:flex;gap:12px;padding:12px;align-items:center}.user-name{font-size:15px;font-weight:600;color:#1d1d1f;margin-bottom:2px}.user-email{font-size:13px;color:#86868b}.dropdown-divider{height:1px;background:#e5e5e7;margin:8px 0}.dropdown-item{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:none;border:none;border-radius:8px;cursor:pointer;font-size:14px;color:#1d1d1f;text-align:left;transition:background .2s}.dropdown-item:hover{background:#f5f5f7}.dropdown-item.logout{color:#ff3b30}.dropdown-item.logout:hover{background:#ffebee}.header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;background:var(--card-bg);border-bottom:1px solid var(--border-color);gap:20px;color:var(--text-primary)}.header-left h2{font-size:22px;font-weight:600;color:var(--text-primary)}.breadcrumb-container{display:flex;align-items:center;gap:10px}.breadcrumbs{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.breadcrumb-item{display:flex;align-items:center;gap:6px}.breadcrumb-link{background:none;border:none;padding:4px 6px;border-radius:6px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:background .2s,color .2s}.breadcrumb-link:hover:not(:disabled){background:var(--hover-bg);color:var(--text-primary)}.breadcrumb-link.active{color:#06c;font-weight:600;cursor:default}.breadcrumb-link:disabled{cursor:default}.breadcrumb-separator{color:#c7c7cc}.back-btn{background:#f5f5f7;border:1px solid transparent;border-radius:8px;padding:6px 8px;cursor:pointer;color:#1d1d1f;transition:all .2s}.back-btn:hover{background:#e5e5e7;border-color:#d2d2d7}.header-center{flex:1;max-width:500px}.search-box{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#f5f5f7;border-radius:10px;border:1px solid transparent;transition:all .2s}.search-box:focus-within{background:#fff;border-color:#06c}.search-box input{flex:1;border:none;background:none;outline:none;font-size:14px;color:var(--text-primary)}.search-box input::placeholder{color:var(--text-secondary)}.header-right{display:flex;gap:12px;align-items:center}.view-toggle{display:flex;gap:4px;background:var(--hover-bg);padding:4px;border-radius:8px}.view-btn{background:none;border:none;padding:8px;cursor:pointer;border-radius:6px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s}.view-btn.active{background:var(--card-bg);color:var(--text-primary)}.dark-mode-btn{background:none;border:none;padding:8px;cursor:pointer;border-radius:8px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s}.dark-mode-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.view-btn:hover{color:#1d1d1f}.view-btn.active{background:#fff;color:#06c;box-shadow:0 1px 3px #0000001a}.menu-toggle{display:none;background:none;border:none;color:var(--text-primary);cursor:pointer;padding:8px;border-radius:8px;transition:background .2s}.menu-toggle:hover{background:var(--hover-bg)}.filter-controls{display:flex;gap:8px}.filter-select{padding:8px 12px;background:var(--hover-bg);border:1px solid transparent;border-radius:8px;font-size:13px;color:var(--text-primary);cursor:pointer;outline:none;transition:all .2s}.filter-select:hover{background:#e5e5e7}.filter-select:focus{background:#fff;border-color:#06c}@media (max-width: 768px){.header{padding:16px;flex-wrap:wrap}.breadcrumb-container{flex-wrap:wrap;gap:6px}.breadcrumbs{width:100%}.menu-toggle{display:flex;align-items:center;justify-content:center}.header-left h2{font-size:18px}.header-center{order:3;width:100%;max-width:100%;margin-top:12px}.search-box{font-size:14px}.filter-controls{width:100%;order:4;margin-top:12px}.filter-select{flex:1}}.file-grid{display:grid;gap:12px;width:100%}.file-grid-surface{position:relative;width:100%}.file-grid-surface{position:relative;width:100%;min-height:60vh}.file-grid.grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr))}.file-grid.list{grid-template-columns:1fr}.file-item{background:var(--card-bg);border:1px solid var(--card-border);border-radius:12px;padding:12px;cursor:pointer;transition:all .2s;position:relative;display:flex;gap:12px;color:var(--text-primary)}.file-grid.grid .file-item{flex-direction:column;align-items:center;text-align:center}.file-grid.grid .file-icon-wrapper{margin-bottom:8px}.file-grid.list .file-item{flex-direction:row;align-items:center}.file-item:hover{border-color:#06c;box-shadow:0 4px 12px #0066cc1a;transform:translateY(-2px)}.file-item.skeleton{cursor:default;border-style:dashed;background:linear-gradient(90deg,#fafbff 0%,#f3f4f8 50%,#fafbff 100%);background-size:200% 100%;animation:shimmer 1.2s ease-in-out infinite}.file-item.skeleton:hover{transform:none;box-shadow:none;border-color:#e5e5e7}.skeleton .skeleton-block{background:#e9ecf3;border-radius:6px;animation:shimmer 1.2s ease-in-out infinite}.skeleton .skeleton-block.icon{width:48px;height:48px}.skeleton.grid .skeleton-block.icon{width:64px;height:64px}.skeleton .skeleton-block.text{width:70%;height:12px;margin-bottom:8px}.skeleton .skeleton-block.text.short{width:40%}.file-icon-wrapper{display:flex;align-items:center;justify-content:center;margin-bottom:8px;flex-shrink:0}.file-grid.list .file-icon-wrapper{margin-bottom:0}.file-preview-img{width:100%;max-width:120px;height:120px;object-fit:cover;border-radius:8px}.file-grid.list .file-preview-img{width:50px;height:50px}.file-icon{color:#86868b}.file-icon.image{color:#34c759}.file-icon.video{color:#ff9500}.file-icon.audio{color:#af52de}.file-icon.text{color:#007aff}.file-icon.pdf{color:#ff3b30}.folder-icon{color:#06c}.file-info{flex:1;min-width:0}.file-grid.grid .file-info{width:100%}.file-name{font-size:14px;font-weight:500;color:#1d1d1f;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;max-width:100%}.file-grid.grid .file-name{white-space:normal;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;word-break:break-word}.file-grid.list .file-name{white-space:normal;overflow:visible;text-overflow:unset;word-break:break-word}.file-size{font-size:12px;color:var(--text-secondary);margin-bottom:2px}.file-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.file-grid.list .file-tags{margin-top:4px}.tag{font-size:11px;padding:2px 8px;background:rgba(0,102,204,.1);color:#06c;border-radius:4px;font-weight:500}.file-menu-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;opacity:0;transition:all .2s;position:absolute;top:12px;right:12px}.file-item:hover .file-menu-btn{opacity:1}.file-menu-btn:hover{background:var(--hover-bg);color:var(--text-primary)}.context-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.context-menu{position:fixed;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 8px 24px var(--shadow-color);padding:8px;z-index:1000;min-width:200px}.context-menu button{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:none;border:none;border-radius:6px;cursor:pointer;font-size:14px;color:var(--text-primary);text-align:left;transition:background .2s}.context-menu button:hover{background:var(--hover-bg)}.context-menu button.danger{color:#ff3b30}.context-menu button.danger:hover{background:#ffebee}.empty-state{grid-column:1 / -1;background:var(--card-bg);border:1px dashed var(--border-color);border-radius:12px;padding:24px;color:var(--text-secondary);text-align:center}.create-file-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;z-index:1100}.create-file-modal{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:20px;width:320px;box-shadow:0 12px 32px var(--shadow-color);color:var(--text-primary)}.create-file-modal h4{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--text-primary)}.create-file-modal input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;outline:none;margin-bottom:14px;background:var(--input-bg);color:var(--text-primary)}.create-file-modal input:focus{border-color:#06c;box-shadow:0 0 0 3px #0066cc1f}.create-file-actions{display:flex;justify-content:flex-end;gap:8px}.create-file-actions button{padding:8px 14px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500}.create-file-actions button.secondary{background:var(--hover-bg);color:var(--text-primary)}.create-file-actions button:not(.secondary){background:#0066cc;color:#fff}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.rename-input{width:100%;padding:4px 8px;border:1px solid #0066cc;border-radius:4px;font-size:14px;outline:none}@media (max-width: 768px){.file-grid.grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.file-item{padding:12px}.file-preview-img{max-width:100px;height:100px}.file-menu-btn{opacity:1}.context-menu{min-width:180px}.context-menu button{padding:12px;font-size:15px}}@media (max-width: 480px){.file-grid.grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.file-preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.preview-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.preview-container{position:relative;background:#fff;border-radius:16px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.preview-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e5e7;background:#fff}.preview-title h3{font-size:18px;font-weight:600;color:#1d1d1f;margin-bottom:4px}.preview-title p{font-size:13px;color:#86868b}.preview-actions{display:flex;gap:8px}.preview-btn{background:none;border:none;color:#86868b;cursor:pointer;padding:8px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.preview-btn:hover{background:#f5f5f7;color:#1d1d1f}.preview-content{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:24px;background:#fafafa}.preview-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:8px}.preview-video{max-width:100%;max-height:70vh;border-radius:8px}.preview-audio{width:100%;max-width:500px;padding:40px}.preview-audio audio{width:100%}.preview-pdf{width:100%;height:70vh}.preview-pdf iframe{width:100%;height:100%;border:none;border-radius:8px}.preview-placeholder{text-align:center;padding:60px 40px}.preview-placeholder p{font-size:16px;color:#86868b;margin-bottom:8px}.preview-filename{font-size:14px;color:#1d1d1f;font-weight:500}.preview-footer{padding:16px 24px;border-top:1px solid #e5e5e7;background:#fff}.preview-tags{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.preview-tags strong{font-size:13px;color:#86868b}.preview-tags .tag{font-size:12px;padding:4px 10px;background:#e8f0fe;color:#06c;border-radius:6px;font-weight:500}.text-editor-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.editor-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.editor-container{position:relative;background:#fff;border-radius:16px;width:100%;max-width:900px;height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d;overflow:hidden}.editor-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e5e7}.editor-title{display:flex;align-items:center;gap:12px}.editor-title h3{font-size:18px;font-weight:600;color:#1d1d1f}.unsaved-indicator{font-size:12px;color:#ff9500;font-weight:500}.editor-actions{display:flex;gap:8px}.editor-btn{display:flex;align-items:center;gap:8px;background:#f5f5f7;border:none;color:#1d1d1f;cursor:pointer;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;transition:all .2s}.editor-btn:hover:not(:disabled){background:#e5e5e7}.editor-btn.save{background:#0066cc;color:#fff}.editor-btn.save:hover:not(:disabled){background:#0055b3}.editor-btn:disabled{opacity:.5;cursor:not-allowed}.editor-content{flex:1;overflow:hidden;padding:24px;display:flex;align-items:center;justify-content:center}.editor-content textarea{width:100%;height:100%;border:none;outline:none;resize:none;font-family:Courier New,monospace;font-size:14px;line-height:1.6;color:#1d1d1f}.editor-content textarea::placeholder{color:#86868b}.editor-loading,.editor-error{display:flex;align-items:center;justify-content:center;font-size:16px;color:#1d1d1f;text-align:center}.editor-error{color:#c62828;font-weight:500}.editor-footer{padding:12px 24px;border-top:1px solid #e5e5e7;background:#fafafa}.editor-stats{font-size:12px;color:#86868b}.upload-area{background:#fff;border:2px dashed #d2d2d7;border-radius:12px;padding:40px;text-align:center;margin-bottom:24px;transition:all .3s;cursor:pointer}.upload-area:hover{border-color:#06c;background:#f9fbfd}.upload-area.dragging{border-color:#06c;background:#e8f0fe;transform:scale(1.02)}.upload-area svg{color:#06c;margin-bottom:16px}.upload-area h3{font-size:18px;font-weight:600;color:#1d1d1f;margin-bottom:8px}.upload-area p{font-size:14px;color:#86868b;margin-bottom:20px}.upload-area input[type=file]{display:none}.upload-btn{display:inline-block;padding:12px 24px;background:#0066cc;color:#fff;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.upload-btn:hover{background:#0055b3}.upload-progress{margin-top:16px;width:100%;max-width:420px;margin-left:auto;margin-right:auto;text-align:left}.upload-progress-bar{height:8px;background:#e5e5e7;border-radius:6px;overflow:hidden;margin-bottom:8px}.upload-progress-fill{height:100%;background:linear-gradient(90deg,#0066cc,#00aaff);transition:width .2s ease}.upload-progress-text{font-size:13px;color:#1d1d1f;display:block}.share-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.share-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.share-container{position:relative;background:#fff;border-radius:16px;width:100%;max-width:550px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.share-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e5e5e7}.share-header h3{font-size:20px;font-weight:600;color:#1d1d1f}.close-btn{background:none;border:none;color:#86868b;cursor:pointer;padding:4px;border-radius:6px;display:flex;transition:all .2s}.share-content{padding:24px}.file-preview-mini{padding:16px;background:#f5f5f7;border-radius:8px;margin-bottom:24px}.file-preview-mini .file-name{font-size:14px;font-weight:500;color:#1d1d1f;margin-bottom:4px}.file-preview-mini .file-size{font-size:12px;color:#86868b}.share-options{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.option-group label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:#1d1d1f;margin-bottom:12px}.radio-group{display:flex;flex-direction:column;gap:8px}.radio-option{display:flex;align-items:center;gap:12px;padding:16px;border:2px solid #e5e5e7;border-radius:10px;cursor:pointer;transition:all .2s}.radio-option:hover{border-color:#06c;background:#f9fbfd}.radio-option.active{border-color:#06c;background:#e8f0fe}.radio-option input{margin:0}.radio-option svg{color:#06c;flex-shrink:0}.option-title{font-size:14px;font-weight:500;color:#1d1d1f;margin-bottom:2px}.option-desc{font-size:12px;color:#86868b}.option-group select{width:100%;padding:12px;border:1px solid #d2d2d7;border-radius:8px;font-size:14px;outline:none;cursor:pointer}.option-group select:focus{border-color:#06c}.generated-link-section{margin-bottom:20px}.generated-link-section label{display:block;font-size:14px;font-weight:500;color:#1d1d1f;margin-bottom:12px}.link-container{display:flex;gap:8px}.link-container input{flex:1;padding:12px;border:1px solid #d2d2d7;border-radius:8px;font-size:13px;outline:none;background:#fafafa}.link-container input:focus{border-color:#06c;background:#fff}.copy-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#0066cc;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap}.copy-btn:hover{background:#0055b3}.share-info{padding:16px;background:#f9f9fb;border-radius:8px;border-left:3px solid #0066cc}.share-info p{font-size:13px;color:#1d1d1f;margin-bottom:8px}.share-info p:last-child{margin-bottom:0}.share-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e5e7;background:#fafafa}.btn-primary{background:#0066cc;color:#fff}.btn-primary:hover{background:#0055b3}.ai-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.ai-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.ai-container{position:relative;background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:90vh;box-shadow:0 20px 60px #0000004d;overflow:hidden;display:flex;flex-direction:column}.ai-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e5e5e7;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.ai-title{display:flex;align-items:center;gap:12px;color:#fff}.sparkle-icon{animation:sparkle 2s infinite}@keyframes sparkle{0%,to{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}}.ai-title h3{font-size:20px;font-weight:600}.ai-header .close-btn{color:#fff}.ai-header .close-btn:hover{background:rgba(255,255,255,.2)}.ai-content{flex:1;overflow-y:auto;padding:24px}.current-file{padding:16px;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);border-radius:12px;margin-bottom:24px}.current-file .file-name{font-size:16px;font-weight:600;color:#1d1d1f;margin-bottom:4px}.current-file .file-type{font-size:12px;color:#86868b;font-weight:500}.analyze-section{text-align:center;padding:40px 20px}.ai-info{margin-bottom:24px}.ai-info svg{color:#667eea;margin-bottom:16px}.ai-info h4{font-size:18px;font-weight:600;color:#1d1d1f;margin-bottom:12px}.ai-info p{font-size:14px;color:#86868b;line-height:1.5;max-width:400px;margin:0 auto}.analyze-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:transform .2s}.analyze-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.analyzing{text-align:center;padding:40px 20px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.analyzing p{font-size:16px;font-weight:500;color:#1d1d1f;margin-bottom:20px}.analyzing-steps{display:flex;flex-direction:column;gap:8px;max-width:300px;margin:0 auto}.step{font-size:13px;color:#86868b;text-align:left;padding:8px 12px;background:#f5f5f7;border-radius:6px}.step.active{color:#667eea;background:#e8edff;font-weight:500}.suggestions{display:flex;flex-direction:column;gap:24px}.suggestion-section label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#1d1d1f;margin-bottom:12px}.suggestion-section label svg{color:#667eea}.name-input{width:100%;padding:12px;border:2px solid #e5e5e7;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.name-input:focus{border-color:#667eea}.suggestion-hint{font-size:12px;color:#86868b;margin-top:8px;font-style:italic}.tag-suggestions,.current-tags{display:flex;flex-wrap:wrap;gap:8px}.tag-btn{position:relative;padding:8px 14px;background:#f5f5f7;border:2px solid #e5e5e7;border-radius:8px;font-size:13px;font-weight:500;color:#1d1d1f;cursor:pointer;transition:all .2s}.tag-btn:hover{border-color:#667eea;background:#e8edff}.tag-btn.selected{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-color:#667eea}.tag-btn.current.removed{opacity:.5;text-decoration:line-through;border-color:#ccc;background:#f9f9f9}.tag-btn .check{margin-left:6px;font-weight:700}.tag-btn .remove{margin-left:6px;font-weight:700;color:#c33}.custom-tag-form{display:flex;gap:8px}.custom-tag-form input{flex:1;padding:10px 12px;border:2px solid #e5e5e7;border-radius:8px;font-size:14px;outline:none}.custom-tag-form input:focus{border-color:#667eea}.custom-tag-form button{padding:10px 16px;background:#667eea;color:#fff;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.custom-tag-form button:hover{background:#5568d3}.selected-tags-preview{padding:16px;background:#f9f9fb;border-radius:8px;border:2px dashed #d2d2d7}.selected-tags-preview label{display:block;font-size:13px;font-weight:600;color:#86868b;margin-bottom:12px}.tags-preview{display:flex;flex-wrap:wrap;gap:8px}.preview-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:white;border:1px solid #e5e5e7;border-radius:6px;font-size:12px;font-weight:500;color:#1d1d1f}.preview-tag button{background:none;border:none;color:#86868b;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.preview-tag button:hover{background:#ff3b30;color:#fff}.ai-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e5e5e7;background:#fafafa}.btn-secondary,.btn-primary{padding:12px 24px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary{background:#f5f5f7;color:#1d1d1f}.btn-secondary:hover{background:#e5e5e7}.btn-primary{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.delete-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:2000}.delete-modal{background:white;border-radius:12px;padding:40px;max-width:400px;width:90%;box-shadow:0 10px 40px #0003;position:relative;text-align:center}.modal-close{position:absolute;top:12px;right:12px;background:none;border:none;cursor:pointer;color:#999;padding:4px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#333}.modal-icon{width:64px;height:64px;background:#fee;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#c33}.delete-modal h2{font-size:20px;font-weight:600;margin-bottom:12px;color:#333}.delete-modal p{font-size:14px;color:#666;margin-bottom:8px}.text-muted{color:#999;font-size:13px}.modal-actions{display:flex;gap:12px;margin-top:24px}.btn-cancel,.btn-delete{flex:1;padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.btn-cancel{background:#f5f5f5;color:#333}.btn-cancel:hover{background:#e8e8e8}.btn-delete{background:#c33;color:#fff}.btn-delete:hover{background:#a22;box-shadow:0 4px 12px #cc33334d}.btn-delete:active{transform:scale(.98)}@media (max-width: 480px){.delete-modal{padding:24px 20px;width:95%}.modal-icon{width:56px;height:56px}.delete-modal h2{font-size:18px}}.profile-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}.profile-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.profile-container{position:relative;background:#fff;border-radius:16px;width:100%;max-width:500px;box-shadow:0 20px 60px #0000004d;overflow:hidden}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid #e5e5e7}.profile-header h2{font-size:20px;font-weight:600;color:#1d1d1f}.close-btn{background:none;border:none;color:#86868b;cursor:pointer;padding:8px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s}.close-btn:hover{background:#f5f5f7;color:#1d1d1f}.profile-tabs{display:flex;border-bottom:1px solid #e5e5e7;padding:0 24px}.tab-btn{display:flex;align-items:center;gap:8px;padding:12px 16px;background:none;border:none;border-bottom:2px solid transparent;color:#86868b;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.tab-btn:hover{color:#1d1d1f}.tab-btn.active{color:#06c;border-bottom-color:#06c}.profile-content{padding:24px}.profile-form{display:flex;flex-direction:column;gap:20px}.form-group label{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#1d1d1f}.form-group input{padding:12px 16px;border:1px solid #d2d2d7;border-radius:8px;font-size:14px;outline:none;transition:border-color .2s}.form-group input:focus{border-color:#06c}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:44px}.password-toggle{position:absolute;right:12px;background:none;border:none;color:#86868b;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;transition:color .2s}.form-group small{font-size:12px;color:#86868b}.form-info{padding:12px 16px;background:#f5f5f7;border-radius:8px}.form-info p{font-size:13px;color:#86868b;margin:0}.alert{padding:14px 16px;border-radius:8px;font-size:14px;margin-bottom:16px;animation:slideIn .3s ease-out;border-left:4px solid;font-weight:500}.alert-error{background:#ffebee;color:#c62828;border-left-color:#c62828;border:1px solid #ef9a9a;border-left:4px solid #c62828}.alert-success{background:#e8f5e9;color:#2e7d32;border-left-color:#2e7d32;border:1px solid #81c784;border-left:4px solid #2e7d32}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.btn-primary{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:#0066cc;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;margin-top:8px}.btn-primary:hover{background:#0055b3;transform:translateY(-1px);box-shadow:0 4px 12px #0066cc4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}@media (max-width: 768px){.profile-container{max-width:100%;margin:0;border-radius:0}.profile-modal{padding:0}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:20px}.error-message{padding:12px 16px;background:#fee;border:1px solid #fcc;border-radius:8px;color:#c33;font-size:14px;margin-bottom:16px}.login-container{display:flex;max-width:1100px;width:100%;background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 20px 60px #0000004d}.login-left{flex:1;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:60px 50px;color:#fff;display:flex;flex-direction:column;justify-content:space-between}.login-branding h1{font-size:48px;font-weight:700;margin-bottom:12px}.login-branding p{font-size:18px;opacity:.9}.login-features{display:flex;flex-direction:column;gap:24px;margin-top:60px}.feature{display:flex;gap:16px;align-items:flex-start}.feature-icon{font-size:32px;flex-shrink:0}.feature h3{font-size:18px;font-weight:600;margin-bottom:4px}.feature p{font-size:14px;opacity:.9}.login-right{flex:1;padding:60px 50px;display:flex;align-items:center;justify-content:center}.login-form-container{width:100%;max-width:400px}.login-form-container h2{font-size:32px;font-weight:700;color:#1d1d1f;margin-bottom:8px}.login-subtitle{font-size:15px;color:#86868b;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#1d1d1f}.input-wrapper{position:relative;display:flex;align-items:center;background:#f5f5f7;border:2px solid transparent;border-radius:10px;padding:12px 16px;transition:all .2s}.input-wrapper:focus-within{background:#fff;border-color:#667eea}.input-wrapper svg{color:#86868b;flex-shrink:0;margin-right:12px}.input-wrapper input{flex:1;border:none;background:none;outline:none;font-size:15px;color:#1d1d1f}.input-wrapper input::placeholder{color:#86868b}.password-toggle{background:none;border:none;color:#86868b;cursor:pointer;padding:4px;display:flex;align-items:center;transition:color .2s}.password-toggle:hover{color:#1d1d1f}.form-footer{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.remember-me{display:flex;align-items:center;gap:8px;font-size:14px;color:#1d1d1f;cursor:pointer}.remember-me input{cursor:pointer}.forgot-password{font-size:14px;color:#667eea;text-decoration:none;font-weight:500}.forgot-password:hover{text-decoration:underline}.login-btn{padding:16px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.login-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}.login-divider{position:relative;text-align:center;margin:32px 0}.login-divider:before{content:"";position:absolute;left:0;top:50%;width:100%;height:1px;background:#e5e5e7}.login-divider span{position:relative;background:#fff;padding:0 16px;font-size:13px;color:#86868b}.social-login{display:flex;gap:12px}.social-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px;background:#f5f5f7;border:1px solid #e5e5e7;border-radius:10px;font-size:14px;font-weight:500;color:#1d1d1f;cursor:pointer;transition:all .2s}.social-btn:hover{background:#e5e5e7;transform:translateY(-1px)}.social-btn.google:hover{background:#f0f7ff;border-color:#4285f4}.social-btn.github:hover{background:#f5f5f5;border-color:#1d1d1f}.switch-mode{text-align:center;margin-top:24px;font-size:14px;color:#86868b}.switch-mode button{background:none;border:none;color:#667eea;font-weight:600;cursor:pointer;font-size:14px}.switch-mode button:hover{text-decoration:underline}@media (max-width: 768px){.login-container{flex-direction:column}.login-left{padding:40px 30px}.login-branding h1{font-size:36px}.login-features{margin-top:40px;gap:16px}.feature-icon{font-size:24px}.login-right{padding:40px 30px}.login-form-container h2{font-size:28px}.social-login{flex-direction:column}}:root{--bg-primary: #ffffff;--bg-secondary: #f5f5f5;--text-primary: #000000;--text-secondary: #666666;--border-color: #e5e5e7;--card-bg: #ffffff;--card-border: #e5e5e7;--hover-bg: rgba(0, 102, 204, .1);--input-bg: #ffffff;--input-border: #e5e5e7;--shadow-color: rgba(0, 0, 0, .1)}:root.dark-mode{--bg-primary: #1e1e1e;--bg-secondary: #2d2d2d;--text-primary: #ffffff;--text-secondary: #b0b0b0;--border-color: #3d3d3d;--card-bg: #2d2d2d;--card-border: #3d3d3d;--hover-bg: rgba(102, 180, 255, .1);--input-bg: #3d3d3d;--input-border: #4d4d4d;--shadow-color: rgba(0, 0, 0, .3)}.app{display:flex;height:100vh;overflow:hidden;background-color:var(--bg-primary);color:var(--text-primary)}.app.loading{align-items:center;justify-content:center;background:var(--bg-secondary)}.loading-spinner{font-size:18px;color:#667eea;padding:24px;text-align:center}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-primary)}.content-area{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;background-color:var(--bg-secondary)}.mobile-overlay{display:none}@media (max-width: 768px){.content-area{padding:16px}.mobile-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:1400}.mobile-overlay.active{display:block}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f7;color:#1d1d1f}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#555}
