/*
Theme Name: TG AD Desk
Author: друг
Version: 1.0.0
Description: Лёгкая тема под лендинг «агрегатор рекламы в Telegram» (вариант 2).
Text Domain: tg-ad-desk
*/

:root{
  /* Палитра отличается от первого сайта */
  --bg:#ffffff;
  --ink:#0b1220;
  --ink-2:#35405a;
  --muted:#768399;

  /* акцент фиолетовый вместо синего */
  --pri:#7c3aed;           /* violet-600 */
  --pri-ink:#ffffff;
  --pri-soft:#f4f0ff;      /* светлый фон для hover */

  --ok:#16a34a;
  --warn:#d97706;

  --card:#ffffff;
  --line:#e6e9f2;
  --line-2:#f2f4f8;

  --radius:14px;           /* другой радиус, не как на первом */
  --shadow:0 8px 28px rgba(11,18,32,.08);

  --max:1160px;
  --sp: clamp(12px, 1.5vw, 16px);
}

/* Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink);
  font:400 16px/1.6 ui-sans-serif,system-ui,-apple-system,"Segoe UI",Inter,Roboto,Arial,sans-serif;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; height:auto; display:block}
a{color:var(--pri); text-decoration:none}
a:hover{text-decoration:underline}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:2px solid var(--pri); outline-offset:2px; border-radius:8px;
}

/* Layout / Type */
.wrap{max-width:var(--max); margin-inline:auto; padding:24px clamp(12px,3vw,20px)}
section{padding-block:calc(var(--sp)*2); border-top:1px solid var(--line-2)}
h1,h2,h3{margin:0 0 10px}
h1{font-weight:900; letter-spacing:.1px; font-size:clamp(32px,3.3vw,46px); line-height:1.12}
h2{font-weight:800; font-size:clamp(24px,2.5vw,33px)}
h3{font-weight:700; font-size:18px}
.muted{color:var(--muted)}
.tagline{color:var(--ink-2)}

