:root{font-family:SF Mono,IBM Plex Mono,Fira Code,Consolas,monospace;line-height:1.5;font-weight:400;color-scheme:dark;color:#e5e5e5;background-color:#0d0d0d;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}.app{--bg: #0d0d0d;--surface: #141414;--border: #262626;--text: #e5e5e5;--text-muted: #737373;--accent: #fff;--error: #f87171;display:flex;flex-direction:column;min-height:100vh;max-width:560px;margin:0 auto;padding:2rem 1.25rem}.footer{margin-top:auto;padding-top:2rem;font-size:.75rem;color:var(--text-muted);text-align:center}.footer__heart{color:var(--error)}.header{margin-bottom:2rem}.header h1{font-size:1.5rem;font-weight:600;letter-spacing:-.02em;color:var(--text);margin:0 0 .25rem}.tagline{font-size:.8125rem;color:var(--text-muted);margin:0}.security-note{font-size:.75rem;color:var(--text-muted);margin:.25rem 0 0}.coming-soon{font-size:.75rem;color:var(--text-muted);margin:.5rem 0 0;opacity:.85}.security{margin-top:2rem;padding:1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:6px}.security__title{font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin:0 0 .75rem}.security__list{list-style:none;padding:0;margin:0}.security__list li{font-size:.8125rem;color:var(--text-muted);line-height:1.5;padding:.25rem 0 .25rem 1rem;position:relative}.security__list li:before{content:"—";position:absolute;left:0;color:var(--text);opacity:.6}.dropzone{position:relative;border:1px dashed var(--border);background:var(--surface);border-radius:6px;padding:2rem;text-align:center;transition:border-color .15s,background .15s}.dropzone:hover:not(.dropzone--disabled),.dropzone--active{border-color:var(--text-muted);background:#1a1a1a}.dropzone--disabled{opacity:.85}.dropzone--disabled .dropzone__input{cursor:not-allowed}.dropzone__input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}.dropzone__text{font-size:.875rem;color:var(--text-muted);pointer-events:none}@media(max-width:480px){.app{padding:1.25rem 1rem}.header{margin-bottom:1.5rem}.dropzone{padding:1.25rem 1rem;min-height:0}.dropzone__text{font-size:.8125rem}}.error{font-size:.8125rem;color:var(--error);margin:.75rem 0 0}.list{list-style:none;padding:0;margin:1.5rem 0 0;border:1px solid var(--border);border-radius:6px;overflow:hidden}.list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);font-size:.875rem;cursor:grab}.list-item:last-child{border-bottom:none}.list-item:active{cursor:grabbing}.list-item--dragging{opacity:.5}.list-item--drop-target{background:#1a1a1a;outline:1px solid var(--text-muted);outline-offset:-1px}.list-item__handle{color:var(--text-muted);font-size:.75rem;letter-spacing:-.1em;-webkit-user-select:none;user-select:none;flex-shrink:0}.list-item__name{flex:1;min-width:0;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-item__pages{flex-shrink:0;color:var(--text-muted);font-size:.8125rem}.list-item__remove{flex-shrink:0;width:1.75rem;height:1.75rem;padding:0;display:inline-flex;align-items:center;justify-content:center;background:transparent;border:1px solid var(--border);color:var(--text-muted);font-size:1.1rem;line-height:1;border-radius:4px;cursor:pointer;transition:color .15s,border-color .15s}.list-item__remove:hover{color:var(--text);border-color:var(--text-muted)}.actions{margin-top:1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.actions__summary{font-size:.8125rem;color:var(--text-muted);margin:0}.button{font-size:.875rem;font-weight:500;padding:.625rem 1.25rem;border-radius:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}.button:hover:not(:disabled){background:#1a1a1a;border-color:var(--text-muted)}.button:disabled{opacity:.6;cursor:not-allowed}.button--primary{background:var(--accent);color:var(--bg);border-color:var(--accent)}.button--primary:hover:not(:disabled){background:#e5e5e5;border-color:#e5e5e5}
