/*/////common/////*/

html {
    position: relative;
    text-size-adjust: 100%;
}

.px30 {
    font-size: 2.4rem;
}


.tableflx {
    display: block;
    margin: 5px 0px 15px;
}

.tableflx:last-of-type {
    margin-bottom: 0;
}

.tableflx .tableflxTtl {
    display: block;
    width: 120px;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-weight: normal;
    text-align: left;
    box-sizing: border-box;
    font-size: 1.6rem;
}

.tableflx .tableflxCnt {
    flex-grow: 1;
    width: auto;
    padding: 10px;
    max-width: 100%;
    box-sizing: border-box;
}

.tableflxCntTr {
    display: block;
}

.tableflxCntTh {
    width: 100%;
}

.tableflx .tableflxCnt ul {
    margin: 10px 0 0;
    padding: 0 1em;
}

.tableflx .tableflxCnt ul li {
    margin-bottom: 10px;
}

a.cmnBtn {
    max-width: 300px;
    margin: auto;
    font-size: 1.8rem;
    text-align: center;
    transition: none;
    transform: none;
    box-sizing: border-box;
}





/*/////header/////*/

header {
    background: #fff;
    height: auto;
    box-shadow: 0 -1px 10px #ccc;
}

#svgBg {
    display: none;
}

header ul {
    display: flex;
    width: 100%;
    height: auto;
    justify-content: space-between;
    align-items: center;
    padding: 10px;
    box-sizing: border-box;
}

.hdlogo {
    flex-basis: 80%;
    margin-top: 0;
    order: 1;
    text-align: left;
}

.hdlogo h1 {
    margin: 0;
    padding: 0;
    line-height: 0;
}

.hdlogo img {
    width: auto;
    height: 100%;
}

.spmenu {
    display: list-item;
    justify-self: flex-end;
    flex-basis: 10%;
    order: 2;
    cursor: pointer;
}

.hdyoukou,
.hdshinsei,
.hdtopics,
.hdcontact {
    display: none;
}

header ul li i {
    font-size: 1.6rem;
    margin-bottom: 0;
}

.aftxt {
    font-size: 1.0rem;
}


header ul.sec {
    background: #fff;
    border-bottom: none;
    height: auto;
    transition: .3s;
}

header ul.sec li i {
    font-size: 1.6rem;
    margin-bottom: 0px;
    transition: .3s;
}

header ul li.hdlogo.sec {
    margin-top: 0px;
    transition: .3s;
}

header ul li.hdconnect.spnone {
    display: none;
}


/*//////leadArea//////*/

#leadArea {
    position: relative;
    background-position: center top;
    background-attachment: scroll;
    background-size: cover;
    width: 100%;
    min-width: initial;
    padding: 80px 15px 0;
    margin: 0;
    box-sizing: border-box;
}

#leadArea::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.5);
}

#leadArea .inner {
    position: relative;
    width: 100%;
    padding-bottom: 5px;
    z-index: 10;
}

#leadArea h2 {
    display: none;
}

#leadArea h1 {
    margin: 0 0 20px;
    font-size: 2.4rem;
    color: #333333;
    text-shadow: none;
}

#leadArea p {
    margin-left: 0px;
    font-size: 1.6rem;
    color: #333333;
    text-shadow: none;
}

#leadArea p br {
    display: none;
}

#leadArea ul {
    flex-wrap: wrap;
    width: 100%;
    margin-top: 20px;
    box-sizing: border-box;
}

#leadArea ul li {
    width: 320px;
    margin: 0 auto 15px;
}

a.leadBtn {
    font-size: 2.0rem;
    text-align: center;
    background: rgba(210, 206, 199, 1);
    box-shadow: 0 0 5px #999;
}



/*//////news//////*/

#news {
    width: 100%;
    margin: auto;
    padding: 20px;
    font-size: 1.6rem;
    box-sizing: border-box;
}

#newsList li {
    list-style: none;
    display: block;
    margin-bottom: 15px;
}


/*//////outline//////*/

#outline {
    background-position: center center;
    background-size: cover;
    background-attachment: scroll;
    width: 100%;
    min-width: initial;
    padding: 20px;
    box-sizing: border-box;
}

