@charset "utf-8";

:root {
	--wide: 1275px;
	--text: #333333;
	--red: #b81c22;
	--lgray:#FAFAFA;
	--gray: #ABABAB;
	--black: #000;
	--wh: #fff;
	--pink: #FFCBCE;
}
#Contents * {
		font-family: 'Noto Sans JP','メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',Arial,Helvetica,sans-serif;
}
/*Common*/
br.PC {
	display: block;
}
br.RWD {
	display: none;
}
.MT {
	margin: auto 0 0 0;
}
.MR {
	margin: 0 auto 0 0;
}
.MB {
	margin: 0 0 auto 0;
}
.ML {
	margin: 0 0 0 auto;
}
.Flex {
	width: 100%;
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	gap: 1.5em;
	margin: 2em 0;
	flex-wrap: wrap;
}
.Flex li {
	flex: 0 1 auto;
}
.Flex.Fl_1 li {
	flex: 1;
}
.Flex.Two.Center {
	align-items: center;
}
.Flex.Two li {
	width: calc((100% / 2) - 1em);
}
.Flex.Four li {
	width: calc((100% / 4) - 1.2em);
	display: flex;
	flex-direction: column;
	justify-content: space-around;
	background: var(--wh);
}
.Flex.Col {
	flex-direction: column;
}
.Flex.Bet {
	justify-content: space-between;
}
.Flex.NwpPC {
	flex-wrap: nowrap;
}
.Flex.Start {
	align-items: flex-start;
}
.Flex.End {
	align-items: flex-end;
}
.Flex.Auto {
	width: auto;
}
.Flex.AlCenter {
	align-items: center;
}
#Contents h2 {
	display: flex;
	align-items: center;
	margin: auto auto 1em;
	font-size: 2.5em;
	background: var(--wh);
	gap: 1em;
	color: var(--text);
}
#Contents h2::before,
#Contents h2::after {
	content: "";
	height: 1px;
	width: 100%;
	flex: 1;
	background: var(--text);
}
.TextStyle1.Bold {
	font-weight: bold;
	font-size: 1em;
	text-align: center;
}
.Grid4 .Flexbox.ImgTxt {
	display: flex;
	margin: 0 0 3em;
}
.Grid4 .Flexbox.ImgTxt li.Img {
	margin: 0 1.5em 0 0;
}

.Grid4 .Flexbox.ImgTxt li.Txt {
	border-left: 1px dotted #a7a7a7;
	padding: 0 0 0 1.5em;
}

.Grid4 .Section .Flexbox.ImgTxt h3 {
	border-bottom: none;
}
.Grid4 .Section {
	padding: 4em 0;
}
.Grid4 .Section.Narrow {
	padding: 2em 0;
}
div#topAdvantage ul.topAdvList li p.img {
    width: 132px;
    height: 120px;
    margin: 0 1em 0 0;
}

.footerContact dl dt::before {
	content: none;
}
.GridSet br.pc {
  display: inline;
}
.GridSet br.sp {
  display: none;
}
.bistromate_top {
  width: 100%;
}
.bistromate_top .Section {
  max-width: var(--wide);
  margin-left: auto;
  margin-right: auto;
}
.Section p.mb80 {
  margin-bottom: 80px;
}
.Section h3.topAdvList_title {
  border: none;
  padding: 0;
  margin-bottom: 30px;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}
