/* ============================================================
   カロリー帳 — 情報・法的・ガイドページ用スタイル
   styles.css のデザイントークン（--bg / --ink / --acc 等）と
   .site-footer / .brand-mark を再利用しつつ、文書系の体裁を足す。
   ============================================================ */

body { background: var(--bg); background-image: var(--bg-grad); }

/* ---------- ヘッダー ---------- */
/* 内容はアプリ（.topnav）と同じく 1180px 本体カラムに整列（full-width の間延びを解消）。
   sticky のまま＝本文オフセット不要。ログイン中はアプリと同じ .brand/.nav-tabs を流用する。 */
.site-head {
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; gap: 14px;
  height: var(--nav-h);
  padding: 0 max(clamp(16px, 4vw, 40px), calc(50% - 590px + clamp(16px, 4vw, 40px)));
  background: color-mix(in oklch, var(--bg) 82%, transparent);
  backdrop-filter: saturate(140%) blur(14px);
  -webkit-backdrop-filter: saturate(140%) blur(14px);
  border-bottom: 1px solid color-mix(in oklch, var(--line) 70%, transparent);
}
.site-head-brand { display: flex; align-items: center; gap: 11px; flex: none; text-decoration: none; color: var(--ink); }
/* アプリ用 .nav-tab は <button> 前提のため、<a> での下線を抑止 */
.site-head .nav-tab { text-decoration: none; }
.site-head-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 9px 16px; border-radius: var(--radius-pill);
  background: var(--acc); color: var(--on-acc);
  font-weight: 700; font-size: 14px; text-decoration: none;
  box-shadow: 0 8px 20px -8px var(--acc);
}
.site-head-cta:hover { background: var(--acc-strong); }

/* ---------- 本文ラッパ ---------- */
.doc-wrap { max-width: 820px; margin: 0 auto; padding: clamp(24px, 4vw, 44px) clamp(16px, 4vw, 40px) 96px; }
.doc-wrap.wide { max-width: 1180px; } /* カード系（ガイド一覧）はアプリ本体と同じ枠に揃える */

.crumbs { font-size: 13px; color: var(--ink-3); margin-bottom: 18px; }
.crumbs a { color: var(--ink-2); text-decoration: none; }
.crumbs a:hover { color: var(--acc-strong); text-decoration: underline; }
.crumbs .sep { margin: 0 7px; color: var(--line-strong); }

.doc-eyebrow { font-family: var(--ff-serif); font-style: italic; font-size: 15px; color: var(--acc-strong); margin-bottom: 4px; }
.doc-h1 { font-family: var(--ff-head); font-size: clamp(26px, 4.5vw, 36px); font-weight: 900; line-height: 1.18; letter-spacing: .01em; margin: 0 0 10px; }
.doc-lead { font-size: 16px; color: var(--ink-2); line-height: 1.85; margin: 0 0 8px; }
.doc-meta { font-size: 12.5px; color: var(--ink-3); margin: 6px 0 26px; }

/* 記事/法的文書の本文 */
.doc { font-size: 15.5px; line-height: 1.95; color: var(--ink); }
.doc h2 { font-family: var(--ff-head); font-size: clamp(20px, 3vw, 25px); font-weight: 800; line-height: 1.35; margin: 38px 0 14px; padding-top: 10px; border-top: 1px solid var(--line); }
.doc h2:first-child { border-top: none; padding-top: 0; margin-top: 0; }
.doc h3 { font-size: 17.5px; font-weight: 800; margin: 26px 0 10px; color: var(--ink); }
.doc p { margin: 0 0 16px; }
.doc ul, .doc ol { margin: 0 0 18px; padding-left: 1.4em; }
.doc li { margin: 6px 0; }
.doc a { color: var(--acc-strong); text-decoration: underline; text-underline-offset: 2px; }
.doc a:hover { color: var(--acc); }
.doc strong { font-weight: 800; }
.doc blockquote { margin: 18px 0; padding: 4px 16px; border-left: 3px solid var(--acc); color: var(--ink-2); background: color-mix(in oklch, var(--acc) 6%, transparent); border-radius: 0 10px 10px 0; }
.doc table { width: 100%; border-collapse: collapse; margin: 18px 0; font-size: 14px; }
.doc th, .doc td { border: 1px solid var(--line); padding: 9px 12px; text-align: left; }
.doc th { background: var(--surface-2); font-weight: 700; }
.doc code { font-family: var(--ff-data); background: var(--surface-2); padding: 1px 6px; border-radius: 6px; font-size: 13.5px; }

