/*----- reset -----*/

html,
body,
div,
span,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
a,
address,
em,
img,
strong,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
thead,
tbody,
tfoot,
tr,
th,
td {
    border: 0;
    font-family: inherit;
    font-size: 100%;
    margin: 0;
    outline: 0;
    padding: 0;
}

:focus {
    outline: 0;
}

ol,
ul {
    list-style: none;
}

table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
}
* {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-tap-highlight-color: transparent;
}
*,
*::before,
*::after {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
html {
    font-family: sans-serif;
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -ms-overflow-style: scrollbar;
    -webkit-tap-highlight-color: transparent;
}

@-ms-viewport {
    width: device-width;
}

article,
aside,
dialog,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section {
    display: block;
}

[tabindex="-1"]:focus {
    outline: 0 !important;
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible;
}

abbr[title],
abbr[data-original-title] {
    text-decoration: underline;
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
    cursor: help;
    border-bottom: 0;
}

address {
    margin-bottom: 1rem;
    font-style: normal;
    line-height: inherit;
}

blockquote {
    margin: 0 0 1rem;
}

dfn {
    font-style: italic;
}

b,
strong {
    font-weight: bolder;
}

sub,
sup {
    position: relative;
    font-size: 75%;
    line-height: 0;
    vertical-align: baseline;
}

a {
    color: #007bff;
    text-decoration: none;
    background-color: transparent;
    -webkit-text-decoration-skip: objects;
}

a:hover {
    color: #0056b3;
    text-decoration: underline;
}

a:not([href]):not([tabindex]) {
    color: inherit;
    text-decoration: none;
}

a:not([href]):not([tabindex]):hover,
a:not([href]):not([tabindex]):focus {
    color: inherit;
    text-decoration: none;
}

a:not([href]):not([tabindex]):focus {
    outline: 0;
}

img {
    vertical-align: middle;
    border-style: none;
}

svg:not(:root) {
    overflow: hidden;
}

table {
    border-collapse: collapse;
}

label {
    display: inline-block;
    margin-bottom: 5px;
}

button {
    border-radius: 0;
}

button:focus {
    outline: 1px dotted;
    outline: 5px auto -webkit-focus-ring-color;
}

input,
button,
select,
optgroup,
textarea {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
}

button,
input {
    overflow: visible;
}

button,
select {
    text-transform: none;
}

button,
html [type="button"],
[type="reset"],
[type="submit"] {
    -webkit-appearance: button;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
    padding: 0;
    border-style: none;
}

input[type="radio"],
input[type="checkbox"] {
    box-sizing: border-box;
    padding: 0;
}

input[type="date"],
input[type="time"],
input[type="datetime-local"],
input[type="month"] {
    -webkit-appearance: listbox;
}

textarea {
    overflow: auto;
    resize: vertical;
}

fieldset {
    min-width: 0;
    padding: 0;
    margin: 0;
    border: 0;
}

legend {
    display: block;
    width: 100%;
    max-width: 100%;
    padding: 0;
    margin-bottom: .5rem;
    font-size: 1.5rem;
    line-height: inherit;
    color: inherit;
    white-space: normal;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
    height: auto;
}

[type="search"] {
    outline-offset: -2px;
    -webkit-appearance: none;
}

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}

::-webkit-file-upload-button {
    font: inherit;
    -webkit-appearance: button;
}

hr {
    margin-top: 1rem;
    margin-bottom: 1rem;
    border: 0;
    border-top: 1px solid rgba(0, 0, 0, 0.1);
}

/* ==================================================
common
================================================== */
body {
    margin: 0;
    font-size: 100%;
    line-height: 1.5;
    color: #222222;
    background-color: #ffffff;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

img {
    width: auto\9;
    height: auto;
    max-width: 100%;
    vertical-align: middle;
    -ms-interpolation-mode: bicubic;
    -webkit-animation: smooth-image 1.2s;
    -moz-animation: smooth-image 1.2s;
    animation: smooth-image 1.2s;
}

/* ==================================================
skip
================================================== */

.skip {
    width: 1px;
    color: #000000;
    font-size: 0.1%;
    line-height: 0.1;
    background-color: #FFFFFF;
    position: absolute;
    left: -3000px;
    z-index: 9999;
}

a.skip {
    color: #003377;
    background-color: #FFFFFF;
    text-align: center;
    padding: 2px 0;
    top: auto;
}

a.skip:active {
    display: block;
    width: 99.99%;
    font-size: 100%;
    line-height: 1.6;
    top: 0;
    left: 0;
}

a.skip:focus {
    display: block;
    width: 99.99%;
    font-size: 100%;
    line-height: 1.6;
    top: 0;
    left: 0;
}
/*wrapper*/

#wrapper {
    height: auto;
    min-height: 100%;
    min-width: 1200px;
}
.container:before,
.container:after{
    content: "";
    display: table;
}
.container:after{
    clear: both;
}
.container{
    margin: 0 auto;
    width: 1200px;
}
/* ==================================================
SP Menu
================================================== */
#hnavi_s,
#sma_lmenu,
#sma_rmenu,
#sma_menu {
    display: none;
}
/*----- Header -----*/

