@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@700&family=Lato:wght@400;700&display=swap");
@import url("w2default.css");
* { font-family: "Lato", sans-serif; color: #404040; font-size: 18px; }

html, body { scroll-behavior: smooth; }

html { background-color: #fff; }

body { min-width: 300px; }

h1, h1 * { font-family: "Josefin Sans", sans-serif; font-size: 60px; line-height: 64px; }

h1, h2 { margin-bottom: 20px; }

h2, h2 * { font-family: "Josefin Sans", sans-serif; font-size: 30px; line-height: 34px; text-transform: uppercase; color: #404040; }

h3 { padding-top: 20px; }

h3, h3 * { font-size: 30px; line-height: 30px; text-transform: uppercase; }

h4, h4 * { font-size: 30px; line-height: 30px; }

h5, h5 * { font-size: 14px; line-height: 17px; }

h6, h6 * { font-size: 12px; line-height: 15px; }

p { margin-bottom: 10px; }

input[type="email"], input[type="password"], input[type="text"], input[type="number"], textarea { background: transparent; border-color: #fff; font-size: 16px; line-height: 18px; height: 40px; }

input[type="submit"] { background-color: transparent; font-family: "Josefin Sans", sans-serif; color: #fff; font-size: 16px; line-height: 18px; height: 40px; border: solid 2px #fff; transition: border 0.3s ease; }

input[type="submit"]:hover { background-color: #fff; color: #9200e6; }

select { height: 40px; border-color: #fff; }

.label { font-family: "Josefin Sans", sans-serif; font-size: 10px; text-transform: uppercase; display: flex; justify-content: space-between; }

.label .mandatory:before { content: "*"; color: #fff; display: block; height: 10px; line-height: 16px; }

.wrapper { width: 1170px; }

.box-knowmore { text-align: center; padding-top: 50px; }

.btn { background-color: #9200e6; height: 50px; padding: 0 20px; font-weight: 700; color: #fff; text-transform: uppercase; font-size: 16px; }

.btn:hover { background-color: #c363fa; }

blockquote { padding: 50px 100px; font-size: 40px; line-height: 45px; font-weight: 700; color: #c363fa; display: flex; }

blockquote:before { background: url("../images/icon-blockquote.svg") no-repeat center center; background-size: contain; content: ""; display: block; width: 55px; height: 55px; flex-shrink: 0; margin-right: 30px; }

.general-section { padding: 100px 0; scroll-margin: 100px; }

.general-section .title { margin-bottom: 50px; }
.general-section .title h2 { position: relative; display: flex; flex-direction: column; align-items: center; margin-bottom: 0; text-align: center; }
.general-section .title h2:after { background-color: #c363fa; content: ""; display: block; width: 170px; height: 2px; margin-top: 20px; }

.cover { background-position: center center; background-size: cover; background-repeat: no-repeat; }

/* ###########################################
			   MOBILE MENU
########################################### */
#mobile-menu-switch { background-color: transparent; flex-direction: column; justify-content: space-between; position: fixed; top: 30px; right: 20px; width: 40px; height: 40px; z-index: 12; cursor: pointer; padding: 10px 5px; transition: all 0.1s ease; }

#mobile-menu-switch span { background-color: #fff; display: block; width: 25px; height: 2px; border-radius: 2px; transition: all 0.1s ease; pointer-events: none; }

#mobile-menu-switch.active { justify-content: center; }

#mobile-menu-switch.active span:nth-child(1) { background-color: #fff; transform: rotate(45deg); margin-top: 2px; }

#mobile-menu-switch.active span:nth-child(2) { opacity: 0; height: 0; width: 0; }

#mobile-menu-switch.active span:nth-child(3) { background-color: #fff; transform: rotate(-45deg); margin-top: -2px; }

#mobile-menu { background-color: #000; width: 280px; height: 100%; position: fixed; top: 0; right: -290px; padding-top: 130px; z-index: 11; transition: all 0.3s ease; }

#mobile-menu.active { right: 0; box-shadow: -10px -10px 30px rgba(0, 0, 0, 0.2); }

#mobile-menu .container { height: 100%; overflow-y: auto; }

#mobile-menu a { font-size: 16px; color: #fff; text-transform: uppercase; text-align: center; padding: 20px; display: block; border-bottom: solid 1px rgba(255, 255, 255, 0.1); position: relative; transition: background-color 0.3s ease; }

#mobile-menu .right a { width: 80%; padding: 0; margin: 30px auto 0; display: flex; justify-content: center; }

#mobile-menu a:hover, #mobile-menu li.active { background-color: #9200e6; }

header { background-color: transparent; position: fixed; left: 0; top: 0; width: 100%; z-index: 10; transition: background 0.3s ease; }

body.truncated header { background-color: #000; }

header * { font-family: "Josefin Sans", sans-serif; color: #fff; }

header .wrapper { display: flex; justify-content: space-between; height: 100px; align-items: center; }
header .wrapper .left { display: flex; align-items: center; height: 100%; }
header .wrapper .left .header-logo { display: block; margin-right: 84px; }
header .wrapper .left .header-logo img { color: #9200e6; font-size: 30px; max-height: 76px; }
header .wrapper .left nav ul { display: flex; height: 100%; }
header .wrapper .left nav ul li { margin-left: 30px; height: 100%; }
header .wrapper .left nav ul li a { font-size: 16px; line-height: 20px; text-transform: uppercase; white-space: nowrap; position: relative; height: 100%; display: flex; align-items: center; transition: color 0.3s ease; }
header .wrapper .left nav ul li a:before { content: ""; background-color: #c363fa; width: 100%; height: 4px; bottom: 0px; display: block; position: absolute; opacity: 0; transition: bottom 0.3s ease, opacity 0.3s ease; pointer-events: none; }
header .wrapper .left nav ul li a:after { content: ""; background-color: #9200e6; display: block; width: 10px; height: 10px; bottom: 0px; left: 50%; transform: translateX(-50%) rotate(45deg); position: absolute; opacity: 0; transition: bottom 0.3s ease, opacity 0.3s ease; pointer-events: none; }
header .wrapper .left nav ul li a:hover:before, header .wrapper .left nav ul li.active a:before { bottom: -14px; opacity: 1; }
header .wrapper .left nav ul li a:hover:after, header .wrapper .left nav ul li.active a:after { bottom: -17px; opacity: 1; }
header .wrapper .right { height: 100%; display: flex; align-items: center; }
header .wrapper .right a { background: transparent; border: solid 2px #fff; height: 40px; padding-top: 2px; transition: background 0.3s ease, border 0.3s ease; }
header .wrapper .right a:hover { background-color: #9200e6; border-color: #9200e6; }

footer { background-color: #404040; padding: 20px 0; }
footer .wrapper { display: flex; align-items: flex-start; justify-content: space-between; }
footer .wrapper * { color: #fff; font-size: 12px; line-height: 15px; }
footer .wrapper .left { margin-right: 30px; margin-top: 10px; }
footer .wrapper .left a { display: inline-block; margin-left: 10px; }
footer .wrapper .left a img { height: 20px; position: relative; top: 2px; }
footer .wrapper .left p { margin-bottom: 3px; }
footer .wrapper .mid { display: flex; margin-right: 30px; white-space: nowrap; }
footer .wrapper .mid p { margin-bottom: 0; white-space: nowrap; padding-top: 10px; margin-right: 3px; }
footer .wrapper .mid ul { display: flex; flex-wrap: wrap; }
footer .wrapper .mid ul li { margin: 3px; }
footer .wrapper .mid a { display: inline-flex; justify-content: center; align-items: center; width: 30px; height: 30px; border: solid 1px #fff; transition: all 0.3s ease; }
footer .wrapper .mid a:before { font-family: FontAwesome; color: #fff; font-size: 13px; }
footer .wrapper .mid a:hover { background-color: #fff; }
footer .wrapper .mid a:hover:before { color: #404040; }
footer .wrapper .mid .facebook:before { content: ""; }
footer .wrapper .mid .twitter:before { content: ""; }
footer .wrapper .mid .instagram:before { content: ""; }
footer .wrapper .mid .linkedin:before { content: ""; }
footer .wrapper .mid .pinterest:before { content: ""; }
footer .wrapper .mid .vimeo:before { content: ""; }
footer .wrapper .mid .youtube:before { content: ""; }
footer .wrapper .mid .behance:before { content: ""; }
footer .wrapper .right { margin-top: 10px; }
footer .wrapper .right p { display: flex; white-space: nowrap; }
footer .wrapper .right a { margin-left: 10px; }
footer .wrapper .right a img { height: 20px; }

.grid-b { display: grid; grid-gap: 30px; grid-template-columns: repeat(3, 1fr); }
.grid-b .grid-item { position: relative; }
.grid-b .grid-item .content { position: absolute; width: 100%; height: 100%; left: 0; top: 0; padding: 40px; z-index: 2; display: flex; flex-direction: column; justify-content: flex-end; }
.grid-b .grid-item .content * { color: #fff; }
.grid-b .grid-item .content .type { font-size: 14px; text-transform: uppercase; margin-bottom: 10px; }
.grid-b .grid-item .content .name { font-family: "Josefin Sans", sans-serif; font-size: 16px; text-transform: uppercase; margin-bottom: 15px; }
.grid-b .grid-item .content .price { font-family: "Josefin Sans", sans-serif; font-size: 30px; border-top: dotted 2px #fff; padding-top: 15px; }
.grid-b .grid-item .image img { width: 100%; position: relative; }
.grid-b .grid-item .image:before { background: url("../images/menu-items-mask.png") no-repeat center center; background-size: cover; content: ""; display: block; width: 100%; height: 100%; position: absolute; left: 0; top: 0; z-index: 1; }

.grid-c { display: grid; grid-gap: 30px; grid-template-columns: repeat(2, 1fr); }
.grid-c .grid-item { background-color: #9200e6; }
.grid-c .grid-item * { color: #fff; font-size: 18px; }
.grid-c .grid-item .image img { width: 100%; }
.grid-c .grid-item .content { padding: 50px; }
.grid-c .grid-item .name { font-family: "Josefin Sans", sans-serif; text-transform: uppercase; font-size: 20px; }
.grid-c .grid-item p { font-weight: 700; }
.grid-c .grid-item span { font-weight: 400; }

#banner { background: #9200e6; min-height: 100vh; height: 100vh; position: relative; }
#banner * { color: #fff; }
#banner .banner-background { background: url("../images/imagem-banner.jpg") no-repeat center center; background-size: cover; position: absolute; width: 100%; height: 100%; left: 0; top: 0; z-index: 1; }
#banner .banner-background:before { background: url("../images/banner-top-mask.png"); background-size: 100% 100%; content: ""; height: 338px; width: 100%; display: block; position: absolute; top: 0; left: 0; z-index: 2; }
#banner .banner-background:after { background-color: rgba(0, 0, 0, 0.3); content: ""; height: 100%; width: 100%; display: block; position: absolute; top: 0; left: 0; z-index: 1; }
#banner .wrapper { display: flex; position: relative; height: 100%; z-index: 2; }
#banner .wrapper .left { width: 50%; display: flex; align-items: center; justify-content: center; }
#banner .wrapper .left h1 { margin-bottom: 10px; }
#banner .wrapper .left p { font-size: 20px; line-height: 24px; margin-bottom: 30px; }
#banner .wrapper .right { display: flex; align-items: center; width: 50%; padding-left: 15px; }
#banner .wrapper .scroll-info { position: absolute; bottom: 40px; left: 0; display: flex; align-items: center; }
#banner .wrapper .scroll-info .icon { background: url("../images/scroll-arrow.png") no-repeat center center; display: block; width: 15px; height: 15px; margin-right: 10px; }
#banner .wrapper .scroll-info .text { font-size: 14px; line-height: 20px; }

#conceito { background: url("../images/bg-white.jpg"); background-size: 100% auto; }
#conceito .wrapper .content { display: flex; }
#conceito .wrapper .content .left { width: 50%; flex-shrink: 0; }
#conceito .wrapper .content .left img { width: 100%; }
#conceito .wrapper .content .right { background-color: #9200e6; width: 50%; padding: 80px; margin-top: 50px; }
#conceito .wrapper .content .right p, #conceito .wrapper .content .right p * { color: #fff; line-height: 24px; }

#ementa { background: url("../images/bg-wood.jpg") repeat top center; padding-bottom: 0; }
#ementa .title h2, #ementa .title h2 * { color: #fff; }

#menu-groups { background: #9200e6; padding: 100px 0; margin-top: 100px; }
#menu-groups .title h2, #menu-groups .title h2 * { color: #fff; }
#menu-groups .wrapper .content { display: flex; align-items: center; }
#menu-groups .wrapper .content .left { width: 50%; flex-shrink: 0; }
#menu-groups .wrapper .content .left img { width: 100%; }
#menu-groups .wrapper .content .right { background-color: #9200e6; width: 50%; padding-left: 30px; }
#menu-groups .wrapper .content .right p, #menu-groups .wrapper .content .right p * { color: #fff; font-size: 24px; line-height: 30px; }

#contactos { background-color: #9200e6; position: relative; }
#contactos .title h2, #contactos .title h2 * { color: #fff; }
#contactos .wrapper * { color: #fff; }
#contactos .wrapper .content { display: flex; }
#contactos .wrapper .content .left { width: 30%; padding-right: 50px; }
#contactos .wrapper .content .left h4 { display: flex; align-items: center; }
#contactos .wrapper .content .left h4, #contactos .wrapper .content .left h4 * { font-family: "Josefin Sans", sans-serif; text-transform: uppercase; font-size: 18px; line-height: 23px; font-weight: bold; margin-bottom: 10px; white-space: nowrap; }
#contactos .wrapper .content .left h4:after { background-color: #fff; content: ""; display: block; height: 1px; width: 100%; margin-left: 10px; }
#contactos .wrapper .content .left .box:not(:last-child) { margin-bottom: 30px; }
#contactos .wrapper .content .left .box.phones p { margin-bottom: 30px; }
#contactos .wrapper .content .left .box.emails p { margin-bottom: 0px; }
#contactos .wrapper .content .right { width: 70%; padding-left: 50px; }
#contactos .wrapper .content .right form { display: flex; flex-wrap: wrap; }
#contactos .wrapper .content .right form .box { margin-bottom: 20px; }
#contactos .wrapper .content .right form .box-name { width: calc(50% - 15px); margin-right: 15px; }
#contactos .wrapper .content .right form .box-email { width: calc(50% - 15px); margin-left: 15px; }
#contactos .wrapper .content .right form .box-subject { width: calc(70% - 15px); margin-right: 15px; }
#contactos .wrapper .content .right form .box-phone { width: calc(30% - 15px); margin-left: 15px; }
#contactos .wrapper .content .right form .box-message { width: 100%; }
#contactos .wrapper .content .right form .box-message .message { height: 200px; }
#contactos .wrapper .content .right form .bot { width: 100%; display: flex; align-items: center; }
#contactos .wrapper .content .right form .bot .left { width: 50%; font-size: 12px; display: flex; }
#contactos .wrapper .content .right form .bot .left .mandatory:before { content: "*"; color: #fff; display: block; height: 10px; line-height: 23px; margin-right: 10px; }
#contactos .wrapper .content .right form .bot .right { width: 50%; text-align: right; }
#contactos .wrapper .content .right form .bot .right .submit { width: 170px; }
#contactos .wrapper .content .right form .bot .right .submit:hover { color: #9200e6; }

#galeria { background-color: #fff; width: 100%; height: 600px; position: relative; padding: 0; }

#galeria .swiper-container { height: 100%; }

#galeria .swiper-slide { width: auto; position: relative; }

#galeria .swiper-slide img { display: block; max-width: 100%; max-height: 100%; }

#galeria .swiper-pagination { bottom: 0; font-family: "Josefin Sans", sans-serif; color: #fff; font-size: 20px; padding-bottom: 10px; }

#galeria .swiper-pagination:after { background-color: #9200e6; content: ""; display: block; width: 90px; height: 90px; opacity: 0.5; position: absolute; bottom: -45px; left: calc(50% - 45px); transform: rotate(45deg); z-index: -1; }

#galeria .swiper-pagination span { font-family: "Josefin Sans", sans-serif; color: #fff; font-size: 20px; }

#galeria .swiper-slide { filter: grayscale(100%); opacity: 0.3; transition: filter 0.3s ease, opacity 0.3s ease; }

#galeria .swiper-slide.swiper-slide-active { filter: none; opacity: 1; }

#restaurantes { background: url("../images/bg-white.jpg"); background-size: 100% auto; }
