@charset "Shift_JIS";

/* ――― 全体レイアウトの設定 ――― */
body {
  width: 955px;       /* 画面全体の横幅を画像・メニューの955pxに統一 */
  margin: 20px auto;  /* 画面の中央に配置する */
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Segoe UI", sans-serif;
}

/* 各ブロック（タイトル、画像、メニュー、コンテンツなど）の上下の隙間 */
.block-container {
  margin-bottom: 25px;
  clear: both;
}

/* タイトルロゴ部分（中央揃えに設定） */
.header-title {
  text-align: center; 
  margin-bottom: 20px;
}
.header-title img {
  vertical-align: middle;
  margin-right: 15px; 
}
.header-title b {
  vertical-align: middle;
}

/* 3枚の画像テーブル */
.image-table {
  width: 955px !important;
  border-collapse: collapse !important;
  table-layout: fixed;
}
.image-table td {
  padding: 0 !important;
}
.image-table img {
  display: block;
  width: 100%;
  height: auto;
}

/* 上部メニュー（ナビゲーションバー） */
.main-menu-table {
  width: 955px !important;
  background-color: #0b2545 !important; 
  border-collapse: collapse !important;
  border-radius: 4px;
  overflow: hidden;
}
.menu-item {
  padding: 0 !important;
  border-right: 1px solid #134074 !important; 
}
.menu-item:last-child {
  border-right: none !important;
}
.menu-item a {
  display: block !important;
  padding: 14px 0 !important; 
  color: #ffffff !important;   
  text-decoration: none !important;
  font-size: 13pt !important;
  font-weight: bold;
  text-align: center;
  transition: background-color 0.2s, color 0.2s;
}
.main-menu-table .menu-item a:hover {
  background-color: #134074 !important; 
  color: #8da9c4 !important;   
}

/* 2列に並ぶメインコンテンツエリア */
.main-layout-table {
  width: 955px !important;
  border-collapse: collapse !important;
  table-layout: fixed;
  margin-bottom: 25px;
}

/* サイドメニュー（ボタンデザイン） */
.sidebar-table {
  width: 270px !important;
  border-collapse: separate !important;
  border-spacing: 0 12px !important;
}
.sidebar-table a {
  text-decoration: none !important;
  color: #333333 !important;
}
.group-box {
  background-color: #f4f6f9 !important; 
  border: 1px solid #d0d7de !important;
  border-radius: 6px;
  padding: 10px 12px !important;
  font-size: 11pt !important;
  text-align: left;
}
.group-title {
  font-weight: bold;
  color: #0b2545; 
  display: block;
  margin-bottom: 8px;
  padding-left: 4px;
}
.sub-button {
  background-color: #ffffff !important;
  border: 1px solid #d4d4d4 !important;
  border-bottom: 2px solid #b3b3b3 !important;
  border-radius: 4px;
  display: block;
  margin: 4px 0 !important;
  padding: 6px 10px !important;
  cursor: pointer;
}
.sub-button:hover {
  background-color: #f7f9fa !important;
  border-bottom: 1px solid #b3b3b3 !important;
  position: relative;
  top: 1px;
}
.single-button {
  background-color: #eef1f6 !important; 
  border: 1px solid #d0d7de !important;
  border-bottom: 3px solid #b3b3b3 !important;
  border-radius: 6px;
  display: block;
  padding: 10px 12px !important;
  font-weight: bold;
  color: #0b2545 !important; 
  cursor: pointer;
}
.single-button:hover {
  background-color: #e0e5ed !important;
  border-bottom: 1px solid #b3b3b3 !important;
  position: relative;
  top: 2px;
}

/* 画像を使わないかっこいい新着見出しのデザイン */
.news-header-box {
  background-color: #0b2545 !important; 
  border-left: 6px solid #cbd5e1 !important; 
  padding: 8px 15px !important;
  border-radius: 0 4px 4px 0;
  margin-bottom: 12px;
  text-align: left;
}
.news-header-title {
  color: #ffffff !important;
  font-size: 12pt !important;
  font-weight: bold !important;
  letter-spacing: 2px; 
}
.news-header-sub {
  color: #8da9c4 !important;
  font-size: 8.5pt !important;
  font-weight: normal !important;
  margin-left: 10px;
}

