:root{--bg:#f5f5f7;--panel:#fff;--muted:#999;--text:#0d0d0d;--line:#efefef;--brand:#0d0d0d;--brand-hover:#333;--accent:#6366f1;--shadow-sm:0 1px 2px 0 #00000005;--shadow:0 8px 30px #0000000a;--shadow-lg:0 30px 60px #00000014;--radius-lg:32px;--radius-md:18px;--radius-sm:12px;--sidebar-width:280px}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;letter-spacing:-.02em;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,sans-serif}a{color:inherit;text-decoration:none}.layout-wrapper{grid-template-columns:var(--sidebar-width) 1fr;background:var(--bg);min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--line);z-index:20;background:#fff;flex-direction:column;height:100vh;padding:0;display:flex;position:sticky;top:0}.sidebar-header{align-items:center;gap:14px;padding:48px 32px 32px;display:flex}.sidebar-logo-icon{background:var(--brand);color:#fff;border-radius:12px;place-items:center;width:36px;height:36px;font-size:20px;font-weight:900;display:grid}.sidebar-header span{letter-spacing:-.03em;color:var(--text);font-size:19px;font-weight:800}.sidebar-content{flex-direction:column;flex:1;gap:40px;padding:0 20px;display:flex;overflow-y:auto}.sidebar-section{flex-direction:column;gap:4px;display:flex}.sidebar-label{color:#bbb;text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px;padding:0 16px;font-size:11px;font-weight:700}.sidebar-link{border-radius:var(--radius-sm);color:#666;align-items:center;gap:12px;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-link .icon{text-align:center;opacity:.8;width:20px;font-size:18px}.sidebar-link:hover{color:var(--text);background:#f8f8f8;transform:translate(4px)}.sidebar-link.active{color:var(--text);background:#f3f3f3;font-weight:700}.sidebar-link.active .icon{opacity:1}.sidebar-footer{border-top:1px solid var(--line);background:#fff;padding:32px 20px}.user-card{border-radius:var(--radius-md);background:#f8f8f8;border:1px solid #eee;align-items:center;gap:12px;padding:12px;transition:all .2s;display:flex}.user-card:hover{background:#f0f0f0}.user-avatar{width:40px;height:40px;color:var(--text);background:#fff;border:1px solid #eee;border-radius:12px;place-items:center;font-size:16px;font-weight:700;display:grid}.user-info{flex:1;min-width:0}.user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:14px;font-weight:700;overflow:hidden}.user-role{color:#999;text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:700}.logout-btn-subtle{color:#999;cursor:pointer;background:0 0;border:none;border-radius:10px;place-items:center;width:32px;height:32px;font-size:18px;transition:all .2s;display:grid}.logout-btn-subtle:hover{color:#ef4444;background:#fee2e2}.main-content{flex-direction:column;height:100vh;padding:24px;display:flex;overflow-y:auto}main{border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);background:#fff;flex:1;padding:48px}.admin-header{justify-content:space-between;align-items:flex-end;margin-bottom:40px;display:flex}.admin-header h1{letter-spacing:-.03em;margin:0 0 8px;font-size:32px;font-weight:800}.admin-header p{color:var(--muted);margin:0;font-size:15px}table{border-collapse:separate;border-spacing:0;width:100%}th{text-align:left;color:#bbb;text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--line);padding:16px;font-size:11px;font-weight:700}td{color:var(--text);border-bottom:1px solid var(--line);vertical-align:middle;padding:20px 16px;font-size:14px}tr:last-child td{border-bottom:none}.badge{text-transform:uppercase;letter-spacing:.02em;border-radius:99px;align-items:center;padding:4px 12px;font-size:11px;font-weight:700;display:inline-flex}.badge.success{color:#166534;background:#f0fdf4}.badge.error{color:#991b1b;background:#fef2f2}.badge.warning{color:#92400e;background:#fffbeb}.badge.info{color:#475569;background:#f1f5f9}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:32px;margin-top:32px;display:grid}.gallery-card{border:1px solid var(--line);border-radius:var(--radius-md);background:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.gallery-card:hover{box-shadow:var(--shadow-lg);border-color:#bbb;transform:translateY(-8px)}.gallery-image-wrapper{aspect-ratio:4/3;background:#fafafa;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.gallery-image-wrapper img{object-fit:cover;width:100%;height:100%}.gallery-info{padding:20px}.gallery-meta{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.gallery-type{color:#bbb;text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:800}.gallery-prompt{color:var(--text);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:3em;margin-bottom:16px;font-size:14px;font-weight:500;line-height:1.5;display:-webkit-box;overflow:hidden}.gallery-footer{border-top:1px solid var(--line);color:#bbb;justify-content:space-between;align-items:center;padding-top:16px;font-size:12px;display:flex}.btn{background:var(--brand);color:#fff;cursor:pointer;border:0;border-radius:14px;justify-content:center;align-items:center;padding:14px 28px;font-weight:700;transition:all .2s;display:inline-flex}.btn:hover{background:var(--brand-hover);transform:translateY(-1px)}.btn.secondary{color:var(--text);background:#f3f3f3}.btn.secondary:hover{background:#eee}.input:focus,textarea:focus,select:focus{background:#fff;border-color:#bbb}label{color:#666;text-transform:uppercase;letter-spacing:.05em;gap:10px;font-size:13px;font-weight:700;display:grid}.result-section{flex-direction:column;gap:32px;display:flex}.current-view{border-radius:var(--radius-lg);background:#fafafa;border:1px dashed #e5e5e5;justify-content:center;align-items:center;min-height:520px;display:flex}.current-view img{object-fit:contain;border-radius:var(--radius-md);max-width:100%;max-height:600px;box-shadow:var(--shadow-lg)}.history-item{border-radius:var(--radius-sm);border:1px solid var(--line);cursor:pointer;background:#f8f8f8;width:110px;height:110px;transition:all .3s;overflow:hidden}.history-item.active{border:2px solid #000;padding:2px}.history-gallery{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:16px;width:100%;display:grid}.history-gallery-wrapper{max-height:400px;padding-right:8px;overflow-y:auto}.upload-zone{border-radius:var(--radius-md);text-align:center;cursor:pointer;background:#fafafa;border:1px dashed #ccc;padding:40px 20px;transition:all .2s}.upload-zone:hover{background:#fff;border-color:#000}.upload-zone .icon{opacity:.5;margin-bottom:12px;font-size:32px}.tabs{background:#f3f3f3;border-radius:14px;gap:8px;padding:6px;display:flex}.tab-btn.active{color:var(--text);background:#fff;box-shadow:0 2px 8px #0000000d}.asset-selector-grid{grid-template-columns:repeat(4,1fr);gap:8px;max-height:240px;padding:4px;display:grid;overflow-y:auto}.asset-item{aspect-ratio:1;border:1px solid var(--line);cursor:pointer;border-radius:8px;overflow:hidden}.asset-item:hover{border-color:#000}.asset-item.active{border:2px solid #000}.login-page{place-items:center;min-height:100vh;padding:48px;display:grid}.login-hero{border:1px solid var(--line);background:var(--panel);border-radius:28px;grid-template-columns:minmax(0,1fr) 380px;align-items:center;gap:48px;width:min(100%,1220px);padding:clamp(32px,5vw,64px);display:grid;box-shadow:0 24px 60px #0f172a14}.login-copy{gap:28px;display:grid}.login-kicker{color:#64748b;letter-spacing:0;margin:0;font-size:20px}.login-copy h1{letter-spacing:0;color:#0f172a;margin:0;font-size:clamp(44px,6vw,74px);line-height:1.12}.login-description{color:#64748b;max-width:740px;margin:0;font-size:clamp(20px,2.4vw,26px);line-height:1.8}.login-form{border-left:1px solid var(--line);gap:16px;padding-left:48px;display:grid}.login-form h2{letter-spacing:0;margin:6px 0 0;font-size:30px;line-height:1.2}.login-form .btn{width:100%;min-height:48px;margin-top:4px}.login-error{color:#b91c1c;min-height:20px;margin:-4px 0 0;font-size:14px;line-height:1.4}.card{border:1px solid var(--line);background:var(--panel);border-radius:20px;padding:32px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -2px #0000000d}.card:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px #0000000d,0 8px 10px -6px #0000000d}.grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px;display:grid}.btn{background:var(--brand);color:#fff;cursor:pointer;border:0;border-radius:12px;justify-content:center;align-items:center;padding:12px 24px;font-weight:700;transition:all .2s;display:inline-flex;box-shadow:0 4px 14px #6366f163}.btn:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px #6366f13b}.btn:active{transform:translateY(0)}.btn.secondary{background:var(--brand-light);color:var(--brand);box-shadow:none}.btn.secondary:hover{box-shadow:0 4px 12px #0000000d}.input,textarea,select{border:1px solid var(--line);width:100%;color:var(--text);background:#fff;border-radius:12px;outline:none;padding:11px 12px;font-size:14px;transition:all .2s}.input:focus,textarea:focus,select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-light)}label{color:var(--text);gap:8px;font-size:14px;font-weight:600;display:grid}button:disabled,select:disabled,input:disabled,textarea:disabled{opacity:.5;cursor:not-allowed}pre{border:1px solid var(--line);color:#334155;background:#f8fafc;border-radius:12px;padding:14px;font-size:13px;overflow:auto}.notice{border:1px solid var(--line);border-radius:12px;margin:12px 0;padding:12px 16px;font-size:14px}.notice.error{color:#991b1b;background:#fef2f2;border-color:#fecaca}.notice.success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.meta-box{border:1px solid var(--line);color:var(--muted);background:#f8fafc;border-radius:12px;gap:6px;padding:12px;font-size:13px;display:grid}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.stack{gap:20px;display:grid}.two-col{grid-template-columns:minmax(360px,420px) 1fr;align-items:start;gap:32px;display:grid}.result-section{flex-direction:column;gap:24px;min-height:0;display:flex}.current-view{background:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;min-height:480px;display:flex;position:relative;overflow:hidden}.current-view img{object-fit:contain;max-width:100%;max-height:600px;box-shadow:var(--shadow-lg);border-radius:12px}.current-view-placeholder{color:var(--muted);text-align:center;flex-direction:column;align-items:center;gap:12px;display:flex}.tabs{background:#f1f5f9;border-radius:10px;gap:4px;margin-bottom:16px;padding:4px;display:flex}.tab-btn{color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:8px;flex:1;padding:8px;font-size:13px;font-weight:600;transition:all .2s}.tab-btn.active{color:var(--brand);box-shadow:var(--shadow);background:#fff}.asset-selector-grid{border:1px solid var(--line);border-radius:12px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;max-height:320px;padding:4px;display:grid;overflow-y:auto}.asset-item{aspect-ratio:1;cursor:pointer;background:#f1f5f9;border:2px solid #0000;border-radius:8px;transition:all .2s;overflow:hidden}.asset-item:hover{border-color:var(--brand-light);transform:scale(.95)}.asset-item.active{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-light)}.asset-item img{object-fit:cover;width:100%;height:100%}.upload-zone{border:2px dashed var(--line);text-align:center;cursor:pointer;background:#f8fafc;border-radius:16px;padding:32px 16px;transition:all .2s}.upload-zone:hover{border-color:var(--brand);background:var(--brand-light)}.upload-zone p{color:var(--muted);margin:8px 0 0;font-size:13px}.upload-zone .icon{color:var(--brand);font-size:24px}.image-preview{object-fit:contain;border:1px solid var(--line);background:#f8fafc;border-radius:12px;width:100%;max-height:300px;display:block}.history-gallery-wrapper{padding-bottom:8px;overflow-x:auto}.history-gallery{gap:12px;width:max-content;display:flex}.history-item{cursor:pointer;background:#f1f5f9;border:2px solid #0000;border-radius:12px;flex-shrink:0;width:100px;height:100px;transition:all .2s;overflow:hidden}.history-item:hover{border-color:var(--brand);transform:scale(1.05)}.history-item.active{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand-light)}.history-item img{object-fit:cover;width:100%;height:100%}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0f172a66;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-container{background:#fff;border-radius:24px;width:100%;max-width:520px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;overflow:hidden;box-shadow:0 25px 50px -12px #00000026}.modal-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:24px 32px;display:flex}.modal-header h2{margin:0;font-size:18px;font-weight:700}.modal-close-btn{cursor:pointer;width:32px;height:32px;color:var(--muted);background:#f1f5f9;border:0;border-radius:50%;place-items:center;font-size:18px;display:grid}.modal-close-btn:hover{color:var(--text);background:#e2e8f0}.modal-body{max-height:80vh;padding:32px;overflow-y:auto}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.inline-check{color:var(--text);cursor:pointer;align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.inline-check input{width:16px;height:16px;accent-color:var(--brand)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin:0 0 32px;display:grid}.stats-grid .meta-box{text-align:center;border-radius:16px;padding:16px}.stats-grid .meta-box strong{color:var(--brand);margin-bottom:4px;font-size:32px;display:block}.stats-grid .meta-box span{color:var(--muted);font-size:13px;font-weight:600}.filter-row{grid-template-columns:160px 180px 1fr;align-items:end;gap:16px;margin-bottom:32px;display:grid}.admin-task-meta{color:var(--muted);flex-wrap:wrap;gap:12px;margin-top:8px;font-size:12px;display:flex}.admin-task-meta span{background:#f1f5f9;border-radius:6px;padding:2px 8px}.task-list{gap:16px;display:grid}.task-row{border:1px solid var(--line);background:var(--panel);box-shadow:var(--shadow);border-radius:16px;grid-template-columns:80px 1fr auto;align-items:center;gap:16px;padding:16px;transition:transform .1s;display:grid}.task-row:hover{border-color:var(--brand);transform:translateY(-1px)}.thumb{border:1px solid var(--line);background:#f1f5f9;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex;overflow:hidden}.thumb img{object-fit:cover;width:100%;height:100%}.status{color:#475569;background:#f1f5f9;border-radius:999px;align-items:center;width:fit-content;padding:4px 10px;font-size:12px;font-weight:700;display:inline-flex}.status.processing,.status.pending{color:#92400e;background:#fef3c7}.status.succeeded,.status.active{color:#166534;background:#dcfce7}.status.failed,.status.disabled{color:#991b1b;background:#fee2e2}@media (max-width:1024px){.layout-wrapper{grid-template-columns:1fr}.sidebar{display:none}.login-page{padding:24px}.login-hero{grid-template-columns:1fr;gap:32px}.login-form{border-left:0;border-top:1px solid var(--line);padding:32px 0 0}}@media (max-width:640px){main{padding:20px}.login-page{padding:16px}.login-hero{border-radius:20px;padding:28px 20px}.login-kicker{font-size:16px}.login-copy{gap:20px}.login-description{font-size:17px;line-height:1.7}.login-form h2{font-size:24px}}