#header {
    color: #fff;
    padding: 21px 0 15px;
}
.custom_application #header{
    background: #ffffff url(/shared/site_shinseisho/images/header/application_header.jpg) no-repeat left center;
    background-size: cover;
    -webkit-background-size: cover;
    -moz-background-size: cover;
}
#header .container{
    padding: 0;
}
#header #hlogo {
    float: left;
    position: relative;
    overflow: hidden;
    font-weight: bold;
    text-indent: -9999px;
    margin-bottom: 10px;
}
.custom_application #hlogo h1,
.custom_application #hlogo p,
.custom_application #hlogo a,
.custom_application #hlogo h1 span,
.custom_application #hlogo p span {
    display: block;
    width: 570px;
    height: 79px;
}
.custom_application #hlogo h1,
.custom_application #hlogo p{
    background: url(/shared/site_shinseisho/images/header/application_hlogo.png) no-repeat left top;
}
#hlogo h1 span,
#hlogo p span {
    position: relative;
    z-index: -1;
    overflow: hidden;
}
#header_menu{
    float: right;
    max-width: 440px;
    margin: 14px 0 0;
}
.custom_procedure #header_menu{
 margin-top: 20px;
}
#header_menu .hlinks{
    list-style: none;
}
#header_menu .hlinks li{
    float: left;
    margin: 0 15px 10px 0;
}
#header_menu .hlinks li:last-child{
    margin-right: 0;
}
#header_menu .hlinks li a{
    display: inline-block;
    text-decoration: none;
    font-size: 112.5%;
    color: #222222;
    background-color: #ffffff;
    border-radius: 5px;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border: 3px solid #ffffff;
    transition: 0.2s all ease-in-out;
    -webkit-transition: 0.2s all ease-in-out;
    -moz-transition: 0.2s all ease-in-out;
}
#header_menu li.change_font a {
    padding: 10px 13px 7px 40px;
    background: #ffffff url(/shared/site_shinseisho/images/header/channge_font_icon.png) no-repeat 9px center;
}
#header_menu li.okinawa_site a {
    padding: 6px 27px 8px 25px;
}
#header_menu li.okinawa_site img{
    max-width: 100%;
    height: auto;
}
#header_menu .hlinks li a:hover,
#header_menu .hlinks li a:focus,
#header_menu .hlinks li a:active{
    border: 3px solid #00529f;
}
/*----- Content -----*/
body.open_modal{
    overflow: hidden;
}
#main_content {
    width: 100%;
    background-color: #ffffff;
}
/*----- Applicarion Page -----*/
/*----- Style Btn -----*/
.application_btn_box{
    text-align: center;
}
.application_btn_box ul.application_btn_col2{
    padding: 0 156px;
}
.application_btn_box ul.application_btn_col2 li{
    width: 50%;
    float: left;
    padding: 0 17px;
}
.application_btn_box ul.application_btn_col3{
    margin: 0 -7px;
}
.application_btn_box ul.application_btn_col3 li{
    width: 33.3333333%;
    float: left;
    padding: 0 7px;
}
.application_btn_box a{
    display: block;
    text-decoration: none;
    font-weight: bold;
    text-align: center;
    font-size: 175%;
    padding: 16px 20px;
    box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -webkit-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -moz-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    transition: 0.2s all ease-in-out;
    -webkit-transition: 0.2s all ease-in-out;
    -moz-transition: 0.2s all ease-in-out;
}
.application_btn_box a.green_application_btn{
    color: #ffffff;
    background-color: #247e80;
    border: 3px solid #247e80;
}
.application_btn_box a.gray_application_btn{
    color: #222222;
    background-color: #f0f0f0;
    border: 3px solid #f0f0f0;
}
.application_btn_box a.big_btn{
    display: inline-block;
    width: 670px;
    font-size: 212.5%;
    padding: 23px 10px 19px;
    margin-left:55px;
}
.application_btn_box a.medium_btn {
    display: inline-block;
    width: 284px;
    font-size: 142%;
    padding: 15px 10px 11px;
}
.application_btn_box a.confirm_qrcode_btn {
    display: inline-block;
    width: 350px;
    font-size: 175%;
    padding: 21px 10px 13px;
}
.application_btn_box a.show_qrcode{
    background: #247e80 url(/shared/site_shinseisho/images/icon/qrcode_icon.jpg) no-repeat 8px center;
    padding: 18px 10px 16px 87px;
    text-align: left;
}
.application_btn_box a.form_print{
    background: #247e80 url(/shared/site_shinseisho/images/icon/print_icon.jpg) no-repeat 8px center;
    padding: 18px 10px 16px 87px;
    text-align: left;
}
.application_btn_box a.green_application_btn:hover,
.application_btn_box a.green_application_btn:focus,
.application_btn_box a.green_application_btn:active{
    color: #247e80;
    background-color: #ffffff;
}
.application_btn_box a.gray_application_btn:hover,
.application_btn_box a.gray_application_btn:focus,
.application_btn_box a.gray_application_btn:active{
    color: #555555;
    background-color: #ffffff;
}
/*----- Pankuzu -----*/
#pankuzu{
    margin: 14px 0 35px;
    font-size: 112.5%;
}
#pankuzu a{
    text-decoration: underline;
    color: inherit;
    background-color: transparent;
}
#pankuzu a:hover,
#pankuzu a:focus,
#pankuzu a:active{
    text-decoration: none;
}
/*----- Content -----*/

