:root{--bg-base:#0c0f14;--bg-elevated:#141a22;--bg-surface:#1a222d;--bg-hover:#222c3a;--border:#ffffff14;--border-strong:#ffffff24;--text-primary:#f0f4f8;--text-secondary:#8b9cb3;--text-muted:#5c6b7f;--accent:#3dd6c6;--accent-dim:#3dd6c626;--accent-glow:#3dd6c659;--danger:#f07178;--danger-dim:#f071781f;--success:#7fd99a;--success-dim:#7fd99a1f;--warning:#e6b84a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--shadow:0 8px 32px #0006;--font-sans:"DM Sans",system-ui,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,monospace}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0c0f14;background:var(--bg-base);color:#f0f4f8;color:var(--text-primary);font-family:DM Sans,system-ui,sans-serif;font-family:var(--font-sans);line-height:1.5}code{font-family:JetBrains Mono,ui-monospace,monospace;font-family:var(--font-mono)}button,input,textarea{font-family:inherit}.app{background:var(--bg-base);display:flex;min-height:100vh}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:20px;overflow-y:auto;padding:24px 16px;width:300px}.brand{align-items:center;display:flex;gap:14px;padding:0 8px}.brand-mark{background:linear-gradient(135deg,var(--accent) 0,#2a9d8f 100%);border-radius:10px;box-shadow:0 0 24px var(--accent-glow);flex-shrink:0;height:36px;width:36px}.brand h1{font-size:1.15rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.brand p{color:var(--text-muted);font-size:.75rem;margin-top:2px}.sidebar-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr}.stat-pill{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;text-align:center}.stat-value{color:var(--accent);display:block;font-size:1.5rem;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);font-size:.7rem;letter-spacing:.06em;margin-top:4px;text-transform:uppercase}.sidebar-actions,.sidebar-form{padding:0 4px}.sidebar-projects{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow:hidden}.sidebar-heading{color:var(--text-muted);font-size:.7rem;font-weight:600;letter-spacing:.08em;padding:0 12px 10px;text-transform:uppercase}.empty-hint{color:var(--text-muted);font-size:.9rem;padding:16px 12px;text-align:center}.main{display:flex;flex:1 1;flex-direction:column;min-width:0}.main-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;padding:28px 32px 0}.page-title{font-size:1.75rem;font-weight:700;letter-spacing:-.03em}.page-subtitle{color:var(--text-secondary);font-size:.95rem;margin-top:6px;max-width:480px}.badge{background:var(--accent-dim);border:1px solid #3dd6c640;border-radius:999px;color:var(--accent);font-size:.8rem;font-weight:600;padding:6px 14px;white-space:nowrap}.toast{align-items:center;animation:toastIn .25s ease;border-radius:var(--radius-md);display:flex;font-size:.9rem;gap:12px;justify-content:space-between;margin:16px 32px 0;padding:12px 16px}.toast-error{background:var(--danger-dim);border:1px solid #f071784d;color:var(--danger)}.toast-success{background:var(--success-dim);border:1px solid #7fd99a4d;color:var(--success)}.toast-close{background:none;border:none;color:inherit;cursor:pointer;font-size:1.25rem;line-height:1;opacity:.7;padding:0 4px}.toast-close:hover{opacity:1}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.main-content{flex:1 1;overflow-y:auto;padding:24px 32px 32px}.panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:24px;padding:24px}.panel-title{align-items:center;color:var(--text-secondary);display:flex;font-size:.85rem;font-weight:600;gap:10px;letter-spacing:.06em;margin-bottom:20px;text-transform:uppercase}.panel-count{background:var(--bg-surface);border-radius:999px;color:var(--text-muted);font-size:.75rem;padding:2px 8px}.empty-state{align-items:center;background:var(--bg-elevated);border:1px dashed var(--border-strong);border-radius:var(--radius-lg);display:flex;flex-direction:column;justify-content:center;min-height:360px;padding:48px;text-align:center}.empty-icon{background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;height:64px;margin-bottom:24px;position:relative;width:64px}.empty-icon:after{border:2px solid var(--text-muted);border-radius:4px;content:"";inset:18px;opacity:.5;position:absolute}.empty-state h3{font-size:1.25rem;margin-bottom:8px}.empty-state p{color:var(--text-secondary);font-size:.95rem;max-width:320px}.main-footer{align-items:center;border-top:1px solid var(--border);color:var(--text-muted);display:flex;font-size:.8rem;gap:8px;padding:16px 32px}.main-footer .dot{opacity:.4}.btn{border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:.9rem;font-weight:600;padding:10px 18px;transition:background .15s,transform .15s,box-shadow .15s}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-accent{background:var(--accent);color:var(--bg-base)}.btn-accent:hover:not(:disabled){box-shadow:0 4px 20px var(--accent-glow);filter:brightness(1.08)}.btn-block{width:100%}@media (max-width:900px){.app{flex-direction:column}.sidebar{border-bottom:1px solid var(--border);border-right:none;max-height:45vh;width:100%}.main-content,.main-footer,.main-header{padding-left:20px;padding-right:20px}.toast{margin-left:20px;margin-right:20px}}.project-form{gap:14px}.form-group,.project-form{display:flex;flex-direction:column}.form-group{gap:6px}.form-group label{color:var(--text-secondary);font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.form-group input,.form-group textarea{background:var(--bg-surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;padding:10px 12px;transition:border-color .15s,box-shadow .15s}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.form-group input:disabled,.form-group textarea:disabled{cursor:not-allowed;opacity:.6}.form-group textarea{min-height:56px;resize:vertical}.project-list{display:flex;flex:1 1;flex-direction:column;gap:4px;list-style:none;overflow-y:auto;padding:0 4px}.project-list li{align-items:stretch;display:flex;gap:4px}.project-item{background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:inherit;cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:0;padding:12px 14px;text-align:left;transition:background .15s,border-color .15s}.project-item:hover{background:var(--bg-hover)}.project-item.active{background:var(--accent-dim);border-color:#3dd6c64d}.project-item-name{font-size:.9rem;font-weight:600}.project-item-desc,.project-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-item-desc{color:var(--text-muted);font-size:.75rem}.project-item-meta{align-items:center;color:var(--text-muted);display:flex;font-size:.7rem;gap:10px}.project-item-count{color:var(--accent);font-family:var(--font-mono);font-weight:500}.project-item-delete{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;transition:color .15s,background .15s,border-color .15s;width:36px}.project-item-delete:hover{background:var(--danger-dim);border-color:#f0717840;color:var(--danger)}.image-upload{position:relative}.drop-zone{background:var(--bg-surface);border:2px dashed var(--border-strong);border-radius:var(--radius-md);cursor:pointer;padding:48px 24px;text-align:center;transition:border-color .2s,background .2s}.drop-zone.active,.drop-zone:hover:not(.loading){background:var(--accent-dim);border-color:var(--accent)}.drop-zone.active{box-shadow:inset 0 0 0 1px #3dd6c633}.drop-zone.loading{opacity:.7;pointer-events:none}.file-input{display:none}.drop-zone-inner{pointer-events:none}.drop-icon{align-items:center;background:var(--bg-elevated);border-radius:50%;color:var(--accent);display:inline-flex;height:56px;justify-content:center;margin-bottom:16px;width:56px}.drop-title{font-size:1rem;font-weight:600;margin-bottom:6px}.drop-hint{color:var(--text-muted);font-size:.85rem}.image-gallery{margin-top:4px}.gallery-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.gallery-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:border-color .2s,box-shadow .2s}.gallery-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow)}.gallery-preview{aspect-ratio:1;background:var(--bg-base);overflow:hidden;position:relative}.gallery-preview img{height:100%;object-fit:cover;transition:transform .3s ease;width:100%}.gallery-card:hover .gallery-preview img{transform:scale(1.04)}.gallery-actions{align-items:center;background:#0c0f14bf;display:flex;flex-wrap:wrap;gap:8px;inset:0;justify-content:center;opacity:0;padding:12px;position:absolute;transition:opacity .2s}.gallery-card:hover .gallery-actions{opacity:1}.gallery-btn{background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.75rem;font-weight:600;padding:6px 12px;transition:background .15s}.gallery-btn:hover:not(:disabled){background:var(--bg-hover)}.gallery-btn-accent{border-color:#3dd6c666;color:var(--accent)}.gallery-btn-danger{border-color:#f0717866;color:var(--danger)}.gallery-btn-danger:hover:not(:disabled){background:var(--danger-dim)}.gallery-btn:disabled{cursor:not-allowed;opacity:.5}.gallery-info{padding:12px 14px}.gallery-filename{font-size:.8rem;font-weight:600;margin-bottom:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-meta{color:var(--text-muted);display:flex;font-size:.7rem;justify-content:space-between;margin-bottom:10px}.gallery-url-row{align-items:center;display:flex;gap:8px}.gallery-url{background:var(--bg-base);border-radius:4px;flex:1 1;font-family:var(--font-mono);font-size:.65rem;overflow:hidden;padding:6px 8px;text-overflow:ellipsis;white-space:nowrap}.gallery-copy-icon,.gallery-url{border:1px solid var(--border);color:var(--text-secondary)}.gallery-copy-icon{align-items:center;background:var(--bg-elevated);border-radius:6px;cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;transition:color .15s,border-color .15s;width:28px}.gallery-copy-icon:hover{border-color:#3dd6c666;color:var(--accent)}@media (max-width:480px){.gallery-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.b4c9a48e.css.map*/