*{margin:0;padding:0;box-sizing: border-box;}
html{margin:0;padding:0;height:100%;}
header, footer, aside, nav, section,article,time,figure,label{display: block;}
h1,h2,h3,h4,h5{font-weight:normal;}
ul,ol{list-style:none;}
a{outline:none;text-decoration:none;}
a img{border:0;}
fieldset{border:0;}
.clear{margin:0;padding:0;height:0;clear:both;}
body {margin:0;padding:0;font-size:13px;background:#fff;color:#666;background-size: cover;font-family:sans-serif;-webkit-text-size-adjust:100%;}

/*Header
--------------------------------------------------------------------------------------------------------------*/
#top{width:100%;height:45px;overflow:hidden;background:#fff;}
#top h1{background-repeat:no-repeat;background-position:center top;background-size:270px 45px; height:45px; text-indent:120%; overflow:hidden; white-space:nowrap;}
#top h1 a{display:block; width:100%; height:100%;}
.logo-3ban h1{background-image:url(../images/logo-3ban.png);}
.logo-4ban h1{background-image:url(../images/logo-4ban.png);}
.logo-5ban h1{background-image:url(../images/logo-5ban.png);}
.logo-6ban h1{background-image:url(../images/logo-6ban.png);}
.logo-7ban h1{background-image:url(../images/logo-7ban.png);}
.logo-8ban h1{background-image:url(../images/logo-8ban.png);}

#top_fix{width:100%;height:85px;overflow:hidden;background:#fff; position:fixed; top:0; z-index:100;}
#top_fix h1{background-repeat:no-repeat;background-position:center top;background-size:270px 45px; height:45px; text-indent:120%; overflow:hidden; white-space:nowrap;}
#top_fix h1 a{display:block; width:100%; height:100%;}
#top_fix nav {height:40px; background:rgba(200,200,200,0.7);}
#top_fix nav ul{width:240px; height:100%; margin:0 auto; background:url(../images/nav_top.png) no-repeat center center; background-size:contain;}
#top_fix nav ul li {float:left; width:60px; height:40px;}
#top_fix nav ul li a{width:60px; line-height:40px; display:block; text-indent:120%; overflow:hidden; white-space:nowrap;}

.wrap{position:relative;}

/*RegButton
--------------------------------------------------------------------------------------------------------------*/
.regbtn{padding:10px 0;text-align:center;background:#edebeb;border-top:1px solid #ddd;border-bottom:1px solid #ddd;}
.regbtn a{margin:0 auto;width:300px;height:60px;overflow:hidden;background:url(../images/btn_regbtn.png) no-repeat 0 0;display:block;background-size:300px 60px;border-radius:8px;}
.regbtn a span{padding:60px 0 0 0;display:block;}

#reg_Q {background:#ffffd6; padding:10px; }
#reg_Q p{text-indent:120%; overflow:hidden; white-space:nowrap; background:url(../images/Q.png) no-repeat center center; height:20px; background-size:contain; margin:0 0 10px;}
#reg_Q ul{display:table; width:100%; border-collapse:separate; border-spacing:5px; box-sizing:border-box; table-layout:fixed;}
#reg_Q ul li {display:table-cell; height:60px; border-radius:5px; box-sizing:border-box; -webkit-border-radius:5px; -webkit-box-sizing:border-box;}
#reg_Q ul li a{display:block; line-height:60px; text-indent:120%; overflow:hidden; white-space:nowrap;}
#reg_Q ul:first-of-type li:first-child{background:#9bfcff; border:2px solid #47dbe0;}
#reg_Q ul:first-of-type li:first-child a{background:url(../images/regbtn_a.gif) no-repeat center center; background-size:contain;}
#reg_Q ul:first-of-type li:last-child{background:#e7396e; border:2px solid #fe88ac;}
#reg_Q ul:first-of-type li:last-child a{background:url(../images/regbtn_c.gif) no-repeat center center; background-size:contain;}
#reg_Q ul:last-of-type li:first-child{background:#ffd5ee; border:2px solid #ed8cc6;}
#reg_Q ul:last-of-type li:first-child a{background:url(../images/regbtn_b.gif) no-repeat center center; background-size:contain;}
#reg_Q ul:last-of-type li:last-child{background:#0095cc; border:2px solid #37c4f8;}
#reg_Q ul:last-of-type li:last-child a{background:url(../images/regbtn_d.gif) no-repeat center center; background-size:contain;}

/*Main
--------------------------------------------------------------------------------------------------------------*/
.intro{width:100%;height:160px;overflow:hidden;position:relative;}
.intro li{width:100%;height:160px;text-align:center;background-size:640px 160px;background-position:center top;background-repeat:no-repeat;}
.intro_01{background-color:#1279b4;}
.intro_02{background-color:#e9cbc1;}
.intro_04{background-color:#f7f5f5;}
.intro_03{background-color:#121413;}
.intro_05{background-color:#1a1a1a;}

.intro_img {margin-top:85px;}
.intro_img img{width:100%;}

.contents header{padding:10px 10px 0 10px;overflow:hidden;}
.contents header h1{padding:0 10px;line-height:30px;font-size:16px;color:#fff;background:url(../images/bg_heading.png) no-repeat right bottom #332e2e;background-size:310px 30px;}

.contents header.maxim{height:90px; background:#1a1a1a; padding:0;}
.contents header.maxim h1{height:100%; text-indent:120%; overflow:hidden; white-space:nowrap; padding:0;}
#about.contents header h1{background:url(../images/heading_about.jpg) no-repeat center 0; background-size:contain;}
#example.contents header h1{background:url(../images/heading_example.jpg) no-repeat center 0; background-size:contain;}
#user.contents header h1{background:url(../images/heading_user.jpg) no-repeat center 0; background-size:contain;}
#voice_list.contents header h1{background:url(../images/heading_voice.jpg) no-repeat center 0; background-size:contain;}
#exp_list.contents header h1{background:url(../images/heading_exp.jpg) no-repeat center 0; background-size:contain;}

#example article{background:#e6e6e6; border:2px dashed #acacac; margin:10px auto; width:90%;}
#example article p{text-indent:120%; overflow:hidden; white-space:nowrap; background:url(../images/article_example.gif) no-repeat center center; background-size:contain; height:190px;}

p.reg_go {background:#ffd5ee; border:2px solid #ed8cc6; border-radius:5px; box-sizing:border-box; -webkit-border-radius:5px; -webkit-box-sizing:border-box; margin:10px;}
p.reg_go a {display:block; line-height:40px; font-size:18px; color:#e7396e; text-align:center; background:url(../images/arrow_pink.png) no-repeat 95% center; background-size:6px 12px;} 

.general article h3{padding:10px 10px 0 10px;font-size:16px;line-height:20px;color:#900;}
.general article p{padding:10px;font-size:13px;line-height:20px;border-bottom:1px solid #ddd;}
.general article aside{padding:0 10px;line-height:20px;color:#999;}
.general article h4{padding-top:10px;}

.general article p span.strong{font-size:120%; font-weight:bold; color:#e11a57; text-shadow:0px 0px 4px #ff6cbc;}

.user_list a{display:block;}
.user_list article{padding:0 10px 0 80px;min-height:80px;position:relative;border-bottom:1px solid #ddd;}
.user_list article h3{padding:10px 0 0 0;font-size:16px;line-height:20px;color:#f68495;}
.user_list article aside{line-height:20px;color:#999;}
.user_list article .comm{padding:0 0 10px 0;font-size:13px;line-height:20px;color:#666;}
.user_list article figure{position:absolute;left:10px;top:10px;}
.user_list article figure img{width:60px;display:block;border-radius:50%;}

.voice article{padding:0 10px 0 80px;min-height:110px;position:relative;border-bottom:1px solid #ddd;}
.voice article h3{padding:10px 0 0 0;font-size:16px;line-height:20px;color:#332e2e;}
.voice article aside{width:80px;color:#999;position:absolute;left:10px;top:10px;}
.voice article p{padding:10px 0 10px 0;font-size:13px;line-height:20px;}
.voice article figure img{width:60px;display:block;border-radius:50%;}
.voice article aside p{width:60px;padding:2px 0;font-size:11px;line-height:14px;text-align:center;color:#f68495;}
.voice article footer{padding:0 0 10px 0;}
.voice article footer a{margin:0 0 0 auto;width:50%;height:30px;line-height:30px;text-align:center;background:#f68495;color:#fff;display:block;border-radius:4px;}
.popup .heading h1{padding:10px;line-height:20px;font-size:16px;background:#f90;color:#fff;}

.sidebox{position:relative;}
.sidebox p{background-image:url(../images/bg_sidebox.jpg);background-size:512px 400px;background-repeat:no-repeat;}
.side_career p{height:200px;background-position:center 0;background-color:#edebeb;}
.side_career p span{padding:20px;position:absolute;bottom:0;right:0;left:0;display:block;}

.side_security p{height:200px;background-position:center -200px;background-color:#010e2a;}
.side_security p span{padding:20px;background:rgba(0,0,0,0.6);color:#fff;position:absolute;bottom:0;right:0;left:0;display:block;}

.faq h3:before{content:"Q.";}
.faq p:before{content:"A.";}

.disc,h4{padding:0 10px; }
.ex {padding:0 10px; background:#fdd;display:block;}

/*close_btn */
a.close_btn {position:fixed; bottom:0; display:block; line-height:50px; width:100%; text-align:center; color:#fff; font-size:16px; background-color:rgba(0,0,0,0.8);}

/* campaign */
.campaign h4{font-weight:normal; margin-bottom:7px; color:#FF5B82; padding:0 10px;}
.campaign h5 {font-weight:normal; font-size:14px;color:#FF5B82; padding:0 10px;}
.campaign p {margin-bottom:10px;}
.cam_msg {font-size:12px; color:#999; padding:0;}
.campaign strong {font-weight:bold; color:#f00;}
.camMenu { margin-bottom:10px;padding:0 10px;}
.camMenu dt { font-weight:bold; margin:5px 0;}
.camMenu dd {margin-bottom:10px;}
.camMenu table {border-collapse:collapse; width:270px; }
.camMenu table th{text-align:center; background:#ccc; width:90px; border:1px solid #aaa;}
.camMenu table td{text-align:right; width:90px; background:#fff; border:1px solid #aaa; padding-right:10px; box-sizing:border-box;}
.camMenu table tr td:last-child{background:#ff0;}

#campaign_btn {position:absolute; top:170px; width:100%; z-index:9;}
#campaign_btn_entry {position:absolute; top:30px; width:100%;}
#campaign_btn a,#campaign_btn_entry a{width:320px; margin:0 auto; height:70px; background:url(../images/campaign_btn.png) no-repeat right 0; display:block; text-indent:-9999px; background-size:contain;}

#body_top #campaign_btn {top:0;}
#body_top #campaign_btn a{width:auto;}

/*--------------------------------
form
--------------------------------*/
.remaining{
    margin: 0 auto;
    padding: 4px;
    height: 32px;
    background: #1a1a1a;
    z-index: 9999;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    text-align: center;
    color: white;
    transition: 0.2s;
}
.remaining .progress{
    width: 0%;
    height: 32px;
    display: block;
    background: #504a4a;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    transition: 0.2s;
}
.remaining p{
	position: absolute;
	top: 6px;
	left: 4px;
	right: 4px;
	bottom: 4px;
}
.remaining span{
	color: white;
}
.remaining.fix{
	top: 0;
}
.remaining + header{
	margin-top: 32px;
}
.notice-box{
    margin: 24px 16px;
    padding: 8px;
    background: #f29b76;
    text-align: center;
    color: white;
}
.form-wrapper{
    margin-bottom: 32px;
    padding: 0 16px;
}
.form-box{
	margin: 16px 10px 32px;
}
.form-label{
	padding: 2px;
	margin-bottom: 8px;
	display: block;
	background: #332e2e;
	text-align: center;
	color: white;
}
.entry-btn{
	margin: 0 10px 32px;
}
input[type=text],
input[type=tel],
input[type=password],
select,
textarea{
	padding: 8px;
	width: 100%;
	height: 60px;
	background: #fff;
	position: relative;
	font-size: 16px;
	border: none;
}
textarea{
	margin-bottom: -4px;
	resize: vertical;
	height: auto;
}
select{
	padding: 8px 20px 8px 8px;
	height: 60px;
	background: url(../images/icon-select.webp) no-repeat right center / 20px, #fff;
	border: 1px solid #ddd;
	color: black;
}
select:focus{
	background: url(../images/icon-select.webp) no-repeat right center / 20px, #ffffe5;
}
.radio-box{
	display: flex;
}
.regular-radio{
	display: none;
}
.radio-label{
	width: 50%;
	line-height: 58px;
}
.radio-label-text{
	background: #fff;
	display: block;
	transition: .3s;
	text-align: center;
	border: 1px solid #ddd;
	box-sizing: border-box;
	color: black;
}
.radio-label:nth-of-type(1) .radio-label-text{
	border-radius: 4px 0 0 4px;
	border-right: 0;
}
.radio-label:nth-of-type(2) .radio-label-text{
	border-radius: 0 4px 4px 0;
}
.regular-radio:checked + .radio-label-text{
	background: #eb739f;
	color: #fff;
}
.regular-checkbox{
	margin-bottom: 5px;
	padding: 5px;
	display: block;
	background: #eee;
	font-size: 18px;
	border: 1px solid #eb739f;
}
.regular-checkbox input:checked + .check-label{
	color: #eb739f;
}
.form-msg,
.alert-msg{
	font-size: 14px;
}
.form-box .form-msg{
	margin: 8px 0 0 0;
	line-height: 1.3;
	text-align: center;
}
.error{
	margin: 8px 0 0;
	padding: 4px;
	background: #ff6d6d;
	font-size: 14px;
	color: #fff;
	text-align: center;
}
.form-item{
	position: relative;
}
.form-border{
	margin: 0 auto;
	width: 100%;
	height: 2px;
	background: #ddd;
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	transform-origin: center;
}
input[type=text]:focus + .form-border::after,
input[type=tel]:focus + .form-border::after,
input[type=password]:focus + .form-border::after,
textarea:focus + .form-border::after{
	margin: 0 auto;
	width: 0%;
	height: 2px;
	content: "";
	background: #eb739f;
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 2;
	transform-origin: center;
	animation: fade-border .3s ease .1s forwards;
}
@keyframes fade-border{
	0%{width: 0%;opacity: 0;}
	100%{width: 100%;opacity: 1;}
}
.entry-btn .btn-area{
    margin: 0 0 32px;
}
.entry-btn .regist-btn{
    width: 100%;
    height: 60px;
    line-height: 60px;
    text-align: center;
    border: 0;
    background: #f68495;
    color: #fff;
    background-image: linear-gradient(rgba(255,255,255,0.1),rgba(255,255,255,0));
    font-size: 16px;
}
.entry-btn .regist-btn{
	filter: grayscale(1);
	pointer-events: none;
	cursor: inherit;
}
.entry-btn .regist-btn.active{
	filter: grayscale(0);
	pointer-events: auto;
	cursor: pointer;
}
.ymd-box{
	column-gap: 8px;
}
.ymd-box,
.area-box{
	display: flex;
	justify-content: space-between;
}
.ymd-box select{
	flex-shrink: 1;
}
.area-box select,
.area-box .sub-area{
	width: calc(50% - 4px);
}
.area-box .sub-area select{
	width: 100%;
	flex-shrink: 0;
}

.juyo { background:rgba(255,0,0,0.1); border:1px dotted #f00 !important; padding:8px !important; box-sizing:border-box;margin:10px 10px 0;}
.form .msg span,.form .juyo span{float:none; padding:0;}
.form p a {
    color: #ff3c81;
}
.success {
    padding: 10px;
}
.success h3, .success p {
    padding: 0 0 10px;
}
.success .juyo{margin: 0;}
/*Footer
--------------------------------------------------------------------------------------------------------------*/
#footer{background:#332e2e;clear:both;position:relative;}
.gnav li{height:44px;line-height:44px;border-top:1px solid rgba(255,255,255,0.1);border-bottom:1px solid rgba(0,0,0,0.2);}
.gnav li a{padding:0 10px;color:#fff;font-size:12px;display:block;background:url(../images/icon_arrow.png) no-repeat right;background-size:12px 10px;}
#footer small{padding:8px 0;font-size:12px;line-height:14px;color:#fff;background:url(../images/icon_u19.png) no-repeat left #332e2e;background-size:60px 60px;text-align:center;display:block;clear:both;}
#footer aside{padding:10px 0;text-align:center;}
#footer aside img{display:block;width:100%;}
.btn_top{width:30px;height:30px;display:block;background:url(../images/btn_top.png) no-repeat right;background-size:30px 30px;position:absolute;right:7px;bottom:7px;border-radius:4px;}


.lpprtitle,.lpprbox,.c-box {color:#fff !important;}