/* 記事中の図解（インライン SVG・図表）。本文の理解を助ける挿絵。 */
.doc-figure { margin: 26px 0; }
.doc-figure svg {
  display: block; width: 100%; height: auto;
  border: 1px solid var(--line); border-radius: 14px;
  background: var(--surface); box-shadow: var(--shadow-sm);
}
.doc-figure figcaption {
  margin-top: 10px; font-size: 12.5px; color: var(--ink-3); line-height: 1.65;
  text-align: center; max-width: 32em; margin-left: auto; margin-right: auto;
}

/* 強調ボックス */
.callout { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; margin: 20px 0; box-shadow: var(--shadow-sm); }
.callout-title { font-weight: 800; margin-bottom: 6px; display: flex; align-items: center; gap: 8px; }
.callout.warn { background: color-mix(in oklch, var(--pos) 7%, var(--surface)); border-color: color-mix(in oklch, var(--pos) 30%, var(--line)); }
.callout.tip { background: color-mix(in oklch, var(--acc) 7%, var(--surface)); border-color: color-mix(in oklch, var(--acc) 28%, var(--line)); }

/* ---------- ガイド一覧（アイコン付きカード） ---------- */
.guide-cards { display: flex; flex-direction: column; gap: 14px; margin-top: 26px; }
.guide-card {
  display: flex; align-items: center; gap: 16px;
  padding: 18px 20px; background: var(--surface);
  border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow-sm); text-decoration: none; color: var(--ink);
  transition: border-color .15s, box-shadow .15s, transform .15s;
}
.guide-card:hover { border-color: var(--acc); box-shadow: var(--shadow); transform: translateY(-1px); }
.guide-ico {
  width: 54px; height: 54px; flex: none; border-radius: 15px;
  display: grid; place-items: center; color: var(--acc-strong);
  background: color-mix(in oklch, var(--acc) 12%, var(--surface));
  border: 1px solid color-mix(in oklch, var(--acc) 22%, transparent);
}
.guide-ico svg { width: 25px; height: 25px; }
.guide-card-body { flex: 1; min-width: 0; }
.guide-card-title { display: flex; align-items: flex-start; gap: 9px; font-size: 16.5px; font-weight: 800; line-height: 1.45; color: var(--ink); }
.guide-num {
  flex: none; margin-top: 1px; width: 22px; height: 22px; border-radius: 50%;
  background: var(--acc); color: var(--on-acc);
  font-size: 12.5px; font-weight: 800; font-family: var(--ff-data);
  display: grid; place-items: center; line-height: 1;
}
.guide-card-titletext { min-width: 0; }
.guide-card-desc { font-size: 13px; color: var(--ink-2); line-height: 1.7; margin-top: 6px; }
.guide-card-arrow { flex: none; color: var(--ink-3); display: grid; place-items: center; transition: color .15s, transform .15s; }
.guide-card-arrow svg { width: 20px; height: 20px; }
.guide-card:hover .guide-card-arrow { color: var(--acc-strong); transform: translateX(3px); }
@media (max-width: 560px) {
  .guide-card { padding: 15px 16px; gap: 13px; }
  .guide-ico { width: 46px; height: 46px; border-radius: 13px; }
  .guide-ico svg { width: 22px; height: 22px; }
  .guide-card-title { font-size: 15px; }
}

