@charset "UTF-8";
/*
Theme Name: 群馬大学技術院 テーマ
Descritpion: 
Version: 1.00
Author: 群馬大学技術院
Author URL: 
*/

@import url('https://fonts.googleapis.com/css2?family=Kiwi+Maru&family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');

html, body {
    margin: 0;
    padding: 0;    
    height: 100%;
}

body {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400; /* 300 */
    font-size: 100%;
    color: var(--black);
    background: var(--white);
    line-height: 1.7;
    overflow-y: scroll; /* スクロールバーを常時表示 */
}

.wrapper {
    display: flex;
    flex-direction: column;
    width: 100%;
    min-height: 100vh;
}

main {
    flex: 1; /* メイン部分を可変にして余白を埋める */
}

.header-title {
    color: var(--black-deep);
}

/* 書体 */
.font-gothic {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
}

.font-mincho {
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
}

.font-maru {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
}

/* 色の設定 */
:root {
    --white: #f9f9f9;
    --black: #222222;
    --black-trans: rgba(34, 34, 34, .5);
    --black-deep: #1a1a1a;
    --green: #80bf41;
    --green-trans: rgba(128, 191, 65, .2);
    --lightblue: #7acbe1;
    --lightblue-trans: rgba(122, 203, 225, .2);
    --blue: #009bc6;
    --blue-trans: rgba(0, 155, 198, .2);
    --secondary: #6c757d;
    --secondary-trans: rgba(108, 117, 125, .2);
    --red: #df212c;
    --red-trans: rgba(223, 33, 44, .2);
    --darkyellow: #ffa100;
    --darkyellow-trans: rgba(255, 161, 0, .5);
    --darkorange: #ed7100;
    --darkorange-trans: rgba(237, 113, 0, .5);

    --cat-pink: #c82459; /* ニュース */
    --cat-pink-trans: rgba(200, 36, 89, .2);
    --cat-yellow: #f3be2d; /* イベント */
    --cat-yellow-trans: rgba(243, 190, 45, .2);
    --cat-green: #8CBE49; /* その他 */
    --cat-green-trans: rgba(140, 190, 73, .2);
    --cat-blue: #00A8BA; /* 受賞・成果等 */
    --cat-blue-trans: rgba(0, 168, 186, .2);
    --cat-purple: #8E4593; /* 発表会 */
    --cat-purple-trans: rgba(142, 69, 147, .2);
    --cat-brown: #57251d; /* 地域貢献 */
    --cat-brown-trans: rgba(87, 37, 29, .2);
    --cat-redpurple: #b21160; /* 報告集 */
    --cat-redpurple-trans: rgba(178, 17, 96, .2);
    --cat-bluegreen: #007d7f; /* 職員向け講習会 */
    --cat-bluepgreen-trans: rgba(0, 125, 127, .2);
    --cat-orange: #ec6816; /* 学生向け講習会 */
    --cat-orangen-trans: rgba(236, 104, 22, .2);
    --cat-deepgreen: #546930; /* 技術院ニュース */
    --cat-deepgreen-trans: rgba(84, 105, 48, .2);
    --cat-deepblue: #00679f; /* 分野 */
    --cat-deepblue-trans: rgba(0, 103, 159, .2);

    --gray-trans: rgba(211, 211, 211, .5);
}

/* フォントサイズ */
.font-70 {
    font-size: 70%;
}

.font-80 {
    font-size: 80%;
}

.font-90 {
    font-size: 90%;
}

.font-120 {
    font-size: 120%;
}

.font-150 {
    font-size: 150%;
}

.font-200 {
    font-size: 200%;
}

/* 画像 */
img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
}

