  :root{
    --blue:#0b4aa2;
    --sky:#e6f4ff;
    --sky2:#cfeaff;
    --yellow:#ffd400;
    --text:#123;
    --muted:#5a6b7b;
    --line:#bcd9f2;
    --white:#fff;
    --shadow: 0 10px 24px rgba(10,40,80,.10);
    --radius: 16px;
  }



/* 見出し内の“白い囲み（枠・角丸・影）”を強制解除 */
h2 span{
  border: none !important;
  border-radius: 0 !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
}

  /* 既存CSSに負けないよう、IDで強めに */
  #sucutaTablesWrap{
    font-family: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", sans-serif;
    color: var(--text);
    line-height: 1.75;
    max-width: 1100px;
    margin: 0 auto;
    padding: 16px;
  }

  #sucutaTablesWrap .st-title{
    margin: 0 0 10px;
    font-weight: 800;
    letter-spacing: .02em;
    font-size: clamp(20px, 2.2vw, 28px);
    color: var(--white);
    position: relative;
    padding-left: 14px;
  }

  #sucutaTablesWrap .st-lead{
    margin: 0 0 16px;
    color: var(--muted);
    font-size: 14px;
  }

  #sucutaTablesWrap .st-grid{
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
  }
  @media (min-width: 920px){
    #sucutaTablesWrap .st-grid{
      grid-template-columns: 1fr 1fr;
      gap: 16px;
    }
    #sucutaTablesWrap .st-grid .st-card--wide{
      grid-column: 1 / -1;
    }
  }

  #sucutaTablesWrap .st-card{
    background: linear-gradient(180deg, var(--sky), var(--white));
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    overflow: hidden;
  }

  #sucutaTablesWrap .st-cardHead{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 10px;
    padding: 14px 14px 10px;
    background: linear-gradient(90deg, var(--blue), #1676d2);
    color: #fff;
  }
  #sucutaTablesWrap .st-cardHead h3{
    margin: 0;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: .02em;
  }
  #sucutaTablesWrap .st-badge{
    display:inline-flex;
    align-items:center;
    gap: 8px;
    padding: 6px 10px;
    border-radius: 999px;
    background: rgba(255,212,0,.95);
    color: #1a2a3a;
    font-weight: 800;
    font-size: 12px;
    white-space: nowrap;
  }

  #sucutaTablesWrap .st-table{
    width:100%;
    border-collapse: collapse;
    table-layout: fixed;
  }
  #sucutaTablesWrap .st-table th,
  #sucutaTablesWrap .st-table td{
    border-top: 1px solid var(--line);
    padding: 12px 14px;
    vertical-align: top;
    word-break: break-word;
  }
  #sucutaTablesWrap .st-table th{
    width: 34%;
    background: linear-gradient(180deg, var(--sky2), var(--sky));
    color: var(--blue);
    font-weight: 800;
    font-size: 13px;
  }
  #sucutaTablesWrap .st-table td{
    background: rgba(255,255,255,.75);
    font-size: 14px;
  }

  #sucutaTablesWrap .st-list{
    margin: 0;
    padding-left: 18px;
  }
  #sucutaTablesWrap .st-list li{ margin: 4px 0; }
  #sucutaTablesWrap .st-note{
    margin-top: 8px;
    color: var(--muted);
    font-size: 12.5px;
  }
  #sucutaTablesWrap a{
    color: var(--blue);
    font-weight: 700;
    text-decoration: underline;
    text-decoration-thickness: 2px;
    text-underline-offset: 2px;
  }
  #sucutaTablesWrap .st-foot{
    margin-top: 14px;
    padding: 14px;
    border-radius: var(--radius);
    background: #f7fbff;
    border: 1px dashed var(--line);
    color: var(--muted);
    font-size: 13px;
  }

  /* スマホで見やすく：見出し列を少し広くしすぎない */
  @media (max-width: 420px){
    #sucutaTablesWrap .st-table th{ width: 38%; }
    #sucutaTablesWrap .st-table th,
    #sucutaTablesWrap .st-table td{ padding: 10px 12px; }
  }

/* アンカーリンク（目次） */
.st-anchorNav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  margin: 12px 0 20px;
  padding: 0;
  list-style: none;
  font-size: 14px;
}

.st-anchorNav li a {
  color: #0066cc;
  text-decoration: none;
  border-bottom: 1px dotted #0066cc;
}

