:root{--hash-blake2-bg:#1a1a2e;--hash-blake2-text:#a78bfa;--hash-blake2-border:#3b2d6b;--hash-blake3-bg:#1a2e1a;--hash-blake3-text:#86efac;--hash-blake3-border:#2d6b3b}[data-theme=light]{--hash-blake2-bg:#ede9fe;--hash-blake2-text:#6d28d9;--hash-blake2-border:#c4b5fd;--hash-blake3-bg:#dcfce7;--hash-blake3-text:#15803d;--hash-blake3-border:#86efac}.tool-main{flex-direction:column;flex:1;width:100%;max-width:100%;padding:0;display:flex;overflow:hidden}.tool-header{border-bottom:1px solid var(--color-border);background-color:var(--color-surface-raised);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:1.5rem;padding:1.5rem 2rem;display:flex}.tool-header__title{flex-direction:column;gap:.25rem;display:flex}.tool-title{color:var(--color-text-title);margin:0;font-size:1.3rem;font-weight:700}.tool-subtitle{color:var(--color-text-muted);margin:0;font-size:.85rem}.hash-workspace{flex:1;grid-template-columns:minmax(0,1fr) minmax(0,1.6fr);min-height:0;display:grid;overflow:hidden}.hash-col{flex-direction:column;min-width:0;display:flex;overflow-y:auto}.hash-col--input{border-right:1px solid var(--color-border);background-color:var(--color-surface-deep);gap:1.5rem;padding:1.75rem}.hash-col--results{background-color:var(--color-bg);flex-direction:column;min-height:0;display:flex}.options-section{flex-direction:column;gap:.55rem;display:flex}.options-label{letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted);font-size:.78rem;font-weight:600}.toggle-group{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.toggle-btn{border:1px solid var(--color-border);color:var(--color-text-faint);cursor:pointer;white-space:nowrap;background:0 0;border-radius:5px;padding:.3rem .85rem;font-size:.8rem;font-weight:500;transition:color .12s,background-color .12s,border-color .12s}.toggle-btn:hover{color:var(--color-text-secondary);border-color:var(--color-sep)}.toggle-btn--active{background-color:var(--color-accent-bg);color:var(--color-accent);border-color:var(--color-accent-border)}.toggle-btn--active:hover{background-color:var(--color-accent-hover-bg);border-color:var(--color-accent);color:var(--color-accent-hover-text)}.hash-textarea{box-sizing:border-box;resize:vertical;background-color:var(--color-surface-input);border:1px solid var(--color-border);width:100%;height:160px;color:var(--color-text-primary);caret-color:var(--color-accent);border-radius:6px;outline:none;padding:.7rem .9rem;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.85rem;line-height:1.5;transition:border-color .15s}.hash-textarea:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 1px var(--color-accent-bg)}.hash-textarea::placeholder{color:var(--color-text-dimmer)}.input-meta{color:var(--color-text-dim);min-height:1em;margin-top:.35rem;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.73rem;line-height:1.4}.file-drop-zone{border:2px dashed var(--color-border);text-align:center;cursor:pointer;background-color:var(--color-surface-input);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2rem 1.5rem;transition:border-color .15s,background-color .15s;display:flex}.file-drop-zone--over{border-color:var(--color-accent);background-color:var(--color-accent-bg)}.file-drop-zone__icon{opacity:.4;font-size:2rem;line-height:1}.file-drop-zone__text{color:var(--color-text-faint);font-size:.88rem}.file-browse-label{color:var(--color-accent);cursor:pointer;text-underline-offset:2px;text-decoration:underline}.file-browse-label:hover{color:var(--color-accent-hover-text)}.file-drop-zone__hint{color:var(--color-text-dim);font-size:.75rem}.file-input-hidden{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.file-info-bar{background-color:var(--color-surface-input);border:1px solid var(--color-border);border-radius:6px;align-items:center;gap:.75rem;min-width:0;padding:.6rem .9rem;display:flex}.file-info-bar__name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.82rem;overflow:hidden}.file-info-bar__size{color:var(--color-text-ghost);white-space:nowrap;flex-shrink:0;font-size:.75rem}.file-remove-btn{width:22px;height:22px;color:var(--color-text-ghost);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;transition:color .12s,background-color .12s;display:flex}.file-remove-btn:hover{color:var(--color-danger);background-color:var(--color-danger-bg)}.hmac-key-wrap{border:1px solid var(--color-border);background-color:var(--color-surface-input);border-radius:6px;align-items:stretch;transition:border-color .15s;display:flex;overflow:hidden}.hmac-key-wrap:focus-within{border-color:var(--color-accent-border);box-shadow:0 0 0 1px var(--color-accent-bg)}.hash-text-input{min-width:0;color:var(--color-text-primary);caret-color:var(--color-accent);background:0 0;border:none;outline:none;flex:1;padding:.55rem .9rem;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.85rem}.hash-text-input::placeholder{color:var(--color-text-dimmer)}.show-key-btn{border:none;border-left:1px solid var(--color-border-subtle);width:36px;color:var(--color-text-dim);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;font-size:.85rem;transition:color .15s,background-color .15s;display:flex}.show-key-btn:hover{color:var(--color-accent);background-color:var(--color-surface-raised)}.show-key-btn--active{color:var(--color-accent)}.input-hint{color:var(--color-text-dim);font-size:.75rem;line-height:1.4}.input-hint--error{color:var(--color-danger)}.input-hint--warn{color:var(--color-warning)}.results-toolbar{border-bottom:1px solid var(--color-border-subtle);background-color:var(--color-surface-deep);flex-shrink:0;justify-content:flex-end;align-items:center;padding:.75rem 1.5rem;display:flex}.copy-all-btn{cursor:pointer;border:1px solid var(--color-accent-border);background-color:var(--color-accent-bg);color:var(--color-accent);border-radius:5px;align-items:center;gap:.35rem;padding:.3rem .85rem;font-size:.8rem;font-weight:500;transition:background-color .12s,border-color .12s,color .12s;display:inline-flex}.copy-all-btn:hover{background-color:var(--color-accent-hover-bg);border-color:var(--color-accent);color:var(--color-accent-hover-text)}.copy-all-btn.copy-btn--copied{background-color:var(--color-success-bg);border-color:var(--color-success-border);color:var(--color-success)}.results-inner{flex:1;padding:1rem 0;overflow-y:auto}.hash-row{border-bottom:1px solid var(--color-border-faint);flex-direction:column;gap:.55rem;padding:1rem 1.5rem;transition:background-color .1s;display:flex}.hash-row:hover{background-color:var(--color-surface-raised)}.hash-row:last-child{border-bottom:none}.hash-row--skipped{opacity:.45}.hash-row--error .hash-row__digest-wrap{display:none}.hash-row__header{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.hash-row__desc{color:var(--color-text-dim);font-size:.72rem;line-height:1.3}.hash-row__digest-wrap{align-items:center;gap:.75rem;min-width:0;display:flex}.hash-digest{color:var(--color-accent);word-break:break-all;-webkit-user-select:all;user-select:all;flex:1;min-width:0;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.82rem;line-height:1.5}.hash-row__skipped-msg{color:var(--color-text-dim);font-size:.78rem;font-style:italic}.hash-row__error{color:var(--color-danger);font-size:.78rem}.hash-alg-badge{letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:4px;flex-shrink:0;align-items:center;padding:.18rem .55rem;font-size:.72rem;font-weight:700;display:inline-flex}.hash-alg-badge--md5{background-color:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}.hash-alg-badge--sha1{background-color:var(--color-surface-raised);color:var(--color-text-secondary);border:1px solid var(--color-border)}.hash-alg-badge--sha2{background-color:var(--color-accent-bg);color:var(--color-accent);border:1px solid var(--color-accent-border)}.hash-alg-badge--sha3{background-color:var(--color-success-bg);color:var(--color-success);border:1px solid var(--color-success-border)}.hash-alg-badge--crc{background-color:var(--color-warning-bg);color:var(--color-warning);border:1px solid var(--color-warning-border)}.hash-alg-badge--blake2{background-color:var(--hash-blake2-bg);color:var(--hash-blake2-text);border:1px solid var(--hash-blake2-border)}.hash-alg-badge--blake3{background-color:var(--hash-blake3-bg);color:var(--hash-blake3-text);border:1px solid var(--hash-blake3-border)}.hash-bits-badge{color:var(--color-text-ghost);background-color:var(--color-surface-raised);border:1px solid var(--color-border-subtle);white-space:nowrap;border-radius:4px;flex-shrink:0;align-items:center;padding:.18rem .5rem;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.68rem;font-weight:500;display:inline-flex}.copy-btn{cursor:pointer;border:1px solid var(--color-accent-border);background-color:var(--color-accent-bg);color:var(--color-accent);white-space:nowrap;border-radius:5px;flex-shrink:0;align-items:center;gap:.35rem;padding:.35rem .9rem;font-size:.8rem;font-weight:500;transition:background-color .12s,border-color .12s,color .12s;display:inline-flex}.copy-btn:hover{background-color:var(--color-accent-hover-bg);border-color:var(--color-accent);color:var(--color-accent-hover-text)}.copy-btn--copied{background-color:var(--color-success-bg)!important;border-color:var(--color-success-border)!important;color:var(--color-success)!important}.copy-btn--small{border-color:var(--color-border);color:var(--color-text-faint);background-color:#0000;padding:.2rem .6rem;font-size:.72rem}.copy-btn--small:hover{background-color:var(--color-surface-raised);border-color:var(--color-sep);color:var(--color-text-secondary)}.results-computing{color:var(--color-text-ghost);justify-content:center;align-items:center;gap:.75rem;padding:3rem 2rem;font-size:.88rem;display:flex}.computing-spinner{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;flex-shrink:0;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.computing-label{color:var(--color-text-ghost)}.results-placeholder{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.85rem;min-height:220px;padding:4rem 2rem;display:flex}.results-placeholder__icon{opacity:.12;font-size:3rem;line-height:1}.results-placeholder__text{color:var(--color-text-dim);font-size:.9rem}.hash-error{background-color:var(--color-warning-bg);border:1px solid var(--color-warning-border);color:var(--color-warning);border-radius:6px;align-items:flex-start;gap:.65rem;margin:1.5rem;padding:1rem 1.25rem;font-size:.85rem;line-height:1.5;display:flex}.hash-error__icon{flex-shrink:0;font-size:1rem}.folder-drop-zone{border:2px dashed var(--color-border);text-align:center;cursor:pointer;background-color:var(--color-surface-input);border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2rem 1.5rem;transition:border-color .15s,background-color .15s;display:flex}.folder-drop-zone--over{border-color:var(--color-accent);background-color:var(--color-accent-bg)}.folder-drop-zone__icon{opacity:.4;line-height:1}.folder-drop-zone__text{color:var(--color-text-faint);font-size:.88rem}.folder-drop-zone__hint{color:var(--color-text-dim);font-size:.75rem}.folder-info-bar{background-color:var(--color-surface-input);border:1px solid var(--color-border);border-radius:6px;align-items:center;gap:.75rem;min-width:0;padding:.6rem .9rem;display:flex}.folder-info-bar__name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.82rem;overflow:hidden}.folder-info-bar__count{color:var(--color-text-ghost);white-space:nowrap;flex-shrink:0;font-size:.75rem}.folder-alg-select{box-sizing:border-box;background-color:var(--color-surface-input);border:1px solid var(--color-border);width:100%;color:var(--color-text-primary);cursor:pointer;appearance:auto;border-radius:6px;outline:none;padding:.45rem .75rem;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.82rem}.folder-alg-select:focus{border-color:var(--color-accent-border);box-shadow:0 0 0 1px var(--color-accent-bg)}.folder-progress{color:var(--color-text-ghost);align-items:center;gap:.65rem;padding:.5rem 0;font-size:.78rem;display:flex}.folder-progress__bar{background-color:var(--color-border);border-radius:2px;flex:1;height:4px;overflow:hidden}.folder-progress__fill{background-color:var(--color-accent);border-radius:2px;height:100%;transition:width .15s}.folder-progress__label{white-space:nowrap;flex-shrink:0;font-family:Menlo,Monaco,Consolas,Courier New,monospace}.manifest-table-wrap{flex:1;min-height:0;overflow:auto}.manifest-table{border-collapse:collapse;width:100%;font-size:.8rem}.manifest-table th{z-index:1;background-color:var(--color-surface-deep);text-align:left;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:.6rem 1rem;font-size:.72rem;font-weight:600;position:sticky;top:0}.manifest-table th.manifest-th--size,.manifest-table td.manifest-td--size{text-align:right;white-space:nowrap}.manifest-table td{border-bottom:1px solid var(--color-border-faint);color:var(--color-text-primary);vertical-align:middle;padding:.5rem 1rem}.manifest-table tr:hover td{background-color:var(--color-surface-raised)}.manifest-td--path{word-break:break-all;min-width:180px;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.78rem}.manifest-td--size{color:var(--color-text-ghost);white-space:nowrap;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.75rem}.manifest-td--hash{color:var(--color-accent);word-break:break-all;-webkit-user-select:all;user-select:all;min-width:200px;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.75rem}.manifest-td--pending{color:var(--color-text-dim);font-style:italic}.manifest-td--error{color:var(--color-danger);font-size:.75rem}.manifest-toolbar{border-bottom:1px solid var(--color-border-subtle);background-color:var(--color-surface-deep);flex-shrink:0;justify-content:flex-end;align-items:center;gap:.5rem;padding:.75rem 1.5rem;display:flex}@media (width<=900px){.hash-workspace{grid-template-columns:1fr;overflow-y:auto}.hash-col--input{border-right:none;border-bottom:1px solid var(--color-border);padding:1.25rem}.hash-col--results{min-height:320px}}@media (width<=480px){.tool-header{padding:1.25rem}.hash-col--input{gap:1.25rem;padding:1rem}.hash-row{padding:.85rem 1rem}.hash-digest{font-size:.75rem}.hash-row__desc{display:none}}