ul.btn li {
	width: 465px;
	margin: 2em auto;
}
.Section ul.btn li a:link {
	color: var(--wh);
}
.Section ul.btn li a {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1em;
	width: 100%;
	background: var(--black) url(/-/media/ind/bistromate/image/ico_btn_01.png) no-repeat 96% center;
	line-height: 50px;
	font-weight: bold;
	font-size: 1.2em;
	color: var(--wh);
	text-align: center;
	text-decoration: none;
	opacity: 1;
	transition: opacity .08s ease;
}
.Section ul.btn li a:hover,
.Section ul.btn li a:active {
	opacity: .8;
}
.Section a:link,
.Section a:visited {
	color: var(--red);
}
.Section .TextStyle1 {
	font-size: 1em;
}
.Section ul.linkR li a {
	padding: 0 14px 0 0;
	line-height: 1.6;
	background: url(/-/media/ind/bistromate/image/ico_tri_02.gif) no-repeat right center;
	color: var(--red);
	font-size: 1em;
	text-decoration: none;
}
/* sec_fv */
.Section.sec_fv {
  max-width: 100%;
  height: auto;
  background: url(/-/media/ind/bistromate/image/top/bg_title.jpg) center center no-repeat;
  background-size: cover;
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
	padding: 0 1em;
}
.Section.sec_fv .Inner {
  width: 100%;
  max-width: var(--wide);
}
.Section.sec_fv .Flex {
	gap: 1em;
	flex-wrap: nowrap;
}
.Section.sec_fv .Flex li {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
}
.Section.sec_fv .lead {
	text-align: center;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 20px;
}
.Section.sec_fv .subtit {
  font-size: 36px;
  font-weight: bold;
  line-height: 1.3;
  margin-bottom: 20px;
  text-shadow: 2px 2px 1px rgba(0, 0, 0, 0.16);
}
.Section.sec_fv h1 {
  margin-bottom: 1.5em;
  position: relative;
}
.Section.sec_fv .bubble {
  text-align: center;
	background: var(--wh);
	padding: 1em;
	border-radius: 5px;
}
.Section.sec_fv .bubble p {
  font-size: 1.4em;
  font-weight: bold;
}
.Section.sec_fv .bubble p span {
	font-size: 1.6em;
	padding: 0 .25em;
}
.Section.sec_fv .btn {
  text-align: left;
  margin-bottom: 0;
}
.Section.sec_fv .btn li {
  width: 465px;
}
#Contents .Section.sec_fv .btn li a {
  height: 100%;
	background-color: var(--red);
  background-position: calc(100% - 20px) center;
  font-size: 1.4em;
	color: var(--wh);
  font-weight: bold;
  letter-spacing: 0.1em;
}
div#topAdvantage.sec_function ul.topAdvList li {
  border: none;
}
div#topCase ul.topCaseList{
  display: flex;
	gap: 1em;
  justify-content: center;
	margin: auto;
	align-items: stretch;
}
div#topCase ul.topCaseList li {
	flex: 1;
	padding: 1em;
	background: var(--lgray);
}
div#topCase ul.topCaseList li div {
	display: flex;
	gap: 1em;
}
div#topCase ul.topCaseList li .img {
	width: max-content;
	padding: 1em;
	background: var(--wh);
}
div#topCase ul.topCaseList li .linkR {
	margin: 0 0 0 auto;
	width: max-content;
}
div#topCase ul.topCaseList dt {
	font-weight: bold;
}
div#topCase h2{
  font-size: 32px;
  font-weight: normal;
  color: #333;
  text-align: center;
}
/* sec_cta */
.Section.sec_cta {
  margin-top: 15px;
  padding-bottom: 0;
  margin-bottom: 60px;
}
.Section.sec_cta p {
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  margin-bottom: 20px;
}
.Section.sec_cta .btn {
  margin-bottom: 0;
}
.Section.sec_cta .btn li {
  width: 465px;
}
.Section.sec_cta .btn li a {
  height: 100%;
  line-height: 63px;
  background-position: calc(100% - 20px) center;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.1em;
}
.Section .Rotation {
	overflow: hidden;;
}
.Section .Rotation > .slick-slide {
	width: 230px;
	margin: 0 .5em;
}
.Rotation .prev.slick-arrow,
.Rotation .next.slick-arrow {
	position: absolute;
	width: 2em;
	height: 80px;
	padding: .25em;
	transition: .08s ease-in;
	background: rgba(0,0,0,.3);
	color: var(--wh);
	font-weight: bold;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 999;
}
.Rotation .next.slick-arrow {
	right: 0;
}
.Rotation .next.slick-arrow,
.Rotation .prev.slick-arrow {
	top: 20px;
}
.Rotation .prev.slick-arrow:hover,
.Rotation .next.slick-arrow:hover {
	background: rgba(0,0,0,.5);
}
.slick-dotted.slick-slider {
	margin-bottom: 0;
}
#News {
	max-width: 965px;
	margin: auto;
	border-radius: 20px;
	border: 1px solid var(--gray);
}
#News .Inner {
	padding: 1em 2em 2em;
}
#News h2 {
	color: var(--text);
	font-size: 2em;
	text-align: center;
	width: max-content;
	margin: auto;
	padding: 0 1em;
	background: var(--wh);
	transform: translateY(-1em);
}
#News dl {
	display: flex;
	align-items: center;
	gap: 1em;
	margin: .25em 0;
}
#News dl dt {
	display: flex;
	align-items: center;
	gap: .5em;
	line-height: 1;
}

