*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#1a1a1a;min-height:100dvh}#app{max-width:600px;margin:0 auto;padding:12px 10px}.screen{display:flex;flex-direction:column}.screen[hidden]{display:none!important}h1{font-size:1.1rem;font-weight:600;margin-bottom:8px}#login-screen{margin-top:20vh;align-items:center}#login-form{width:100%;max-width:320px;display:flex;flex-direction:column;gap:12px}input[type=password],input[type=search]{width:100%;padding:10px 12px;font-size:.95rem;border:1.5px solid #ddd;border-radius:6px;outline:none;transition:border-color .15s}input:focus{border-color:#2563eb}button[type=submit]{padding:12px;font-size:1rem;font-weight:600;background:#2563eb;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .15s}button[type=submit]:hover{background:#1d4ed8}.error{color:#dc2626;font-size:.875rem;text-align:center}.search-header{display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:8px}.header-left h1{margin-bottom:0}.kb-toggle{font-size:1.2rem}.kb-toggle.active{background:#eff6ff;color:#2563eb}.nav-buttons{display:flex;gap:4px;align-items:center}.nav-link{color:#2563eb;text-decoration:none;font-size:.75rem;font-weight:600;border-radius:6px;background:#eff6ff;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.nav-btn{background:#f3f4f6;border:none;color:#6b7280;font-size:.65rem;font-weight:500;cursor:pointer;border-radius:6px;width:48px;height:48px;display:flex;align-items:center;justify-content:center}.link-btn{background:none;border:none;color:#6b7280;font-size:.8rem;cursor:pointer;text-decoration:underline}.search-bar{display:flex;gap:6px;margin-bottom:4px}#search-input{flex:1;min-width:0}.clear-btn{flex-shrink:0;width:48px;background:#f3f4f6;border:1.5px solid #ddd;border-radius:6px;color:#6b7280;font-size:1.1rem;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background .1s}.clear-btn:active{background:#e5e7eb}#keypad{position:fixed;left:50%;bottom:0;transform:translate(-50%);width:100%;max-width:600px;padding:8px 10px calc(8px + env(safe-area-inset-bottom));background:#e9eaed;border-top:1px solid #d1d5db;box-shadow:0 -3px 12px #0000001f;z-index:50}#keypad[hidden]{display:none}#search-screen.keypad-open #results-list,#search-screen.keypad-open #no-results{padding-bottom:440px}.numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;max-width:300px;margin:0 auto 8px}.numpad[hidden],.alphapad[hidden]{display:none}.alphapad{display:flex;flex-direction:column;gap:6px}.alpha-row{display:flex;gap:4px}.alpha-row .numpad-key{flex:1;min-width:0;padding:12px 0;font-size:1.05rem}.alpha-space{flex:1;text-transform:none;color:#6b7280}.numpad-key{padding:14px 0;font-size:1.35rem;font-weight:600;background:#fff;color:#1a1a1a;border:1.5px solid #ddd;border-radius:8px;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background .1s,border-color .1s}.numpad-key:active{background:#eff6ff;border-color:#2563eb}.numpad-dash,.numpad-back{color:#6b7280}.search-options{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.checkbox-label{font-size:.75rem;color:#6b7280;cursor:pointer;display:flex;align-items:center;gap:4px}.checkbox-label input{margin:0}.meta{font-size:.75rem;color:#9ca3af}#results-list{list-style:none;display:flex;flex-direction:column;gap:2px}#results-list li{background:#fff;border-radius:4px;overflow:hidden}#results-list a{display:flex;align-items:flex-start;gap:8px;padding:6px 10px;text-decoration:none;color:inherit;transition:background .1s}#results-list a:hover{background:#eff6ff}.result-icon{flex-shrink:0;width:16px;height:16px;margin-top:1px}.result-info{flex:1;min-width:0}.result-name{font-weight:600;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.result-bottom{display:flex;align-items:baseline;gap:6px;margin-top:1px}.result-path{font-size:.65rem;color:#9ca3af;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.result-date{font-size:.6rem;color:#b0b7c0;white-space:nowrap;flex-shrink:0}#no-results{text-align:center;color:#6b7280;margin-top:32px;font-size:.875rem}
