:root {
  --bg: #060b17;
  --bg-soft: #0d1830;
  --surface: #0f1f3f;
  --text: #f7f9ff;
  --muted: #c4d1ee;
  --accent: #ffc400;
  --accent-dark: #e5a900;
  --ok: #20c997;
  --radius: 14px;
  --shadow: 0 12px 28px rgba(0,0,0,.22);
}
* { box-sizing: border-box; }
html, body { margin:0; padding:0; font-family: 'Segoe UI', Tahoma, Arial, sans-serif; color:var(--text); background: radial-gradient(circle at 20% 20%, #10244a, #060b17 45%); }
a { color: inherit; text-decoration: none; }
.container { width:min(1160px, 92%); margin:0 auto; }
.topbar { position: sticky; top:0; z-index:40; background:rgba(5,10,21,.9); backdrop-filter: blur(8px); border-bottom:1px solid rgba(255,255,255,.08); }
.topbar-wrap { display:flex; gap:16px; align-items:center; justify-content:space-between; padding:12px 0; }
.logo { font-weight:800; letter-spacing:.4px; }
.nav { display:flex; gap:14px; flex-wrap:wrap; }
.nav a { color:var(--muted); font-size:14px; }
.btn { display:inline-block; padding:12px 18px; border-radius:12px; font-weight:700; transition:.2s ease; }
.btn-primary { background:var(--accent); color:#111; }
.btn-primary:hover { background:var(--accent-dark); }
.btn-primary[href^='tel:'] { animation: callBlink 1s infinite; box-shadow: 0 0 0 rgba(255,196,0,.0); }
.btn-outline { border:1px solid rgba(255,255,255,.28); }
.hero { padding:68px 0 44px; }
.hero h1 { font-size:clamp(30px,4.8vw,52px); line-height:1.12; margin:0 0 12px; }
.hero p { max-width:760px; color:var(--muted); font-size:18px; margin:0 0 24px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; }
.hero-highlights { margin-top:18px; display:flex; flex-wrap:wrap; gap:10px; }
.hero-highlights span { background:rgba(255,196,0,.12); border:1px solid rgba(255,196,0,.35); color:#ffe9a6; padding:8px 12px; border-radius:999px; font-size:13px; font-weight:700; }
.hero-banner { margin-top:22px; border-radius:14px; overflow:hidden; border:1px solid rgba(255,255,255,.2); box-shadow:var(--shadow); }
.hero-banner img { width:100%; display:block; }
.section { padding:38px 0; }
.section h2 { font-size:30px; margin:0 0 14px; }
.section p.lead { color:var(--muted); max-width:850px; }
.grid { display:grid; gap:16px; }
.services { grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); }
.card { background:linear-gradient(170deg, rgba(255,255,255,.05), rgba(255,255,255,.02)); border:1px solid rgba(255,255,255,.09); border-radius:var(--radius); padding:20px; box-shadow:var(--shadow); }
.card:hover { border-color:rgba(255,196,0,.55); transform:translateY(-2px); transition:.2s ease; }
.card-image { width:100%; border-radius:10px; margin-bottom:12px; border:1px solid rgba(255,255,255,.16); display:block; }
.card h3 { margin:0 0 10px; }
.card p { margin:0; color:var(--muted); line-height:1.6; }
.districts { grid-template-columns:repeat(auto-fit,minmax(170px,1fr)); }
.district-card { display:block; padding:14px; border-radius:12px; text-align:center; border:1px solid rgba(255,255,255,.12); background:#0b1630; font-weight:700; }
.district-card:hover { border-color:var(--accent); color:var(--accent); }
.media-grid { grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); }
.media-grid a { display:block; border-radius:12px; overflow:hidden; border:1px solid rgba(255,255,255,.15); box-shadow:var(--shadow); }
.media-grid img { width:100%; height:200px; object-fit:cover; display:block; }
.list { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:14px; }
.list div { background:#0b1630; padding:16px; border-radius:12px; border:1px solid rgba(255,255,255,.08); }
.testimonial { border-left:4px solid var(--accent); padding-left:14px; margin-bottom:14px; }
.faq details { border:1px solid rgba(255,255,255,.12); border-radius:12px; padding:12px 14px; margin-bottom:10px; background:#0b1630; }
.faq summary { cursor:pointer; font-weight:700; }
.page-content { line-height:1.8; color:#e9f0ff; }
.page-content h2, .page-content h3 { line-height:1.35; margin-top:26px; }
.service-detail-image { width:100%; border-radius:14px; border:1px solid rgba(255,255,255,.15); box-shadow:var(--shadow); margin:8px 0 16px; display:block; }
.cta-strip { margin:24px 0; padding:18px; border-radius:14px; background:linear-gradient(90deg, #122750, #0b1630); border:1px solid rgba(255,255,255,.12); display:flex; gap:10px; flex-wrap:wrap; align-items:center; justify-content:space-between; }
.footer { margin-top:30px; border-top:1px solid rgba(255,255,255,.11); padding:30px 0 90px; background:#060b17; }
.footer-grid { display:grid; grid-template-columns:1.1fr 1fr 1fr; gap:20px; }
.footer-links { display:grid; grid-template-columns:repeat(2, minmax(120px,1fr)); gap:8px; max-height:260px; overflow:auto; padding-right:8px; }
.footer a { color:#d8e4ff; font-size:14px; }
.map iframe { width:100%; height:200px; border:0; border-radius:10px; }
.sticky-mobile { position:fixed; left:0; right:0; bottom:0; z-index:45; display:flex; }
.sticky-mobile a { flex:1; text-align:center; padding:13px 10px; font-weight:800; }
.call { background:var(--accent); color:#111; }
.wa { background:#1ea85f; color:#fff; }
.call { animation: callBlink 1s infinite; }

@keyframes callBlink {
  0%, 100% { opacity: 1; transform: scale(1); box-shadow: 0 0 0 rgba(255,196,0,0); }
  50% { opacity: .55; transform: scale(1.02); box-shadow: 0 0 22px rgba(255,196,0,.55); }
}

@media (prefers-reduced-motion: reduce) {
  .btn-primary[href^='tel:'],
  .call { animation: none; }
}
@media (max-width:860px) {
  .footer-grid { grid-template-columns:1fr; }
  .nav { display:none; }
}