a {
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

header a:hover {
    text-decoration: none;
}

a:hover img {
  filter: brightness(70%);
  transition: filter 0.3s;
}

header a:hover img {
  filter: none !important;
  opacity: 1 !important;
}

/* 箇条書きをデフォルト設定 */
ul, ol {
  list-style: revert;       /* デフォルト状態に戻す */
  padding-left: 1.5em;      /* 左側の余白を確保 */
  margin-left: 0;           /* 必要に応じて調整 */
}

.page-top-bar {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: linear-gradient(90deg, var(--blue), var(--green));
    color: var(--white);
    font-size: 120%;
    padding: 2rem;
    margin-bottom: 0.5rem;
}

.page-top-bar-single {
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    border: 3px solid;
    border-image: linear-gradient(90deg, var(--blue), var(--green)) 1;
    padding: 0.3rem 0.5rem;
    margin-bottom: 0.5rem;
}

/* ボタンの設定 */
.btn:hover {
    text-decoration: none;
}

.btn-primary {
    background: var(--blue);
    color: var(--white);
    border: 1px solid var(--blue);
}

.btn-primary:hover {
    color: var(--blue);
    background: var(--blue-trans);
    border: 1px solid var(--blue);
}

.btn-outline-primary {
    color: var(--blue);
    border: 1px solid var(--blue);
}

.btn-outline-primary:hover {
    color: var(--blue);
    background: var(--blue-trans);
    border: 1px solid var(--blue);
}

.btn-success {
    background: var(--green);
    color: var(--white);
    border: 1px solid var(--green);
}

.btn-success:hover {
    color: var(--green);
    background: var(--green-trans);
    border: 1px solid var(--green);
}

.btn-outline-success {
    color: var(--green);
    border: 3px solid var(--green);
}

.btn-outline-success:hover {
    color: var(--green);
    background: var(--green-trans);
    border: 3px solid var(--green);
}

.btn-outline-secondary {
    color: var(--secondary);
    border: 3px solid var(--secondary);
}

.btn-outline-secondary:hover {
    color: var(--secondary);
    background: var(--secondary-trans);
    border: 3px solid var(--secondary);
}

.btn-link {
    color: var(--blue);
}

.btn-link:hover {
    color: var(--secondary);
}

/* 背景 */
.bg-white {
    background: var(--white) !important;
}

.bg-primary {
    background: var(--blue) !important;
}

.bg-success {
    background: var(--green) !important;
}

.bg-secondary {
    background: var(--secondary) !important;
}

span.top-square:before {
    content: "\f45c";
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    margin-top: 3px;
    margin-right: 10px;
    color: var(--blue);
}

/* カテゴリの設定 */
/* トピックス */
span.topics a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-pink);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.topics a:hover {
    background: var(--cat-pink-trans);
    color: var(--cat-pink);
    text-decoration: none;
}

/* イベント */
span.event a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-yellow);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.event a:hover {
    background: var(--cat-yellow-trans);
    color: var(--cat-yellow);
    text-decoration: none;
}

/* 受賞・成果等 */
span.prize a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-blue);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.prize a:hover {
    background: var(--cat-blue-trans);
    color: var(--cat-blue);
    text-decoration: none;
}

/* その他 */
span.other a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-brown);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.other a:hover {
    background: var(--cat-brown-trans);
    color: var(--cat-brown);
    text-decoration: none;
}

/* 発表会 */
span.presentation a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-purple);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.presentation a:hover {
    background: var(--cat-purple-trans);
    color: var(--cat-purple);
    text-decoration: none;
}

/* 地域貢献 */
span.community a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-green);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.community a:hover {
    background: var(--cat-green-trans);
    color: var(--cat-green);
    text-decoration: none;
}

/* 技術職員向け講習会 */
span.seminar-staff a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-bluegreen);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.seminar-staff a:hover {
    background: var(--cat-bluegreen-trans);
    color: var(--cat-bluegreen);
    text-decoration: none;
}

/* 学生向け講習会 */
span.seminar-student a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-orange);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.seminar-student a:hover {
    background: var(--cat-orange-trans);
    color: var(--cat-orange);
    text-decoration: none;
}

/* 報告集 */
span.report a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-redpurple);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.report a:hover {
    background: var(--cat-redpurple-trans);
    color: var(--cat-redpurple);
    text-decoration: none;
}

/* 技術部ニュース */
span.technews a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--cat-deepgreen);
    color: var(--white);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.technews a:hover {
    background: var(--cat-deepgreen-trans);
    color: var(--cat-deepgreen);
    text-decoration: none;
}

/* 分野 */
span.johomedia a, span.igakukiban a, span.seimeikagaku a,
span.kagakukeisoku a,span.kikaidenki a, span.kankyoanzen a {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: var(--gray-trans);
    color: var(--cat-deepblue);
    padding: 1px 5px 3px 5px;
    margin-left: 3px;
    font-size: 80%;
}

span.johomedia a:hover, span.igakukiban a:hover, span.seimeikagaku a:hover,
span.kagakukeisoku a:hover, span.kikaidenki a:hover, span.kankyoanzen a:hover {
    background: var(--cat-deepblue-trans);
    text-decoration: none;
}

/* 新しい投稿 */
p.post-new {
    border-bottom: 1px solid var(--red);
    border-top: 1px solid var(--red);
    color: var(--red);
    font-size: 90%;
    margin: 0 10px 0 10px;
}

.container {
    max-width: 650px;
    margin-left: auto;
    margin-right: auto;
    padding: 0;
}

.separate-bar {
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    background: linear-gradient(90deg, var(--blue), var(--green));
    color: var(--white);
    padding: 15px;
    font-size: 110%;
}

.top-image {
    background: url("./image/main.jpg") no-repeat right top / 60vw auto;
}

