@charset "UTF-8";
/*
 Theme Name: Pizzeria da Lucaテーマ
 Description 消さないでください
 Theme URI: 
 Author: K
 Author URI: 
 Version: 
 License: 
 License URI: 
*/
/* =============================================================================================================================================
															【PC】
============================================================================================================================================= */

/* #################### COMMON_PAGE ################################################################################ */

/* clearfix */
.cf:after{
    content: "."; 
    display: block; 
    height: 0; 
    font-size:0;	
    clear: both; 
	visibility:hidden;
}
.cf{
	display: inline-block;
} 
* html .cf{
	height: 1%;
}
.cf{
	display:block;
}

.left {
	float: left;
}
.right {
	float: right;
}

span.anchor {
	position: absolute;
    top: -100px;
    width: 0;
    height: 0;
    visibility: hidden;
}
.is_sp {
    display: none;
}

* {
	box-sizing: border-box;
}

a {
    word-break: break-all;
	text-decoration: none;
}


/* hover */
.hover {
	transition: all .3s;
}
.hover:hover {
	opacity: .7;
}

a figure {
	overflow: hidden;
} 
a figure img {
	transition: all .3s;
} 
a:hover figure img {
	-webkit-transform: scale(1.1);
	transform: scale();
} 


/* fadein up */
.fadein {
	transition: .5s;
	opacity: 0;
}
.fadein.on {
	opacity: 1.0;
}
.fadein-up {
	transition: .5s;
	opacity: 0;
	transform: translate(0,60px); 
	-webkit-transform: translate(0,60px); 
}
.fadein-up.on {
	opacity: 1.0;
	transform: translate(0,0); 
	-webkit-transform: translate(0,0);
}
.fadein-right {
	transition: .5s;
	opacity: 0;
	transform: translate(-60px,0); 
	-webkit-transform: translate(-60px,0); 
}
.fadein-right.on {
	opacity: 1.0;
	transform: translate(0,0); 
	-webkit-transform: translate(0,0);
}
.fadein-zoom-out {
	transition: .5s;
	opacity: 0;
	transform: scale(1.2, 1.2);
	-webkit-transform: scale(1.2, 1.2);
}
.fadein-zoom-out.on {
	opacity: 1.0;
	transform: scale(1, 1);
	-webkit-transform: scale(1, 1);
}
.hover_slide {
	position: relative;
	overflow: hidden;
	z-index: 1;
	transition: .3s;
}
.hover_slide::before {
	position: absolute;
	transition: .5s;
	content: '';
	width: 0;
	bottom: 0;
	background: #000;
	height: 120%;
	left: -10%;
	-webkit-transform: skewX(15deg);
		  transform: skewX(15deg);
	z-index: -1;
}
.hover_slide:hover {
	cursor: pointer;
	color: #FFF!important;
}
.hover_slide:hover::before {
	left: -10%;
	width: 120%;
}
.hover_slide.orange::before {
	background: #FF5800;
}
.hover_slide.orange:hover {
	color: #FFF!important;
}
.hover_slide.white {
	border: solid 1px #000;
}
.hover_slide.white::before {
	background: #FFF;
}
.hover_slide.white:hover {
	color: #000!important;
}





body {
    width: 100%;
	min-width: 1050px;
	font-size: 14px;
	-webkit-text-size-adjust: 100%;
	font-family:"ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック", YuGothic, "メイリオ", "Meiryo", sans-serif;
	position: relative;
	z-index: 1;
	color: #000;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

main {
	min-height: 200px;
	min-width: 1050px;
	margin: 0 auto;
	overflow: hidden;
}
.wrap {
	width: 980px;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

img {
	max-width: 100%;
}

.left {
	float: left;
}
.right {
	float: right;
}
.clear {
	clear: both;
}

b, strong {
	font-weight: bold;
}

.mincho {
     font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",HGS明朝E,メイリオ,Meiryo,serif;
}
h2.ttl {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
}
h2.ttl span {
	display: block;
	font-size: 12px;
	font-weight: normal;
	margin-top: 1.5em;
}

/* ==================== HEADER ==================== */
header.pc {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 100px;
	width: 100%;
	z-index: 10;
}
nav.gnav {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 35px;
}
nav.gnav a {
	color: #FFF;
	transition: all .3s;
}
nav.gnav a:hover {
/*	opacity: .8;*/
}
nav.gnav ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	position: absolute;
	left: 0;
	right: 0;
	padding-top: 18px;
}
nav.gnav ul li {
	margin: 0 19px;
	text-align: center;
}
nav.gnav ul li a {
	display: inline-block;
}
nav.gnav ul li a span {
	font-size: 14px;
	font-weight: bold;
	display: block;
	margin-bottom: .6em;
}
nav.gnav ul li a b {
	font-size: 12px;
	font-weight: normal;
}
nav.gnav .logo,
nav.gnav .tel {
}

a.tel {
	display: block;
	font-size: 30px;
	font-weight: bold;
	color: inherit;
}
a.tel span {
	font-size: 14px;
	font-weight: normal;
	display: block;
	margin-top: .7em;
}

/* ==================== /HEADER ==================== */


/* ==================== FOOTER ==================== */
footer {
	background-color: #000;
	color: #FFF;
	padding: 15px 35px 50px;
	text-align: center;
}
footer p#copyright {
	font-size: 10px;
}

