.gallery-root{--gallery-accent:#ff5f1f;--gallery-bg:#0d0d0d;--gallery-panel:#141414;--gallery-panel-soft:#191919;--gallery-border:#2a2a2a;--gallery-text:#f5f0eb;--gallery-muted:#888;background:var(--gallery-bg);min-height:100vh;color:var(--gallery-text);text-align:left;box-sizing:border-box;padding:28px 32px 40px;font-family:system-ui,Segoe UI,Roboto,sans-serif}.gallery-header{border-bottom:1px solid var(--gallery-border);justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:18px;display:flex}.gallery-header-left{align-items:center;gap:20px;min-width:0;display:flex}.gallery-back-btn{background:var(--gallery-panel);border:1px solid var(--gallery-border);color:var(--gallery-muted);cursor:pointer;border-radius:7px;align-items:center;gap:6px;padding:8px 12px 8px 9px;font-size:12px;font-weight:500;transition:all .2s;display:flex}.gallery-back-btn:hover{color:var(--gallery-text);background:#ffffff0d;border-color:#4a4a4a}.gallery-back-btn svg{transition:transform .2s}.gallery-back-btn:hover svg{transform:translate(-3px)}.gallery-heading{min-width:0}.gallery-wordmark{letter-spacing:.18em;text-transform:uppercase;color:var(--gallery-accent);align-items:center;gap:6px;margin-bottom:7px;font-size:10px;font-weight:700;display:flex}.gallery-wordmark-dot{background:var(--gallery-accent);border-radius:50%;width:6px;height:6px;display:inline-block}.gallery-title{color:var(--gallery-text);margin:0;font-size:28px;font-weight:650;line-height:1.05}.gallery-count{color:var(--gallery-muted);margin-top:7px;font-size:12px}.gallery-dropzone{text-align:center;cursor:pointer;background:#ff5f1f14;border:1px dashed #555;border-radius:12px;margin-bottom:1.75rem;padding:2rem;transition:border-color .15s,background .15s}.gallery-dropzone:hover,.gallery-dropzone.hovered{background:#ff5f1f2e;border-color:#ff5f1f}.gallery-dropzone-icon{color:#ff5f1f;margin-bottom:10px;font-size:28px}.gallery-dropzone-text{color:#888;font-size:14px}.gallery-dropzone-accent{color:#ff5f1f;font-weight:500}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(148px,1fr));align-items:start;gap:14px;display:grid}.gallery-grid-item{cursor:pointer;aspect-ratio:1;background:var(--gallery-panel-soft);border:1px solid #ffffffeb;border-radius:8px;padding:4px;transition:border-color .15s,box-shadow .15s,transform .15s;position:relative;overflow:hidden;box-shadow:0 10px 22px #00000047}.gallery-grid-item:hover,.gallery-grid-item.hovered{border-color:#fff;transform:scale(1.02);box-shadow:0 12px 26px #0000005c,0 0 0 2px #ff5f1f7a}.gallery-grid-item.selected{box-shadow:0 0 0 2px var(--gallery-accent), 0 12px 24px #00000061;border-color:#fff;transform:scale(.96)}.gallery-item-img{object-fit:cover;border-radius:4px;width:100%;height:100%;display:block}.gallery-item-name{color:#f5f0ebe0;white-space:nowrap;text-overflow:ellipsis;background:linear-gradient(#0000,#000000c7);border-radius:0 0 4px 4px;padding:18px 9px 7px;font-size:11px;line-height:1.2;position:absolute;bottom:4px;left:4px;right:4px;overflow:hidden}.gallery-empty-state{text-align:center;color:#555;padding:4rem 1rem;font-size:14px}.gallery-viewer-overlay{z-index:1000;background:#050505f7;flex-direction:column;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.gallery-viewer-topbar{justify-content:space-between;align-items:center;display:flex;position:absolute;top:20px;left:20px;right:20px}.gallery-viewer-filename{color:#888;letter-spacing:.03em;text-overflow:ellipsis;white-space:nowrap;max-width:60%;font-size:13px;overflow:hidden}.gallery-viewer-actions{align-items:center;gap:8px;display:flex}.gallery-viewer-img{object-fit:contain;background:#fff;border:4px solid #fff;border-radius:6px;max-width:82%;max-height:78vh}.gallery-nav-btn{color:#f5f0eb;cursor:pointer;background:#1f1f1f;border:.5px solid #2a2a2a;border-radius:50%;justify-content:center;align-items:center;width:42px;height:42px;font-size:18px;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.gallery-nav-btn.left{left:20px}.gallery-nav-btn.right{right:20px}.gallery-viewer-counter{color:#555;letter-spacing:.1em;font-size:12px;position:absolute;bottom:20px}.gallery-tabs{background:var(--gallery-panel);border:1px solid var(--gallery-border);border-radius:9px;gap:4px;width:fit-content;margin:-4px 0 24px auto;padding:4px;display:flex}.gallery-tab{color:var(--gallery-muted);cursor:pointer;text-align:center;background:0 0;border:1px solid #0000;border-radius:7px;min-width:96px;padding:8px 14px;font-size:14px;font-weight:650;line-height:1.1;transition:all .2s}.gallery-tab:hover{color:var(--gallery-text);background:#ffffff0d}.gallery-tab.active{color:var(--gallery-accent);background:#ff5f1f14;border-color:#ff5f1f73}.albums-grid{grid-template-columns:repeat(auto-fill,minmax(174px,1fr));gap:14px;display:grid}.album-card{background:var(--gallery-panel);border:1px solid var(--gallery-border);cursor:pointer;aspect-ratio:1;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;padding:24px 16px 20px;transition:border-color .2s,background .2s,transform .2s;display:flex}.album-card:hover{border-color:var(--gallery-accent);background:#181818;transform:scale(1.02)}.album-icon{width:58px;height:48px;margin-bottom:16px;position:relative}.album-folder-icon,.album-folder-icon:before,.album-folder-icon:after{box-sizing:border-box;display:block;position:absolute}.album-folder-icon{color:#ffffffeb;background:0 0;border:2px solid;border-radius:3px 3px 6px 6px;inset:10px 3px 4px;transform:none;box-shadow:0 10px 18px #00000038}.album-folder-icon:before{content:"";width:34px;height:12px;box-shadow:none;background:0 0;border:2px solid;border-bottom:0;border-radius:4px 4px 0 0;top:-12px;left:-2px;transform:none}.album-folder-icon:after{content:none}.album-name{color:var(--gallery-text);text-align:center;overflow-wrap:anywhere;max-width:100%;font-size:13px;font-weight:650;line-height:1.25}.album-count{color:var(--gallery-muted);margin-top:7px;font-size:11px}.album-create-card{color:var(--gallery-accent);background:0 0;border:1px dashed #555}.album-create-card:hover{background:#ff5f1f14}.album-create-icon{margin-bottom:10px;font-size:30px;line-height:1}.album-detail-header{background:var(--gallery-panel);border:1px solid var(--gallery-border);border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:18px;padding:12px 14px;display:flex}.album-detail-title{align-items:center;gap:10px;min-width:0;font-size:14px;font-weight:650;display:flex}.album-back-link{color:var(--gallery-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:12px;font-weight:600;transition:color .2s}.album-back-link:hover{color:var(--gallery-accent)}.album-add-btn{color:#ff5f1f;cursor:pointer;background:#ff5f1f1a;border:.5px solid #ff5f1f;border-radius:6px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;transition:all .2s;display:flex}.album-add-btn:hover{color:#fff;background:#ff5f1f}.checkbox-wrapper{z-index:10;cursor:pointer;border:2px solid #fffc;border-radius:4px;justify-content:center;align-items:center;width:22px;height:22px;transition:all .2s;display:flex;position:absolute;top:8px;left:8px}.checkbox-wrapper.checked{background:#ff5f1f;border-color:#ff5f1f}.checkbox-wrapper.unchecked{background:#0006}.checkbox-wrapper:hover{transform:scale(1.1)}.check-icon{color:#fff;font-size:14px;font-weight:700}.action-bar{z-index:100;background:#1f1f1f;border:1px solid #333;border-radius:30px;align-items:center;gap:20px;padding:12px 24px;display:flex;position:fixed;bottom:30px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #0009}.action-bar-text{color:#f5f0eb;font-size:14px;font-weight:500}.btn-danger{color:#fff;cursor:pointer;background:#e24b4a;border:1px solid #e24b4a;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn-danger:hover{background:#ff4d4f;border-color:#ff4d4f}.btn-secondary{color:#f5f0eb;cursor:pointer;background:#1f1f1f;border:1px solid #333;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn-secondary:hover{background:#2a2a2a;border-color:#444}.btn-icon-only{color:#888;cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;font-size:16px;transition:color .2s;display:flex}.btn-icon-only:hover{color:#f5f0eb}.grid-delete-btn{color:#e24b4a;cursor:pointer;z-index:10;background:#0d0d0dd9;border:1px solid #e24b4a59;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:all .2s;display:flex;position:absolute;top:6px;right:6px}.grid-delete-btn:hover{color:#fff;background:#e24b4a}.action-bar-btn:hover{background:#ff4d4f}.add-media-card{color:#ff5f1f;aspect-ratio:1;cursor:pointer;background:#ff5f1f0d;border:1px dashed #555;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;min-width:0;transition:all .2s;display:flex}.info-drawer{z-index:40;box-sizing:border-box;background:#111;border-left:1px solid #222;flex-direction:column;gap:16px;width:300px;height:100vh;padding:20px;display:flex;position:fixed;top:0;right:0;overflow-y:auto}.info-drawer-header{justify-content:space-between;align-items:center;display:flex}.info-drawer-title{text-transform:uppercase;letter-spacing:.08em;color:#ff8a61;font-size:13px;font-weight:700}.info-drawer-close{color:#f5f0eb;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:8px;padding:4px 10px;font-size:13px}.info-drawer-close:hover{color:#ff5f1f;border-color:#ff5f1f}.info-drawer-thumb-wrap{background:#000;border:1px solid #222;border-radius:12px;justify-content:center;align-items:center;width:100%;min-height:160px;display:flex;overflow:hidden}.info-drawer-thumb{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:220px;display:block}.info-drawer-rows{flex-direction:column;gap:10px;display:flex}.info-row{border-bottom:1px solid #1e1e1e;flex-direction:column;gap:3px;padding-bottom:10px;display:flex}.info-label{text-transform:uppercase;letter-spacing:.06em;color:#555;font-size:11px}.info-value{color:#ddd;word-break:break-all;font-size:13px}.info-drawer-open-btn{color:#f5f0eb;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:12px;width:100%;margin-top:auto;padding:12px;font-size:13px;transition:border-color .15s,color .15s}.info-drawer-open-btn:hover{color:#ff5f1f;border-color:#ff5f1f}.add-media-card:hover{border-color:var(--gallery-accent);background:#ff5f1f1a}.add-media-icon{margin-bottom:8px;font-size:30px;line-height:1}.add-media-text{font-size:12px;font-weight:650}.album-card{position:relative}.grid-toolbar{justify-content:flex-start;align-items:center;margin-bottom:14px;display:flex}.select-all-btn{background:var(--gallery-panel);border:1px solid var(--gallery-border);color:var(--gallery-text);cursor:pointer;border-radius:7px;align-items:center;gap:8px;padding:7px 11px;font-size:12px;font-weight:600;transition:all .2s;display:flex}.select-all-btn:hover{background:#1f1f1f;border-color:#555}.select-all-checkbox{border:1px solid #888;border-radius:3px;justify-content:center;align-items:center;width:14px;height:14px;font-size:10px;transition:all .2s;display:inline-flex}.select-all-btn.active .select-all-checkbox{background:var(--gallery-accent);border-color:var(--gallery-accent);color:#fff}@media (width<=720px){.gallery-root{padding:20px 16px 32px}.gallery-header-left{flex-direction:column;align-items:flex-start;gap:14px}.gallery-title{font-size:25px}.gallery-tabs{width:100%;margin:0 0 20px}.gallery-tab{flex:1;min-width:0;font-size:13px}.gallery-grid,.albums-grid{grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:12px}.gallery-viewer-topbar{align-items:flex-start;gap:12px}.gallery-viewer-actions{flex-shrink:0}.gallery-viewer-img{max-width:90%;max-height:72vh}.action-bar{box-sizing:border-box;justify-content:space-between;width:calc(100% - 32px);padding:10px 14px;bottom:18px}}.crop-root{color:#f5f0eb;box-sizing:border-box;background:#0d0d0d;min-height:100vh;padding:28px;font-family:Inter,system-ui,sans-serif}.crop-header{align-items:center;gap:20px;margin-bottom:24px;display:flex}.crop-back-btn{color:#f5f0eb;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:12px;padding:10px 16px}.crop-title{margin-bottom:6px;font-size:28px;font-weight:500}.crop-subtitle{color:#888;font-size:13px}.crop-body{grid-template-columns:320px 1fr;gap:24px;display:grid}.crop-sidebar{gap:18px;display:grid}.crop-panel{background:#121212;border:1px solid #222;border-radius:18px;padding:18px}.crop-panel-heading{letter-spacing:.08em;text-transform:uppercase;color:#ff8a61;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:13px;font-weight:700;display:flex}.crop-file-btn,.crop-panel button{color:#f5f0eb;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:12px;justify-content:center;align-items:center;width:100%;margin-bottom:10px;padding:12px 14px;transition:border-color .15s,color .15s,background .15s;display:inline-flex}.crop-icon{color:#ff9a6b;background:#ff5f1f24;border-radius:100px;justify-content:center;align-items:center;width:20px;height:20px;margin-right:8px;font-weight:700;display:inline-flex}.crop-icon-btn{color:#f5f0eb;background:0 0;border-color:#2a2a2a;padding:12px 0;font-size:18px}.crop-file-btn:hover,.crop-panel button:hover,.crop-icon-btn:hover{color:#ff5f1f;border-color:#ff5f1f}.crop-file-name{color:#ccc;margin-top:10px;font-size:13px}.crop-toolbar-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:8px;display:grid}.crop-panel label{color:#bbb;gap:6px;margin-bottom:10px;font-size:12px;display:grid}.crop-panel input{color:#f5f0eb;background:#101010;border:1px solid #2a2a2a;border-radius:10px;width:100%;padding:10px 12px;font-size:13px}.crop-panel input[type=number]::-webkit-inner-spin-button{appearance:none}.crop-panel input[type=number]::-webkit-outer-spin-button{appearance:none}.crop-preview-panel{background:#121212;border:1px solid #222;border-radius:18px;margin-bottom:24px;padding:18px}.crop-preview-panel .crop-panel-heading{justify-content:flex-start}.crop-fullscreen-btn{color:#f5f0eb;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:12px;margin-left:12px;padding:8px 12px;font-size:12px}.crop-fullscreen-btn:hover{color:#ff5f1f;border-color:#ff5f1f}.crop-main{gap:24px;display:grid}.crop-preview-box{background:#0f0f0f;border:1px dashed #2b2b2b;border-radius:16px;justify-content:center;align-items:center;min-height:200px;padding:12px;display:flex;position:relative;overflow:hidden}.crop-empty-state{color:#666;text-align:center;padding:28px;font-size:14px}.crop-preview-area,.crop-fullscreen-image-area{cursor:move;display:inline-flex;position:relative}.crop-preview-image{-webkit-user-select:none;user-select:none;width:auto;max-width:min(100%,900px);height:auto;max-height:540px;display:block}.crop-fullscreen-image{-webkit-user-select:none;user-select:none;width:auto;max-width:100%;height:auto;max-height:calc(100vh - 180px);display:block}.crop-overlay{box-sizing:border-box;cursor:move;touch-action:none;border:2px solid #ff5f1fe6;position:absolute;box-shadow:0 0 0 9999px #0000008c}.crop-handle{box-sizing:border-box;cursor:pointer;background:#ff5f1f;border:2px solid #111;border-radius:50%;width:16px;height:16px;position:absolute}.crop-handle.nw{cursor:nwse-resize;top:-10px;left:-10px}.crop-handle.ne{cursor:nesw-resize;top:-10px;right:-10px}.crop-handle.sw{cursor:nesw-resize;bottom:-10px;left:-10px}.crop-handle.se{cursor:nwse-resize;bottom:-10px;right:-10px}.crop-handle.n{cursor:ns-resize;top:-10px;left:50%;transform:translate(-50%)}.crop-handle.s{cursor:ns-resize;bottom:-10px;left:50%;transform:translate(-50%)}.crop-handle.e{cursor:ew-resize;top:50%;right:-10px;transform:translateY(-50%)}.crop-handle.w{cursor:ew-resize;top:50%;left:-10px;transform:translateY(-50%)}.crop-output-letterbox{background:#000;border:1px solid #2a2a2a;border-radius:16px;justify-content:center;align-items:center;width:100%;min-height:200px;max-height:520px;display:flex;overflow:hidden}.crop-output-img{object-fit:contain;width:auto;max-width:100%;height:auto;max-height:520px;display:block}.crop-result-panel{gap:12px;display:grid}.crop-result-details{color:#aaa;justify-content:space-between;gap:8px;font-size:13px;display:flex}.crop-fullscreen-layer{z-index:50;background:#000000e6;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.crop-fullscreen-content{background:#111;border:1px solid #222;border-radius:20px;gap:18px;width:100%;max-width:1180px;padding:18px;display:grid}.crop-fullscreen-header{color:#ccc;justify-content:space-between;align-items:center;gap:10px;font-size:13px;display:flex}.crop-close-btn{color:#f5f0eb;cursor:pointer;background:0 0;border:1px solid #2a2a2a;border-radius:12px;padding:10px 16px}.crop-fullscreen-image-area{background:#0f0f0f;border-radius:18px;min-height:520px;position:relative;overflow:hidden}@media (width<=980px){.crop-body{grid-template-columns:1fr}.crop-preview-panel{padding:16px}}