.top-image h2 {
    font-family: 'Noto Serif JP', serif;
    font-weight: 400;
    font-size: 1.5rem;
    margin: 8vw 0 12vw;
    background: rgba(255, 255, 255, .8);
    padding: 1rem;
    display: inline-block;
}

.top-image p {
    margin: 0 1rem 1rem 1rem;
    background: rgba(255, 255, 255, .4);
}

/* サイト内検索 */
.text-warning-dark {
    color: var(--darkorange);
    font-weight: 400;
}

.excerpt {
    overflow: hidden;
}

.excerpt p {
    margin: 5px 0 0 10px;
}

.excerpt p.more {
    display: inline-block;
    float: right;
    margin: 0 0 5px 0;
}

.excerpt .more a {
    float: right;
    margin: 0 10px 0 0;
}

.excerpt .more i {
    margin-left: 5px;
}

a.search-sep {
    position: relative;
    display: block;
    margin: 0 0 10px 0;
    padding: 10px;
    min-width: 120px;
    max-width: 100%;
    background: var(--lightblue-trans);
}

a.search-sep:hover {
    text-decoration: none;

    background: var(--lightblue);
}

span.seq-marker {
    background: linear-gradient(transparent 60%, var(--darkorange-trans) 60%);
}

footer {
    background: var(--blue);
    color: var(--white);
    margin-top: 1rem;
}

/* トップページ分野画像 */
/* テキスト背景の白透過 */
.custom-bg {
  background: rgba(255, 255, 255, 0.6);
}

/* Contact Form 7 */
/* 背景色の変更 */
.contact-form-wrap {
    background-color: #f9f9f9; /* 背景色 */
    border: 1px solid #ccc;
    padding: 2rem;
}

/* テキストボックスの色やデザインの変更 */
/* テキストボックス全体 */
.wpcf7-form-control[type="text"],
.wpcf7-form-control[type="email"],
.wpcf7-form-control,
.wpcf7-form-control.wpcf7-textarea {
    width: 100%;
    background-color: #fff;
    border: 1px solid var(--secondary);
    padding: 10px;
    border-radius: 5px;
    color: var(--black);
}

/* フォーカス時（クリックで選択された時） */
.wpcf7-form-control:focus {
    border-color: var(--blue);
    box-shadow: 0 0 5px var(--blue-trans);
    outline: none;
}

/* 送信ボタンのデザイン変更 */
.wpcf7-submit {
    background-color: var(--blue); /* ボタン色 */
    color: var(--white);
    border: 1px solid var(--blue);
    padding: 5px 20px;
    border-radius: 5px;
    cursor: pointer;
    transition: 0.3s;
}

.wpcf7-submit:hover {
    color: var(--blue);
    background-color: var(--blue-trans);
    border: 1px solid var(--blue);
}

.font-maru + .table-responsive {
  margin-top: 0 !important;   /* すぐ下の .table-responsive の余白を消す */
  padding-top: 0 !important;
}

.table-responsive {
  margin-top: 0 !important;
  padding-top: 0 !important;
  line-height: 0; /* ブロック間の空白も潰す */
}

.table-responsive table {
  margin-top: 0 !important;
  border-collapse: collapse;
}

/* --- スマートフォン用ヘッダの調整 --- */
.site-header {
    background: var(--white);
    padding: 0;
    position: relative; 
    z-index: 1000; /* メニューより高いz-indexで手前に表示 */
    border-bottom: 1px solid var(--white);
}

/* スマホ用ヘッダ全体に背景色を設定 */
.d-block.d-lg-none {
    background: var(--white); /* 不透明な背景色を追加 */
    position: relative; /* z-indexが効くように */
    z-index: 1000; /* site-headerと同じかそれ以上のz-indexを付けて、下にあるmobile-menuを覆い隠す */
}

.menu-toggle {
    background: var(--blue);
    color: var(--white);
    border: none;
    padding: 13px 10px;
    cursor: pointer;
    font-size: 1rem;
    line-height: 1;
}

.mobile-menu {
    position: absolute;
    /* top: はJavaScriptで動的に設定 */
    left: 0;
    width: 100%;
    margin: 0;
    
    /* 画面外に隠す (topで設定された位置から100%分上にオフセット) */
    transform: translateY(-100%); 
    transition: transform 0.3s ease-in-out; /* スライドのアニメーション */
    
    z-index: 999; /* ヘッダー (z-index: 1000) より低い重なり順 */
    overflow: hidden;
}

/* メニューが開いた状態 */
.mobile-menu.active {
    /* topで設定された位置までスライドして表示 */
    transform: translateY(0);
}

/* メニュー項目 */
.mobile-menu ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

.mobile-menu li {
    border-bottom: 1px solid var(--gray-trans);
}

.mobile-menu li:first-child {
    border-top: 1px solid var(--gray-trans);
}