/* ---------- お問い合わせフォーム ---------- */
.contact-form { margin-top: 22px; max-width: 560px; }
.contact-form .field { margin-bottom: 16px; }
.contact-form textarea.input { min-height: 150px; resize: vertical; line-height: 1.7; }
.contact-hp { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }
.form-note { font-size: 12.5px; color: var(--ink-3); margin-top: 10px; line-height: 1.7; }
.form-error { color: var(--pos); font-weight: 700; font-size: 13.5px; margin-bottom: 14px; }
.form-ok { background: color-mix(in oklch, var(--neg) 12%, var(--surface)); border: 1px solid color-mix(in oklch, var(--neg) 32%, var(--line)); color: var(--ink); border-radius: var(--radius); padding: 18px 20px; }
.form-ok-title { font-weight: 800; font-size: 16px; margin-bottom: 6px; }

/* 記事本文内の CTA ボタン（.doc a の下線・色に勝つよう a.doc-cta で指定） */
.doc-cta, .doc a.doc-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 26px; border-radius: var(--radius-pill);
  background: var(--acc); color: var(--on-acc);
  font-weight: 800; font-size: 15.5px; text-decoration: none;
  box-shadow: 0 12px 26px -10px var(--acc); transition: background .15s, transform .12s;
}
.doc-cta:hover, .doc a.doc-cta:hover { background: var(--acc-strong); color: var(--on-acc); text-decoration: none; transform: translateY(-1px); }
.doc-cta:active, .doc a.doc-cta:active { transform: translateY(0); }

