@charset "utf-8";

/* ------------------------------------------------------------------
 * (C) KADOKAWA CORPORATION
 * B-Luxe 持ち込みフォーム
------------------------------------------------------------------- */
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */ html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:0.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace, monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace, monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}button,[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{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:0.35em 0.75em 0.625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type="search"]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}

*,*::before,*::after { box-sizing: border-box; }

html {	font-size: 62.5%; }
body{
	margin: 0 auto;
	width: 100%;
	-webkit-text-size-adjust: 100%;
	background-color: #FAF6F8;
	color: #3f3f3f;
	backface-visibility: hidden;
	font-size: 1.4rem;
	line-height: 24px;
	font-family: "Montserrat","Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN","Arial","Yu Gothic","Meiryo",sans-serif;
	font-feature-settings: "palt";
}
h1, h2, h3, h4, h5, h6	{	font-weight: bold; line-height: 1em;	}
img						{	border:0; margin:0; -ms-interpolation-mode: bicubic;	}
fieldset				{	border:0; margin:0;	}
br						{	letter-spacing:0;	}
ol,ul,li				{	list-style:none;list-style-position: outside;	}
li img					{	vertical-align:top;	}
li a					{	zoom: 1;	}
em,cite					{	font-style: normal;	}
strong					{	font-weight:bold;	}
table					{	border-collapse: collapse;	border-spacing: 0;	}
p						{	line-height: 1.7; font-size: 1.4rem;}

input,button,input:focus,button:focus {	outline:0px none ;}
input,button,textarea,select {	font-family : inherit; font-size: 1.5rem; text-align:left;padding: 2px;}

a img {vertical-align: bottom;}

/*-------------------------------------------------------------------- */
a:link		{	color: #00adea;	text-decoration: underline; outline:none;	}
a:visited	{	color: #00adea;	text-decoration: underline;	}
a:hover		{	color: #009ad0;	text-decoration: none;	}
/* float --------------------------------------------------------------------*/
.fL	{float:left;}
.fR	{float: right;}

#base ul.ul1 li:after,
#base .noticeChk .noticeChk_chk label:after,
#base:after,
.clearfix:after {	visibility: hidden;	display: block;	font-size: 0;	content: " ";	clear: both;	height: 0;	}

* html #base #base ul.ul1 li,
* html #base .noticeChk .noticeChk_chk label,
* html #base,
* html .clearfix {	zoom: 1; } /* IE6 */

*:first-child+html #base ul.ul1 li,
*:first-child+html #base .noticeChk .noticeChk_chk label,
*:first-child+html #base,
*:first-child+html .clearfix {	zoom: 1; } /* IE7 */

/* layout --------------------------------------------------------------------*/
.pconly { display: block; }
.sponly { display: none; }
h1 {
	margin: 0;
	padding: 40px 0 0;
	color: #333;
	font-size: 2.8rem;
	text-align: center;
}

h2 {
	margin: 20px 0;
	padding: 0;
	line-height: 100%;
	position: relative;
	font-size: 2.4rem;
	font-weight: 900;
	text-align: center;
}

h3{
	margin: 20px auto;
	padding: 0;
	line-height: 100%;
	font-size: 2.0rem;
	font-weight: 900;
	text-align: center;
}

form	{	margin: 0; padding: 0;	}
header h1 {
	margin: 0 auto 30px;
}
header h1 img {
	margin: 0 10px 0 0;
	width: 380px;
}
p.copy	{
	margin: 0 auto;
	padding: 60px 0;
	font-size: 1.2rem;
	text-align: center;
}

#base{
	margin: -70px auto 20px;
	padding: 30px;
	width: 1000px;
	background: #fff;
	border: none;
	border-radius: 40px;
	line-height: 1.7;
}
#base h2.idx {
	padding: 0 0 0 1.2em;
	border: 0;
	text-align: left;
}
#base h2.idx::before {
	content: '';
    display: block;
    width: 48px;
    height: 26px;
    background-color: #ff4f75;
    position: absolute;
    left: -30px;
    top: -3px;
    border-radius: 0px 4px 4px 0px / 0px 4px 4px 0px;
    -webkit-border-top-left-radius: 0px 0px;
    -webkit-border-top-right-radius: 4px 4px;
    -webkit-border-bottom-right-radius: 4px 4px;
    -webkit-border-bottom-left-radius: 0px 0px;
}
#base h2.ttl {
	margin: 40px auto;
	padding: 10px;
	position: relative;
	font-size: 2.8rem;
}
#base h2.ttl::before {
	content: '';
    position: absolute;
    bottom: -7px;
    border-radius: 2px;
    display: inline-block;
    width: 50px;
    height: 7px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #ff4f75;
}
#base ul,#base ol		{	margin: 20px 0 20px 30px;}
#base ul li				{	list-style: disc outside ;	margin: 0; }
#base ul.circle li		{	list-style: circle outside ;}
#base ul.margin0 li		{	margin: 10px 0;}
#base ul.notype 		{	margin: 20px 0; }
#base ul.notype li		{	margin: 1em 0; list-style: none; }

