* { box-sizing: border-box; margin: 0; padding: 0; }

body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif; height: 100vh; display: flex; }

/* Map layout */
#sidebar {
  width: 300px;
  min-width: 300px;
  background: #fff;
  border-right: 1px solid #ddd;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 16px;
  overflow-y: auto;
}

#sidebar h2 {
  font-size: 1.1rem;
  color: #1a1a2e;
  margin-bottom: 12px;
}

#search-form input {
  display: block;
  width: 100%;
  padding: 8px 10px;
  margin-bottom: 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 0.875rem;
}

#search-form button {
  width: 48%;
  padding: 8px;
  border: none;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.875rem;
}

#search-form button[type="submit"] { background: #1a73e8; color: #fff; margin-right: 4%; }
#search-form button[type="button"] { background: #e8eaf6; color: #333; }

#result-count { font-size: 0.8rem; color: #666; margin: 10px 0 6px; }

#result-list { font-size: 0.8rem; }
.result-item { padding: 6px 0; border-bottom: 1px solid #f0f0f0; cursor: pointer; }
.result-item:hover { background: #f5f5f5; }
.result-item .company { font-weight: 600; }
.result-item .location { color: #666; }

#map { flex: 1; }

#logout-btn {
  display: block;
  width: 100%;
  margin-top: auto;
  padding: 8px;
  background: none;
  border: 1px solid #ddd;
  border-radius: 4px;
  color: #888;
  font-size: 0.8rem;
  cursor: pointer;
  text-align: center;
  flex-shrink: 0;
}
#logout-btn:hover { background: #f5f5f5; color: #333; }

/* Login page */
body.login-page { justify-content: center; align-items: center; background: #f0f2f5; }
.login-box {
  background: #fff;
  padding: 36px 40px;
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
  width: 340px;
}
.login-box h1 { font-size: 1.2rem; margin-bottom: 24px; color: #1a1a2e; }
.login-box label { display: block; font-size: 0.85rem; margin-bottom: 4px; color: #555; }
.login-box input { display: block; width: 100%; padding: 10px; border: 1px solid #ccc; border-radius: 4px; margin-bottom: 16px; font-size: 0.95rem; }
.login-box button { width: 100%; padding: 11px; background: #1a73e8; color: #fff; border: none; border-radius: 4px; font-size: 1rem; cursor: pointer; }
.login-box button:hover { background: #1558b0; }
.error { color: #d93025; font-size: 0.85rem; margin-top: 10px; }
.hidden { display: none; }
