/* ============================================================
   HoReCa B2B — кликабельный прототип.
   Дополняет ../ui-kit/styles.css (дизайн-токены и компоненты).
   Здесь — только то, чего нет в UI-ките: каркас прототипа,
   переключатель состояний, экран входа, карта прототипа.
   ============================================================ */

/* ---------- Переключатель состояний (demo-chrome) ---------- */
.state-bar{
  display:flex;flex-wrap:wrap;align-items:center;gap:10px;
  padding:8px 12px;margin-bottom:20px;
  border:1px dashed var(--border-strong);border-radius:10px;
  background:var(--c-info-bg);
}
.state-bar .state-label{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:600;color:var(--c-info-text);white-space:nowrap;
}
.state-bar .state-label i{font-size:16px;}
.seg{display:inline-flex;flex-wrap:wrap;gap:4px;}
.seg a{
  display:inline-flex;align-items:center;gap:5px;
  height:28px;padding:0 12px;border-radius:999px;
  font-size:12px;font-weight:600;color:var(--text-secondary);
  background:#fff;border:1px solid var(--border);text-decoration:none;
  transition:background var(--dur),color var(--dur),border-color var(--dur);
}
.seg a:hover{border-color:var(--border-strong);color:var(--text-primary);}
.seg a.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary);}
.state-bar .state-route{margin-left:auto;font-size:11px;color:var(--text-muted);}
.state-bar .state-route code{
  background:#fff;border:1px solid var(--border);border-radius:4px;padding:1px 6px;font-size:11px;
}

/* ---------- Хлебные крошки / шапка экрана ---------- */
.crumbs{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-bottom:8px;}
.crumbs a{color:var(--text-secondary);text-decoration:none;}
.crumbs a:hover{color:var(--c-primary);text-decoration:underline;}
.crumbs i{font-size:14px;}
.page-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:12px;margin-bottom:20px;}
.page-head .page-title{font-size:22px;font-weight:700;line-height:1.2;}
.page-head .page-sub{color:var(--text-secondary);font-size:14px;margin-top:4px;max-width:60ch;}
.page-actions{display:flex;flex-wrap:wrap;gap:8px;}

/* ---------- Экран входа ---------- */
.auth-wrap{min-height:100vh;display:grid;grid-template-columns:1fr;background:var(--bg-page);}
.auth-main{display:flex;flex-direction:column;justify-content:center;align-items:center;padding:24px;}
.auth-card{width:100%;max-width:400px;}
.auth-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px;}
.auth-logo .brand-mark{width:40px;height:40px;border-radius:10px;}
.auth-hero{
  display:none;position:relative;overflow:hidden;
  background:var(--c-primary);color:#fff;padding:48px;flex-direction:column;justify-content:center;
}
.auth-hero .illus{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.25);color:rgba(255,255,255,.8);}
.auth-hero .illus i{color:#9BC463;opacity:.9;}
.auth-hero .illus code{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.25);color:#fff;}
.auth-hero h2{color:#fff;}
@media (min-width:900px){
  .auth-wrap{grid-template-columns:1.05fr .95fr;}
  .auth-hero{display:flex;}
}

/* ---------- Карта прототипа (лаунчер) ---------- */
.sitemap-hero{
  border-radius:14px;background:var(--c-primary);color:#fff;
  padding:28px;margin-bottom:28px;position:relative;overflow:hidden;
}
.sitemap-hero h1{color:#fff;font-size:26px;font-weight:700;margin-bottom:8px;}
.sitemap-hero p{color:var(--c-indigo-200,#CDD3EF);max-width:64ch;}
.map-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;}
.map-card{
  display:flex;flex-direction:column;gap:2px;padding:14px;border:1px solid var(--border);
  border-radius:10px;background:#fff;text-decoration:none;color:inherit;
  transition:box-shadow var(--dur),border-color var(--dur),transform var(--dur);
}
.map-card:hover{box-shadow:0 8px 24px rgba(19,27,77,.10);border-color:var(--border-strong);transform:translateY(-1px);}
.map-card .map-top{display:flex;align-items:center;gap:8px;}
.map-card .map-ico{display:grid;place-items:center;width:32px;height:32px;border-radius:8px;background:var(--c-info-bg);color:var(--c-primary);}
.map-card .map-ico i{font-size:18px;}
.map-card .map-name{font-weight:600;color:var(--text-primary);}
.map-card .map-states{font-size:12px;color:var(--text-muted);margin-top:6px;}
.map-section-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin:24px 0 12px;}

/* ---------- Мелочи ---------- */
.kv{display:grid;gap:2px;}
.kv .kv-label{font-size:12px;color:var(--text-muted);}
.kv .kv-val{font-weight:500;}
.dl-row{display:flex;justify-content:space-between;gap:12px;padding:6px 0;}
.section-divider{height:1px;background:var(--border);margin:8px 0;border:0;}
.tag-dot{display:inline-block;width:8px;height:8px;border-radius:999px;background:var(--c-accent-strong);}
.muted{color:var(--text-muted);}
.link{color:var(--c-info);text-decoration:none;font-weight:500;}
.link:hover{text-decoration:underline;}
.row-click{cursor:pointer;}
.price-cell-strong{font-weight:600;}

/* нав-разделитель в сайдбаре */
.nav-sep{height:1px;background:var(--border);margin:8px 4px;}
.nav-cap{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);padding:8px 12px 4px;}
