/* ── IP Geolocation ─────────────────────────────────────────────────── */
.tool-title {
  display: flex; align-items: center; gap: 10px;
  font-size: 22px; font-weight: 600; margin-bottom: 6px;
}
.tool-icon {
  width: 36px; height: 36px;
  background: linear-gradient(135deg, var(--accent), var(--cyan));
  border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 18px;
}
.tool-icon--ip { background: linear-gradient(135deg, var(--accent2), var(--accent)); }
.tool-desc { color: var(--muted2); font-size: 14px; margin-bottom: 24px; }

.ip-form .form-row { display: flex; gap: 10px; }
.input-wrap--domain { flex: 1; }
.ip-form .input {
  width: 100%; padding: 12px 16px;
  background: var(--surface2); border: 1px solid var(--border2);
  border-radius: var(--radius-sm); color: var(--text);
  font-size: 15px; font-family: var(--mono); transition: border-color .2s;
}
.ip-form .input:focus { outline: none; border-color: var(--accent); }
.ip-form .btn-primary {
  padding: 12px 28px;
  background: linear-gradient(135deg, var(--accent2), var(--accent));
  color: var(--white); border: none; border-radius: var(--radius-sm);
  font-size: 14px; font-weight: 600; cursor: pointer;
  transition: opacity .2s; white-space: nowrap;
  display: flex; align-items: center; gap: 8px;
}
.ip-form .btn-primary:hover { opacity: .9; }
.ip-form .btn-primary:disabled { opacity: .5; cursor: not-allowed; }

}

.ip-error { color: var(--red); font-size: 14px; margin-top: 16px; }

/* IP banner */
.ip-banner {
  margin-top: 16px; padding: 20px 24px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius); text-align: center;
}
.ip-address {
  font-family: var(--mono); font-size: 28px; font-weight: 700;
  color: var(--accent); margin-bottom: 4px;
}
.ip-location {
  font-size: 16px; color: var(--text); margin-bottom: 2px;
}
.ip-country-flag {
  font-size: 32px; margin-bottom: 8px;
}

/* Info grid */
.ip-grid {
  margin-top: 16px; display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}
.ip-item {
  padding: 12px 16px; background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
}
.ip-item-label {
  font-size: 11px; color: var(--muted); text-transform: uppercase;
  letter-spacing: .5px; margin-bottom: 4px;
}
.ip-item-value {
  font-family: var(--mono); font-size: 13px; color: var(--text);
  word-break: break-all;
}

/* Coordinates */
.ip-coords {
  margin-top: 16px; padding: 14px 20px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; gap: 16px;
}
.ip-coords-label { font-size: 12px; color: var(--muted); }
.ip-coords-value {
  font-family: var(--mono); font-size: 14px; color: var(--cyan);
}
.ip-coords-link {
  margin-left: auto; padding: 6px 14px;
  background: var(--surface2); border: 1px solid var(--border2);
  border-radius: 6px; font-size: 12px; color: var(--accent);
  text-decoration: none; transition: border-color .2s;
}
.ip-coords-link:hover { border-color: var(--accent); }

.ip-meta {
  display: flex; gap: 16px; margin-top: 16px; padding: 10px 16px;
  background: var(--surface2); border-radius: var(--radius-sm);
  font-size: 12px; color: var(--muted);
}
.ip-meta span { color: var(--muted2); }

@media (max-width: 600px) {
  .ip-form .form-row { flex-direction: column; }
  .ip-form .btn-primary { width: 100%; justify-content: center; }
  .ip-grid { grid-template-columns: 1fr; }
  .ip-address { font-size: 22px; }
  .ip-coords { flex-direction: column; align-items: flex-start; }
  .ip-coords-link { margin-left: 0; }
}