/* Applicarion Page 01 */
.about_application{
    overflow: hidden;
    margin: 75px 0 45px;
}
.custom_application h2{
    font-size: 200%;
}
.custom_application h3{
    font-size: 175%;
}
.use_system{
    padding: 0 30px 24px;
    margin: 0 0 70px;
    background-color: #e6fafa;
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
}
.use_system .use_system_ttl{
    text-align: center;
    padding: 31px 0 12px;
    border-bottom: 2px solid #96d2d3;
}
.use_system .use_system_cnt{
    padding: 38px 0 15px;
}
.use_system .use_system_sp{
    display: none;
}
.use_system .use_system_cnt img{
    width: 100%;
    height: auto;
}
/* Applicarion Page 02 */
.application_form{
    overflow: hidden;
    margin-bottom: 95px;
    border-radius: 20px;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
}
.form_ttl{
    font-size: 275%;
    font-weight: bold;
    padding: 14px 60px 6px;
    color: #ffffff;
    background-color: #247e80;
}
.form_ttl .close_btn p{
    display: inline-block;
}
.form_ttl .close_btn{
    float: right;
    font-size: 62.5%;
}
.form_ttl .close_btn a{
    position: relative;
    display: block;
    text-decoration: none;
    font-size: 112.5%;
    color: #222222;
    background-color: #ffffff;
    padding: 10px 30px 10px 34px;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    transition: 0.2s all ease-in-out;
    -webkit-transition: 0.2s all ease-in-out;
    -moz-transition: 0.2s all ease-in-out;
}
.form_ttl .close_btn a:before{
    content: "";
    width: 12px;
    height: 11px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 5px;
    margin-bottom: 4px;
    color: inherit;
    background: transparent url(/shared/site_shinseisho/images/icon/close_modal.png) no-repeat left center;
}
.form_ttl .close_btn a:hover,
.form_ttl .close_btn a:focus,
.form_ttl .close_btn a:active{
    background-color: #e3e3e3;
}
.form_cnt{
    overflow: hidden;
    padding: 37px 60px 60px;
    color: #222222;
    background-color: #d7f2f3;
}
.form_cnt_heading{
    text-align: center;
    padding: 0 0 13px;
    margin: 0 0 48px;
    border-bottom: 2px solid #96d2d3;
}
.form_cnt_main{
    margin: 0 0 60px;
}
.form_cnt_main .form_checkbox{
    overflow: hidden;
    margin: 0 0 27px;
}
.form_checkbox ul{
    list-style: none;
    margin: 0 -5px;
}
.form_checkbox ul li{
    width: 33.3333333%;
    float: left;
    padding: 0 5px;
    margin: 0 0 10px;
}
.form_checkbox ul li:nth-child(3n+1){
    clear: left;
}
.form_checkbox ul li:nth-child(3n){
    clear: right;
}
.form_checkbox .checkbox_item{
    color: #222222;
    background-color: #ffffff;
}
.checkbox_item .checkbox_item_input {
    display: none;
    opacity: 0;
}
.checkbox_item .checkbox_item_label {
    position: relative;
    padding: 14px 10px 10px 54px;
    margin-bottom: 0;
    font-weight: normal;
    display: block;
    cursor: pointer;
    font-size: 150%;
}
.checkbox_item .checkbox_item_label:before {
    position: absolute;
    top: 18px;
    left: 14px;
    transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    content: " ";
    display: inline-block;
    vertical-align: middle;
    width: 24px;
    height: 24px;
    border: 2px solid #98cbcc;
}
.checkbox_item .checkbox_item_label:after {
    position: absolute;
    top: 20px;
    left: 22px;
    transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    -moz-transform: rotate(45deg) scale(1.2);
    -webkit-transform: rotate(45deg) scale(1.2);
    transform: rotate(45deg) scale(1.2);
    content: " ";
    display: block;
    width: 8px;
    height: 16px;
    border: solid transparent;
    border-width: 0 3px 4px 0;
}
.checkbox_item .checkbox_item_input:checked + .checkbox_item_label:after {
    position: absolute;
    top: 20px;
    left: 22px;
    transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    content: " ";
    display: block;
    width: 8px;
    height: 16px;
    border: solid #c42f0c;
    border-width: 0 3px 4px 0;
    -moz-transform: rotate(45deg) scale(1);
    -webkit-transform: rotate(45deg) scale(1);
    transform: rotate(45deg) scale(1);
}
.checkbox_item .checkbox_item_label:hover,
.checkbox_item .checkbox_item_label:focus,
.checkbox_item .checkbox_item_label:active{
    background-color: #eefeff;
}
.application_table th,
.application_table td{
    padding: 10px 10px 12px;
    border: 2px solid #d7f2f3;
    font-size: 150%;
}
.application_table th{
    width: 235px;
    padding: 19px 11px 14px 30px;
    text-align: left;
    font-weight: 500;
    color: #222222;
    background-color: #aee6e7;
}
.application_table th .application_label{
    margin-bottom: 0;
    cursor: pointer;
}
.application_table td{
    color: #222222;
    background-color: #ffffff;
}
.form_field table td .search_address{
    display: inline-block;
    text-decoration: none;
    font-size: 83.3%;
    padding: 14px 17px 7px 42px;
    margin: 0 0 0 5px;
    color: #222222;
    background: #f0f0f0 url(/shared/site_shinseisho/images/icon/search_address_icon.png) no-repeat 9px center;
    border-radius: 10px;
    -webkit-border-radius: 6px;
    -moz-border-radius: 10px;
    box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -webkit-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -moz-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    transition: 0.2s all ease-in-out;
    -webkit-transition: 0.2s all ease-in-out;
    -moz-transition: 0.2s all ease-in-out;
}
.form_field table td .search_address:hover,
.form_field table td .search_address:focus,
.form_field table td .search_address:active{
    background-color: #d7f2f3;
}
.form_field table td input{
    width: 100%;
    border: 1px solid #98cbcc;
    padding: 7px 10px 5px;
}
.form_field table td input#in_name{
    width: 570px;
}
.form_field table td input#in_address_number{
    width: 150px;
}
.form_field table td input#in_address_by_search{
    border: 1px solid #cbcbcb;
}
.form_field table td input#in_address_by_search:disabled{
    background-color: #f0f0f0;
    border-color: #cbcbcb;
}
.form_field table td select.select_date_birth{
    border: 1px solid #98cbcc;
}
.select_box_date {
    position: relative;
    display: inline-block;
    cursor: pointer;
}
.select_box_date span{
    display: inline-block;
    margin: 0 3px 0 6px;
}
.select_box_date .select_date_birth {
    position: relative;
    z-index: 2;
    padding: 10px 40px 3px 10px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
    border: 1px solid #98cbcc;
    color: #222222;
    background: none;
}
.select_box_date .select_date_label {
    position: absolute;
    z-index: 1;
    padding: 10px 10px 3px 14px;
    margin: 0 5px 0 0;
    overflow: hidden;
    white-space: nowrap;
    text-align: center;
    color: #222222;
    border: 1px solid #98cbcc;
}
.select_box_date .select_date_label:after {
    margin: -4px 0 0 10px;
    display: inline-block;
    vertical-align: middle;
    width: 0;
    height: 0;
    border-left: 9px solid transparent;
    border-right: 9px solid transparent;
    border-top: 12px solid #247e80;
    content: '';
}
.form_field table td input.choose_sex_input{
    width: auto;
    opacity: 0;
    position: absolute;
}
.form_field table td .radio_sex{
    padding: 5px 0 0;
}
.radio_sex_item{
    display: inline-block;
    margin-right: 17px;
}
.radio_regular .choose_sex_input + .choose_sex_label{
    position: relative;
    padding-left: 40px;
    margin-bottom: 0;
    font-weight: normal;
    display: block;
    cursor: pointer;
    outline: 0;
}
.radio_regular .choose_sex_input + .choose_sex_label:before {
    content: '';
    position: absolute;
    top: 2px;
    left: 0;
    border-radius: 50%;
    -moz-border-radius: 50%;
    -webkit-border-radius: 50%;
    transition: all .3s ease;
    -moz-transition: all .3s ease;
    -webkit-transition: all .3s ease;
    border: 2px solid #98cbcc;
    display: inline-block;
    width: 30px;
    height: 30px;
    margin-right: 16px;
    vertical-align: middle;
    cursor: pointer;
    text-align: center;
}
.radio_regular .choose_sex_input:checked + .choose_sex_label::before {
    transition: all .3s ease;
    -moz-transition: all .3s ease;
    -webkit-transition: all .3s ease;
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    transform: scale(1);
    background-color: #c42f0c;
    box-shadow: inset 0 0 0 5px #ffffff;
}
/* Applicarion Page 03 */
.confirm_form .form_cnt{
    padding-top: 54px;
    padding-bottom: 72px;
}
.card_list{
    overflow: hidden;
    margin: 0 0 43px;
}
.card_list ul{
    list-style: none;
    margin: 0 -5px;
}
.card_list ul li {
    width: 33.3333333%;
    float: left;
    padding: 0 5px;
    margin: 0 0 10px;
}
.card_list ul li:nth-child(3n+1){
    clear: left;
}
.card_list ul li:nth-child(3n){
    clear: right;
}
.card_list ul li span{
    display: block;
    font-size: 150%;
    padding: 15px 16px 10px;
    color: #222222;
    background-color: #ffffff;
}
.confirm_table .application_table th{
    padding: 19px 11px 17px 30px;
}
.confirm_table .application_table td{
    padding: 21px 27px 10px;
}
/* Applicarion Page 04 */
.qrcode_form .form_cnt{
    padding-top: 60px;
    padding-bottom: 75px;
}
.qrcode_des{
    font-size: 150%;
    margin: 0 0 63px;
}
.qrcode_image{
    text-align: center;
    margin: 0 0 63px;
}
.qrcode_image a{
    display: inline-block;
}
.qrcode_image img{
    max-width: 100%;
    height: auto;
}
/* Applicarion Page 05 */
.confirm_qrcode .form_cnt{
    padding-top: 58px;
    padding-bottom: 82px;
}
.qrcode_cnt{
    font-size: 150%;
    margin: 0 0 90px;
}
.qrcode_cnt th,
.qrcode_cnt td{
    border: 1px solid #d7f2f3;
    vertical-align: top;
    text-align: left;
}
.qrcode_cnt .qrcode_cnt_ttl{
    width: 234px;
    padding: 20px 32px;
    font-weight: 500;
    background-color: #aee6e7;
}
.qrcode_cnt .qrcode_cnt_des{
    height: 360px;
    padding: 21px 30px 10px 25px;
    color: #222222;
    background-color: #ffffff;
}
.qrcode_cnt .qrcode_cnt_des textarea{
    height: 360px;
    width: 100%;
    padding: 21px 30px 10px 25px;
    color: #222222;
    background-color: #ffffff;
}

