@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap');
  :root {
    --bg: #FFFFFF;
    --surface: #F7F8FC;
    --border: #E2E5F0;
    --accent: #2A47BB;
    --accent-shade: #EAECF6;
    --accent2: #BEF452;
    --accent2-shade: #DCEED1;
    --black: #030303;
    --text: #030303;
    --text-dim: #6B7280;
    --text-mid: #374151;
    --green: #2A47BB;
    --green-dim: #EAECF6;
    /* ── セマンティック拡張トークン（ダークモード一括化の土台。ライト値） ── */
    --card: #FFFFFF;          /* カード/入力の面（旧 #fff） */
    --on-accent: #FFFFFF;     /* アクセント色の上に乗る文字（ダークでも白固定） */
    --on-strong: #FFFFFF;     /* 濃ボタン上の文字 */
    --btn-strong: #4B5563;    /* 中濃ボタン（一覧戻る等） */
    --btn-strong-h: #3B424F;
    --btn-dark: #1F2937;      /* AI/要約系の濃ボタン */
    --accent-soft: #EEF2FF;   /* 淡アクセント面 */
    --ok: #1E7E4F;
    --warn: #D6921A;
    --danger: #C0392B;
    --danger-soft: #FBEAEA;
    /* ステータス/データ色（チップ・バッジ） */
    --st-blue: #6B7CFF; --st-amber: #D6B24A; --st-gray: #B9BFC7; --st-green: #2E9E6B; --st-slate: #8B929C; --st-rose: #D98B8B;
    --pri-p1: #E2574C; --pri-p2: #D6921A; --pri-p3: #7A86C0;
    /* 淡色コールアウト（FACILITATOR補足=amber / ADVISOR壁打ち=indigo） */
    --amber-bg: #FFF8E6; --amber-border: #F0D089; --amber-accent: #E0A800; --amber-head: #B8860B; --amber-text: #5A4A1A;
    --indigo-bg: #EEF2FF; --indigo-bg-h: #E0E7FF; --indigo-border: #C7D2FE; --indigo-head: #4F46E5; --indigo-text: #33373D;
  }
  /* ── ダークモード一括上書き（トグルで html.dark を付与） ── */
  html.dark {
    --bg:#0F141B; --surface:#161D27; --border:#2C3440; --accent:#7C8CFF; --accent-shade:#222C46; --accent2:#BEF452; --accent2-shade:#2A361C;
    --black:#F0F2F5; --text:#E6E8EC; --text-dim:#9AA3B2; --text-mid:#C4CAD4; --green:#7C8CFF; --green-dim:#222C46;
    --card:#1B2230; --on-accent:#FFFFFF; --on-strong:#FFFFFF; --btn-strong:#3A4150; --btn-strong-h:#2C323D; --btn-dark:#2A3140; --accent-soft:#1E2440;
    --ok:#3FB984; --warn:#E0A848; --danger:#F0726A; --danger-soft:#3A1F1F;
    --st-blue:#7C8CFF; --st-amber:#D6B24A; --st-gray:#7A828F; --st-green:#34B07A; --st-slate:#8B929C; --st-rose:#D98B8B;
    --pri-p1:#F0726A; --pri-p2:#E0A848; --pri-p3:#9AA3E8;
    --amber-bg:#2A2417; --amber-border:#4A3F22; --amber-accent:#CAA23A; --amber-head:#E0B84A; --amber-text:#E9DCB8;
    --indigo-bg:#1E2336; --indigo-bg-h:#262D44; --indigo-border:#39426A; --indigo-head:#AAB4FF; --indigo-text:#D6DAE6;
  }
  html.dark body { background: var(--bg); }
  /* ── ライト固定の島（未ダーク化モジュール：DOVE/LAIKA/IRIS/NAUTILUS） ── */
  .ark-light {
    --bg:#FFFFFF; --surface:#F7F8FC; --border:#E2E5F0; --accent:#2A47BB; --accent-shade:#EAECF6; --accent2:#BEF452; --accent2-shade:#DCEED1;
    --black:#030303; --text:#030303; --text-dim:#6B7280; --text-mid:#374151; --green:#2A47BB; --green-dim:#EAECF6;
    --card:#FFFFFF; --on-accent:#FFFFFF; --on-strong:#FFFFFF; --btn-strong:#4B5563; --btn-strong-h:#3B424F; --btn-dark:#1F2937; --accent-soft:#EEF2FF;
    --ok:#1E7E4F; --warn:#D6921A; --danger:#C0392B; --danger-soft:#FBEAEA;
    --st-blue:#6B7CFF; --st-amber:#D6B24A; --st-gray:#B9BFC7; --st-green:#2E9E6B; --st-slate:#8B929C; --st-rose:#D98B8B;
    --pri-p1:#E2574C; --pri-p2:#D6921A; --pri-p3:#7A86C0;
    --amber-bg:#FFF8E6; --amber-border:#F0D089; --amber-accent:#E0A800; --amber-head:#B8860B; --amber-text:#5A4A1A;
    --indigo-bg:#EEF2FF; --indigo-bg-h:#E0E7FF; --indigo-border:#C7D2FE; --indigo-head:#4F46E5; --indigo-text:#33373D;
    background:#FFFFFF; color:#030303;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  body {
    background: var(--bg);
    color: var(--text);
    font-family: 'Segoe UI', 'Noto Sans JP', sans-serif;
    min-height: 100vh;
    font-size: 14px;
  }
  .header { border-bottom: 1px solid var(--border); padding: 16px 32px; display: flex; align-items: center; gap: 16px; background: var(--bg); }
  .logo { font-family: 'Segoe UI', 'Noto Sans JP', sans-serif; font-size: 20px; font-weight: 700; color: var(--accent); letter-spacing: 0.05em; }
  .logo-sub { color: var(--text-dim); font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; }
  .status-wrap { margin-left: auto; display: flex; align-items: center; gap: 8px; }
  .status-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--text-dim); }
  .status-dot.connected { background: var(--green); animation: pulse 2s infinite; }
  .status-label { font-size: 10px; color: var(--text-dim); letter-spacing: 0.1em; }
  @keyframes pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.3; } }
  .main { display: grid; grid-template-columns: 360px 1fr; height: calc(100vh - 65px); }
  .sidebar { border-right: 1px solid var(--border); padding: 24px; overflow-y: auto; flex-direction: column; gap: 20px; background: var(--surface); width: 360px; min-width: 360px; }
  .sidebar.visible { display: flex; }
  .sidebar.hidden { display: none; width: 0; min-width: 0; padding: 0; border: none; }
  .main.no-sidebar { grid-template-columns: 1fr; }
  .section-label { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-dim); margin-bottom: 12px; }
  .token-section { background: var(--bg); border: 1px solid var(--border); padding: 16px; border-radius: 6px; }
  input, select, textarea { width: 100%; background: var(--bg); border: 1px solid var(--border); color: var(--text); font-family: 'Segoe UI', 'Noto Sans JP', sans-serif; font-size: 14px; padding: 10px 12px; border-radius: 6px; outline: none; transition: border-color 0.2s; }
  input:focus, select:focus, textarea:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-shade); }
  input::placeholder, textarea::placeholder { color: var(--text-dim); }
  select option { background: var(--bg); }
  .field { margin-bottom: 12px; }
  .field label { display: block; font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-mid); margin-bottom: 6px; }
  .ms-options { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
  .ms-option { font-size: 12px; padding: 4px 10px; border: 1.5px solid var(--border); border-radius: 20px; color: var(--text-dim); cursor: pointer; transition: all 0.15s; user-select: none; background: var(--bg); }
  .ms-option.active { border-color: var(--accent); color: var(--accent); background: var(--accent-shade); }
  .btn { width: 100%; padding: 10px 16px; background: transparent; border: 1.5px solid var(--accent); color: var(--accent); font-family: 'Segoe UI', 'Noto Sans JP', sans-serif; font-size: 13px; font-weight: 500; letter-spacing: 0.03em; cursor: pointer; border-radius: 6px; transition: all 0.2s; }
  .btn:hover { background: var(--accent); color: var(--bg); }
  .btn:disabled { border-color: var(--border); color: var(--text-dim); cursor: not-allowed; }
  .btn:disabled:hover { background: transparent; color: var(--text-dim); }
  .btn-primary { background: var(--accent); color: var(--bg); font-weight: 700; }
  .btn-primary:hover { background: #1e38a0; }
  .btn-primary:disabled { background: var(--accent-shade); border-color: var(--accent-shade); color: var(--text-dim); }
  .btn-sm { padding: 6px 14px; font-size: 12px; width: auto; }
  .content { display: flex; flex-direction: column; overflow: hidden; }
  .tabs { border-bottom: 1px solid var(--border); display: flex; padding: 0 32px; background: var(--bg); }
  .tab { padding: 14px 20px; font-size: 12px; font-weight: 500; letter-spacing: 0.05em; color: var(--text-dim); cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.2s; }
  .tab.active { color: var(--accent); border-bottom-color: var(--accent); }
  .tab:hover:not(.active) { color: var(--text-mid); }
  .panel { flex: 1; overflow-y: auto; padding: 32px; display: none; }
  .panel.active { display: block; }
  .cases-grid { display: grid; gap: 12px; }
  .case-card { background: var(--surface); border: 1px solid var(--border); border-radius: 4px; padding: 20px; cursor: pointer; transition: all 0.2s; }
  .case-card:hover { border-color: var(--green); }
  .case-card.selected { border-color: var(--green); background: var(--accent-shade); }
  .case-brand { font-family: 'DM Serif Display', serif; font-size: 18px; color: var(--accent); margin-bottom: 6px; }
  .case-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 10px; }
  .tag { font-size: 10px; padding: 3px 8px; border: 1px solid var(--border); border-radius: 2px; color: var(--text-dim); letter-spacing: 0.1em; }
  .tag.green { border-color: var(--green-dim); color: var(--green); }
  .tag.pill { border-radius: 999px; border-color: var(--border); color: var(--text-dim); font-size: 10px; padding: 2px 8px; }
  .tag-divider { width: 1px; background: var(--border); align-self: stretch; margin: 0 4px; display: inline-block; }
  .case-brief { font-size: 12px; color: var(--text-mid); line-height: 1.6; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
  .output-area { background: var(--surface); border: 1px solid var(--border); border-radius: 4px; padding: 24px; min-height: 300px; font-size: 13px; line-height: 1.8; color: var(--text); white-space: pre-wrap; }
  .output-area.empty { display: flex; align-items: center; justify-content: center; color: var(--text-dim); font-style: italic; }
  .loading { display: flex; align-items: center; gap: 8px; color: var(--text-dim); font-size: 13px; }
  .spinner { width: 16px; height: 16px; border: 2px solid var(--border); border-top-color: var(--accent); border-radius: 50%; animation: spin 0.8s linear infinite; }
  @keyframes spin { to { transform: rotate(360deg); } }
  .error { color: #e07070; font-size: 11px; padding: 10px 12px; background: #1a0f0f; border: 1px solid #3a1f1f; border-radius: 3px; margin-top: 8px; word-break: break-all; line-height: 1.6; }
  .success { color: var(--green); font-size: 12px; padding: 10px 12px; background: var(--accent-shade); border: 1px solid var(--green-dim); border-radius: 3px; margin-top: 8px; }
  .url-section { background: var(--bg); border: 1.5px solid var(--border); padding: 20px; border-radius: 8px; margin-bottom: 20px; }
  .url-input-row { display: flex; gap: 8px; }
  .url-input-row input { flex: 1; }
  .import-status { margin-top: 10px; font-size: 11px; line-height: 1.7; color: var(--text-mid); }
  .import-step { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
  .import-step .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--border); flex-shrink: 0; }
  .import-step.done .dot { background: var(--green); }
  .import-step.active .dot { background: var(--accent); animation: pulse 1s infinite; }
  .import-step.error .dot { background: #e07070; }
  textarea { resize: vertical; min-height: 60px; }
  ::-webkit-scrollbar { width: 6px; }
  ::-webkit-scrollbar-track { background: var(--surface); }
  ::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }
  ::-webkit-scrollbar-thumb:hover { background: var(--accent); }

  /* トップページ */
  .agent-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; padding: 40px; max-width: 1000px; margin: 0 auto; }
  .agent-card { background: var(--bg); border: 1.5px solid var(--border); border-radius: 12px; padding: 28px 24px; cursor: pointer; transition: all 0.2s; }
  .agent-card:hover:not(.disabled) { border-color: var(--accent); box-shadow: 0 4px 16px rgba(42,71,187,0.1); transform: translateY(-2px); }
  .agent-card.disabled { opacity: 0.4; cursor: not-allowed; }
  .agent-emoji { font-size: 32px; margin-bottom: 12px; }
  .agent-name { font-size: 16px; font-weight: 700; color: var(--black); margin-bottom: 4px; letter-spacing: 0.05em; }
  .agent-role { font-size: 11px; font-weight: 500; color: var(--accent); text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 10px; }
  .agent-desc { font-size: 12px; color: var(--text-dim); line-height: 1.6; }
  .agent-badge { display: inline-block; font-size: 10px; padding: 2px 8px; border-radius: 20px; background: var(--accent-shade); color: var(--accent); margin-top: 12px; }
  .agent-badge.soon { background: var(--surface); color: var(--text-dim); }

  /* ── LAIKA モーダル ──────────────────────────────────────────────── */
  .laika-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.45);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .laika-modal-box {
    background: var(--bg);
    border: 1.5px solid var(--border);
    border-radius: 12px;
    width: 480px;
    max-width: 90vw;
    max-height: 70vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  }
  .laika-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
    font-weight: 700;
    color: var(--black);
    flex-shrink: 0;
  }
  .laika-modal-close {
    background: none;
    border: none;
    width: auto !important;
    padding: 0 2px;
    font-size: 18px;
    line-height: 1;
    color: var(--text-dim);
    cursor: pointer;
  }
  .laika-modal-close:hover { color: var(--text); }
  .laika-modal-actions {
    display: flex;
    gap: 8px;
    padding: 8px 14px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
  }
  .laika-modal-body {
    overflow-y: auto;
    flex: 1;
  }
  .laika-modal-footer {
    display: flex;
    justify-content: flex-end;
    padding: 10px 14px;
    border-top: 1px solid var(--border);
    flex-shrink: 0;
  }

  /* ── LAIKA チェックリスト（laikaPage・モーダル共通） ─────────────── */
  .laika-list {
    border: 1.5px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 14px;
  }
  .laika-row {
    display: flex !important;
    align-items: center;
    justify-content: flex-start !important;
    text-align: left !important;
    gap: 10px;
    padding: 8px 14px;
    box-sizing: border-box;
    width: 100%;
    border-top: 1px solid var(--border);
    cursor: pointer;
  }
  /* DOVE見積：checkbox に global input{width:100%;padding} が効いてラベルと泣き別れる
     のを打ち消す（label でラップした「☑ ラベル」を横に隣接させる） */
  #dovePage input[type=checkbox] {
    width: auto !important;
    flex: 0 0 auto;
    margin: 0;
    padding: 0;
  }
  .laika-row:first-child { border-top: none; }
  .laika-row input[type=checkbox] {
    width: auto !important;   /* global input{width:100%} を打ち消す */
    flex: 0 0 auto;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 0;
    box-shadow: none;
    cursor: pointer;
  }
  .laika-row .laika-name {
    flex: 1 1 auto;
    min-width: 0;             /* flex子はデフォルトmin-width:auto → はみ出す。0で縮めを許可 */
    font-size: 13px;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: left;
  }
  .laika-row .laika-badge {
    flex: 0 0 auto;
    font-size: 10px;
    color: var(--text-dim);
    background: var(--surface);
    padding: 2px 7px;
    border-radius: 4px;
    border: 1px solid var(--border);
    white-space: nowrap;
  }

  @media (min-width: 1024px) {
    .panel { padding: 32px 4%; }
    #lynxPage { padding: 32px 4%; }
  }
  @media (min-width: 1440px) {
    .panel { padding: 40px 6%; }
    #lynxPage { padding: 40px 6%; }
  }
  @media (min-width: 1920px) {
    .panel { padding: 48px 10%; }
    #lynxPage { padding: 48px 10%; }
  }

  /* ── OFFERING カタログ（ark-offering.js が .ofr-root に描画） ── */
  .ofr-root { font-size: 14px; }
  .ofr-hero { margin-bottom: 20px; }
  .ofr-hero h1 { font-size: 24px; font-weight: 700; color: var(--black); letter-spacing: 0.04em; margin-bottom: 8px; }
  .ofr-hero p { font-size: 13px; color: var(--text-mid); line-height: 1.75; max-width: 760px; }
  .ofr-hero .meta { display: flex; gap: 16px; flex-wrap: wrap; margin-top: 10px; font-size: 11px; letter-spacing: 0.1em; color: var(--text-dim); }
  .ofr-tabs { border-bottom: 1px solid var(--border); display: flex; flex-wrap: wrap; margin-bottom: 20px; }
  .ofr-tab { padding: 12px 18px; font-size: 13px; font-weight: 500; letter-spacing: 0.04em; color: var(--text-dim); cursor: pointer; border-bottom: 2px solid transparent; transition: all 0.2s; }
  .ofr-tab.active { color: var(--accent); border-bottom-color: var(--accent); font-weight: 700; }
  .ofr-tab:hover:not(.active) { color: var(--text-mid); }
  .ofr-view { display: none; }
  .ofr-view.active { display: block; }
  .cap-head h2 { font-size: 20px; font-weight: 700; color: var(--black); letter-spacing: 0.03em; }
  .cap-head .cap-en { font-size: 11px; letter-spacing: 0.14em; color: var(--text-dim); text-transform: uppercase; margin-top: 2px; }
  .cap-aim { font-size: 13px; color: var(--text-mid); line-height: 1.7; max-width: 820px; margin: 12px 0 24px; padding-left: 12px; border-left: 2px solid var(--accent); }
  .phase-nav { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
  .phase-pill { font-size: 12px; padding: 6px 14px; border: 1.5px solid var(--border); border-radius: 20px; color: var(--text-dim); cursor: pointer; transition: all 0.15s; user-select: none; background: var(--bg); }
  .phase-pill.active { border-color: var(--accent); color: var(--accent); background: var(--accent-shade); font-weight: 700; }
  .phase-block { display: none; }
  .phase-block.active { display: block; }
  .phase-title { font-size: 16px; font-weight: 700; color: var(--accent); margin-bottom: 4px; letter-spacing: 0.03em; }
  .phase-title .pt-en { font-size: 11px; color: var(--text-dim); letter-spacing: 0.1em; font-weight: 500; margin-left: 8px; text-transform: uppercase; }
  .phase-aim { font-size: 12.5px; color: var(--text-mid); line-height: 1.7; max-width: 820px; margin: 8px 0 20px; }
  .ofr-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 14px; align-items: start; }
  .ofr-card { background: var(--surface); border: 1px solid var(--border); border-radius: 8px; padding: 18px 20px; transition: border-color 0.2s; }
  .ofr-card:hover { border-color: var(--accent); }
  .ofr-card h4 { font-size: 14.5px; font-weight: 700; color: var(--black); margin-bottom: 12px; letter-spacing: 0.02em; }
  .ofr-card .qa { display: grid; grid-template-columns: 54px 1fr; gap: 6px 12px; }
  .ofr-card .qa .q { font-size: 10px; letter-spacing: 0.08em; color: var(--accent); font-weight: 700; padding-top: 3px; }
  .ofr-card .qa .a { font-size: 12.5px; color: var(--text-mid); line-height: 1.65; }
  .matrix-cap { margin-bottom: 28px; }
  .matrix-cap > .mc-head { display: flex; align-items: baseline; gap: 10px; padding-bottom: 8px; border-bottom: 1.5px solid var(--accent); margin-bottom: 14px; }
  .matrix-cap > .mc-head h3 { font-size: 16px; font-weight: 700; color: var(--black); }
  .matrix-cap > .mc-head .mc-count { font-size: 11px; color: var(--text-dim); letter-spacing: 0.1em; }
  .matrix-phase { margin-bottom: 14px; }
  .matrix-phase .mp-label { font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
  .matrix-tags { display: flex; flex-wrap: wrap; gap: 6px; }
  .matrix-tag { font-size: 12px; padding: 5px 11px; border: 1px solid var(--border); border-radius: 4px; color: var(--text-mid); background: var(--bg); white-space: nowrap; }
  .matrix-tag.new { border-color: var(--accent); color: var(--accent); }
  .ofr-foot { border-top: 1px solid var(--border); margin-top: 28px; padding-top: 18px; }
  .ofr-foot p { font-size: 11px; color: var(--text-dim); line-height: 1.8; }
  @media (min-width: 1440px) {
    .ofr-root { font-size: 15px; }
    .ofr-hero h1 { font-size: 28px; }
    .ofr-grid { grid-template-columns: repeat(auto-fill, minmax(380px, 1fr)); gap: 16px; }
    .matrix-tag { font-size: 13px; }
  }
  @media (max-width: 720px) {
    .ofr-grid { grid-template-columns: 1fr; }
    .ofr-card .qa { grid-template-columns: 1fr; gap: 2px; }
    .ofr-card .qa .q { padding-top: 6px; }
  }
