/* Base / shared look matching your site style */
* { box-sizing: border-box; }
body {
  font-family: Arial, sans-serif;
  background: #f8f9fa;
  color: #333;
  margin: 0;
  line-height: 1.6;
}

/* Header */
header {
  text-align: center;
  background: #007bff;
  color: #fff;
  padding: 2rem 1rem;
}
header h1 { margin: 0; font-size: 2.5rem; }
header p.intro { margin: 0.5rem 0 0; font-size: 1.05rem; opacity: 0.95; }

/* Main layout */
main { max-width: 1200px; margin: auto; padding: 2rem 1rem; }
section { background: #fff; padding: 2rem; margin-bottom: 2rem; border-radius: 12px; box-shadow: 0 4px 6px rgba(0,0,0,0.08); }

.section-title { text-align: center; margin-bottom: 1.5rem; font-size: 1.8rem; color: #007bff; position: relative; }
.section-title::after { content:""; position:absolute; bottom:-10px; left:50%; transform:translateX(-50%); width:80px; height:3px; background:#007bff; border-radius:2px; opacity:0.8; }

/* Buttons */
.btn-primary, .btn-secondary {
  padding: 0.65rem 1.2rem; border: none; border-radius: 6px; cursor: pointer; font-size: 1rem; font-weight: 500; margin: 0.25rem; transition: 0.15s;
}
.btn-primary { background: #007bff; color: #fff; }
.btn-primary:hover:not(:disabled){ background:#0056b3; transform: translateY(-2px); }
.btn-secondary { background:#6c757d; color:#fff; }
.btn-secondary:hover:not(:disabled){ background:#545b62; }

/* Lookup grid */
.lookup-container { display: grid; grid-template-columns: 1fr 1.1fr; gap: 1.25rem; }
.lookup-left, .lookup-right { background: transparent; }

/* Result grid */
.result-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.9rem; }
.result-card { background:#f8f9ff; border-radius:8px; padding:0.9rem; border:1px solid #e1e8ef; box-shadow: 0 2px 6px rgba(0,0,0,0.03); }
.result-card .label { font-size:0.85rem; color:#666; margin-bottom:0.4rem; font-weight:600; color:#0056b3; }
.result-card .value { font-size:1rem; font-weight:700; color:#222; word-break:break-word; }

/* Full width control */
.control-row { display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:1rem; }
.control-group { flex:1 1 180px; display:flex; flex-direction:column; }
.control-group.full-width { flex-basis:100%; }
.control-group label { font-size:0.9rem; font-weight:600; margin-bottom:0.25rem; color:#0056b3; }
.control-group select, .control-group input { padding:0.55rem 0.7rem; border-radius:6px; border:1px solid #ced4da; font-size:1rem; outline:none; }
.control-group select:focus, .control-group input:focus { border-color:#007bff; }

/* Messages and note */
.help-text { font-size:0.85rem; color:#666; margin-top:0.25rem; }
.error-message { margin-top:0.25rem; font-size:0.95rem; color:#dc3545; }
.status-message { margin-top:0.75rem; font-size:0.9rem; color:#28a745; }

.note-box { text-align:center; margin:1rem 0 0; padding:1rem 1.5rem; border:2px solid #007bff; border-radius:8px; background:#e9f5ff; color:#0056b3; font-weight:500; box-shadow:0 2px 8px rgba(0,123,255,0.08); }

/* Raw JSON modal */
.raw-json { position:fixed; inset:0; display:flex; align-items:center; justify-content:center; background: rgba(0,0,0,0.45); z-index:9999; padding:1rem; }
.raw-json-inner { background:#fff; padding:1rem; border-radius:8px; max-width:900px; width:100%; }
.hidden { display:none; }

/* Map tweaks */
#ipMap { width:100%; height:260px; border-radius:8px; }
.leaflet-container { border-radius:8px; }

/* Steps / benefits / FAQ reuse your style */
.steps { display:grid; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); gap:2rem; margin-top:2rem; }
.step { background:#fff; border:1px solid #e1e8ef; border-radius:12px; padding:1.8rem; text-align:center; box-shadow:0 3px 10px rgba(0,0,0,0.04); }
.step-number { width:60px; height:60px; background:linear-gradient(145deg,#007bff,#0056b3); color:#fff; font-size:1.4rem; display:flex; align-items:center; justify-content:center; margin:0 auto 1rem; border-radius:50%; box-shadow:0 4px 8px rgba(0,123,255,0.18); }
.benefits-grid ul { list-style:none; padding:0; margin:0; display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:1rem; }
.benefits-grid li { background:#f8f9fa; padding:1rem; border-left:4px solid #007bff; border-radius:6px; font-size:1rem; }
#faq { margin-top:2rem; }
.faq-question { width:100%; background:#f8f9fa; border:1px solid #e9ecef; border-radius:6px; padding:1rem; font-weight:bold; text-align:left; cursor:pointer; color:#007bff; }
.faq-answer { display:none; padding:1rem; border-left:3px solid #007bff; margin-top:0.5rem; background:#fff; border-radius:4px; }
.faq-item.active .faq-answer { display:block; }

/* Responsive */
@media (max-width:1000px){ .result-grid { grid-template-columns: repeat(2,1fr); } .lookup-container{ grid-template-columns:1fr; } }
@media (max-width:600px){ .result-grid{ grid-template-columns:1fr; } header h1{ font-size:1.7rem; } }
/* Footer */
footer {
  background: #f1f1f1;
  text-align: center;
  padding: 2rem 1rem;
  color: #666;
}

footer a {
  color: #007bff;
  text-decoration: none;
}

footer a:hover {
  text-decoration: underline;
}