:root{--primary: #4a90d9;--primary-hover: #357abd;--success: #28a745;--warning: #ffc107;--error: #dc3545;--bg: #f5f7fa;--card-bg: rgba(255, 255, 255, .82);--text: #2c3e50;--text-secondary: #6c757d;--border: #e1e8ed;--shadow: 0 2px 10px rgba(0, 0, 0, .08);--radius: 12px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;position:relative}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:url(/bg.png) no-repeat center center;background-size:cover;filter:blur(6px);z-index:-1;pointer-events:none}.container{width:100%;margin:0 auto;padding:0;display:flex;min-height:100vh}.sidebar{width:200px;min-width:200px;background:var(--card-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-header{display:flex;align-items:center;gap:10px;padding:20px 16px 16px;border-bottom:1px solid var(--border)}.sidebar-logo{width:32px;height:32px;border-radius:6px;object-fit:contain;flex-shrink:0}.sidebar-title{font-size:1.1rem;font-weight:700;color:var(--text)}.sidebar-actions{display:flex;flex-direction:column;padding:8px;gap:4px;border-bottom:1px solid var(--border)}.sidebar-search{padding:4px 0}.sidebar-search-input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:8px;font-size:.85rem;outline:none;background:var(--bg);color:var(--text);font-family:inherit;transition:border-color .15s}.sidebar-search-input:focus{border-color:var(--primary)}.sidebar-search-input::placeholder{color:var(--text-secondary)}.sidebar-action-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;border-radius:8px;background:none;font-size:.9rem;cursor:pointer;color:var(--text);transition:all .15s;text-align:left;font-family:inherit}.sidebar-action-btn:hover{background:var(--bg)}.sidebar-action-btn#add-file-btn{background:var(--success);color:#fff;font-weight:600}.sidebar-action-btn#add-file-btn:hover{background:#218838}.sidebar-action-btn#add-file-btn:disabled{opacity:.6;cursor:not-allowed}.sidebar-action-btn#add-file-btn.uploading{animation:pulse 1s ease-in-out infinite}.sidebar-action-btn#create-folder-btn{background:var(--primary);color:#fff;font-weight:600}.sidebar-action-btn#create-folder-btn:hover{background:var(--primary-hover)}.sidebar-nav-label{padding:16px 16px 6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);opacity:.7}.sidebar-nav{display:flex;flex-direction:column;padding:6px 8px;gap:2px}.sidebar-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;border-radius:10px;background:none;font-size:.88rem;cursor:pointer;color:var(--text-secondary);transition:all .18s ease;text-align:left;text-decoration:none;position:relative}.sidebar-item:hover{background:#4a90d90f;color:var(--text)}.sidebar-item.active{background:linear-gradient(135deg,#4a90d91f,#4a90d90f);color:var(--primary);font-weight:600;box-shadow:inset 3px 0 0 var(--primary);border-radius:0 10px 10px 0;margin-left:-3px;padding-left:15px}.sidebar-item-icon{font-size:1.1rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:20px;height:20px;transition:color .18s ease}.sidebar-item-text{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.workspace{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.topbar{display:flex;align-items:center;padding:12px 16px;margin:20px 20px 0;background:#ffffffa6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius);box-shadow:var(--shadow);flex-shrink:0}.topbar-search{display:flex;align-items:center;gap:8px;flex:1;max-width:480px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 14px;transition:border-color .15s}.topbar-search:focus-within{border-color:var(--primary)}.topbar-search-icon{font-size:.85rem;flex-shrink:0;opacity:.6}.topbar-search-input{flex:1;border:none;background:transparent;font-size:.9rem;outline:none;color:var(--text);font-family:inherit}.topbar-search-input::placeholder{color:var(--text-secondary)}.topbar-user{position:relative;margin-left:auto;flex-shrink:0}.topbar-avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--border);background:linear-gradient(135deg,var(--primary),#6c5ce7);color:#fff;font-size:.9rem;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,box-shadow .15s;text-transform:uppercase}.topbar-avatar:hover{border-color:var(--primary);box-shadow:0 0 0 3px #4a90d926}.topbar-user-popup{min-width:220px;background:var(--card-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:12px;box-shadow:0 12px 40px #0000001f,0 0 0 1px #0000000a;padding:8px;z-index:10000;animation:topbarPopupIn .15s ease}@keyframes topbarPopupIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.topbar-user-email{padding:10px 12px;font-size:.85rem;color:var(--text);word-break:break-all;line-height:1.4}.topbar-user-logout{display:block;width:100%;padding:10px 12px;border:none;border-radius:8px;background:transparent;color:var(--error);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;text-align:left;transition:background .15s}.topbar-user-logout:hover{background:#dc354514}.topbar-user-link{display:block;width:100%;padding:10px 12px;border:none;border-radius:8px;background:transparent;color:var(--text);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;text-align:left;transition:background .15s}.topbar-user-link:hover{background:var(--bg)}.workspace-content{flex:1;overflow-y:auto;padding:20px}.breadcrumb-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.breadcrumb-row .breadcrumb{flex:1;margin-bottom:0}.sort-select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:.8rem;background:#fff;cursor:pointer;flex-shrink:0;max-width:150px}.sort-select:focus{outline:none;border-color:var(--primary)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-secondary{background:var(--bg);color:var(--text);border:2px solid var(--border)}.btn-secondary:hover{border-color:var(--primary);color:var(--primary)}.btn-warning{background:var(--warning);color:var(--text)}.btn-warning:hover{background:#e0a800}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover{background:#c82333}.btn-icon{font-size:1.1rem}.files-section{background:#ffffffa6;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding:20px;border-radius:var(--radius);box-shadow:var(--shadow)}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:4px;padding:10px 0;margin-bottom:0;font-size:.9rem}.breadcrumb-item{color:var(--primary);cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s;white-space:nowrap}.breadcrumb-item:hover{background:#4a90d91a}.breadcrumb-item.active{color:var(--text);font-weight:600;cursor:default}.breadcrumb-item.active:hover{background:none}.breadcrumb-item.drop-target{background:#28a74526;outline:2px dashed var(--success);outline-offset:-2px;border-radius:4px}.breadcrumb-separator{color:var(--text-secondary);-webkit-user-select:none;user-select:none}.files-header{display:flex;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px}.btn-delete-selected{padding:6px 10px;border:none;border-radius:8px;background:var(--error);color:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:background .2s;flex-shrink:0}.btn-delete-selected:hover{background:#c82333}.btn-delete-selected:disabled{opacity:.5;cursor:not-allowed}.btn-download-selected{padding:6px 10px;border:none;border-radius:8px;background:var(--success);color:#fff;font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:4px;transition:background .2s;flex-shrink:0}.btn-download-selected:hover{background:#218838}.btn-download-selected:disabled{opacity:.5;cursor:not-allowed}.files-selected-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.files-actions{display:flex;gap:10px;flex-wrap:wrap}.filter-select{padding:8px 14px;border:2px solid var(--border);border-radius:8px;font-size:.9rem;background:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--primary)}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px;position:relative}.lasso-rect{position:absolute;background:#4a90d926;border:1px solid rgba(74,144,217,.5);border-radius:2px;pointer-events:none;z-index:10}.file-tile{background:transparent;border-radius:var(--radius);padding:16px 12px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;transition:background .15s;cursor:default;position:relative;user-select:none;-webkit-user-select:none}.file-tile:hover{background:#0000000a}.file-tile.selected{background:#4a90d91a}.file-tile-icon{font-size:3rem;line-height:1}.file-tile-thumbnail{width:60px;height:60px;object-fit:contain;border-radius:6px;background:#00000008;display:block}.file-tile.has-thumbnail .file-tile-thumbnail{transition:transform .15s ease}.file-tile.has-thumbnail:hover .file-tile-thumbnail{transform:scale(1.08)}.file-tile-name{font-size:.85rem;font-weight:500;line-height:1.3;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;max-width:100%}.file-tile-name.has-extension{display:flex;text-overflow:unset}.file-name-base{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.file-name-ext{flex-shrink:0;white-space:nowrap}.file-tile-name.audio-meta-name{display:flex;flex-direction:column;align-items:center;gap:1px;text-overflow:unset;white-space:normal;word-break:break-word;line-height:1.2}.audio-title{font-weight:600;font-size:.82rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.audio-artist{font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.file-tile-thumbnail.audio-cover{border-radius:8px;object-fit:cover}.file-tile-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}.file-tile-size{font-size:.75rem;color:var(--text-secondary)}.file-tile-actions{display:flex;gap:6px;margin-top:4px}.ghost-tile{opacity:.7;border:2px dashed var(--primary);background:#4a90d90d;animation:ghostPulse 1.5s ease-in-out infinite}@keyframes ghostPulse{0%,to{border-color:var(--primary)}50%{border-color:#4a90d94d}}.ghost-spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-top:4px}.ghost-progress-wrap{width:100%;height:4px;background:var(--border);border-radius:2px;margin-top:6px;overflow:hidden}.ghost-progress-bar{height:100%;background:var(--primary);border-radius:2px;transition:width .15s ease}.ghost-progress-label{font-size:.7rem;color:var(--text-secondary);margin-top:2px;text-align:center}.ghost-success{border:2px solid var(--success);background:#28a7450d;transition:all .3s}.ghost-error{border:2px solid var(--error);background:#dc35450d;transition:all .3s}.storage-badge{position:absolute;bottom:6px;right:6px;font-size:.75rem;line-height:1;opacity:.7;transition:opacity .2s;display:inline-flex;align-items:center;gap:1px}.file-tile:hover .storage-badge{opacity:1}.storage-badge small{font-size:.6rem}.storage-local,.storage-cloud,.storage-both{filter:none}.storage-none{filter:grayscale(100%);opacity:.5}.file-badge-processing{position:absolute;top:8px;left:8px;z-index:3;display:inline-flex;align-items:center;gap:4px;background:#ffc107eb;color:#5a4200;font-size:.6rem;font-weight:600;padding:3px 8px;border-radius:10px;letter-spacing:.02em;line-height:1.2;white-space:nowrap;pointer-events:none;box-shadow:0 1px 4px #ffc1074d;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.file-badge-processing:before{content:"";display:inline-block;width:5px;height:5px;border-radius:50%;background:#e6a800;animation:processing-dot-blink 1.4s ease-in-out infinite}.file-tile:hover .file-badge-processing{background:#ffc107;box-shadow:0 2px 8px #ffc10766}@keyframes processing-dot-blink{0%,to{opacity:1}50%{opacity:.2}}.status-dot-error{position:absolute;top:8px;right:8px;width:10px;height:10px;border-radius:50%;background:var(--error);box-shadow:0 0 0 2px #dc35454d;z-index:2}.context-menu{position:fixed;z-index:1001;background:var(--card-bg);border-radius:8px;box-shadow:0 8px 30px #0000002e;border:1px solid var(--border);padding:4px 0;min-width:180px;display:none}.context-menu.visible{display:block}.context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 16px;border:none;background:none;font-size:.9rem;cursor:pointer;color:var(--text);transition:background .15s;text-align:left}.context-menu-item:hover{background:var(--bg)}.context-menu-item:disabled{opacity:.4;cursor:not-allowed}.context-menu-item:disabled:hover{background:none}.context-menu-item-danger{color:var(--error)}.context-menu-item-danger:hover{background:#dc354514}.context-menu-item-active{color:var(--primary);font-weight:600}.context-menu-submenu-trigger{position:relative;display:flex;align-items:center;justify-content:space-between}.context-menu-submenu-arrow{font-size:1.1rem;line-height:1;opacity:.5}.context-submenu{position:absolute;left:100%;top:-4px;margin-left:2px;min-width:180px;background:#fffffff5;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 30px #0000001f;padding:4px;z-index:10010;animation:submenuIn .12s ease}@keyframes submenuIn{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}.context-menu-separator{height:1px;background:var(--border);margin:4px 0}.context-menu-file-info{padding:8px 16px 4px}.context-menu-file-name{font-size:.85rem;font-weight:600;color:var(--text);word-break:break-all;line-height:1.3}.context-menu-file-size{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.action-btn{padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.action-btn-copy{background:var(--primary);color:#fff}.action-btn-copy:hover{background:var(--primary-hover)}.action-btn-download{background:#28a745;color:#fff}.action-btn-download:hover{background:#218838}.action-btn-delete{background:var(--error);color:#fff}.action-btn-delete:hover{background:#c82333}.action-btn-rename{background:var(--primary);color:#fff}.action-btn-rename:hover{background:var(--primary-hover)}.action-btn-retry{background:var(--warning);color:var(--text)}.action-btn-retry:hover{background:#e0a800}.folder-tile{cursor:pointer;transition:background .15s}.folder-tile:not(.parent-folder-tile){cursor:grab}.folder-tile:not(.parent-folder-tile):active{cursor:grabbing}.folder-tile:hover{background:#0000000a}.folder-tile.drop-target{background:#28a7451f}.file-tile.dragging{opacity:.4}.file-tile.drag-source{opacity:.5;outline:2px dashed var(--primary);outline-offset:-2px}.folder-icon{font-size:2.8rem}.folder-file-count{font-size:.75rem;color:var(--text-secondary)}.parent-folder-tile{background:transparent}.parent-folder-tile:hover{background:#0000000a}.parent-folder-icon{font-size:2.8rem;opacity:.7}.parent-folder-tile.drop-target{background:#28a7451f}.pagination{display:flex;justify-content:center;gap:8px;margin-top:20px}.pagination button{padding:8px 16px;border:2px solid var(--border);background:#fff;border-radius:8px;cursor:pointer;transition:all .2s}.pagination button:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.toast-container{position:fixed;top:20px;right:20px;z-index:1000;display:flex;flex-direction:column;gap:10px}.toast{padding:16px 20px;border-radius:8px;color:#fff;font-weight:500;box-shadow:0 4px 20px #00000026;animation:slideIn .3s ease;display:flex;align-items:center;gap:10px;min-width:300px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{background:var(--success)}.toast-error{background:var(--error)}.toast-info{background:var(--primary)}.toast-warning{background:var(--warning);color:var(--text)}.loading{text-align:center;padding:40px;color:var(--text-secondary)}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-state-icon{font-size:4rem;margin-bottom:15px}.empty-state p{font-size:1.1rem}body.drag-over:after{content:"Перетащите файлы сюда для загрузки";position:fixed;top:0;left:0;right:0;bottom:0;background:#4a90d926;border:4px dashed var(--primary);z-index:999;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--primary);pointer-events:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}body.drag-over{user-select:none;-webkit-user-select:none}.photos-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.photos-title{font-size:1.2rem;font-weight:600}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:16px}@media(max-width:768px){.container{flex-direction:column}.sidebar{width:100%;min-width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--border)}.sidebar-actions{flex-direction:row;overflow-x:auto;border-bottom:none;border-right:none;padding:4px 8px}.sidebar-nav{flex-direction:row;overflow-x:auto}.workspace-content{padding:15px}.breadcrumb-row{flex-wrap:wrap}.files-header{flex-direction:column;align-items:stretch}.files-actions{flex-direction:column}}.folder-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:3000;display:none;align-items:center;justify-content:center}.folder-modal.visible{display:flex}.folder-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:folderModalFadeIn .2s ease}@keyframes folderModalFadeIn{0%{opacity:0}to{opacity:1}}.folder-modal-dialog{position:relative;width:420px;max-width:92vw;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0003,0 0 0 1px #0000000d;z-index:1;animation:folderModalSlideIn .25s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes folderModalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.folder-modal-header{display:flex;align-items:center;gap:12px;padding:20px 24px 0}.folder-modal-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,#4a90d91f,#4a90d90a);border-radius:12px;flex-shrink:0}.folder-modal-title{flex:1;font-size:1.15rem;font-weight:700;color:var(--text);margin:0;line-height:1.3}.folder-modal-close{width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);font-size:20px;line-height:1;border-radius:8px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.folder-modal-close:hover{background:var(--bg);color:var(--text)}.folder-modal-body{padding:20px 24px}.folder-modal-label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.03em}.folder-modal-input-wrapper{position:relative;display:flex;align-items:center}.folder-modal-input{width:100%;padding:12px 16px 12px 44px;border:2px solid var(--border);border-radius:10px;font-size:1rem;font-family:inherit;color:var(--text);background:var(--bg);transition:all .2s;outline:none}.folder-modal-input:focus{border-color:var(--primary);background:var(--card-bg);box-shadow:0 0 0 4px #4a90d91f}.folder-modal-input::placeholder{color:var(--text-secondary);opacity:.6}.folder-modal-input-icon{position:absolute;left:14px;font-size:1.1rem;pointer-events:none;opacity:.5;transition:opacity .2s}.folder-modal-input:focus~.folder-modal-input-icon{opacity:.8}.folder-modal-hint{font-size:.8rem;color:var(--text-secondary);margin-top:8px;min-height:18px;transition:color .2s}.folder-modal-hint.error{color:var(--error)}.folder-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px 20px;background:#00000004;border-top:1px solid var(--border)}.folder-modal-btn{padding:10px 22px;border:none;border-radius:10px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;line-height:1.4}.folder-modal-btn-cancel{background:transparent;color:var(--text-secondary)}.folder-modal-btn-cancel:hover{background:var(--bg);color:var(--text)}.folder-modal-btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4a90d94d}.folder-modal-btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #4a90d959}.folder-modal-btn-primary:active{transform:translateY(0)}.folder-modal-btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}@media(max-width:768px){.folder-modal-dialog{max-width:95vw;border-radius:14px}.folder-modal-header{padding:16px 18px 0}.folder-modal-body{padding:16px 18px}.folder-modal-footer{padding:12px 18px 16px}}.confirm-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:3000;display:none;align-items:center;justify-content:center}.confirm-modal.visible{display:flex}.confirm-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:folderModalFadeIn .2s ease}.confirm-modal-dialog{position:relative;width:400px;max-width:92vw;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0003,0 0 0 1px #0000000d;z-index:1;animation:folderModalSlideIn .25s cubic-bezier(.16,1,.3,1);overflow:hidden}.confirm-modal-header{display:flex;align-items:center;gap:12px;padding:20px 24px 0}.confirm-modal-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,#dc35451f,#dc35450a);border-radius:12px;flex-shrink:0}.confirm-modal-title{flex:1;font-size:1.15rem;font-weight:700;color:var(--text);margin:0;line-height:1.3}.confirm-modal-close{width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);font-size:20px;line-height:1;border-radius:8px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.confirm-modal-close:hover{background:var(--bg);color:var(--text)}.confirm-modal-body{padding:20px 24px}.confirm-modal-message{font-size:.95rem;color:var(--text);line-height:1.5;margin:0}.confirm-modal-detail{font-size:.85rem;color:var(--text-secondary);margin:8px 0 0;line-height:1.4}.confirm-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px 20px;background:#00000004;border-top:1px solid var(--border)}.confirm-modal-btn{padding:10px 22px;border:none;border-radius:10px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;line-height:1.4}.confirm-modal-btn-cancel{background:transparent;color:var(--text-secondary)}.confirm-modal-btn-cancel:hover{background:var(--bg);color:var(--text)}.confirm-modal-btn-danger{background:var(--error);color:#fff;box-shadow:0 2px 8px #dc35454d}.confirm-modal-btn-danger:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 4px 12px #dc354559}.confirm-modal-btn-danger:active{transform:translateY(0)}.confirm-modal-btn-danger:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}@media(max-width:768px){.confirm-modal-dialog{max-width:95vw;border-radius:14px}.confirm-modal-header{padding:16px 18px 0}.confirm-modal-body{padding:16px 18px}.confirm-modal-footer{padding:12px 18px 16px}}.image-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:none;align-items:center;justify-content:center}.image-modal.visible{display:flex}.image-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000e6;cursor:pointer}.image-modal-content{position:relative;max-width:95vw;max-height:95vh;display:flex;flex-direction:column;align-items:center;z-index:1}.image-modal-close{position:fixed;top:15px;right:20px;width:40px;height:40px;border:none;background:#ffffff1a;color:#fff;font-size:28px;line-height:1;border-radius:50%;cursor:pointer;transition:background .2s,transform .2s;z-index:10;display:flex;align-items:center;justify-content:center}.image-modal-close:hover{background:#fff3;transform:scale(1.1)}.image-modal-nav{position:fixed;top:50%;transform:translateY(-50%);width:50px;height:70px;border:none;background:#ffffff1a;color:#fff;font-size:32px;border-radius:8px;cursor:pointer;transition:background .2s,transform .2s;z-index:10;display:flex;align-items:center;justify-content:center}.image-modal-nav:hover{background:#fff3;transform:translateY(-50%) scale(1.05)}.image-modal-prev{left:15px}.image-modal-next{right:15px}.image-modal-nav:disabled{opacity:.3;cursor:not-allowed}.image-modal-nav:disabled:hover{background:#ffffff1a;transform:translateY(-50%)}.image-modal-spinner{display:none;width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;position:absolute}.image-modal.loading .image-modal-spinner{display:block}.image-modal-img{max-width:95vw;max-height:85vh;object-fit:contain;border-radius:4px;opacity:1;transition:opacity .2s}.image-modal.loading .image-modal-img{opacity:0}.image-modal-info{display:flex;align-items:center;gap:16px;padding:12px 20px;background:#0009;border-radius:8px;margin-top:12px;color:#fff;font-size:.9rem}.image-modal-name{font-weight:500;word-break:break-all}.image-modal-size{color:#ffffffb3;flex-shrink:0}@media(max-width:768px){.image-modal-nav{width:40px;height:50px;font-size:24px}.image-modal-prev{left:5px}.image-modal-next{right:5px}.image-modal-info{flex-direction:column;gap:4px;text-align:center;font-size:.8rem}}.pdf-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:none;align-items:center;justify-content:center}.pdf-modal.visible{display:flex}.pdf-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000e6;cursor:pointer}.pdf-modal-content{position:relative;width:90vw;height:90vh;display:flex;flex-direction:column;align-items:center;z-index:1}.pdf-modal-close{position:fixed;top:15px;right:20px;width:40px;height:40px;border:none;background:#ffffff1a;color:#fff;font-size:28px;line-height:1;border-radius:50%;cursor:pointer;transition:background .2s,transform .2s;z-index:10;display:flex;align-items:center;justify-content:center}.pdf-modal-close:hover{background:#fff3;transform:scale(1.1)}.pdf-modal-spinner{display:none;width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5}.pdf-modal.loading .pdf-modal-spinner{display:block}.pdf-modal-iframe{width:100%;height:100%;border:none;border-radius:4px;background:#fff}.pdf-modal.loading .pdf-modal-iframe{opacity:0}.pdf-modal-iframe{opacity:1;transition:opacity .2s}.pdf-modal-info{display:flex;align-items:center;gap:16px;padding:12px 20px;background:#0009;border-radius:8px;margin-top:12px;color:#fff;font-size:.9rem}.pdf-modal-name{font-weight:500;word-break:break-all}.pdf-modal-size{color:#ffffffb3;flex-shrink:0}@media(max-width:768px){.pdf-modal-content{width:98vw;height:85vh}.pdf-modal-info{flex-direction:column;gap:4px;text-align:center;font-size:.8rem}}.audio-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:none;align-items:center;justify-content:center}.audio-modal.visible{display:flex}.audio-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000d9;cursor:pointer}.audio-modal-content{position:relative;width:480px;max-width:92vw;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;z-index:1;padding:32px 28px 24px;display:flex;flex-direction:column;align-items:center;gap:20px;animation:folderModalSlideIn .25s cubic-bezier(.16,1,.3,1)}.audio-modal-close{position:fixed;top:15px;right:20px;width:40px;height:40px;border:none;background:#ffffff1a;color:#fff;font-size:28px;line-height:1;border-radius:50%;cursor:pointer;transition:background .2s,transform .2s;z-index:10;display:flex;align-items:center;justify-content:center}.audio-modal-close:hover{background:#fff3;transform:scale(1.1)}.audio-modal-icon{font-size:3.5rem;line-height:1}.audio-modal-player-wrapper{width:100%}.audio-modal-player{width:100%;height:48px;border-radius:8px;outline:none}.audio-modal-info{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center;font-size:.9rem;color:var(--text)}.audio-modal-name{font-weight:600;word-break:break-all}.audio-modal-size{color:var(--text-secondary);flex-shrink:0}@media(max-width:768px){.audio-modal-content{max-width:95vw;padding:24px 16px 20px}.audio-modal-info{flex-direction:column;gap:4px;text-align:center;font-size:.8rem}}.video-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:none;align-items:center;justify-content:center}.video-modal.visible{display:flex}.video-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000e6;cursor:pointer}.video-modal-content{position:relative;width:90vw;max-width:960px;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;z-index:1;padding:20px;display:flex;flex-direction:column;align-items:center;gap:16px;animation:folderModalSlideIn .25s cubic-bezier(.16,1,.3,1)}.video-modal-close{position:fixed;top:15px;right:20px;width:40px;height:40px;border:none;background:#ffffff1a;color:#fff;font-size:28px;line-height:1;border-radius:50%;cursor:pointer;transition:background .2s,transform .2s;z-index:10;display:flex;align-items:center;justify-content:center}.video-modal-close:hover{background:#fff3;transform:scale(1.1)}.video-modal-player-wrapper{width:100%;background:#000;border-radius:8px;overflow:hidden}.video-modal-player{width:100%;max-height:70vh;display:block;outline:none}.video-modal-info{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:center;font-size:.9rem;color:var(--text)}.video-modal-name{font-weight:600;word-break:break-all}.video-modal-size{color:var(--text-secondary);flex-shrink:0}@media(max-width:768px){.video-modal-content{max-width:95vw;padding:16px}.video-modal-info{flex-direction:column;gap:4px;text-align:center;font-size:.8rem}}.text-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:none;align-items:center;justify-content:center}.text-modal.visible{display:flex}.text-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000d9;cursor:pointer}.text-modal-content{position:relative;width:90vw;max-width:960px;max-height:90vh;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;z-index:1;padding:20px;display:flex;flex-direction:column;gap:0;animation:folderModalSlideIn .25s cubic-bezier(.16,1,.3,1);overflow:hidden}.text-modal-close{position:fixed;top:15px;right:20px;width:40px;height:40px;border:none;background:#ffffff1a;color:#fff;font-size:28px;line-height:1;border-radius:50%;cursor:pointer;transition:background .2s,transform .2s;z-index:10;display:flex;align-items:center;justify-content:center}.text-modal-close:hover{background:#fff3;transform:scale(1.1)}.text-modal-toolbar{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:12px;flex-shrink:0}.text-modal-filename{font-weight:600;font-size:.9rem;color:var(--text);word-break:break-all;flex:1;min-width:0}.text-modal-size{color:var(--text-secondary);font-size:.85rem;flex-shrink:0}.text-modal-wrap-btn,.text-modal-copy-btn{width:32px;height:32px;border:1px solid var(--border);background:transparent;border-radius:6px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s;flex-shrink:0}.text-modal-wrap-btn:hover,.text-modal-copy-btn:hover{background:var(--bg);border-color:var(--primary)}.text-modal-wrap-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.text-modal-body{flex:1;min-height:0;overflow:auto;position:relative}.text-modal-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:40px auto}.text-modal-error{color:var(--error);text-align:center;padding:40px 16px;font-size:.9rem}.text-modal-pre{width:100%;height:100%;overflow:auto;margin:0;padding:16px;font-family:Cascadia Code,Fira Code,JetBrains Mono,Consolas,monospace;font-size:.85rem;line-height:1.6;color:var(--text);background:#00000008;border-radius:8px;box-sizing:border-box;white-space:pre;-moz-tab-size:4;tab-size:4}.text-modal-pre.wrap{white-space:pre-wrap;word-break:break-all}@media(max-width:768px){.text-modal-content{max-width:95vw;padding:12px}.text-modal-toolbar{flex-wrap:wrap;gap:8px}.text-modal-filename{font-size:.8rem}.text-modal-pre{font-size:.78rem;padding:12px}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{width:420px;max-width:95vw;background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:16px;box-shadow:0 20px 60px #00000026,0 0 0 1px #0000000d;padding:40px 32px 32px;animation:folderModalSlideIn .3s cubic-bezier(.16,1,.3,1)}.login-header{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:32px}.login-logo{width:56px;height:56px;border-radius:12px;object-fit:contain}.login-title{font-size:1.5rem;font-weight:700;color:var(--text)}.login-fields{display:flex;flex-direction:column;gap:16px}.login-field{display:flex;flex-direction:column;gap:6px}.login-label{font-size:.85rem;font-weight:600;color:var(--text-secondary)}.login-input{width:100%;padding:12px 16px;border:2px solid var(--border);border-radius:10px;font-size:1rem;font-family:inherit;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s,box-shadow .2s}.login-input:focus{border-color:var(--primary);box-shadow:0 0 0 4px #4a90d91f}.login-input::placeholder{color:var(--text-secondary);opacity:.6}.login-error{margin-top:12px;padding:10px 14px;background:#dc354514;border:1px solid rgba(220,53,69,.2);border-radius:8px;color:var(--error);font-size:.9rem;text-align:center}.login-submit{width:100%;margin-top:24px;padding:13px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-size:1rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:48px}.login-submit:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #4a90d959}.login-submit:active{transform:translateY(0)}.login-submit:disabled{opacity:.7;cursor:not-allowed}.login-spinner{width:22px;height:22px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.login-toggle{width:100%;margin-top:16px;padding:10px;border:none;border-radius:8px;background:transparent;color:var(--primary);font-size:.9rem;font-family:inherit;cursor:pointer;transition:background .15s}.login-toggle:hover{background:#4a90d90f}.tokens-page{max-width:720px;margin:0 auto}.tokens-header{margin-bottom:24px}.tokens-title{font-size:1.3rem;font-weight:700;color:var(--text)}.tokens-create-form{background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:20px}.tokens-form-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.tokens-input{flex:1;min-width:180px;padding:10px 14px;border:2px solid var(--border);border-radius:10px;font-size:.9rem;font-family:inherit;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s}.tokens-input:focus{border-color:var(--primary)}.tokens-checkbox-label{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text);cursor:pointer;white-space:nowrap}.tokens-checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.tokens-select{padding:10px 12px;border:2px solid var(--border);border-radius:10px;font-size:.85rem;font-family:inherit;color:var(--text);background:var(--bg);outline:none;cursor:pointer}.tokens-select:focus{border-color:var(--primary)}.tokens-create-btn{padding:10px 24px;border:none;border-radius:10px;background:var(--primary);color:#fff;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.tokens-create-btn:hover{background:var(--primary-hover)}.tokens-create-btn:disabled{opacity:.5;cursor:not-allowed}.tokens-created-card{background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:2px solid var(--success);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:20px}.tokens-created-header{font-size:.9rem;font-weight:600;color:var(--success);margin-bottom:12px}.tokens-created-value{display:flex;align-items:center;gap:10px;margin-bottom:12px}.tokens-created-value code{flex:1;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-size:.8rem;word-break:break-all;line-height:1.5;max-height:120px;overflow-y:auto}.tokens-copy-btn{padding:8px 16px;border:none;border-radius:8px;background:var(--primary);color:#fff;font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s}.tokens-copy-btn:hover{background:var(--primary-hover)}.tokens-created-close{padding:6px 14px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.8rem;font-family:inherit;cursor:pointer;transition:background .15s}.tokens-created-close:hover{background:var(--bg)}.tokens-list{display:flex;flex-direction:column;gap:10px}.tokens-empty{text-align:center;padding:40px 20px;color:var(--text-secondary);font-size:.95rem}.tokens-item{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px 20px;transition:opacity .2s}.tokens-item.expired{opacity:.55}.tokens-item-info{flex:1;min-width:0}.tokens-item-name{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:4px}.tokens-item-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;font-size:.78rem;color:var(--text-secondary)}.tokens-badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.tokens-badge.permanent{background:#28a7451a;color:var(--success)}.tokens-badge.expired{background:#dc35451a;color:var(--error)}.tokens-delete-btn{padding:8px 16px;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.8rem;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.tokens-delete-btn:hover{background:#dc354514;color:var(--error)}@media(max-width:600px){.tokens-form-row{flex-direction:column;align-items:stretch}.tokens-input{min-width:0}}.cinema-header{margin-bottom:24px}.cinema-title{font-size:1.3rem;font-weight:700;color:var(--text)}.cinema-breadcrumb{display:flex;align-items:center;gap:4px;margin-bottom:20px;flex-wrap:wrap}.cinema-breadcrumb-item{background:none;border:none;padding:4px 8px;border-radius:6px;font-size:.85rem;font-family:inherit;color:var(--primary);cursor:pointer;transition:background .15s}.cinema-breadcrumb-item:hover{background:#4a90d914}.cinema-breadcrumb-item.current{color:var(--text);font-weight:600;cursor:default}.cinema-breadcrumb-item.current:hover{background:none}.cinema-breadcrumb-sep{color:var(--text-secondary);font-size:.8rem;-webkit-user-select:none;user-select:none}.cinema-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.cinema-card{background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;outline:none}.cinema-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001a}.cinema-card:focus-visible{box-shadow:0 0 0 3px #4a90d94d}.cinema-card-poster{aspect-ratio:16 / 9;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.cinema-card-poster:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 50%,rgba(74,144,217,.15),transparent 70%)}.cinema-card-icon{font-size:2.2rem;opacity:.6;filter:grayscale(.2);position:relative;z-index:1}.cinema-card-info{padding:12px 14px 14px}.cinema-card-name{font-size:.92rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cinema-card-meta{font-size:.78rem;color:var(--text-secondary);margin-top:4px}.cinema-subfolders{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.cinema-subfolder-card{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;transition:transform .15s,box-shadow .15s;outline:none}.cinema-subfolder-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014}.cinema-subfolder-icon{font-size:1.2rem}.cinema-subfolder-name{font-size:.88rem;font-weight:600;color:var(--text);max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cinema-files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.cinema-file-card{background:var(--card-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;outline:none}.cinema-file-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.cinema-file-poster{aspect-ratio:16 / 9;width:100%;object-fit:cover;display:block;background:var(--bg)}.cinema-file-poster-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2d2d3f,#1e1e2e);font-size:2rem}.cinema-file-info{padding:10px 12px 12px}.cinema-file-name{font-size:.85rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cinema-file-meta{font-size:.75rem;color:var(--text-secondary);margin-top:3px}@media(max-width:600px){.cinema-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.cinema-files-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}}.vmeta-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:3000;display:none;align-items:center;justify-content:center}.vmeta-modal.visible{display:flex}.vmeta-modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.vmeta-modal-dialog{position:relative;width:420px;max-width:92vw;background:var(--card-bg);border-radius:16px;box-shadow:0 20px 60px #0003,0 0 0 1px #0000000d;z-index:1;animation:vmetaSlideIn .25s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes vmetaSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.vmeta-modal-header{display:flex;align-items:center;gap:12px;padding:20px 24px 0}.vmeta-modal-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;background:linear-gradient(135deg,#4a90d91f,#4a90d90a);border-radius:12px;flex-shrink:0}.vmeta-modal-title{flex:1;font-size:1.15rem;font-weight:700;color:var(--text);margin:0;line-height:1.3}.vmeta-modal-close{width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);font-size:20px;line-height:1;border-radius:8px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.vmeta-modal-close:hover{background:var(--bg);color:var(--text)}.vmeta-modal-body{padding:20px 24px}.vmeta-modal-filename{font-size:.85rem;color:var(--text-secondary);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vmeta-field{display:flex;flex-direction:column;gap:6px}.vmeta-label{font-size:.82rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.03em}.vmeta-input{width:100%;padding:10px 14px;border:2px solid var(--border);border-radius:10px;font-size:.95rem;font-family:inherit;color:var(--text);background:var(--bg);outline:none;transition:border-color .2s}.vmeta-input:focus{border-color:var(--primary)}.vmeta-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:16px 24px 20px;background:#00000004;border-top:1px solid var(--border)}.vmeta-btn{padding:10px 22px;border:none;border-radius:10px;font-size:.9rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;line-height:1.4}.vmeta-btn-cancel{background:transparent;color:var(--text-secondary)}.vmeta-btn-cancel:hover{background:var(--bg);color:var(--text)}.vmeta-btn-save{background:var(--primary);color:#fff;box-shadow:0 2px 8px #4a90d94d}.vmeta-btn-save:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #4a90d959}.vmeta-btn-save:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