/* Modal*/
.modal_window{
    position: fixed;
    z-index: 99999;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    overflow: auto;
    -webkit-transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    -moz-transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    opacity: 0;
    visibility: hidden;
    overflow-y: auto;
}
.modal_window.show {
	opacity: 1;
	visibility: visible;
}
.modal_window .box_modal_window {
    position: relative;
    overflow: hidden;
    margin: 50px auto;
    max-width: 768px;
    top: 7%;
}
.box_modal_cnt{
    overflow: hidden;
    border-radius: 20px;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
}
.box_modal_heading{
    position: relative;
    padding: 14px 190px 6px 60px;
    color: #ffffff;
    background-color: #247e80;
}
.box_modal_heading .modal_heading_txt{
    font-size: 275%;
    font-weight: bold;
}
.box_modal_heading .modal_close{
    display: inline-block;
    position: absolute;
    right: 25px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
}
.box_modal_heading .modal_close a{
    position: relative;
    display: block;
    text-decoration: none;
    font-size: 112.5%;
    color: #222222;
    background-color: #ffffff;
    padding: 10px 30px 10px 34px;
    border-radius: 30px;
    -webkit-border-radius: 30px;
    -moz-border-radius: 30px;
    transition: 0.2s all ease-in-out;
    -webkit-transition: 0.2s all ease-in-out;
    -moz-transition: 0.2s all ease-in-out;
}
.box_modal_heading .modal_close a:before{
    content: "";
    width: 12px;
    height: 11px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 5px;
    margin-bottom: 4px;
    color: inherit;
    background: transparent url(/shared/site_shinseisho/images/icon/close_modal.png) no-repeat left center;
}
.box_modal_heading .modal_close a:hover,
.box_modal_heading .modal_close a:focus,
.box_modal_heading .modal_close a:active{
    background-color: #e3e3e3;
}
.box_modal_main{
    padding: 50px 60px 75px;
    color: #222222;
    background-color: #d7f2f3;
}
.box_modal_main .modal_cnt_ttl{
    font-size: 150%;
    text-align: center;
    margin: 0 0 37px;
}
.print_method{
    margin: 0 0 55px
}
.print_method li{
    padding: 17px 0 12px;
    border-top: 2px solid #b6e2e3;
}
.print_method li:last-child{
    border-bottom: 2px solid #b6e2e3;
}
.print_method .print_item{
    width: 100%;
    display: table;
    font-size: 150%;
}
.print_item .application_ttl{
    width: 155px;
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}
/* Modal 2*/
.modal_checkbox{
    position: fixed;
    z-index: 99999;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    overflow: auto;
    -webkit-transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    -moz-transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    opacity: 0;
    visibility: hidden;
    overflow-y: auto;
}
.modal_checkbox.show {
	opacity: 1;
	visibility: visible;
}
.modal_checkbox .box_modal_checkbox {
    position: relative;
    overflow: hidden;
    margin: 50px auto;
    max-width: 768px;
    top: 7%;
}
.select_application{
    margin: 0 0 57px;
}
.application_list li {
    padding: 15px 0 13px;
    border-top: 2px solid #b6e2e3;
}
.application_list li:last-child{
    border-bottom: 2px solid #b6e2e3;
}
.application_method{
    position: relative;
    color: #222222;
    background-color: #ffffff;
    padding: 13px 174px 10px 21px;
    box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -webkit-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -moz-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
}
.application_method .print_btn{
    position: absolute;
    display: inline-block;
    top: 50%;
    right: 10px;
    width: 150px;
    height: 45px;
    color: inherit;
    background: transparent url(/shared/site_shinseisho/images/print_btn.png) no-repeat left center;
    background-size: 100% auto;
    -webkit-background-size: 100% auto;
    -moz-background-size: 100% auto;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    transition: 0.2s all ease-in-out;
    -webkit-transition: 0.2s all ease-in-out;
    -moz-transition: 0.2s all ease-in-out;
}
.application_method .print_btn span{
    font-size: 87.5%;
    display: none;
}
.application_method .print_btn:hover,
.application_method .print_btn:focus,
.application_method .print_btn:active{
    background: transparent url(/shared/site_shinseisho/images/print_btn_hover.png) no-repeat left center;
    background-size: 100% auto;
    -webkit-background-size: 100% auto;
    -moz-background-size: 100% auto;
}
.box_modal_main .checkbox_item .checkbox_item_label{
    padding: 14px 10px 10px 51px;
    color: #222222;
    background-color: #ffffff;
    box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -webkit-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    -moz-box-shadow: 0 3px 0 0 rgba(203, 203, 203, 1);
    border-radius: 10px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
}
.box_modal_main .checkbox_item .checkbox_item_label:before{
    top: 18px;
    left: 20px;
}
.box_modal_main .checkbox_item .checkbox_item_label:after{
    top: 21px;
    left: 30px;
}
.box_modal_main .checkbox_item_input:checked + .checkbox_item_label:after{
    top: 21px;
    left: 28px;
}
.box_modal_main .checkbox_item .checkbox_item_label:hover,
.box_modal_main .checkbox_item .checkbox_item_label:focus,
.box_modal_main .checkbox_item .checkbox_item_label:active{
    background-color: #eefeff;
}
.box_modal_main .application_btn_box a.green_application_btn{
    width: 315px;
}

