*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}img,svg{display:block;max-width:100%}button{cursor:pointer;font:inherit}input,textarea{font:inherit}table{border-collapse:collapse}a{color:inherit}:root{--bg: #0a0a0f;--bg-surface: #12121a;--bg-elevated: #1a1a26;--bg-hover: #22222e;--border: #2a2a3a;--border-accent: #4a4a6a;--text: #e8e8f0;--text-secondary: #8888a0;--text-dim: #55556a;--accent: #6c7aff;--accent-hover: #8290ff;--accent-dim: #3a3a6a;--success: #4ade80;--error: #f87171;--warning: #fbbf24;--radius: 8px;--radius-lg: 12px;--radius-sm: 4px;--transition: .2s ease;--sidebar-width: 320px;--font-mono: "SF Mono", "Cascadia Code", "Fira Code", "JetBrains Mono", monospace}#app{min-height:0;flex:1;overflow:hidden}body{display:flex;flex-direction:column;height:100vh;overflow:hidden}.site-footer{flex-shrink:0;padding:10px 20px;font-size:11px;line-height:1.6;color:var(--text-dim);background:var(--bg-surface);border-top:1px solid var(--border);text-align:center}.site-footer strong{color:var(--text-secondary)}.site-footer__sep{margin:0 6px;opacity:.4}.site-footer__help{color:var(--accent);text-decoration:none;cursor:pointer}.site-footer__help:hover{text-decoration:underline;color:var(--accent-hover)}.help-panel{margin-top:8px;padding-top:8px;border-top:1px solid var(--border);text-align:left;max-width:700px;margin-left:auto;margin-right:auto}.help-panel p{margin:0 0 6px}.app-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;height:100%;overflow:hidden}.app-layout__sidebar{background:var(--bg-surface);border-right:1px solid var(--border);overflow-y:auto;padding:20px}.app-layout__main{display:flex;flex-direction:column;overflow:hidden}.app-layout__viz{flex:1;overflow:hidden;display:flex;flex-direction:column}.drop-zone{height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);transition:background var(--transition);position:relative}.drop-zone:before{content:"";position:absolute;inset:20px;border:2px dashed var(--border);border-radius:var(--radius-lg);pointer-events:none;transition:border-color var(--transition),background var(--transition)}.drop-zone--active:before{border-color:var(--accent);background:#6c7aff0d}.drop-zone__content{text-align:center;z-index:1}.drop-zone__icon{color:var(--text-dim);margin:0 auto 24px;transition:color var(--transition),transform var(--transition)}.drop-zone--active .drop-zone__icon{color:var(--accent);transform:translateY(-8px)}.drop-zone__title{font-size:28px;font-weight:600;color:var(--text);margin-bottom:8px}.drop-zone__subtitle{color:var(--text-secondary);font-size:16px;margin-bottom:16px}.drop-zone__browse{color:var(--accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.drop-zone__browse:hover{color:var(--accent-hover)}.drop-zone__hint{color:var(--text-dim);font-size:13px;max-width:400px;margin:0 auto}.drop-zone .progress{position:absolute;bottom:40px;left:50%;transform:translate(-50%);width:300px}.sidebar__header{display:flex;align-items:flex-start;gap:12px;margin-bottom:20px}.sidebar__icon{font-size:32px;line-height:1;flex-shrink:0}.sidebar__file-info{min-width:0}.sidebar__filename{font-size:16px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__meta{font-size:13px;color:var(--text-secondary)}.sidebar__summary{background:var(--bg-elevated);border-radius:var(--radius);padding:12px;margin-bottom:20px;font-size:13px;color:var(--text-secondary);line-height:1.6}.sidebar__metadata h3{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);margin-bottom:8px}.sidebar__table-wrap{max-height:calc(100vh - 380px);overflow-y:auto;margin-bottom:20px}.sidebar__table{width:100%;font-size:12px;font-family:var(--font-mono)}.sidebar__table tr{border-bottom:1px solid var(--border)}.sidebar__key{color:var(--accent);padding:6px 8px 6px 0;white-space:nowrap;vertical-align:top;width:1%}.sidebar__val{color:var(--text-secondary);padding:6px 0;word-break:break-all;max-width:0}.sidebar__actions{padding-top:12px;border-top:1px solid var(--border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;font-weight:500;background:var(--bg-elevated);color:var(--text);transition:all var(--transition)}.btn:hover{background:var(--bg-hover);border-color:var(--border-accent)}.btn--primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn--secondary{width:100%}.progress{display:flex;flex-direction:column;gap:6px}.progress__label{font-size:12px;color:var(--text-secondary);text-align:center}.progress__track{height:4px;background:var(--bg-elevated);border-radius:2px;overflow:hidden}.progress__bar{height:100%;background:var(--accent);border-radius:2px;width:0%;transition:width .3s ease}.viz-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 16px;background:var(--bg-surface);flex-shrink:0;overflow-x:auto;scrollbar-width:thin}.viz-tab{padding:10px 16px;border:none;background:none;color:var(--text-secondary);font-size:13px;font-weight:500;border-bottom:2px solid transparent;transition:all var(--transition);white-space:nowrap;flex-shrink:0}.viz-tab:hover{color:var(--text)}.viz-tab--active{color:var(--accent);border-bottom-color:var(--accent)}.viz-content{flex:1;overflow:auto;padding:16px}.viz-loading,.viz-empty,.viz-error{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-dim);font-size:14px}.viz-error{color:var(--error)}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:var(--radius);font-size:13px;color:var(--text);opacity:0;transform:translate(20px);transition:all .3s ease;max-width:400px}.toast--visible{opacity:1;transform:translate(0)}.toast--info{background:var(--bg-elevated);border:1px solid var(--border)}.toast--error{background:#2a1515;border:1px solid var(--error)}.toast--success{background:#152a15;border:1px solid var(--success)}.metadata-viz{font-family:var(--font-mono);font-size:12px}.metadata-viz table{width:100%}.metadata-viz th{text-align:left;padding:8px 12px;background:var(--bg-elevated);color:var(--text-dim);font-size:11px;text-transform:uppercase;letter-spacing:.05em}.metadata-viz td{padding:6px 12px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.metadata-viz td:first-child{color:var(--accent);white-space:nowrap;width:1%}.text-viz{font-family:var(--font-mono);font-size:13px;line-height:1.6;color:var(--text);white-space:pre-wrap;word-break:break-word;background:var(--bg-elevated);padding:16px;border-radius:var(--radius);overflow:auto;max-height:100%}.text-viz .line-number{color:var(--text-dim);user-select:none;display:inline-block;width:4ch;text-align:right;margin-right:16px}.hex-viz{font-family:var(--font-mono);font-size:12px;line-height:1.4;overflow:auto;max-height:100%}.hex-viz__row{display:flex;gap:0}.hex-viz__offset{color:var(--text-dim);width:9ch;flex-shrink:0;text-align:right;padding-right:12px;user-select:none}.hex-viz__bytes{flex:1;display:flex;flex-wrap:wrap;gap:0 6px}.hex-viz__byte{width:2ch;text-align:center}.hex-viz__byte--null{color:var(--text-dim)}.hex-viz__byte--printable{color:var(--success)}.hex-viz__byte--high{color:var(--accent)}.hex-viz__byte--control{color:var(--error)}.hex-viz__ascii{width:16ch;flex-shrink:0;padding-left:12px;border-left:1px solid var(--border);color:var(--text-secondary)}.image-viz{display:flex;align-items:center;justify-content:center;height:100%;overflow:auto;background:repeating-conic-gradient(var(--bg-elevated) 0% 25%,var(--bg) 0% 50%) 50% / 20px 20px}.image-viz canvas,.image-viz img{max-width:100%;max-height:100%;object-fit:contain}.pdf-viz{display:flex;flex-direction:column;align-items:center;gap:16px;padding:16px}.pdf-viz__page-wrap{position:relative;box-shadow:0 2px 8px #0000004d;border-radius:var(--radius-sm);overflow:hidden}.pdf-viz__page{display:block}.textLayer{color-scheme:inherit!important;user-select:none}.textLayer span{user-select:text}.textLayer ::selection{background:#64a0ff59}.textLayer .endOfContent{position:absolute;inset:100% 0 0;user-select:none;z-index:0}.textLayer.selecting .endOfContent{top:0}.pdf-viz__nav{display:flex;align-items:center;gap:12px;position:sticky;top:0;background:var(--bg-surface);padding:8px 16px;border-radius:var(--radius);z-index:1}.entropy-viz{display:flex;flex-direction:column;gap:12px}.entropy-viz__canvas{width:100%;border-radius:var(--radius)}.entropy-viz__legend{display:flex;justify-content:space-between;font-size:11px;color:var(--text-dim);padding:0 4px}.font-viz{display:flex;flex-direction:column;gap:24px}.font-viz__sample{font-size:48px;line-height:1.3;color:var(--text);word-break:break-all}.font-viz__glyphs{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:8px}.font-viz__glyph{display:flex;align-items:center;justify-content:center;aspect-ratio:1;background:var(--bg-elevated);border-radius:var(--radius-sm);font-size:28px;color:var(--text)}.archive-viz{font-family:var(--font-mono);font-size:12px}.archive-viz table{width:100%}.archive-viz th{text-align:left;padding:8px 12px;background:var(--bg-elevated);color:var(--text-dim);font-size:11px;text-transform:uppercase;position:sticky;top:0}.archive-viz td{padding:6px 12px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.archive-viz__dir{color:var(--accent)}