/* ==================== /FOOTER ==================== */


/* #################### /COMMON_PAGE ################################################################################ */



/* #################### INDEX ################################################################################ */
body.home #hero {
	position: relative;
	color: #FFF;
	width: 100%;
	height: 700px;
	overflow: hidden;
}
body.home #hero #main_slide {
	background-image: url("images/img_main01.png");
	background-size: cover;
	background-position: center;
	width: 100%;
	height: 700px;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
body.home #hero #main_slide div {
	width: 100vw;
	height: 100%;
}
body.home #hero #main_slide .slick-slide {
	background-size: cover;
	background-position: center;	
}
body.home #hero #main_slide .slide1 {
	background-image: url("images/img_main01.png");
}
body.home #hero #main_slide .slide2 {
	background-image: url("images/img_main02.png");
}
body.home #hero #main_slide .slide3 {
	background-image: url("images/img_main03.png");
}
body.home #hero .logo {
	display: block;
	width: 215px;
	margin: 0 auto;
	padding: 215px 0 75px;
	position: relative;
	z-index: 2;
}
body.home #hero h1 {
	text-align: center;
	font-size: 30px;
	position: relative;
	z-index: 2;
}
body.home #hero h1 span {
	display: block;
	font-size: 20px;
	margin-bottom: .8em;
}

body.home main > section.half {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
body.home main > section.half > div {
	width: 50%;
	height: 500px;
	text-align: center;
}
body.home #concetto > div.txt {
	padding: 120px 0 0;
}
body.home #concetto > div.txt h2 {
	margin-bottom: 2.2em;
}
body.home #concetto > div.txt p {
	font-size: 30px;
	line-height: 1.7;
	font-weight: bold;
}
body.home #concetto > div.bg {
	background-image: url("images/img_concetto.png");
	background-size: cover;
	background-position: center;
}

body.home #menu {
	min-height: 1000px;
	background-image: url("images/bakc_menu.png");
	background-size: cover;
	background-position: center;
	color: #FFF;
	padding-top: 100px;
}
body.home #menu h2.ttl {
	margin-bottom: 80px;
}
body.home #menu > div {
	width: 980px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
body.home #menu > div .menu {
	width: 450px;
	margin-bottom: 90px;
}
body.home #menu > div .menu.full {
	width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
body.home #menu > div .menu.full .slides,
body.home #menu > div .menu.full dl {
    width: 450px;
}
/*
body.home #menu > div .menu.full .slides {
    width: 100%;
    display: flex;
    justify-content: space-between;
}
body.home #menu > div .menu.full .slides dl {
    width: 450px;
}
*/
body.home #menu > div .menu dl {
	margin-top: 40px;
}
body.home #menu > div .menu.full dl {
	margin-top: 0;
}
body.home #menu > div .menu dl dt {
	font-size: 12px;
	border-bottom: solid 1px #FFF;
	padding-bottom: 1.5em;
	margin-bottom: 1.5em;
}
body.home #menu > div .menu dl dt span {
	font-size: 20px;
	font-weight: bold;
	display: inline-block;
	margin-right: 1em;
}
body.home #menu > div .menu dl dd {
	font-size: 14px;
	line-height: 2.2;
}
.slick-dots {
	position: static;
	width: 100%;
	display: flex;
	flex-wrap: wrap;
}
.slick-dots li {
	width: 23.5%;
	height: auto;
	margin: 2% 2% 2% 0;
}
.slick-dots li:nth-child(4n) {
	margin: 2% 0 2% 0;
}
.slick-dots li button {
	width: 100%;
	height: auto;
	padding: 0;
	transition: all .3s;
}
.slick-dots li button:hover {
	opacity: .9;
}
.slick-dots li button:before {
	content: '';
	display: none;
}

