*:not(br), *:not(img) {
	border:0;margin:0;padding:0;
	border-collapse:collapse;
	box-sizing: border-box;
}

html {
	min-width:320px;
	overflow-x:hidden;
}

header {
	width:100%;height: auto;
	position: fixed;
	z-index: 9999;
	top:0;left:0;right:0;
	
  background: repeating-linear-gradient(
    180deg,
    rgba(255, 255, 255, 1),
    rgba(255, 255, 255, 0.9),
    rgba(255, 255, 255, 0.6),
    rgba(255, 255, 255, 0)
  );
}

#pc_logo {
	text-align:center;
}
#pc_logo img {
	width:auto;
	max-height:90px;
	display:inline-block;
}

#sp_logo {
	display:none;
}

.frame {
	border: 1px solid #ccc;
	padding: 10px 10px 10px 10px;
	background:#fff;
	text-align:center;
}

.frame img {
	vertical-align:bottom;
}

ul, li {
	list-style:none;
	
}

#menus {
	width:100%;height:auto;
	max-width:1120px;
	max-height:100px;
	margin: 0 auto;
	display:block;
/*	position:absolute;
	z-index:9999;
	left:0;right:0;top:20px;bottom:0;*/

    -webkit-filter: drop-shadow(0px 5px 7px rgba(0,0,0,0.3));
	filter: drop-shadow(0px 5px 7px rgba(0,0,0,0.3));
}


#menus li {
	width:calc(100% / 6);
	display:inline-block;
	margin:0;padding:0;
}

#menus li:hover > a img {
-webkit-filter: grayscale(100%);
filter: grayscale(100%);
}

.acn {
	width:100%;height:100%;
	display:block;
	cursor:pointer;

	font-size:1.2em;
	color:#aaa;

	padding: 10px 20px;
	margin-bottom:10px;

	background:#fff;
	border:1px solid #aaa;
}

.acn > .icons {
	background:#e88e82;
	font-size:0.8em;
	color:#fff;
	padding:5px 10px;
	border-radius:10px;
	margin-right:10px;
}

a.acn > .fa {
	font-size:1.6em;
	line-height:1.5;
	color:#aaa;
	float:right;
}

.drop_area {
	display:none;
	background:#fff;
	
	padding:20px;
	margin:10px 0 20px;
}

.copyright{
	background:#444;
}

.copyright > a, .copyright {
	font-size:0.7em;
	color:#fff;
	text-align:center;
}

.corp_footer {
	background:#fafafa;
	padding:30px;
}

.main {
	padding-top:150px;
	min-height:90vh;
	position:relative;
}

img.rounds {
border-radius:100%;
filter: drop-shadow(3px 3px 5px rgba(0,0,0,0.6));
transition: 0.2s ease-out;
}
a:hover img.rounds {
filter: none;
transform: translate(0,2px);
}

section {
/*	min-height:100vh;
	padding: 20px 0;*/
/*	padding: 40px 0 40px;*/
    z-index:-1;
}


.w_full {
	width:100%;
	max-width:1120px;
	margin: 0 auto;
}

.w_hulf {
	width:50%;
	max-width:640px;
}

footer {
	width:100%;
	background:#eee;
	padding: 0 20px;
}

.footer_logo {
	padding: 40px 20px 20px;
	text-align:center;
}
.footer_logo img {
	max-width:270px;
}

.sitemap {
	max-width:1280px;
	margin:0 auto;
	padding:40px 0 60px;
}

.sitemap * a {
	font-size:1em;
	color:#666;
	text-decoration:none;
}

.sitemap ul {
	list-style:none;
	padding:10px;
}

.sitemap > li {
	width:25%;
	display:inline-block;

	vertical-align:top;
	padding:0 10px;
}

.sitemap > li > ul > li {
}

.sitemap > li > ul > li:not(:first-child) {
	text-indent:1.5em;
}

.sitemap .stick {
	height:30px;
	font-weight:bold;
	border-bottom:1px solid #ccc;
}

.sitemap_bottom {
	padding: 0 20px 5px;
}

.sitemap_bottom a {
	font-size:0.9em;
	color:#666;
	text-decoration:none;
	padding: 0 20px;
}

/* image */
img {
	width:auto;height:auto;
	max-width:100%;
}

img.circle {
	width:100%;
	max-width: 240px;
	border-radius: 50%;
	display:block;
	margin: 0 auto;
}

.font_red {
	background:#C13332;
	font-size:0.7em;
	color:#fff;
	padding: 0 5px;
	margin-left:20px;
}

/* text */
h1 {
	font-size:1.4em;
	letter-spacing:0.1em;
	font-weight: 600;
	text-align: center;
	margin-bottom:0.5em;
}

