*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0b0b0b;--surface:#141414;--surface2:#1c1c1c;--surface3:#232323;--border:#242424;--border2:#333;--border3:#444;--text:#ece8e1;--text2:#a3a3a3;--text3:#8a8a8a;--accent:#aaee44;--accent2:#88cc22;--accent-bg:#162208;--accent-dim:#2a3d10;--danger:#ee4444;--info:#4499ee;--info-bg:#0a1a2e;--warn:#ddaa33;--warn-bg:#1e1608;--mono:"Courier New", Courier, monospace;--sans:-apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--r:5px}html{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--sans);height:100%;min-height:600px;display:flex;flex-direction:column}header{border-bottom:1px solid var(--border);padding:.7rem 1.5rem;display:flex;align-items:center;gap:1rem;flex-shrink:0}.logo{font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);text-decoration:none}.logo-dot{color:var(--text2);font-weight:400}.chip{font-family:var(--mono);font-size:.57rem;letter-spacing:.06em;padding:2px 6px;border-radius:3px;border:1px solid var(--border2);color:var(--text3)}footer{border-top:1px solid var(--border);padding:.75rem 1.5rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;flex-shrink:0}.footer-left{font-size:.65rem;color:var(--text3)}.footer-left a{color:var(--text2);text-decoration:none}.footer-left a:hover{color:var(--accent)}.footer-right{margin-left:auto;display:flex;gap:1rem}.footer-right a{font-size:.65rem;color:var(--text3);text-decoration:none}.footer-right a:hover{color:var(--text2)}.btn{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:.55rem .9rem;border-radius:var(--r);cursor:pointer;transition:all .12s;border:none}.btn-full{width:100%}.btn-primary{background:var(--accent);color:#0b0b0b}.btn-primary:hover{background:var(--accent2)}.btn-primary:disabled{background:var(--surface3);color:var(--text3);cursor:not-allowed}.btn-ghost{background:#fff0;color:var(--text2);border:1px solid var(--border2)}.btn-ghost:hover{color:var(--text);border-color:var(--border3)}.btn-ghost:disabled{opacity:.3;cursor:not-allowed}.tabs{border-bottom:1px solid var(--border);display:flex;padding:0 1.25rem;flex-shrink:0}.tab-btn{font-family:var(--sans);font-size:.68rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;padding:.65rem .9rem;background:#fff0;border:none;color:var(--text3);cursor:pointer;border-bottom:2px solid #fff0;margin-bottom:-1px;transition:color .12s,border-color .12s;white-space:nowrap}.tab-btn:hover{color:var(--text2)}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.field-row{padding:.8rem 0;border-bottom:1px solid var(--border)}.field-row:last-child{border-bottom:none}.field-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.field-label{font-size:.72rem;font-weight:600;color:var(--text)}.field-badge{font-family:var(--mono);font-size:.54rem;letter-spacing:.06em;padding:1px 5px;border-radius:3px;background:var(--info-bg);color:var(--info);border:1px solid #1a3d6a}.field-input-wrap{margin-bottom:.28rem}.field-input{font-family:var(--mono);font-size:.72rem;background:var(--surface2);border:1px solid var(--border2);color:var(--text);padding:.38rem .6rem;border-radius:var(--r);outline:none;width:100%;transition:border .12s}.field-input:focus{border-color:var(--accent2);background:var(--surface3)}.field-input::placeholder{color:var(--text3)}.field-textarea{resize:vertical;min-height:68px;line-height:1.5;font-family:var(--sans);font-size:.72rem}.field-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23666' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:26px}.field-help{font-size:.62rem;color:var(--text3);line-height:1.5}.tags-wrap{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem;background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r);padding:.3rem .45rem;min-height:36px;cursor:text;transition:border .12s}.tags-wrap:focus-within{border-color:var(--accent2)}.tag-chip{display:inline-flex;align-items:center;gap:.3rem;background:var(--accent-bg);border:1px solid var(--accent-dim);color:var(--accent);font-family:var(--mono);font-size:.62rem;padding:2px 5px;border-radius:3px}.tag-remove{background:none;border:none;color:var(--accent2);cursor:pointer;font-size:.8rem;line-height:1;padding:0}.tag-remove:hover{color:var(--danger)}.tag-input{font-family:var(--mono);font-size:.68rem;background:#fff0;border:none;outline:none;color:var(--text);flex:1;min-width:100px}.tag-input::placeholder{color:var(--text3)}.chevron{width:10px;height:10px;stroke:var(--text3);fill:none;transition:transform .15s;flex-shrink:0}.collapsed .chevron{transform:rotate(-90deg)}.collapsed .exif-edit-rows,.collapsed .raw-rows{display:none}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:#fff0}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}.app{display:grid;grid-template-columns:280px 1fr;flex:1;min-height:0;overflow:hidden;height:0}.sidebar{border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;min-height:0}.drop-zone{flex-shrink:0;border-bottom:1px solid var(--border);padding:1.25rem;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:background .12s;min-height:155px;position:relative;text-align:center}.drop-zone:hover,.drop-zone.drag-over{background:var(--surface)}.drop-zone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;font-size:0}.drop-icon{width:36px;height:36px;border:1px solid var(--border2);border-radius:7px;display:flex;align-items:center;justify-content:center}.drop-icon svg{width:16px;height:16px;stroke:var(--text3);fill:none;stroke-width:1.5}.drop-label{font-size:.7rem;color:var(--text2);line-height:1.6}.drop-label strong{color:var(--text);font-weight:600}.drop-fmts{font-family:var(--mono);font-size:.57rem;color:var(--text3)}.preview-wrap{display:none;flex-shrink:0;border-bottom:1px solid var(--border);padding:.85rem 1.1rem}.preview-wrap.visible{display:block}.preview-wrap img{width:100%;max-height:140px;object-fit:cover;border-radius:4px;display:block}.file-meta{margin-top:.4rem;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.file-name{font-family:var(--mono);font-size:.6rem;color:var(--text2);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{font-family:var(--mono);font-size:.57rem;color:var(--text3)}.fmt-badge{font-family:var(--mono);font-size:.54rem;letter-spacing:.08em;padding:1px 5px;border-radius:3px;background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-dim)}.sidebar-scroll{flex:1;overflow-y:auto;min-height:0;display:flex;flex-direction:column}.sidebar-bottom{flex-shrink:0;border-top:1px solid var(--border);padding:.9rem 1.1rem;display:flex;flex-direction:column;gap:.5rem}.legal-check-wrap{display:flex;align-items:flex-start;gap:.5rem}.legal-check-wrap input[type=checkbox]{flex-shrink:0;margin-top:2px;accent-color:var(--accent);cursor:pointer}.legal-check-label{font-size:.62rem;color:var(--text3);line-height:1.5;cursor:pointer}.legal-check-label a{color:var(--text2);text-decoration:underline;text-decoration-color:var(--border3)}.legal-check-label a:hover{color:var(--accent)}.main-content{display:flex;flex-direction:column;overflow:hidden;min-height:0;height:100%}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:.9rem;padding:3rem 2rem;text-align:center}.empty-state svg{width:38px;height:38px;stroke:var(--border2);fill:none;stroke-width:1}.empty-state p{font-size:.75rem;color:var(--text3);line-height:1.7}.empty-chips{display:flex;gap:.35rem;justify-content:center}.tab-panel{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;display:none;min-height:0}.tab-panel.active{display:block}.section-title{font-size:.62rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);padding-bottom:.55rem;border-bottom:1px solid var(--border);margin-bottom:.1rem}.fields-block{margin-bottom:1.5rem}.exif-edit-section{border-bottom:1px solid var(--border)}.exif-edit-section:last-child{border-bottom:none}.exif-edit-hdr{padding:.55rem 0;display:flex;align-items:center;gap:.5rem;cursor:pointer;user-select:none}.exif-edit-hdr span{font-family:var(--mono);font-size:.62rem;letter-spacing:.07em;color:var(--text2);text-transform:uppercase}.exif-edit-hdr:hover span{color:var(--text)}.exif-edit-count{background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:0 6px;font-size:.55rem!important;color:var(--text3)!important;margin-left:auto}.exif-edit-rows{padding-bottom:.5rem}.exif-edit-row{display:grid;grid-template-columns:200px 1fr;gap:.75rem;padding:.55rem 0;border-bottom:1px solid var(--border);align-items:start}.exif-edit-row:last-child{border-bottom:none}.exif-edit-row.modified .exif-edit-name{color:var(--accent)}.exif-edit-label{display:flex;flex-direction:column;gap:.2rem;padding-top:.1rem}.exif-edit-name{font-size:.7rem;font-weight:600;color:var(--text);line-height:1.3}.exif-edit-tag{font-family:var(--mono);font-size:.57rem;color:var(--text3)}.exif-edit-input{display:flex;flex-direction:column;gap:.2rem}.raw-toolbar{display:flex;align-items:center;gap:.75rem;padding:.6rem 0 .8rem}.raw-label{font-size:.62rem;font-weight:700;letter-spacing:.1em;color:var(--text3);text-transform:uppercase;margin-right:auto}.raw-search{font-family:var(--mono);font-size:.68rem;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.3rem .55rem;border-radius:var(--r);outline:none;width:180px}.raw-search:focus{border-color:var(--border3)}.raw-search::placeholder{color:var(--text3)}.raw-section{border-bottom:1px solid var(--border)}.raw-section:last-child{border-bottom:none}.raw-section-hdr{padding:.5rem 0;display:flex;align-items:center;gap:.5rem;cursor:pointer;user-select:none}.raw-section-hdr span{font-family:var(--mono);font-size:.6rem;letter-spacing:.08em;color:var(--text2);text-transform:uppercase}.raw-count{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:0 5px;font-size:.55rem!important;color:var(--text3)!important;margin-left:auto}.raw-row{display:grid;grid-template-columns:200px 1fr;border-bottom:1px solid var(--border)}.raw-row:last-child{border-bottom:none}.raw-row:hover{background:var(--surface)}.raw-key{padding:.42rem 0;border-right:1px solid var(--border);display:flex;align-items:center;gap:.35rem;padding-right:.75rem;min-width:0}.raw-key-name{font-family:var(--mono);font-size:.63rem;color:var(--text2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.raw-type{font-family:var(--mono);font-size:.5rem;color:var(--text3);border:1px solid var(--border);border-radius:2px;padding:0 3px;flex-shrink:0}.raw-val{padding:.42rem 0 .42rem .75rem;font-family:var(--mono);font-size:.63rem;color:var(--text2);word-break:break-word}.raw-empty{font-family:var(--mono);font-size:.7rem;color:var(--text3);padding:1.5rem 0}.toast{position:fixed;bottom:1.25rem;right:1.25rem;background:var(--surface2);border:1px solid var(--border2);border-left:3px solid var(--accent);color:var(--text);font-family:var(--mono);font-size:.67rem;padding:.6rem .9rem;border-radius:var(--r);opacity:0;transform:translateY(5px);transition:all .2s;pointer-events:none;z-index:999;max-width:280px;line-height:1.4}.toast.show{opacity:1;transform:none}.toast.error{border-left-color:var(--danger)}@media (max-width:720px){html,body{height:auto;min-height:100vh;overflow:auto}.app{grid-template-columns:1fr;overflow:visible;height:auto;min-height:0;flex:none}.sidebar{border-right:none;border-bottom:1px solid var(--border);overflow:visible;height:auto}.sidebar-scroll{overflow:visible;flex:none;height:auto}.sidebar-bottom{margin-top:0}.main-content{overflow:visible;height:auto;min-height:0}.tab-panel{overflow:visible;min-height:0}#mainPanel{flex:none!important;overflow:visible!important;height:auto!important}.exif-edit-row{grid-template-columns:1fr;gap:.3rem}.raw-row{grid-template-columns:1fr}.raw-key{border-right:none;border-bottom:1px solid var(--border);padding-right:0}}.header-actions{display:flex;align-items:center;gap:.4rem;margin-left:auto}.action-chip{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--mono);font-size:.6rem;letter-spacing:.06em;padding:3px 9px;border-radius:3px;border:1px solid var(--border2);background:#fff0;color:var(--text2);cursor:pointer;text-decoration:none;transition:border-color .12s,color .12s;white-space:nowrap}.action-chip:hover{border-color:var(--border3);color:var(--text)}.action-chip svg{flex-shrink:0}.modal-overlay{position:fixed;inset:0;z-index:9999;background:rgb(0 0 0 / .75);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .18s}.modal-overlay.open{opacity:1;pointer-events:all}.modal-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .75rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-panel-title{font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text2)}.modal-close{background:none;border:none;color:var(--text3);font-size:1.2rem;line-height:1;cursor:pointer;padding:0 .1rem;transition:color .12s}.modal-close:hover{color:var(--text)}.lang-list{list-style:none;overflow-y:auto;padding:.4rem 0}.lang-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;text-decoration:none;transition:background .1s;cursor:pointer}.lang-item:hover{background:var(--surface2)}.lang-item.active{background:var(--accent-bg)}.lang-item.active .lang-native{color:var(--accent)}.lang-item.active .lang-code{color:var(--accent2);border-color:var(--accent-dim)}.lang-native{font-size:.85rem;color:var(--text);font-weight:500}.lang-code{font-family:var(--mono);font-size:.6rem;letter-spacing:.06em;color:var(--text3);border:1px solid var(--border2);border-radius:3px;padding:1px 6px}.lang-panel{background:var(--surface);border:1px solid var(--border2);border-radius:10px;width:min(400px, calc(100vw - 2rem));max-height:min(560px, calc(100vh - 4rem));display:flex;flex-direction:column;overflow:hidden;transform:translateY(8px) scale(.98);transition:transform .18s}.modal-overlay.open .lang-panel{transform:none}.donate-panel{background:var(--surface);border:1px solid var(--border2);border-radius:10px;width:min(480px, calc(100vw - 2rem));max-height:min(90vh, 700px);display:flex;flex-direction:column;overflow:hidden;transform:translateY(8px) scale(.98);transition:transform .18s}.modal-overlay.open .donate-panel{transform:none}.donate-body{padding:1.75rem 1.75rem 1.5rem;overflow-y:auto;display:flex;flex-direction:column;align-items:center;text-align:center;gap:.9rem}.donate-icon{width:56px;height:56px;border-radius:50%;background:#1f0a0a;border:1px solid #3d1515;display:flex;align-items:center;justify-content:center;color:#d55;flex-shrink:0}.donate-heading{font-size:1.05rem;font-weight:700;color:var(--text);letter-spacing:-.01em;line-height:1.3}.donate-text{font-size:.8rem;color:var(--text2);line-height:1.75;max-width:380px}.donate-divider{width:40px;height:1px;background:var(--border2);flex-shrink:0}.donate-btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent);color:#0b0b0b;font-family:var(--sans);font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.7rem 1.5rem;border-radius:6px;text-decoration:none;transition:background .12s;flex-shrink:0}.donate-btn:hover{background:var(--accent2)}.donate-note{font-size:.63rem;color:var(--text3);line-height:1.5}