.dashboard{padding:32px;max-width:1400px;margin:0 auto;flex:1}.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:36px}.dashboard-header h1{font-size:22px;font-weight:700;color:var(--white)}.dashboard-header p{font-size:13px;color:var(--text-muted);margin-top:2px}.presentations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.presentation-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-lg);padding:24px;cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden}.presentation-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--teal-muted));opacity:0;transition:opacity var(--transition)}.presentation-card:hover{border-color:var(--teal-muted);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.presentation-card:hover:before{opacity:1}.card-title{font-size:16px;font-weight:700;color:var(--white);margin-bottom:6px;line-height:1.4}.card-description{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:16px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-meta{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}.card-meta-item{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-dim)}.card-meta-item svg{width:13px;height:13px}.card-actions{display:flex;gap:8px;border-top:1px solid var(--panel-border);padding-top:16px;margin-top:auto}.card-actions .btn{flex:1;justify-content:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#041013d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}.modal{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:520px;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-header h2{font-size:18px;font-weight:700}.modal-close{color:var(--text-muted);font-size:20px;line-height:1;padding:4px;border-radius:var(--radius-sm);transition:all var(--transition)}.modal-close:hover{color:var(--white);background:var(--panel-light)}.modal-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.dashboard-empty{grid-column:1 / -1}.editor-layout{display:grid;grid-template-columns:260px 1fr 300px;grid-template-rows:60px 1fr;height:100vh;overflow:hidden}.editor-topbar{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;padding:0 20px;background:var(--bg-deep);border-bottom:1px solid var(--panel-border);gap:16px}.editor-topbar-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.editor-topbar-center,.editor-topbar-right{display:flex;align-items:center;gap:10px}.editor-title-input{background:transparent;border:none;font-size:15px;font-weight:700;color:var(--white);padding:4px 8px;border-radius:var(--radius-sm);flex:1;min-width:0;transition:background var(--transition)}.editor-title-input:hover{background:var(--panel)}.editor-title-input:focus{background:var(--panel);outline:none;border-color:transparent}.scene-sidebar{background:var(--bg-deep);border-right:1px solid var(--panel-border);display:flex;flex-direction:column;overflow:hidden}.scene-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--panel-border);flex-shrink:0}.scene-sidebar-header h3{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.scene-list{flex:1;overflow-y:auto;padding:8px}.scene-item{display:flex;align-items:center;gap:8px;padding:10px 10px 10px 12px;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);position:relative;margin-bottom:2px;border:1px solid transparent}.scene-item:hover{background:var(--panel)}.scene-item.active{background:var(--panel);border-color:var(--teal-muted)}.scene-item-number{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--bg-deep);border:1px solid var(--panel-border);border-radius:var(--radius-sm);font-size:11px;font-weight:700;color:var(--text-muted);flex-shrink:0}.scene-item.active .scene-item-number{background:var(--teal-dim);border-color:var(--teal-muted);color:var(--teal)}.scene-item-content{flex:1;min-width:0}.scene-item-title{font-size:13px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-item-subtitle{font-size:11px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.scene-item-actions{display:none;gap:2px;flex-shrink:0}.scene-item:hover .scene-item-actions{display:flex}.scene-item-btn{padding:3px 5px;font-size:11px;border-radius:4px;color:var(--text-muted);transition:all var(--transition)}.scene-item-btn:hover{color:var(--white);background:var(--panel-light)}.scene-item-btn.danger:hover{color:var(--danger);background:var(--danger-dim)}.editor-canvas{display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.canvas-area{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;overflow:auto}.scene-preview{position:relative;width:100%;max-width:900px;aspect-ratio:16 / 9;background:var(--bg-deep);border-radius:var(--radius-lg);border:1px solid var(--panel-border);overflow:hidden;box-shadow:var(--shadow-lg);flex-shrink:0}.scene-preview-bg{position:absolute;top:0;right:0;bottom:0;left:0;object-fit:cover;width:100%;height:100%}.scene-preview-bg video{width:100%;height:100%;object-fit:cover}.scene-preview-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#0410131a,#041013bf);display:flex;flex-direction:column;justify-content:flex-end;padding:36px}.scene-preview-title{font-size:clamp(18px,2.5vw,32px);font-weight:800;color:var(--white);line-height:1.2;margin-bottom:8px;text-shadow:0 2px 8px rgba(0,0,0,.5)}.scene-preview-subtitle{font-size:clamp(12px,1.5vw,18px);color:var(--teal);font-weight:600;margin-bottom:12px;text-shadow:0 1px 4px rgba(0,0,0,.5)}.scene-preview-body{font-size:clamp(10px,1.2vw,15px);color:var(--white-muted);line-height:1.5;text-shadow:0 1px 4px rgba(0,0,0,.5)}.scene-preview-assets{position:absolute;top:16px;right:16px;display:flex;gap:8px;flex-wrap:wrap;max-width:45%;justify-content:flex-end}.scene-preview-asset-thumb{width:80px;height:60px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid rgba(255,255,255,.15);background:#041013b3;display:flex;align-items:center;justify-content:center;font-size:20px}.scene-preview-asset-thumb img{width:100%;height:100%;object-fit:cover}.scene-preview-empty{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-dim)}.scene-preview-empty-icon{font-size:48px;opacity:.3}.editor-panel{background:var(--bg-deep);border-left:1px solid var(--panel-border);display:flex;flex-direction:column;overflow:hidden}.editor-panel-tabs{display:flex;border-bottom:1px solid var(--panel-border);flex-shrink:0}.editor-panel-tab{flex:1;padding:12px 8px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:center;border-bottom:2px solid transparent;transition:all var(--transition);cursor:pointer}.editor-panel-tab.active{color:var(--teal);border-bottom-color:var(--teal)}.editor-panel-tab:hover:not(.active){color:var(--white)}.editor-panel-body{flex:1;overflow-y:auto;padding:16px}.editor-panel-body .form-group{margin-bottom:14px}.editor-panel-section{margin-bottom:20px}.editor-panel-section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;display:flex;align-items:center;gap:8px}.editor-panel-section-title:after{content:"";flex:1;height:1px;background:var(--panel-border)}.asset-picker-trigger{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-deep);border:1px dashed var(--panel-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);width:100%}.asset-picker-trigger:hover{border-color:var(--teal-muted);background:var(--teal-dim)}.asset-picker-preview{width:48px;height:36px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0;background:var(--panel);display:flex;align-items:center;justify-content:center}.asset-picker-preview img{width:100%;height:100%;object-fit:cover}.asset-picker-info{flex:1;min-width:0;text-align:left}.asset-picker-name{font-size:12px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.asset-picker-type{font-size:11px;color:var(--text-muted)}.clear-asset-btn{color:var(--text-dim);font-size:16px;padding:2px;border-radius:3px}.clear-asset-btn:hover{color:var(--danger)}.asset-picker-modal .modal{max-width:720px;max-height:80vh;display:flex;flex-direction:column}.asset-picker-modal .modal-body{flex:1;overflow-y:auto;margin-top:16px}.asset-picker-filter{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.asset-picker-filter-btn{padding:5px 14px;border-radius:99px;font-size:12px;font-weight:600;color:var(--text-muted);background:var(--panel);border:1px solid var(--panel-border);transition:all var(--transition);cursor:pointer}.asset-picker-filter-btn.active,.asset-picker-filter-btn:hover{color:var(--teal);border-color:var(--teal-muted);background:var(--teal-dim)}.picker-upload-strip{display:flex;align-items:center;gap:10px;padding:9px 14px;border:1px dashed var(--panel-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:var(--bg-deep);flex-shrink:0}.picker-upload-strip:hover,.picker-upload-strip.drag-over{border-color:var(--teal-muted);background:var(--teal-dim)}.picker-upload-strip.uploading{cursor:default;pointer-events:none;border-color:var(--teal-muted);background:var(--teal-dim)}.picker-upload-progress-bar{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.picker-upload-progress-fill{height:100%;background:var(--teal);transition:width .25s ease;border-radius:2px}.asset-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.asset-picker-item{border-radius:var(--radius-md);overflow:hidden;border:2px solid var(--panel-border);cursor:pointer;transition:all var(--transition);background:var(--panel)}.asset-picker-item:hover{border-color:var(--teal-muted)}.asset-picker-item.selected{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal-dim)}.asset-picker-item-thumb{height:72px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-deep)}.asset-picker-item-thumb img{width:100%;height:100%;object-fit:cover}.asset-picker-item-thumb .file-icon{font-size:28px}.asset-picker-item-label{padding:6px 8px;font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attached-assets-list{display:flex;flex-direction:column;gap:6px}.attached-asset-item{display:flex;align-items:center;gap:8px;padding:7px 10px;background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-sm);font-size:12px}.attached-asset-icon{font-size:16px;flex-shrink:0}.attached-asset-name{flex:1;min-width:0;color:var(--white-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attached-asset-remove{color:var(--text-dim);font-size:14px;padding:2px 4px;border-radius:3px}.attached-asset-remove:hover{color:var(--danger);background:var(--danger-dim)}.no-scene-selected{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px;color:var(--text-dim);padding:40px;text-align:center}.no-scene-selected .icon{font-size:48px;opacity:.3}.presentation-mode{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;display:flex;flex-direction:column;z-index:100;overflow:hidden;cursor:none}.presentation-mode.cursor-visible{cursor:default}.presentation-stage-wrapper{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden}.presentation-stage{position:relative;width:100%;max-height:100vh;aspect-ratio:16 / 9;overflow:hidden;flex-shrink:0}@supports not (aspect-ratio: 16 / 9){.presentation-stage{width:min(100vw,calc(100vh * 16 / 9));height:min(100vh,56.25vw)}}.scene-bg{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:#000}.scene-bg img{width:100%;height:100%;object-fit:contain;display:block}.scene-bg video{width:100%;height:100%;object-fit:contain;display:block}.scene-bg-fallback{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,#0f2027,#203a43,#2c5364)}.scene-gradient-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to bottom,#04101300,#04101340 55%,#041013b8);pointer-events:none}.scene-content{position:relative;z-index:10;display:flex;flex-direction:column;justify-content:flex-end;padding:clamp(32px,5vw,80px);width:100%;max-width:1100px;margin:0 auto}.scene-title{font-size:clamp(24px,4vw,56px);font-weight:800;color:var(--white);line-height:1.15;margin-bottom:12px;text-shadow:0 2px 16px rgba(0,0,0,.6)}.scene-subtitle{font-size:clamp(14px,1.8vw,24px);color:var(--teal);font-weight:600;margin-bottom:16px;text-shadow:0 1px 8px rgba(0,0,0,.5)}.scene-body{font-size:clamp(13px,1.4vw,20px);color:var(--white-muted);line-height:1.65;max-width:700px;text-shadow:0 1px 6px rgba(0,0,0,.5);white-space:pre-line}.scene-overlay-text{position:absolute;top:40px;right:clamp(20px,4vw,60px);background:var(--orange-dim);border:1px solid rgba(255,107,26,.3);color:var(--orange);padding:8px 20px;border-radius:99px;font-size:clamp(12px,1.2vw,16px);font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.scene-media-assets{position:absolute;top:clamp(16px,3vw,48px);right:clamp(16px,4vw,60px);display:flex;gap:12px;flex-direction:column;max-width:40%;z-index:10}.scene-media-item{border-radius:var(--radius-md);overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-md);max-height:220px}.scene-media-item img{display:block;max-width:100%;max-height:200px;object-fit:contain;background:#04101399}.scene-media-item video{display:block;max-width:100%;max-height:200px}.captions-bar{position:absolute;bottom:48px;left:50%;transform:translate(-50%);background:#041013d9;border:1px solid rgba(24,213,195,.15);color:var(--white);padding:10px 24px;border-radius:99px;font-size:clamp(13px,1.4vw,18px);max-width:80%;text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:20}.speaker-notes-overlay{position:absolute;bottom:90px;right:clamp(16px,3vw,48px);width:340px;max-height:200px;background:#041013e6;border:1px solid var(--teal-muted);border-radius:var(--radius-md);padding:14px 16px;z-index:30;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);overflow-y:auto}.speaker-notes-overlay-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--teal);margin-bottom:8px}.speaker-notes-overlay-text{font-size:13px;color:var(--white-muted);line-height:1.6}.progress-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff14;z-index:20}.progress-fill{height:100%;background:linear-gradient(90deg,var(--teal),var(--teal-muted));transition:width .4s ease}.presentation-controls{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:25}.controls-top{position:absolute;top:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;pointer-events:all}.controls-bottom{position:absolute;bottom:18px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;pointer-events:all}.control-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#09272dd9;border:1px solid rgba(20,58,66,.8);border-radius:99px;color:var(--white-muted);font-size:12px;font-weight:600;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition);cursor:pointer}.control-btn:hover{color:var(--white);border-color:var(--teal-muted);background:#0e3540e6}.control-btn.active{color:var(--teal);border-color:var(--teal-muted)}.control-btn svg,.control-btn .icon{width:14px;height:14px;font-size:14px}.scene-counter{font-size:12px;font-weight:700;color:var(--white-muted);padding:8px 14px;background:#09272db3;border-radius:99px;border:1px solid rgba(20,58,66,.6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.nav-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#09272dcc;border:1px solid rgba(20,58,66,.8);color:var(--white-muted);font-size:22px;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition);pointer-events:all}.nav-arrow:hover{color:var(--white);border-color:var(--teal-muted);background:#0e3540e6}.nav-arrow.prev{left:20px}.nav-arrow.next{right:20px}.nav-arrow:disabled{opacity:.2;cursor:not-allowed}.scene-transition-enter{opacity:0}.scene-transition-enter-active{opacity:1;transition:opacity .4s ease}.scene-transition-exit{opacity:1}.scene-transition-exit-active{opacity:0;transition:opacity .25s ease}.shortcuts-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#041013f2;border:1px solid var(--panel-border);border-radius:var(--radius-xl);padding:28px 36px;z-index:40;min-width:320px;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.shortcuts-hint h3{font-size:14px;font-weight:700;color:var(--teal);margin-bottom:16px;text-transform:uppercase;letter-spacing:.06em}.shortcut-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:13px}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:2px 8px;background:var(--panel);border:1px solid var(--panel-border);border-radius:4px;font-family:monospace;font-size:12px;color:var(--white)}.presentation-entry{min-height:100vh;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px}.presentation-entry-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-xl);padding:48px;max-width:600px;width:100%;text-align:center}.presentation-entry-card h1{font-size:26px;font-weight:800;margin-bottom:10px}.presentation-entry-card p{color:var(--text-muted);margin-bottom:32px}.presentation-entry-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}.presentation-entry-meta{display:flex;gap:20px;justify-content:center;margin-bottom:28px;flex-wrap:wrap}.presentation-entry-meta-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-muted)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: transparent;--bg-deep: rgba(10, 24, 32, .6);--panel: rgba(15, 38, 52, .72);--panel-light: rgba(25, 58, 78, .8);--panel-border: rgba(44, 83, 100, .55);--teal: #18d5c3;--teal-muted: #0e8f89;--teal-dim: rgba(24, 213, 195, .12);--orange: #ff6b1a;--orange-dim: rgba(255, 107, 26, .15);--white: #f5f7f7;--white-muted: rgba(245, 247, 247, .7);--text-muted: #9fb6b8;--text-dim: #5c7e82;--danger: #e53e3e;--danger-dim: rgba(229, 62, 62, .15);--success: #38a169;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 4px rgba(0,0,0,.4);--shadow-md: 0 4px 16px rgba(0,0,0,.5);--shadow-lg: 0 8px 32px rgba(0,0,0,.6);--transition: .18s ease;--font: "Gabarito", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html,body{height:100%;background:linear-gradient(90deg,#0f2027,#203a43,#2c5364);background-attachment:fixed;color:var(--white);font-family:var(--font);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%;display:flex;flex-direction:column}a{color:var(--teal);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font);cursor:pointer;border:none;background:none;outline:none}input,textarea,select{font-family:var(--font);background:var(--bg-deep);border:1px solid var(--panel-border);color:var(--white);border-radius:var(--radius-sm);padding:8px 12px;font-size:14px;width:100%;outline:none;transition:border-color var(--transition)}input:focus,textarea:focus,select:focus{border-color:var(--teal-muted)}input::placeholder,textarea::placeholder{color:var(--text-dim)}select option{background:var(--panel)}textarea{resize:vertical;min-height:72px}label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;transition:all var(--transition);line-height:1;white-space:nowrap}.btn-primary{background:var(--teal);color:var(--bg)}.btn-primary:hover{background:#21f0dc;box-shadow:0 0 16px #18d5c34d}.btn-secondary{background:var(--panel);color:var(--white);border:1px solid var(--panel-border)}.btn-secondary:hover{background:var(--panel-light);border-color:var(--teal-muted)}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid transparent}.btn-ghost:hover{color:var(--white);background:var(--panel)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(229,62,62,.25)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-icon{padding:7px;border-radius:var(--radius-sm);font-size:16px}.btn-sm{padding:6px 12px;font-size:13px}.btn-lg{padding:12px 28px;font-size:15px;border-radius:var(--radius-md)}.btn:disabled{opacity:.45;cursor:not-allowed}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-deep)}::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--teal-muted)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:99px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.badge-teal{background:var(--teal-dim);color:var(--teal)}.badge-orange{background:var(--orange-dim);color:var(--orange)}.badge-dim{background:#ffffff0f;color:var(--text-muted)}.divider{border:none;border-top:1px solid var(--panel-border);margin:16px 0}.spinner{width:20px;height:20px;border:2px solid var(--panel-border);border-top-color:var(--teal);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}.spinner-lg{width:36px;height:36px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-group{margin-bottom:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.toast{position:fixed;bottom:24px;right:24px;background:var(--panel);border:1px solid var(--panel-border);border-left:3px solid var(--teal);color:var(--white);padding:12px 20px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:14px;z-index:9999;animation:slideIn .2s ease}.toast-error{border-left-color:var(--danger)}@keyframes slideIn{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-nav{display:flex;align-items:center;justify-content:space-between;padding:0 28px;height:58px;background:var(--bg-deep);border-bottom:1px solid var(--panel-border);flex-shrink:0}.app-nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none}.app-nav-links{display:flex;gap:4px}.app-nav-link{padding:6px 14px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:all var(--transition)}.app-nav-link:hover{color:var(--white);background:var(--panel);text-decoration:none}.app-nav-link.active{color:var(--teal);background:var(--teal-dim)}.app-nav-user{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted)}.app-nav-avatar{width:28px;height:28px;border-radius:50%;background:var(--teal-dim);border:1px solid var(--teal-muted);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--teal)}.app-main{flex:1;display:flex;flex-direction:column}.asset-library{padding:32px;max-width:1400px;margin:0 auto;width:100%}.asset-library-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}.asset-library-header h1{font-size:22px;font-weight:700}.asset-library-filters{display:flex;gap:10px;margin-bottom:24px;flex-wrap:wrap;align-items:center}.asset-library-search{flex:1;min-width:200px;max-width:320px}.asset-type-filters{display:flex;gap:6px}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px}.asset-card{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-md);overflow:hidden;cursor:default;transition:all var(--transition)}.asset-card:hover{border-color:var(--teal-muted);transform:translateY(-1px)}.asset-card-thumb{height:120px;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-deep);position:relative}.asset-card-thumb img{width:100%;height:100%;object-fit:cover}.asset-card-thumb video{width:100%;height:100%;object-fit:cover}.asset-card-file-icon{font-size:40px;opacity:.5}.asset-card-type-badge{position:absolute;top:8px;left:8px}.asset-card-info{padding:10px 12px}.asset-card-name{font-size:12px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.asset-card-meta{display:flex;justify-content:space-between;align-items:center}.asset-card-size{font-size:11px;color:var(--text-dim)}.asset-card-delete{color:var(--text-dim);font-size:13px;padding:2px 4px;border-radius:3px}.asset-card-delete:hover{color:var(--danger);background:var(--danger-dim)}.upload-zone{border:2px dashed var(--panel-border);border-radius:var(--radius-xl);padding:40px;text-align:center;cursor:pointer;transition:all var(--transition);margin-bottom:28px}.upload-zone:hover,.upload-zone.drag-over{border-color:var(--teal-muted);background:var(--teal-dim)}.upload-zone.uploading{border-color:var(--teal-muted);background:var(--teal-dim);pointer-events:none}.upload-zone-progress-bar{width:60%;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden;margin-top:12px}.upload-zone-progress-fill{height:100%;background:var(--teal);transition:width .3s ease;border-radius:2px}.upload-zone-icon{font-size:40px;margin-bottom:12px;opacity:.5}.upload-zone h3{font-size:15px;font-weight:700;margin-bottom:4px}.upload-zone p{font-size:13px;color:var(--text-muted)}.upload-progress{margin-top:16px;display:flex;flex-direction:column;gap:8px}.upload-progress-item{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-sm);padding:10px 14px;display:flex;align-items:center;gap:10px}.upload-progress-bar{flex:1;height:4px;background:var(--panel-border);border-radius:2px;overflow:hidden}.upload-progress-fill{height:100%;background:var(--teal);transition:width .3s ease}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 40px;text-align:center;color:var(--text-dim)}.empty-state-icon{font-size:56px;margin-bottom:16px;opacity:.25}.empty-state h3{font-size:16px;font-weight:700;color:var(--text-muted);margin-bottom:6px}.empty-state p{font-size:13px;color:var(--text-dim);margin-bottom:20px;max-width:300px;line-height:1.5}.loading-screen{display:flex;align-items:center;justify-content:center;flex:1;padding:80px}.media-renderer{display:flex;align-items:center;justify-content:center;width:100%;height:100%}.media-renderer img{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-sm)}.media-renderer video{max-width:100%;max-height:100%;border-radius:var(--radius-sm)}.media-renderer audio{width:100%}.media-renderer-pdf{width:100%;height:100%;min-height:400px;border-radius:var(--radius-sm);border:none}.media-renderer-file{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px;background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius-md);text-decoration:none;color:var(--text-muted);transition:all var(--transition)}.media-renderer-file:hover{border-color:var(--teal-muted);color:var(--teal);text-decoration:none}.media-renderer-file-icon{font-size:36px}.media-renderer-file-name{font-size:12px;font-weight:600;max-width:140px;text-align:center;word-break:break-all}