h2 {
	font-size:1.5em;
	font-weight: 600;
	text-align: center;
	letter-spacing:0.1em;
	margin-bottom:1em;
	color:#083967;
}

h2 span {
	font-size: 0.7em;
	letter-spacing:0.2em;
	color: #aaa;
	font-family: "Barlow", sans-serif;
	font-weight: 400;
	font-style: normal;

	display: block;
	position: relative;
}

h3 a {
  color:#222;
  text-decoration:none;
}

h3 {
/*	margin: 0 auto 20px;*/
	text-align: center;
	font-size: 1.3em;
	font-weight:bold;

    position: relative;
    padding: 0 0 0.5em;
    margin-bottom: 1em;
}

h3::before {
    position: absolute;
    border-bottom: 3px solid #444;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    width: 48px;
    content: '';
}

.sub_title {
	font-size:0.8em;
}

.font_white, .font_white * {
	color:#ffffff;
}

.hint {
	font-size:0.7em;
}

.food_mark {
	width:100%;
	display:block;

	border:1px solid #222;
	margin-bottom:20px;

	border-radius: 20px;
}

/* table */
.plan, #calc_tab {
	width:100%;
	max-width:1080px;

	margin: 0 auto;
	table-layout:fixed;
/*	border:1px solid #ccc;*/
}

.plan2 {
	width:100%;
	max-width:540px;

	margin: 0 auto;
	table-layout:fixed;
/*	border:1px solid #ccc;*/
}

.plan tr, .plan2 tr {
	border:0;
	border-bottom:1px solid #ccc;
}

.plan tr:last-child, .plan2 tr:last-child {
	border:0;
}

.plan th, .plan td {
	padding: 20px;
}

.plan2 th, .plan2 td {
	padding: 10px 15px;
}

.plan th {width:33.3%;
text-align:left;
}
.plan td {
	width:66.6%;
	border-left:1px dashed #ccc;
}

.plan2 th {width:70%;text-align:left;font-size:1.15em;}
.plan2 td {width:30%;text-align:right;font-size:1.35em;}

#calc_tab th, #calc_tab td {
	text-align:left;

	padding:10px;
}

#calc_tab td.cell1 {width:60%;}
#calc_tab td.cell2 {width:10%;}
#result {
	font-size:2.5em;
	font-weight:800;
	color:#fff;
}

.faq {
	width:100%;
	display:block;
	padding:10px;
}

.border_box {
	padding:20px;
	margin:10px 0;
	border:1px solid #ccc;
}

/* form */
.tbox {
	width:100%;height:3em;
	border:1px solid #eee;
	padding:0 10px;
}

.selectbox {
	width:100%;height:3em;
	border:1px solid #eee;
	padding:0 10px;
}

.tarea {
	width:100%;height:10em;
	border:1px solid #eee;
	padding:0 10px;

	color:#333;
}

.f_btn {
	width:100%;height:60px;

	padding:5px;

	color:#887551;
	border:1px solid #887551;
	background:#fff;
	text-align:center;

	transition: 0.2s;
	display:inline-block;
}

.f_btn:hover {
	background:#887551;
	color:#fff;
}

input:focus, textarea:focus {
	border:2px solid #ccc;
}

/* content */
.tab, .tab2 {display:table;table-layout:fixed;}
.tab_split75 {width:75%;display:table-cell;}
.tab_split70 {width:70%;display:table-cell;}
.tab_split66 {width:66.6%;display:table-cell;}
.tab_split60 {width:60%;display:table-cell;}
.tab_hulf {width:50%;display:table-cell;}
.tab_split40 {width:40%;display:table-cell;}
.tab_split33 {width:33.3%;display:table-cell;}
.tab_split30 {width:30%;display:table-cell;}
.tab_split25 {width:25%;display:table-cell;}

.m_none {margin:0;}
.m_20 {margin:20px auto;}

.p_none {padding:0;}
.p_10 {padding:10px}
.p_20, .p_20x {padding:20px;}
.p_20v {padding:0 20px;}
.p_20w {padding:20px 0;}
.p_40 {padding:40px}
.p_40v {padding:0 40px;}
.p_40w {padding:40px 0;}

.left {text-align:left;}
.center, .sp_left {text-align:center;}
.right {text-align:right;}

.top {vertical-align:top;}
.middle {vertical-align:middle;}
.bottom {vertical-align:bottom;}

p, .p_br {
	margin-bottom:30px;
}

.next_button {
	width:90%;
	max-width:480px;

	margin: 20px auto 20px;
	text-align:center;
	display:block;
}

.next_button::after {
	clear:both;
}