/*----- Footer -----*/
.pnavi{
    padding: 0 0 20px;
}
.pnavi .ptop {
    text-align: right;
}
.pnavi .ptop a {
    display: inline-block;
    text-indent: 100%;
    width: 218px;
    height: 46px;
    background: transparent url(/shared/site_shinseisho/images/footer/ptop.png) no-repeat left center;
    transition: 0.2s all ease-in-out;
    -webkit-transition: 0.2s all ease-in-out;
    -moz-transition: 0.2s all ease-in-out;
}
.pnavi .ptop a:hover,
.pnavi .ptop a:focus,
.pnavi .ptop a:active{
    background: transparent url(/shared/site_shinseisho/images/footer/ptop_hover.png) no-repeat left center;
    background-size: 100% auto;
    -webkit-background-size: 100% auto;
    -moz-background-size: 100% auto;
}
.pnavi .ptop span {
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
    text-indent: 100%;
    white-space: nowrap;
}
#footer {
    text-align: center;
    color: #222222;
    background-color: #ffffff;
    box-shadow: inset 0 10px 20px 0 rgba(125, 125, 125, 0.13);
    -webkit-box-shadow:inset 0 10px 20px 0 rgba(125, 125, 125, 0.13);
    -moz-box-shadow:inset 0 10px 20px 0 rgba(125, 125, 125, 0.13);
}

