﻿@charset "UTF-8";

/* Index =============================

    1. headline
    2. pathBlock
    3. mainBlock
    4. mvBox
    5. ptBox
    6. col2Box
    7. menuList
    8. themeBox
    9. recipeCap
    10. media screen

   =================================== */

/* -----------------------------------
    1. headline
   ----------------------------------- */
.hdline01 {
  background-color: #e7c057;
  margin-bottom: 12px;
}

.hdline01 h1 {
  color: #333;
  font-weight: normal;
  letter-spacing: .125em;
  padding: 1px 24px;
}

.hdline02 {
  position: relative;
}

.hdline02 h1 {
  border-bottom: 1px solid #f7e8c3;
  color: #e7c057;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', 'Meiryo UI', 'メイリオ', meiryo, 'Hiragino Kaku Gothic ProN', meiryo, sans-serif;
  font-size: 2.62rem;
  margin: 0 0 3px 270px;
  padding: 7px 0 10px;
}

.hdline02 h1::before {
  background-color: #e7c057;
  box-sizing: border-box;
  color: #333;
  content: attr(data-title);
  display: inline-block;
  font-family: 'LumberjackR';
  font-size: 2.86rem;
  font-weight: normal;
  left: 0;
  line-height: 1.75;
  padding: 5px 0;
  position: absolute;
  text-align: center;
  top: 0;
  width: 254px;
}

.hdline02 div {
  background-color: #e7c057;
  cursor: pointer;
  height: 38px;
  position: absolute;
  right: 0;
  top: 18px;
  line-height: 1;
  width: 38px;
}

.hdline02 div::before {
  background-color: #333;
  color: #e7c057;
  content: attr(data-title);
  font-family: 'LumberjackR';
  font-size: 1.5rem;
  line-height: 1;
	letter-spacing: 0;
  font-weight: bold;
  position: absolute;
  text-align: center;
  top: -19px;
  width: 100%;
}

.hdline02 div img {
  height: 38px;
  width: 38px;
}


/* ----------------------------------- */


/* -----------------------------------
    2. pathBlock
   ----------------------------------- */
.pathBlock {
  background: #f9eac5;
  color: #333;
}

.pathBlock ul {
  font-size: 1.4rem;
  line-height: 1.4;
  margin: 0 auto;
  padding: 14px 12px;
  width: 1024px;
}

.pathBlock li {
  display: inline-block;
}

.pathBlock li:not(:last-child)::after {
  content: '＞';
  padding-left: 6px;
}

.pathBlock a {
  color: #333;
}


/* ----------------------------------- */


/* -----------------------------------
    3. mainBlock
   ----------------------------------- */
.mainBlock {
  margin: 0 auto;
  padding: 4rem 12px 2rem;
  width: 1024px;
}

.mainBlock .themeArea {
  margin-bottom: 35px;
}


/* ----------------------------------- */


/* -----------------------------------
    4. mvBox
   ----------------------------------- */
.mvBox {
  margin: 0 0 40px;
  position: relative;
}

.mvBox h1 {
	box-sizing: border-box;
  color: #e7c057;
  background: url(/kenko_recipe/common/img/bg_dot.svg) repeat left top rgba(0, 0, 0, 0.45);
  left: 16px;
	max-width: calc(100% - 32px);
  padding: 11px 24px;
  position: absolute;
  top: 16px;
}

.mvBox img {
  border-radius: 3px;
}


/* ----------------------------------- */


/* -----------------------------------
    5. ptBox
   ----------------------------------- */
.ptBox {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin-bottom: 30px;
}

.ptBox div {
  background: #e7c057;
  box-sizing: border-box;
  padding: 13px 0;
  position:relative;
  width: 315px;
	min-height: 102px;
}

.ptBox div h2 {
  color: #333;
  left: 50%;
  position: absolute;
  text-align: center;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  white-space: nowrap;
}

.ptBox div h2::before {
  content: attr(data-title);
  display: block;
  font-family: 'LumberjackR';
  font-weight: normal;
  width: 100%;
}

.ptBox ul {
  padding-left: 30px;
  width: calc(100% - 345px);
}

.ptBox ul li {
  font-size: 2rem;
  list-style-type: none;
  margin: 0 0 .9rem;
  padding-left: 28px;
  position: relative;
}

.ptBox ul li::before {
  background: #f9eac5;
  border-radius: .5em;
  content: '';
  display: block;
  height: .7em;
  left: 2px;
  list-style-type: none;
  position: absolute;
  top: .35em;
  width: .7em;
}

/* ----------------------------------- */


/* -----------------------------------
    6. col2Box
   ----------------------------------- */
.col2Box {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  margin-bottom: 24px;
}

.col2Box .box {
  align-items: stretch;
  background: #f9eac5;
  width: calc(50% - 10px);
  -webkit-align-items: stretch;
  -ms-flex-align: stretch;
}

.col2Box .box:first-child {
  margin-right: 10px;
}