.next_button a {
	width:100%;height:50px;

	font-size: 1em;
	font-weight:400;
	line-height:48px;
	color:#6D3B07;
	background:#fff;
	padding-left:40px;
	border:1px solid #6D3B07;
	border-radius:25px;

	letter-spacing:0.05em;
	text-decoration:none;
	display:block;

	white-space:nowrap;
	overflow: hidden;
	text-overflow: ellipsis;

	transition: 0.2s ease-out;
}

.next_button a i {
	font-size:1.6em;
	color:#6D3B07;
	line-height:48px;
	float:right;
	padding-right:20px;
}

.next_button a:hover i {
	color:#fff;
}

.next_button a:hover {
	color:#fff;
	background:#6D3B07;
}

.next_button2 {
	width:100%;height:48px;
	max-width:640px;

	background:#C13332;
	margin:0 auto;
	text-align:center;
	display:block;

	border-radius: 0 0 0 5px;
}

.next_button2 a {
	width:100%;height:100%;

	font-weight:600;
	line-height:48px;
	color:#fff;

	display:block;

	white-space:nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.next_button2 a i {
	color:#fff;
	line-height:48px;
	margin-left:5px;
}

.next_button2:hover {
	color:#fff;
	background:#333;
}




hr.white {
	border-bottom:1px solid #ccc;
}

.pc_not {
	display:none;
}


/* link */

/* background */
.bg_000 {
	background:#ffffff;
}

.bg_001 {
	background:rgba(255,255,255,0.5);
}

.bg_002 {
	background:rgba(248,244,230, 0.6);
}

.bg_003 {
	background:#f1f5e4;
}

.bg_004 {
	background:url('/img/pattern2.png') repeat, no-repeat center bottom/cover url('/img/back2.jpg') ;
	color:#fff;
}

.bg_005 {
	background:#c8e6ff;
}

#Shop_banner {
	padding:20px;
}

.border_right {
	border-right:1px solid #ccc;
}

/*nav::after {
	clear:both;
}*/

@media only screen and (max-width: 959px) {
	#sp_logo {
		display:block;
	}
	#sp_menu {
	width:60px;height:100%;

	text-align:center;
	display:block;
	cursor:pointer;
	z-index:9999;
	border-left:#ccc 1px solid;
	float:right;
	}

	#sp_menu:hover {
	background:#ccc;
	}
	
	#sp_menu:hover i {
	color:#fff;
	}
	
	#sp_menu i {
	font-size:1.4em;
	line-height:60px;
	}

	#menu {
		list-style:none;
	}

	#menu li {
		width:100%;
		border-top:1px solid #f9f9f9;
		text-align:center;
	}

	#menu li:first-child {
		border-top:none;
	}

	#menu li a {
		width:100%;
		font-size:1.1em;
		color:#ccc;
		padding:3px;
		display:inline-block;
	}

	#menu li:hover * {
		color:#666;
		background:#eee;
	}

	
.fix_tag{
	display:none;
}
	
body{
	font-size:14px;
}

body:not(br), *:not(img) {
	line-height:2em;
}

.menu {
	display:none;
	height:0;
}

#pc_logo {
	height:60px;
	text-align:center;
}

#pc_logo img {
	width:auto;
	max-height:60px;
	padding:10px;
}

p, .p_br {
	margin-bottom:10px;
}

nav {
	width:100%;height:60px;
	position:fixed;
	display:inline-block;
	left:0;top:0;

	background:#fff;
	z-index:9997;
}

#sp_menu {
	width:60px;height:60px;
	position:fixed;
	display:block;
	top:0;right:0;
}

.main {
	padding-top:60px;
}

.border_right {
	border:0;	
}

	.sp_not {
		display:none !important;
	}

	.pc_not {
		display:inline;
	}

	#sp_logo {
	position:relative;
	}

	#sp_logo img {
	max-height:120px;
	display:block;
	margin:0 auto;
	}

	.sp_left {
		text-align:left;
	}

	section {
		padding:10px 0;
	}

section {
	padding: 0 10px;
}
.content {
	padding: 30px 20px 30px;
}

h2 {
	line-height:18px !important;
}
h2 span {
	margin-top:1em;
}

/* table */
.plan {
	width:100%;
	margin: 0 auto;
}

.plan tr {
	border:0;
}

.plan th, .plan td {
	width:100%;
	vertical-align:top;
	font-size:14px;
	
	display:block;
	padding:5px 10px;
}

.plan th {
	font-weight:600;
	text-align:center;

	background:#e9e9e9;
}

	.tab > div, .tab .tab-tr > div {
		width:100%;
		display:block;
	}

	.w_full {
		width:100%;
	}

	.sitemap {
		display:none;
	}

	.next_button {
		margin-bottom:10px;
		width:100%;
	}

}