/* フッターエリア */
.footer-area {
  width: 955px;
  margin-top: 40px;
  padding-top: 20px;
  border-top: 1px solid #dddddd;
  font-size: 11pt;
  line-height: 1.6;
}

/* インラインフレーム専用の設定 */
body.iframe-body {
  width: auto !important;     
  margin: 5px !important;
  padding: 0 !important;
  background-color: #ffffff !important;
}
.news-list {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.news-item {
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px dashed #e0e0e0;
  font-size: 10.5pt;
  line-height: 1.5;
}
.news-date {
  font-size: 11pt;
  color: #666666;
  font-weight: bold;
  display: block;
  margin-bottom: 4px; 
}
.news-item a {
  color: #0b2545 !important;
  text-decoration: underline !important;
}
.news-item a:hover {
  color: #134074 !important;
}
.alert-text {
  color: #ff0000 !important;
  font-weight: bold !important;
}

/* ――― 【追加】ここから「お知らせ」サブページ専用スタイル ――― */
.breadcrumb {
  font-size: 10pt;
  color: #555555;
  margin-bottom: 20px;
}
.breadcrumb a {
  color: #0b2545;
  text-decoration: none;
}
.breadcrumb a:hover {
  text-decoration: underline;
}
.page-title-box {
  background-color: #0b2545;
  border-left: 6px solid #cbd5e1;
  padding: 12px 20px;
  border-radius: 4px;
  color: #ffffff;
  font-size: 16pt;
  font-weight: bold;
  margin-bottom: 30px;
  letter-spacing: 1px;
}
.info-section {
  background-color: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 20px 25px;
  margin-bottom: 25px;
}
.info-section h3 {
  margin: 0 0 15px 0;
  padding-bottom: 10px;
  border-bottom: 2px solid #0b2545;
  color: #0b2545;
  font-size: 13pt;
  font-weight: bold;
}
.info-section ul {
  margin: 0;
  padding-left: 20px;
}
.info-section li {
  margin-bottom: 10px;
  font-size: 11pt;
}
.info-section li:last-child {
  margin-bottom: 0;
}
.info-section li a {
  color: #1e3a8a;
  text-decoration: none;
  font-weight: bold;
}
.info-section li a:hover {
  text-decoration: underline;
  color: #2563eb;
}
.campaign-container {
  display: table;
  width: 100%;
  margin-top: 15px;
}
.campaign-img {
  display: table-cell;
  width: 240px;
  vertical-align: top;
  padding-right: 20px;
}
.campaign-img img {
  border: 1px solid #cbd5e1;
  border-radius: 4px;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}
.campaign-text {
  display: table-cell;
  vertical-align: top;
  font-size: 11pt;
  line-height: 1.7;
  color: #333333;
}
.campaign-sub-title {
  font-weight: bold;
  color: #0b2545;
  margin-top: 15px;
  margin-bottom: 5px;
  font-size: 11pt;
}
.back-btn-container {
  text-align: center;
  margin: 40px 0 20px 0;
}
.back-button {
  display: inline-block;
  background-color: #eef1f6;
  border: 1px solid #d0d7de;
  border-bottom: 3px solid #b3b3b3;
  border-radius: 6px;
  padding: 10px 35px;
  font-weight: bold;
  color: #0b2545;
  text-decoration: none;
  cursor: pointer;
  font-size: 11pt;
}
.back-button:hover {
  background-color: #e0e5ed;
  position: relative;
  top: 2px;
  border-bottom: 1px solid #b3b3b3;
}

.anime-new {
  display: inline-block;
  background-color: #ff9800; /* オレンジ色 */
  color: #ffffff;
  font-size: 0.8rem;
  font-weight: bold;
  padding: 3px 8px;
  border-radius: 4px;
  animation: flash 1.5s infinite; /* アニメーションの指定 */
}

@keyframes flash {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.5; } /* 途中で半透明になる */
}