.col2Box .box:nth-child(2) {
  margin-left: 10px;
}

.col2Box .box h2 {
  background-color: #333;
  font-weight: normal;
  color: #e7c057;
  padding-bottom: 2rem;
	margin: -0.6px;
}

.col2Box .box h2::after {
  background: url(/kenko_recipe/common/img/bg_line.svg) repeat-x bottom left #333;
  content: '';
  display: block;
  height: 6px;
  padding-top: 5px;
}

.col2Box .box .prosBox {
  color: #333;
  padding: 16px;
}

.col2Box .box .prosBox li {
  list-style-type: none;
  margin: 0 0 .9rem;
  position: relative;
}

.col2Box .box .prosBox ul li {
	list-style: none;
	margin-left: 28px;
}

.col2Box .box .prosBox ul li span {
  left: -20px;
  list-style-type: none;
  position: absolute;
  top: 0;
}

.col2Box .box .prosBox ul li li {
	margin: 0.2rem 0 0.3rem 14px;}

.col2Box .box .prosBox ul li li span {
	left: -12px;
}

.col2Box .box .prosBox ol {
  counter-reset: table-ol;
}

.col2Box .box .prosBox ol li {
  padding-left: 28px;
  counter-increment: table-ol;
}

.col2Box .box .prosBox ol li:before {
  content: counter(table-ol) '.';
  position: absolute;
  left: 2px;
}


/* ----------------------------------- */


/* -----------------------------------
    7. menuList
   ----------------------------------- */
.menuList {
  margin-top: 33px;
}

.menuList h2 {
  border-bottom: 2px solid #f7e8c3;
  font-weight: bold;
  margin: 0 0 2.4rem;
  padding-bottom: 10px;
}

.menuList h2 .fa {
  padding: 0 12px 0 8px;
}

.menuList ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  list-style-type: none;
  margin: 0 0 3.6rem;
  -ms-flex-wrap: wrap;
}

.menuList ul li {
  margin: 0 2% 2.4rem 0;
  width: 32%;
}

.menuList ul li:nth-child(3n) {
  margin-right: 0;
}

.menuList ul li a {
  color: #f7e8c3;
  display: block;
  height: 100%;
  position: relative;
  text-decoration: none;
  vertical-align: middle;
}

.menuList ul li a::after {
  background: rgba(247, 232, 195, .5);
  background: -webkit-gradient(linear, left top, left bottom, color-stop(0, rgba(247, 232, 195, .5)), color-stop(.5, rgba(255, 255, 255, 0)), color-stop(1, rgba(247, 232, 195, .5)));
  background: -webkit-linear-gradient(right, rgba(247, 232, 195, .5) 0%, rgba(255, 255, 255, 0) 50%, rgba(247, 232, 195, .5) 100%);
  background: linear-gradient(-90deg, rgba(247, 232, 195, .5) 0%, rgba(255, 255, 255, 0) 50%, rgba(247, 232, 195, .5) 100%);
  content: '';
  display: block;
  height: 100%;
  opacity: 0;
  position: absolute;
  top: 0;
  transition: opacity .3s ease;
  width: 100%;
  zoom: 1;
  -webkit-transition: opacity .3s ease;
}

.menuList ul li a:hover::after {
  opacity: 1;
}

.menuList ul li .txtLink {
  border-top: 1px solid #f7e8c3;
  display: block;
  margin: 1.6rem 0 4.5rem;
  padding: 1.2rem 0 0 30px;
  position: relative;
}

.menuList ul li .txtLink .fa {
  font-size: .8em;
  display: inline-block;
  left: 12px;
  position: absolute;
  top: 1.8rem;
}


/* ----------------------------------- */


/* -----------------------------------
    8. themeBox
   ----------------------------------- */
.themeBox {
  background-color: #f7e8c3;
  padding: 14px 24px 28px;
  overflow: hidden;
  zoom: 1;
}

.themeBox h2 {
  color: #333;
  font-weight: normal;
  margin-bottom: 24px;
	padding-bottom: 0;
}

.themeBox h2::after {
  background: #333 url(/kenko_recipe/common/img/bg_line.svg) repeat-x bottom left;
  content: '';
  display: block;
  height: 6px;
  margin: .6rem 0 0;
}

.themeBox .artBox {
  overflow: hidden;
  zoom: 1;
}

.themeBox .artBox figure {
  float: left;
  max-width: 207px;
}

.themeBox .artBox figure img {
  border-radius: 3px;
  margin-bottom: 10px;
}

.themeBox .artBox figure figcaption {
  color: #333;
  text-align: center;
	font-size: 1.4rem;
}

.themeBox .artBox article {
	-moz-column-count: 2;
	-webkit-column-count: 2;
	column-count: 2;
	-moz-column-gap: 16px;
	-webkit-column-gap: 16px;
	column-gap: 16px;
  float: right;
  width: calc(100% - 231px);
}

.themeBox .artBox article p {
  color: #333;
	margin-bottom: 9px;
}