#outline .inner {
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
}

#outline h1 {
    margin-bottom: 20px;
}

.outlinecnt {
    margin: 0 0 15px;
}

.outlinecnt h2 {
    font-size: 1.8rem;
    margin-bottom: 10px;
}

.outlinecnt p {
    margin: 0 0 15px;
}

.outlinecnt .tableflx {
    display: block;
    margin: 5px 0px 15px;
}

.outlinecnt .tableflx:last-of-type {
    margin-bottom: 0;
}

.outlinecnt .tableflx .tableflxTtl {
    display: block;
    width: 100%;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-weight: normal;
    text-align: left;
    box-sizing: border-box;
    font-size: 1.6rem;
}

.outlinecnt .tableflx .tableflxCnt {
    flex-grow: 1;
    padding: 10px;
}

.outlinecnt .tableflx .tableflxCnt ul {
    margin: 10px 0 0;
    padding: 0 1em;
}

.outlinecnt .tableflx .tableflxCnt ul li {
    margin-bottom: 10px;
}

.fileArea {
    display: block;
    margin: 5px 0 20px;
}

.fileLeft {
    margin-right: 0px;
    margin-bottom: 20px;
}

.fileRight ul {
    padding-left: 1.5em;
}

.fileRight ul li {
    margin-bottom: 15px;
}



/*//////oubo//////*/

#oubo {
    min-width: initial;
}

#oubo .inner {
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
}

#oubo ul {
    display: block;
    justify-content: space-between;
    margin-top: 20px;
    margin-bottom: -20px;
    padding: 0;
}

#oubo ul li {
    margin-bottom: 15px;
}


/*//////about//////*/

#about {
    background-position: center bottom;
    background-attachment: scroll;
    background-size: cover;
    width: 100%;
    min-width: initial;
    padding: 20px;
    box-sizing: border-box;
}


#about .inner {
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
}

#about h1 {
    margin-bottom: 20px;
}

#about figure {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-flow: column;
}

#about figcaption {
    margin-top: 15px;
    font-size: 1.4rem;
}

#about p {
    margin: 20px 0 25px;
}


/*//////footer//////*/

footer {
    border-top: solid 3px #95CF82;
    min-width: initial;
}

#ftnav {
    display: none;
    position: fixed;
    background: rgba(255, 255, 255, 0.6);
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    padding: 30px 0 50px;
    transform: translate3d(0, 0, 110px);
    z-index: 1100;
    box-sizing: border-box;
}

#ftnav ul {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 80%;
    height: 90%;
    margin: auto;
}

#ftnav ul li {
    width: 100%;
}

#ftnav ul li.menuclose {
    display: block;
    font-size: 1.8rem;
    text-align: center;
    cursor: pointer;
}

#ftnav ul li a {
    display: block;
    background: #A3D2E0;
    padding: 1em 2.5em;
    border: solid 2px #5DA2B8;
    border-radius: 3px;
    color: #fff;
    text-decoration: none;
    text-align: center;
    box-sizing: border-box;
}

#ftnav ul li .aftxt {
    font-size: 1.8rem;
}

#ftnav ul li a::after {
    content: none;
}

@media(max-height:480px) {
    #ftnav ul li a {
        padding: 10px;
    }
    #ftnav ul li .aftxt {
        font-size: 1.6rem;
    }
}

#ftinfo {
    padding-bottom: 10px;
}

#ftinfo .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-direction: column;
    max-width: 900px;
    margin: auto;
    padding: 0 20px;
}

.okadaiInfo {
    display: block;
    width: 100%;
}

.okadaiInfo figure {
    display: block;
    width: 100%;
    flex-wrap: wrap;
}

.okadaiInfo figure img {
    width: 100%;
    margin-bottom: 15px;
}

.okadaiInfo figure figcaption {
    font-size: 1.6rem;
    font-weight: bold;
}

.okadaiInfo figure figcaption br.spnone {
    display: none;
}

.okadaiInfo figure figcaption span {
    display: inline-block;
    margin-left: 10px;
}

.okadaiInfo p {
    font-size: 1.4rem;
    margin: 10px 0 10px 8px;
}

.spzip {
    display: block;
}