.Section .txt {
	width: max-content;
	margin: auto;
}
.Section h3 {
	font-size: 1.8em;
	border: none;
	background: transparent;
}
.FuncList {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	align-content: space-between;
	height: 100%;
}
.FuncList h3 {
	font-size: 1.2em;
	background: var(--pink);
	color: var(--black);
	border: none;
	padding: 1em;
}
.Flex.Service li {
	width: calc((100% / 2) - 1em);
	border-radius: 10px;
	background: var(--lgray);
	padding: 1em;
}
.Flex.Service li .TextStyle1 {
	margin: 0;
}
.List {
	margin: 0 0 1em 1.5em;
}
.List li {
	list-style-type: disc;
}
.Flex.NwpPC.Point .ImgOnlyStyle {
	margin: auto;
	text-align: center;
}
/* スライダー再生ボタン */
.Rotation_btn {
  width: 30px; 
  height: 30px;  
  background-color: #fff;  
  border-radius: 50%; 
  position: relative; 
  cursor: pointer;    
  border: solid 2px #666;
}
.Rotation_btn::after {
  content: ''; 
  width: 5px;  
  height: 13px; 
  border-width: 0 3px 0 3px; 
  border-color: transparent #666 transparent #666; 
  border-style: solid;  
  position: absolute; 
  top: 50%;  
  left: 50%; 
  transform: translate(-50%,-50%);
}
.Rotation_btn.playback::after {
  width: 0;    
  height: 0;   
  border-width: 5px 0 5px 10px;  
  border-color: transparent transparent transparent #666; 
	 
}
.play_button_wrap{
    text-align: center;
}

@media screen and (max-width: 995px) {
	.JS .Rotation .next.slick-arrow {
		right: -15px;
	}
	.JS .Rotation .prev.slick-arrow {
		left: -15px;
	}
}

@media screen and (max-width: 994px) {
  .GridSet br.pc {
    display: none;
  }
  .GridSet br.sp {
    display: inline;
  }
  .Section.sec_fv .Inner {
    padding: 26vw 15px 40px 15px;
  }
  .Section.sec_fv .lead {
    font-size: 17px;
    text-align: center;
  }
  .Section.sec_fv .subtit {
    text-align: center;
  }
  .Section.sec_fv h1 {
    padding: 0;
  }
  .Section.sec_fv h1 .bubble p {
    font-size: 1.6em;
    padding: 0;
		font-weight: bold;
    padding-bottom: 1em;
  }
	.JS #Contents .Section.sec_fv .btn li a {
		width: 100%;
		padding: .5em 2em;
	}
	.JS .Section.Narrow .Flex.Bet {
		flex-direction: row;
	}
	.JS .Section.Narrow .Flex.Bet li {
		width: max-content;
	}
	.JS #News {
		margin: 1em;
		width: auto;
	}
  /* sec_cta */
  .Section.sec_cta ul.btn li {
    width: 100%;
  }
  div#topCase ul.topCaseList{
    display: block;
  }
	.JS .Section {
		padding: 2em 1em;
	}
	.JS .Flex.Bet {
		gap: 1em;
		justify-content: start;
		margin: 2em auto;
	}
}
@media screen and (max-width: 767px) {
	.JS .Section.sec_fv {
		padding: 0;
	}
	.JS .Flex.Bet {
		flex-wrap: wrap;
	}
	.JS .Flex.Bet li {
		width: 100%;
	}
	.JS .Flex.Service li {
		width: calc((100% / 3) - 1.2em);
	}
	.JS .Section.sec_function .Flex {
		flex-direction: column;
	}
	.JS .Section.Narrow .Flex.Bet li {
		width: calc((100% / 3) - .7em);
	}
	.JS .txt3 {
		padding: 1em;
	}
}
@media screen and (max-width: 579px) {
	.JS .Flex.Service li,
	.JS .Flex.NwpPC.Point li {
		width: calc((100% / 2) - 1em);
	}
	.JS .Flex.NwpPC.Point {
		flex-wrap: wrap;
	}
	.JS .Flex.NwpPC.AlCenter {
		flex-direction: column;
	}
	.JS .Section.Narrow .Flex.Bet li {
		width: calc((100% / 2) - .7em);
	}
	.JS #News dl {
		flex-direction: column;
		align-items: flex-start;
	}
	.JS ul.btn li {
		width: 100%;
	}
	.JS .Section ul.btn li a {
		line-height: 1.2;
		text-align: left;
	}
}