@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=Space+Mono:wght@400;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f11;--bg-surface: #161619;--bg-hover: #1e1e22;--bg-active: #252529;--border: #2a2a2f;--border-hi: #3a3a42;--text: #e8e8ed;--text-muted: #8888a0;--text-dim: #555560;--accent: #6610f2;--accent-hi: #7c3aed;--accent-dim: #4c0db8;--danger: #e05550;--danger-hi: #f06560;--success: #45c870;--radius-sm: 6px;--radius: 10px;--radius-lg: 16px;--shadow: 0 2px 12px rgba(0,0,0,.4);--shadow-lg: 0 8px 40px rgba(0,0,0,.7);--transition: .15s ease;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "Space Mono", monospace}html{font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hi)}button{cursor:pointer;font-family:inherit}.page{min-height:100vh;display:flex;flex-direction:column;max-width:1440px;margin:0 auto;padding:0 24px 64px}.gallery-page,.manage-page{padding-top:20px}.page-header{display:flex;align-items:center;justify-content:flex-end;padding:0 0 16px;margin-bottom:4px;gap:16px;flex-wrap:wrap}.page-header__left{display:flex;align-items:center;gap:32px}.page-header__actions{display:flex;gap:10px;align-items:center}.page-title{display:flex;align-items:center;gap:10px;font-size:1.35rem;font-weight:600;letter-spacing:-.02em;color:var(--text)}.page-nav{display:flex;gap:4px}.nav-link{padding:6px 14px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--text-muted);transition:color var(--transition),background var(--transition)}.nav-link:hover{color:var(--text);background:var(--bg-hover)}.nav-link--active{color:var(--accent)!important;background:#6610f21a!important}.page-body{flex:1}.section{margin-bottom:40px}.section-title{font-size:.75rem;font-family:var(--font-mono);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted);margin-bottom:14px;display:flex;align-items:center;gap:10px}.section-count{background:var(--bg-active);border:1px solid var(--border);border-radius:20px;padding:1px 8px;font-size:.7rem;color:var(--text-dim)}.section-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px}.section-toolbar .section-title{margin-bottom:0}.section-toolbar__actions{display:flex;align-items:center;gap:8px}.selection-count{font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;border:none;transition:background var(--transition),color var(--transition),transform var(--transition)}.btn:active{transform:scale(.97)}.btn--primary{background:var(--accent);color:#000}.btn--primary:hover{background:var(--accent-hi)}.btn--ghost{background:var(--bg-surface);color:var(--text-muted);border:1px solid var(--border)}.btn--ghost:hover{background:var(--bg-hover);color:var(--text)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover{background:var(--danger-hi)}.btn--sm{padding:5px 12px;font-size:.8rem}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);font-size:.9rem;transition:background var(--transition),color var(--transition)}.icon-btn:hover{background:var(--bg-hover);color:var(--text)}.icon-btn--danger:hover{background:#e0555026;color:var(--danger)}.icon-btn--sm{width:28px;height:28px;font-size:.8rem}.view-toggle{display:flex;gap:2px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.view-btn{display:flex;align-items:center;justify-content:center;width:34px;height:30px;border:none;border-radius:5px;background:transparent;color:var(--text-muted);transition:background var(--transition),color var(--transition)}.view-btn:hover{color:var(--text);background:var(--bg-hover)}.view-btn--active{background:var(--accent);color:#000}.breadcrumb-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px;flex-wrap:wrap}.breadcrumb-bar .breadcrumb{margin-bottom:0;flex:1;min-width:0}.breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:4px;margin-bottom:20px;font-size:.8rem;font-family:var(--font-mono)}.breadcrumb-item{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-muted);cursor:pointer;transition:color var(--transition),background var(--transition)}.breadcrumb-item:hover{color:var(--accent);background:#6610f214}.breadcrumb-home{color:var(--text-muted)}.breadcrumb-current{color:var(--text);font-weight:700;cursor:default}.breadcrumb-current:hover{background:transparent;color:var(--text)}.breadcrumb-separator{color:var(--text-dim)}.folder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:8px}.folder-card{position:relative;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color var(--transition),background var(--transition)}.folder-card:hover{border-color:var(--border-hi);background:var(--bg-hover)}.folder-card__body{display:flex;align-items:center;gap:10px;padding:12px 14px;width:100%;cursor:pointer;min-width:0}.folder-card__icon{width:20px;height:20px;flex-shrink:0;color:var(--accent)}.folder-card__name{font-size:.85rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.folder-card__actions{position:absolute;top:50%;right:6px;transform:translateY(-50%);display:flex;gap:2px;opacity:0;transition:opacity var(--transition);background:var(--bg-hover);border-radius:var(--radius-sm);padding:2px}.folder-card:hover .folder-card__actions{opacity:1}.folder-card--renaming{padding:8px 12px;border-color:var(--accent)}.media-grid--grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}.media-grid--masonry{columns:4;column-gap:12px}@media (max-width: 1200px){.media-grid--masonry{columns:3}}@media (max-width: 800px){.media-grid--masonry{columns:2}}@media (max-width: 500px){.media-grid--masonry{columns:1}}.media-grid--list{display:flex;flex-direction:column;gap:6px}.media-tile{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition)}.media-tile:hover{border-color:var(--border-hi);transform:translateY(-2px);box-shadow:var(--shadow)}.media-tile--grid,.media-tile--masonry{display:flex;flex-direction:column;break-inside:avoid;margin-bottom:12px}.media-tile--masonry{margin-bottom:12px}.media-tile__image-wrap{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--bg-active)}.media-tile--masonry .media-tile__image-wrap{aspect-ratio:unset;min-height:120px}.media-tile__img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}.media-tile:hover .media-tile__img{transform:scale(1.04)}.media-tile__play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000059}.media-tile__placeholder{width:100%;height:100%;min-height:120px;display:flex;align-items:center;justify-content:center;background:var(--bg-active);color:var(--text-dim);font-size:2rem}.media-tile__skeleton{width:100%;height:100%;background:linear-gradient(90deg,var(--bg-active) 25%,var(--bg-hover) 50%,var(--bg-active) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.media-tile__err-icon{font-size:1.4rem;color:var(--danger)}.media-tile__footer{padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:8px}.media-tile__name{font-size:.8rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.media-tile__size{font-size:.7rem;color:var(--text-dim);font-family:var(--font-mono);flex-shrink:0}.media-tile--list{display:flex;align-items:center;gap:12px;padding:10px 14px}.media-tile__thumb-sm{width:48px;height:48px;border-radius:6px;overflow:hidden;flex-shrink:0;background:var(--bg-active);display:flex;align-items:center;justify-content:center}.media-tile__thumb-sm img{width:100%;height:100%;object-fit:cover}.media-tile__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.media-tile__meta{font-size:.72rem;color:var(--text-dim);font-family:var(--font-mono)}.media-tile__badge{font-size:.65rem;font-family:var(--font-mono);font-weight:700;letter-spacing:.05em;background:#e8a03026;color:var(--accent);border:1px solid rgba(232,160,48,.3);border-radius:4px;padding:2px 6px}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);padding:36px 24px;text-align:center;cursor:pointer;transition:border-color var(--transition),background var(--transition);margin-bottom:24px}.dropzone:hover,.dropzone--active{border-color:var(--accent);background:#6610f20a}.dropzone--uploading{cursor:default;border-color:var(--accent-dim)}.dropzone__input{display:none}.dropzone__content{display:flex;flex-direction:column;align-items:center;gap:10px}.dropzone__icon{width:40px;height:40px;color:var(--text-dim)}.dropzone__text{font-size:.95rem;color:var(--text-muted);font-weight:500}.dropzone__hint{font-size:.78rem;color:var(--text-dim);font-family:var(--font-mono)}.dropzone__spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.upload-progress{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:20px}.upload-progress__header{display:flex;justify-content:space-between;font-size:.82rem;color:var(--text-muted);margin-bottom:8px}.upload-progress__counter{color:var(--text-dim);font-family:var(--font-mono);font-size:.78rem}.upload-progress__failed{color:var(--danger)}.upload-progress__bar{height:4px;background:var(--bg-active);border-radius:2px;overflow:hidden;margin-bottom:10px;position:relative}.upload-progress__fill{height:100%;background:var(--accent);border-radius:2px;transition:width .2s ease}.upload-progress__fill--failed{background:var(--danger);position:absolute;right:0;top:0}.upload-progress__file{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-dim);font-family:var(--font-mono);padding:2px 0}.upload-progress__file--failed{color:var(--danger)}.upload-progress__file--more{color:var(--text-dim);font-style:italic;justify-content:flex-start}.upload-progress__file-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.upload-progress__file-pct{flex-shrink:0;margin-left:12px}.upload-progress__active{border-top:1px solid var(--border);padding-top:8px;margin-top:4px}.file-table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius)}.file-table{width:100%;border-collapse:collapse;font-size:.875rem}.file-table thead tr{border-bottom:1px solid var(--border)}.file-table th{padding:10px 14px;text-align:left;font-size:.72rem;font-family:var(--font-mono);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim);background:var(--bg-surface);white-space:nowrap}.file-row td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle}.file-row:last-child td{border-bottom:none}.file-row{background:transparent;transition:background var(--transition)}.file-row:hover{background:var(--bg-hover)}.file-row--selected{background:#6610f20f}.file-row--selected:hover{background:#6610f21a}.file-row__check{width:40px}.file-row__icon{width:36px;font-size:1.1rem}.file-row__name{max-width:280px}.file-row__name span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.file-row__name-link{color:var(--text);cursor:pointer;transition:color var(--transition);text-decoration:none}.file-row__name-link:hover{color:var(--accent);text-decoration:underline}.file-row__size{font-family:var(--font-mono);font-size:.78rem;color:var(--text-muted);white-space:nowrap}.file-row__date{font-family:var(--font-mono);font-size:.78rem;color:var(--text-dim);white-space:nowrap}.file-row__actions{width:80px}.file-row__actions{display:flex;gap:4px;align-items:center}.inline-rename{background:var(--bg-active);border:1px solid var(--accent);border-radius:var(--radius-sm);color:var(--text);padding:4px 8px;font-size:.85rem;font-family:inherit;outline:none;width:100%}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal{background:var(--bg-surface);border:1px solid var(--border-hi);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg)}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal__title{font-size:1.1rem;font-weight:600}.modal__close{width:32px;height:32px;border:none;background:transparent;color:var(--text-muted);font-size:1rem;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition)}.modal__close:hover{background:var(--bg-hover);color:var(--text)}.modal__body{padding:20px 24px}.modal__hint{font-size:.82rem;color:var(--text-muted);margin-bottom:16px;font-family:var(--font-mono)}.modal__footer{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.8rem;font-weight:500;color:var(--text-muted)}.form-input{background:var(--bg-active);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:9px 12px;font-size:.9rem;font-family:inherit;outline:none;transition:border-color var(--transition)}.form-input:focus{border-color:var(--accent)}.form-input--error{border-color:var(--danger)}.form-error{font-size:.78rem;color:var(--danger)}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.lightbox-container{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;gap:14px}.lightbox-close{position:absolute;top:-44px;right:0;width:36px;height:36px;border:1px solid var(--border-hi);border-radius:50%;background:var(--bg-surface);color:var(--text);font-size:1rem;z-index:10;transition:background var(--transition)}.lightbox-close:hover{background:var(--bg-active)}.lightbox-media{max-width:88vw;max-height:80vh;object-fit:contain;border-radius:var(--radius);box-shadow:var(--shadow-lg);display:block}.lightbox-filename{font-size:.8rem;font-family:var(--font-mono);color:var(--text-muted);text-align:center}.lightbox-loading,.lightbox-error{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);font-size:.9rem}.lightbox-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.error-banner{display:flex;align-items:center;gap:10px;background:#e055501a;border:1px solid rgba(224,85,80,.3);border-radius:var(--radius);padding:12px 16px;margin-bottom:20px;font-size:.875rem}.error-banner__icon{color:var(--danger);font-size:1.1rem;flex-shrink:0}.error-banner__message{flex:1;color:var(--text)}.error-banner__close{width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);border-radius:var(--radius-sm);font-size:.9rem;transition:background var(--transition)}.error-banner__close:hover{background:#e0555033;color:var(--danger)}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;gap:14px;color:var(--text-muted);font-size:.9rem;text-align:center}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-hi);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}@media (max-width: 768px){.page{padding:0 16px 48px}.manage-page{padding-top:16px}.page-header{padding:16px 0 18px}.page-header__left{flex-direction:column;align-items:flex-start;gap:10px}.media-grid--grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.folder-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:.72rem;font-family:var(--font-mono);font-weight:400;background:#6610f226;color:var(--accent-hi);border:1px solid rgba(102,16,242,.3);white-space:nowrap;line-height:1.6}.tag--sm{padding:1px 6px;font-size:.65rem}.tag--more{background:var(--bg-active);color:var(--text-dim);border-color:var(--border)}.tag__remove{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border:none;background:transparent;color:inherit;font-size:.85rem;line-height:1;cursor:pointer;opacity:.7;border-radius:50%;transition:opacity var(--transition),background var(--transition);padding:0}.tag__remove:hover{opacity:1;background:#ffffff26}.tag-editor{display:flex;flex-wrap:wrap;align-items:center;gap:4px;min-height:30px;padding:3px 6px;background:var(--bg-active);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:text;transition:border-color var(--transition)}.tag-editor:focus-within{border-color:var(--accent)}.tag-editor__input{border:none;background:transparent;color:var(--text);font-size:.78rem;font-family:var(--font-mono);outline:none;min-width:80px;flex:1;padding:0 2px}.tag-editor__input::placeholder{color:var(--text-dim)}.tag-editor__input:disabled{cursor:not-allowed;opacity:.5}.tag-editor__saving{font-size:.68rem;font-family:var(--font-mono);color:var(--text-dim);padding:0 4px}.search-bar{display:flex;align-items:center;gap:10px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;margin-bottom:16px;transition:border-color var(--transition),box-shadow var(--transition)}.search-bar:focus-within,.search-bar--active{border-color:var(--accent);box-shadow:0 0 0 3px #6610f21f}.search-bar__icon{color:var(--text-dim);flex-shrink:0;display:flex;align-items:center}.search-bar__spin{animation:spin .8s linear infinite;color:var(--accent)}.search-bar__input{flex:1;border:none;background:transparent;color:var(--text);font-size:.9rem;font-family:var(--font-body);outline:none}.search-bar__input::placeholder{color:var(--text-dim)}.search-bar__clear{width:22px;height:22px;border-radius:50%;border:none;background:var(--bg-active);color:var(--text-muted);font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background var(--transition),color var(--transition)}.search-bar__clear:hover{background:var(--border-hi);color:var(--text)}.search-bar__hint{font-family:var(--font-mono);font-size:.68rem;color:var(--text-dim);background:var(--bg-active);border:1px solid var(--border);border-radius:4px;padding:2px 5px;pointer-events:none}.search-label{font-size:.78rem;font-family:var(--font-mono);color:var(--text-dim);margin-bottom:16px;padding:0 2px}.media-tile__tags{display:flex;flex-wrap:wrap;gap:4px;padding:0 10px 8px}.file-row__tags{max-width:260px;min-width:160px}
