:root{
  --ink:#0ea5b7;
  --glass-bg: rgba(255,255,255,.06);
  --glass-brd: rgba(255,255,255,.18);
  --hero-grad: radial-gradient(1200px 600px at 10% -10%, rgba(14,165,183,.25), transparent 60%),
               radial-gradient(900px 500px at 90% 10%, rgba(60,145,75,.22), transparent 55%),
               linear-gradient(180deg, #0b1020 0%, #0f1630 60%, #101528 100%);
}
body{ background:#0c1226; color:#e8eef7; }
header{
  position:relative; overflow:hidden; padding:68px 20px 54px; text-align:center;
  background:var(--hero-grad); isolation:isolate;
}
header::after{
  content:""; position:absolute; inset:-20% -20% auto -20%; height:160%;
  background: conic-gradient(from 90deg at 50% 40%, rgba(255,255,255,.06), transparent 35%, rgba(255,255,255,.08));
  filter: blur(40px); opacity:.6; z-index:-1; animation:slowPulse 12s linear infinite;
}
@keyframes slowPulse{0%{transform:translateY(0)}50%{transform:translateY(8px)}100%{transform:translateY(0)}}

.section{ padding: 24px 16px 40px; }
.section p{ color:#d7e2ff }

.tab-UI1{ position:relative; margin-top:18px; }
.tab-btn{
  position:relative; display:inline-block; padding:10px 14px; margin:0 6px 10px 0;
  border-radius:999px; background:var(--glass-bg); border:1px solid var(--glass-brd);
  backdrop-filter:saturate(140%) blur(6px); color:#dbe7ff; cursor:pointer; transition:transform .2s ease, background .2s ease;
}
.tab-btn:hover{ transform:translateY(-1px); background:rgba(255,255,255,.09) }
.tab-UI1 .inkbar{
  position:absolute; height:2px; background:var(--ink); bottom:-2px; border-radius:2px; transition:all .25s ease;
}

.layout_box.responsive{ display:grid; grid-template-columns:repeat(auto-fit, minmax(260px,1fr)); gap:14px; }
.float_item{ border-radius:16px; transition:transform .18s ease, box-shadow .18s ease, background .18s ease; }
.float_item:hover{ transform:translateY(-4px); box-shadow:0 12px 28px rgba(0,0,0,.24); }

img.lazyish{ display:block; width:100%; height:auto; border-radius:12px; background:rgba(255,255,255,.06); }

.section-title-divider{
  position:relative; display:inline-block; padding:10px 16px; border-radius:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--glass-brd);
  color:#e8eef7;
}
.section-title-divider::after{
  content:""; position:absolute; left:12px; right:12px; bottom:-6px; height:2px;
  background:linear-gradient(90deg, transparent, var(--ink), transparent); filter: blur(.5px);
}

@media print{
  @page{ size:A4; margin:16mm }
  body{ background:#fff; color:#000 }
  header{ background:#fff !important; padding:8mm 0 }
  a[href]::after{ content:" (" attr(href) ")"; font-size:10pt; color:#444 }
  .float_item{ break-inside:avoid }
  .tab-btn, .inkbar{ display:none!important }
}
/* =========================
   Contrast Hotfix (append)
   ========================= */
:root{
  --text-strong: #eef3ff;   /* ダーク背景上の本文（ほぼ白） */
  --text-soft:   #cfe0ff;   /* 補助テキスト */
  --text-dark:   #17212e;   /* ライト背景上の本文（濃い紺） */
  --text-dark-2: #2a3646;   /* ライト背景上の小見出しなど */
}

/* ダーク背景（ページ地）の本文を明るく */
body, .section, .tab-content{
  color: var(--text-strong);
}
.section p,
.tab-content p,
.tab-content li{
  color: var(--text-strong);
}

/* 見出し中のサブテキスト（元: #777 を上書き） */
.tab-content h3 span{
  color: var(--text-soft) !important;
}

/* ライト背景カード内は濃色文字に切り替え */
.float_item,
.float_item p,
.float_item h6,
.float_item li,
.float_item span{
  color: var(--text-dark) !important;
}
.float_item h6{
  color: var(--text-dark-2) !important;
}

/* 任意：本文にリンクがある場合の視認性 */
a{ color:#8ad6ff; }
a:hover{ color:#a8e4ff; }

/* 既存の薄め指定があれば無効化（保険） */
.section p{ opacity: 1 !important; }

/* ===== タブ冒頭の説明部を黒/紺に ===== */

/* サブテキスト (例: | 次世代工作機械の進化) */
.tab-content h3 span {
  color: #1a2233 !important;  /* 濃い紺 */
  font-weight: 600;
}

/* 冒頭の本文 (h3直下の説明文) */
.tab-content > div > div > p {
  color: #000000 !important;  /* 黒 */
  font-weight: 400;
  line-height: 1.8;
}

/* ===== フッターの背景をページ全体と統一 (紺色系) ===== */
footer {
  background-color: #0c1226;  /* ページのbodyと同じ紺色系 */
  padding: 12px 0;
}
footer .copyright {
  margin: 0;
  font-size: 10px;
  color: #ffffff;
  text-align: center;
}
