:root {
  --orange: #FF973C;        /* 自社UI色：面・帯・バーなど非文字面に使う */
  --orange-strong: #B45F0C; /* 白文字ボタン用（AA達成のため濃いめ） */
  --orange-soft: #FFF3E6;   /* 読み上げ枠の薄面 */
  --orange-line: #FFD9B0;
  --red: #E5343A;           /* 緊急・速報・NG */
  --red-soft: #FDECEC;
  --green: #1D9E75;         /* 鮮度OK */
  --amber: #EF9F27;         /* まもなく要確認 */
  --ink: #1A1A1A;
  --mute: #595959;
  --line: #E5E3DE;
  --bg: #FAFAF8;
  --ok: #1D7A44;
}
* { box-sizing: border-box; -webkit-font-smoothing: antialiased; }
html, body { margin: 0; background: var(--bg); color: var(--ink);
  font-family: "Hiragino Kaku Gothic ProN", "Noto Sans JP", system-ui, sans-serif;
  font-size: 16px; line-height: 1.6; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }

/* ヘッダー：現在ブランドの色帯を常時固定 */
.header { background: #fff; border-bottom: 1px solid var(--line);
  border-left: 7px solid var(--brand-color, #888);
  padding: 10px 16px; display: flex; align-items: center; gap: 14px; position: sticky; top: 0; z-index: 20; }
.logo { font-weight: 800; color: var(--orange); font-size: 20px; letter-spacing: .02em; }
.brand-home { display: inline-flex; align-items: center; flex-shrink: 0; }
.brand-logo { height: 30px; width: auto; display: block; }
@media (max-width: 640px) { .brand-logo { height: 24px; } }
.header-sub { font-size: 13px; color: var(--mute); }
.app-name { display: inline-flex; flex-direction: column; line-height: 1.1; text-decoration: none; }
.app-name-jp { font-weight: 900; font-size: 22px; color: var(--orange-strong); letter-spacing: .02em; }
.app-name-en { font-size: 11px; font-weight: 700; color: var(--mute); letter-spacing: .04em; }
@media (max-width: 640px) { .app-name-jp { font-size: 18px; } .app-name-en { font-size: 10px; } }
.header-game { margin-left: auto; font-size: 13px; font-weight: 700; color: #b5631a;
  background: var(--orange-soft); border: 1px solid var(--orange-line); padding: 6px 12px; border-radius: 999px; }
.header-admin { font-size: 13px; font-weight: 700; color: #444;
  background: #fff; border: 1px solid var(--line); padding: 6px 12px; border-radius: 999px; }
.header-admin:hover { border-color: #999; }
@media (max-width: 640px) { .header-sub { display: none; } .header-game, .header-admin { padding: 6px 9px; } }

/* 管理者エリア */
.admin-gate { max-width: 380px; margin: 30px auto; text-align: center; }
.admin-bar { display: flex; align-items: center; justify-content: space-between; margin: 6px 0; }

.wrap { max-width: 860px; margin: 0 auto; padding: 16px; }
#main:focus { outline: none; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0; }

/* 検索：主役・最大 */
.search { width: 100%; height: 56px; font-size: 18px; padding: 0 18px;
  border: 2px solid var(--orange); border-radius: 14px; outline: none; background: #fff; }
.search:focus { box-shadow: 0 0 0 4px var(--orange-soft); }
.search-hint { font-size: 12px; color: var(--mute); margin: 6px 2px 0; }
.search-wrap { position: relative; }
.sugg { position: absolute; left: 0; right: 0; top: 60px; z-index: 30; background: #fff;
  border: 1px solid var(--line); border-radius: 12px; box-shadow: 0 6px 24px rgba(0,0,0,.10); overflow: hidden; }
.sugg-item { display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 10px 14px; border-bottom: 1px solid var(--line); }
.sugg-item:last-child { border-bottom: none; }
.sugg-item:hover, .sugg-item.sugg-on { background: var(--orange-soft); }
.sugg-item b { font-weight: 700; font-size: 14px; }
.sugg-item span { font-size: 11px; color: var(--mute); flex-shrink: 0; }
.sugg-empty { padding: 12px 14px; font-size: 13px; color: var(--mute); }
.sugg-foot { padding: 7px 14px; font-size: 11px; color: var(--mute); background: #FAFAF8; border-top: 1px solid var(--line); }
@media (prefers-reduced-motion: reduce) { * { transition: none !important; animation: none !important; } }
.banner { background: var(--red); color: #fff; font-size: 13px; font-weight: 700;
  padding: 8px 16px; text-align: center; }

/* 鮮度バッジ：文字は濃色固定・状態はドット色（S6） */
.fresh { font-size: 11px; font-weight: 700; color: #444; display: inline-flex; align-items: center; gap: 5px; margin-left: auto; }

/* 管理者ダッシュボード */
.dash { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 14px; }
.dash-row { display: flex; gap: 10px; }
.dash-num { flex: 1; background: var(--bg); border-radius: 10px; padding: 12px; text-align: center;
  font-size: 30px; font-weight: 800; line-height: 1.1; }
.dash-num span { display: block; font-size: 12px; color: var(--mute); font-weight: 600; margin-top: 2px; }

/* レスポンシブ＆タップ標的（S8） */
@media (max-width: 600px) {
  .tiles { grid-template-columns: repeat(2, 1fr); }
  .kpis { grid-template-columns: 1fr; }
  .dash-num { font-size: 24px; }
}
@media (pointer: coarse) {
  .pin, .copy-btn, .fb-btn, .back { min-height: 44px; display: inline-flex; align-items: center; }
  .tile { min-height: 112px; }
  .sugg-item { min-height: 44px; }
  .row { min-height: 44px; }
}

/* フォーカス可視化（S9・数字キー/タブ運用） */
:focus-visible { outline: 3px solid var(--orange); outline-offset: 2px; border-radius: 4px; }

/* 動画 */
.card-video { width: 100%; max-height: 420px; border-radius: 12px; background: #000; margin: 4px 0 14px; display: block; }
.vchip { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px; background: #EDE7FB; color: #5A3BA0; }
.dchip { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px; background: #E1F0E8; color: #1d7a44; }
.ichip { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px; background: #FBEAF0; color: #993556; }
.card-image { width: 100%; max-height: 460px; object-fit: contain; border-radius: 12px; background: #faf9f6; border: 1px solid var(--line); margin: 4px 0 14px; display: block; }
.media-cur { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 8px; }
.media-chip { font-size: 13px; background: var(--orange-soft); border: 1px solid var(--orange-line); color: #8a4a12; padding: 5px 10px; border-radius: 999px; display: inline-flex; align-items: center; gap: 8px; }
.media-x { font-size: 11px; font-weight: 700; border: 1px solid var(--orange-line); background: #fff; color: #b5631a; border-radius: 6px; padding: 2px 8px; cursor: pointer; }
.doc-wrap { margin: 4px 0 8px; }
.card-doc { width: 100%; height: 72vh; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.doc-open { display: inline-block; font-size: 13px; font-weight: 700; color: #b5631a; margin-bottom: 12px; }

/* カード編集フォーム */
.edit-form { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 16px; }
.edit-form label { display: block; font-size: 13px; font-weight: 700; color: #444; margin: 12px 0 4px; }
.edit-form label:first-child { margin-top: 0; }
.edit-form input, .edit-form select, .edit-form textarea {
  width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 9px 11px; font-size: 15px; font-family: inherit; }
.edit-form input:focus, .edit-form select:focus, .edit-form textarea:focus { outline: none; border-color: var(--orange); }
.edit-form .req { font-size: 11px; font-weight: 700; color: var(--red); background: var(--red-soft); padding: 1px 6px; border-radius: 4px; margin-left: 4px; }
.ngok2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
@media (max-width: 560px) { .ngok2 { grid-template-columns: 1fr; } }

/* 角の編集ボタン（FAB）＋編集パスワードのモーダル */
.edit-fab { position: fixed; right: 18px; bottom: 18px; z-index: 50;
  background: var(--orange-strong); color: #fff; border: none; border-radius: 999px;
  font-size: 14px; font-weight: 800; padding: 12px 18px; cursor: pointer;
  box-shadow: 0 4px 16px rgba(0,0,0,.18); }
.edit-fab:hover { filter: brightness(0.96); }
.edit-fab.on { background: #1d7a44; }
.edit-fab.dim { background: #6b6b6b; opacity: .5; font-size: 13px; padding: 9px 14px; }
.edit-fab.dim:hover { opacity: 1; }
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,.45);
  display: flex; align-items: center; justify-content: center; z-index: 60; }
.modal { background: #fff; border-radius: 16px; padding: 24px; width: 320px; max-width: 90vw; text-align: center; }

/* 速報帯 */
.sokuho { display: flex; align-items: center; gap: 10px; background: #E9F1FB;
  border-left: 6px solid #185FA5; border-radius: 8px; padding: 10px 12px; margin: 12px 0;
  font-size: 14px; color: #0c447c; font-weight: 600; }
.sokuho:hover { filter: brightness(0.98); }
.sokuho.sokuho-high { background: var(--red-soft); border-left-color: var(--red); color: #7a1d20; }
.sokuho .tag { background: #185FA5; color: #fff; font-size: 11px; font-weight: 700;
  padding: 2px 8px; border-radius: 999px; flex-shrink: 0; }
.sokuho.sokuho-high .tag { background: var(--red); }

/* カテゴリタイル */
.tiles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-top: 6px; }
.tile { background: #fff; border: 1px solid var(--line); border-radius: 14px;
  padding: 16px 14px; display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
  transition: .12s; min-height: 104px; }
.tile:hover { border-color: var(--orange); transform: translateY(-1px); }
.tile { position: relative; }
.tile .tnum { position: absolute; top: 8px; right: 10px; font-size: 11px; font-weight: 800;
  color: #8a5e16; background: #F7E7C6; border-radius: 6px; padding: 1px 6px; }
.tile .ico { font-size: 28px; line-height: 1; }
.tile .t-label { font-weight: 700; font-size: 16px; }
.tile .t-note { font-size: 12px; color: var(--mute); line-height: 1.4; }
.tile.accent { border: 2px solid var(--orange); }
.tile.game { background: var(--orange-soft); border: 1px solid var(--orange-line); }

.section-label { font-size: 12px; color: var(--mute); margin: 18px 2px 6px; }
.pins { display: flex; flex-wrap: wrap; gap: 8px; }
.pin { background: #fff; border: 1px solid var(--line); border-radius: 999px;
  padding: 6px 14px; font-size: 13px; font-weight: 600; }
.pin:hover { border-color: var(--orange); }

/* 一覧（密） */
.list { display: flex; flex-direction: column; gap: 8px; }
/* カテゴリ内のカードグリッド（モダン・複数列） */
.cardgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(248px, 1fr)); gap: 10px; align-items: start; }
.cardgrid .row { height: 100%; }
.cardgrid .row-ans { -webkit-line-clamp: 3; }

/* 息抜きミニゲーム */
.game-wrap { border: 1px solid var(--line); border-radius: 14px; overflow: hidden; background: #FFF7EF; line-height: 0; }
#gcanvas { width: 100%; height: auto; display: block; touch-action: none; cursor: pointer; }
.ext-mark { font-size: 11px; color: var(--mute); }

/* トップ画面の編集 */
.home-edit-bar { display: block; text-align: center; background: var(--orange-soft); border: 1px dashed var(--orange-line);
  color: #b5631a; font-weight: 700; font-size: 13px; padding: 10px; border-radius: 10px; margin: 6px 0 14px; }
.he-group { border: 1px solid var(--line); border-radius: 12px; padding: 12px; margin-bottom: 12px; background: #fff; }
.he-grouphead { display: flex; gap: 8px; margin-bottom: 10px; }
.he-heading { font-weight: 700; flex: 1; }
.he-tile { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; padding: 8px; border: 1px solid #F2F0EA; border-radius: 8px; margin-bottom: 8px; }
.he-in { border: 1px solid var(--line); border-radius: 7px; padding: 7px 9px; font-size: 14px; font-family: inherit; }
.he-ico { width: 56px; text-align: center; }
.he-label { flex: 1; min-width: 120px; }
.he-note2 { flex: 1.4; min-width: 140px; }
.he-type { flex-shrink: 0; }
.he-note { font-size: 12px; color: var(--mute); }
.he-del { font-size: 12px; font-weight: 700; border: 1px solid var(--line); background: #fff; color: var(--red); border-radius: 7px; padding: 6px 10px; cursor: pointer; }
.he-actions { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-top: 6px; }

/* モグラたたき */
.mole-top { font-size: 15px; margin-bottom: 10px; }
.mole-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; max-width: 420px; }
.mole-hole { aspect-ratio: 1 / 1; background: #6b4a2b; border-radius: 50%; position: relative; overflow: hidden;
  box-shadow: inset 0 -8px 0 rgba(0,0,0,.18); cursor: pointer; }
.mole-hole .mole { position: absolute; left: 0; right: 0; bottom: -100%; font-size: 44px; text-align: center;
  transition: bottom .08s; line-height: 1.4; }
.mole-hole.up .mole { bottom: 6%; }
@media (max-width: 480px) { .mole-hole .mole { font-size: 34px; } }

/* 反射神経テスト */
.react-zone { height: 260px; border-radius: 16px; display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 800; color: #fff; cursor: pointer; user-select: none; text-align: center; padding: 12px; }
.react-idle { background: #5F6B7A; }
.react-wait { background: #C0392B; }
.react-go { background: #1d9e75; }
.react-bad { background: #8a5a00; }
/* ミニゲーム共通：トップ10ランキング */
.lb-wrap { margin-top: 16px; max-width: 460px; }
.lb-form { background: #FFF7EF; border: 1px solid var(--orange); border-radius: 12px; padding: 12px; margin-bottom: 12px; }
.lb-congrats { font-weight: 800; color: var(--orange-strong); margin-bottom: 8px; }
.lb-table { width: 100%; border-collapse: collapse; background: #fff; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.lb-table th { text-align: left; font-size: 12px; color: var(--mute); background: #FAF7F2; padding: 7px 10px; border-bottom: 1px solid var(--line); }
.lb-table td { padding: 8px 10px; border-bottom: 1px solid var(--line); font-size: 14px; }
.lb-table tr:last-child td { border-bottom: none; }
.lb-rank { width: 48px; font-weight: 800; }
.lb-name { font-weight: 700; }
.lb-score { text-align: right; font-weight: 800; color: var(--orange-strong); white-space: nowrap; }
.lb-table tr.lb-me td { background: #FFEFD9; }
.row { background: #fff; border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; }
.row:hover { border-color: var(--orange); }
.row .row-top { display: flex; align-items: center; gap: 6px; margin-bottom: 3px; }
.row .row-title { font-weight: 700; font-size: 15px; }
.row .row-ans { font-size: 13px; color: var(--mute); overflow: hidden;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }

/* チップ・バッジ */
.chip { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px; color: #fff; }
.chip.common { background: #7C7A73; }
.cat-chip { font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px;
  background: #F0EEE9; color: #5F5E5A; }
.dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.draft-badge { background: #EEE; color: #777; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px; }

/* カード詳細（疎） */
.back { font-size: 13px; color: var(--mute); display: inline-block; margin-bottom: 10px; }
.card { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 22px; }
.card .meta { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.card .answer { font-size: 25px; font-weight: 800; line-height: 1.45; margin: 6px 0 12px; padding-left: 12px; border-left: 4px solid var(--orange); }
.sample-note { font-size: 12px; color: #8a5a00; background: #FBF1DD; border: 1px solid #F0D9A8; border-radius: 8px; padding: 7px 11px; margin: 0 0 14px; }
.warn-brand { background: #FFF8E1; border: 1px solid var(--amber); color: #7a5a00;
  font-size: 13px; font-weight: 700; padding: 8px 12px; border-radius: 8px; margin-bottom: 14px; }
.say-box { background: var(--orange-soft); border: 1px solid var(--orange-line);
  border-radius: 12px; padding: 14px 16px; margin-bottom: 16px; }
.say-box .label { font-size: 12px; font-weight: 700; color: #b5631a; display: flex; justify-content: space-between; align-items: center; }
.say-box.say-ph { background: #F7F6F3; border-color: var(--line); }
.say-box.say-ph .label { color: var(--mute); }
.say-box .say { font-size: 18px; line-height: 1.75; margin-top: 6px; }
.copy-btn { background: var(--orange-strong); color: #fff; border: none; border-radius: 8px;
  font-size: 12px; font-weight: 700; padding: 5px 12px; }
.ngok { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 16px; }
@media (max-width: 600px) { .ngok { grid-template-columns: 1fr; } .tiles { grid-template-columns: repeat(2, 1fr); gap: 8px; } }
.ng-box { background: var(--red-soft); border-left: 5px solid var(--red); border-radius: 8px; padding: 12px 14px; }
.ng-box .label { font-size: 12px; font-weight: 700; color: var(--red); margin-bottom: 4px; }
.ok-box { background: #ECF8F1; border-left: 5px solid var(--green); border-radius: 8px; padding: 12px 14px; }
.ok-box .label { font-size: 12px; font-weight: 700; color: var(--ok); margin-bottom: 4px; }
.steps { padding-left: 20px; margin: 4px 0; } .steps li { margin: 3px 0; font-size: 15px; }
.sub { font-size: 14px; color: #444; margin: 6px 0; }
.sub b { color: var(--ink); }
.esc { background: #F4F1FB; border-left: 5px solid #7F4ABF; border-radius: 8px; padding: 10px 14px; font-size: 14px; margin-bottom: 14px; }
.related { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.related a { border: 1px solid var(--orange-line); color: #b5631a; font-size: 13px; font-weight: 600; padding: 6px 12px; border-radius: 999px; }

/* フィードバック・投稿 */
.fb { display: flex; align-items: center; gap: 10px; border-top: 1px solid var(--line); margin-top: 18px; padding-top: 14px; flex-wrap: wrap; }
.fb-btn { border: 1px solid var(--line); background: #fff; border-radius: 8px; font-size: 14px; font-weight: 700; padding: 8px 14px; }
.fb-btn.hit.on { background: #ECF8F1; border-color: var(--green); color: var(--ok); }
.fb-btn.miss.on { background: var(--red-soft); border-color: var(--red); color: var(--red); }
.fb-note { font-size: 12px; }

.cta { display: block; text-align: center; background: var(--orange-strong); color: #fff; font-weight: 800;
  border-radius: 12px; padding: 14px; margin: 14px 0; font-size: 16px; }
.tool { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 18px; }
.tool label { display: block; font-size: 14px; color: var(--mute); margin: 10px 0 4px; }
.tool input { width: 100%; height: 42px; font-size: 16px; padding: 0 12px; border: 1px solid var(--line); border-radius: 8px; }
.result-box { border: 2px solid; border-radius: 12px; padding: 16px; margin-top: 16px; font-weight: 800; font-size: 18px; line-height: 1.5; }

.reason-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.reason-btn { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 16px; font-weight: 700; font-size: 15px; text-align: left; }
.reason-btn:hover { border-color: var(--orange); }
.reason-btn:disabled { cursor: default; }
.reason-btn.quiz-correct { background: #ECF8F1; border-color: var(--green); color: var(--ok); }
.reason-btn.quiz-wrong { background: var(--red-soft); border-color: var(--red); color: #7a1d20; }

.zero { background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 18px; }
.footer { text-align: center; font-size: 12px; color: var(--mute); margin: 28px 0 12px; }
.post-form textarea, .post-form input { width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 8px; font-size: 14px; font-family: inherit; }
.post-form { background: #fff; border: 1px dashed var(--line); border-radius: 12px; padding: 14px; margin-top: 14px; }

/* 大カテゴリ章見出し */
.group-head { font-size: 14px; font-weight: 800; color: var(--ink); margin: 20px 2px 8px;
  padding-left: 10px; border-left: 4px solid var(--orange); }

/* 全体周知事項 */
.notice { background: #fff; border: 1px solid var(--line); border-left: 6px solid #888; border-radius: 10px; padding: 12px 14px; }
.notice-tag { color: #fff; font-size: 11px; font-weight: 700; padding: 2px 8px; border-radius: 6px; }

/* ブランド実績（比較テーブル） */
.btable-wrap { overflow-x: auto; border: 1px solid var(--line); border-radius: 14px; background: #fff;
  -webkit-overflow-scrolling: touch; }
.btable { width: 100%; border-collapse: collapse; font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum"; font-size: 15px; }
.btable th { font-size: 11px; color: var(--mute); font-weight: 700; text-align: right;
  padding: 11px 14px; border-bottom: 1.5px solid var(--line); white-space: nowrap; }
.btable td { text-align: right; padding: 11px 14px; border-bottom: 1px solid #F2F0EA; white-space: nowrap; color: var(--ink); }
.btable tbody tr:last-child td { border-bottom: none; }
.btable tbody tr:hover td { background: var(--orange-soft); }
.btable .bt-brand { text-align: left; font-weight: 700; position: sticky; left: 0; background: #fff; padding-right: 18px; }
.btable th.bt-brand { color: var(--ink); }
.btable tbody tr:hover .bt-brand { background: #FFF3E6; }
.bt-dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; margin-right: 8px; vertical-align: middle; }
.bt-trend { font-size: 11px; font-weight: 800; margin-left: 7px; }
.bt-na { color: #C9C6BD; }
.bt-hero .bt-val { font-weight: 800; }
.bt-bar { height: 3px; background: #EFEDE6; border-radius: 2px; margin-top: 5px; min-width: 48px; }
.bt-bar i { display: block; height: 100%; background: var(--orange); border-radius: 2px; }

/* コンセプトブック */
.concept-hero { background: var(--orange-soft); border-color: var(--orange-line); }
.concept-k { font-size: 12px; font-weight: 800; color: #b5631a; letter-spacing: .08em; }
.concept-mission { font-size: 24px; font-weight: 800; line-height: 1.5; margin: 4px 0; }
.concept-vision { margin: 6px 0 0; padding-left: 20px; } .concept-vision li { font-size: 16px; margin: 3px 0; }
.mast { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; }
@media (max-width: 560px) { .mast { grid-template-columns: 1fr; } }
.mast-item { display: flex; gap: 12px; background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 12px 14px; align-items: center; }
.mast-k { font-size: 26px; font-weight: 800; color: var(--orange); width: 32px; text-align: center; flex-shrink: 0; }