#footer .copyright {
    font-size: 112.5%;
    padding: 38px 0 30px;
}
/* ==================================================
clearfix
================================================== */
#header_menu .hlinks:after,
.form_checkbox ul:after,
.application_btn_box ul:after,
.card_list ul:after{
    content: '';
    display: table;
    clear: both;
}
/* ==================================================
change:font-size
================================================== */
/* small*/
.fsize_small {
	font-size: 75% !important;
}
/* big */
.fsize_big {
	font-size: 125% !important;
}
/* biggest(doubled)*/
.fsize_big2 {
	font-size: 175% !important;
}
/* change_color commons
================================================== */
.color_blue #wrapper,
.color_blue #wrapper *,
.color_yellow #wrapper,
.color_yellow #wrapper *,
.color_black #wrapper,
.color_black #wrapper * {
	background-image: none !important;
	list-style-image: none !important;
	box-shadow:none !important;
}
.color_blue #wrapper span,
.color_yellow #wrapper span,
.color_black #wrapper span {
	z-index: auto !important;
}
/* headding */
.color_blue #main_content h1,
.color_blue #main_content h2,
.color_blue #main_content h3,
.color_blue #main_content h4,
.color_blue #main_content h5,
.color_blue #main_content h6,
.color_yellow #main_content h1,
.color_yellow #main_content h2,
.color_yellow #main_content h3,
.color_yellow #main_content h4,
.color_yellow #main_content h5,
.color_yellow #main_content h6,
.color_black #main_content h1,
.color_black #main_content h2,
.color_black #main_content h3,
.color_black #main_content h4,
.color_black #main_content h5,
.color_black #main_content h6 {
	padding: 5px !important;
	border: none !important;
}
/* bg:blue
/* text:yellow
/* link:white
================================================== */
.color_blue #wrapper,
.color_blue #wrapper * {
	color: #FFFF00 !important;
	background-color: #00008B !important;
	border-color: #FFFF00 !important;
}
.color_blue #wrapper a,
.color_blue #wrapper a span,
.color_blue #wrapper button,
.color_blue #wrapper .used_bg_img a span,
.color_blue #wrapper input[type="submit"],
.color_blue #wrapper input[type="button"],
.color_blue #wrapper input[type="reset"] {
	color: #FFFFFF !important;
	background-color: transparent !important;
}
.color_blue #main_content h1 {
	border: 3px solid yellow !important;
}
.color_blue #main_content h2 {
	border-bottom: 1px solid yellow !important;
	border-left: 3px solid yellow !important;
}
.color_blue #main_content h3 {
	border-left: 3px solid yellow !important;
}
/* bg:yellow
/* text:black
/* link:blue
================================================== */
.color_yellow #wrapper,
.color_yellow #wrapper * {
	color: #000000 !important;
	background-color: #FFFF00 !important;
	border-color: #000000 !important;
}

