﻿@charset "utf-8";
/* CSS Document */
body,
#header,
#footer {
    width: auto;
	min-width: 320px;
}
body.active {
    overflow: hidden;
}
img {
    max-width: 100%;
    height: auto;
}
#header {
    justify-content: center;
    align-items: center;
    min-height: 75px;
}
#logo {
    padding: 0;
}
#logo h1,
#logo a {
    width: auto;
    height: auto;
}
#logo h1 img,
#logo a img {
    max-width: 178px;
    height: auto;
}
#head_cnt {
    position: fixed;
    bottom: 0;
    left: 0;
    z-index: 9000;
    flex-direction: row;
    background-color: #000D2A;
    color: #FFFFFF;
    width: 100%;
    padding: 0;
    gap: 0;
    min-width: 320px;
}
#header.top_head #head_cnt {
    background-color: #0377B6;
}
.menu_btn {
    width: calc(100% - 83px);
}
.menu_btn a {
    color: #FFFFFF;
    padding: 15px 10px 16px 117px;
}
.menu_btn a::before,
.menu_btn a::after {
    right: auto;
    left: 86px;
}
.menu_btn a::before {
    width: 19px;
    border-top-color: #FFFFFF;
    border-bottom-color: #FFFFFF;
    top: 16px;

}
.menu_btn a::after {
    width: 12px;
    background-color: #FFFFFF;
    top: 28px;
}
.setting_btn {
    border-left: 1px solid #FFFFFF;
    width: 83px;
}
.setting_btn a {
    background: url("/soshiki_file/daigakusougou2023/img/icon/setting-btn-w.png") 18px 16px/14px auto no-repeat;
    padding: 15px 17px 16px 42px;
    color: #FFFFFF;
}
.sp_menu_btn {
	display: block;
	position: fixed;
	top: 10px;
	right: 10px;
	width: 58px;
	height: 58px;
    padding: 8px 8px 0;
    z-index: 9999;
    background-color: #FFFFFF;
}
.sp_menu_btn a {
    display: block;
    font-size: 12px;
    padding: 26px 3px 5px;
    text-align: center;
    text-decoration: none;
    color: #333333;
    position: relative;
}
.sp_menu_btn a:before,
.sp_menu_btn a:after {
    content: "";
    display: block;
    position: absolute;
    transition: all 0.6s;
    width: 42px;
}
.sp_menu_btn a:before {
    height: 18px;
    border-top: 2px solid #333333;
    border-bottom: 2px solid #333333;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
}
.sp_menu_btn a:after {
    height: 2px;
    background-color: #333333;
    top: 10px;
    left: 0;
    right: 0;
    margin: auto;
}
.sp_menu_btn.active a:before {
    transform: rotate(35deg);
    border: none;
    background: #333333;
    height: 2px;
    top: 10px;
}
.sp_menu_btn.active a:after {
    transform: rotate(145deg);
}
nav,
#head_setting {
    width: 100%;
    right: -100%;
}
.col2,
.col3,
.col4 {
    flex-direction: column;
}
.col2 .col2_box,
.col3 .col3_box,
.col4 .col4_box {
    width: auto;
    margin: 0 0 10px;
}
/* Youtube動画 */
.youtube_box {
    position: relative;
    display: block;
    height: 0;
    padding-bottom: 56.25%;
    overflow: hidden;
}
.youtube_box iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
#page_top p a,
#page_top.active p a {
    transform: translate(0);
    left: auto;
    right: 10px;
}
#page_top.active p a {
    bottom: 49px;
}
#footer {
    padding: 40px 0 49px;
}
#footer #footer_cnt,
#footer #foot_link {
    width: auto;
}
#footer #foot_link,
#footer #foot_link ul {
    flex-direction: column;
}
#footer #foot_link {
    margin-bottom: 41px;
}
#footer #foot_link ul {
    margin: 0;
    max-width: 100%;
    gap: 0;
}
#footer #foot_link ul li {
    width: 222px;
    margin: 0 auto;
}
#footer #foot_link ul li a {
    display: inline-block;
    background-position: calc(100% - 11px) center;
    background-size: 15px auto;
    font-size: 0.75rem;
    letter-spacing: 1.25px;
    padding: 11px 35px 10px 14px;
}
#footer #foot_link ul.link_btn_list {
    flex-direction: column;
    border-top: none;
    gap:9px;
    margin-bottom: 22px;
}
#footer #foot_link ul.link_btn_list li {
    border-bottom: none;
}
#footer #foot_link ul.link_btn_list li a {
    width: 196px;
    margin: 0 auto;
    letter-spacing: 0;
    padding: 9px 36px 4px 26px;
    background-position: calc(100% - 13px) center;
    background-size: 16px auto;
}
#footer #footer_cnt {
    margin-bottom: 45px;
}
#footer #footer_cnt #flogo {
    margin-bottom: 16px;
}
#footer #footer_cnt #flogo img {
    max-width: 251px;
}
#footer #footer_cnt p {
    font-size: 0.875rem;
    margin-bottom: 13px;
}
#footer #footer_cnt address {
    line-height: 1.57;
}
#footer #footer_cnt address span {
    display: block;
    margin-left: 0;
}
#footer #copyright {
    font-size: 0.625rem;
    padding-top: 15px;
    letter-spacing: 0.15px;
}