body.home #informazione > div {
	height: 700px;
}
body.home #informazione > div.txt {
	padding-top: 56px;
}
body.home #informazione > div.txt h2 {
	margin-bottom: 45px;
}
body.home #informazione > div.txt img {
	display: inline-block;
	margin-bottom: 30px;
}
body.home #informazione > div.txt p {
	font-size: 14px;
	line-height: 1.7;
	margin-bottom: 2em;
}
body.home #informazione > div.txt p em {
	font-weight: bold;
	display: block;
	margin-bottom: 1em;
}
body.home #informazione > div.txt h3 {
	font-size: 16px;
	line-height: 1.7;
	margin-bottom: 1.5em;
}
body.home #informazione > div.txt .online {
	display: inline-block;
	font-size: 16px;
	background-color: #000;
	color: #FFF;
	font-weight: bold;
	padding: 1.4em 2.8em;
    margin-top: 2em;
}
body.home #informazione > div.map iframe {
	width: 100%;
}

body.home #altro {
	height: 500px;
	background-image: url("images/back_altro.png");
	background-size: cover;
	background-position: center;
	color: #FFF;
	padding-top: 80px;
	text-align: center;
}
body.home #altro h2 {
	margin-bottom: 80px;
}
body.home #altro p {
	font-size: 30px;
	font-weight: bold;
	margin-bottom: 80px;
}
body.home #altro a {
	display: inline-block;
	font-size: 16px;
	background-color: #FFF;
	color: #000;
	font-weight: bold;
	padding: 1.4em 5.3em;
}


/* #################### /INDEX ################################################################################ */










