/* Сайты всем — каталог готовых сайтов. Светлая тема, акцент индиго. */
:root{
  --brand:#4f46e5; --brand-600:#4338ca; --brand-50:#eef2ff; --brand-100:#e0e7ff;
  --ink:#10172a; --text:#3a4660; --muted:#737e96;
  --bg:#f6f7fb; --bg-soft:#eef1f8; --card:#ffffff; --line:#e6e9f2;
  --ok:#1c7a45; --ok-bg:#e7f7ee; --err:#c0392b; --err-bg:#fdeaea;
  --radius:16px; --shadow:0 10px 30px -14px rgba(30,40,90,.18);
  --shadow-lg:0 24px 60px -22px rgba(30,40,90,.30);
  --maxw:1240px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:84px}
body{margin:0;background:var(--bg);color:var(--text);font-family:Manrope,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{color:var(--ink);line-height:1.15;margin:0;font-weight:800;letter-spacing:-.02em}
h1{font-size:clamp(1.9rem,4vw,3rem)}
h2{font-size:clamp(1.5rem,2.6vw,2.1rem)}
h3{font-size:1.12rem;font-weight:700}
p{margin:0}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--brand);outline-offset:2px;border-radius:6px}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.accent{color:var(--brand)}
.muted{color:var(--muted)}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand);background:var(--brand-50);padding:6px 12px;border-radius:999px}

