/* uslugi.* portal — base CSS */
*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden;max-width:100vw}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;line-height:1.6;color:#1a1a2e;background:#fafbfc}
a{color:#c0392b;text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 24px}

/* Topbar */
.topbar{background:#fff;border-bottom:1px solid #e5e7eb;padding:12px 0;position:sticky;top:0;z-index:100}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px}
.logo{font-family:'Segoe UI',sans-serif;font-weight:800;font-size:22px;color:#c0392b;flex-shrink:0}
.logo span{color:#1a1a2e}
.topbar nav{display:flex;gap:18px;flex-wrap:wrap}
.topbar nav a{color:#555;font-size:14px;font-weight:600}
.topbar nav a:hover{color:#c0392b}
.dev-badge{background:#fbbf24;color:#1a1a2e;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}

/* Hero */
.hero{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 50%,#0f3460 100%);color:#fff;padding:64px 0;text-align:center}
.hero h1{font-size:40px;font-weight:800;margin-bottom:16px;letter-spacing:-0.5px}
.hero h1 span{color:#f5a623}
.hero p{font-size:18px;max-width:680px;margin:0 auto 28px;color:#cbd5e0}
.hero-search{max-width:640px;margin:0 auto;background:#fff;border-radius:12px;padding:8px;display:flex;gap:8px;box-shadow:0 8px 32px rgba(0,0,0,0.2)}
.hero-search input{flex:1;border:none;padding:14px 18px;font-size:15px;outline:none;border-radius:8px;color:#1a1a2e}
.hero-search button{background:#c0392b;color:#fff;border:none;padding:14px 28px;border-radius:8px;font-weight:700;cursor:pointer;font-size:14px;letter-spacing:0.3px;text-transform:uppercase}
.hero-search button:hover{background:#a93226}

/* Stats */
.stats{background:#fff;border-bottom:1px solid #e5e7eb;padding:24px 0}
.stats .wrap{display:flex;gap:32px;justify-content:center;flex-wrap:wrap}
.stat{text-align:center}
.stat strong{display:block;font-size:24px;font-weight:800;color:#c0392b}
.stat span{font-size:13px;color:#6b7280}

/* Sections */
.section{padding:56px 0}
.section h2{font-size:28px;font-weight:800;margin-bottom:8px;letter-spacing:-0.3px}
.section .subtitle{color:#6b7280;font-size:16px;margin-bottom:32px}

/* Cat grid */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}
.cat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px;transition:transform .2s,box-shadow .2s,border-color .2s;display:block;color:inherit}
.cat-card:hover{transform:translateY(-2px);box-shadow:0 12px 24px rgba(0,0,0,0.08);border-color:#c0392b;text-decoration:none}
.cat-card .icon{font-size:32px;margin-bottom:10px}
.cat-card h3{font-size:18px;font-weight:700;margin-bottom:6px;color:#1a1a2e}
.cat-card p{font-size:14px;color:#6b7280;margin-bottom:10px}
.cat-card .count{font-size:12px;color:#c0392b;font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.cat-card.featured{background:linear-gradient(135deg,#fff5ee 0%,#fff 100%);border-color:#c0392b}
.cat-card .badge{display:inline-block;background:#c0392b;color:#fff;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}

/* Firm card */
.firms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:24px}
.firm-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:22px;display:block;color:inherit}
.firm-card:hover{box-shadow:0 8px 16px rgba(0,0,0,0.08);text-decoration:none;border-color:#c0392b}
.firm-card.featured{background:linear-gradient(135deg,#fff5ee 0%,#fff 100%);border-color:#c0392b}
.firm-card h3{font-size:18px;font-weight:700;margin-bottom:6px;color:#1a1a2e}
.firm-card .meta{font-size:13px;color:#6b7280;margin-bottom:10px}
.firm-card .desc{font-size:14px;color:#374151;line-height:1.55}

/* Single firm */
.firm-single{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:32px;margin:32px 0}
.firm-single h1{font-size:32px;margin-bottom:8px}
.firm-single .meta{color:#6b7280;font-size:14px;margin-bottom:24px}
.firm-single .info{display:grid;grid-template-columns:140px 1fr;gap:8px 16px;margin-top:20px;font-size:14px}
.firm-single .info dt{color:#6b7280;font-weight:600}
.firm-single .info dd a{word-break:break-all}

/* CTA */
.cta-section{background:#fff5ee;padding:56px 0;text-align:center}
.cta-section h2{font-size:28px;margin-bottom:12px}
.cta-section p{font-size:16px;color:#555;margin-bottom:24px}
.btn-primary{display:inline-block;background:#c0392b;color:#fff;padding:14px 32px;border-radius:8px;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:0.5px}
.btn-primary:hover{background:#a93226;text-decoration:none}
.btn-outline{display:inline-block;border:2px solid #c0392b;color:#c0392b;padding:12px 32px;border-radius:8px;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:0.5px;margin-left:10px}
.btn-outline:hover{background:#c0392b;color:#fff;text-decoration:none}

/* Footer */
footer{background:#1a1a2e;color:#9ca3af;padding:40px 0 24px;margin-top:64px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:24px}
.footer-grid h4{color:#fff;font-size:14px;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;font-weight:700}
.footer-grid a{color:#9ca3af;display:block;padding:3px 0;font-size:14px}
.footer-grid a:hover{color:#fff}
.footer-bottom{border-top:1px solid #374151;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px}

/* Breadcrumbs */
.crumbs{padding:14px 0;font-size:13px;color:#6b7280;background:#f3f4f6;border-bottom:1px solid #e5e7eb}
.crumbs a{color:#6b7280}
.crumbs a:hover{color:#c0392b}
.crumbs .sep{margin:0 8px;color:#9ca3af}

/* Empty state */
.empty{padding:48px 24px;text-align:center;color:#6b7280;background:#fff;border:1px dashed #d1d5db;border-radius:12px}
.empty h3{color:#374151;margin-bottom:6px}

/* Mobile */
@media(max-width:768px){
  .hero h1{font-size:28px}
  .hero p{font-size:15px}
  .hero-search{flex-direction:column}
  .hero-search button{width:100%}
  .topbar nav{gap:12px}
  .topbar nav a{font-size:13px}
  .firm-single .info{grid-template-columns:1fr}
  .firm-single .info dt{margin-top:8px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .section h2{font-size:24px}
}