/* 関連記事リスト（記事末の回遊導線） */
.doc ul.doc-related { list-style: none; padding-left: 0; margin: 0 0 8px; display: grid; gap: 10px; }
.doc ul.doc-related li { margin: 0; }
.doc ul.doc-related a {
  display: block; padding: 14px 16px; border: 1px solid var(--line); border-radius: 12px;
  background: var(--card, #fff); color: var(--ink); font-weight: 700; text-decoration: none;
  transition: border-color .15s, background .15s;
}
.doc ul.doc-related a:hover { border-color: var(--acc); color: var(--acc-strong); }

.back-link { display: inline-flex; align-items: center; gap: 6px; margin-top: 36px; font-size: 14px; font-weight: 700; color: var(--acc-strong); text-decoration: none; }
.back-link:hover { text-decoration: underline; }

/* ---------- 使い方ガイド（howto） ---------- */
/* 一覧カードのアイコンは guide のラインアイコン枠（.guide-ico）をそのまま流用。 */
/* 章ページ h1 の先頭に置くコーラルのラインアイコン（バッジ） */
.howto-h1 { display: flex; align-items: center; gap: 12px; }
.howto-h1-ico {
  flex: none; width: 40px; height: 40px; border-radius: 11px;
  display: grid; place-items: center; color: var(--acc-strong);
  background: color-mix(in oklch, var(--acc) 12%, var(--surface));
  border: 1px solid color-mix(in oklch, var(--acc) 22%, transparent);
}
.howto-h1-ico svg { width: 22px; height: 22px; }
@media (max-width: 560px) {
  .howto-h1 { gap: 10px; }
  .howto-h1-ico { width: 34px; height: 34px; border-radius: 10px; }
  .howto-h1-ico svg { width: 19px; height: 19px; }
}

/* スクリーンショット図（SP縦長・番号は画像に焼き込み済み） */
.doc .howto-shot { margin: 22px 0; text-align: center; }
.doc .howto-shot img {
  max-width: 340px; width: 100%; height: auto; border-radius: 14px;
  border: 1px solid var(--line); box-shadow: var(--shadow);
  background: var(--surface);
}
.doc .howto-shot figcaption {
  margin-top: 10px; font-size: 12.5px; color: var(--ink-3); line-height: 1.65;
  max-width: 28em; margin-left: auto; margin-right: auto;
}

/* 前後の章ナビ */
.howto-nav { display: flex; gap: 12px; margin: 36px 0 8px; }
.howto-nav-btn {
  flex: 1 1 0; min-width: 0; display: flex; flex-direction: column; gap: 3px;
  padding: 13px 16px; border: 1px solid var(--line); border-radius: 12px;
  background: var(--surface); text-decoration: none; transition: border-color .15s, box-shadow .15s, transform .15s;
}
.howto-nav-btn.next { text-align: right; align-items: flex-end; }
.howto-nav-btn:hover { border-color: var(--acc); box-shadow: var(--shadow-sm); transform: translateY(-1px); }
.howto-nav-btn.disabled { visibility: hidden; }
.howto-nav-dir { font-size: 12px; font-weight: 700; color: var(--acc-strong); }
.howto-nav-title { font-size: 13.5px; font-weight: 700; color: var(--ink); line-height: 1.4; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 100%; }
@media (max-width: 560px) { .howto-nav-title { white-space: normal; } }

/* 章内の目次 */
.howto-toc { margin-top: 30px; padding: 18px 20px; border: 1px solid var(--line); border-radius: 14px; background: var(--surface-2); }
.howto-toc-h { font-weight: 800; font-size: 14px; margin-bottom: 10px; color: var(--ink); }
.howto-toc-list { margin: 0; padding-left: 1.4em; display: grid; gap: 7px; font-size: 14px; }
.howto-toc-list li { line-height: 1.5; }
.howto-toc-list a { color: var(--ink-2); text-decoration: none; }
.howto-toc-list a:hover { color: var(--acc-strong); text-decoration: underline; }
.howto-toc-list li.cur { font-weight: 800; color: var(--ink); }

/* ---------- 404 ---------- */
.notfound { text-align: center; padding: clamp(28px, 8vw, 80px) 0 40px; }
.notfound-code {
  font-family: var(--ff-serif); font-weight: 600; line-height: 1;
  font-size: clamp(84px, 18vw, 160px);
  background: linear-gradient(155deg, var(--acc) 0%, var(--acc-strong) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  letter-spacing: .02em; margin-bottom: 8px;
}
.notfound .doc-lead { max-width: 30em; margin: 0 auto 26px; }
.notfound-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 26px; }
.notfound-links { display: flex; gap: 8px 22px; justify-content: center; flex-wrap: wrap; }
.notfound-links a { font-size: 14px; font-weight: 600; color: var(--ink-2); text-decoration: none; }
.notfound-links a:hover { color: var(--acc-strong); text-decoration: underline; }

/* ===== allauth ページ（新規登録・メール認証・パスワード再設定） =====
   葉テンプレートは {% element %} の素の HTML（h1/p/form/input/button）を出力するため、
   .allauth-card 配下を個別に装飾する（フォーム類は styles.css の変数を流用）。 */
.auth-stack { display: flex; flex-direction: column; align-items: center; }
.auth-stack .back-link { margin-top: 22px; }
.allauth-card h1 { font-size: 22px; font-weight: 800; letter-spacing: .01em; margin: 2px 0 14px; }
.allauth-card > p { font-size: 13.5px; color: var(--ink-3); line-height: 1.75; margin: 0 0 14px; }
.allauth-card form { margin: 16px 0 4px; }
.allauth-card form p { margin: 0 0 14px; color: var(--ink); font-size: 13.5px; }
.allauth-card label { display: block; font-size: 12.5px; font-weight: 700; color: var(--ink-2); margin: 0 0 6px; }
.allauth-card input[type="text"],
.allauth-card input[type="email"],
.allauth-card input[type="password"] {
  width: 100%; box-sizing: border-box; height: 46px; padding: 0 14px;
  border: 1px solid var(--line); border-radius: 12px; background: var(--surface);
  font-size: 15px; color: var(--ink); font-family: inherit;
}
.allauth-card input:focus { outline: none; border-color: var(--acc); box-shadow: 0 0 0 3px color-mix(in oklch, var(--acc) 20%, transparent); }
.allauth-card button[type="submit"], .allauth-card a.button {
  display: block; width: 100%; box-sizing: border-box; text-align: center;
  margin-top: 10px; height: 48px; line-height: 48px; padding: 0 18px; border: none;
  border-radius: 12px; background: var(--acc); color: var(--on-acc);
  font-size: 15px; font-weight: 700; cursor: pointer; text-decoration: none;
  box-shadow: 0 8px 20px -8px var(--acc);
}
.allauth-card button[type="submit"]:hover, .allauth-card a.button:hover { background: var(--acc-strong); }
/* キャンセル等のリンク調ボタン（パスワード再設定の Cancel など） */
.allauth-card button[form="logout-from-stage"], .allauth-card button.cancel, .allauth-card a.cancel {
  background: none; color: var(--ink-3); box-shadow: none; font-weight: 600;
  height: auto; line-height: 1.7; margin-top: 12px;
}
.allauth-card .errorlist { list-style: none; margin: 0 0 8px; padding: 0; color: var(--pos); font-size: 12px; font-weight: 700; }
.allauth-card .helptext { display: block; font-size: 11.5px; color: var(--ink-3); margin-top: 5px; line-height: 1.55; }
.allauth-card a { color: var(--acc-strong); font-weight: 700; }
.auth-msgs { margin-bottom: 14px; }
.auth-msg { font-size: 13px; padding: 10px 12px; border-radius: 10px; background: var(--surface-2); margin: 0 0 8px; line-height: 1.6; }
.auth-msg.error { color: var(--pos); }
.auth-msg.success { color: var(--acc-strong); }

/* ===== 秘匿管理画面（スーパーユーザー専用 /admin_.../） ===== */
.ops-head .ops-badge { margin-left: 8px; font-size: 11px; font-weight: 800; color: var(--on-acc); background: var(--ink); padding: 2px 8px; border-radius: 999px; letter-spacing: .04em; }
.ops-me { font-size: 12.5px; color: var(--ink-3); margin-right: 12px; }
.ops-wrap { padding-top: 18px; }
.ops-nav { display: flex; gap: 6px; flex-wrap: wrap; border-bottom: 1px solid var(--line); margin-bottom: 18px; }
.ops-tab { padding: 9px 14px; font-size: 13.5px; font-weight: 700; color: var(--ink-2); text-decoration: none; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.ops-tab:hover { color: var(--acc-strong); }
.ops-tab.on { color: var(--acc-strong); border-bottom-color: var(--acc); }
.ops-badge-n { display: inline-grid; place-items: center; min-width: 18px; height: 18px; padding: 0 5px; margin-left: 6px; border-radius: 999px; background: var(--pos); color: #fff; font-size: 11px; font-weight: 800; font-family: var(--ff-data); line-height: 1; vertical-align: middle; }

/* お問い合わせ内のサブタブ（通常 / NG） */
.ops-subtabs { display: inline-flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 999px; padding: 4px; margin-bottom: 16px; }
.ops-subtab { display: inline-flex; align-items: center; padding: 7px 18px; border-radius: 999px; font-size: 13.5px; font-weight: 700; color: var(--ink-2); text-decoration: none; }
.ops-subtab:hover { color: var(--acc-strong); }
.ops-subtab.on { background: var(--surface); color: var(--acc-strong); box-shadow: var(--shadow-sm); }

/* 未読（今回表示で既読化した）メッセージの強調 */
.ops-contact.is-new { border-color: color-mix(in oklch, var(--acc) 45%, var(--line)); background: color-mix(in oklch, var(--acc) 5%, var(--surface)); }
.ops-newpill { display: inline-block; font-size: 10.5px; font-weight: 800; color: var(--on-acc); background: var(--acc); border-radius: 4px; padding: 1px 6px; margin-right: 8px; vertical-align: middle; }
.ops-h1 { font-family: var(--ff-head); font-size: 24px; font-weight: 900; margin: 4px 0 18px; }
.ops-h2 { font-size: 17px; font-weight: 800; margin: 26px 0 12px; }
.ops-note { font-size: 13px; color: var(--ink-2); line-height: 1.7; margin: 0 0 14px; }
.ops-hint { font-size: 11.5px; color: var(--ink-3); margin: 5px 0 0; }
.ops-count { font-size: 13px; color: var(--ink-3); margin: 0 0 14px; }
.ops-empty { color: var(--ink-3); font-size: 13.5px; padding: 16px 0; text-align: center; }

.ops-msgs { margin-bottom: 16px; display: flex; flex-direction: column; gap: 8px; }
.ops-msg { font-size: 13.5px; padding: 11px 14px; border-radius: 10px; background: var(--surface-2); border: 1px solid var(--line); }
.ops-msg.success { border-color: color-mix(in oklch, var(--neg) 40%, var(--line)); background: color-mix(in oklch, var(--neg) 10%, var(--surface)); }
.ops-msg.error { border-color: color-mix(in oklch, var(--pos) 40%, var(--line)); background: color-mix(in oklch, var(--pos) 10%, var(--surface)); color: var(--ink); }

.ops-stat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 12px; }
.ops-stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px 18px; box-shadow: var(--shadow-sm); }
.ops-stat-warn { border-color: color-mix(in oklch, var(--pos) 35%, var(--line)); }
.ops-stat-n { font-family: var(--ff-data); font-size: 26px; font-weight: 800; color: var(--ink); line-height: 1.1; }
.ops-stat-l { font-size: 12px; color: var(--ink-3); margin-top: 6px; }

/* ダッシュボード：主要KPI */
.ops-kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); gap: 14px; margin-bottom: 26px; }
.ops-kpi { background: var(--surface); border: 1px solid var(--line); border-left: 4px solid var(--acc); border-radius: var(--radius); padding: 18px 20px; box-shadow: var(--shadow-sm); }
.ops-kpi-n { font-family: var(--ff-data); font-size: 34px; font-weight: 800; color: var(--ink); line-height: 1.05; }
.ops-kpi-l { font-size: 13px; font-weight: 700; color: var(--ink-2); margin-top: 7px; }
.ops-kpi-s { font-size: 11px; font-weight: 500; color: var(--ink-3); display: block; margin-top: 1px; }

