@import url(https://fonts.googleapis.com/css?family=Pacifico);
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url(https://fonts.googleapis.com/css?family=Josefin+Sans);
/* reset css*/

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td {
	margin: 0;
	padding: 0;
}

address, caption, cite, code, dfn, em, strong, th, var {
	font-style: normal;
}

ul {
	list-style: none;
}

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

caption, th {
	text-align: left;
}

q:before, q:after {
	content: '';
}

object, embed {
	vertical-align: top;
}

legend {
	display: none;
}

h1, h2, h3, h4, h5, h6 {
	font-size: 100%;
}

img, abbr, acronym, fieldset {
	border: 0;
}

body {
	font: 14px/1.9 'Noto Sans JP', Arial, Verdana, 游ゴシック, Yu Gothic, 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', メイリオ, Meiryo, sans-serif;
	font-weight: 300;
	-webkit-text-size-adjust: 100%;
	overflow-x: hidden;
    line-height: 1.7;
    color: #745d18;
	background-color: #fff 100% 100% fixed;
}

a {
	color: #0066ff;
	text-decoration: none;
}

a:hover, .active {
	text-decoration: underline;
}

a:active, a:focus, input:active, input:focus {
	outline: 0;
}

/* ヘッダー
------------------------------------------------------------*/

#header {
	position: relative;
	overflow: hidden;
	width: 100vw; /*元のサイズ100%*/
	height:845px; /*元のサイズ568px*/
	}

#header img {
	position: absolute;
	left: 50%;
	width: 1920px;
	height: 845px;
	margin-left: -980px;
}

#sitetitle {
	position: absolute;
	top: 15%;
	width: 100%;
	-webkit-transform: translate(0, -50%);
	transform: translate(0, -50%);
	color: #fff;
	line-height: 1.2;
	text-align: center;
	filter: drop-shadow(3px 3px 3px rgba(0, 0, 0, 0.5));
	/*ロゴのシャドー*/
	filter: drop-shadow(0 0 0.85rem #fff);
	/*ロゴのシャドー 白*/
}

#sitetitle h1 {
	font-size: 3rem;
	font-family: 'Pacifico', cursive;
	margin-bottom: 20px;
	font-weight: normal;
}

#sitetitle h2 {
	font-size: 2rem;
	font-weight: normal;
}

/* フッター
------------------------------------------------------------*/

#footer {
	clear: both;
	padding: 50px 10px 50px 0;
	text-align: center;
	font-size: 1.2rem;
	background-color: #f0f0f0;
}
.copyright {
	font-size: 1.2rem;
	background-color: #f0f0f0;
}

/* 共通
------------------------------------------------------------*/

h1, h2, h3 {
	font-family: 'Josefin Sans', 'Noto Sans JP', serif;
}

img {
	width: 100%;
	height: auto;
}

.wrapper {
    max-width: 1100px;
    margin: 0 auto;
    padding: 0 4%;
}


section {
	clear: both;
	background: #16160e;
}

section h2 {
	font-size: 22px;
	font-weight: normal;
	text-align: center;
}

section h3 {
	font-size: 150%;
	font-weight: normal;
}


.inner {
	width: 94%;
	margin: 0 auto;
	padding-bottom: 50px;
}

.col2 li {
	display: inline-block;
	width: 100%;
	margin: 20px 0 20px 0;
}

/* 見出し */
.main-title {
    font-size: 3rem;
    font-family: 'Philosopher', serif;
    text-transform: uppercase;
    font-weight: normal;
}
.sub-title {
    font-size: 1.375rem;
    padding: 0 8px 8px;
    border-bottom: 2px # solid;
    font-weight: normal;
}

/* ボタン */
.button {
    font-size: 1.375rem;
    background: #0bd;
    color: #fff;
    border-radius: 5px;
    padding: 18px 32px;
    margin-bottom:30px;
}
.button:hover {
    background: #0090aa;
}

/* iframe */
iframe {
    width: 100%;
}

/* SEC01 メインインフォメーション
------------------------------------------------------------*/

#sec01 {
	padding-bottom: 80px;
}

#sec01 h2 {
	font-size: 2.5rem;
}