.mobile-menu a {
    display: block;
    padding: 15px 1rem;
    /*    color: var(--black); */
    color: var(--white);
    text-decoration: none;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    transition: background-color 0.2s;
}

.mobile-menu a:hover {
    /*
    background-color: var(--lightblue-trans);
    color: var(--blue);
   */
    background-color: rgba(255, 255, 255, 0.1); 
    color: var(--white);    
}

/* タブ */
/* タブ全体の調整 */
.nav-tabs {
  border-bottom: none;   /* Bootstrapの線を消す */
  margin-bottom: 0;      /* タブ下の余白を消す */
}

/* 各タブボタンの基本設定 */
.nav-tabs .nav-link {
    border: none;
    border-radius: 0;
    background-color: white;
    color: var(--black);
    border-bottom: 5px solid transparent; /* カスタム下線 */
    transition: all 0.25s ease;
    font-family: 'Kiwi Maru', serif;
    font-weight: 400;
    padding: 3px;
    font-size: 90%;
}

/* カテゴリ別に下線色を設定 */
.nav-tabs .nav-link.tab-all { /* すべて */
    border-bottom-color: var(--secondary);
}
.nav-tabs .nav-link.tab-topics { /* ニュース */
    border-bottom-color: var(--cat-pink);
}
.nav-tabs .nav-link.tab-event { /* イベント */
    border-bottom-color: var(--cat-yellow);
}
.nav-tabs .nav-link.tab-prize { /* 受賞・成果等 */
    border-bottom-color: var(--cat-blue);
}
.nav-tabs .nav-link.tab-community { /* 地域貢献 */
    border-bottom-color: var(--cat-green);
}

/* アクティブ時：背景色を下線色に */
.nav-tabs .nav-link.tab-all.active {
    background-color: var(--secondary);
    color: var(--white);
    border-bottom-color: var(--secondary); 
}
.nav-tabs .nav-link.tab-topics.active {
    background-color: var(--cat-pink);
    color: var(--white);
    border-bottom-color: var(--cat-pink); 
}
.nav-tabs .nav-link.tab-event.active {
    background-color: var(--cat-yellow);
    color: var(--white);
    border-bottom-color: var(--cat-yellow);
}
.nav-tabs .nav-link.tab-prize.active {
    background-color: var(--cat-blue);
    color: var(--white);
    border-bottom-color: var(--cat-blue);
}
.nav-tabs .nav-link.tab-community.active {
    background-color: var(--cat-green);
    color: var(--white);
    border-bottom-color: var(--cat-green);
}

/* hover */
.nav-tabs .nav-link.tab-all:hover {
    background: var(--secondary-trans);
    color: var(--cat-secondary);
}
.nav-tabs .nav-link.tab-topics:hover {
    background: var(--cat-pink-trans);
    color: var(--cat-pink);
}
.nav-tabs .nav-link.tab-event:hover {
    background: var(--cat-yellow-trans);
    color: var(--cat-yellow);
}
.nav-tabs .nav-link.tab-prize:hover {
    background: var(--cat-blue-trans);
    color: var(--cat-blue);
}
.nav-tabs .nav-link.tab-community:hover {
    background: var(--cat-green-trans);
    color: var(--cat-green);
}

/* focus時の余計な青い枠線を消す */
.nav-tabs .nav-link:focus {
  outline: none;
  box-shadow: none;
}


/* responsiveな表のスクロール対応 */
.scrollable-table-wrapper {
  position: relative;
}

.scroll-hint {
  position: absolute;
  top: 4px;
  right: 4px;
  background: var(--black-trans);
  color: var(--white);
  padding: 10px;
  font-size: 12px;
  border-radius: 4px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s;
  z-index: 10;
}

.scroll-hint.active {
  opacity: 1;
}

/* 各分野のお知らせ */
ul.latest-posts {
    list-style: none;
    background-color: white;
    color: var(--black);
    padding: 3px;
    font-size: 90%;
}

.latest-posts li:last-child {
  border-bottom: none !important;
}


@media print, screen and (min-width: 600px) {
    .top-image {
	padding: 9vw 1rem;
    }

    .top-image h2 {
	font-size: 2.5rem;
	margin: 0 0 2rem;
	background: none;
	padding: 0;
    }

    .top-image p {
	width: 38vw;
	margin: 0 0 2rem 0;
    }

    .header-title {
	font-size: 200%;
    }

    .page-top-bar-single {
	padding: 0.5rem 1rem;
    }

    .menu-toggle {
	padding: 20px 10px;
    }

} /* @media (min-width: 600px) */

@media print, screen and (min-width: 768px) {

    .container {
	max-width: 768px;
    }

} /* @media (min-width: 768px) */

@media print, screen and (min-width: 1000px) {

    .container {
	max-width: 1000px;
    }

} /* @media (min-width: 1000px) */
