* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; background: #f8faf9; color: #1a1a1a; line-height: 1.6; }
html[data-theme="dark"] body { background: #151a21; color: #e3e8f0; }
.mp-nav { background: #fff; border-bottom: 1px solid #e5e7eb; padding: 14px 0; }
html[data-theme="dark"] .mp-nav { background: #1e2531; border-color: #2a3441; }
.mp-nav__inner, .mp-wrap { max-width: 1040px; margin: 0 auto; padding: 0 20px; }
.mp-nav__inner { display: flex; align-items: center; gap: 18px; }
.mp-nav__logo img { height: 26px; display: block; }
.mp-nav__links { margin-left: auto; display: flex; gap: 6px; font-size: 14px; }
.mp-nav__links a { color: #4b5563; padding: 8px 12px; border-radius: 6px; text-decoration: none; font-weight: 500; }
.mp-nav__links a:hover { color: #108f64; background: #f0fdf4; }
.mp-hero { text-align: center; padding: 40px 16px 22px; }
.mp-hero h1 { font-size: 34px; line-height: 1.2; margin-bottom: 10px; }
.mp-hero p { color: #6b7280; max-width: 620px; margin: 0 auto; }
.mp-subcount { color: #9ca3af; font-size: 13px; margin-top: 8px; }
.mp-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; padding: 14px 0 50px; }
.mp-card { background: #fff; border: 1px solid #eef2f6; border-radius: 14px; padding: 20px; display: flex; flex-direction: column; gap: 10px; }
html[data-theme="dark"] .mp-card { background: #1e2531; border-color: #2a3441; }
.mp-domain { font-size: 22px; font-weight: 700; color: #118f64; word-break: break-all; }
.mp-cat { font-size: 11px; text-transform: uppercase; letter-spacing: .5px; color: #9ca3af; }
.mp-desc { font-size: 13px; color: #6b7280; flex: 1; }
.mp-price { font-size: 20px; font-weight: 700; }
.mp-btn { background: #118f64; color: #fff; border: 0; border-radius: 8px; padding: 10px 16px; font-weight: 600; cursor: pointer; text-decoration: none; text-align: center; font-size: 14px; }
.mp-btn:hover { background: #0e7a55; }
.mp-msg { font-size: 12px; margin-top: 4px; }
.mp-msg.ok { color: #16a34a; }
.mp-msg.err { color: #dc2626; }
.mp-empty { text-align: center; color: #9ca3af; padding: 60px 20px; }
.mp-layout { display: grid; grid-template-columns: 250px 1fr; gap: 22px; padding: 8px 0 50px; align-items: start; }
@media (max-width: 760px) { .mp-layout { grid-template-columns: 1fr; } }
.mp-filter { background: #fff; border: 1px solid #eef2f6; border-radius: 14px; padding: 18px; position: sticky; top: 14px; }
html[data-theme="dark"] .mp-filter { background: #1e2531; border-color: #2a3441; }
.mp-filter h3 { font-size: 14px; display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.mp-filter h3 a { font-size: 12px; color: #6b7280; font-weight: 500; text-decoration: none; }
.mp-filter label.fl { display: block; font-size: 12px; color: #6b7280; font-weight: 600; margin: 14px 0 6px; }
.mp-filter input, .mp-filter select { width: 100%; padding: 8px 10px; border: 1px solid #d1d5db; border-radius: 8px; font-size: 13px; font-family: inherit; }
html[data-theme="dark"] .mp-filter input, html[data-theme="dark"] .mp-filter select { background: #151a21; border-color: #2a3441; color: #e3e8f0; }
.mp-row { display: flex; gap: 8px; }
.mp-exts { max-height: 200px; overflow-y: auto; display: flex; flex-direction: column; gap: 4px; margin-top: 4px; }
.mp-ext { display: flex; align-items: center; gap: 7px; font-size: 13px; color: #4b5563; cursor: pointer; }
html[data-theme="dark"] .mp-ext { color: #cbd5e1; }
.mp-ext input { width: auto; }
.mp-ext .c { margin-left: auto; color: #9ca3af; font-size: 11px; }
.mp-apply { width: 100%; margin-top: 16px; background: #118f64; color: #fff; border: 0; border-radius: 8px; padding: 11px; font-weight: 600; cursor: pointer; }
.mp-topbar { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 14px; flex-wrap: wrap; }
.mp-topbar .cnt { color: #6b7280; font-size: 13px; }
.mp-topbar select { padding: 8px 10px; border: 1px solid #d1d5db; border-radius: 8px; font-size: 13px; width: auto; }
.mp-pages { display: flex; flex-wrap: wrap; gap: 6px; justify-content: center; padding: 24px 0 10px; }
.mp-pages a, .mp-pages span { padding: 7px 12px; border-radius: 8px; font-size: 14px; text-decoration: none; border: 1px solid #e5e7eb; color: #4b5563; }
.mp-pages .cur { background: #118f64; color: #fff; border-color: #118f64; }
