* {
    box-sizing: border-box;
}
.flex-text {
    display: flex;
    align-items:end;
    justify-content: center;
}
.dis-block {
    display:block;
}
.bold {
    font-weight:bold;
}
.m-b40 {
    margin-bottom:40px!important;
}
.m-b80 {
    margin-bottom:80px!important;
}
.m-b160 {
    margin-bottom:160px!important;
}
.m-t100 {
    margin-top:100px!important;
}

.top-view img{
    margin-top:-140px;
}
.top-view img {
    width:100%;
    height:auto;
    object-fit: contain;
}
.main-title-wrapper  {
    text-align:center;
    font-size:calc(100vw / 28);
    margin:40px 0 20px;;
    letter-spacing: 0.2em;;
}
.main-title {
    border-bottom:2px solid #f9b81c;
    position:relative;
}
.main-title span,
.exhibition-inner p span,
.question-title span span,
.point-title span span {
    color:#f9b81c;
}
.main-title::before {
    content:"";
    position:absolute;
    top:100%;
    left:50%;
    transform: translateX(-50%);
    width:0;
    height:0;
    border-color:#f9b81c transparent transparent transparent;
    border-style:solid;
    border-width:20px 30px 0 30px;
}

.exhibition-title {
    margin-bottom:40px;
}
.exhibition-title span,
.question-awnser span,
.point-title span {
    display:inline-block;
    font-size:36px;
}

.exhibition-inner {
    max-width:800px;
    width:100%;
    text-align:center;
    margin:0 auto 100px;
    padding:0 20px;
}
.exhibition-inner p {
    font-size:18px;
    margin-bottom:40px;
}
.exhibition-inner .point-title span {
    font-size:43px!important;
}


.question-wrapper,
.result-wrapper {
    text-align:center;
    background-image: url(./images-ta/bg.jpg);
    padding:90px 0;
}
.question-title {
    font-size:26px;
    line-height:1.4em;
    margin-bottom:25px;
}
.question-title span {
    font-size:40px;
}

.flex-wrapper1 {
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    max-width:1000px;
    margin:0 auto;
    padding:20px;
    column-gap: 30px;
    row-gap: 30px;
}
.item {
    display:flex;
    align-items:center;
    justify-content: center;

    width:300px;
    height:100px;
    background: #fff;
    border-radius:4px;
    border:1px solid #ffd56f;
}
.item-text {
    font-size:18px;
}
.question-awnser {
    margin-top:40px;
    text-align:left
}

.point-title {
    margin:50px 0 5px;
}
.small-title {
    font-size:18px;
    margin-bottom:50px;
    text-align:center;
}

.item2 {
    width:300px;
    text-align:center;
}

.item2-text1 {
    font-size:20px;
    line-height:0.8em;
}

.result-wrapper .point-title {
    margin:0 0 5px;
}
.flex-wrapper2 {
    display:flex;
    flex-direction:column;
    max-width:1020px;
    margin:0 auto;
    padding:0 20px;
}
.flex-wrapper3 {
    display:flex;
    flex-wrap:wrap;
    justify-content:center;
    column-gap: 20px;
    row-gap: 20px;
}
.item3 {
    width:180px;
    height:88px;
    background: #fff;
}
.item3 img {
    width:100%;
    height:100%;
    object-fit: contain;
}
.item3:nth-child(7),
.item3:nth-child(14) {
    background: #333;
}
.flex-wrapper2 .small-title {
    font-size:26px;
    text-align:right;
    margin-top:20px;
}

.merit-title {
    width:300px;
    margin:70px auto 0;
}
.item2-text2 {
    font-size:50px;
    text-align:center;
    margin-bottom:70px;
    line-height:1.2em;
}

.flex-wrapper4 {
    display:flex;
    width:calc(100vw / 14 * 10);
    margin:30px auto;
}
.flex-wrapper4 .inner1 {
    width:65%;
    padding-right:calc(100vw / 30);
}
.flex-wrapper4 .inner1 .title {
    font-size:calc(100vw / 43);
    margin-bottom:1em;
}
.flex-wrapper4 .inner1 .text {
    font-size:calc(100vw / 54);
}
.flex-wrapper4 .inner2 {
    width:35%;
    border:1px solid #b5b4b4;
    box-shadow: 3px 3px 5px #808080;
}
.flex-wrapper4 .inner2 img {
    width:calc(100vw / 14 * 10 * 35 / 100);
    height:calc(100vw / 14 * 10 * 35 / 100 / 14 * 10);
    object-fit: cover;
}
.under-image-wrapper img{
    width:100%;
    height:auto;
    object-fit:contain;
}

.fixed-btn-wrapper {
    -webkit-transition:all 0.5s;
    -o-transition:all 0.5s;
    transition:all 0.5s;
    opacity:0;
    width:120px;
    height:120px;
    background-color:rgba(255, 255,255, 0.8);
    position:fixed;
    bottom:6vh;
    right:40px;
    display:flex;
    justify-content:center;
    align-items:center;
    z-index:101;
    text-align:center;
    line-height:80px;
    border-radius:50%;
    border:2px solid #cdcdcd;
}
.fixed-btn-wrapper a {
    color:inherit;
    font-size:16px;
}

/*アカウント開設ボタン*/
.fixed-btn-wrapper2 {
    -webkit-transition:all 0.5s;
    -o-transition:all 0.5s;
    transition:all 0.5s;
    opacity:1;
    background-color:#F28F1E;
    position:fixed;
    bottom:9vh;
    right: 180px;
    display:flex;
    justify-content:center;
    align-items:center;
    z-index:101;
    padding:8px 32px;
    border-radius:10px;
}

.fixed-btn-wrapper2:hover {
    opacity:0.8;
    color:#707070;
}
.fixed-btn-wrapper2 span {
    font-size:32px;
    color:#ffffff;
}

/*.fixed-btn-wrapperに付与させるボタン*/
.fixed-btn-wrapper.isActive {
    opacity:1;
    -webkit-transition:all 0.5s;
    -o-transition:all 0.5s;
    transition:all 0.5s;
}
.fixed-btn-wrapper2.isHide {
    opacity:0;
    pointer-events: none;
}
/*案内バナー*/
.banner-wrapper {
    margin:80px 20px;
}
.banner-image {
    display:block;
    max-width:800px;
    width:100%;
    margin:0 auto;
    padding:0 20px;
}
.banner-image img {
    width:100%;
    object-fit: contain;
}

/*fixedの影響で隠れてしまうコンテンツの高さ調整*/
/*.merit-title.link-height {
    padding-top:120px;
    margin-top: -80px;
}*/