/* ダッシュボード：チャート（サーバー生成のインラインSVG） */
.ops-chart { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px 20px; box-shadow: var(--shadow-sm); margin-bottom: 18px; }
.ops-chart-head { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 10px; }
.ops-chart-title { font-size: 15px; font-weight: 800; color: var(--ink); margin: 0; }
.ops-chart-range { font-size: 12px; color: var(--ink-3); font-family: var(--ff-data); }
.ops-chart-legend { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 6px; }
.ops-leg { font-size: 12px; color: var(--ink-2); display: inline-flex; align-items: center; gap: 6px; }
.ops-leg i { width: 11px; height: 11px; border-radius: 3px; display: inline-block; }
.ops-leg b { font-family: var(--ff-data); color: var(--ink); }
.ops-chart-svgwrap { width: 100%; overflow-x: auto; }
.ops-chartsvg { width: 100%; min-width: 560px; height: auto; display: block; }
.ops-grid { stroke: var(--line); stroke-width: 1; }
.ops-axislab { fill: var(--ink-3); font-size: 11px; font-family: var(--ff-data); }
.ops-barrect { fill: var(--acc); }

/* ダッシュボード：補助指標の見出し下の余白調整は inline で */

/* お問い合わせ：ツールバー・既読フィルタ・UA 表示 */
.ops-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; margin: 0 0 14px; }
.ops-filter { display: inline-flex; gap: 4px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 999px; padding: 3px; }
.ops-filter-tab { padding: 5px 14px; border-radius: 999px; font-size: 12.5px; font-weight: 700; color: var(--ink-2); text-decoration: none; }
.ops-filter-tab:hover { color: var(--acc-strong); }
.ops-filter-tab.on { background: var(--surface); color: var(--acc-strong); box-shadow: var(--shadow-sm); }
.ops-contact-ua { display: flex; flex-wrap: wrap; gap: 6px 16px; margin-top: 10px; }
.ops-contact-meta.ua { word-break: break-all; max-width: 100%; }
.ops-link.strong { color: var(--acc-strong); background: none; border: none; font: inherit; font-weight: 800; cursor: pointer; padding: 0; }
.ops-link.strong:hover { text-decoration: underline; }

