/* G-Search — портал-шелл (Ф0). Лёгкий, на дизайн-токенах Suite (с фолбэками). */
:root {
  --gs-bg: var(--suite-bg, #f6f7fb);
  --gs-surface: var(--suite-surface, #ffffff);
  --gs-border: var(--suite-border, #e3e6ef);
  --gs-text: var(--suite-text, #1f2430);
  --gs-muted: var(--suite-muted, #6b7280);
  --gs-accent: var(--suite-accent, #4f46e5);
  --gs-accent-weak: var(--suite-accent-weak, #eef0ff);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--gs-bg); color: var(--gs-text);
  min-height: 100vh;
}

.gs-topbar {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 18px; background: var(--gs-surface);
  border-bottom: 1px solid var(--gs-border);
  position: sticky; top: 0; z-index: 50;
}
.gs-brand { font-size: 18px; font-weight: 700; margin: 0; letter-spacing: .2px; }
.suite-waffle { display: inline-flex; }
.topbar-right { margin-left: auto; display: flex; align-items: center; gap: 8px; }

.gs-main { max-width: 920px; margin: 0 auto; padding: 28px 18px 64px; }

.gs-searchbar { display: flex; gap: 10px; margin: 8px 0 14px; }
.gs-input {
  flex: 1; font-size: 16px; padding: 12px 16px;
  border: 1px solid var(--gs-border); border-radius: 10px;
  background: var(--gs-surface); color: var(--gs-text); outline: none;
}
.gs-input:focus { border-color: var(--gs-accent); box-shadow: 0 0 0 3px var(--gs-accent-weak); }
.gs-btn-search {
  font-size: 15px; font-weight: 600; padding: 0 22px;
  border: none; border-radius: 10px; cursor: pointer;
  background: var(--gs-accent); color: #fff;
}
.gs-btn-search:hover { filter: brightness(1.05); }

.gs-recent { margin: 4px 0 12px; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.gs-recent-label { color: var(--gs-muted); font-size: 13px; }
.gs-recent-list { display: flex; gap: 6px; flex-wrap: wrap; }
.gs-chip {
  font-size: 13px; padding: 4px 10px; border-radius: 999px; cursor: pointer;
  border: 1px solid var(--gs-border); background: var(--gs-surface); color: var(--gs-text);
}
.gs-chip:hover { background: var(--gs-accent-weak); border-color: var(--gs-accent); }

.gs-partial {
  margin: 4px 0 12px; padding: 8px 12px; border-radius: 8px; font-size: 13px;
  background: #fff7ed; color: #9a3412; border: 1px solid #fdba74;
}

.gs-meta { color: var(--gs-muted); font-size: 13px; margin: 2px 0 14px; }

.gs-hint, .gs-empty { color: var(--gs-muted); padding: 28px 4px; text-align: center; }

.gs-group { margin: 0 0 22px; }
.gs-group-title {
  font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px;
  color: var(--gs-muted); margin: 0 0 8px; display: flex; align-items: center; gap: 8px;
}
.gs-group-count {
  font-size: 12px; font-weight: 600; color: var(--gs-accent);
  background: var(--gs-accent-weak); padding: 1px 8px; border-radius: 999px;
}
.gs-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.gs-item {
  background: var(--gs-surface); border: 1px solid var(--gs-border);
  border-radius: 10px; padding: 10px 14px;
}
.gs-item-type {
  display: inline-block; font-size: 11px; font-weight: 600; color: var(--gs-muted);
  background: var(--gs-bg); border: 1px solid var(--gs-border);
  padding: 1px 7px; border-radius: 6px; margin-right: 8px; vertical-align: middle;
}
.gs-item-title { font-size: 15px; font-weight: 600; color: var(--gs-accent); text-decoration: none; }
a.gs-item-title:hover { text-decoration: underline; }
.gs-item-sub { font-size: 13px; color: var(--gs-muted); margin-top: 3px; }