#contents,
#contents.cnt2,
#contents.cnt2 .lcnt,
#contents.cnt2 .rcnt,
#page_top,
#footer_cnt {
    display: block;
	width: auto;
}
#contents.cnt2 .lcnt,
#contents.cnt2 .rcnt {
    margin-bottom: 10px;
}
#contents.cnt2 .rnav {
    width: auto;
}
/*トップ*/
#main_visual,
#top_site_link,
#top_info ul,
#top_list .box_cnt {
    width: auto;
    min-width: 320px;
}
#main_visual {
    background-size: 14px auto;
    height: 430px;
}
#main_visual_img {
}
#main_visual_img img {
    width: 1190px;
    height: 430px;
    max-width: initial;
    clip-path: polygon(57.25% 0, 100% 0%, 40.25% 100%, 0% 100%);
    position: relative;
    top: 0;
    left: 152px;
    object-position: -192px -22px;
}
#main_visual_txt {
    width: 280px;
    top: 35px;
    left: 0;
    right: 0;
    margin: auto;
    font-size: 0.875rem;
    color: #0377B6;
    letter-spacing: 1.4px;
}
#main_visual_txt span {
    background: url("/soshiki_file/daigakusougou2023/img/top/main-visual-txt-sp.png") left top/contain no-repeat;
    width: 279px;
    height: 98px;
    margin: 10px 0 0 -4px;
}
#main_visual_txt span img {
    display: none;
}
#main_visual_img {
    height: 430px;
}
#top_site_link {
    flex-direction: column;
    padding: 20px 20px 36px;
    gap: 64px;
    background-position: right bottom;
    position: relative;
}
#top_site_link::before {
    content: "";
    display: block;
    width: 100%;
    height: calc(100% - 273px);
    background-color: #FFFFFF;
    position: absolute;
    left: 0;
    bottom: 273px;
}
#top_site_link .site_link_box {
    width: auto;
    min-height: 175px;
    padding: 0 120px 12px 17px;
    top: -101px;
}
#top_site_link .site_link_box h2 {
    padding-right: 10px;
    margin: -2px -122px 10px -19px;
    padding: 6px 10px 5px;
    font-size: 1.0625rem;
    letter-spacing: 0.5px;
}
#top_site_link .site_link_box p {
    font-size: 0.875rem;
    line-height: 1.57;
}
#top_site_link .site_link_box .user_type {
    font-size: 0.75rem;
    width: 174px;
    padding: 11px 5px 9px;
    border-radius: 6px;
    min-height: initial;
    position: absolute;
    bottom: calc(100% + 8px);
    left: 0;
    right: 0;
    margin: 0 auto;
    border-width: 1px;
    letter-spacing: 1.5px;
}
#top_site_link .site_link_box .user_type::before {
    border-width: 5px 4px 0 4px;
	bottom: -5px;
}
#top_site_link .site_link_box .user_type::after {
    border-width: 3px 3px 0 3px;
	bottom: -3px;
}
#top_site_link .site_link_box .user_type br {
    display: none;
}
#top_site_link .site_link_box .site_link_img {
    width: 102px;
    bottom: 50px;
    right: 9px;
}
#top_site_link .site_link_box.recurrent .site_link_img {
    bottom: 38px;
    right: 12px;
    width: 96px;
}
#top_site_link .site_link_box .link_btn {
    bottom: 8px;
    left: auto;
    right: 10px;
}
#top_site_link .site_link_box a {
    font-size: 0.75rem;
    padding-right: 23px;
}
#top_info .cnt_ttl {
    width: auto;
    margin: -75px 20px 15px;
    position: relative;
}
#top_info .cnt_ttl h2 {
    font-size: 1.625rem;
}
#top_info .cnt_ttl p {
    font-size: 0.875rem;
}
#top_info ul {
    padding: 0 20px;
    gap: 8px;
}
#top_info ul li {
    width: calc(50% - 4px);
    min-height: initial;
}
#top_info ul li a {
    width: 100%;
    font-size: 0.875rem;
    border-width: 3px;
    line-height: 1.3;
    padding: 12px 5px 26px;
}
#top_info ul li a br {
    display: none;
}
#top_info ul li a::after {
    font-size: 0.75rem;
    bottom: 2px;
    right: 9px;
    background-size: 8px auto;
    padding-right: 13px;
}
#top_info ul li a span {
    margin: auto;
}
#top_info ul li a img {
    max-width: 80%;
}
#top_list {
    background-size: 16px auto;
}
#top_list .box_cnt {
    padding: 47px 20px 50px;
}
#top_list .box_cnt .cnt_ttl h2 {
    font-size: 1.625rem;
}
#top_list .box_cnt .cnt_ttl p {
    font-size: 0.875rem;
}
#top_list h3 {
    font-size: 1.125rem;
    margin: 40px 0 20px;
    padding: 17px 10px 14px;
}
#top_list .box_cnt .cnt_ttl + h3 {
    margin-top: 36px;
}
#top_list .box_cnt ul {
    gap: 14px;
}
#top_list .box_cnt ul li {
    width: calc(50% - 7px);
    border-radius: 4px;
    min-height: 80px;
}
#top_list .box_cnt ul li a {
    font-size: 0.875rem;
    letter-spacing: 0;
    gap:9px;
    background-position: calc(100% - 9px) calc(100% - 7px);
    background-size: 9px auto;
}
#top_list .box_cnt ul li a span {
    width: 32px;
}
#top_banner_area {
    padding: 35px 20px 31px;
}
#top_banner_area ul {
    gap: 6px 12px;
    justify-content: flex-start;
}
#top_banner_area ul li {
    width: calc(50% - 6px);
}
#top_banner_area ul li:nth-child(2n+1) {
    text-align: right;
}
/*リカレント講座トップ*/
#re_search_area .area_box,
#re_news_area .cnt_ttl,
#re_news_area ul,
#re_topics_area .cnt_ttl,
#re_event_area .cnt_box {
    width: auto;
}
#re_event_area .area_cnt {
    width: auto;
    flex-direction: column;
}
.recurrent #main_visual {
    height: 430px;
}
.recurrent #main_visual_img {
    height: 430px;
}
.recurrent #main_visual_img img {
    width: 1200px;
    height: 430px;
    left: 146px;
    clip-path: polygon(57% 0, 100% 0%, 46% 100%, 0 100%);
    object-position: -90px 0;
}
.recurrent #main_visual::after {
    clip-path: polygon(260px 0%, 100% 0, 100% 100%, 0% 100%);
}
.recurrent #main_visual_txt {
    top: 24px;
    left: 0;
}
.recurrent #main_visual_txt h1 {
    font-size: 0.75rem;
    letter-spacing: 0.5px;
}
.recurrent #main_visual_txt img {
    width: 246px;
    margin: 4px 0 7px;
}
.recurrent #main_visual_txt p {
    font-size: 0.625rem;
    line-height: 1.8;
}
#re_search_area {
    min-height: 259px;
    padding: 0 20px;
}
#re_search_area .area_box {
    top: -35px;
    background: #FDF4ED;
    border-radius: 4px;
}
#re_search_area .area_box a {
    padding: 54px 20px 30px;
}
#re_search_area .area_box a::before,
#re_search_area .area_box a::after {
    content: "";
    display: block;
    position: absolute;
    background-size: contain !important;
}
#re_search_area .area_box a::before {
    background: url("/soshiki_file/daigakusougou2023/img/recurrent/search-img01.png") left top no-repeat;
    width: 100px;
    height: 74px;
    top: -24px;
    left: -9px;
}
#re_search_area .area_box a::after {
    background: url("/soshiki_file/daigakusougou2023/img/recurrent/search-img02.png") left top no-repeat;
    width: 64px;
    height: 68px;
    top: -23px;
    right: 16px;
}