.kanrenLink ul {
    flex-direction: column;
    width: 100%;
    margin-bottom: 25px;
    padding: 0;
    box-sizing: border-box;
}

.kanrenLink ul li,
.kanrenLink ul li:first-of-type,
.kanrenLink ul li:last-of-type {
    width: 100%;
    margin: 0 0 15px;
}

.kanrenLink ul li:last-of-type {
    margin-bottom: 0;
}

.kanrenLink ul li img {
    max-height: 65px;
}

.kanrenLink ul li:last-of-type {
    width: 100%;
}





/*//////youkou//////*/

.youkou #outline {
    padding-top: 80px;
}

.youkou #outline h1 {
    margin-bottom: 20px;
    font-size: 2.4rem;
}

.youkou #outline .outlinecnt h2 {
    font-size: 1.8rem;
    margin-bottom: 30px;
}

.youkou #outline .outlinecnt h3 {
    margin: 0 0 10px;
}

#download .inner {
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
}

.downloadInner p.cap {
    margin: 0;
}


.youkou ul.btnarea {
    display: block;
    margin-top: 35px;
}

.youkou ul.btnarea li {
    margin-bottom: 15px;
}


/*//////touroku//////*/

#touroku2,
#touroku {
    padding: 80px 20px 25px;
}

#touroku2 .inner,
#touroku .inner {
    width: 100%;
    padding: 0;
    box-sizing: border-box;
}

#touroku2 .inner p,
#touroku .inner p {
    width: 100%;
    margin: 25px 0;
}

.rdArea {
    padding: 15px;
}

.formcnt {
    margin-bottom: 20px;
}

.cklist li {
    display: block;
}

.fileboxLeft {
    width: 55%;
    font-size: 1.4rem;
}

.fileboxRight {
    width: 45%;
    padding: 15px 5px;
    font-size: 1.4rem;
}

.fileboxRight span {
    display: none;
}

.singleBtn {
    margin-bottom: 0;
}


/*form*/

input.btn,
button {
    width: 100%;
    max-width: 300px;
    margin: auto;
    font-size: 1.8rem;
    text-align: center;
    transition: none;
    transform: none;
    box-sizing: border-box;
}



/*/////confirm-t/////*/

.multiBtn {
    display: flex;
    justify-content: space-between;
    box-sizing: border-box;
}

.multiBtn li {
    width: 45%;
}

.multiBtn input.btn,
.multiBtn button {
    padding: 10px 15px;
    font-size: 1.6rem;
}


/*//////contact//////*/

#contact {
    padding: 80px 20px 25px;
}

#contact .inner {
    width: 100%;
    padding: 0;
    box-sizing: border-box;
}

#contact .inner p,
.contacttop {
    width: 100%;
    margin: 25px 0;
}


/*//////news//////*/

body.news #news {
    padding: 80px 20px 25px;
}

span.moreBtn {
    width: 100%;
    max-width: 300px;
    margin: auto;
    box-sizing: border-box;
}

/*//////2次募集//////*/
.second_boshu {
    margin: 0;
    line-height: 1.8;
}

#outline .second_boshu h1 {
    display: block;
}

#outline .second_boshu h1 span {
    display: inline-block;
}

#outline .second_boshu h1 span.new {
    margin-right: 10px;
}

.second_boshu dl.boshu_dl {
    display: block;
    flex-wrap: wrap;
    margin-bottom: 1.5em;
    line-height: 1.5;
}

.second_boshu dl.boshu_dl dt {
    margin-bottom: 0.3em;
}

.second_boshu dl.boshu_dl dd {
    flex-basis: 86%;
    margin-bottom: 1.5em;
}

.second_boshu dl.boshu_dl dt::after {
    display: none;
}

.jimukyoku {
    display: block;
    width: 100%;
    padding: 20px;
    box-sizing: border-box;
}

.jimukyoku_left {
    margin-bottom: 0.5em;
    padding: 0;
    font-size: 18px;
    font-weight: bold;
}

.jimukyoku_right {
    padding: 0;
}


#boshu_main.finish .finish_text br,
body.finish #outline .finish_text br,
body.touroku.finish #touroku .finish_text br {
    display: inline;
}