﻿@charset "utf-8";

/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */

html {
	font-family: “メイリオ”, Arial, Roboto, “Droid Sans”, “游ゴシック”, YuGothic, “ヒラギノ角ゴ ProN W3”, “Hiragino Kaku Gothic ProN”, Meiryo, sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  /* 2025/11/11 :垣田：タスク一覧：No17 Start */
  touch-action: pan-y;
  -ms-touch-action: pan-y;
  /* 2025/11/11 :垣田：タスク一覧：No17 End */
}

body {
  margin: 0;
}

/* HTML5 display definitions
   ========================================================================== */

article,aside,details,figcaption,figure,footer,header,hgroup,main,menu,nav,section,summary {
  display: block;
}


/* Links
   ========================================================================== */

a {
  background-color: transparent;
}

a:active,
a:hover {
  outline: 0;
}

a.blank_link::after {
  background: url(../img/blank_icon.png) no-repeat top/contain;
  content: "";
  margin: 0 0.3em -0.1em 0.1em;
  display: inline-block;
  height: 0.8em;
  width: 0.8em;
}

/* Text-level semantics
   ========================================================================== */

b,strong {
  font-weight: bold;
}

/* Embedded content
   ========================================================================== */

img {
  border: 0;
	vertical-align:baseline;
	max-width:100%;
}

.onegazoulimit {
  width : 640px;
  height : 480px;
}

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

/* Forms
   ========================================================================== */

button,input,optgroup,select,textarea {
  color: inherit;
  font: inherit;
  margin: 0;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: none;
  cursor: pointer;
}

button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}

input {
  line-height: normal;
}
input::-ms-clear{
	display: none;
	margin-left: -4rem;
}

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

input[type="text"]::-webkit-inner-spin-button,
input[type="text"]::-webkit-outer-spin-button {
  height: auto;
}
input:focus,
select:focus{
	outline: 0;
}
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 0.125rem;
  padding: 0.35em 0.625em 0.75em;
}

textarea {
  overflow: auto;
}

select::-ms-expand{/* ie */
  display:none;
}

/* Tables
   ========================================================================== */

table {
  border-collapse: collapse;
  border-spacing: 0;
}

td,
th {
  padding: 0;
}

/*! normalize end */


/*
00 基礎要素
*/
html,body,article,section,div,p,dl,ol,ul,dt,dd,li,span,small,h1,h2,h3,h4,pre,strong{
	margin:0;
}
html{
	height:100%;
	font-size:100%;
}
body {
	background: #fff;
	height:100%;
	color: #333;
}
body p {
	font-size: 16px;
}
#wrapper {
	position: relative;
	min-height: 100%;
	margin: 0;
	overflow: hidden;
}
h1,h2,h3,p,dd,li,span,small,pre,input{
	/*word-break:break-all;*/
}

label{
    font-size: 13pt;
}

a, a:visited{
	text-decoration:underline;
	color: #09F;
}

table{
	width:100%;
	border-collapse: collapse;
	border-right:1px solid #CCCCCC;
	border-bottom:1px solid #CCCCCC;
}
table th{
	background-color:#F5F5F5;
	padding: .25rem 1.5rem;
    font-size: 13pt;
}
table thead th{
	background-color:#fff2f2;
	padding: .25rem 1.5rem;
}
th , td{
	border:1px solid #CCCCCC;
	border-width: 1px 0 0 1px;
	padding:.25rem;
	background-color:#fff;
	vertical-align: middle;
}
th.blank , td.blank{
	background: none;
	border: none;
}
tbody.item_group tr:first-of-type th {
	border-bottom:none;
}
tbody.item_group tr:not(:first-of-type) th {
	border-top:none;
}

.imgNum_table{
	margin: 1em 0;
	border-right: 3px solid #0062c4;
}
.imgNum_table th,
.imgNum_table td{
	border-width: 3px 0px 3px 0px ;
	border-color: #0062c4;
	padding: .5rem;
}
.imgNum_table th{
	background-color: #0062c4;
	color: #fff;
}
.imgNum_table td{
	border-left: none;
}
.imgNum_table td.num{
	letter-spacing: .125em;
    font-size: 13pt;
}

/* cell-width */
.cw10{width: 10% !important}
.cw20{width: 20% !important}
.cw30{width: 30% !important}
.cw40{width: 40% !important}
.cw50{width: 50% !important}

/* 標準文字サイズ */
h1{
	font-size:1.5rem;
}
h2{
	font-size:1.25rem;
}
h3{
	font-size:1.125rem;
}

li{
	font-size:13pt;
}

.txt_black{
	color:#333 !important;
}

section.processing {
	border-bottom: 2px solid #df0023;
}

/* margin */
.mt1{
	margin-top:1rem !important;
}
.mt2{
	margin-top:2rem !important;
}
.mt3{
	margin-top:3rem !important;
}
.mb05{
	margin-bottom: 0.5rem;
}

/* text align */
.alignL{
	text-align:left !important;
}
.alignC{
	text-align:center !important;
}
.alignR{
	text-align:right !important;
}
span.alignR{
	display:block;
}

/* note */
span.note{
	font-size: .875rem;
	color: #4d4d4d;
}

/* indent list */
ul.ind1em,
ul.ind1_5em,
ul.ind2em,
ul.ind3em{
	list-style:none;
	margin:inherit 0;
	padding:0;
	font-size:16px;
}
ul.ind1em li{
	display:block;
	text-indent:-1em;
	padding-left:1em;
	font-size:16px;
}
ul.ind1_5em li{
	display:block;
	text-indent:-1.5em;
	padding-left:1.5em;
	font-size:16px;
	margin-bottom: 1rem;
}
ul.ind1_5em li.mb0,
ul.ind1_5em li:last-child{
	margin-bottom: 0;
}
ul.ind2em li{
	display:block;
	text-indent:-2em;
	padding-left:2em;
	font-size:16px;
}
ul.ind3em li{
	display:block;
	text-indent:-3em;
	padding-left:3em;
}