#base ul {
	padding: 0;
}
#base li {
	margin: 0 0 .5em;
	list-style:none;
}
#base .asterisk li,
#base p.asterisk,
#base p span.asterisk {
	margin: 0;
	padding: 0;
	padding-left: 1em;
	text-indent: -1em;
	display: block;
	font-size: 1.5rem;
}
#base .asterisk li::before,
#base p.asterisk::before,
#base p span.asterisk::before {
  content:"※";
}

#base .lede{
	margin: 0 auto;
	padding: 50px 0;
	position: relative;
	z-index: 1;
}
#base .lede h2 {
	margin: 0 auto 40px;
	padding: 5px 20px;
	border: none;
	position: relative;
	width: 600px;
	font-size: 3.6rem;
	font-weight: 900;
	-webkit-font-smoothing: antialiased;
	text-align: center;
}
#base .lede h2::before {
	content: '';
    position: absolute;
    bottom: -15px;
    border-radius: 2px;
    display: inline-block;
    width: 50px;
    height: 7px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: #ff4f75;
}
#base .lede .ledeinner {
	margin: 0 auto;
	padding: 0;
	position: relative;
	width: 600px;
	z-index: 1;
	text-align: center;
}
#base .lede p {
	margin: 0 auto .1em;
	font-size: 1.8rem;
	font-weight: bold;
}
#base .lede p strong {
	margin: .5em 0 0;
	display: block;
	font-size: 2.8rem;
	line-height: 1.5;
	color: #a50082;
	text-align: center;
}
#base .lede p:last-of-type {
	margin-bottom: 0;
}

#base ul li strong		{	font-size: 122%; padding-right: 1em;}
#base ol li				{	list-style: decimal outside ;	margin: 0.8em;	line-height: 1.4em;}
#base ul li p			{	 margin:5px 0; padding: 0; }

#base ul li ul.innerList		{	margin: 10px 0 30px 25px;}
#base ul li ul.innerList li		{	list-style: disc outside !important; color: #ccc; margin: 1em 0;font-size: 92%;}
#base ul li ul.innerList li p	{	line-height: 1.2em;padding: 0;margin: 0; }

#base ul.ul1			{	margin: 20px 0; border: 1px solid #ccc;}
#base ul.ul1 li			{	list-style: none outside ; margin: 5px; padding: 5px; _zoom: 1; overflow: hidden;}
#base ul.ul1 li strong	{	display: block; width: 100px; float: left;}
#base .borderBox{margin: 10px 0; border: 1px solid #ccc;padding: 10px;}
#base p					{	margin: 0; font-size: 1.5rem; }
#base > ul 				{ margin-bottom: 40px;}
#base > p,  #base > p.asterisk		{ margin: 0 0 0 30px;}
#base > p:last-of-type	{ margin-bottom: 1em; }
#base p em				{	font-weight: bold;	display: block;}
#base p.name			{	line-height: 1.7em;}
#base p.catch			{	font-weight: bold; color: #000;	text-shadow: 1px 1px 0px #ddd;font-size: 14px;}