.vision {
	width: 65%;
	margin: 0 auto;
	padding-bottom: 0px;
	padding-left: 25%;
	font-size: 0.85rem;
text-align: justify; /* 両端揃え(均等割り付け) */
}


.news {
	width: 65%;
	padding: 5px 20px 20px 25px;
	margin: 20px auto 20px auto;
	color: #1b1b1b;
	background: #fff;
	box-shadow: 0px 0px 0px 10px #fff;
	border: dashed 2px #9b0000;
	border-radius: 8px;
}

.news p {
	margin: 0;
	padding: 0;
}

/* SEC02 「案内」「プリンソフト」「５つのこだわり」
------------------------------------------------------------*/

#sec02 h2 {
	font-weight: bold;
	background: #16160e;
}

#sec02 {
	font-size: 16px;
	background: #fffff0;
	}

.wrap {
	clear: both;
	width: 100%;
	background: #fffff0;
}

.bg {
	line-height: 0;
	}

.
.txt h2 {
	padding: 0 0 20px !important;
}

/* SEC03 「商品種類」「PACKAGE」「悠々庵」
------------------------------------------------------------*/

#sec03 {
	padding-top: 50px;
}

.col3 li {
	margin-top: 55px;
	margin-bottom: 25px;
	padding-bottom: 35px;
}

.col3 img {
	max-width: 288px;
	display: block;
	margin: -5px auto 20px;
}

/* SEC04 （イメージ固定背景）
------------------------------*/

#sec04 {
	background: url(../images/sec04_bg.jpg) no-repeat 100% 100% fixed;
	background-size: cover;
	-webkit-background-size: cover;
	color: #fff;
}

.note {
	width: 60%;
	margin: 0 auto;
	padding-bottom: 80px;
}

.note p {
	display: inline-block;
	text-align: left;
}


/* location  店舗情報・地図
-----------------------------*/
#location {
    padding: 4% 0;
    font-size: 1rem;
}
#location .wrapper {
    display: flex;
    justify-content: space-between;
}
.location-info {
    width: 22%;
}
.location-info p {
    padding: 12px 10px;
}
.location-map {
    width: 74%;
}

/* SNS
-------------------------------*/
#sns {
    background: #FAF7F0;
    padding: 4% 0;
}
#sns .wrapper {
    display: flex;
    justify-content: space-between;
}
#sns .sub-title {
    margin-bottom: 30px;
}
.sns-box {
    width: 30%;
}

/* フッター
------------------------------- */
footer {
    background: #16160e;
    text-align: center;
    padding: 26px 0;
}
footer p {
    color: #fff;
    font-size: 1rem;
}



/* 
------------------------------------------------------------*/

@media only screen and (min-width: 1200px) {
	.inner {
		width: 1024px;
		padding-bottom: 120px;
	}
	section h2 {
		padding: 70px 0 20px;
	}
	.txt h2 {
		padding: 0 0 20px !important;
	}
}

@media only screen and (min-width: 800px) {
	body {
		font-size: 14px;
	}
	a#menu {
		display: none;
	}
	.panel {
		display: block !important;
	}
	#mainnav {
		position: fixed;
		top: 0;
		width: 100%;
		z-index: 500;
	}
	#mainnav ul {
		text-align: right;
		padding-right: 30px;
	}
	#mainnav li {
		display: inline-block;
		padding: 40px 10px 20px;
		font-size: 14px;
		font-weight: 300;
	}
	#mainnav a {
		color: #000;
	}
	#mainnav.changeNav {
		background: rgba(255, 255, 255, .9);
		border-bottom: 1px solid #d1d1d1;
	}
	#mainnav.changeNav li {
		padding: 20px 10px;
	}
	/* SEC02
------------------------------------------------------------*/
	.txt, .bg {
		width: 50%;
		float: left;
		display: table;
		background: f0f0f0;
	}
	#sec02_02 .txt, #sec02_02 .bg {
		float: right;
	}
	.vMid {
		display: table-cell;
		padding: 0 100px;
		vertical-align: middle;
	}
	/* SEC03
------------------------------------------------------------*/
	.col3 {
		text-align: center;
	}
	.col3 li {
		display: inline-block;
		width: 30%;
		padding: 0 1.5%;
		margin-bottom: 0;
		vertical-align: top;
		text-align: left;
	}
	/* SEC05 アクセス・フッター
------------------------------------------------------------*/
	#sec05 {
		padding-top: 20px;
	}

}