li > ul.ind1em,
ul.ind1em li + li{
	margin-top:.5rem;
}

.col2box{
	display: flex;
	justify-content: space-between;
}
.col2box .column{
	width: 49%;
}

.col4box{
	display: flex;
	justify-content: space-between;
}
.col4box .column{
	width: 24%;
}

.uploadImg{
	position: relative;
	border:1px solid #ccc;
	padding:5px;
	aspect-ratio: 1/1; /* 幅を基準に正方形とする */
}
.uploadImg span{
	position: absolute;
	right: 0.5rem;
	top: 0.5rem;
	background: #777;
	width: 36px;
	height: 36px;
	border-radius: 20px;
}
.uploadImg span img{
	cursor: pointer;
	width: 20px;
	height: 20px;
	position: relative;
	top: 8px;
	left: 8px;
}
.uploadImg .img_box{
	padding: 0;
	border-radius: 1rem;
	overflow: hidden;
	aspect-ratio: 1/1; /* 幅を基準に正方形とする */
}
.uploadImg .img_box img{
    position: absolute; /* 画像を絶対位置に設定 */
    top: 50%; /* 縦方向の中央に配置 */
    left: 50%; /* 横方向の中央に配置 */
    transform: translate(-50%, -50%); /* 画像の中心が中央にくるように調整 */
}
/*
01 header
*/
header {
	position:fixed;
	top:0;
	left:0;
	width: 100%;
	/* border-bottom: 2px solid #58595b; */

	box-sizing:border-box;
	-moz-box-sizing:border-box;
	-webkit-box-sizing:border-box;
	-o-box-sizing:border-box;

	text-align:center;

	z-index:999;
}

/*
02 pagetitle
*/
h1.appTit{
	position: absolute;
	top: 0;
	width: 100%;
	font-size:18pt;
	margin:0;
	padding:0;
	text-align:left;
	line-height:1;
	background: #fff2f2;
	white-space:nowrap;
	box-sizing: border-box;

	box-sizing:border-box;
	-moz-box-sizing:border-box;
	-webkit-box-sizing:border-box;
	-o-box-sizing:border-box;
}
h1.appTit.error,
h1.appTit.processing{
	background: #fff;
	box-shadow: none;
}

h1.appTit span{
	width: 100%;
	display: block;
	margin: 0 auto;
	padding: 0 5%;
	text-align: left;
	box-sizing: border-box;
}
h1.appTit.fixed{
	width:100%;
	position:fixed;
	top:0;
	left:0;
}
h1.appTit span.serviceTit{
	width: 100%;
	display: block;
	font-size: 1rem;
	padding: 0.5rem 5%;
	color: #fff;
	background: #ff4d4d;
}
h1.appTit span.pageTit{
	padding: 1rem 5% .5rem;
}
/*
03 #container
*/
#container {
	padding: 2rem 0 230px 0;
	/* top:header height / bottom:footer height */
	margin: 0;
	overflow:hidden;
}
#container.hidden{
	padding: 0;
	height:0px;
}
#container.login {
	padding: 0;
}
#container.footerOff {
	padding-bottom: 4rem;
}
#container.processing {
	padding: 3rem 0 1.5rem;
	border-bottom: 2px solid #df0023;
}
#container.error {
	padding: 5rem 0 3.5rem;
	border-bottom: 2px solid #df0023;
}

/*
0301 section
*/
.titleBox {
    width: 100%;
    padding: 0;
    overflow: hidden;
    box-sizing: border-box;
    background-color: #fff;
}
.processing .titleBox,
.titleBox.error{
	position: relative;
}
.titleBox h2{
	padding: 0 5%;
}
.steps.wrapper{
	padding: 10px;
}
.steps{
	position :relative;
	z-index :0;
	background :#f5f5f5;
}
.steps ol{
	display: flex;
	justify-content: space-between;
	list-style: none;
	margin: 0;
	padding: 0;
}

.steps .step{
	width :48px;
	height :48px;
	margin :0;
}
.steps .step-line{
	position :absolute;
	z-index :-1;
	top :50%;
	left :4.5%;
	width :92%;
	height :4px;
	background :#dcd8d9;
}

.wrpBox {
	width: 100%;
	/*margin: 0 auto 2rem;*/
	margin: 0 auto;
/*	padding: 0.8rem 5%;*/
	padding: 0 5%;
	overflow:hidden;
	box-sizing: border-box;
}

.wrpBox h2 {
	margin: 1rem 0 0.8rem;
}

.wrpBox:not([class*="bg01"]) + .wrpBox:not([class*="bg01"]){
	padding-top:0;
}
.error ~ .wrpBox {
	margin-top: 0;
}
.wrpBox.msgOnly {
	position:absolute;
	top:50%;
	left:50%;

	transform:translate(-50%, -50%);
	-moz-transform:translate(-50%, -50%);
	-webkit-transform:translate(-50%, -50%);
	-o-transform:translate(-50%, -50%);

	display: flex;
	display: -moz-flex;
	display: -webkit-flex;
	display: -o-flex;

	justify-content: center;
	-moz-justify-content: center;
	-webkit-justify-content: center;
	-o-justify-content: center;

	align-items: center;
	-moz-align-items: center;
	-webkit-align-items: center;
	-o-align-items: center;

	width:100%;
	box-sizing:border-box;
	text-align:center;
}
.wrpBox small{
	display:block;
	margin-top:.5rem;
	padding-left:1em;
	text-indent:-1em;
	font-size:0.7rem;
}
.wrpBox small + small{
	margin-top:.5rem;
}
.wrpBox small.red{
	color:#EC1B23;
}
.wrpBox > p {
	word-break: normal;
	font-size: 16px;
}