/* Кнопки */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:700;font-family:inherit;border:1.5px solid transparent;border-radius:11px;padding:11px 18px;cursor:pointer;transition:.16s ease;white-space:nowrap;font-size:.95rem}
.btn-sm{padding:9px 15px;font-size:.9rem}
.btn-lg{padding:14px 22px;font-size:1rem}
.btn-block{width:100%}
.btn-primary{background:var(--brand);color:#fff;box-shadow:0 8px 20px -8px rgba(79,70,229,.6)}
.btn-primary:hover{background:var(--brand-600);transform:translateY(-1px)}
.btn-ghost{background:#fff;color:var(--brand);border-color:var(--brand-100)}
.btn-ghost:hover{background:var(--brand-50)}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}

/* Шапка */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:24px;height:70px}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink)}
.brand-mark{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--brand),#7c75f0);color:#fff}
.brand-text{display:flex;flex-direction:column;line-height:1.05}
.brand-text b{font-size:1.08rem;font-weight:800;color:var(--ink)}
.brand-text small{font-size:.7rem;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.brand-text.light b{color:#fff}.brand-text.light small{color:#aeb8d0}
.nav{display:flex;gap:4px;margin-left:auto}
.nav a{padding:9px 13px;border-radius:9px;font-weight:600;font-size:.95rem;color:var(--text);white-space:nowrap;transition:.15s}
.nav a:hover{color:var(--brand);background:var(--brand-50)}
.header-cta{display:flex;align-items:center;gap:14px}
.phone{font-weight:800;color:var(--ink);white-space:nowrap}
.phone:hover{color:var(--brand)}

/* Герой */
.hero{padding:54px 0 30px;background:radial-gradient(1100px 460px at 85% -20%,rgba(79,70,229,.10),transparent 60%)}
.hero .eyebrow{margin-bottom:16px}
.hero h1{margin-bottom:14px;max-width:760px}
.lead{font-size:1.12rem;color:var(--text);max-width:640px;margin-bottom:24px}
.hero-search{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--line);border-radius:13px;padding:0 16px;max-width:560px;box-shadow:var(--shadow);color:var(--muted)}
.hero-search input{width:100%;border:none;outline:none;background:none;font-family:inherit;font-size:1rem;color:var(--ink);padding:14px 0}

/* Секции */
.section{padding:46px 0}
.section-alt{background:var(--bg-soft)}
.section-head{max-width:720px;margin:0 auto 34px;text-align:center}
.section-head .eyebrow{margin-bottom:12px}
.grid{display:grid;gap:18px}

/* Каталог: сетка ниши + контент */
.catalog{display:grid;grid-template-columns:262px 1fr;gap:26px;align-items:start}
.cats{position:sticky;top:86px}
.cats-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cats-head>span{font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.cats-toggle{display:none}
.cats-list{list-style:none;margin:0;padding:6px;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:2px}
.cats-list li{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;cursor:pointer;font-weight:600;color:var(--text);transition:.14s;user-select:none}
.cats-list li .ic{font-size:1.15rem;width:24px;text-align:center;flex:none}
.cats-list li .cnt{margin-left:auto;font-size:.78rem;font-weight:700;color:var(--muted);background:var(--bg-soft);border-radius:999px;padding:2px 9px;min-width:26px;text-align:center}
.cats-list li:hover{background:var(--brand-50);color:var(--ink)}
.cats-list li.active{background:var(--brand);color:#fff}
.cats-list li.active .cnt{background:rgba(255,255,255,.22);color:#fff}

.catalog-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.catalog-bar h2{font-size:1.5rem}
.catalog-meta{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.count{color:var(--muted);font-size:.92rem;font-weight:600}
.sort{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--muted)}
.sort select{font-family:inherit;font-size:.9rem;color:var(--ink);border:1.5px solid var(--line);border-radius:9px;padding:7px 10px;background:#fff;cursor:pointer;outline:none}
.sort select:focus{border-color:var(--brand)}

#grid{grid-template-columns:repeat(auto-fill,minmax(270px,1fr))}
.empty{margin-top:18px;color:var(--muted);text-align:center;padding:30px}

/* Карточка сайта */
.site{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.18s;box-shadow:var(--shadow)}
.site:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#cfd6f0}
/* Превью-«браузер» — рисуем мини-макет сайта без картинок */
.preview{position:relative;aspect-ratio:16/10;background:#eef1f8;overflow:hidden}
.preview .pvframe{position:absolute;top:0;left:0;border:0;transform-origin:0 0;pointer-events:none;background:#fff}
.buy-preview{border-radius:12px;border:1px solid var(--line);margin-bottom:16px}
.preview .bar{height:22px;background:rgba(255,255,255,.16);display:flex;align-items:center;gap:5px;padding:0 9px}
.preview .bar i{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.55)}
.preview .page{position:absolute;inset:30px 16px 16px;display:flex;flex-direction:column;gap:7px}
.preview .ph{background:rgba(255,255,255,.92);border-radius:5px}
.preview .ph.h{height:13px;width:42%}
.preview .ph.hero{height:34%;border-radius:8px;background:rgba(255,255,255,.32);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.86rem;letter-spacing:.02em;text-align:center;padding:0 10px}
.preview .row{display:flex;gap:7px;flex:1}
.preview .row .ph{flex:1}
.badge{position:absolute;top:10px;right:10px;background:#fff;color:var(--brand);font-size:.7rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:4px 9px;border-radius:999px;box-shadow:var(--shadow)}
.site .body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:9px;flex:1}
.site .body h3{font-size:1.04rem}
.site .desc{font-size:.9rem;color:var(--muted);flex:1}
.tags{display:flex;flex-wrap:wrap;gap:5px}
.tags span{font-size:.72rem;color:var(--text);background:var(--bg-soft);border-radius:6px;padding:3px 8px}
.site .price{display:flex;align-items:baseline;gap:8px;margin-top:2px}
.site .price b{font-size:1.25rem;color:var(--ink);font-weight:800}
.site .price s{color:var(--muted);font-size:.92rem}
.site .actions{display:flex;gap:8px;margin-top:6px}
.site .actions .btn{flex:1}

/* Шаги */
.steps{list-style:none;counter-reset:s;padding:0;margin:0;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.steps li{counter-increment:s;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow)}
.steps li::before{content:counter(s);display:grid;place-items:center;width:40px;height:40px;border-radius:11px;background:var(--brand);color:#fff;font-weight:800;margin-bottom:13px}
.steps h3{margin-bottom:6px;font-size:1.04rem}
.steps p{font-size:.9rem;color:var(--muted)}

/* Почему мы */
.why-grid{grid-template-columns:repeat(4,1fr)}
.why{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.why .ic{font-size:1.7rem;margin-bottom:10px}
.why h3{font-size:1.04rem;margin-bottom:7px}
.why p{font-size:.9rem;color:var(--muted)}

/* Контакты + заказ */
.contacts-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.contacts-text .eyebrow{margin-bottom:14px}
.contacts-text p{color:var(--text);margin:14px 0 18px;font-size:1.05rem}
.contacts-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px;color:var(--text)}
.contacts-list a:hover{color:var(--brand)}
.order-card{padding:24px;display:flex;flex-direction:column;gap:11px}
.order-card h3{margin-bottom:2px}
.order-for{font-size:.9rem;color:var(--brand);font-weight:700;background:var(--brand-50);padding:9px 12px;border-radius:10px}
input,textarea,select{width:100%;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:11px;padding:12px 14px;transition:.15s;outline:none}
textarea{resize:vertical}
input:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-50)}
.form-note{font-size:.77rem;color:var(--muted)}
.form-status{font-size:.92rem;font-weight:600;padding:10px 12px;border-radius:10px}
.form-status.ok{background:var(--ok-bg);color:var(--ok)}
.form-status.err{background:var(--err-bg);color:var(--err)}

/* Подвал */
.site-footer{background:var(--ink);color:#c3cbe0;padding:46px 0 24px}
.footer-inner{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:30px;padding-bottom:26px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-inner>div>p{color:#8a96b3;font-size:.9rem;margin-top:12px;max-width:330px}
.footer-nav{display:flex;flex-direction:column;gap:9px}
.footer-nav a:hover{color:#fff}
.footer-contact{display:flex;flex-direction:column;gap:9px}
.footer-contact a{font-weight:700;color:#fff}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-top:18px;font-size:.84rem;color:#7d89a8}

/* Модалка */
.modal{position:fixed;inset:0;z-index:200;display:grid;place-items:center;padding:18px}
.modal[hidden]{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(16,23,42,.55);backdrop-filter:blur(3px)}
.modal-box{position:relative;width:100%;max-width:440px;padding:26px;animation:pop .18s ease}
@keyframes pop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.modal-box h3{font-size:1.3rem}
.modal-sub{color:var(--muted);font-size:.92rem;margin:6px 0 16px}
.modal-box form{display:flex;flex-direction:column;gap:11px}
.modal-x{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:10px;border:none;background:var(--bg-soft);color:var(--ink);font-size:1.5rem;line-height:1;cursor:pointer;transition:.15s}
.modal-x:hover{background:var(--brand-50);color:var(--brand)}

/* Адаптив */
@media(max-width:900px){
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .contacts-inner{grid-template-columns:1fr;gap:26px}
}
@media(max-width:760px){
  .nav{display:none}
  .catalog{grid-template-columns:1fr;gap:16px}
  .cats{position:static}
  .cats-head{margin-bottom:0}
  .cats-toggle{display:inline-flex;align-items:center;border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:8px 14px;font-family:inherit;font-weight:700;font-size:.9rem;color:var(--brand);cursor:pointer}
  .cats-list{margin-top:10px;max-height:0;overflow:hidden;padding:0;border:none;box-shadow:none;transition:.22s}
  .cats.open .cats-list{max-height:760px;padding:6px;border:1px solid var(--line);box-shadow:var(--shadow)}
}
@media(max-width:520px){
  .header-cta .btn{display:none}
  .phone{font-size:.95rem}
  #grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:22px}
}
