@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual {
    height: 600px;
    position: relative;
}
.mainVisual .photoList {
    width: 100%;
    height: 600px;
    position: absolute;
    top: 0;
    left: 0;
}
.mainVisual .photoList li {
    width: 100%;
    height: 600px;
	vertical-align: top;
    background: url("../img/index/main_visual_bg01.jpg") no-repeat center / cover;
}
.mainVisual .photoList li.bg01 {
    background: url("../img/index/main_visual_bg02.jpg") no-repeat center / cover;
}
.mainVisual .photoList li.bg02 {
    background: url("../img/index/main_visual_bg03.jpg") no-repeat center / cover;
}
.mainVisual .slick-dots {
    width: 100%;
    display: block;
	position: absolute;
	left: 0;
	bottom: 18px;
    text-align: center;
}
.mainVisual .slick-dots li {
    margin: 0 5px;
    display: inline-block;
    width: 10px !important;
    height: 10px !important;
    border-radius: 50%;
    background: #a2a2a2;
}
.mainVisual .slick-dots li button {
    display: none;
}
.mainVisual .slick-dots li.slick-active {
    background: #7d7d7d;
}
.mainVisual .subBox {
    padding-top: 210px;
    position: relative;
    align-items: center;
    flex-direction: column;
    z-index: 100;
}
.mainVisual .subBox .han {
    color: #FFF;
    font-size: 6rem;
    font-weight: 900;
    letter-spacing: 0.13em;
    text-align: center;
}
.mainVisual .subBox .han .sml {
    margin-top: 12px;
    display: block;
    font-size: 1.8rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    line-height: 1.89;
}
#main .news {
    padding-top: 109px;
}
#main .news .headLine01 {
    margin-bottom: 4px;
}
#main .news .tabList {
    margin: -10px 0 0 auto;
    text-align: right;
}
#main .news .tabList li {
    display: inline-block;
}
#main .news .tabList li:not(:last-of-type) {
    margin-right: 6px;
}
#main .news .tabList li a {
    padding: 0 8px 30px;
    display: block;
    letter-spacing: 0.15em;
}
#main .news .tabList li.on a {
    color: #377e38;
    border-bottom: 5px solid #377e38;
}
#main .news .tabBox {
    margin-bottom: 68px;
}
#main .news .tabBox dl {
    font-size: 1.55rem;
    letter-spacing: 0.15em;
    border-top: 1px solid #e6e6e6;
}
#main .news .tabBox dt {
    padding: 26px 0;
    width: 230px;
    overflow: hidden;
    border-bottom: 1px solid #e6e6e6;
}
#main .news .tabBox dt .time {
    display: inline-block;
    min-width: 120px;
}
#main .news .tabBox dt ul {
    margin-top: -4px;
    float: right;
    width: 100px;
}
#main .news .tabBox dt li {
    margin-top: 4px;
    padding: 3px 2px;
    min-width: 100px;
    color: #377e38;
    font-size: 1.4rem;
    line-height: 1;
    letter-spacing: 0.13em;
    text-align: center;
    border: 1px solid #377e38;
    border-radius: 5px;
    box-sizing: border-box;
}
#main .news .tabBox dd {
    padding: 26px 0 29px 30px;
    width: calc(100% - 230px);
    font-size: 1.55rem;
    border-bottom: 1px solid #e6e6e6;
    box-sizing: border-box;
}
#main .news .tabBox dd img {
    padding-top: 3px;
}
#main .vison {
    padding: 116px 0 124px;
}
#main .vison .headLine01 {
    margin: 0 auto 49px;
    width: 1140px;
}
#main .vison .photo {
    width: calc(50% + 570px);
}
#main .vison .photo img {
    width: 100%;
}
#main .vison .visonList {
    margin: -220px auto 0;
    width: 1140px;
    position: relative;
    z-index: 100;
    align-items: flex-end;
}
#main .vison .visonList li {
    padding: 54px 50px 63px 61px;
    width: 510px;
    background-color: #FFF;
    border-radius: 20px;
    box-sizing: border-box;
    box-shadow: 0px 0px 70px 0px rgba(0, 0, 0, 0.1);
}
#main .vison .visonList li:not(:last-of-type) {
    margin-right: 60px;
}
#main .vison .visonList li p {
    line-height: 2;
    letter-spacing: 0.15em;
    text-align: justify;
    text-justify:inter-ideograph;
}
#main .holdings {
    padding: 113px 0 119px;
    background: url("../img/index/bg01.jpg") left top;
}
#main .holdings .content {
    padding: 0 20px;
    width: auto;
    max-width: 1480px;
}
#main .holdings .headLine01 {
    margin: 0 auto 55px;
    width: 1140px;
}
#main .holdings .headLine01 .en {
    margin-top: 0;
    vertical-align: 20px;
}
#main .holdings .holdList {
    margin-top: -61px;
}
#main .holdings .holdList li {
    margin-top: 61px;
    width: 21.96%;
    box-shadow: 0px 0px 40px 0px rgba(0, 0, 0, 0.05);
}
#main .holdings .holdList li a {
    padding: 40px 0 38px;
    display: block;
    background-color: #FFF;
    text-align: center;
    border-radius: 10px;
}
#main .holdings .holdList li a:hover {
    opacity: 0.7;
}
#main .holdings .holdList li .txt {
    color: #377e38;
    font-weight: 700;
    letter-spacing: 0.13em;
}
#main .holdings .holdList li .pho {
    margin-bottom: 34px;
    padding-bottom: 38px;
    position: relative;
}
#main .holdings .holdList li .pho::after {
    width: 100px;
    height: 1px;
    position: absolute;
    left: 50%;
    bottom: 0;
    background-color: #e1e1e1;
    transform: translateX(-50%);
    content: '';
}
#main .holdings .holdList li:not(:nth-of-type(4n)) {
    margin-right: 4%;
}
#main .greeting {
	margin-bottom: 116px;
}
#main .greeting .textBox {
    width: calc(50% + 100px);
}
#main .greeting .textBox .photo {
    margin-bottom: 20px;
}
#main .greeting .textBox .subBox {
    margin: 100px 56px 0 auto;
    width: 614px;
}
#main .greeting .textBox .subBox p {
    line-height: 2;
    letter-spacing: 0.15em;
    text-align: justify;
    text-justify:inter-ideograph;
}
#main .greeting .textBox .subBox .name {
    font-size: 2.2rem;
    font-weight: 700;
    letter-spacing: 0.13em;
}
#main .greeting .textBox .subBox p:not(:last-of-type) {
    margin-bottom: 16px;
}
#main .greeting .textBox .subBox .text {
    margin-bottom: 37px!important;
}
#main .greeting .photoBox {
    width: calc(50% - 100px);
}
#main .greeting .photoBox .subBox {
    box-shadow: 0px 0px 40px 0px rgba(0, 0, 0, 0.15);
    border-bottom-left-radius: 20px;
}
#main .greeting .photoBox img {
    width: 100%;
}
#main .greeting .content {
    padding-top: 100px;
}
#main .greeting .headLine02 {
    margin-bottom: 60px;
}
#main .greeting .greetingList {
    margin-top: -56px;
}
#main .greeting .greetingList li {
    margin-top: 56px;
    width: 340px;
    position: relative;
    text-align: center;
}
#main .greeting .greetingList li .pho {
    margin-bottom: 25px;
}
#main .greeting .greetingList::after {
    width: 340px;
    content: '';
}
#main .greeting .greetingList li a {
    display: block;
    letter-spacing: 0.13em;
}
#main .greeting .greetingList li a:hover {
    opacity: 0.7;
}
#main .summary {
	padding: 120px 0;
	background: url("../img/index/bg01.jpg") left top;
}
#main .summary .textBox {
	width: calc(50% - 70px)
}
#main .summary .textBox .headLine01 {
    margin: -10px 0 55px;
}
#main .summary .textBox .subBox {
    padding: 8px 30px 14px;
    width: 615px;
    position: relative;
	background-color: #FFF;
    box-sizing: border-box;
    border-radius: 10px;
    z-index: 100;
}
#main .summary .textBox .subBox table {
    width: 100%;
    border-collapse: collapse;
}
#main .summary .textBox .subBox th,
#main .summary .textBox .subBox td {
    padding: 20px 0 16px;
    width: 28%;
    font-size: 1.5rem;
	font-weight: 500;
    line-height: 1.33;
    letter-spacing: 0.15em;
    text-align: left;
    vertical-align: top;
    word-break: break-all;
    border-bottom: 1px solid #377e38;
    box-sizing: border-box;
}
#main .summary .textBox .subBox td {
    padding: 20px 0 14px 18px;
    width: 72%;
    letter-spacing: 0.12em;
    border-bottom: 1px solid #e6e6e6;
}
#main .summary .textBox .subBox tr:last-of-type th,
#main .summary .textBox .subBox tr:last-of-type td {
    padding-bottom: 0;
    border: 0;
}
#main .summary .photoBox {
	width: calc(50% + 70px);
}
#main .summary .photoBox .photoList {
    margin-bottom: 13px;
}
#main .summary .photoBox .photoList li img {
    border-radius: 10px;
}
#main .summary .photoBox .dots {
    margin: 0 7px 11px;
    text-align: right;
}
#main .summary .photoBox .slick-dots {
    position: relative;
    height: 16px;
}
#main .summary .photoBox .slick-dots::after {
    width: 230px;
    height: 1px;
    position: absolute;
    top: 50%;
    right: 10px;
	z-index: 1;
    background-color: #377e38;
    content: '';
}
#main .summary .photoBox .slick-dots li {
    width: 16px;
    height: 16px;
    display: inline-block;
    background: url("../img/common/icon06.png") no-repeat center;
    border-radius: 50%;
    box-sizing: border-box;
}
#main .summary .photoBox .slick-dots li.slick-active {
    border: 1px solid #377e38;
    background: url("../img/common/icon07.png") no-repeat center;
}
#main .summary .photoBox .slick-dots li:not(:last-of-type) {
    margin-right: 10px;
}
#main .summary .photoBox .slick-dots li button {
	display: none;
}
#main .summary .photoBox .en {
    padding-right: 8px;
    color: #377e38;
    font-size: 1.5rem;
    font-weight: 700;
    letter-spacing: 0.15em;
    text-align: right;
}
@media all and (min-width: 897px) {
    #main .news .tabList li a:hover {
        color: #377e38;
        border-bottom: 5px solid #377e38;
    }
    #main .news .tabBox dd a:hover {
        text-decoration: underline;
    }
}
@media all and (max-width: 896px) {
    .mainVisual {
        height: 350px;
    }
    .mainVisual .photoList {
        height: 350px;
    }
    .mainVisual .photoList li {
        height: 350px;
    }
    .mainVisual .subBox {
        padding: 120px 15px 0;
    }
    .mainVisual .subBox .han {
        color: #FFF;
        font-size: 2.4rem;
        font-weight: 900;
        letter-spacing: 0.13em;
    }
    .mainVisual .subBox .han .sml {
        margin-top: 12px;
        display: block;
        font-size: 1.3rem;
        font-weight: 700;
        line-height: 1.5;
    }
    #main .news {
        padding-top: 60px;
    }
    #main .news .tabList {
        margin: 0 auto;
        text-align: center;
    }
    #main .news .tabList li:not(:last-of-type) {
        margin-right: 4px;
    }
    #main .news .tabList li a {
        padding: 30px 2px;
        display: block;
        letter-spacing: 0.15em;
    }
    #main .news .tabBox {
        margin-bottom: 30px;
    }
    #main .news .tabBox dl {
        display: block;
    }
    #main .news .tabBox dt {
        padding: 26px 0 0;
        width: 100%;
        border: 0;
    }
    #main .news .tabBox dt ul {
        float: none;    
        display: inline-block;
    }
    #main .news .tabBox dd {
        padding: 15px 0 20px;
        width: 100%;
        font-size: 1.5rem;
    }
    #main .news .tabBox dd img {
        padding-top: 1px;
    }
    #main .vison {
        padding: 60px 0;
    }
    #main .vison .headLine01 {
        margin: 0 auto 30px 35px;
        width: auto;
    }
    #main .vison .photo {
        width: 100%;
    }
    #main .vison .visonList {
        margin: -40px 15px 0;
        width: auto;
        display: block;
    }
    #main .vison .visonList li {
        padding: 30px;
        width: auto;
    }
    #main .vison .visonList li:not(:last-of-type) {
        margin: 0 0 20px;
    }
    #main .vison .visonList li p {
        line-height: 1.85;
        letter-spacing: 0.15em;
    }
    #main .holdings {
        padding: 60px 0;
    }
    #main .holdings .content {
        padding: 0;
        max-width: inherit;
    }
    #main .holdings .headLine01 {
        margin: 0 auto 30px 15px;
        width: auto;
    }
    #main .holdings .headLine01 .en {
        margin-top: 10px;
        vertical-align: 0;
    }
    #main .holdings .holdList {
        margin-top: 0;
        display: flex;
        justify-content: space-between;
        
    }
    
    
    #main .holdings .holdList::after {