.color_yellow #wrapper a,
.color_yellow #wrapper a span,
.color_yellow #wrapper button,
.color_yellow #wrapper .used_bg_img a span,
.color_yellow #wrapper input[type="submit"],
.color_yellow #wrapper input[type="button"],
.color_yellow #wrapper input[type="reset"] {
	color: #0000FF !important;
	background-color: transparent !important;
}
.color_yellow #main_content h1 {
	border: 3px solid black !important;
}
.color_yellow #main_content h2 {
	border-bottom: 1px solid black !important;
	border-left: 3px solid black !important;
}
.color_yellow #main_content h3 {
	border-left: 3px solid black !important;
}
/* bg:black
/* text:yellow
/* link:white
================================================== */
.color_black #wrapper,
.color_black #wrapper * {
	color: #FFFF00 !important;
	background-color: #000000 !important;
	border-color: #FFFF00 !important;
}
.color_black #wrapper a,
.color_black #wrapper a span,
.color_black #wrapper button,
.color_black #wrapper .used_bg_img a span,
.color_black #wrapper input[type="submit"],
.color_black #wrapper input[type="button"],
.color_black #wrapper input[type="reset"] {
	color: #FFFFFF !important;
	background-color: transparent !important;
}
.color_black #main_content h1 {
	border: 3px solid yellow !important;
}
.color_black #main_content h2 {
	border-left: 3px solid yellow !important;
	border-bottom: 1px solid yellow !important;
}
.color_black #main_content h3 {
	border-left: 3px solid yellow !important;
}
/* ==================================================
accessibility style change:color
================================================== */
.color_blue #hlogo h1,
.color_blue #hlogo p,
.color_yellow #hlogo h1,
.color_yellow #hlogo p,
.color_black #hlogo h1,
.color_black #hlogo p{
	font-size: 1.5rem;
}
.color_blue #hlogo span,
.color_yellow #hlogo span,
.color_black #hlogo span {
	overflow: visible !important;
	text-indent:0 !important;
	white-space: normal !important;
}
.color_blue .pnavi .ptop a span,
.color_yellow .pnavi .ptop a span,
.color_black .pnavi .ptop a span {
    overflow: visible !important;
    text-indent: 0 !important;
    white-space: normal !important;
    font-size: 1.2rem;
}
.color_yellow #wrapper input,
.color_yellow #wrapper textarea,
.color_yellow #wrapper textarea,
.color_yellow #wrapper select,
.color_yellow #wrapper .select_counter_label{
    border: 1px solid #000000 !important;
}

