.tool-main{flex:1;display:flex;flex-direction:column;width:100%;max-width:100%;padding:0;overflow:hidden}.tool-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;padding:1.5rem 2rem;border-bottom:1px solid var(--color-border);background-color:var(--color-surface-raised);flex-shrink:0}.tool-header__title{display:flex;flex-direction:column;gap:.25rem}.tool-title{font-size:1.3rem;font-weight:700;color:var(--color-text-title)}.tool-subtitle{font-size:.85rem;color:var(--color-text-muted)}.hash-workspace{flex:1;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.6fr);min-height:0;overflow:hidden}.hash-col{display:flex;flex-direction:column;overflow-y:auto;min-width:0}.hash-col--input{border-right:1px solid var(--color-border);background-color:var(--color-surface-deep);padding:1.75rem;gap:1.5rem}.hash-col--results{background-color:var(--color-bg);display:flex;flex-direction:column;min-height:0}.options-section{display:flex;flex-direction:column;gap:.55rem}.options-label{font-size:.78rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-muted)}.toggle-group{display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.toggle-btn{padding:.3rem .85rem;border-radius:5px;font-size:.8rem;font-weight:500;border:1px solid var(--color-border);background:none;color:var(--color-text-faint);cursor:pointer;transition:color .12s ease,background-color .12s ease,border-color .12s ease;white-space:nowrap}.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{width:100%;box-sizing:border-box;height:160px;resize:vertical;background-color:var(--color-surface-input);border:1px solid var(--color-border);border-radius:6px;outline:none;padding:.7rem .9rem;color:var(--color-text-primary);font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.85rem;line-height:1.5;caret-color:var(--color-accent);transition:border-color .15s ease}.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{font-size:.73rem;color:var(--color-text-dim);margin-top:.35rem;line-height:1.4;min-height:1em;font-family:Menlo,Monaco,Consolas,Courier New,monospace}.file-drop-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem 1.5rem;border:2px dashed var(--color-border);border-radius:8px;text-align:center;cursor:pointer;transition:border-color .15s ease,background-color .15s ease;background-color:var(--color-surface-input)}.file-drop-zone--over{border-color:var(--color-accent);background-color:var(--color-accent-bg)}.file-drop-zone__icon{font-size:2rem;opacity:.4;line-height:1}.file-drop-zone__text{font-size:.88rem;color:var(--color-text-faint)}.file-browse-label{color:var(--color-accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.file-browse-label:hover{color:var(--color-accent-hover-text)}.file-drop-zone__hint{font-size:.75rem;color:var(--color-text-dim)}.file-input-hidden{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.file-info-bar{display:flex;align-items:center;gap:.75rem;padding:.6rem .9rem;background-color:var(--color-surface-input);border:1px solid var(--color-border);border-radius:6px;min-width:0}.file-info-bar__name{flex:1;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.82rem;color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.file-info-bar__size{font-size:.75rem;color:var(--color-text-ghost);white-space:nowrap;flex-shrink:0}.file-remove-btn{flex-shrink:0;width:22px;height:22px;border-radius:4px;border:none;background:none;color:var(--color-text-ghost);cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:color .12s ease,background-color .12s ease}.file-remove-btn:hover{color:var(--color-danger);background-color:var(--color-danger-bg)}.hmac-key-wrap{display:flex;align-items:stretch;border:1px solid var(--color-border);border-radius:6px;overflow:hidden;background-color:var(--color-surface-input);transition:border-color .15s ease}.hmac-key-wrap:focus-within{border-color:var(--color-accent-border);box-shadow:0 0 0 1px var(--color-accent-bg)}.hash-text-input{flex:1;min-width:0;background:none;border:none;outline:none;padding:.55rem .9rem;color:var(--color-text-primary);font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.85rem;caret-color:var(--color-accent)}.hash-text-input::placeholder{color:var(--color-text-dimmer)}.show-key-btn{display:flex;align-items:center;justify-content:center;width:36px;flex-shrink:0;background:none;border:none;border-left:1px solid var(--color-border-subtle);color:var(--color-text-dim);font-size:.85rem;cursor:pointer;transition:color .15s ease,background-color .15s ease}.show-key-btn:hover{color:var(--color-accent);background-color:var(--color-surface-raised)}.show-key-btn--active{color:var(--color-accent)}.input-hint{font-size:.75rem;color:var(--color-text-dim);line-height:1.4}.input-hint--error{color:var(--color-danger)}.clear-btn{align-self:flex-start;padding:.35rem .85rem;border-radius:5px;font-size:.8rem;font-weight:500;border:1px solid var(--color-border);background:none;color:var(--color-text-faint);cursor:pointer;transition:color .12s ease,border-color .12s ease}.clear-btn:hover{color:var(--color-text-primary);border-color:var(--color-text-ghost)}.results-toolbar{display:flex;align-items:center;justify-content:flex-end;padding:.75rem 1.5rem;border-bottom:1px solid var(--color-border-subtle);background-color:var(--color-surface-deep);flex-shrink:0}.copy-all-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .85rem;border-radius:5px;font-size:.8rem;font-weight:500;cursor:pointer;border:1px solid var(--color-accent-border);background-color:var(--color-accent-bg);color:var(--color-accent);transition:background-color .12s ease,border-color .12s ease,color .12s ease}.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;overflow-y:auto;padding:1rem 0}.hash-row{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border-faint);display:flex;flex-direction:column;gap:.55rem;transition:background-color .1s ease}.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{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}.hash-row__desc{font-size:.72rem;color:var(--color-text-dim);line-height:1.3}.hash-row__digest-wrap{display:flex;align-items:center;gap:.75rem;min-width:0}.hash-digest{font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:.82rem;color:var(--color-accent);word-break:break-all;flex:1;min-width:0;-webkit-user-select:all;user-select:all;line-height:1.5}.hash-row__skipped-msg{font-size:.78rem;color:var(--color-text-dim);font-style:italic}.hash-row__error{font-size:.78rem;color:var(--color-danger)}.hash-alg-badge{display:inline-flex;align-items:center;padding:.18rem .55rem;border-radius:4px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;flex-shrink:0}.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-bits-badge{display:inline-flex;align-items:center;padding:.18rem .5rem;border-radius:4px;font-size:.68rem;font-weight:500;color:var(--color-text-ghost);background-color:var(--color-surface-raised);border:1px solid var(--color-border-subtle);white-space:nowrap;flex-shrink:0;font-family:Menlo,Monaco,Consolas,Courier New,monospace}.copy-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .9rem;border-radius:5px;font-size:.8rem;font-weight:500;cursor:pointer;border:1px solid var(--color-accent-border);background-color:var(--color-accent-bg);color:var(--color-accent);transition:background-color .12s ease,border-color .12s ease,color .12s ease;white-space:nowrap;flex-shrink:0}.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{padding:.2rem .6rem;font-size:.72rem;background-color:transparent;border-color:var(--color-border);color:var(--color-text-faint)}.copy-btn--small:hover{background-color:var(--color-surface-raised);border-color:var(--color-sep);color:var(--color-text-secondary)}.results-computing{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:3rem 2rem;color:var(--color-text-ghost);font-size:.88rem}.computing-spinner{width:18px;height:18px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.computing-label{color:var(--color-text-ghost)}.results-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;text-align:center;padding:4rem 2rem;min-height:220px}.results-placeholder__icon{font-size:3rem;line-height:1;opacity:.12}.results-placeholder__text{font-size:.9rem;color:var(--color-text-dim)}.hash-error{display:flex;align-items:flex-start;gap:.65rem;padding:1rem 1.25rem;margin:1.5rem;background-color:var(--color-warning-bg);border:1px solid var(--color-warning-border);border-radius:6px;color:var(--color-warning);font-size:.85rem;line-height:1.5}.hash-error__icon{flex-shrink:0;font-size:1rem}@media(max-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(max-width:480px){.tool-header{padding:1.25rem}.hash-col--input{padding:1rem;gap:1.25rem}.hash-row{padding:.85rem 1rem}.hash-digest{font-size:.75rem}.hash-row__desc{display:none}}
