@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100;300;400;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Saira+Stencil+One&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900&display=swap");

/* VITA FA デザインシステム - カラーパレット */
:root {
  --vita-primary: #061331;
  --vita-primary-hover: #0a2157;
  --vita-accent: #ffb332;
  --vita-heading: #1c558e;
  --vita-heading-ja: #2472b2;
  --vita-bg: #f4f4f4;
  --vita-focus: #ffb332;
}

.dropdown { position: relative; }
div.vita_menu .dropdown-toggle::after { display: none; }
.dropdown-menu { position: absolute; z-index: 1050; min-width: 14rem; padding: 0.5rem 0; background-color: var(--vita-primary); border-radius: 0.375rem; list-style: none; }
.dropdown-menu.show { display: block; }
.dropdown-item { display: block; padding: 0.25rem 1rem; color: #ffffff; text-decoration: none; }
.dropdown-item:hover { background-color: var(--vita-primary-hover); color: #ffffff; }
.collapse { display: none !important; }
.collapse.show { display: block !important; }
/* モバイルオーバーレイは hidden 属性で制御（Bootstrap競合回避） */
div.vita_menu_sp_overlay[hidden] { display: none !important; }

.text-green { color: #45c4a0 !important; }
.text-orange { color: #f78b77 !important; }
.text-yellow { color: #fab758 !important; }
.text-blue { color: #3f78e0 !important; }
.text-red { color: #e2626b !important; }
.text-purple { color: #747ed1 !important; }

body { background: #f4f4f4; font-family: "Noto Sans JP"; }
body.sp-menu-open main,
body.sp-menu-open footer { visibility: hidden; }
p { line-height: 170%; }

h2.midashi, .midashi.h2 { display: flex; flex-direction: column; align-items: baseline; font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem); font-weight: 700; color: var(--vita-heading); margin-bottom: 40px; line-height: 110%; }
@media (max-width: 768px) { h2.midashi, .midashi.h2 { flex-direction: column; margin-bottom: 20px; } }
h2.midashi span.en, .midashi.h2 span.en { font-family: "Poppins"; }
h2.midashi span.ja, .midashi.h2 span.ja { font-family: "Noto Sans JP"; font-size: 1rem; margin-left: 10px; color: var(--vita-heading-ja); line-height: 120%; }
@media (max-width: 768px) { h2.midashi span.ja, .midashi.h2 span.ja { margin-left: 0; font-size: 0.9rem; } }
h3.midashi, .midashi.h3 { font-family: "Poppins", "Noto Sans JP"; font-weight: 700; font-size: clamp(1.125rem, 0.716rem + 2.05vw, 2.25rem); margin-top: 42px; margin-bottom: 16px; }
h4.midashi, .midashi.h4 { font-family: "Noto Sans JP"; font-weight: 700; color: var(--vita-primary); font-size: 22px; border-left: 6px solid var(--vita-primary); padding-left: 10px; margin-top: 32px; line-height: 180%; }
@media (max-width: 768px) { h4.midashi, .midashi.h4 { font-size: 20px; margin-top: 16px; } }

section.page-header { padding-top: 120px; padding-bottom: 60px; }
@media (max-width: 768px) { section.page-header { padding-top: 90px; padding-bottom: 30px; } }
section.page-header div.breadcrumb { display: inline-block; font-size: 0.85rem; color: #343a40; background-color: #ffffff; border-radius: 12px; padding: 6px 16px; }
@media (max-width: 768px) { section.page-header div.breadcrumb { font-size: 0.7rem; padding: 4px 10px; } }
section.page-header div.breadcrumb a { color: #343a40; }
section.page-header h1, section.page-header .h1 { font-family: "Poppins", "Noto Sans JP"; color: var(--vita-primary); font-size: 60px; font-weight: 700; }
@media (max-width: 768px) { section.page-header h1, section.page-header .h1 { font-size: 32px; } }
.sction_title { font-size: clamp(1.75rem, 1.295rem + 2.27vw, 3rem); font-family: "Poppins"; color: var(--vita-primary); font-weight: 600; }

div.vita_menu { position: fixed; top: 0; left: 0; right: 0; background: #ffffff; height: 60px; z-index: 999; }
div.vita_menu div.vita_menu_logo { height: 100%; }
div.vita_menu div.vita_menu_logo a { display: flex; justify-content: center; align-items: center; }
div.vita_menu div.vita_menu_logo a img { max-height: 40px; }
div.vita_menu ul.vita_menu_list { margin: 0; padding: 0; height: 100%; }
div.vita_menu ul.vita_menu_list li.vita_menu_item { list-style: none; display: flex; align-items: center; font-size: 1.15rem; font-weight: 700; }
div.vita_menu ul.vita_menu_list li.vita_menu_item a { text-decoration: none; padding: 10px 20px; }
div.vita_menu ul.vita_menu_list li.vita_menu_item > a:visited { color: var(--vita-primary); }
div.vita_menu ul.vita_menu_list li.vita_menu_item ul.dropdown-menu a:visited { color: #ffffff; }
div.vita_menu div.vita_menu_btnbox { font-weight: 700; }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn { position: relative; display: flex; flex-direction: column; align-items: center; justify-content: center; line-height: 115%; transform: skew(-10deg); flex-shrink: 0; }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn.vita_menu_btn_01 { background-color: var(--vita-primary); color: #ffffff; z-index: 1; }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn.vita_menu_btn_01:hover { background-color: var(--vita-primary-hover); }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn.vita_menu_btn_01 .vita_menu_btn_english { font-family: "Oswald"; color: #7e7e7e; }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn.vita_menu_btn_01 div { transform: skew(10deg); }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn.vita_menu_btn_02 { background-color: var(--vita-accent); color: #000000; transform: scaleX(1.1); }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn.vita_menu_btn_02:hover { filter: brightness(1.1); }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn.vita_menu_btn_02 .vita_menu_btn_english { font-family: "Oswald"; color: #93671d; }
div.vita_menu div.vita_menu_btnbox div.vita_menu_btn a { position: absolute; display: block; top: 0; bottom: 0; left: 0; right: 0; }

div.vita_menu_sp { position: fixed; top: 0; background: #ffffff; height: 45px; z-index: 999; }
div.vita_menu_sp div.vita_menu_logo { height: 100%; }
div.vita_menu_sp div.vita_menu_logo a { display: flex; justify-content: start; align-items: center; }
div.vita_menu_sp div.vita_menu_logo a img { max-height: 30px; }
div.vita_menu_sp div.vita_menu_btn a { height: 100%; display: flex; justify-content: center; align-items: center; }
div.vita_menu_sp div.vita_menu_btn a img { width: 30px; height: 30px; }
div.vita_menu_sp_overlay { position: fixed; inset: 0; height: 100%; width: 100%; top: 0; left: 0; background-color: var(--vita-primary); padding-top: 16px; overflow-y: auto; overflow-x: hidden; opacity: 1; z-index: 9999; isolation: isolate; }
div.vita_menu_sp_overlay_inner { background-color: var(--vita-primary); min-height: 100%; position: relative; z-index: 1; }
div.vita_menu_sp_overlay_header { display: flex; width: 100%; }
div.vita_menu_sp_overlay_body { margin-top: 3rem; padding: 0 0.5rem; }
div.vita_menu_sp_overlay_cta { display: flex; justify-content: center; margin-top: 1rem; }
div.vita_menu_sp_overlay_social { display: flex; justify-content: center; margin-top: 3rem; padding-bottom: 2rem; }
div.vita_menu_sp_overlay div.vita_menu_logo img { height: 40px; }
div.vita_menu_sp_overlay div.vita_menu_btn { line-height: 100%; }
div.vita_menu_sp_overlay div.vita_menu_btn i { font-size: 30px; color: #ffffff; }
div.vita_menu_sp_overlay div.sp_menu_item { min-height: 60px; border-top: 1px solid rgba(255, 255, 255, 0.5); }
div.vita_menu_sp_overlay div.sp_menu_item ul { padding-left: 0; }
div.vita_menu_sp_overlay div.sp_menu_item:last-child { border-bottom: 1px solid rgba(255, 255, 255, 0.5); }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header { width: 100%; display: flex; flex-direction: column; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header > a { display: flex; align-items: center; justify-content: space-between; height: 60px; width: 100%; color: #ffffff; font-size: 1.4rem; font-weight: 400; font-family: "Saira Stencil One"; flex-shrink: 0; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header > a.collapsed span.minus { display: none; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header > a:not(.collapsed) span.minus { display: inline-block; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header > a.collapsed span.plus { display: inline-block; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header > a:not(.collapsed) span.plus { display: none; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header .sp_menu_item_contents { padding-left: 1rem; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header .sp_menu_item_contents.show { display: block !important; visibility: visible !important; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header .sp_menu_item_contents ul { padding-bottom: 0; padding-left: 0; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header .sp_menu_item_contents ul li { list-style: none; padding: 4px 0; }
div.vita_menu_sp_overlay div.sp_menu_item .sp_menu_item_header .sp_menu_item_contents ul li a { font-size: 0.9rem; font-weight: 400; color: #fff; display: block; }
div.vita_menu_sp_overlay a.vita_menu_sp_taikenbtn { display: inline-block; margin-top: 30px; padding: 6px 10px; color: #ffffff; font-size: 1.2rem; opacity: 1; border: 1px solid #ffffff; }

div.mainvisual { position: relative; padding-top: 60px; }
@media (max-width: 768px) { div.mainvisual { padding-top: 45px; } }
div.mainvisual .mainvisual_copy { position: absolute; bottom: 12vw; left: 8vw; }
div.mainvisual .mainvisual_copy img { width: 55vw; filter: drop-shadow(0 0 4px rgba(0,0,0,0.5)) drop-shadow(0 0 6px rgba(0,0,0,0.3)); }
div.mainvisual .mainvisual_copy_sp { position: absolute; bottom: 25vw; left: 4vw; }
div.mainvisual .mainvisual_copy_sp img { width: 84vw; filter: drop-shadow(0 0 4px rgba(0,0,0,0.5)) drop-shadow(0 0 6px rgba(0,0,0,0.3)); }

section.top_vision .top_vision_copy { max-width: 100%; }
@media (max-width: 768px) { section.top_vision .top_vision_copy { max-width: 85%; } }
section.top_vision .top_vision_text { font-size: 1.2rem; }
@media (max-width: 768px) { section.top_vision .top_vision_text { font-size: 1rem; } }
section.top_vision .top_vision_image_01 img { transform: translatex(20px) translatey(5px); }
@media (max-width: 768px) { section.top_vision .top_vision_image_01 img { transform: translatex(10px) translatey(5px); } }
section.top_vision .top_vision_image_02 { margin-top: 30px; transform: translatex(-5px); }
@media (max-width: 768px) { section.top_vision .top_vision_image_02 { margin-top: 20px; transform: translatex(0); } }
section.top_vision .top_vision_image_03 img { transform: translatex(20px); }
@media (max-width: 768px) { section.top_vision .top_vision_image_03 img { transform: translatex(2px); } }

section.top_news { position: relative; background: #ecf5ff; }
section.top_news::before { position: absolute; display: block; content: ""; top: 0; right: 0; background-image: url(/images/bg_ashirai_yellow.svg); background-size: cover; height: 24px; width: 240px; }
@media (max-width: 768px) { section.top_news::before { height: 20px; width: 200px; } }
section.top_news .nav { display: flex; list-style: none; padding-left: 0; margin-bottom: 0; }
section.top_news .nav-tabs { border-bottom: none; gap: 0; }
section.top_news .nav-tabs .nav-link { font-family: "Poppins"; font-size: clamp(1.125rem, 0.898rem + 1.14vw, 1.75rem); font-weight: 500; padding: 0.5rem 2rem; border-radius: 0; background: #ced4da !important; color: #495057 !important; border: none; cursor: pointer; }
@media (max-width: 768px) { section.top_news .nav-tabs .nav-link { padding: 0.4rem 1.4rem; } }
section.top_news .nav-tabs .nav-link.active { color: #ffffff !important; background: #061331 !important; font-weight: 700; border: none; }
.tab-content { margin-top: 0; }
.tab-pane { display: none; }
.tab-pane.show { display: block; }
section.top_news a.vitafa_tab_news_items { display: block; background: #ffffff; border-bottom: 1px solid var(--vita-primary); }
section.top_news a.vitafa_tab_news_items.vitafa_tab_news_items--alt { background: #e8eef5; }
section.top_news a.vitafa_tab_news_items:last-of-type { border-bottom: 0; }
section.top_news a.vitafa_tab_news_items .vitafa_tab_news_items__date { font-family: "Poppins"; font-weight: 600; color: #6c757d; }
section.top_news a.vitafa_tab_news_items .vitafa_tab_news_items__title { color: var(--vita-primary); font-weight: 700; }
section.top_news a.vitafa_tab_news_items .vitafa_tab_news_items__cat ul.vitafa_tab_news_items__cat_list { padding-left: 0; display: flex; flex-direction: row; margin-bottom: 0; list-style: none; }
section.top_news a.vitafa_tab_news_items .vitafa_tab_news_items__cat ul.vitafa_tab_news_items__cat_list li { list-style: none; color: var(--vita-primary); font-size: 0.85rem; padding: 1px 6px; border: 1px solid var(--vita-primary); }
section.top_news a.vitafa_tab_news_items .vitafa_tab_news_items__cat ul.vitafa_tab_news_items__cat_list li:not(:first-child) { margin-left: 6px; }

/* ニュース一覧カード（section-vitafanews） */
section.section-vitafanews .flex.flex-wrap.gap-4 { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 768px) { section.section-vitafanews .flex.flex-wrap.gap-4 { grid-template-columns: repeat(3, 1fr); } }
section.section-vitafanews .flex.flex-wrap.gap-4 > nav.vitafa-pagination { grid-column: 1 / -1; }
section.section-vitafanews .vitafanews-item { display: flex; flex-direction: column; height: 100%; background: #ffffff; border-radius: 12px; overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,0.08); text-decoration: none; color: inherit; transition: box-shadow 0.2s, transform 0.2s; border: 1px solid #e9ecef; }
section.section-vitafanews .vitafanews-item:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.12); transform: translateY(-2px); }
section.section-vitafanews .vitafanews_image { position: relative; overflow: hidden; aspect-ratio: 16/10; background: #e9ecef; min-height: 120px; }
section.section-vitafanews .vitafanews_image img.vitafanews-img { position: absolute; top: 0; left: 0; width: 100% !important; height: 100% !important; object-fit: cover; display: block; }
section.section-vitafanews .vitafanews_detail { padding: 1rem 1.25rem; flex: 1; display: flex; flex-direction: column; }
section.section-vitafanews .vitafanews_subject { font-weight: 700; color: var(--vita-primary); font-size: 0.95rem; line-height: 1.5; margin-bottom: 0.5rem; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; min-height: 2.85em; }
section.section-vitafanews .vitafanews_category { margin-bottom: 0.5rem; }
section.section-vitafanews .vitafanews_category ul.post-categories { padding-left: 0; margin: 0; list-style: none; display: flex; flex-wrap: wrap; gap: 6px; }
section.section-vitafanews .vitafanews_category ul.post-categories li { font-size: 0.7rem; padding: 3px 8px; border: 1px solid var(--vita-primary); color: var(--vita-primary); border-radius: 4px; font-weight: 500; }
section.section-vitafanews .vitafanews_date { font-size: 0.8rem; color: #6c757d; margin-top: auto; }
section.section-vitafanews .vitafanews_date .human_time { margin-left: 0.5rem; opacity: 0.9; }
/* ページネーション */
section.section-vitafanews nav.vitafa-pagination { width: 100%; margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid #dee2e6; display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 0.5rem; }
section.section-vitafanews nav.vitafa-pagination a.page-numbers,
section.section-vitafanews nav.vitafa-pagination span.page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 2.5rem; height: 2.5rem; padding: 0 0.5rem; font-size: 0.9rem; font-weight: 500; text-decoration: none; color: var(--vita-primary); background: #fff; border: 1px solid #dee2e6; border-radius: 6px; transition: all 0.2s; }
section.section-vitafanews nav.vitafa-pagination a.page-numbers:hover { background: var(--vita-primary); color: #fff; border-color: var(--vita-primary); }
section.section-vitafanews nav.vitafa-pagination span.page-numbers.current { background: var(--vita-primary); color: #fff; border-color: var(--vita-primary); }
section.section-vitafanews nav.vitafa-pagination span.page-numbers.dots { border: none; background: transparent; min-width: auto; color: #6c757d; }
section.section-vitafanews nav.vitafa-pagination a.page-numbers.prev,
section.section-vitafanews nav.vitafa-pagination a.page-numbers.next { font-size: 1.1rem; }

.method-card { box-shadow: 3px 3px 7px rgba(0,0,0,0.06); }
.method-card .method-card-category { border: 2px solid var(--vita-primary); padding: 3px 10px; color: var(--vita-primary); font-weight: 700; display: inline-block; }
.method-card .method-card-title { font-weight: 700; font-size: clamp(1.125rem, 0.989rem + 0.68vw, 1.5rem); }
div.box01 { background-color: rgb(220,224,230); border-radius: 6px; display: flex; flex-wrap: wrap; }
div.box02 { background-color: rgb(235,235,235); border-radius: 6px; display: flex; flex-wrap: wrap; }
div.box03 { background-color: rgb(222,231,243); border-radius: 6px; display: flex; flex-wrap: wrap; }
div.box04 { background-color: var(--vita-primary); border-radius: 6px; display: flex; flex-wrap: wrap; color: #ffffff; }
div.box04 h2.midashi, div.box04 .midashi.h2 { color: var(--vita-accent); }
div.box04 h2.midashi span.ja, div.box04 .midashi.h2 span.ja { color: var(--vita-accent); }
div.box04 ul { list-style: disc; padding-left: 1.5rem; margin: 1rem 0; }
div.box04 ul li { color: #ffffff; display: list-item; margin-bottom: 0.5rem; line-height: 1.6; }
div.box04 ul li:last-child { margin-bottom: 0; }
div.box04 p { color: #ffffff; margin-bottom: 0.5rem; }
div.box04 p a { color: #ffffff; }

footer { background: var(--vita-primary); }
footer div.footer-copyright { display: flex; justify-content: end; padding: 48px 0 16px; color: #ffffff; font-size: 0.8rem; font-family: "Oswald"; }
.footer_logo img { width: 40%; }
@media (max-width: 768px) { .footer_logo img { width: 25%; margin-bottom: 50px; } }
ul.footer_menu { color: #ffffff; padding-left: 0; }
@media (max-width: 768px) { ul.footer_menu { margin-left: 16px; } }
ul.footer_menu li { list-style: none; }
ul.footer_menu li:not(:first-child) { margin-top: 16px; }
ul.footer_menu li:not(:last-child) { margin-bottom: 16px; }
ul.footer_menu li.footer_menu_items { font-weight: 700; font-size: 1.25rem; color: #ffffff; }
ul.footer_menu li.footer_menu_items a { color: #ffffff; }
ul.footer_menu li.footer_menu_items ul.footer_menu_2nd { padding-left: 24px; }
ul.footer_menu li.footer_menu_items ul.footer_menu_2nd li.footer_menu_2nd_items { font-weight: 400; font-size: 1rem; margin-top: 8px; margin-bottom: 8px; }
ul.footer_menu li.footer_menu_items ul.footer_menu_2nd li.footer_menu_2nd_items a { text-decoration: none; }

div.school-profilebox { background-color: #f4f4f4; border-top-left-radius: 10px; border-bottom-left-radius: 10px; margin-top: -160px; }
@media (max-width: 768px) { div.school-profilebox { margin-top: -60px; } }
div.school-profilebox .school-profilebox-name { font-size: 1.4rem; font-weight: 700; margin-bottom: 16px; color: var(--vita-primary); display: block; }
@media (max-width: 768px) { div.school-profilebox .school-profilebox-name { display: none; } }
div.school-profilebox h4, div.school-profilebox .h4 { font-size: 1.5rem; font-weight: 700; }
@media (max-width: 768px) { div.school-profilebox h4, div.school-profilebox .h4 { font-size: 1.1rem; } }
div.school-feature-box { background-color: #e7ecf5; border-radius: 8px; padding: 12px 18px; }
div.school-feature-box .school-feature-icon { display: flex; align-items: center; justify-content: center; height: 100%; }
div.school-feature-box .school-feature-icon i { font-size: 48px; }
div.school-feature-box .school-feature-tite { font-size: 1.2rem; font-weight: 700; margin-bottom: 4px; }
div.school-feature-box .school-feature-link { font-size: 0.9rem; margin-top: 8px; }
ul.icon-list { padding-left: 2.5rem; }
ul.icon-list li { list-style: none; text-indent: -0.8rem; margin-top: 10px; margin-bottom: 10px; }
ul.icon-list li i { margin-right: 8px; }

div.coach-box div.coach-img { display: flex; width: 100%; position: relative; }
div.coach-box div.coach-img::before { display: block; content: ""; padding-top: 100%; }
div.coach-box div.coach-img img { object-fit: cover; }
div.coach-box div.coach-img div.coach-name { position: absolute; bottom: 36px; right: 10px; background-color: rgba(255,255,255,0.9); padding: 4px 10px; border-radius: 8px; font-weight: 700; font-size: 1.2rem; }
@media (max-width: 768px) { div.coach-box div.coach-img div.coach-name { font-size: 0.9rem; padding: 2px 10px; bottom: 30px; } }
div.coach-box div.coach-img div.coach-profile-btn { position: absolute; bottom: 8px; right: 15px; font-size: 0.7rem; font-family: "Poppins"; background-color: rgba(255,255,255,0.6); padding: 1px 5px; border-radius: 6px; }
table.table-team tr th, table.table-team tr td { text-align: center; vertical-align: middle; font-size: 1rem; }
table.table-team thead tr th { background-color: var(--vita-primary); color: #ffffff; }
table.table-team tbody tr td:first-child { font-weight: 700; }
table.table-team tbody tr:nth-child(odd) td { background-color: #f8f9fa; }
table.table-team tbody tr:nth-child(even) td { background-color: #ffffff; }
/* rowspanを持つ行は論理行単位で同じ色（table-team-rowspanでnth-childを無効化） */
table.table-team-rowspan tbody tr:nth-child(odd) td,
table.table-team-rowspan tbody tr:nth-child(even) td { background-color: unset; }
table.table-team-rowspan tbody tr.tr-bg-1 td { background-color: #f8f9fa; }
table.table-team-rowspan tbody tr.tr-bg-2 td { background-color: #ffffff; }
/* rowspan継続行でtd:first-childが対象列になるため、first-childの太字を解除。曜日・クラスは.font-boldで指定 */
table.table-team-rowspan tbody tr td:first-child { font-weight: 400; }
table.table-team-rowspan tbody tr td.font-bold { font-weight: 700; }
table.table-school tr th { background-color: var(--vita-primary); color: #ffffff; vertical-align: middle; }
table.table-school tr td { vertical-align: middle; }
table.monthly-theme tr th { background-color: var(--vita-primary); color: #ffffff; }
table.monthly-theme tr td { background-color: #ffffff; vertical-align: middle; }
table.monthly-theme tr td:first-of-type { white-space: nowrap; font-weight: 700; background-color: #1eb7bf; color: #ffffff; text-align: center; }
table.monthly-theme tr td:nth-of-type(2) { white-space: nowrap; background-color: #00489d; color: #ffffff; font-weight: 700; text-align: center; }

.taikenbtn, a.taikenbtn, button.taikenbtn { font-size: 1.6rem; font-weight: 700; line-height: 1.5; position: relative; display: inline-block; padding: 1rem 4rem; cursor: pointer; transition: all 0.3s; text-align: center; vertical-align: middle; text-decoration: none; letter-spacing: 0.1em; color: #212529; border-radius: 0.5rem; }
@media (max-width: 768px) { .taikenbtn, a.taikenbtn, button.taikenbtn { padding: 0.7rem 2rem; font-size: 1.3rem; } }
a.taikenbtn-border-shadow { padding: calc(1.5rem - 12px) 3rem 1.5rem; background: #fff; }
a.taikenbtn-border-shadow:before { position: absolute; top: -6px; left: -6px; width: 100%; height: 100%; content: ""; transition: all 0.3s ease; border: 3px solid #000; border-radius: 0.5rem; }
a.taikenbtn-border-shadow:hover { padding: calc(1.5rem - 6px) 3rem; }
a.taikenbtn-border-shadow:hover:before { top: 0; left: 0; }
a.taikenbtn-border-shadow--color { border-radius: 0; background: yellow; }
a.taikenbtn-border-shadow--color:before { border-radius: 0; }

/* テーブル・ユーティリティ（Bootstrap代替） */
table.table { width: 100%; border-collapse: collapse; margin-bottom: 1rem; }
table.table-bordered { border: 1px solid #dee2e6; }
table.table-bordered th, table.table-bordered td { border: 1px solid #dee2e6; padding: 0.5rem; }
table.table-sm th, table.table-sm td { padding: 0.25rem 0.5rem; }
table.table-light { background-color: #f8f9fa; }
.bg-light { background-color: #f8f9fa !important; }
.bg-white { background-color: #ffffff !important; }
.mb-0 { margin-bottom: 0 !important; }

/* ポップオーバー（Bootstrap代替） */
.vitafa-popover { position: fixed; z-index: 1070; max-width: 320px; padding: 0.5rem 1rem; background: #fff; border: 1px solid rgba(0,0,0,0.2); border-radius: 0.375rem; box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.15); }
.vitafa-popover-title { font-weight: 700; margin-bottom: 0.5rem; padding-bottom: 0.5rem; border-bottom: 1px solid #dee2e6; }
.vitafa-popover-body { font-size: 0.9rem; line-height: 1.5; }
.vitafa-popover-body p { margin-bottom: 0.5rem; }
.vitafa-popover-body p:last-child { margin-bottom: 0; }

/* フォーカス表示（アクセシビリティ） */
a:focus-visible,
button:focus-visible,
.menu-toggle:focus-visible,
.collapse-toggle:focus-visible,
.taikenbtn:focus-visible,
.dropdown-toggle:focus-visible,
.dropdown-item:focus-visible { outline: 2px solid var(--vita-focus); outline-offset: 2px; }
#cf7-area {
  width: 100%;
  margin: 0 auto;
}
#cf7-area .cf7-item {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  margin: 0 0 1.75em;
}
@media (max-width: 767.98px) {
  #cf7-area .cf7-item {
    display: block;
  }
}
#cf7-area .cf7-item .cf7-q {
  width: 30%;
  margin: 0 0 0 10px;
}
@media (max-width: 767.98px) {
  #cf7-area .cf7-item .cf7-q {
    width: 100%;
    margin: 0;
  }
}
#cf7-area .cf7-item .cf7-a {
  width: 60%;
}
@media (max-width: 767.98px) {
  #cf7-area .cf7-item .cf7-a {
    width: 100%;
  }
}
#cf7-area .cf7-item label {
  font-weight: bold;
}
@media (max-width: 767.98px) {
  #cf7-area .cf7-item label {
    display: block;
    margin-bottom: 10px;
  }
}
#cf7-area .cf7-item select {
  margin-left: 10px;
  padding: 4px;
  border-radius: 4px;
  background: #ffffff;
  max-width: 100%;
}
@media (max-width: 767.98px) {
  #cf7-area .cf7-item select {
    margin-left: 0;
  }
}
#cf7-area .cf7-item input[type=text],
#cf7-area .cf7-item input[type=email],
#cf7-area .cf7-item input[type=tel],
#cf7-area .cf7-item textarea {
  background: #ffffff;
  width: 100%;
  margin-left: 10px;
  border: 1px solid #061331;
}
@media (max-width: 767.98px) {
  #cf7-area .cf7-item input[type=text],
  #cf7-area .cf7-item input[type=email],
  #cf7-area .cf7-item input[type=tel],
  #cf7-area .cf7-item textarea {
    width: 100%;
    margin-left: 0;
  }
}
#cf7-area .cf7-item input[type=text]:focus,
#cf7-area .cf7-item input[type=email]:focus,
#cf7-area .cf7-item input[type=tel]:focus,
#cf7-area .cf7-item textarea:focus {
  background: #ffffff;
  border: 2px solid #061331;
  outline: 0;
}
#cf7-area .cf7-item input[type=checkbox],
#cf7-area .cf7-item input[type=radio] {
  -webkit-appearance: auto;
     -moz-appearance: auto;
          appearance: auto;
}
#cf7-area .cf7-item .wpcf7-list-item {
  display: block;
}
#cf7-area .cf7-item textarea {
  height: 100px;
  padding: 0.625em 0.4375em;
  border: 1px solid #061331;
}
#cf7-area .cf7-accept-check {
  text-align: center;
  margin: 50px auto;
}
#cf7-area .cf7-submit {
  width: 50%;
  margin: 0 auto;
  text-align: center;
}
@media (max-width: 767.98px) {
  #cf7-area .cf7-submit {
    width: 90%;
  }
}
#cf7-area input[type=submit] {
  width: 100%;
  background-color: #061331;
  color: #fff;
  border-radius: 5px;
  font-size: 1.1em;
  padding: 0.8em 10px;
  border-width: 0;
}
#cf7-area input[type=submit]:hover {
  background-color: #ffb332;
  color: #061331;
  font-weight: 700;
}
#cf7-area .cf7-must {
  font-size: 1.2em;
  font-weight: 700;
  line-height: 100%;
  color: #d42329;
  margin-left: 2px;
  display: inline-block;
  transform: translateY(-2px);
}