#re_search_area .area_box .area_icon {
    background-position: center 15px;
    background-size: 28px auto;
    font-size: 0.65rem;
    width: 84px;
    height: 84px;
    padding: 50px 5px 4px;
}
#re_search_area .area_box h2 {
    width: 192px;
    font-size: 1.0625rem;
    padding: 7px 12px 6px 18px;
    margin-bottom: 13px;
}
#re_search_area .area_box p {
    padding: 24px 0 0 5px;
    font-size: 0.625rem;
    letter-spacing: 0.5px;
    background-size: 14px auto;
}
#re_news_area {
    padding: 0 20px 51px;
}
#re_news_area .cnt_ttl {
    margin: -67px auto 9px;
    padding-top: 38px;
    border-radius: 4px 4px 0 0;
}
#re_news_area .cnt_ttl h2 {
    font-size: 1.625rem;
}
#re_news_area .cnt_ttl p {
    margin-bottom: 4px;
}
#re_news_area ul {
    margin-bottom: 28px;
}
#re_news_area ul li {
    padding: 16px 0 15px;
}
#re_news_area ul li span {
    display: block;
    font-size: 0.875rem;
    margin-bottom: 13px;
}
#re_news_area ul li a {
    font-size: 0.875rem;
}
#re_news_area .list_link a {
    font-size: 0.75rem;
    padding: 13px 54px 12px 42px;
    background-position: calc(100% - 14px) center;
}
#re_topics_area {
    padding: 160px 20px 40px;
}
#re_topics_area::before {
    height: 181px;
}
#re_topics_area .cnt_ttl {
    margin-top: -46px;
    margin-bottom: 0;
    padding-top: 38px;
}
#re_topics_area .cnt_ttl h2 {
    font-size: 1.625rem;
}
#re_topics_area .cnt_ttl p {
    margin-bottom: 3px;
}
#re_topics_area #topics_slide .slick-list {
    margin-bottom: 24px;
}
#re_topics_area #topics_slide .slick-slide img {
    margin-top: 7px;
}
#re_topics_area .slide_box {
    flex-wrap: wrap;
    padding: 11px 23px 23px 18px;
    gap: 13px;
}
#re_topics_area .slide_box .slide_img {
    width: 40%;
}
#re_topics_area .slide_box .box_cnt {
    width: auto;
    max-width: calc(60% - 13px);
}
#re_topics_area .slide_box h3 {
    font-size: 1rem;
    line-height: 1.5;
    margin-bottom: 4px;
}
#re_topics_area .slide_box p {
    font-size: 0.875rem;
}
#re_topics_area .slide_box .link_btn {
    margin-bottom: 0;
    text-align: center;
}
#re_topics_area .slide_box .link_btn a {
    font-size: 0.6875rem;
    padding: 14px 48px 13px 31px;
}
#topics_slide + .dot_wrap {
    gap: 16px;
}
#topics_slide + .dot_wrap .slick-dots {
}
#topics_slide + .dot_wrap .buttons {
    margin: 0;
}
#topics_slide + .dot_wrap .buttons a {
    border-radius: 5px;
    font-size: 0.625rem;
    min-width: 42px;
    padding: 3px 3px 0px;
}
#topics_slide + .dot_wrap .slick-dots li {
    width: 10px;
    height: 10px;
    margin: 0 5px;
}
#topics_slide + .dot_wrap .slick-dots li button {
    width: 10px;
    height: 10px;
}
#topics_slide + .dot_wrap .prev,
#topics_slide + .dot_wrap .next {
    width: 31px;
    height: 31px;
}
#topics_slide + .dot_wrap .prev {
    margin-right: 16px;
}
#topics_slide + .dot_wrap .next {
    margin-left: 16px;
}
#topics_slide + .dot_wrap .prev a,
#topics_slide + .dot_wrap .next a {
    width: 27px;
    height: 27px;
}
#topics_slide + .dot_wrap .prev a::before,
#topics_slide + .dot_wrap .next a::before,
#topics_slide + .dot_wrap .prev a::after,
#topics_slide + .dot_wrap .next a::after {
    width: 6px;
    height: 1px;
}
#topics_slide + .dot_wrap .prev a::before,
#topics_slide + .dot_wrap .next a::before {
    top: 4px;
}
#topics_slide + .dot_wrap .prev a::after,
#topics_slide + .dot_wrap .next a::after {
    bottom: 4px;
}
#re_event_area {
    padding: 40px 20px 30px;
}
#re_event_area .cnt_img {
    text-align: center;
}
#re_event_area h2 {
    font-size: 0.875rem;
    text-align: center;
}
#re_event_area h3 {
    font-size: 1.625rem;
}
#re_event_area p {
    font-size: 0.875rem;
    font-weight: normal;
}
#re_event_area .link_btn {
    text-align: center;
}
/*末端*/
#recurrent_wrap {
    height: 109px;
}
#recurrent_ttl {
    top: 24px;
    left: 23px;
}
#recurrent_ttl .ttl_txt {
    font-size: 0.625rem;
    margin-bottom: 2px;
}
#recurrent_ttl .ttl_img img {
    width: 118px;
}
#pankuzu_wrap .pankuzu {
    padding: 9px 14px 11px;
}
#pankuzu_wrap .pankuzu li,
#pankuzu_wrap .pankuzu li a {
    font-size: 0.75rem;
}
#contents {
    padding: 20px 15px 51px;
    font-size: 0.875rem;
}
#contents h1 {
    margin-bottom: 20px;
}
#contents h2 {
    font-size: 1.375rem;
    margin: 47px 0 37px;
    padding: 11px 14px;
}
#contents h2::before {
    border-width: 11px 14px 0 0;
}
#contents h3 {
    font-size: 1.0625rem;
    margin: 37px 0 27px;
    padding: 6px 14px 8px;
}
#contents h4 {
    font-size: 1rem;
    margin: 27px 0 25px;
}
#contents h4::before {
    top: 0.55rem;
}
#contents h5 {
    font-size: 1rem;
    margin: 24px 0;
}
#contents h6 {
    font-size: 0.875rem;
    margin: 26px 0 31px;
}
#contents p {
    font-size: 0.875rem;
    line-height: 1.57;
}
#contents ul {
    margin-left: 0;
}
#contents ol {
    margin-left: 17px;
}
#contents ul li {
    padding-left: 14px;
    margin-bottom: 0.925rem;
}
#contents ul li:before {
    top: 0.45rem;
}
#contents table {
    margin: 41px 0 2.7rem;
}
#contents .sp_table_wrap2 {
    margin: 41px 0 2.7rem;
}
#contents .sp_table_wrap table {
    margin: 5px 0 0;
}
#contents table tr th,
#contents table tr td {
    padding-bottom: 26px;
}
#contents dl dt,
#contents dl dd {
    display: block;
    text-align: left;
    width: auto;
}
#contents #section_footer {
    margin-top: 55px;
}
#contents #section_footer h2 {
    padding: 18px 15px;
}
#contents #section_footer_info {
    padding: 18px 16px 29px;
}
#contents #section_footer_info span {
    margin-bottom: 0;
    line-height: 1.57;
}
#content_header {
    margin: 20px 0;
}
#contents #print_mode_link {
    display: none;
}
#contents #article_update {
    font-size: 0.75rem;
}
#contents .outline_box {
    padding: 18px 20px 14px;
}
#contents .result_box {
    padding: 20px 15px 20px;
}
#contents .result_ttl {
    flex-direction: column;
    gap: 10px;
    padding-bottom: 10px;
    align-items: flex-start;
}
#contents .result_ttl h2,
#contents .result_ttl .result_list {
    max-width: initial;
}
#contents .result_ttl .result_list li {
    padding: 1px 3px 0;
}
#contents .result_cnt {
    flex-direction: column;
}
#contents .result_cnt dl dt {
    display: inline-block;
    text-align: center;
    width: auto;
    min-width: 137px;
    margin-bottom: 5px;
}
#contents .result_cnt dl dd {
    width: 100%;
    padding-left: 0;
}
#contents .result_cnt .link_btn {
    width: 100%;
    margin: 20px 0 0;
}
#contents #pagenation {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 10px;
    position: relative;
}
#contents #pagenation li.prev,
#contents #pagenation li.next {
    margin: 0;
    border: none !important;
}
#contents #pagenation li.prev {
    width: calc(50% - 5px);
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 1;
}
#contents #pagenation li.next {
    width: 100%;
    order: 1000;
    text-align: right;
    padding: 0;
}
#contents #pagenation li.prev a,
#contents #pagenation li.next a {
    border: 1px solid #C84915;
}
#contents #pagenation li.next a {
    width: calc(50% - 5px);
    display: inline-block;
    text-align: center;
    margin: 0;
}
#search_area {
    padding: 86px 20px 52px;
}
#search_area input[type="submit"] {
    margin-top: 42px;
}
#search_area .area_box a {
    padding: 10px;
}
#search_area .area_box {
    width: auto;
    background: #FDF4ED;
    border-radius: 4px;
}
#search_area .area_box a {
    padding: 54px 20px 30px;
}
#search_area .area_box a::before,
#search_area .area_box a::after {
    content: "";
    display: block;
    position: absolute;
    background-size: contain !important;
}
#search_area .area_box a::before {
    background: url("/soshiki_file/daigakusougou2023/img/recurrent/search-img01.png") left top no-repeat;
    width: 100px;
    height: 74px;
    top: -24px;
    left: -9px;
}
#search_area .area_box a::after {
    background: url("/soshiki_file/daigakusougou2023/img/recurrent/search-img02.png") left top no-repeat;
    width: 64px;
    height: 68px;
    top: -23px;
    right: 16px;
}
#search_area .area_box .area_icon {
    background-position: center 15px;
    background-size: 28px auto;
    font-size: 0.65rem;
    width: 84px;
    height: 84px;
    padding: 50px 5px 4px;
}
#search_area .area_box h2 {
    width: 192px;
    font-size: 1.0625rem;
    padding: 7px 12px 6px 18px;
    margin-bottom: 13px;
}
#search_area .area_box p {
    padding: 24px 0 0 5px;
    font-size: 0.625rem;
    letter-spacing: 0.5px;
    background-size: 14px auto;
}
#contents fieldset {
    
}
#contents fieldset span {
    border: 1px solid #8D8D8D;
    border-radius: 3px;
    margin: 0 6px 10px 0;
    position: relative;
}
#contents input[type="checkbox"], #contents input[type="radio"] {
    position: absolute;
    top: 14px;
    left: 12px;
}
#contents label {
    max-width: 100%;
    margin: 0;
    padding: 13px 18px 10px 37px;
    font-size: 0.8125rem;
}