.ops-search { display: flex; gap: 8px; margin-bottom: 14px; max-width: 520px; }
.ops-search .input { flex: 1; }
.ops-link { color: var(--acc-strong); font-weight: 700; text-decoration: none; }
.ops-link:hover { text-decoration: underline; }
.ops-link.danger, .ops-contact-foot button.danger { color: var(--pos); background: none; border: none; font: inherit; font-weight: 700; cursor: pointer; padding: 0; }
.ops-pill { display: inline-block; font-size: 11px; font-weight: 800; padding: 1px 7px; border-radius: 999px; }
.ops-pill.ok { color: var(--neg); background: color-mix(in oklch, var(--neg) 14%, transparent); }
.ops-pill.ng { color: var(--pos); background: color-mix(in oklch, var(--pos) 14%, transparent); }
.ops-pill.super { color: var(--on-acc); background: var(--acc); }

.ops-pager { display: flex; align-items: center; gap: 14px; justify-content: center; margin-top: 22px; }
.ops-pager-now { font-size: 13px; color: var(--ink-3); }

.ops-panel { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 20px 22px; box-shadow: var(--shadow-sm); margin-bottom: 20px; }
.ops-kv { width: 100%; border-collapse: collapse; }
.ops-kv th { text-align: left; width: 140px; color: var(--ink-3); font-weight: 700; font-size: 13px; padding: 7px 10px 7px 0; vertical-align: top; }
.ops-kv td { padding: 7px 0; font-size: 14px; }