/* Topnav */
.topnav{
  position:sticky; top:0; z-index:10;
  backdrop-filter:saturate(1.05) blur(8px);
  background:rgba(255,255,255,.9);
  border-bottom:1px solid var(--line);
}
.topnav-inner{display:flex; align-items:center; justify-content:space-between; gap:12px}
.logo{display:inline-flex; align-items:center; gap:10px; font-weight:900; letter-spacing:.2px; color:var(--ink)}
.logo-dot{width:10px; height:10px; border-radius:50%; background:var(--pri); box-shadow:0 0 10px rgba(124,58,237,.45)}
.logo img{height:22px; width:auto; display:block}
.menu{display:flex; gap:8px 14px; flex-wrap:wrap}
.menu a{
  display:inline-flex; align-items:center; justify-content:center; height:40px; padding:0 14px; color:#27314a;
  border:1px solid transparent; border-radius:999px; background:transparent;
  transition:background .18s ease,border-color .18s ease,transform .15s ease;
}
.menu a:hover{background:var(--pri-soft); border-color:#e6ddff}
.menu a:active{transform:translateY(1px)}

/* Hero */
.hero{
  display:grid; gap:clamp(16px,2.6vw,28px);
  grid-template-columns:1.1fr .9fr; align-items:center;
  padding-block:clamp(28px,4vw,40px)
}
.kicker{text-transform:uppercase; font:700 11px/1.2 inherit; color:#9aa6bf; letter-spacing:.16em; margin-bottom:8px}
.hero img{border-radius:calc(var(--radius) + 2px); border:1px solid var(--line); box-shadow:var(--shadow)}
.cta{display:flex; gap:10px 12px; flex-wrap:wrap; margin-top:16px}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  height:46px; padding:0 20px; border-radius:12px; cursor:pointer; user-select:none;
  border:1px solid #6d28d9; background:var(--pri); color:var(--pri-ink);
  box-shadow:0 10px 24px rgba(124,58,237,.22);
  transition:transform .1s ease, box-shadow .2s ease, opacity .2s ease;
}
.btn:hover{box-shadow:0 14px 32px rgba(124,58,237,.28)}
.btn:active{transform:translateY(1px)}
.btn.sec{background:#ffffff; color:var(--pri); border:1px solid #e3d9ff; box-shadow:none}
.btn.sec:hover{background:var(--pri-soft)}
.btn.ghost{background:transparent; border:1px dashed #d8e0f1; color:#374565}
.badges{display:flex; gap:8px 12px; flex-wrap:wrap; margin-top:12px}
.badge{font-size:12px; color:#3e1f7a; background:#f6f2ff; border:1px solid #e9ddff; padding:6px 10px; border-radius:999px}
.badge.warn{color:#7a4a0f; background:#fff7ed; border-color:#f8e3b0}

/* Grids / Cards */
.grid{display:grid; grid-template-columns:repeat(12,1fr); gap:16px}
.card{
  grid-column:span 4; background:var(--card); border:1px solid var(--line);
  border-radius:var(--radius); padding:16px; box-shadow:var(--shadow);
  transition:transform .18s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{transform:translateY(-2px); box-shadow:0 14px 30px rgba(11,18,32,.12); border-color:#dde2f3}
.card p{color:var(--ink-2); margin:0 0 10px}
.meta{display:flex; flex-wrap:wrap; gap:8px 12px; font-size:13px; color:var(--muted)}
.price{font-weight:800; color:#0f172a}
.list{display:grid; gap:6px; color:var(--ink-2); padding:0; margin:0}
.list li{list-style:none; display:flex; gap:10px; align-items:flex-start}
.catalog .card{display:flex; flex-direction:column; gap:10px; min-height:232px}

/* Not found tweaks */
.not-found-hero{border-top:1px solid var(--line-2)}
.not-found{padding:40px 0}
.nf-grid{display:grid; grid-template-columns:repeat(12,1fr); gap:16px}
.nf-grid .card{grid-column:span 6}

/* Формы (обновлено, чтоб отличаться от первого сайта) */
form{display:grid; gap:10px}
input[type="text"],
input[type="tel"],
input[type="email"],
textarea{
  width:100%;
  border:1px solid #dfe4f3;
  background:#fcfdff;
  color:var(--ink);
  border-radius:12px;
  padding:12px 14px;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
textarea{min-height:110px; resize:vertical}
input::placeholder, textarea::placeholder{color:#9aa6bf}
input:focus, textarea:focus{
  border-color:#c9b8ff;
  box-shadow:0 0 0 3px rgba(124,58,237,.15);
  background:#ffffff;
}
label.agree{display:flex; gap:10px; align-items:flex-start; font-size:14px; color:#4b5567}
button.btn[type="submit"]{justify-self:start}

/* Таблицы и прочее */
table{border-collapse:collapse; width:100%}
th,td{border:1px solid var(--line); padding:10px; text-align:left}

/* Sticky footer layout */
html, body { height: 100%; }
body {
  min-height: 100svh;
  display: flex;
  flex-direction: column;
}
main { flex: 1 0 auto; }
.site-footer { margin-top: auto; border-top:1px solid var(--line); background:#fafbff; color:#4c5872 }
.site-footer .wrap{display:flex; align-items:center; justify-content:space-between; gap:12px}

/* Utility */
.hide{display:none !important}
.center{text-align:center}

/* Responsive */
@media (max-width: 960px){
  .hero{grid-template-columns:1fr; padding-block:28px}
  .grid{grid-template-columns:repeat(6,1fr)}
  .card{grid-column:span 6}
  .nf-grid .card{grid-column:span 6}
}
@media (max-width: 640px){
  .grid{grid-template-columns:repeat(4,1fr)}
  .card{grid-column:span 4}
  .nf-grid .card{grid-column:span 4}
  .menu{gap:8px}
  .menu a{height:38px; padding:0 12px}
  .btn{height:44px}
}

.site-footer{border-top:1px solid var(--line-2); background:#0f1115; color:#c9d1e2; padding:20px 0}
.site-footer a{color:#9bb1ff}
.footer-cols{display:flex; gap:20px; align-items:flex-start; justify-content:space-between; flex-wrap:wrap}
.f-menu{display:flex; gap:12px 16px; flex-wrap:wrap}
.f-menu a{padding:6px 10px; border-radius:999px; border:1px solid transparent}
.f-menu a:hover{background:#141a24; border-color:#2a3342; text-decoration:none}
.logo.mini{display:inline-flex; align-items:center; gap:8px; font-weight:800; color:#e6ecff}

/* Лого: если нет файла, просто текст, без дыр */
.logo { gap: 10px; }
.logo-img { display:inline-block; height:22px; width:auto; }
.logo-text { font-weight:900; letter-spacing:.2px; color:var(--ink); }

/* Hero fallback без изображения */
.hero.no-hero { grid-template-columns: 1fr; }
.hero.no-hero > div:last-child { display:none; }
.hero img { max-width:100%; height:auto; display:block; }

/* На всякий случай — минимальная высота блока справа, когда картинка есть */
.hero > div:last-child { min-height: 240px; }
