.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--border);border-radius:2px;padding:3rem 2.5rem;position:relative;animation:slideUp .5s ease}.login-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent2),var(--accent),var(--accent2));background-size:200%;animation:shimmer 3s linear infinite}.brand-mark{display:flex;align-items:center;gap:.75rem;margin-bottom:2.5rem}.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--accent2),var(--accent));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.brand-name{font-size:1.4rem;font-weight:800;letter-spacing:-.5px}.brand-name span{color:var(--accent)}.login-title{font-size:1.6rem;font-weight:800;margin-bottom:.4rem;letter-spacing:-.5px}.login-sub{font-size:.85rem;color:var(--text-muted);font-family:Space Mono,monospace;margin-bottom:2rem}.field{margin-bottom:1.2rem}.field label{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:.5rem;font-family:Space Mono,monospace}.field input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:2px;padding:.85rem 1rem;color:var(--text);font-family:Space Mono,monospace;font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #00ffc814}.field input::placeholder{color:var(--text-dim)}.btn-primary{width:100%;padding:.9rem;background:var(--accent);color:#0a0a0f;border:none;border-radius:2px;font-family:Syne,sans-serif;font-size:.95rem;font-weight:800;letter-spacing:.5px;cursor:pointer;transition:all .2s;margin-top:.5rem;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary:hover:not(:disabled){background:#00e6b4;transform:translateY(-1px);box-shadow:0 8px 24px #00ffc840}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.demo-creds{margin-top:1.5rem;padding:1rem;background:#7b61ff14;border:1px solid rgba(123,97,255,.2);border-radius:2px}.demo-creds p{font-size:.72rem;font-family:Space Mono,monospace;color:var(--text-muted);line-height:1.7}.demo-creds strong{color:var(--accent2)}.header{background:#11111af2;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:.6rem;font-size:1.1rem;font-weight:800;letter-spacing:-.3px}.header-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent2),var(--accent));border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.9rem}.header-brand span{color:var(--accent)}.header-right{display:flex;align-items:center;gap:1rem}.user-chip{display:flex;align-items:center;gap:.6rem;padding:.4rem .8rem;background:var(--surface2);border:1px solid var(--border);border-radius:100px;font-size:.8rem;color:var(--text-muted);font-family:Space Mono,monospace}.user-avatar{width:22px;height:22px;background:linear-gradient(135deg,var(--accent2),var(--accent));border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff}.btn-logout{background:none;border:1px solid var(--border);border-radius:2px;color:var(--text-muted);font-family:Space Mono,monospace;font-size:.75rem;padding:.4rem .8rem;cursor:pointer;transition:all .2s}.btn-logout:hover{border-color:var(--error);color:var(--error)}.search-section{background:var(--surface);border:1px solid var(--border);border-radius:4px;padding:1.5rem}.search-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);font-family:Space Mono,monospace;margin-bottom:.75rem}.search-row{display:flex;gap:.75rem}.search-input{flex:1;background:var(--surface2);border:1px solid var(--border);border-radius:2px;padding:.75rem 1rem;color:var(--text);font-family:Space Mono,monospace;font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #00ffc814}.search-input.error-border{border-color:var(--error)}.btn-search{padding:.75rem 1.25rem;background:var(--accent);color:#0a0a0f;border:none;border-radius:2px;font-family:Syne,sans-serif;font-weight:800;font-size:.85rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-search:hover:not(:disabled){background:#00e6b4;box-shadow:0 4px 16px #00ffc84d}.btn-search:disabled{opacity:.5;cursor:not-allowed}.btn-clear{padding:.75rem 1rem;background:none;border:1px solid var(--border);border-radius:2px;color:var(--text-muted);font-family:Space Mono,monospace;font-size:.75rem;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-clear:hover{border-color:var(--text-muted);color:var(--text)}.search-error{margin-top:.5rem;font-size:.78rem;color:var(--error);font-family:Space Mono,monospace;display:flex;align-items:center;gap:.4rem}.leaflet-map{height:100%;width:100%}.map-pin{width:14px;height:14px;background:#00ffc8;border:2px solid #0a0a0f;border-radius:50%;box-shadow:0 0 12px #00ffc8b3}.geo-card{background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden;animation:fadeIn .4s ease}.geo-card-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.geo-card-title{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);font-family:Space Mono,monospace}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--success);position:relative}.status-dot:after{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;background:var(--success);opacity:.3;animation:ping 1.5s ease-in-out infinite}.geo-ip{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:.75rem;flex-wrap:wrap}.geo-ip-value{font-size:2rem;font-weight:800;font-family:Space Mono,monospace;color:var(--accent);letter-spacing:-1px}.geo-ip-tag{font-size:.7rem;font-family:Space Mono,monospace;color:var(--text-muted);background:var(--surface2);padding:.2rem .6rem;border-radius:100px;border:1px solid var(--border)}.geo-grid{display:grid;grid-template-columns:1fr 1fr}.geo-item{padding:1rem 1.5rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border)}.geo-item:nth-child(2n){border-right:none}.geo-item-label{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);font-family:Space Mono,monospace;margin-bottom:.3rem}.geo-item-value{font-size:.9rem;font-weight:600;color:var(--text);font-family:Space Mono,monospace}.map-container{height:280px;border-top:1px solid var(--border)}.right-panel{border-left:1px solid var(--border);display:flex;flex-direction:column;height:100%;overflow:hidden}.panel-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.panel-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);font-family:Space Mono,monospace}.btn-delete-selected{padding:.3rem .7rem;background:#ff47571a;border:1px solid rgba(255,71,87,.3);border-radius:2px;color:var(--error);font-family:Space Mono,monospace;font-size:.68rem;cursor:pointer;transition:all .2s}.btn-delete-selected:hover{background:#ff475733}.history-list{flex:1;overflow-y:auto;padding:.5rem 0}.history-list::-webkit-scrollbar{width:4px}.history-list::-webkit-scrollbar-track{background:transparent}.history-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.history-empty{padding:3rem 1.5rem;text-align:center;color:var(--text-dim);font-family:Space Mono,monospace;font-size:.78rem;line-height:1.8}.history-empty span{color:var(--text-dim)}.history-item{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.5rem;border-bottom:1px solid rgba(42,42,69,.5);cursor:pointer;transition:background .15s;animation:fadeIn .3s ease}.history-item:hover{background:var(--surface)}.history-item.active-item{background:#00ffc80d;border-left:2px solid var(--accent)}.history-checkbox{width:16px;height:16px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--surface2);border:1px solid var(--border);border-radius:2px;cursor:pointer;flex-shrink:0;position:relative;transition:all .15s}.history-checkbox:checked{background:var(--accent2);border-color:var(--accent2)}.history-checkbox:checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.65rem;color:#fff;line-height:1}.history-info{flex:1;min-width:0}.history-ip{font-family:Space Mono,monospace;font-size:.85rem;font-weight:700;color:var(--text);margin-bottom:.2rem}.history-meta{font-size:.7rem;color:var(--text-muted);font-family:Space Mono,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-time{font-size:.65rem;color:var(--text-dim);font-family:Space Mono,monospace;flex-shrink:0}@media (max-width: 900px){.right-panel{border-left:none;border-top:1px solid var(--border);height:320px}}.home-layout{display:grid;grid-template-rows:auto 1fr;min-height:100vh}.main-content{display:grid;grid-template-columns:1fr 380px;height:calc(100vh - 64px)}.left-panel{padding:2rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.5rem}.left-panel::-webkit-scrollbar{width:4px}.left-panel::-webkit-scrollbar-track{background:transparent}.left-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}@media (max-width: 900px){.main-content{grid-template-columns:1fr;grid-template-rows:1fr auto;height:auto}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--surface: #11111a;--surface2: #18182a;--border: #2a2a45;--accent: #00ffc8;--accent2: #7b61ff;--text: #e8e8f0;--text-muted: #6b6b8a;--text-dim: #3a3a5a;--success: #00e67a;--error: #ff4757}html,body{height:100%}body{font-family:Syne,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,255,200,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,255,200,.03) 1px,transparent 1px);background-size:40px 40px;pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh}@keyframes shimmer{to{background-position:200%}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes ping{0%{transform:scale(1);opacity:1}to{transform:scale(2);opacity:0}}.spinner{width:18px;height:18px;border:2px solid rgba(0,255,200,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0;display:inline-block}.skeleton{background:linear-gradient(90deg,var(--surface2) 25%,var(--border) 50%,var(--surface2) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:4px;height:1rem}.error-msg{padding:.75rem 1rem;background:#ff47571a;border:1px solid rgba(255,71,87,.3);border-radius:2px;color:var(--error);font-size:.82rem;font-family:Space Mono,monospace;margin-bottom:1.2rem}