.color_blue #wrapper input,
.color_blue #wrapper textarea,
.color_blue #wrapper textarea,
.color_blue #wrapper select,
.color_blue #wrapper .select_counter_label,
.color_black #wrapper input,
.color_black #wrapper textarea,
.color_black #wrapper textarea,
.color_black #wrapper select,
.color_black #wrapper .select_counter_label{
    border: 1px solid #FFFF00 !important;
}
/* ==================================================
accessibility style change:fsize
================================================== */
.fsize_big2 #wrapper .new_reservation .reservation_table .calendar_box{
    font-size: 1rem !important;
}
/* ==================================================
accessibility style change:color
================================================== */
.color_blue .application_method .print_btn span,
.color_black .application_method .print_btn span,
.color_yellow .application_method .print_btn span{
    display: block !important;
}
/* ==================================================
文字サイズ色合い変更
================================================== */
#tmp_contents {
    margin: 30px 0 0;
    padding: 0 0 40px;
}
#tmp_contents h1 {
    font-size: 211%;
    line-height: 1.3;
    border-bottom: 2px solid #000000;
    margin: 0 0 30px;
    padding: 0 0 20px;
    clear: both;
}
#tmp_contents h2,
#tmp_contents h3,
#tmp_contents h4,
#tmp_contents h5,
#tmp_contents h6 {
    margin: 1.5em 0 0.8em;
    clear: both;
}
#tmp_contents p{
    margin: 0 0 0.8em;
}
#tmp_contents h2{
    font-size: 155.6%;
    padding: 18px 15px 22px;
    background-color: #d7f2f3;
    line-height: 1.3;
}
#tmp_contents h3{
    font-size: 144.4%;
    border-bottom: 1px solid #e4ebf0;
    padding-bottom: 10px;
    line-height: 1.3;
}
#tmp_contents div.outline{
    color: inherit;
    background-color: #FFFFFF;
    padding: 18px 18px 3px;
    margin: 0 0 40px;
    border: 2px solid #000000;
    clear: both;
}
#tmp_contents #tmp_fsize table,
#tmp_contents #tmp_color table {
	color: inherit;
	border-collapse: collapse;
	border-spacing: 0;
	word-break: break-all;
	vertical-align: top;
}
#tmp_contents #tmp_fsize table td,
#tmp_contents #tmp_color table td{
	width: 50%;
	padding: 5px 8px;
	border: 1px solid #b0b0b0;
	font-size: 114.2%;
	vertical-align: top;
}
#tmp_contents #tmp_fsize table.datatable tr:nth-child(2n) td,
#tmp_contents #tmp_fsize table.datatable tr:nth-child(2n) th,
#tmp_contents #tmp_color table.datatable tr:nth-child(2n) td,
#tmp_contents #tmp_color table.datatable tr:nth-child(2n) th {
	background-color:#ffffff;
}
#tmp_contents #tmp_fsize .datatable a,
#tmp_contents #tmp_color .datatable a {
	text-decoration:none;
	display:block;
	color:#000000;
}
#tmp_contents #tmp_fsize table td a:hover,
#tmp_contents #tmp_color table td a:hover {
	opacity:0.6;
}
#tmp_contents #tmp_fsize .fsize_small .cs_heading {
	font-size: 1.5825rem;
}
#tmp_contents #tmp_fsize .fsize_small .cs_outline {
	font-size: 0.75rem;
}
#tmp_contents #tmp_fsize .cs_default .cs_heading {
	font-size: 2.38rem;
}
#tmp_contents #tmp_fsize .cs_default .cs_outline {
	font-size: 1.125rem;
}
#tmp_contents #tmp_fsize .fsize_big .cs_heading {
	font-size: 2.64rem;
}
#tmp_contents #tmp_fsize .fsize_big .cs_outline {
	font-size: 1.25rem;
}
#tmp_contents #tmp_fsize .fsize_big2 .cs_heading {
	font-size: 3.693rem;
}
#tmp_contents #tmp_fsize .fsize_big2 .cs_outline {
	font-size: 1.75rem;
}
#tmp_contents #tmp_color .cs_heading {
	font-size: 2.38rem;
}
#tmp_contents #tmp_color .cs_outline {
	font-size: 1.125rem;
}
#tmp_contents #tmp_fsize .cs_heading,
#tmp_contents #tmp_color .cs_heading {
	display:block;
	margin: 0 0 30px;
	font-weight: bold;
	padding:10px 0 16px;
	border-bottom:2px solid #000000;
	clear:both; /* Do not edit */
}
#tmp_contents #tmp_fsize .cs_outline,
#tmp_contents #tmp_color .cs_outline {
	display:block;
	margin:0 0 40px; /* Do not edit */
	border:2px solid #222222;
	background-color:#ffffff;
	color: #222222;
	padding:15px;
	clear:both; /* Do not edit */
}
#tmp_contents #tmp_color .color_yellow .cs_heading,
#tmp_contents #tmp_color .color_black .cs_heading,
#tmp_contents #tmp_color .color_blue .cs_heading {
	background-image: none;
}
#tmp_contents .cs_box.color_blue,
#tmp_contents .cs_box.color_blue .cs_heading,
#tmp_contents .cs_box.color_blue .cs_outline {
	display: block;
	color: #FFFF00 !important;
	background-color: #00008B !important;
	border-color: #FFFF00 !important;
	background-image: none;
}
#tmp_contents .cs_box.color_yellow,
#tmp_contents .cs_box.color_yellow .cs_heading,
#tmp_contents .cs_box.color_yellow .cs_outline {
	display: block;
	color:#000000 !important;
	background-color:#FFFF00 !important;
	border-color:#000000 !important;
	background-image: none;
}
#tmp_contents .cs_box.color_black,
#tmp_contents .cs_box.color_black .cs_heading,
#tmp_contents .cs_box.color_black .cs_outline {
	display: block;
	color:#FFFF00 !important;
	background-color:#000000 !important;
	border-color:#FFFF00 !important;
	background-image: none;
}
#tmp_contents .cs_box.color_blue .cs_heading,
.color_blue #tmp_contents #tmp_fsize .cs_heading {
	border: 3px solid yellow !important;
}
#tmp_contents .cs_box.color_yellow .cs_heading,
.color_yellow #tmp_contents #tmp_fsize .cs_heading {
	border: 3px solid black !important;
}
#tmp_contents .cs_box.color_black .cs_heading,
.color_black #tmp_contents #tmp_fsize .cs_heading {
	border: 3px solid yellow !important;
}
#tmp_contents .cs_box.color_default,
#tmp_contents .cs_box.color_default .cs_heading,
#tmp_contents .cs_box.color_default .cs_outline {
	display: block;
}
#tmp_contents .cs_box.color_default {
	background-color:#FFFFFF !important;
	border-bottom-color:#000000 !important;
}
.color_blue #tmp_contents #tmp_color .cs_box.color_default .cs_heading,
.color_yellow #tmp_contents #tmp_color .cs_box.color_default .cs_heading,
.color_black #tmp_contents #tmp_color .cs_box.color_default .cs_heading {
	border-bottom-color:#000000 !important;
}
#tmp_contents .cs_box.color_default .cs_heading {
	color: #000000 !important;
	background-color:#ffffff !important;
}
#tmp_contents .cs_box.color_default .cs_outline {
	color:#222222 !important;
	background-color:#ffffff !important;
	border-color:#222222 !important;
}
@media all and (-ms-high-contrast:none){
    #tmp_tabmenu .menu_item .menu_item_link:after,
    #tmp_employment .employment_item:after{
        right: 3px;
    }
}
@-moz-document url-prefix() {
    #tmp_tabmenu .menu_item .menu_item_link:after,
    #tmp_employment .employment_item:after{
        right: 3px;
    }
}
/*smooth-image*/
@-webkit-keyframes smooth-image {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@-moz-keyframes smooth-image {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@keyframes smooth-image {
    0% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}
.open_modal .modal_window,
.open_modal .modal_checkbox {
    overflow-x: hidden;
    overflow-y: auto;
}
/* ==================================================
print
================================================== */
@media print {
body {
    background:#FFFFFF !important;
}
#wrapper {
    width:100% !important;
}
#header,
.custom_application #header,
.custom_counter #header {
    margin-bottom:10px !important;
    padding-bottom:10px !important;
    color:#000000 !important;
    background:#FFFFFF !important;
    border-bottom:1px solid #000000 !important;
}
#footer {
    margin-top:10px !important;
    padding-top:10px !important;
    color:#000000 !important;
    background:#FFFFFF !important;
    border-top:1px solid #000000 !important;
}
.pnavi,
#header_menu,
#pankuzu {
    display:none !important;
}
#tmp_hlogo p{
    text-indent: inherit;
}
#hlogo p span,
.custom_counter #hlogo h1 span,
.custom_counter #hlogo p span{
    z-index: 1;
}
.copyright {
    text-align:center !important;
}
/* for Firefox */
#main_content:after{
    content:"."; /* Do not edit */
    height:1px; /* Do not edit */

}
}

/* ==================================================
SYSTEM
================================================== */
.help {
	display:none;
}