display: block;
content:"";
width: 32%;
}
    
    
    #main .holdings .holdList li .txt {
font-size:1rem;
}
    
    
    #main .holdings .holdList li {
        margin-top: 20px;
        width: 32%;
    }
    #main .holdings .holdList li a {
        padding: 20px 10px;
    }
    #main .holdings .holdList li .pho {
        margin-bottom: 15px;
        padding-bottom: 15px;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    #main .holdings .holdList li:not(:nth-of-type(4n)) {
        margin-right: 0;
    }
    #main .greeting {
        padding-top: 60px;
        margin-bottom: 40px;
    }
    #main .greeting .imgBox {
        margin: 0 15px;
    }
    #main .greeting .textBox {
        margin-bottom: 30px;
        width: 100%;
    }
    #main .greeting .textBox .subBox {
        margin: 0 auto;
        width: auto;
    }
    #main .greeting .textBox .subBox .name {
        font-size: 2rem;
    }
    #main .greeting .textBox .subBox p:not(:last-of-type) {
        margin-bottom: 10px;
    }
    #main .greeting .textBox .subBox .text {
        margin-bottom: 10px!important;
    }
    #main .greeting .photoBox {
        width: 100%;
    }
    #main .greeting .content {
        padding-top: 30px;
    }
    #main .greeting .headLine02 {
        margin-bottom: 0;
    }
    #main .greeting .greetingList {
        margin-top: 0;
        display: flex;
        justify-content: space-between;
    }
    #main .greeting .greetingList li {
        margin-top: 30px;
        width: 48.5%;
    }
    #main .greeting .greetingList li .pho {
        margin-bottom: 15px;
    }
    #main .greeting .greetingList li .pho img {
        width: 100%;
    }
    #main .summary {
        padding: 60px 0;
    }
    #main .summary .textBox {
        margin-bottom: 20px;
        width: 100%;
    }
    #main .summary .textBox .headLine01 {
        margin: 0 0 30px 15px;
    }
    #main .summary .textBox .subBox {
        padding: 8px 30px 14px;
        width: auto;
    }
    #main .summary .textBox .subBox th,
    #main .summary .textBox .subBox td {
        padding: 20px 0 0;
        width: 100%;
        display: block;
    }
    #main .summary .textBox .subBox th {
        border-bottom: 0;
    }
    #main .summary .textBox .subBox td {
        padding: 10px 0 15px;
        width: 100%;
    }
    #main .summary .photoList {
        width: 100%;
    }
    #main .summary .photoBox {
        width: 100%;
    }
    #main .summary .photoBox img {
        width: 100%;
    }
}
@media all and (max-width: 374px) {
    .mainVisual .subBox .han {
        font-size: 2.1rem;
    }
    .mainVisual .subBox .han .sml {
        font-size: 1.2rem;
    }
    #main .news .tabList li:not(:last-of-type) {
        margin-right: 3px;
    }
    #main .news .tabList li a {
        padding: 30px 2px;
        display: block;
        font-size: 1.2rem;
        letter-spacing: 0.15em;
    }
}
@media all and (-ms-high-contrast:none){
    #main .news .tabBox dd img {
        padding-top: 0;
    }
    #main .news .tabBox dt li {
        padding: 6px 2px 0;
    }
} 