.app-header{position:sticky;top:0;z-index:100;background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 4%}.header-inner{max-width:1400px;margin:0 auto;height:60px;display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:32px}.header-logo{display:flex;align-items:center;gap:10px;text-decoration:none}.logo-text{font-size:22px;font-weight:800;color:var(--accent);letter-spacing:-.5px}.header-nav{display:flex;gap:6px}.header-nav a{padding:6px 14px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:all .2s}.header-nav a:hover{color:var(--text-primary);background:var(--bg-card)}.header-nav a.active{color:var(--text-primary);background:var(--accent-soft)}.header-right{display:flex;align-items:center;gap:12px}.header-account{position:relative;cursor:pointer}.account-avatar{width:34px;height:34px;border-radius:6px;background:var(--accent);color:#fff;font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center}.account-menu{position:absolute;right:0;top:44px;width:240px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden;z-index:200}.account-info{padding:14px 16px}.account-bucket{font-weight:700;font-size:14px}.account-endpoint{font-size:12px;color:var(--text-muted);margin-top:2px;word-break:break-all}.account-divider{height:1px;background:var(--border)}.account-menu-item{display:block;width:100%;padding:10px 16px;text-align:left;background:none;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:background .15s}.account-menu-item:hover{background:var(--bg-card);color:var(--danger)}@media (max-width: 640px){.header-nav{display:none}.logo-text{font-size:18px}}.welcome-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px}.welcome-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;max-width:480px;width:100%}.empty-state-icon{width:88px;height:88px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:28px;color:var(--accent)}.empty-state-title{font-size:24px;font-weight:700;margin-bottom:12px;color:var(--text-primary);letter-spacing:-.3px}.empty-state-desc{font-size:15px;color:var(--text-muted);line-height:1.6;max-width:380px;margin-bottom:32px}.empty-state-btn{padding:14px 36px;font-size:15px;font-weight:600;border-radius:var(--radius-lg)}.welcome-accounts{width:100%;max-width:520px;display:flex;flex-direction:column;gap:32px}.welcome-header-bar{display:flex;align-items:center;justify-content:center}.welcome-logo{display:flex;align-items:center;gap:10px}.welcome-logo-text{font-size:26px;font-weight:800;color:var(--accent);letter-spacing:-.5px}.welcome-accounts-section h2{font-size:20px;font-weight:700;margin-bottom:6px}.welcome-accounts-desc{font-size:14px;color:var(--text-muted);margin-bottom:18px}.account-list{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.account-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s;position:relative}.account-card:hover{background:var(--bg-card-hover);border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow)}.account-card-avatar{width:42px;height:42px;border-radius:8px;background:var(--accent);color:#fff;font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.account-card-info{flex:1;min-width:0}.account-card-name{font-weight:700;font-size:15px}.account-card-detail{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-card-remove{position:absolute;top:8px;right:10px;background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;line-height:1;padding:2px 6px}.account-card-remove:hover{color:var(--danger)}.conn-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:8px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.conn-direct{background:#46d36926;color:var(--success)}.conn-proxy{background:#e8b70826;color:var(--warning)}.add-another-btn{width:100%;justify-content:center;padding:12px 20px;border-style:dashed;font-size:14px}.source-chooser-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:480px;width:100%;animation:slideUp .25s ease}.source-chooser-header{padding:24px 28px 0;position:relative}.source-chooser-header .modal-close{position:absolute;top:16px;right:16px}.source-chooser-header h2{font-size:20px;font-weight:700;margin-bottom:6px}.source-chooser-desc{font-size:13px;color:var(--text-muted);line-height:1.5}.source-chooser-cards{display:flex;flex-direction:column;gap:10px;padding:20px 28px 28px}.source-card{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:all .2s}.source-card:hover{background:var(--bg-card-hover);border-color:var(--accent);transform:translateY(-1px);box-shadow:var(--shadow)}.source-card-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.source-card-icon-local{background:#3b82f61f;color:#3b82f6}.source-card-icon-cloud{background:var(--accent-soft);color:var(--accent)}.source-card-text{flex:1;min-width:0}.source-card-text h3{font-size:15px;font-weight:700;margin-bottom:4px;color:var(--text-primary)}.source-card-text p{font-size:13px;color:var(--text-muted);line-height:1.4;margin:0}.source-card-arrow{color:var(--text-muted);flex-shrink:0;transition:transform .2s}.source-card:hover .source-card-arrow{transform:translate(2px);color:var(--accent)}.s3-connect-modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .25s ease}.s3-modal-header{padding:24px 28px 0;position:relative}.s3-modal-header .modal-close{position:absolute;top:16px;right:16px}.s3-modal-icon{width:44px;height:44px;border-radius:10px;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.s3-modal-header h2{font-size:20px;font-weight:700;margin-bottom:6px}.s3-modal-desc{font-size:13px;color:var(--text-muted);line-height:1.5}.s3-connect-form{padding:20px 28px 28px}.s3-connect-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.s3-connect-form .form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.required{color:var(--danger)}.connect-status{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius);background:var(--accent-soft);color:var(--accent);font-size:13px;font-weight:500;margin-bottom:16px}.spinner-sm{width:18px;height:18px;border-width:2px}.cors-info{display:flex;align-items:flex-start;gap:8px;padding:10px 14px;border-radius:var(--radius);background:var(--bg-card);font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:4px}.cors-info svg{flex-shrink:0;margin-top:1px}.form-error{background:#e509141a;color:var(--danger);padding:10px 14px;border-radius:var(--radius);margin-bottom:16px;font-size:14px}.btn-lg{padding:14px 32px;font-size:16px}@media (max-width: 520px){.s3-connect-form .form-row{grid-template-columns:1fr}.empty-state-title{font-size:20px}.empty-state-desc{font-size:14px}.s3-connect-modal,.source-chooser-modal{margin:10px}.source-card{padding:14px 16px;gap:12px}.source-card-icon{width:48px;height:48px}}.media-card{flex:0 0 220px;scroll-snap-align:start;cursor:pointer;border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s;background:var(--bg-card)}.media-card:hover{transform:scale(1.05);box-shadow:var(--shadow-lg);z-index:2}.media-card--audio{flex:0 0 180px}.card-thumb{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;background:var(--bg-input)}.media-card--audio .card-thumb{aspect-ratio:1}.card-thumb img{width:100%;height:100%;object-fit:cover;display:block}.card-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.card-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;opacity:0;transition:opacity .2s}.media-card:hover .card-play-overlay{opacity:1}.card-progress{position:absolute;bottom:0;left:0;right:0;height:4px;background:#fff3}.card-progress-bar{height:100%;background:var(--accent)}.card-info{padding:10px 12px}.card-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-cats{font-size:11px;color:var(--text-muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.media-row{margin-bottom:36px}.row-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.row-title{font-size:20px;font-weight:700}.row-arrows{display:flex;gap:4px}.row-arrow{width:32px;height:32px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1}.row-arrow:hover{background:var(--bg-card-hover);border-color:var(--accent)}.row-scroll-wrapper{padding:0 4%}.row-scroll{display:flex;gap:12px;overflow-x:auto;scroll-snap-type:x mandatory;-ms-overflow-style:none;scrollbar-width:none;padding-bottom:4px}.row-scroll::-webkit-scrollbar{display:none}.cat-manager-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0009;display:flex;align-items:center;justify-content:center}.cat-manager{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:480px;max-width:95vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0006}.cat-manager-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.cat-manager-header h2{font-size:18px;font-weight:700;margin:0}.cat-manager-close{background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:0;line-height:1}.cat-manager-close:hover{color:var(--text-primary)}.cat-manager-body{padding:20px 24px;overflow-y:auto;flex:1}.cat-section{margin-bottom:20px}.cat-section h3{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:10px}.cat-list{display:flex;flex-direction:column;gap:4px}.cat-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-radius:var(--radius);background:var(--bg-secondary);gap:8px}.cat-item-name{font-size:14px;font-weight:500;flex:1}.cat-item-actions{display:flex;gap:4px}.cat-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center}.cat-action-btn:hover{color:var(--text-primary);background:var(--border)}.cat-action-btn.cat-delete:hover{color:var(--error)}.cat-edit-input{flex:1;padding:4px 8px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--accent);border-radius:4px;font-size:14px;outline:none}.cat-empty{font-size:13px;color:var(--text-muted);padding:8px 12px;font-style:italic}.cat-add-form{display:flex;gap:8px;align-items:center;padding-top:16px;border-top:1px solid var(--border)}.cat-add-input{flex:1;padding:8px 12px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;outline:none}.cat-add-input:focus{border-color:var(--accent)}.cat-add-select{padding:8px 10px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;outline:none}.library-page{padding-bottom:60px}.library-hero{background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);padding:40px 0 32px;border-bottom:1px solid var(--border)}.hero-content{max-width:600px}.hero-title{font-size:36px;font-weight:800;margin-bottom:6px}.hero-subtitle{color:var(--text-secondary);font-size:15px;margin-bottom:20px}.hero-search{position:relative}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:12px 14px 12px 42px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius-lg);font-size:15px;outline:none;transition:border-color .2s}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-muted)}.library-empty{text-align:center;padding:80px 20px}.empty-icon{margin-bottom:20px;opacity:.4}.library-empty h2{font-size:24px;font-weight:700;margin-bottom:8px}.library-empty p{color:var(--text-secondary);max-width:380px;margin:0 auto 24px;font-size:15px}.empty-actions{display:flex;gap:12px;justify-content:center}.hero-actions-row{display:flex;gap:12px;align-items:stretch}.hero-actions-row .hero-search{flex:1}.btn-manage-cats{display:flex;align-items:center;gap:6px;white-space:nowrap;font-size:13px;font-weight:600;padding:0 16px}.library-rows{padding-top:24px}.library-no-results{text-align:center;padding:60px 20px;color:var(--text-muted);font-size:16px}.player-container{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#000;display:flex;align-items:center;justify-content:center}.player-container.hide-cursor{cursor:none}.video-element{width:100%;height:100%;object-fit:contain}.audio-element{display:none}.player-back{position:absolute;top:20px;left:20px;z-index:10;background:#00000080;border:none;color:#fff;padding:8px;border-radius:50%;cursor:pointer;transition:all .2s}.player-back:hover{background:#ffffff26}.player-back.hidden{opacity:0;pointer-events:none}.player-controls{position:absolute;bottom:0;left:0;right:0;z-index:10;background:linear-gradient(transparent,#000000d9);padding:40px 20px 16px;transition:opacity .3s}.player-controls.hidden{opacity:0;pointer-events:none}.progress-track{position:relative;height:5px;background:#fff3;border-radius:3px;cursor:pointer;margin-bottom:12px;transition:height .1s}.progress-track:hover{height:8px}.progress-played{position:absolute;top:0;left:0;height:100%;background:var(--accent, #e50914);border-radius:3px}.progress-handle{position:absolute;top:50%;width:14px;height:14px;background:var(--accent, #e50914);border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity .15s}.progress-track:hover .progress-handle{opacity:1}.controls-bar{display:flex;align-items:center;justify-content:space-between}.controls-left{display:flex;align-items:center;gap:8px}.controls-right{display:flex;align-items:center;gap:12px}.ctrl-btn{background:none;border:none;color:#fff;padding:6px;cursor:pointer;border-radius:4px;display:flex;align-items:center;transition:background .15s}.ctrl-btn:hover{background:#ffffff1a}.volume-group{display:flex;align-items:center;gap:4px}.volume-slider{width:80px;height:4px;accent-color:#fff;cursor:pointer}.time-display{color:#ccc;font-size:13px;font-variant-numeric:tabular-nums;margin-left:4px;white-space:nowrap}.ctrl-title{color:#fff;font-size:14px;font-weight:600;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-error{text-align:center;padding:80px 20px}.player-error h2{margin-bottom:8px}.player-error p{color:var(--text-secondary);margin-bottom:20px}.audio-player-container{background:linear-gradient(135deg,#0f0f0f,#1a1a2e,#16213e);flex-direction:column;overflow-y:auto}.audio-player-visual{display:flex;flex-direction:column;align-items:center;padding:40px 24px;max-width:480px;width:100%}.audio-player-art{position:relative;width:280px;height:280px;border-radius:16px;overflow:hidden;cursor:pointer;box-shadow:0 12px 48px #0009;margin-bottom:32px;flex-shrink:0}.audio-player-art img{width:100%;height:100%;object-fit:cover;display:block}.audio-player-art-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#2a2a3e,#1a1a2e);display:flex;align-items:center;justify-content:center;color:var(--accent, #e50914)}.audio-player-art-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0000004d;opacity:0;transition:opacity .2s}.audio-player-art:hover .audio-player-art-overlay{opacity:1}.audio-player-title{color:#fff;font-size:24px;font-weight:700;text-align:center;margin:0 0 6px;line-height:1.3;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.audio-player-desc{color:#999;font-size:14px;text-align:center;margin:0 0 4px;line-height:1.4;max-width:100%;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.audio-player-cats{color:#666;font-size:12px;text-align:center;margin-bottom:28px;letter-spacing:.5px;text-transform:uppercase}.audio-player-progress-wrap{display:flex;align-items:center;gap:12px;width:100%;margin-bottom:20px}.audio-player-time{color:#888;font-size:12px;font-variant-numeric:tabular-nums;min-width:40px;white-space:nowrap}.audio-player-time:first-child{text-align:right}.audio-player-time:last-child{text-align:left}.audio-player-progress{flex:1;position:relative;height:6px;background:#ffffff26;border-radius:3px;cursor:pointer;transition:height .1s}.audio-player-progress:hover{height:8px}.audio-player-progress-fill{position:absolute;top:0;left:0;height:100%;background:var(--accent, #e50914);border-radius:3px}.audio-player-progress-handle{position:absolute;top:50%;width:14px;height:14px;background:#fff;border-radius:50%;transform:translate(-50%,-50%);opacity:0;transition:opacity .15s;box-shadow:0 1px 4px #0006}.audio-player-progress:hover .audio-player-progress-handle{opacity:1}.audio-player-controls{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:20px}.audio-ctrl-btn{background:none;border:none;color:#fff;padding:8px;cursor:pointer;border-radius:50%;display:flex;align-items:center;transition:background .15s}.audio-ctrl-btn:hover{background:#ffffff1a}.audio-ctrl-play{background:var(--accent, #e50914);width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%}.audio-ctrl-play:hover{background:#ff1a2a}.audio-player-volume{display:flex;align-items:center;justify-content:center;gap:8px}.audio-volume-slider{width:120px;height:4px;accent-color:var(--accent, #e50914);cursor:pointer}@media (max-width: 640px){.volume-group,.ctrl-title{display:none}.controls-bar{gap:6px}.audio-player-art{width:200px;height:200px}.audio-player-title{font-size:20px}.audio-player-volume{display:none}.audio-player-visual{padding:24px 16px}}.upload-page{padding:32px 0 60px;max-width:700px}.upload-header{margin-bottom:28px}.upload-header h1{font-size:28px;font-weight:800;margin-bottom:4px}.upload-header p{color:var(--text-secondary);font-size:15px}.upload-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px}.upload-drop{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:40px;text-align:center;cursor:pointer;transition:all .2s;margin-bottom:24px}.upload-drop:hover{border-color:var(--accent);background:var(--accent-soft)}.upload-placeholder{color:var(--text-muted)}.upload-placeholder p{margin-top:12px;font-size:15px}.upload-hint{font-size:12px!important;color:var(--text-muted);margin-top:4px!important}.upload-selected{display:flex;align-items:center;gap:10px;justify-content:center;font-size:15px;font-weight:600}.upload-size{color:var(--text-muted);font-weight:400;font-size:13px}.cat-grid{display:flex;flex-wrap:wrap;gap:8px}.cat-chip{padding:6px 16px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.cat-chip:hover{border-color:var(--accent);color:var(--accent)}.cat-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.upload-extras{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:20px}.extra-item{display:flex;flex-direction:column;gap:6px}.extra-item label{font-size:13px;font-weight:600;color:var(--text-secondary)}.extra-item .btn{font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-progress{margin-bottom:20px}.upload-progress-label{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text-secondary)}.upload-progress-track{height:8px;border-radius:4px;background:var(--border);overflow:hidden}.upload-progress-bar{height:100%;border-radius:4px;background:var(--accent);transition:width .15s ease}@media (max-width: 600px){.upload-extras{grid-template-columns:1fr}.upload-page{padding:20px 0}}.edit-media-page{padding:32px 0 60px;max-width:900px}.edit-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:4px;overflow:hidden}.edit-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:transparent;border:none;border-radius:var(--radius);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.edit-tab:hover{color:var(--text-primary);background:var(--bg-card-hover)}.edit-tab.active{background:var(--accent);color:#fff;font-weight:600}.edit-library{min-height:200px}.edit-empty{text-align:center;padding:60px 20px;color:var(--text-muted)}.edit-empty p{margin-bottom:16px}.edit-list{display:flex;flex-direction:column;gap:6px}.edit-item{display:flex;align-items:center;gap:16px;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .15s}.edit-item:hover{border-color:var(--border-light);background:var(--bg-card-hover)}.edit-item-info{flex:1;min-width:0}.edit-item-title{font-size:15px;font-weight:600;margin-bottom:2px}.edit-item-detail{font-size:12px;color:var(--text-muted)}.edit-item-desc{font-size:12px;color:var(--text-secondary);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:500px}.edit-item-actions{display:flex;gap:6px;flex-shrink:0}.edit-delete-btn:hover{color:var(--danger)!important;border-color:var(--danger)!important}.edit-modal{max-width:560px}.thumb-edit-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.thumb-path{font-size:12px;color:var(--text-muted);font-family:monospace;background:var(--bg-input);padding:4px 8px;border-radius:4px}.thumb-uploading{font-size:12px;color:var(--accent);font-weight:500}.edit-media-page .s3-browser{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.edit-media-page .s3-path{display:flex;align-items:center;gap:8px;padding:14px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap}.edit-media-page .s3-current-path{font-size:13px;color:var(--text-muted);font-family:monospace}.edit-media-page .s3-empty{padding:40px;text-align:center;color:var(--text-muted);font-size:15px}.edit-media-page .s3-list{max-height:500px;overflow-y:auto}.edit-media-page .s3-item{display:flex;align-items:center;gap:12px;padding:12px 20px;border-bottom:1px solid var(--border);cursor:default;transition:background .15s}.edit-media-page .s3-item:last-child{border-bottom:none}.edit-media-page .s3-folder{cursor:pointer}.edit-media-page .s3-folder:hover{background:var(--bg-card-hover)}.edit-media-page .s3-media{cursor:pointer}.edit-media-page .s3-media:hover{background:var(--accent-soft)}.edit-media-page .s3-item-icon{flex-shrink:0;display:flex;align-items:center}.edit-media-page .s3-item-name{flex:1;font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edit-media-page .s3-item-size{font-size:12px;color:var(--text-muted);flex-shrink:0}.edit-media-page .selected-file-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--accent-soft);border-radius:var(--radius);margin-bottom:20px;font-size:14px;font-weight:600;word-break:break-all}@media (max-width: 640px){.edit-item{flex-direction:column;align-items:flex-start;gap:10px}.edit-item-actions{width:100%}.edit-tabs{flex-direction:column}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.container{max-width:1400px;margin:0 auto;padding:0 4%}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border:none;border-radius:var(--radius);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:scale(1.02)}.btn-secondary{background:var(--bg-input);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-light)}.btn-outline{background:transparent;color:var(--text-primary);border:1px solid var(--border-light)}.btn-outline:hover{background:var(--bg-card)}.btn-sm{padding:6px 14px;font-size:13px}.btn-icon{width:40px;height:40px;padding:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#ffffff1a;border:1px solid var(--border);color:var(--text-primary);cursor:pointer;transition:all .2s}.btn-icon:hover{background:#fff3}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-input{width:100%;padding:10px 14px;background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border);border-radius:var(--radius);font-size:14px;outline:none;transition:border-color .2s}.form-input:focus{border-color:var(--accent)}.form-input::placeholder{color:var(--text-muted)}select.form-input{cursor:pointer}textarea.form-input{resize:vertical;min-height:80px}.tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:600;background:var(--accent-soft);color:var(--accent)}.tag-removable{cursor:pointer}.tag-removable:hover{opacity:.7}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9000;background:var(--bg-overlay);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s}.modal{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;padding:28px;animation:slideUp .25s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-title{font-size:20px;font-weight:700}.modal-close{background:none;border:none;color:var(--text-muted);font-size:24px;cursor:pointer;padding:4px;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.toast-container{position:fixed;top:80px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius);color:#fff;font-size:14px;font-weight:500;box-shadow:var(--shadow);animation:slideIn .3s ease}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-info{background:var(--accent)}@keyframes slideIn{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;min-height:300px}.progress-bar{width:100%;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--accent);transition:width .3s;border-radius:2px}