/* RESPONSIVE 設定
------------------------------------------------------------*/

@media only screen and (min-width: 641px) {
	.col2 li {
		width: 40%;
		padding: 0 3%;
		vertical-align: top;
	}
}

@media only screen and (max-width: 640px) {
	#map iframe {
		width: 96% !important;
		left: 2%;
	}
}


@media only screen and (max-width: 799px) {
	#sitetitle h1 {
		font-size: 31px;
	}
	#sitetitle h2 {
		font-size: 16px;
	}
	a#menu {
		display: inline-block;
		position: relative;
		width: 40px;
		height: 40px;
		margin: 10px;
	}
	#menuBtn {
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		width: 18px;
		height: 2px;
		margin: -1px 0 0 -7px;
		background: #fff;
		transition: .2s;
	}
	#menuBtn:before, #menuBtn:after {
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		left: 0;
		width: 18px;
		height: 2px;
		background: #fff;
		transition: .3s;
	}
	#menuBtn:before {
		margin-top: -7px;
	}
	#menuBtn:after {
		margin-top: 5px;
	}
	a#menu .close {
		background: transparent;
	}
	a#menu .close:before, a#menu .close:after {
		margin-top: 0;
	}
	a#menu .close:before {
		transform: rotate(-45deg);
		-webkit-transform: rotate(-45deg);
	}
	a#menu .close:after {
		transform: rotate(-135deg);
		-webkit-transform: rotate(-135deg);
	}
	.panel {
		width: 100%;
		display: none;
		overflow: hidden;
		position: relative;
		left: 0;
		top: 0;
		z-index: 100;
	}
	#mainnav {
		position: absolute;
		top: 0;
		right: 0;
		width: 100%;
		text-align: right;
		z-index: 500;
	}
	#mainnav ul {
		border-bottom: 1px solid #ccc;
		background: #fff;
		text-align: left;
	}
	#mainnav li a {
		position: relative;
		display: block;
		padding: 15px 25px;
		border-bottom: 1px solid #ccc;
		color: #000;
		font-weight: 400;
	}
	#mainnav li a:before {
		display: block;
		content: "";
		position: absolute;
		top: 50%;
		left: 5px;
		width: 6px;
		height: 6px;
		margin: -4px 0 0 0;
		border-top: solid 2px #000;
		border-right: solid 2px #000;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
    /* 店舗情報・地図 / SNS */
    #location .wrapper,
    #sns .wrapper {
        flex-direction: column;
    }
    .location-info,
    .location-map,
    .sns-box {
        width: 100%;
    }
    .sns-box {
        margin-bottom: 30px;
    }
}

@media only screen and (max-width: 1199px) {
	section h2 {
		padding: 50px 0 20px 0;
	}
	#sec01 h2 {
		padding: 70px 0 20px;
	}
	.vMid {
		padding: 0 20px;
	}
}

/* スライドショー 
------------------------------------------------------------*/

.slideWrap {
	width: 100%;
	margin: 0px auto;
}

@media screen and (max-width:767px) {
	.slideWrap {
		width: 100%;
	}
}

/* slideパターン02 
------------------------------------------------------------*/

.slide02 {
	width: 100%;
	overflow: hidden;
	position: relative;
}

.slide02 .slideInner {
	list-style: none;
	margin: 0;
	padding: 0;
}

.slide02 .slideInner li {
	position: absolute;
	width: 100%;
	background: #fff;
	margin: 0;
	padding: 0;
}

.slide02 .slideInner li img {
	width: 100%;
}

/* トップに戻るボタン 
------------------------------------------------------------*/

.pagetop {
	color: #fff;
	background-color: rgba(0, 0, 0, 0.3);
	text-decoration: none;
	display: none;
	position: fixed;
	bottom: 1rem;
	right: 1rem;
	font-size: 1.5rem;
	width: 3.3rem;
	height: 3.3rem;
	line-height: 3.3rem;
	border-radius: 3.3rem;
	text-align: center;
	cursor: pointer;
}

.pagetop:hover {
	color: #fff !important;
	background-color: #ed702b;
	text-decoration: none;
}