.ops-actions { display: flex; flex-direction: column; gap: 12px; margin: 18px 0 8px; }
.ops-act { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.ops-danger { border: 1px solid color-mix(in oklch, var(--pos) 40%, var(--line)); border-radius: var(--radius); padding: 14px 16px; background: color-mix(in oklch, var(--pos) 6%, var(--surface)); }
.ops-danger-title { font-weight: 800; color: var(--pos); margin-bottom: 4px; }
.ops-danger-note { font-size: 12.5px; color: var(--ink-2); margin: 0 0 10px; line-height: 1.6; }
.ops-danger .input { max-width: 280px; }

.btn-warn { background: color-mix(in oklch, var(--pos) 16%, var(--surface)); color: var(--pos); border: 1px solid color-mix(in oklch, var(--pos) 40%, var(--line)); }
.btn-warn:hover { background: color-mix(in oklch, var(--pos) 24%, var(--surface)); }
.btn-danger { background: var(--pos); color: #fff; }
.btn-danger:hover { filter: brightness(.94); }

.ops-contact-list { display: flex; flex-direction: column; gap: 12px; }
.ops-contact { background: var(--surface); border: 1px solid var(--line); border-radius: var(--radius); padding: 14px 16px; box-shadow: var(--shadow-sm); }
.ops-contact-head { display: flex; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-bottom: 8px; }
.ops-contact-from { font-weight: 700; font-size: 14px; color: var(--ink); }
.ops-contact-at { font-size: 12px; color: var(--ink-3); }
.ops-contact-body { font-size: 14px; line-height: 1.75; color: var(--ink); white-space: pre-wrap; word-break: break-word; }
.ops-contact-foot { display: flex; justify-content: space-between; align-items: center; gap: 10px; margin-top: 10px; padding-top: 8px; border-top: 1px solid var(--line); }
.ops-contact-meta { font-size: 11.5px; color: var(--ink-3); font-family: var(--ff-data); }

.ops-field { margin: 14px 0; }
.ops-lbl { display: block; font-size: 12.5px; font-weight: 700; color: var(--ink-2); margin-bottom: 6px; }
.ops-check { display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600; margin-bottom: 8px; }
.ops-ngadd { display: flex; gap: 8px; align-items: flex-start; margin-bottom: 14px; }
.ops-ngadd .input { flex: 1; }
.ops-ngwords { display: flex; flex-wrap: wrap; gap: 8px; }
.ops-ngword { display: inline-flex; align-items: center; gap: 6px; background: var(--surface-2); border: 1px solid var(--line); border-radius: 999px; padding: 4px 6px 4px 12px; font-size: 13px; }
.ops-ngword form { display: inline; }
.ops-ngword button { border: none; background: var(--line); color: var(--ink-2); width: 18px; height: 18px; border-radius: 50%; cursor: pointer; font-size: 12px; line-height: 1; display: grid; place-items: center; }
.ops-ngword button:hover { background: var(--pos); color: #fff; }