.themeBox .btnBox {
  display: none;
}


/* ----------------------------------- */


/* -----------------------------------
    9. recipeCap
   ----------------------------------- */
.recipeCap {
	margin: 0 0 7px 0;
}
.recipeCap p {
	font-size: 1.4rem;
	line-height: 1.96rem;
	padding-left: 1.5em;
	position: relative;
}
.recipeCap p:before {
	content: "※";
	left: 0;
	position: absolute;
	top: 0;
}


/* ----------------------------------- */


/* -----------------------------------
    10. media screen
   ----------------------------------- */
@media screen and (max-width:767px) {
  .mainBlock {
    box-sizing: border-box;
    padding: 3.2rem 0;
    width: 100%;
  }

  .pathBlock ul {
    font-size: 1.2rem;
    width: auto;
  }


/* hdline ----- */
  .hdline01 h1 {
    padding: 1px 13px;
  }

  .hdline02 {
    margin: 0 12px;
  }

  .hdline02 h1 {
    margin: 0 0 3px;
    padding: 0;
  }

  .hdline02 h1::before {
    display: block;
    font-size: 2rem;
    font-weight: bold;
    margin-bottom: 5px;
    padding: 8px 0;
    position: static;
    width: 173px;
  }

  .hdline02 div {
    height: 32px;
    width: 32px;
  }

  .hdline02 div img {
    height: 32px;
    width: 32px;
  }

  h2 {
    padding-bottom: 6px;
  }

  h2 .fa {
    padding: 0 8px;
  }

/* mvBox ----- */
.mvBox {
  margin: 0 0 32px;
  position: relative;
}

.mvBox h1 {
	box-sizing: border-box;
  left: 12px;
	max-width: calc(100% - 24px);
  padding: 9px 12px;
  position: absolute;
  top: 12px;
}

.mvBox img {
  border-radius: none;
}

/* ptBox ----- */
  .ptBox {
    display: block;
    margin: 0 12px 30px;
  }

  .ptBox div,
  .ptBox ul {
    display: block;
  }

  .ptBox div {
    margin: 0 auto 24px;
    position: static;
    width: 216px;
		min-height: -moz-initial;
		min-height: initial;
  }

  .ptBox div h2 {
    position: static;
    top: auto;
    left: auto;
    -webkit-transform: none;
    transform: none;
    white-space: normal;
  }

  .ptBox h2::before {
    font-size: 2.0rem;
  }

  .ptBox ul {
    padding-left: 0;
    width: 100%;
  }


/* col2Box ----- */
  .col2Box {
    display: block;
    margin: 0 12px 30px;
  }

  .col2Box .box {
    width: 100%;
  }

  .col2Box .box:first-child {
    margin-right: 0;
  }

  .col2Box .box:nth-child(2) {
    margin: 15px 0 0;
  }

  .col2Box .box h2 {
    padding-bottom: 1.5rem;
  }


/* themeBox ----- */
  .themeBox {
    background-color: #f7e8c3;
    margin: 0 12px;
    padding: 12px 12px 15px;
  }

	.themeBox h2 {
		margin-bottom: 16px;
	}

  .themeBox .artBox figure {
    max-width: none;
    width: 100%;
    overflow: hidden;
    zoom: 1;
    position: relative;
  }

  .themeBox .artBox figure img {
    float: left;
    max-width: 50%;
  }

  .themeBox .artBox figure figcaption {
    padding-left: calc(50% + 8px);
    text-align: left;
    position: absolute;
    bottom: 1.2rem;
  }

  .themeBox .artBox article {
    -moz-column-count: auto;
    -webkit-column-count: auto;
    column-count: auto;
    width: 100%;
  }

  .themeBox .btnBox {
    display: block;
    padding-top: 20px;
    text-align: center;
    width: 100%;
  }

  .themeBox .btnBox div {
    background-color: #e7c057;
    color: #333;
    display: inline-block;
    padding: 10px 15px;
    cursor: pointer;
  }

  .themeBox .btnBox div i {
    font-size: 1.8rem;
    margin-right: .5em;
  }

	.recipeCap {
		margin: 0 12px 7px 12px;
	}


/* menuList ----- */
  .menuList {
    margin: 26px 12px 0;
  }

  .menuList ul {
    display: block;
    -js-display: block;
  }

  .menuList ul li {
    margin-right: 0;
    width: 100%;
  }

  .menuList ul li a {
    overflow: hidden;
  }

  .menuList ul .imgBox {
    float: left;
    width: 37.2%;
  }

  .menuList ul li a::after {
    background: none;
  }

  .menuList ul li .txtLink {
    box-sizing: border-box;
    border-top: none;
    float: right;
    margin: 0;
    padding: 0 0 0 2.6rem;
    width: 62.8%;
  }

  .menuList ul li .txtLink .fa {
    left: .8rem;
    top: .5rem;
  }

	.recipeCap p {
		font-size: 1.2rem;
	}
}


/* ----------------------------------- */