/*
030101 pagetitle
*/
h2.pageTit{
	font-size: 16pt;
	line-height: 1;
	border:1px solid #ccc;
	background: -webkit-linear-gradient(#fff2f2 92%, #FF1234 92.1%);
	background: -o-linear-gradient(#fff2f2 92%, #FF1234 92.1%);
	background: linear-gradient(#fff2f2 92%, #FF1234 92.1%);
	padding: .5rem .75rem;
	margin-bottom: 0.5rem;
    margin-top: 0.5rem;
	border-radius: 0.25em;
}
h2.pageTit.error,
h2.pageTit.processing{
	background:none;
	border:none;
	padding: 0;
}
h2.pageTit.error {
	padding: 0 5%;
}
h2.pageTit.error span,
h2.pageTit.processing span{
	display:block;
	background: url(../img/icon_error_tit.png) left center no-repeat;
	background-size: 1.5rem auto;
	padding: .25rem .5rem .25rem 2rem;
	font-size: 13pt;
	font-weight: normal;
}

/*
030101 subtitle
*/
h2.subTitle{
	position: relative;
	font-size: 13pt;
	line-height: 1.5rem;
	padding: .5rem 5% .5rem 1.5rem;
	margin: 0 -6% 1rem;
	background-color: #f5f5f5;
}
h2.subTitle::before{
	content: "";
	position: absolute;
	left:0;
	top:0;
	width: 0.375rem;
	height: 100%;
	background-color: #FF1234;
}

.read{
    margin-bottom: 1rem;
}

/*
030102 read
*/
p.readConfirm {
    margin-bottom: 1rem;
    font-size: 13pt;
}
/*
030103 img_box
*/
.img_box{
	display: block;
	overflow: auto;
	background: #f7f7f7;
	padding: .75rem;
	text-align: center;
	box-sizing: border-box;
}
.img_box img{
	max-width: 97%;  /* 100%だとuploadImgに合わせたサイズになる */
	max-height: 97%; /* img_box内にimgを収めるための調整 */
}
.img_box .btn_area {
	margin-top: 0.5em;
}
/*img_box supplement*/
.img_box.sample{
	display: inline-block;
	margin: 0 auto;
	width: 35%;
}
.img_box.sample img{
}

/*ul.attention*/
ul.attention{
	position: relative;
	display: block;
	background:#fffcf2;
	list-style:none;
	margin:0;
	padding:0.5rem 0.5rem 0.5rem 3rem !important;
	border: 3px solid #ffc400;
	border-radius: 0.25rem;
}
ul.attention::before{
	content: "";
	position: absolute;
	top: 0.5rem;
	left: 0.5rem;
	width: 1.5rem;
	height: 1.5rem;
	background: url(../img/icon_attention.png) center center no-repeat;
	background-size: 100%;
}
* ~ ul.attention{
	margin-top: 1em;
}
ul.attention > li{
	display: block;
	word-break:normal;
	font-size: 16px;
}
ul.attention li ~ li{
	margin-top:.5rem;
}
ul.attention pre{
	display:block;
	background-color:#fff;
	color:#8f9394;
	padding:.5rem;
	border-radius:4px;
}
ul.attention pre span{
	display:block;
}
/*ul.disc*/
ul.disc{
	position: relative;
	display: block;
	list-style: none;
	padding: 0 .5em;
}
ul.disc > li{
	position:relative;
	padding-left: 0.75em;
}
ul.disc > li::before{
	content: "";
	position: absolute;
	top: .375em;
	left: 0;
	width: 0.25em;
	height: 0.25em;
	border-radius: .125em;
	background-color: #333;
}
ul.attention.disc li.no-disc {
	padding-left: 0;
}
ul.attention.disc li.no-disc::before {
	display: none;
}

/*
030104 chk_item_box
*/
.chk_item_box{
	border: 2px solid #CCCCCC;
	border-radius: .25em;
}
.chk_item_box.dash{
	border-style: dashed;
	border-color: #4d4d4d;
	border-radius: 0;
}
.chk_item_box .inner{
	padding: 1em 1.5em;
}
.chk_item_box p.item{
	position: relative;
	display: block;
	line-height: 1.5;
	padding-left: 1.5em;
}
.chk_item_box p.item::before{
	content: "";
	position: absolute;
	left: .25em;
	top: .25em;
	display: block;
	background-color: #000000;
	width: .75em;
	height: .75em;
	border-radius: .5em;
}
.chk_item_box p.item ~ p.item{
	margin-top: 1em;
}

.chk_item_box table.error_case,
.chk_item_box table.error_case tr td {
	border: 0;
	background: transparent;
}
.chk_item_box table.error_case tr:nth-child(2n-1){
	background: #fffeee;
}
.chk_item_box table.error_case tr td:first-child {
	width: 25%;
}
.chk_item_box table.error_case tr td.w30 {
	width: 30%;
}
.chk_item_box table.error_case tr td p.item ~ p.item {
	margin-top: 0;
}

/*
030105 menu
*/
.menu{
}
.menu .button{
	display: block;
    font-size: 13pt;

	background: #fcfcfc;
	background: no-repeat right center, -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: no-repeat right center, -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat right center, -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat right center, linear-gradient(to bottom, #fcfcfc 0%,#d9d9d9 100%);
    background-size: 38px, 100%;
}
.menu .button ~ .button{
	margin-top: 1em;
}


/*
0302 form
*/
#container form {
	padding: 0;
	margin: 0;
}

/*input text typing*/
:placeholder-shown {color: #8a8a8a;}
::-webkit-input-placeholder {color: #8a8a8a;}
:-ms-input-placeholder {color: #8a8a8a;}

input[type="text"],
input[type="tel"],
input[type="password"],
select{
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	-o-appearance: none;

	display: inline-block;
	width: 100%;
	height: 2rem;

	padding: 0 0 0 0.5rem;
	margin: 0;
	overflow: hidden;

	background: #f6f6f6;
	background: -moz-linear-gradient(top, #f6f6f6 0%, #ffffff 20%, #ffffff 100%);
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#f6f6f6), color-stop(100%,#ffffff), color-stop(100%,#ffffff));
	background: -webkit-linear-gradient(top, #f6f6f6 0%,#ffffff 20%,#ffffff 100%);
	background: -o-linear-gradient(top, #f6f6f6 0%,#ffffff 20%,#ffffff 100%);
	background: linear-gradient(to bottom, #f6f6f6 0%,#ffffff 20%,#ffffff 100%);

	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;

	text-align: left;

	font-size: 1rem ;
	line-height: 1.2;
	font-weight: normal;

	border: solid 1px #ccc;
	border-radius: .5rem;
	-moz-border-radius: .5rem;
	-webkit-border-radius: .5rem;
	-o-border-radius: .5rem;
}
select{
	padding-right: 2em;
	background: #f6f6f6 url(../img/icon_select.png) right center no-repeat;
	background:url(../img/icon_select.png) no-repeat right center/1.5rem auto, -moz-linear-gradient(top, #f6f6f6 0%, #ffffff 20%, #ffffff 100%);
	background:url(../img/icon_select.png) no-repeat right center/1.5rem auto, -webkit-gradient(linear, left top, left bottom, color-stop(0%,#f6f6f6), color-stop(100%,#ffffff), color-stop(100%,#ffffff));
	background:url(../img/icon_select.png) no-repeat right center/1.5rem auto, -webkit-linear-gradient(top, #f6f6f6 0%,#ffffff 20%,#ffffff 100%);
	background:url(../img/icon_select.png) no-repeat right center/1.5rem auto, -o-linear-gradient(top, #f6f6f6 0%,#ffffff 20%,#ffffff 100%);
	background:url(../img/icon_select.png) no-repeat right center/1.5rem auto, linear-gradient(to bottom, #f6f6f6 0%,#ffffff 20%,#ffffff 100%);
}
input[type="text"]:focus,
input[type="tel"]:focus,
input[type="password"]:focus,
select:focus{/*フォーカス時*/
	border: 3px solid #298ccb;
}

input[type="text"]:disabled,
input[type="tel"]:disabled,
input[type="password"]:disabled,
select:disabled{/*非活性*/
	border-color: #ccc !important;
	background: #f5f5f5 !important;
}
input[required],
select[reauired]{
	background: #ffe5e5;
}

/* checkbox */
div.checkbox_btn{
	display: inline-block;
}
div.checkbox_btn input[type="checkbox"]{
	display: none;
}
div.checkbox_btn input[type="checkbox"] ~ label{
	display: block;
	padding: 1em 1em 1em 1.5em;
	background: url(../img/icon_check_off.png) left 1.125em no-repeat;
	background-size: 1em;
	font-weight: bold;
}
div.checkbox_btn input[type="checkbox"]:checked ~ label{
	background: url(../img/icon_check_on.png) left 1.125em no-repeat;
	background-size: 1em;
}

.chk_item_box div.checkbox_btn{
	display: block;
	border-top: 2px solid #ff9700;
	background: -moz-linear-gradient(top, #ffffd8 0%, #ffd154 100%);
	background: -webkit-linear-gradient(top, #ffffd8 0%,#ffd154 100%);
	background: linear-gradient(to bottom, #ffffd8 0%,#ffd154 100%);
}
.chk_item_box div.checkbox_btn input[type="checkbox"] ~ label{
	padding: 1em 1em 1em 3em;
	background-position:1.5em 1.125em;
}

/* number input */
.ipt_num{
	display:block;
}
.ipt_num > div{
	display:inline-block;
	white-space: nowrap;
	padding:.25rem;
}
.ipt_num > div ~ div{
	padding-left: 0.25em;
}
.ipt_num > div.np{
	padding-left: 0;
    font-size:13pt;
}
.ipt_num > div input{
	display:inline-block;
}

.ipt_num > div input.ipt_2dig{
	width:4rem;
}
.ipt_num > div input.ipt_3dig{
	width:5rem;
}
.ipt_num > div input.ipt_4dig{
	width:6rem;
}
.ipt_num > div input.ipt_7dig{
	width:9rem;
}
.ipt_num > div input.ipt_9dig{
	width:11rem;
}

/*button style*/
input[type="file"]{
	display: none;
}
label.fileBtn,input[type="submit"],input[type="button"],a.button{
	appearance:none;
	-moz-appearance:none;
	-webkit-appearance:none;
	-o-appearance:none;

	width:100%;
	padding:.5rem .5rem;
	font-size:16pt;
	line-height: 1;
	text-decoration: none;

	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: linear-gradient(to bottom, #fcfcfc 0%,#e5e6e6 100%);

	border:1px solid #abacad;

	border-radius:.5rem;
	-moz-border-radius:.5rem;
	-webkit-border-radius:.5rem;
	-o-border-radius:.5rem;
	display:inline-block;
	position:relative;

	box-sizing:border-box;
	-moz-box-sizing:border-box;
	-webkit-box-sizing:border-box;
	-o-box-sizing:border-box;
}
label.fileBtn{
	text-align: center;
	cursor: pointer;
}
label.fileBtn.disabled{
	text-align: center;
	cursor: pointer;
	pointer-events: none;
	/* color: #aaa; */
	opacity: .4;
}


input[type="submit"]:disabled,input[type="button"]:disabled{/* 非活性 */
	background:#c7c9c9;
	color: #eee;
	border:1px solid #c7c9c9;
}
input[type="submit"]:active,input[type="button"]:active{
	opacity:.7;
}

/*btnNext*/
input.btnNext,
a.btnNext{
	width: auto;
	font-size:16pt;
	font-weight: bold;
	padding:.55rem 1.5rem;

	background: #f0680d;
	color:#fff;
	box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
input.btnNext{
	/* top: 0.7em; */
}
a.btnNext {
    text-align:center;
}

input.btnNext.otxt,
a.btnNext.otxt{
	font-size:1rem;
}
a.btnNext strong{
	font-size:1.5rem;
	font-weight:normal;
}

/*btnEntry*/
input.btnEntry,
a.btnEntry{
	width: auto;
	padding:.5rem 2rem .5rem 2rem;

	background: #fcfcfc;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: linear-gradient(to bottom, #fcfcfc 0%,#d9d9d9 100%);

	color:#1a1a1a;
  font-size:13pt;
}

input.btnNext.otxt,
a.btnNext.otxt{
	font-size:1rem;
}
a.btnNext strong{
	font-size:1.5rem;
	font-weight:normal;
}



input.btn,
a.btn{
	width: auto;
	height:2.25rem;
	padding:.55rem 1.5rem;

	margin-top: .125em;
	font-size: 13pt;
	text-align: center;
	background-size:1.75rem, 100%;
}

/*btnBack*/
input.btnBack,
a.btnBack{
	width: auto;
	height:2.25rem;
	padding:.55rem 1.5rem;

	background: #ffd154;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: linear-gradient(to bottom, #fcfcfc 0%,#d9d9d9 100%);

	margin-top: .125em;
	font-size: 13pt;
}
/*btnAgain*/
input.btnAgain,
a.btnAgain{
	width: auto;
	padding:.5rem 2.5rem .5rem 2.5rem;

	background: #ffd154;
	background: no-repeat .5em center, -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: no-repeat .5em center, -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat .5em center, -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat .5em center, linear-gradient(to bottom, #fcfcfc 0%,#d9d9d9 100%);
	background-size: 1.5rem , 100%;
    font-size: 13pt;
}
.img_box .btn_area .btnAgain{
	padding:.5rem 4.5rem .5rem 4.5rem;
	background: no-repeat 2.5em center, -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: no-repeat 2.5em center, -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat 2.5em center, -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat 2.5em center, linear-gradient(to bottom, #fcfcfc 0%,#d9d9d9 100%);
	background-size: 1.5rem , 100%;
}

/*btnWrite*/
input.btnWrite,
a.btnWrite{
	width: auto;
	height:2.25rem;
	padding:0 1rem;

	background: #ffd154;
	background: no-repeat .5em center, -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: no-repeat .5em center, -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat .5em center, -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat .5em center, linear-gradient(to bottom, #fcfcfc 0%,#d9d9d9 100%);
	background-size: 1.75rem , 100%;
    font-size: 13pt;
}

/*form_table*/
* ~ .form_table{
	margin-top:	0.5em;
}
.form_table td{
	line-height: 2;
    font-size: 13pt;
}
.add_input_row{
	display:none;
}
/*
0303 column
*/
.column_2h,
.column_2t{
	display: block;
	overflow: hidden;
}
.column_2h .column_box,
.column_2t .column_box{
	display: block;
	float: left;
	box-sizing: border-box;
}
.column_2h .column_box{
	width: 50%;
}
.column_2h .column_box:first-child{
	padding-right: 1em;
}
.column_2h .column_box:last-child{
	padding-left: 1em;
}
.column_2t .column_box:first-child{
	width: 33%;
}
.column_2t .column_box:last-child{
	width: 67%;
	padding-left: 2%;
}

.call h2{
	border-left: 8px solid #df0023;
	background-color: #f5f5f5;
	padding: 1rem;
}
.call .closeBtn{
	padding: 1rem;
	background-color: #d9d9d9;
	text-align: center;
}
.call .closeBtn .btn{
	padding: .55rem 3rem;
}
.call .tel_num{
	padding: 1.5rem 5%;
}
.call .tel_num .num_box{
	display: flex;
	justify-content: center;
	border: 2px solid #cccccc;
	border-radius: .25rem;
	background: #fff;
	margin: 0 0 1.5rem;
}
.call .tel_num .num_box > div{
	width: 50%;
}
.call .tel_num .num_box .num{
	display: flex;
	width: 100%;
	justify-content: center;
	align-items: center;
	padding: 1.5rem 0;
	text-decoration: none;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: linear-gradient(to bottom, #fcfcfc 0%,#e5e6e6 100%);
}
.call .tel_num .num_box .num img{
	width: 25px;
	height: auto;
}
.call .tel_num .num_box .num p{
	font-size: 1.5rem;
	font-weight: bold;
	color: #df0023;
	padding-left:1rem;
	display: flex;
    align-items: flex-end;
}
.call .tel_num .num_box .num p span{
	display: inline-block;
	font-size: 1rem;
	color: #4d4d4d;
}
.call .tel_num > p{
	font-size: 1rem;
	text-align: center;
}
/*
04 footer_btn
*/
.footer_btn{
	position: absolute;
	box-sizing: border-box;
	bottom: 0;
	left: 0;
	width: 100%;
	padding: 0;
}
.footer_btn .wrpBox{
	position: relative;
	margin: 0 auto;
	padding: 0;
/*	border-top:4px solid #FF1234;*/
}
.footer_btn .wrpBox .next{
	padding: 0 5%;
	margin-top: 1.5rem;
	margin-bottom: 1.5rem;
}
.footer_btn .wrpBox .serviceTop a{
	display: block;
	background: #7f7f7f;
	text-align: center;
	color: #fff;
	font-size: 1.25rem;
	font-weight: bold;
	text-decoration: none;
	padding: 1rem 0;
}
.footer_btn .wrpBox .pageTop a{
	display: block;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#4d4d4d), color-stop(100%,#333333));
	background: -webkit-linear-gradient(top, #4d4d4d 0%,#333333 100%);
	background: -o-linear-gradient(top, #4d4d4d 0%,#333333 100%);
	background: linear-gradient(to bottom, #4d4d4d 0%,#333333 100%);
	text-align: center;
	color: #fff;
	font-size: 1.25rem;
	font-weight: bold;
	text-decoration: none;
	padding: 1rem 0;
}
.footer_btn .wrpBox .pageTop a img{
	width: 22px;
	height: auto;
	margin-right: 1rem;
	vertical-align:middle;
}

.footer_btn .wrpBox .btnExit,
.footer_btn .wrpBox .btnBack,
.footer_btn .wrpBox .btnNext{
	font-weight: bold;
	width: 100%;
}
.footer_btn .wrpBox .btnBack{
	left: 0;
}
.footer_btn .wrpBox .btnExit,
.footer_btn .wrpBox .btnNext{
	right: 0;
}
.foot_number {
	font-size:90%;
	text-align:right;
	padding:0.5rem 0.5rem 0.5rem 0;
	border-top: 4px solid #FF1234;
}
/*
05 footer
*/
footer {
	position:absolute;
	bottom:0;
	width:100%;
	height:1.375rem;
	background:#b3b3b3;
	color: #333;
}

footer small {
	display: block;

	text-align: center;

	font-size: 10pt;
	line-height:1.375rem;
	font-weight: normal;
}

@media only screen and (orientation:portrait){

	/*
	0303 column
	*/
	.column_2t .column_box
	.column_2h .column_box:not(.menu){
		float: none;
		box-sizing: border-box;
	}
	.column_2h .column_box:not(.menu){
		width:100%;
		padding: 0;
	}
	.column_2t .column_box:first-child{
		width: 100%;
	}
	.column_2h .column_box:not(.menu):last-child,
	.column_2t .column_box:last-child{
		width: 100%;
		padding-left: 0%;
		padding-top: 1em;
	}
	.img_box{
		text-align: center;
	}
/*	.img_box img{
		max-width: 65%;
	}*/
	.img_box.sample{
		width: 50%;
	}
	.img_box.sample img{
		max-width: 100%;
	}
}

/* モーダルウィンドウ */
.modalbox {
  overflow: hidden;
  background-color: #fff;

	border-radius:.25rem;
	-moz-border-radius:.25rem;
	-webkit-border-radius:.25rem;
	-o-border-radius:.25rem;

  /*以下モーダルウィンドウに必要な箇所*/
  position: fixed;
  z-index: 1000;
  display: none;
  width: 50%;
}
.modalbox .cancel_btn{
	position: absolute;
	top: 0.25em;
	right: 0.25em;
	width: 1.5em;
	height: 1.5em;
	background:#333;
	border-radius: .75em;
}
.modalbox .cancel_btn:active{
	background:#c33;
}
.modalbox .cancel_btn::before,
.modalbox .cancel_btn::after{
	content: "";
	position: absolute;
	display: block;
	width: 1em;
	height: 1em;
	top: 0.6em;
}
.modalbox .cancel_btn::before{
	border-left: 2px solid #fff;
	left: 0.5625em;
	transform: rotate(45deg);
}
.modalbox .cancel_btn::after{
	border-right: 2px solid #fff;
	left: -0.125em;
	transform: rotate(-45deg);
}

.modalbox p{
	padding:2rem;
	margin-bottom:2rem;
	text-align: center;
}
.modalbox a.close_btn{
	position:absolute;
	display:block;
	width:100%;
	bottom:0;
	padding:.5rem 0;
	background-color:#fff;
	text-align:center;
	border-top:1px solid #09F;
	text-decoration:none;
}

.modalbox .close_btn:active{
	color:#fff;
	background-color:#09F;
}

/*---------------------
    モーダルウィンドウ
    レイヤー
----------------------- */
.layer {
  position: fixed;
  top: 0;
  z-index: 999;
  display: none;
  width: 100%;
  height: 100%;
  background-color: #333;
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(opacity=50)"!important;
  opacity: 0.5;
}

/* スプラッシュ画面 */
img.splash{
	width:auto;
	position:absolute;
	top:50%;
	left:50%;

	-moz-transform:translate(-50%,-50%);
	-webkit-transform:translate(-50%,-50%);
	-o-transform:translate(-50%,-50%);
	transform:translate(-50%,-50%);

}

/*---------------------
  2ボタンモーダル用
----------------------- */
.modalbox a.left_btn{
	position:absolute;
	display:block;
	width:50%;
    height:1.5em;
	bottom:0;
	padding:.5rem 0;
	background-color:#fff;
	text-align:center;
	border-top:1px solid #09F;
	text-decoration:none;
}

.modalbox a.left_btn:active{
	color:#fff;
	background-color:#09F;
}

.modalbox a.right_btn{
	position:absolute;
	display:block;
	width:50%;
    height:1.5em;
	bottom:0;
    left:50%;
	padding:.5rem 0;
	background-color:#fff;
	text-align:center;
	border-top:1px solid #09F;
    border-left:1px solid #09F;
	text-decoration:none;
}

.modalbox a.right_btn:active{
	color:#fff;
	background-color:#09F;
}

#modalerror div {
    height: 100%;
    overflow: auto;
}

#modalMessage, #modalErrorMessage {
    padding-bottom:1rem;
}

/*---------------------
  イメージダイアログ
----------------------- */
.imageDialog{
  position: fixed;
  top: 0;
  z-index: 1010;
  display: none;
  width: 100%;
  height: 100%;
  overflow: auto;
  background-color: rgba(51,51,51,1);
  /*-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(opacity=50)"!important;*/
}

.imageDialogCloseButton{
   margin-top: 20px;
   margin-left: 4px;
   margin-bottom:4px;
   width: 5em !important;
}

/*---------------------
    ローディング画像
----------------------- */
#loading{
    /*display:none;*/
    position:fixed;
    width:100%;
    height:100%;
    top:0;
    left:0;
    background-color:rgba(0,0,0,0.7);
    z-index:1000;
	display: flex;
    align-items: center;
    justify-content: center;
}
#loading img {
    padding: 10px;
    /*border: solid 2px #333;*/
    border-radius: 15px;
    background-color: #FFF;
}

/*---------------------
    利用規約画面の番号
----------------------- */
#wv002num{
    position:absolute;
    right:2.25rem;
    bottom:5rem;
    line-height:2rem;
    font-size:10pt;
}

/*----------------------------------------------
    撮影注意事項画面(パスポート等)の案内文
------------------------------------------------ */
.subTitle_wv013{
	font-weight:normal;
	position: relative;
	font-size: 13pt;
	line-height: 36px;
	margin-bottom: 1rem;
	border-radius: 0.25em;
}


/*btnOrange*/
input.btnOrange{
	width: auto;
	font-size:16pt;
	font-weight: bold;
	width: 100%;
	padding:.55rem 1.5rem;
	background: #ff8000;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffca59), color-stop(50%,#ff9e3a), color-stop(100%,#ff8000));
	background: -webkit-linear-gradient(top, #ffca59 0%,#ff9e3a 50%,#ff8000 100%);
	background: -o-linear-gradient(top, #ffca59 0%,#ff9e3a 50%,#ff8000 100%);
	background: linear-gradient(to bottom, #ffca59 0%,#ff9e3a 50%,#ff8000 100%);
	color: #fff;
	border: 1px solid #d17b07;
	box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
.large_hight input.btnOrange{
	padding:0.5rem;
}
input.btnOrange.disabled{
	 pointer-events: none;
	opacity: 0.3;
	background: #000;
	border: 1px solid #000;
}
input.btnOrange.otxt{
	font-size:1rem;
}
/*btnGray*/
input.btnGray{
	font-weight: bold;
	color: #555;
	/*background: #ff8000;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#ffca59), color-stop(50%,#ff9e3a), color-stop(100%,#ff8000));
	background: -webkit-linear-gradient(top, #ffca59 0%,#ff9e3a 50%,#ff8000 100%);
	background: -o-linear-gradient(top, #ffca59 0%,#ff9e3a 50%,#ff8000 100%);
	background: linear-gradient(to bottom, #ffca59 0%,#ff9e3a 50%,#ff8000 100%);
	color: #fff;
	border: 1px solid #d17b07;*/
	box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}
/*.large_hight input.btnGray{
	padding:1.5rem;
}*/

/*btnBack*/
input.btnBack{
	width: auto;
	font-size:16pt;
	font-weight: bold;
	width: 100%;
	color: #fff;
	background: #000000;
	opacity:0.3;
	box-shadow: 0 2px 4px rgba(0,0,0,0.2);
}

/*----------------------------------------------
    学資年金開始WEB手続画面
------------------------------------------------ */
#container.gakushi{
	padding: 2rem 0 20rem 0;
}
#container.gakushi .wrpBox{
	margin: 0 auto;
}
#container.gakushi .wrpBox p{
	font-size: 16px;
	margin: 1rem 0;
}
#container.gakushi .notes {
	list-style: none;
	padding: 0;
	margin: 0.5em 0 0 0;
}
#container.gakushi .notes li{
	display: block;
    background: url("../img/icon_info.png") left top no-repeat;
    background-size: 1.5rem auto;
    padding: 0 0 0.5em 2rem;
	font-size: 16px;
}
#container.gakushi .notes.error li{
    background: url("../img/icon_error_tit.png") left top no-repeat;
    background-size: 1.5rem auto;
	color: #FF1234;
}
#container.gakushi .next{
	margin-bottom: 1rem;
}
#container.gakushi .footer_btn .Back{
	display:inline-block;
	position:relative;
	margin: 0 0 2rem;
	padding: 0 5%;
}
#container.gakushi .footer_btn .Back::after{
	content: '';
	width: 6px;
	height: 6px;
	border: 0;
	border-top: solid 2px #333;
	border-left: solid 2px #333;
	position: absolute;
	top: 50%;
	left: 30px;
	margin-top: -4px;
	transform: rotate(-45deg);
}
#container.gakushi .footer_btn .Back input.btnGray{
	width: auto;
	height: 3.3rem;
	padding: 0.1rem 1rem 0 1.6rem;
	background: #ffd154;
	background: no-repeat .5em center, -webkit-gradient(linear, left top, left bottom, color-stop(0%,#fcfcfc), color-stop(100%,#d9d9d9));
	background: no-repeat .5em center, -webkit-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat .5em center, -o-linear-gradient(top, #fcfcfc 0%,#d9d9d9 100%);
	background: no-repeat .5em center, linear-gradient(to bottom, #fcfcfc 0%,#d9d9d9 100%);
	background-size: 1.75rem , 100%;
	font-size: 1.1em;
	font-weight: bold;
}
.att_list dt{
	margin-left:0.7em;
	text-indent:-0.6em;
}
.att_list dd{
	margin-left:1.6em;
	text-indent:-1em;
}
span.note2{
	font-size: .875rem;
	color: #4d4d4d;
	margin-left:1em;
	text-indent:-1em;
	display:block;
}
/*---------------------
    フッター追加
----------------------- */
#container.gakushi .footer_btn {
    bottom: 70px;
}
#footerArea{
	position: absolute;
	box-sizing: border-box;
    bottom: 0;
	width: 100%;
	height: 70px;
}
#footerArea .number{
	text-align: right;
	padding: 10px 10px 0 0;
}
#footerArea footer{
	bottom: 8px;
}
#footerArea small{
	background: #fff;
}
.modal-btn-wrap > input[type="file"]{
	display: block;
}
/*---------------------
    エラー画面
----------------------- */
#container.gakushi.error{
	padding: 2rem 0 0 0;
	border-bottom: none;
}
#container.gakushi .footer_btn {
    bottom: 0;
}
/*---------------------
    2024.05 本人確認書類の撮影
----------------------- */
/* STEP */
.stepArea{
	margin: 14px 0 0;
}
.stepArea ul{
	display: flex;
	align-items: stretch;
	list-style: none;
	margin: 0;
    padding: 0;
}
.stepArea ul li{
	width: 33.3%;
	height: 50px;
	font-size: 11px;
	text-align: center;
    background: #f5f5f5;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
.stepArea ul li::before{
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 25px solid transparent;
	border-bottom: 25px solid transparent;
	border-left: 10px solid #f5f5f5;
	border-right: 0;
	position: absolute;
	top: 0;
	right: 0px;
	bottom: 0;
	margin: auto;
	z-index: 2;
}
.stepArea ul li::after{
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 25px solid transparent;
	border-bottom: 25px solid transparent;
	border-left: 10px solid #FF1234;
	border-right: 0;
	position: absolute;
	top: 0;
	right: -1px;
	bottom: 0;
	margin: auto;
	z-index: 1;
}
.stepArea ul li.active{
    background: #FF1234;
	color: #fff;
}
.stepArea ul li.active::after{
	content: '';
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 25px 0 25px 8px;
	border-color: transparent transparent transparent #FF1234;
	position: absolute;
	top: 0;
	right: -8px;
	bottom: 0;
	margin: auto;
}
.stepArea ul li:last-of-type::before,
.stepArea ul li:last-of-type::after,
.stepArea ul li.active::before{
	content: none;
}

.doc_type{
	margin: 20px 0;
}
.doc_type th{
	width: 40%;
}
.doc_type th,
.doc_type td{
	font-size: 16px;
	padding: 8px 14px;
}
.doc_type td.td_flex{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.list_dot{
	margin: 0;
	padding: 0;
	list-style: none;
}
.list_dot li{
	font-size: 1em;
	text-indent: -1em;
	padding: 0 0 1em 1em;
}
.btn_inline .btnGray{
	width: auto;
	font-size: 1em;
	padding: .5rem 1rem;
}
.btn_inline.column2{
	display: flex;
	justify-content: space-between;
	border:1px solid #ccc;
	border-top: none;
	padding:5px;
}
.btn_inline_outer{
	border:1px solid #ccc;
	border-top: none;
}
.btn_inline_outer .btn_inline.column2{
	border: none;
}
.btn_inline.column2 .btnGray{
	width: 48%;
}

/* Loading背景画面設定　*/
#splash {
    /*fixedで全面に固定*/
	position: fixed;
	z-index: 99999;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .8);
	text-align:center;
	color:#fff;
}
/* Loadingバー中央配置　*/
#splash_text {
	position: absolute;
	top: 45%;
	left: 50%;
    z-index: 999;
	width: 86%;
	transform: translate(-50%, -50%);
	color: #fff;
}
#splash_text2 {
	position: absolute;
	top: 45%;
	left: 50%;
	width: 86%;
    z-index: 999;
	transform: translate(-50%, -50%);
	margin: 80px 0 0;
	color: #fff;
	text-align: left;
	font-size: 13px;
}
#splash_text3 {
	position: absolute;
    top: 50%;
    left: 50%;
    z-index: 999;
    width: 28%;
    transform: translate(-50%, -50%);
    color: #fff;
}
/* マスキング　*/
.maskingTable{
	margin: 20px 0 0;
}
.maskingTable th{
	text-align: left;
	padding: .6rem;
}
.maskingTable td{
	padding: .8rem;
}
.maskingArea{
	position: relative;
}
.maskingTable td.maskingArea{
	padding: 0 !important;
}
.maskBtn{
	position: absolute;
    left: 25%;
    top: 25%;
}
.maskingArea .lead_txt{
	padding: 5px 5px 0;
}
.maskingArea .resizable {
	width: 150px;
	border-radius: 0.75rem;
	padding: 12px;
	margin: 0.5rem;
	background-color: black;
	color: white;
	font-size: 20px;
	font-family: sans-serif;
	overflow: hidden;
	touch-action: none;
	box-sizing: border-box;
	position: absolute;
	min-height:2.3em;
}

.fixBtnExpiry.on{
	background: #ffdede;
	/*background: linear-gradient(to bottom, #ffdede 0%,#ddc2c2 100%);*/
}
.fixBtnLicense.on{
	background: #ffdede;
	/*background: linear-gradient(to bottom, #ffdede 0%,#ddc2c2 100%);*/
}





/* underline */
.underLine {
	text-decoration: underline;
}

/* input */
input[type="text"].inputY{
	width: 28%;
}
input[type="text"].inputM,input[type="text"].inputD{
	width: 17%;
}