:root{color-scheme:dark;--bg: #0b0d12;--panel: #161922;--panel-2: #1c2030;--border: #2a2f40;--text: #e6e8ee;--muted: #8d93a3;--accent: #6ea8ff;--accent-strong: #4d8df0;--danger: #e96565;--canvas-bg: #3a3d42;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app{display:grid;grid-template-rows:48px 1fr;height:100vh}.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 16px;background:var(--panel);border-bottom:1px solid var(--border)}.topbar h1{font-size:14px;font-weight:600;margin:0;letter-spacing:.02em}.topbar .right{display:flex;gap:8px;align-items:center}.topbar .dims{font-size:11px;color:var(--muted)}button{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 12px;font-size:12px;cursor:pointer}button:hover:not(:disabled){background:#232938}button:disabled{opacity:.5;cursor:not-allowed}button.primary{background:var(--accent-strong);border-color:var(--accent-strong);color:#fff}button.primary:hover:not(:disabled){background:var(--accent)}.body{display:grid;grid-template-columns:1fr 340px;min-height:0;transition:grid-template-columns .22s ease}.app.panel-collapsed .body{grid-template-columns:1fr 28px}.stage{display:grid;grid-template-rows:1fr auto;min-width:0;min-height:0;background:var(--canvas-bg)}.canvas-area{position:relative;background:var(--canvas-bg);display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.canvas-area img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.canvas-area .empty{text-align:center;color:var(--muted);padding:40px}.canvas-area .empty h2{font-weight:500;margin:0 0 12px;color:var(--text)}.canvas-area .empty p{font-size:12px;margin:0}.canvas-area .loading{position:absolute;top:12px;left:12px;font-size:11px;background:#0000008c;padding:4px 8px;border-radius:4px;color:var(--text)}.canvas-area .canvas-error{position:absolute;bottom:12px;left:12px;right:12px;font-size:12px;background:#0009;padding:6px 10px;border-radius:4px;color:var(--danger)}.filmstrip{background:var(--panel);border-top:1px solid var(--border);display:flex;flex-direction:column}.filmstrip-inner{overflow:hidden;max-height:0;transition:max-height .22s ease}.filmstrip.open .filmstrip-inner{max-height:168px;overflow-y:hidden}.thumbs{display:flex;gap:8px;padding:10px 12px;overflow-x:auto}.filmstrip-empty,.filmstrip-inner>.error{padding:12px;font-size:12px}.thumb{flex:0 0 auto;width:104px;height:92px;padding:0;display:flex;flex-direction:column;align-items:stretch;justify-content:space-between;border:1px solid var(--border);border-radius:6px;background:var(--panel-2);overflow:hidden}.thumb.active{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent) inset}.thumb-icon{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:#2a3142;overflow:hidden}.thumb-icon img{width:100%;height:100%;object-fit:cover;display:block}.thumb-icon.no-thumb:after{content:"RAW";font-size:11px;letter-spacing:.12em;color:var(--muted)}.thumb-name{font-size:10px;padding:4px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text);text-align:left}.panel{position:relative;background:var(--panel);border-left:1px solid var(--border);overflow:hidden;display:flex}.panel-inner{flex:1;overflow-y:auto;padding:8px 0;min-width:340px}.app.panel-collapsed .panel-inner{opacity:0;pointer-events:none;transition:opacity .12s ease}.collapse-tab{display:flex;align-items:center;gap:6px;border:none;border-radius:0;background:var(--panel-2);color:var(--muted);font-size:11px;letter-spacing:.06em;text-transform:uppercase}.collapse-tab:hover:not(:disabled){background:#232938;color:var(--text)}.collapse-tab .chevron{font-size:10px}.filmstrip-tab{justify-content:flex-start;padding:4px 12px;border-bottom:1px solid var(--border)}.panel-tab{flex:0 0 28px;width:28px;flex-direction:column;justify-content:flex-start;padding-top:12px;gap:10px;border-right:1px solid var(--border)}.panel-tab .collapse-label{writing-mode:vertical-rl;text-orientation:mixed}.section{border-bottom:1px solid var(--border);padding:8px 14px 12px}.section h3{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:4px 0 8px}.row{display:grid;grid-template-columns:90px 1fr 42px;align-items:center;gap:8px;padding:3px 0;font-size:12px}.row label{color:var(--text)}.row .val{text-align:right;font-variant-numeric:tabular-nums;color:var(--muted);font-size:11px}input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:16px;background:transparent}input[type=range]::-webkit-slider-runnable-track{height:3px;background:var(--border);border-radius:2px}input[type=range]::-moz-range-track{height:3px;background:var(--border);border-radius:2px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;margin-top:-4.5px;background:var(--accent);border-radius:50%;cursor:pointer}input[type=range]::-moz-range-thumb{width:12px;height:12px;background:var(--accent);border-radius:50%;border:none;cursor:pointer}.hint{font-size:10px;color:var(--muted);margin-top:6px}.curve-editor{width:100%;height:180px;background:var(--panel-2);border:1px solid var(--border);border-radius:4px;cursor:crosshair;display:block}.hsl-mixer{display:flex;flex-direction:column;gap:4px}.hsl-bands{display:flex;gap:4px;margin-bottom:8px}.hsl-band{flex:1;height:22px;min-width:0;padding:0;border:1px solid var(--border);border-radius:3px;cursor:pointer;color:#0b0d12;font-size:12px;line-height:1;opacity:.6}.hsl-band:hover{opacity:.85}.hsl-band.active{opacity:1;border-color:var(--text);box-shadow:0 0 0 1px var(--text) inset}.toolbar-actions{display:flex;gap:6px}.error{color:var(--danger);font-size:12px;margin-top:8px}