.st-anchorNav li a:hover {
  text-decoration: underline;
}

/* アンカー位置ずれ対策（固定ヘッダーがある場合） */
.st-card {
  scroll-margin-top: 80px;
}

/* =========================================================
   目次（アンカー）見やすく：同サイズ＋囲み枠＋虫眼鏡アイコン
   ========================================================= */

#sucutaTablesWrap .st-anchorBox{
  /* 囲み枠（中央ソロ） */
  max-width: 860px;
  margin: 14px auto 14px;
  padding: 14px 16px;
  background: #ffffff;     /* 指定どおり */
  border: none;            /* フチなし */
  border-radius: 0;        /* 角Rなし */
  box-sizing: border-box;
}

#sucutaTablesWrap .st-anchorNav{
  /* ul のデフォルトを消す */
  list-style: none;
  margin: 0;
  padding: 0;

  /* 文字サイズ：下の説明文（st-lead）と同等にしたいので 1rem に固定 */
  font-size: 1rem;
  line-height: 1.7;

  /* 見やすい並び（PCは2列、スマホは1列） */
  column-count: 2;
  column-gap: 24px;
}

@media (max-width: 640px){
  #sucutaTablesWrap .st-anchorNav{
    column-count: 1;
  }
}

#sucutaTablesWrap .st-anchorNav li{
  break-inside: avoid;
  padding: 2px 0;
  margin: 0;
}

#sucutaTablesWrap .st-anchorNav a{
  /* “説明文に負けない”見え方に */
  display: inline-flex;
  align-items: center;
  gap: 0.45em;

  font-size: 1em;          /* st-anchorNav の 1rem に揃う */
  font-weight: 700;
  color: #0b3a8a;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.22em;
}

#sucutaTablesWrap .st-anchorNav a:hover{
  opacity: 0.85;
}

#sucutaTablesWrap .st-anchorNav a:focus-visible{
  outline: 2px solid rgba(11,58,138,0.35);
  outline-offset: 3px;
}

/* 控えめでおしゃれな虫眼鏡（CSSで付与） */
#sucutaTablesWrap .st-anchorNav a::before{
  content: "";
  width: 1.05em;
  height: 1.05em;
  flex: 0 0 1.05em;

  /* SVG（虫眼鏡） */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%230b3a8a' d='M10 2a8 8 0 105.293 14.293l4.707 4.707a1 1 0 001.414-1.414l-4.707-4.707A8 8 0 0010 2zm0 2a6 6 0 110 12 6 6 0 010-12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;

  opacity: 0.55;           /* 控えめ */
  transform: translateY(0.03em);
}

/* ================================
   目次リンク：下線（アンダーバー）削除
   ================================ */

#sucutaTablesWrap .st-anchorNav a{
  text-decoration: none !important;
}

.alert-notice-box {
    margin: 20px 0;
    border: 2px solid #ff9800;
    border-radius: 10px;
    background-color: #fff9f0;
    overflow: hidden;
}

/* A. 見出しを改行させない設定 */
.alert-header {
    background-color: #ff9800;
    color: #fff;
    padding: 10px 12px;
    font-weight: bold;
    /* 改行禁止の設定 */
    white-space: nowrap; 
    /* 横幅からはみ出る場合は少し小さくする調整（スマホ対応） */
    font-size: clamp(0.85rem, 4vw, 1.05rem); 
    display: flex;
    align-items: center;
}

.alert-icon {
    margin-right: 5px;
    flex-shrink: 0;
}

.alert-body {
    padding: 15px;
}

/* B. 文章のサイズを下のテキスト（0.85rem）に合わせる */
.alert-item {
    display: flex;
    margin-bottom: 12px;
    line-height: 1.6;
    font-size: 0.85rem; /* 下の注釈と同じサイズに設定 */
}

.alert-num {
    background-color: #ff9800;
    color: #fff;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: bold;
    margin-right: 10px;
    flex-shrink: 0;
    margin-top: 3px;
}

.alert-item strong {
    color: #e65100;
    background: linear-gradient(transparent 70%, #ffe0b2 70%);
    font-weight: bold;
}

.alert-footer {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px dashed #ffb74d;
    font-size: 0.85rem; /* ここに合わせています */
    color: #555;
}

.alert-footer p {
    margin: 4px 0;
}