/* =============================================================================================================================================
															【SMARTPHONE】
============================================================================================================================================= */
@media screen and (max-width : 767px) {
	.is_pc {
		display: none!important;
	}
	.is_sp {
		display: inherit!important;
	}
	
	body {
		padding-top: 3.2rem;
		font-size: 4vw;
	}

	
	/* drawer */
	.drawer-navbar {
		z-index: 999;
		height: auto;
	}
/*	.drawer-navbar,
	.drawer-navbar .drawer-nav,
	.drawer-navbar .drawer-menu-item {
		height: auto;
		line-height: inherit;
	}
*/
	
	.drawer--navbarTopGutter {
		padding-top: 3.2rem;
	}
	.drawer-navbar-header {
		height: 3.2rem;
		text-align: left;
		padding: 0 3%;
		border-bottom: none!important;
	}
	.drawer-navbar .drawer-navbar-header {
		background-color: #000;
	}
	.drawer-navbar .drawer-brand {
		width: 16vw;
		line-height: 3.2rem;
		padding: 0;
	}
	.drawer-navbar .drawer-brand img {
		width: 100%;
    	vertical-align: middle;
    	padding-bottom: 5%;
	}
	.drawer-hamburger {
		padding: 10px .75rem 10px;
	}
	.drawer-hamburger-icon {
		margin-top: 15px;
	}
	.drawer-hamburger-icon, .drawer-hamburger-icon:after, .drawer-hamburger-icon:before {
		height: 2px;
    	background-color: #FFF;
	}
	.drawer-hamburger-icon:before {
		top: -8px;
	}
	.drawer-hamburger-icon:after {
		top: 8px;
	}
	.drawer-navbar #menu_text {
		margin-top: 10px;
		display: inline-block;
		font-size: 0.5rem;
		font-weight: bold;
	}
	.drawer-open .drawer-hamburger {
		padding-bottom: 2rem;
	}
	.drawer-open .drawer-hamburger-icon {
		margin-top: 15px;
	}
	.drawer-open #menu_text {
		display: none;
	}
	.drawer-nav {
		width: 100%;
		background-color: #000;
		padding: 0;
	}
	.drawer--right .drawer-nav {
		right: -100%;
		padding-top: 3.2rem;
	}
	.drawer-navbar .drawer-menu li {
		border-bottom: solid 1px #FFF;
		width: 80vw;
		margin: 0 auto;
	}
	.drawer-navbar .drawer-menu li:last-child {
		border-bottom: none;
		text-align: center;
	}
	.drawer-navbar .drawer-menu li a.tel {
		color: #FFF;
		padding: 10vw 0;
	}

	.drawer-menu {
		padding: 5% 0;
	}
	.drawer-menu-item {
		color: #FFF;
		text-align: center;
		font-size: 4vw;
		letter-spacing: 0.1em;
		padding: 7vw 0;
		font-weight: bold;
	}
	.drawer-menu-item:hover {
		color: inherit;
		text-decoration: none;
	}
	.drawer-menu-item span {
		display: block;
		font-size: 4vw;
		margin-bottom: 4vw;
		color: #FFF;
	}
	.drawer-menu-item b {
		display: block;
		font-size: 3.5vw;
	}
	.drawer-navbar .drawer-menu li.sns .drawer-menu-item {
		display: inline-block;
		font-size: 2rem;
		margin: 0 2%;
	}

	span.anchor {
		top: -3.2rem;
	}
	img {
		max-width: 100%;
	}

	.wrap {
		width: auto;
	}
	
	h2.ttl {
	    font-size: 6vw;
	}
	h2.ttl span {
		font-size: 3vw;
	}

	body,
	main {
		min-width: inherit;
	}
	main {
/*		overflow: auto;*/
	}
	body.home #hero {
		height: 54vw;
	}
	body.home #hero #main_slide {
		height: 54vw;
	}
	body.home #hero .logo {
		width: 40vw;
		padding: 10vw 5vw 5vw;
	}
	body.home #hero h1 {
		font-size: 5vw;
	}
	body.home #hero h1 span {
		font-size: 3.5vw;
	}
	body.home main > section.half > div {
		width: 100%;
		height: auto;
	}
	body.home #concetto > div.txt {
		padding: 10vw 5vw;
	}
	body.home #concetto > div.txt h2 {
		margin-bottom: 5vw;
	}
	body.home #concetto > div.txt p {
		font-size: 6vw;
	}
	body.home #concetto > div.bg {
		height: 71.5vw;
	}
	body.home #menu {
		padding: 10vw 5vw 5vw;
	}
	body.home #menu h2.ttl {
		margin-bottom: 10vw;
	}
	body.home #menu > div {
	    width: auto;
	}
	body.home #menu > div .menu {
		width: 100%;
		margin-bottom: 10vw;
	}
	body.home #menu > div .menu dl,
	body.home #menu > div .menu.full dl {
		margin-top: 8vw;
	}
	body.home #menu > div .menu dl dt {
		font-size: 3vw;
	}
	body.home #menu > div .menu dl dt span {
		font-size: 5vw;
	}
	body.home #menu > div .menu dl dd {
	    font-size: 3vw;
	}
	body.home #menu > div .menu.full .slides, body.home #menu > div .menu.full dl {
		width: 100%;
	}
	.slick-list {
		 height: auto; 
	}
	.slick-dotted.slick-slider {
    	margin-bottom: 8vw;
	}
	body.home #informazione > div {
		height: auto;
	}
	body.home #informazione > div.txt {
		padding: 10vw 0;
	}
	body.home #informazione > div.txt h2 {
		margin-bottom: 5vw;
	}
	body.home #informazione > div.txt img {
		margin-bottom: 8vw;
		width: 50vw;
	}
	body.home #informazione > div.txt p {
		font-size: 4vw;
	}
	body.home #informazione > div.txt h3 {
		font-size: 4vw;
	}
	a.tel {
		font-size: 8vw;
	}
	a.tel span {
		font-size: 4vw;
	}
	body.home #informazione > div.txt .online {
		font-size: 4vw;
	}
	body.home #informazione > div.map iframe {
		height: 71.5vw;
	}
	body.home #altro {
		height: auto;
		padding: 10vw 0;
	}
	body.home #altro h2 {
		margin-bottom: 5vw;
	}
	body.home #altro p {
		font-size: 5vw;
		line-height: 1.7;
		margin-bottom: 7vw;
	}
	body.home #altro a {
    	font-size: 3.5vw;
	}
	
	footer {
		padding: 10vw 5vw 5vw;
	}
	footer a.logo {
		width: 50vw;
		margin: 0 auto 5vw;
	}
	footer nav.gnav {
		padding: 0;
		justify-content: center;
	}
	footer nav.gnav ul {
		position: static;
		padding: 0 0 10vw;
	}
	footer nav.gnav ul li {
		margin: 5vw 0;
		width: 100%;
	}
	footer nav.gnav ul li a span {
		font-size: 4vw;
	}
	footer nav.gnav ul li a b {
		font-size: 3.5vw;
	}
	footer a.tel {
		margin: 0 auto 15vw;
	}

}