.submitBtn { 
	margin: 50px auto;
	text-align: center;
}
.submitBtn .btn {
	margin: 25px auto;
	padding: 15px;
	display: block;
	width: 320px;
	outline: none;
	overflow: hidden;
	position: relative;
	z-index: 2;
	background-color: #aaa;
	border: 2px solid #aaa;
	color: #fff;
	position: relative;
	transition: all .2s;
	border-radius: 6px;
	box-shadow: 0px 2px 0px rgba(0, 0, 0, 0.1);
	-moz-box-shadow: 0px 2px 0px rgba(0, 0, 0, 0.1);
	-webkit-box-shadow: 0px 2px 0px rgba(0, 0, 0, 0.1);
	font-size: 1.8rem;
	font-weight: 800;
	text-align: center;
	text-decoration: none;
	line-height: 1.5;
}
.btn::before,
.btn::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.btn,
.btn::before,
.btn::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
.btn:hover {
	cursor: pointer;
	background-color: #fff;
	color: #aaa;
}
.btn.back {
	background-color: #3F3F3F;
	border-color: #3F3F3F;
}
.btn.back:hover {
	cursor: pointer;
	background-color: #fff;
	color: #3F3F3F;
}
.submitBtn .submit,
.submitBtn .agree,
.submitBtn .chk,
.submitBtn .fix{
	width: 320px;
	background: #ff4f75;
	border: 2px solid #ff4f75;
	color: #ffffff;
}
.submitBtn .submit:hover,
.submitBtn .agree:hover,
.submitBtn .chk:hover,
.submitBtn .fix:hover{
	background-color: #fff;
	color: #ff4f75;
}
.tableForm table td .form-file {
	margin: 0;
	padding: 2px;
	position: relative;
	overflow: hidden;
	line-height: 1.6;
}
.tableForm table td .file-btn {
    padding: 7px 20px;
    display: inline-block;
    background-color: #718bc6;
    color: #ffffff;
	border: 2px solid #718bc6;
	border-radius: 4px;
	outline: 0;
	width: 200px;
	transform: rotate(.04deg);
	-webkit-font-smoothing: antialiased;
	font-size: 1.6rem;
	font-weight: 900;
	letter-spacing: .020em;
	line-height: 1;
	font-weight: 700;
    text-align: center;
	line-height: 1.4;
	vertical-align: middle;
	cursor: pointer;
}
.tableForm table td .form-file .file-input {
    display: none;
    position: absolute;
    width: 1px;
}
.tableForm table td .file-btn:hover {
	color: #718bc6;
	background-color: #ffffff;
}
.tableForm table td .file-btn:focus {
    border: 2px solid #718bc6;
}
.tableForm table td .file-name {
	margin: 5px 0 5px .75em !important;
	display: inline;
	font-size: 1.5rem;
}
.tableForm									{	border: rgba(0, 0, 0, 0.1) solid 1px;	width: 100%; margin: 20px 0 40px; overflow: hidden; }
.tableForm table							{	width: 100%;	margin-top: -1px; }
.tableForm table th, .tableForm table td	{	border-top: rgba(0, 0, 0, 0.1) solid 1px;	 font-weight: normal;	padding:15px 10px;word-break: break-all; }
.tableForm table th							{	width: 280px;	background: #f6f6f6; text-align: left; font-weight: bold;font-size: 1.4rem; }
.tableForm table th span					{	margin: 0 0 0 5px; padding: 2px 3px; vertical-align: 2px; font-size: 1.1rem; line-height: 1.1; font-weight: bold; color: #ffffff; background-color: #fd025aff; display: inline-block; border-radius: 3px; }
.tableForm table th span.normal				{	font-weight: normal;	color: #00B0EC;}
.tableForm table th small					{	font-size: 1.2rem; }
.tableForm table td							{	background: #fff;}
.tableForm table td label { padding: 0 1.5em 0 0;display: inline-block; font-size: 1.5rem;  }
.tableForm table td input					{	padding: 5px;}
.tableForm table td p						{	margin: 0 !important;padding-bottom: 0.5em; font-size: 1.4rem !important; }
.tableForm table td p span					{	display: block; font-size: 1.3rem; }

.tableForm table.imgup th 					{   width: 300px;}
.tableForm table td img						{	vertical-align: middle;}
.tableForm table td span.imgTitle			{	padding: 1em;}

input#Name,input#NameKana,input#PenName,input#PenNameKana,input#Job,input#Tel	{	width: 280px;}
input#Addr,input#MailAddr,input#Note,input#Title	{	width: 100%;}
input#Zip,input#DataFormat,input#BirthY	{	width: 7em;}
input#Age	{	width: 5em;}
input#Age,input#BirthY	{	margin-right: 5px; }


.tableForm input[type="text"],
.tableForm input[type="email"],
.tableForm input[type="tel"],
.tableForm textarea {
	outline: none;
	-webkit-transition: all .3s;
	transition: all .3s;
	border: rgba(0, 0, 0, 0.1) solid 1px;
}
.tableForm input[type="text"]:focus,
.tableForm input[type="email"]:focus,
.tableForm input[type="tel"]:focus,
.tableForm textarea:focus {
	box-shadow: 0 0 5px #00B0EC;
	border: 1px solid #00B0EC;
}

.tableForm input[type="radio"] , input[type="checkbox"]{
	margin: 0 0.25em 0;
}

textarea	{	width: 100%;height: 10em;overflow-y: scroll;overflow-x: hidden;font-size: 12px;}

#BumonTable1 table th,
#BumonTable2 table th,
#BumonTable3 table th	{	width: 280px;}


#inputFile				{ margin: 20px 0;	overflow: hidden; border: 1px solid #828282;padding: 10px; background: #ede7c7;color: #333;font-weight: bold; text-align: center;}

#base .completeMsg		{	margin: 40px 0; padding: 0; }
#base .completeMsg p	{	margin: 1.5em auto;		width: 600px;	font-size: 1.6rem !important; }
#base .endMsg			{	padding: 50px 0;}
#base .endMsg p			{	text-align: center;	font-size: 1.6rem;	line-height: 1.6em;}

#base .noticeMsg p,
#jsoff		{	font-size: 1.4rem;	color: #d71111; margin: 1em 0;}

#base .note {
	margin: 50px 0 20px;
	padding: 0 20px;
}
#base .note h2 {
	margin: 1.5em 0;
	font-size: 1.7rem;
	font-weight: 700;
	line-height: 1.5;
}
.noticeData,
.noticeChk{
	margin: 0 0 40px;
	padding:0 20px;
	border: rgba(0, 0, 0, 0.1) solid 1px;
	background: #f6f6f6;
}
.noticeData {
	padding: 20px;
}
#base .noticeData h3 {
	margin: 10px auto 20px;
	font-size: 1.8rem;
}
#base .noticeData h3::before {
	content: none;
}
#base .noticeData h4 {
	margin: 0 0 .5em;
}
#base .noticeData ul {
	margin: 0 30px 20px;
	padding: 0;
}
#base .noticeData ul:last-of-type {
	margin-bottom: 0;
}
#base .noticeData li {
	margin: 0 !important;
	font-size: 1.5rem;
}
#base .noticeData li ul {
	margin: 0;
}
#base .noticeChk h2{
	margin: 0 -20px;
	padding: .5em 20px;
	color: #fff;
	border-bottom: 1px solid #505050;
	background-color: #d94276;
	text-align: center;
	font-size: 1.7rem;
	font-weight: 600;
}
#base .information {
	padding: 0 15px;
}
#base .information dt {
	margin: 0 0 .5em;
	font-size: 1.8rem;
	font-weight: 900;
}
#base .information dd {
	margin: 0;
	font-size: 1.6rem;
}
#base .information ul {
	margin: 10px 0;
}
#base .information li {
	font-size: 1.4rem;
}
.example { color: #1199fd; }

.noticeChk_chk {
	margin: 1em 0;
	padding: 0px 10px;
}
.noticeChk_chk ul {
	padding-left: 0;
}
.noticeChk_chk li {
	font-weight: 600;
}
.noticeChk_chk label {
	display: block;
	margin: .75em 0;
	_zoom: 1;
	overflow: hidden;
	font-size:107.2%;
}
.noticeChk_chk label input[type="checkbox"] {
	float: left;
	margin: 5px 10px 5px 0;
	width: 15px;
	height: 15px;
}
.noticeChk_chk label span {
	display: block;
	overflow: hidden;
	_zoom: 1;
}

@media only screen and (max-width: 700px) {
	body { 
		word-break:break-all;
		font-size:1.6rem;
	}
	.pconly { display: none; }
	.sponly { display: block; }
	#base h2 { font-size: 2.4rem; }
	#base h3 { margin: 20px 0; font-size: 1.8rem; }
	#base p { font-size: 1.6rem; }
	#base{
		margin: -50px auto 0;
		padding: 20px;
		width: 100%;
	}
	#base .note {
		padding: 0;
	}
	#base ul, #base ol {
		margin: 15px 0;
		padding: 0 .5em 0 1.25em;
	}
	header h1 { margin-bottom: 20px; padding-top: 20px; }
	header h1 img 	{	margin-bottom: 0; max-width: 100%; width: 280px; height: auto; }
	header h2 { 
		padding: 10px;
		width: auto;
		font-size: 2.4rem;
		line-height:1.3;
	}
	#base p, #base .asterisk {
		font-size: 1.5rem;
	}
	#base .lede {
		padding: 30px 0 20px;
	}
	#base .lede h2 {
		width: 100%;
		font-size: 2.8rem;
	}
	#base > h2 {
		padding: 0 0 0 .75em;
	}
	#base h2.ttl {
		font-size: 2.3rem;
	}
	#base h2.idx {
		margin: 30px 0 20px;
		padding: 0 0 0 18px;
	}
	#base h2.idx::before {
		width: 38px;
		top: -5px;
	}
	#base .note h2 {
		text-align: left;
	}
	#base > p {
		margin-left: 1.2em;
	}
	#base .lede .ledeinner {
		padding: 0 1em;
		width: 100%;
	}
	#base .lede p {
		width: auto;
		font-size: 1.7rem;
		text-align: left;
	}
	.lede { margin: 0 auto 20px; padding: 0; }
	.lede .ledeinner { margin: 0 0 20px; padding: 20px; width: 100%; }
	.lede p { font-size: 1.5rem; }
	.lede p strong { display: block; font-size: 1.8rem; }
	#base ul.asterisk { margin: 1em 0; padding: 0; }
	#base .noticeData ul {
		margin: 20px 0 20px 20px;
	}
	.noticeData, .noticeChk {
		margin: 20px auto;
	}
	#base .noticeData h3,
	#base .noticeChk h3 {
		margin: 5px auto 10px;
		line-height: 1.5;
		font-size: 1.6rem;
	}
	.noticeChk_chk {
		padding: .75em 0;
	}
	.noticeChk_chk li {
		font-size: 1.5rem;
	}
	.noticeData li {
		font-size: 1.4rem;
	}
	#base .noticeChk_chk {
		padding:0;
	}
	.noticeChk_chk label {
		font-size: 1.5rem;
	}
	.noticeChk_chk label {
		margin: .5em 0;
	}
	.tableForm table th,
	.tableForm table td,
	#BumonTable1 table th,
	#BumonTable2 table th,
	#BumonTable3 table th{
		display: block;
		width: 100%;
	}
	.tableForm table th{
		font-size: 1.5rem;
	}
	.tableForm table td{
		border: none;
		font-size: 1.5rem;
	}
	input[type="text"],textarea{width: 100% !important;}
	input#Name,input#NameKana,input#PenName,input#PenNameKana,input#Tel,input#Bumon,input#DataSize,input#BirAddr	{	width: 200px;}
input#Addr,input#MailAddr,input#Note,input#Title,input#Job { width: 100%; }
	input#Male,input#Female,input#NA,input#ReviewYes,input#ReviewNo {width: auto !important;}
	input#Age,input#BirthY,input#Zip{width: 7em !important;}
	.tableForm table td input[type="file"] { line-height: 25px; font-size: 1.5rem; }
	.submitBtn { margin: 30px auto; }
	.submitBtn .btn { margin: 20px auto; }
	.submitBtn .btn, .submitBtn .submit, .submitBtn .agree, .submitBtn .chk, .submitBtn .fix {
		padding: 15px 10px;
		width: 100%;
		font-size: 1.8rem;
	}
	#base .completeMsg {
		padding: 0;
	}
	#base .completeMsg p {
		margin: 0 0 1em;
		width: auto;
		font-size: 1.5rem;
	}
}

