@charset "UTF-8";
/* FLEXBOX */
/* FLEXBOX */
/*! normalize.css v2.1.2 | MIT License | git.io/normalize */
/* ==========================================================================
   HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined in IE 8/9.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block; }

/**
 * Correct `inline-block` display not defined in IE 8/9.
 */
audio,
canvas,
video {
  display: inline-block; }

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/**
 * Address styling not present in IE 8/9.
 */
[hidden] {
  display: none; }

/* ==========================================================================
   Base
   ========================================================================== */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/**
 * Remove default margin.
 */
body {
  margin: 0; }

/* ==========================================================================
   Links
   ========================================================================== */
/**
 * Address `outline` inconsistency between Chrome and other browsers.
 */
a:focus {
  outline: thin dotted; }

/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0; }

/* ==========================================================================
   Typography
   ========================================================================== */
/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari 5, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/**
 * Address styling not present in IE 8/9, Safari 5, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted; }

/**
 * Address style set to `bolder` in Firefox 4+, Safari 5, and Chrome.
 */
b,
strong {
  font-weight: bold; }

/**
 * Address styling not present in Safari 5 and Chrome.
 */
dfn {
  font-style: italic; }

/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0; }

/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000; }

/**
 * Correct font family set oddly in Safari 5 and Chrome.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, serif;
  font-size: 1em; }

/**
 * Improve readability of pre-formatted text in all browsers.
 */
pre {
  white-space: pre-wrap; }

/**
 * Set consistent quote types.
 */
q {
  quotes: "\201C" "\201D" "\2018" "\2019"; }

/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

/* ==========================================================================
   Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9.
 */
img {
  border: 0; }

/**
 * Correct overflow displayed oddly in IE 9.
 */
svg:not(:root) {
  overflow: hidden; }

/* ==========================================================================
   Figures
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari 5.
 */
figure {
  margin: 0; }

/* ==========================================================================
   Forms
   ========================================================================== */
/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/**
 * 1. Correct `color` not being inherited in IE 8/9.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * 1. Correct font family not being inherited in all browsers.
 * 2. Correct font size not being inherited in all browsers.
 * 3. Address margins set differently in Firefox 4+, Safari 5, and Chrome.
 */
button,
input,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 2 */
  margin: 0;
  /* 3 */ }

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
button,
input {
  line-height: normal; }

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Chrome, Safari 5+, and IE 8+.
 * Correct `select` style inheritance in Firefox 4+ and Opera.
 */
button,
select {
  text-transform: none; }

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */ }

/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default; }

/**
 * 1. Address box sizing set to `content-box` in IE 8/9.
 * 2. Remove excess padding in IE 8/9.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  /* 2 */
  box-sizing: content-box; }

/**
 * Remove inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

/**
 * 1. Remove default vertical scrollbar in IE 8/9.
 * 2. Improve readability and alignment in all browsers.
 */
textarea {
  overflow: auto;
  /* 1 */
  vertical-align: top;
  /* 2 */ }

/* ==========================================================================
   Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

/*! original.css v1.0.0 | MIT License */
/* ==========================================================================
   set original style with normalize.css
   
   ※補足
    'img'が縦に並ぶ際、画像の高さが低いものに関して、隙間が生じる場合がある。
    その際は'line-height'、'font-size'が影響している。
    各エレメントに対して必要に応じてリセット。
   ========================================================================== */
/**
 * set font-size
 */
html {
  font-size: 62.5%;
  /* equal '10px' */
  font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif; }

/**
 * set original style
 */
body {
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word; }

h1 {
  margin: 0;
  font-size: 100%; }

h2 {
  margin: 0;
  font-size: 100%; }

h3 {
  margin: 0;
  font-size: 100%; }

h4 {
  margin: 0;
  font-size: 100%; }

h5 {
  margin: 0;
  font-size: 100%; }

h6 {
  margin: 0;
  font-size: 100%; }

p {
  margin: 0; }

ul {
  margin: 0;
  padding: 0;
  list-style: none; }

dl {
  margin: 0; }

dd {
  margin: 0; }

input[type="text"], input[type="tel"], input[type="email"], textarea {
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none; }

input[type="submit"] {
  outline: none; }

table {
  word-break: break-all; }

small {
  font-size: 100%; }

/**
 * clean up extra space on 'img'
 */
img {
  vertical-align: top; }

/**
 * delete focus outline
 */
area, area:focus {
  outline: none; }

/**
 * delete focus outline for 'firefox'
 */
a, a:focus {
  outline: none; }

object, embed, video {
  outline: none; }

/**
 * clearfix
 */
.cf:before,
.cf:after {
  content: "";
  display: table; }

.cf:after {
  clear: both; }

.cf {
  zoom: 1; }

/* for ie6, 7 */
/**
 * BxSlider v4.1.2 - Fully loaded, responsive content slider
 * http://bxslider.com
 *
 * Written by: Steven Wanderski, 2014
 * http://stevenwanderski.com
 * (while drinking Belgian ales and listening to jazz)
 *
 * CEO and founder of bxCreative, LTD
 * http://bxcreative.com
 */
/** RESET AND LAYOUT
===================================*/
.bx-wrapper {
  position: relative;
  /*margin: 0 auto 60px;*/
  /* change */
  padding: 0;
  *zoom: 1; }

.bx-wrapper img {
  max-width: 100%;
  display: block; }

/** THEME
===================================*/
.bx-wrapper .bx-viewport {
  /*-moz-box-shadow: 0 0 5px #ccc;
    -webkit-box-shadow: 0 0 5px #ccc;
    box-shadow: 0 0 5px #ccc;
    border:  5px solid #fff;
    left: -5px;
    background: #fff;*/
  /* change */
  /*fix other elements on the page moving (on Chrome)*/
  -webkit-transform: translatez(0);
  transform: translatez(0); }

.bx-wrapper .bx-pager,
.bx-wrapper .bx-controls-auto {
  position: absolute;
  width: 100%; }

/* LOADER */
.bx-wrapper .bx-loading {
  min-height: 50px;
  background: url(../img/common/loader.gif) center center no-repeat #fff;
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2000; }

/* PAGER */
.bx-wrapper .bx-controls {
  height: 0; }

/* change */
.bx-wrapper .bx-pager {
  position: relative;
  bottom: -40px;
  text-align: center; }
  @media only screen and (max-width: 768px) {
    .bx-wrapper .bx-pager {
      bottom: -15px; } }

.bx-wrapper .bx-pager .bx-pager-item,
.bx-wrapper .bx-controls-auto .bx-controls-auto-item {
  display: inline-block;
  *zoom: 1;
  *display: inline; }

/* change */
.bx-wrapper .bx-pager.bx-default-pager a {
  display: block;
  width: 35px;
  height: 35px;
  margin: 0 8px;
  padding: 6px 0 0 0;
  border-radius: 50%;
  box-sizing: border-box;
  text-align: center;
  text-decoration: none;
  background-color: #fff;
  color: #999; }
  @media only screen and (max-width: 768px) {
    .bx-wrapper .bx-pager.bx-default-pager a {
      width: 22px;
      height: 22px;
      margin: 0 4px;
      padding-top: 4px;
      font-size: 10px; } }

/* change */
.bx-wrapper .bx-pager.bx-default-pager a.active {
  background-color: #f6ab00;
  color: #fff;
  font-weight: bold; }

/* DIRECTION CONTROLS (NEXT / PREV) */
.bx-wrapper .bx-prev {
  display: none;
  /*left: 10px;
    background: url(images/controls.png) no-repeat 0 -32px;*/
  /* change */ }

.bx-wrapper .bx-next {
  display: none;
  /*right: 10px;
    background: url(images/controls.png) no-repeat -43px -32px;*/
  /* change */ }

.bx-wrapper .bx-prev:hover {
  background-position: 0 0; }

.bx-wrapper .bx-next:hover {
  background-position: -43px 0; }

.bx-wrapper .bx-controls-direction a {
  position: absolute;
  top: 50%;
  margin-top: -16px;
  outline: 0;
  width: 32px;
  height: 32px;
  text-indent: -9999px;
  z-index: 9999; }

.bx-wrapper .bx-controls-direction a.disabled {
  display: none; }

/* AUTO CONTROLS (START / STOP) */
.bx-wrapper .bx-controls-auto {
  text-align: center; }

.bx-wrapper .bx-controls-auto .bx-start {
  display: block;
  text-indent: -9999px;
  width: 10px;
  height: 11px;
  outline: 0;
  /*background: url(images/controls.png) -86px -11px no-repeat;*/
  /* change */
  margin: 0 3px; }

.bx-wrapper .bx-controls-auto .bx-start:hover,
.bx-wrapper .bx-controls-auto .bx-start.active {
  background-position: -86px 0; }

.bx-wrapper .bx-controls-auto .bx-stop {
  display: block;
  text-indent: -9999px;
  width: 9px;
  height: 11px;
  outline: 0;
  /*background: url(images/controls.png) -86px -44px no-repeat;*/
  /* change */
  margin: 0 3px; }

.bx-wrapper .bx-controls-auto .bx-stop:hover,
.bx-wrapper .bx-controls-auto .bx-stop.active {
  background-position: -86px -33px; }

/* PAGER WITH AUTO-CONTROLS HYBRID LAYOUT */
.bx-wrapper .bx-controls.bx-has-controls-auto.bx-has-pager .bx-pager {
  text-align: left;
  width: 80%; }

.bx-wrapper .bx-controls.bx-has-controls-auto.bx-has-pager .bx-controls-auto {
  right: 0;
  width: 35px; }

/* IMAGE CAPTIONS */
.bx-wrapper .bx-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  background: #666\9;
  background: rgba(80, 80, 80, 0.75);
  width: 100%; }

.bx-wrapper .bx-caption span {
  color: #fff;
  font-family: Arial;
  display: block;
  font-size: .85em;
  padding: 10px; }

/* ----------------------------------------
 * 基本設定
 * ------------------------------------- */
html.is-fix {
  overflow: hidden; }

html, body {
  height: 100%; }

body {
  position: relative;
  line-height: 1.5;
  background-color: #fff;
  color: #333;
  font-size: 16px; }
  @media only screen and (max-width: 768px) {
    body {
      font-size: 14px; } }

a {
  color: #f6ab00; }
  a:hover {
    color: #f68b00; }
    @media only screen and (max-width: 768px) {
      a:hover {
        color: #f6ab00; } }

/* ----------------------------------------
 * コンテナー
 * ------------------------------------- */
.root-container {
  position: relative;
  margin: 0 auto; }

.content-inner {
  max-width: 1400px;
  margin: 0 auto; }

/* ----------------------------------------
 * ヘッダー
 * ------------------------------------- */
.header-ci {
  position: absolute;
  top: 0;
  left: 0; }
  .header-ci h1 {
    background-color: #f6ab00; }
    @media only screen and (max-width: 768px) {
      .header-ci h1 {
        padding-left: 15px; } }
  .header-ci a {
    display: block;
    width: 240px;
    height: 180px;
    background-position: center center;
    background-repeat: no-repeat;
    overflow: hidden;
    text-indent: 300%;
    white-space: nowrap; }
    @media only screen and (max-width: 768px) {
      .header-ci a {
        width: 100% !important;
        height: 48px !important;
        background-position: left center; } }

/* ----------------------------------------
 * グロナビ
 * ------------------------------------- */
@media only screen and (max-width: 768px) {
  .gnav-all {
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    overflow-scrolling: touch;
    visibility: hidden;
    opacity: 0;
    transition: 0.3s ease 0s;
    z-index: 50;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #333; } }

@media only screen and (max-width: 768px) {
  .gnav-all.is-show {
    visibility: visible;
    opacity: 1; } }

@media only screen and (max-width: 768px) {
  .gnav.is-show ul a {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
    opacity: 1; } }

.gnav-head {
  display: none; }
  @media only screen and (max-width: 768px) {
    .gnav-head {
      position: relative;
      display: -webkit-box;
      display: flex;
      padding-left: 15px; } }

@media only screen and (max-width: 768px) {
  .gnav-head-ci a {
    display: block;
    height: 48px;
    background-position: left center;
    background-repeat: no-repeat;
    overflow: hidden;
    text-indent: 300%;
    white-space: nowrap; } }

@media only screen and (max-width: 768px) {
  .gnav-head-menu {
    display: -webkit-box;
    display: flex;
    margin-left: auto; } }

@media only screen and (max-width: 768px) {
  .gnav-head-menu a {
    display: block;
    width: 60px;
    height: 48px;
    background-image: url(../img/common/gnav_menu_icn_02.png);
    background-position: center center;
    background-repeat: no-repeat;
    background-size: 22px 19px; } }

.gnav {
  position: absolute;
  top: 0;
  right: 0;
  max-width: 1000px;
  width: 64.2%; }
  @media only screen and (max-width: 768px) {
    .gnav {
      overflow-x: hidden;
      overflow-y: auto;
      -webkit-overflow-scrolling: touch;
      overflow-scrolling: touch;
      z-index: 50;
      top: 48px;
      width: 100%; } }
  .gnav ul {
    display: -webkit-box;
    display: flex; }
    @media only screen and (max-width: 768px) {
      .gnav ul {
        flex-wrap: wrap; } }
    .gnav ul li {
      border-right: 1px solid #bbb;
      border-bottom: 1px solid #bbb; }
      @media only screen and (max-width: 768px) {
        .gnav ul li {
          border-right: none;
          border-bottom: 1px solid #666; } }
    .gnav ul a {
      display: -webkit-box;
      display: flex;
      -webkit-box-pack: center;
      justify-content: center;
      -webkit-box-align: center;
      align-items: center;
      transition: 0.3s ease 0s;
      opacity: 1;
      width: 100%;
      height: 90px;
      box-sizing: border-box;
      text-align: center;
      text-decoration: none;
      color: #fff; }
      @media only screen and (max-width: 768px) {
        .gnav ul a {
          transition: 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0s;
          -webkit-transform: translate(-20px, 0);
          transform: translate(-20px, 0);
          opacity: 0;
          display: block;
          height: 48px;
          padding: 14px 15px 0 15px;
          text-align: left; } }
      .gnav ul a:hover {
        color: #f6ab00; }
        @media only screen and (max-width: 768px) {
          .gnav ul a:hover {
            color: #fff; } }
    .gnav ul .current {
      background-image: url(../img/common/bg_opacity_orange_50.png);
      background-position: left top;
      background-repeat: repeat; }
      @media only screen and (max-width: 768px) {
        .gnav ul .current {
          background-image: none; } }
      .gnav ul .current:hover {
        color: #fff; }
    .gnav ul li:first-child {
      border-left: 1px solid #bbb; }
      @media only screen and (max-width: 768px) {
        .gnav ul li:first-child {
          border-top: 1px solid #666;
          border-left: none; } }
    .gnav ul .btn-gnav-contact {
      border: none;
      border-bottom: 1px solid #3d3d3c; }
      @media only screen and (max-width: 768px) {
        .gnav ul .btn-gnav-contact {
          border-bottom: 1px solid #666; } }
      .gnav ul .btn-gnav-contact a {
        position: relative;
        line-height: 1.3;
        background-image: url(../img/common/bg_opacity_black_60.png);
        background-position: left top;
        background-repeat: repeat; }
        @media only screen and (max-width: 768px) {
          .gnav ul .btn-gnav-contact a {
            line-height: 1.5;
            background-image: none; } }
        .gnav ul .btn-gnav-contact a:hover {
          opacity: 0.6;
          color: #fff; }
          @media only screen and (max-width: 768px) {
            .gnav ul .btn-gnav-contact a:hover {
              opacity: 1; } }
      .gnav ul .btn-gnav-contact span {
        position: relative;
        display: block;
        width: 100%;
        height: 100%;
        padding-top: 40px;
        box-sizing: border-box; }
        @media only screen and (max-width: 768px) {
          .gnav ul .btn-gnav-contact span {
            display: inline-block;
            width: auto;
            height: auto;
            padding-top: 0;
            line-height: 1.5;
            background-image: none; } }
      .gnav ul .btn-gnav-contact span:before {
        content: "";
        position: absolute;
        display: block;
        background-position: left top;
        background-repeat: no-repeat;
        top: 16px;
        left: 50%;
        width: 20px;
        height: 14px;
        margin-left: -10px;
        background-image: url(../img/common/icn_contact_01.png);
        background-position: left top;
        background-repeat: no-repeat; }
        @media only screen and (max-width: 768px) {
          .gnav ul .btn-gnav-contact span:before {
            top: 5px;
            left: auto;
            right: -24px;
            width: 14px;
            height: 10px;
            margin-left: 0;
            background-size: 14px auto; } }
    @media only screen and (max-width: 768px) {
      .gnav ul .btn-with-icn a {
        position: relative; } }
    @media only screen and (max-width: 768px) {
      .gnav ul .btn-with-icn span {
        position: relative;
        display: inline-block; } }
    @media only screen and (max-width: 768px) {
      .gnav ul .btn-with-icn span:before {
        content: "";
        position: absolute;
        display: block;
        background-position: left top;
        background-repeat: no-repeat;
        top: 5px;
        right: -23px;
        width: 13px;
        height: 12px;
        background-image: url(../img/common/icn_external_01.png);
        background-position: left top;
        background-repeat: no-repeat;
        background-size: 13px auto; } }

.gnav-menu {
  display: none; }
  @media only screen and (max-width: 768px) {
    .gnav-menu {
      position: absolute;
      top: 0;
      right: 0;
      display: block; }
      .gnav-menu a {
        display: -webkit-box;
        display: flex;
        -webkit-box-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        align-items: center;
        width: 60px;
        height: 48px; }
      .gnav-menu span {
        display: block;
        width: 22px;
        height: 18px;
        background-image: url(../img/common/gnav_menu_icn_01.png);
        background-position: left top;
        background-repeat: no-repeat;
        background-size: 22px 18px; } }

/* ----------------------------------------
 * フッター
 * ------------------------------------- */
.footer {
  margin: 110px 0 0 0;
  padding: 12px 0 7px 0;
  text-align: center;
  background-color: #333;
  color: #fff;
  font-size: 14px; }
  @media only screen and (max-width: 768px) {
    .footer {
      margin-top: 29px;
      padding-top: 7px;
      padding-bottom: 5px;
      font-size: 10px; } }

/* ----------------------------------------
 * 汎用ボタン
 * ------------------------------------- */
.btn-standard-01, .btn-standard-02, .btn-standard-03, .btn-standard-06, .btn-standard-07, .btn-standard-04, .btn-standard-05 {
  box-sizing: border-box; }
  .btn-standard-01 a, .btn-standard-02 a, .btn-standard-03 a, .btn-standard-06 a, .btn-standard-07 a, .btn-standard-04 a, .btn-standard-05 a {
    position: relative;
    display: block;
    height: 70px;
    padding-top: 23px;
    border-radius: 5px;
    box-sizing: border-box;
    text-align: center;
    text-decoration: none;
    background-color: #fff;
    color: #666;
    font-size: 18px;
    font-weight: bold; }
    @media only screen and (max-width: 768px) {
      .btn-standard-01 a, .btn-standard-02 a, .btn-standard-03 a, .btn-standard-06 a, .btn-standard-07 a, .btn-standard-04 a, .btn-standard-05 a {
        height: 48px;
        padding-top: 14px;
        font-size: 14px; } }
  .btn-standard-01 a:after, .btn-standard-02 a:after, .btn-standard-03 a:after, .btn-standard-06 a:after, .btn-standard-07 a:after, .btn-standard-04 a:after, .btn-standard-05 a:after {
    content: "";
    position: absolute;
    display: block;
    background-position: left top;
    background-repeat: no-repeat;
    top: 27px;
    right: 37px;
    width: 18px;
    height: 16px;
    background-image: url(../img/common/icn_arrow_right_01.png);
    background-position: left top;
    background-repeat: no-repeat; }
    @media only screen and (max-width: 768px) {
      .btn-standard-01 a:after, .btn-standard-02 a:after, .btn-standard-03 a:after, .btn-standard-06 a:after, .btn-standard-07 a:after, .btn-standard-04 a:after, .btn-standard-05 a:after {
        top: 16px;
        right: 19px;
        width: 18px;
        height: 16px;
        background-image: url(../img/common/icn_arrow_right_01_sp.png);
        background-size: 18px 16px; } }

.btn-standard-02, .btn-standard-03, .btn-standard-06, .btn-standard-07 {
  width: 422px;
  margin: 0 auto; }
  @media only screen and (max-width: 768px) {
    .btn-standard-02, .btn-standard-03, .btn-standard-06, .btn-standard-07 {
      width: 100%; } }
  .btn-standard-02 a, .btn-standard-03 a, .btn-standard-06 a, .btn-standard-07 a {
    background-color: #f68b00;
    color: #fff; }
  .btn-standard-02 a:after, .btn-standard-03 a:after, .btn-standard-06 a:after, .btn-standard-07 a:after {
    right: 27px;
    background-image: url(../img/common/icn_arrow_right_03.png); }
    @media only screen and (max-width: 768px) {
      .btn-standard-02 a:after, .btn-standard-03 a:after, .btn-standard-06 a:after, .btn-standard-07 a:after {
        background-image: url(../img/common/icn_arrow_right_03_sp.png); } }

.btn-standard-03 {
  width: 590px; }
  @media only screen and (max-width: 768px) {
    .btn-standard-03 {
      width: 100%; } }
  .btn-standard-03 a {
    height: 98px;
    padding-top: 30px;
    background-color: #ea3f31;
    color: #fff;
    font-size: 24px; }
    @media only screen and (max-width: 768px) {
      .btn-standard-03 a {
        height: 48px;
        padding-top: 14px;
        font-size: 14px; } }
  .btn-standard-03 a:after {
    top: 38px;
    right: 30px;
    width: 24px;
    height: 22px;
    background-image: url(../img/common/icn_arrow_right_04.png); }
    @media only screen and (max-width: 768px) {
      .btn-standard-03 a:after {
        top: 16px;
        right: 19px;
        width: 18px;
        height: 16px;
        background-image: url(../img/common/icn_arrow_right_03_sp.png);
        background-size: 18px 16px; } }

.win .btn-standard-03 a {
  padding-top: 34px; }
  /* 170324 add*/
  @media only screen and (max-width: 768px) {
    .win .btn-standard-03 a {
      padding-top: 14px; } }


.btn-standard-04 a {
  background-color: #ea3f31;
  color: #fff; }

.btn-standard-04 a:after {
  right: 27px;
  background-image: url(../img/common/icn_arrow_right_03.png); }
  @media only screen and (max-width: 768px) {
    .btn-standard-04 a:after {
      top: 16px;
      right: 19px;
      width: 18px;
      height: 16px;
      background-image: url(../img/common/icn_arrow_right_03_sp.png);
      background-size: 18px 16px; } }

.btn-standard-05 a {
  background-color: #999;
  color: #fff; }

.btn-standard-05 a:after {
  right: 27px;
  background-image: url(../img/common/icn_arrow_right_03.png); }
  @media only screen and (max-width: 768px) {
    .btn-standard-05 a:after {
      top: 16px;
      right: 19px;
      width: 18px;
      height: 16px;
      background-image: url(../img/common/icn_arrow_right_03_sp.png);
      background-size: 18px 16px; } }

.btn-standard-06 a {
  background-color: #f6ab00; }

.btn-standard-07 a {
  padding-top: 19px;
  border: 3px solid #f6ab00;
  background-color: #fff;
  color: #f6ab00; }
  @media only screen and (max-width: 768px) {
    .btn-standard-07 a {
      padding-top: 12px;
      border: 2px solid #f6ab00; } }

.btn-standard-07 a:after {
  top: 23px;
  background-image: url(../img/common/icn_arrow_right_01.png); }
  @media only screen and (max-width: 768px) {
    .btn-standard-07 a:after {
      top: 14px;
      right: 17px;
      background-image: url(../img/common/icn_arrow_right_01_sp.png);
      background-size: 18px 16px; } }

/* ----------------------------------------
 * 表示切替
 * ------------------------------------- */
.no-pc {
  display: none; }
  @media only screen and (max-width: 768px) {
    .no-pc {
      display: inline-block; } }

.no-sp {
  display: inline-block; }
  @media only screen and (max-width: 768px) {
    .no-sp {
      display: none; } }

/* ----------------------------------------
 * 汎用見出し
 * ------------------------------------- */
.shd-01 {
  position: relative;
  margin: 0 0 37px 0;
  padding: 0 0 34px 0;
  text-align: center;
  line-height: 1.6;
  letter-spacing: 0.2em;
  font-size: 36px;
  font-weight: normal; }
  @media only screen and (max-width: 768px) {
    .shd-01 {
      margin-bottom: 19px;
      padding-bottom: 17px;
      letter-spacing: 0.1em;
      font-size: 20px; } }

.shd-01:before {
  content: "";
  position: absolute;
  display: block;
  background-position: left top;
  background-repeat: no-repeat;
  bottom: 0;
  left: 50%;
  width: 50px;
  height: 3px;
  margin-left: -25px;
  background-color: #f6ab00; }
  @media only screen and (max-width: 768px) {
    .shd-01:before {
      width: 25px;
      height: 2px;
      margin-left: -12px; } }

/* ----------------------------------------
 * 汎用テキスト
 * ------------------------------------- */
.txt-block-01, .txt-block-02, .txt-block-03, .txt-block-04 {
  margin: 0 0 46px 0;
  text-align: center;
  line-height: 2.3;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .txt-block-01, .txt-block-02, .txt-block-03, .txt-block-04 {
      margin-bottom: 29px;
      padding-left: 6%;
      padding-right: 6%;
      text-align: left;
      line-height: 1.8;
      font-size: 14px; } }
  .txt-block-01 .indent, .txt-block-02 .indent, .txt-block-03 .indent, .txt-block-04 .indent {
    margin-left: -8px; }

.txt-block-02 {
  line-height: 1.5; }
  @media only screen and (max-width: 768px) {
    .txt-block-02 {
      line-height: 1.8; } }

.txt-block-03 {
  line-height: 1.8;
  font-size: 18px; }
  @media only screen and (max-width: 768px) {
    .txt-block-03 {
      font-size: 14px; } }

.txt-block-04 {
  line-height: 1.8; }

.txt-block-05 {
  padding: 13px 0 11px 0;
  text-align: center;
  background-color: #eee;
  color: #666;
  font-size: 18px; }
  @media only screen and (max-width: 768px) {
    .txt-block-05 {
      padding-top: 7px;
      padding-bottom: 6px;
      font-size: 14px; } }

.txt-accent-01 {
  margin: 0 5px 0 5px;
  color: #f6ab00;
  font-size: 30px; }
  @media only screen and (max-width: 768px) {
    .txt-accent-01 {
      font-size: 14px; } }

.txt-accent-02 {
  margin: 0 0 16px 0;
  text-align: center;
  color: #f6ab00;
  font-size: 20px;
  font-weight: bold; }
  @media only screen and (max-width: 768px) {
    .txt-accent-02 {
      margin-left: 6%;
      margin-right: 6%;
      text-align: left;
      font-size: 14px; } }

/* ----------------------------------------
 * セクション
 * ------------------------------------- */
.section-01 {
  margin: 57px 0 0 0; }
  @media only screen and (max-width: 768px) {
    .section-01 {
      margin-top: 29px; } }

.section-02 {
  margin: 57px 0 57px 0; }
  @media only screen and (max-width: 768px) {
    .section-02 {
      margin-top: 29px;
      margin-bottom: 29px; } }

.section-03 {
  padding: 90px 0 100px 0;
  background-color: #f7f5f1; }
  @media only screen and (max-width: 768px) {
    .section-03 {
      padding-top: 29px;
      padding-bottom: 29px; } }

.section-04 {
  margin: 57px 2.5% 90px 2.5%;
  padding: 0 0 100px 0;
  border-bottom: 1px solid #ccc; }
  @media only screen and (max-width: 768px) {
    .section-04 {
      margin: 29px 0 29px 0;
      padding-bottom: 29px; } }

.section-05 {
  margin: 90px 0 100px 0; }
  @media only screen and (max-width: 768px) {
    .section-05 {
      margin: 29px 0 29px 0; } }

/* ----------------------------------------
 * ロールオーバー
 * ------------------------------------- */
.btn-opacity {
  transition: opacity 0.3s ease 0s; }
  .btn-opacity:hover {
    opacity: 0.5; }
    @media only screen and (max-width: 768px) {
      .btn-opacity:hover {
        opacity: 1; } }

/* ----------------------------------------
 * トップ：VI
 * ------------------------------------- */
.vi {
  height: 520px;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover; }
  @media only screen and (max-width: 768px) {
    .vi {
      height: 260px; } }
  .vi dl dt {
    margin: 0 auto 17px;
    background-position: left top;
    background-repeat: no-repeat;
    overflow: hidden;
    text-indent: 300%;
    white-space: nowrap; }
    @media only screen and (max-width: 768px) {
      .vi dl dt {
        margin-bottom: 13px; } }
  .vi dl dd {
    margin: 0 auto;
    background-position: left top;
    background-repeat: no-repeat;
    overflow: hidden;
    text-indent: 300%;
    white-space: nowrap; }

.vi-inner {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center;
  height: 100%;
  background-image: url(../img/common/img_scroll.png);
  background-position: center bottom;
  background-repeat: no-repeat; }
  @media only screen and (max-width: 768px) {
    .vi-inner {
      background-size: 49px 42px; } }

/* ----------------------------------------
 * 下層：VI
 * ------------------------------------- */
.low-vi {
  margin: 0 0 50px 0; }
  @media only screen and (max-width: 768px) {
    .low-vi {
      margin-bottom: 29px; } }

.low-vi-visual {
  height: 300px;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover; }
  @media only screen and (max-width: 768px) {
    .low-vi-visual {
      height: 150px; } }
  .low-vi-visual h1 {
    position: relative;
    margin: 0 0 50px 0;
    padding: 0 0 21px 0;
    letter-spacing: 0.2em;
    color: #fff;
    font-size: 35px; }
    @media only screen and (max-width: 768px) {
      .low-vi-visual h1 {
        margin-bottom: 25px;
        padding-bottom: 11px;
        font-size: 20px; } }
  .low-vi-visual h1:before {
    content: "";
    position: absolute;
    display: block;
    background-position: left top;
    background-repeat: no-repeat;
    bottom: 0;
    left: 50%;
    width: 50px;
    height: 3px;
    margin-left: -25px;
    background-color: #f6ab00; }
    @media only screen and (max-width: 768px) {
      .low-vi-visual h1:before {
        width: 25px;
        height: 2px;
        margin-left: -12px; } }

.low-vi-visual-inner {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: end;
  align-items: flex-end;
  width: 100%;
  height: 100%;
  background-image: url(../img/common/bg_ami_01.png);
  background-position: left top;
  background-repeat: repeat; }
  @media only screen and (max-width: 768px) {
    .low-vi-visual-inner {
      background-size: 3px 3px; } }

.low-vi-info {
  padding: 22px 0 20px 0;
  background-color: #eee; }
  @media only screen and (max-width: 768px) {
    .low-vi-info {
      padding: 10px 6% 10px 6%; } }

.low-vi-info-accent-txt {
  margin: 0 0 15px 0;
  text-align: center;
  color: #f6ab00;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .low-vi-info-accent-txt {
      margin-bottom: 7px;
      text-align: left;
      font-size: 14px; } }

.low-vi-info-txt {
  text-align: center;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .low-vi-info-txt {
      text-align: left;
      font-size: 14px; } }

/* ----------------------------------------
 * 背景：網
 * ------------------------------------- */
.bg-ami-01 {
  background-image: url(../img/common/bg_ami_02.png);
  background-position: left top;
  background-repeat: repeat; }
  @media only screen and (max-width: 768px) {
    .bg-ami-01 {
      background-size: 3px 3px; } }

/* ----------------------------------------
 * サービス提供エリア
 * ------------------------------------- */
.service-area-all {
  padding: 0 6.1% 0 6.1%; }
  @media only screen and (max-width: 768px) {
    .service-area-all {
      padding-left: 6%;
      padding-right: 6%; } }

.service-area {
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .service-area {
      flex-wrap: wrap; } }
  .service-area .figure {
    flex-basis: 48%;
    margin-right: 4%; }
    @media only screen and (max-width: 768px) {
      .service-area .figure {
        flex-basis: 100%;
        margin-right: 0;
        margin-bottom: 15px; } }
    .service-area .figure figure {
      border: 1px solid #eee; }
      .service-area .figure figure img {
        max-width: 100%;
        width: 100%;
        height: auto; }
    .service-area .figure p {
      margin-top: 6px;
      text-align: right; }
  .service-area .content {
    flex-basis: 48%; }
    @media only screen and (max-width: 768px) {
      .service-area .content {
        flex-basis: 100%; } }
    .service-area .content dl {
      margin: 0 0 11px 0;
      background-color: #fff; }
      @media only screen and (max-width: 768px) {
        .service-area .content dl {
          margin-bottom: 15px; } }
      .service-area .content dl dt {
        padding: 3px 15px 2px 15px;
        color: #666;
        font-size: 26px; }
        @media only screen and (max-width: 768px) {
          .service-area .content dl dt {
            font-size: 16px; } }
      .service-area .content dl dd {
        padding: 1px 15px 2px 15px;
        background-color: #f6ab00;
        color: #fff;
        font-size: 20px; }
        @media only screen and (max-width: 768px) {
          .service-area .content dl dd {
            font-size: 14px; } }
    .service-area .content p {
      line-height: 2.5;
      font-size: 18px; }
      @media only screen and (max-width: 768px) {
        .service-area .content p {
          line-height: 1.8;
          font-size: 14px; } }

/* ----------------------------------------
 * 運営者情報
 * ------------------------------------- */
.site-host-all {
  background-image: url(../img/common/img_bg_layer_01.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover; }

.site-host-inner {
  padding: 50px 6.1% 50px 6.1%; }
  @media only screen and (max-width: 768px) {
    .site-host-inner {
      padding: 29px 6% 29px 6%; } }

.site-host-profile .txt {
  margin-top: 16px;
  text-align: center;
  font-weight: bold; }
  @media only screen and (max-width: 768px) {
    .site-host-profile .txt {
      margin-top: 5px;
      text-align: left;
      font-size: 12px; } }

.site-host-profile-body {
  display: -webkit-box;
  display: flex;
  padding: 25px 0 25px 0;
  background-image: url(../img/common/bg_opacity_white_80.png);
  background-position: left top;
  background-repeat: repeat; }
  @media only screen and (max-width: 768px) {
    .site-host-profile-body {
      flex-wrap: wrap; } }
  .site-host-profile-body figure, .site-host-profile-body > div {
    display: -webkit-box;
    display: flex;
    flex-basis: 50%;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    align-items: center;
    padding: 14px 0 15px 0;
    box-sizing: border-box; }
    @media only screen and (max-width: 768px) {
      .site-host-profile-body figure, .site-host-profile-body > div {
        flex-basis: 100%;
        padding: 0; } }
  .site-host-profile-body figure {
    border-right: 1px solid #d5d5d5; }
    @media only screen and (max-width: 768px) {
      .site-host-profile-body figure {
        margin-bottom: 15px;
        padding-left: 10%;
        padding-right: 10%;
        border-right: none; }
        .site-host-profile-body figure img {
          max-width: 100%;
          width: 100%;
          height: auto; } }
  .site-host-profile-body > div {
    line-height: 1.8;
    font-size: 20px; }
    @media only screen and (max-width: 768px) {
      .site-host-profile-body > div {
        line-height: 1.3;
        font-size: 14px; } }
    .site-host-profile-body > div span {
      color: #666;
      font-size: 18px; }
      @media only screen and (max-width: 768px) {
        .site-host-profile-body > div span {
          font-size: 12px; } }

.site-host-link {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  margin-top: 37px; }
  @media only screen and (max-width: 768px) {
    .site-host-link {
      flex-wrap: wrap;
      margin-top: 15px; } }
  .site-host-link li {
    width: 422px; }
    @media only screen and (max-width: 768px) {
      .site-host-link li {
        width: 100%; } }
  .site-host-link li:first-child {
    margin-right: 18px; }
    @media only screen and (max-width: 768px) {
      .site-host-link li:first-child {
        margin-right: 0;
        margin-bottom: 10px; } }

/* ----------------------------------------
 * カラム
 * ------------------------------------- */
.column-03-block-01 {
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .column-03-block-01 {
      flex-wrap: wrap; } }
  .column-03-block-01 > div {
    flex-basis: 33.3%;
    padding: 184px 0 0 0;
    border-right: 1px solid #fff;
    box-sizing: border-box;
    background-color: #f6ab00;
    background-repeat: no-repeat; }
    @media only screen and (max-width: 768px) {
      .column-03-block-01 > div {
        flex-basis: 100%;
        height: auto !important;
        padding-top: 100px;
        padding-bottom: 29px;
        border-right: 0;
        border-bottom: 1px solid #fff; } }
    .column-03-block-01 > div dl dt, .column-03-block-01 > div dl dd {
      text-align: center;
      color: #fff; }
    .column-03-block-01 > div dl dt {
      margin: 0 0 11px 0;
      font-size: 30px; }
      @media only screen and (max-width: 768px) {
        .column-03-block-01 > div dl dt {
          margin-bottom: 5px;
          font-size: 16px;
          font-weight: bold; } }
    .column-03-block-01 > div dl dd {
      font-size: 20px; }
      @media only screen and (max-width: 768px) {
        .column-03-block-01 > div dl dd {
          font-size: 14px; } }
  .column-03-block-01 > div:nth-child(3n) {
    border-right: none; }
    @media only screen and (max-width: 768px) {
      .column-03-block-01 > div:nth-child(3n) {
        border-bottom: none; } }
  .column-03-block-01 .column-03-block-01-reasonable {
    background-image: url(../img/common/img_illust_01.png);
    background-position: center 57px; }
    @media only screen and (max-width: 768px) {
      .column-03-block-01 .column-03-block-01-reasonable {
        background-position: center 29px;
        background-size: 47px 55px; } }
  .column-03-block-01 .column-03-block-01-allinone {
    background-image: url(../img/common/img_illust_02.png);
    background-position: center 49px; }
    @media only screen and (max-width: 768px) {
      .column-03-block-01 .column-03-block-01-allinone {
        background-position: center 29px;
        background-size: 63px 58px; } }
  .column-03-block-01 .column-03-block-01-customize {
    background-image: url(../img/common/img_illust_03.png);
    background-position: center 64px; }
    @media only screen and (max-width: 768px) {
      .column-03-block-01 .column-03-block-01-customize {
        background-position: center 32px;
        background-size: 46px 46px; } }
  .column-03-block-01 .column-03-block-01-omakase {
    background-image: url(../img/common/img_illust_04.png);
    background-position: center 54px; }
    @media only screen and (max-width: 768px) {
      .column-03-block-01 .column-03-block-01-omakase {
        background-position: center 27px;
        background-size: 34px 56px; } }
  .column-03-block-01 .column-03-block-01-trust {
    background-image: url(../img/common/img_illust_05.png);
    background-position: center 51px; }
    @media only screen and (max-width: 768px) {
      .column-03-block-01 .column-03-block-01-trust {
        background-position: center 26px;
        background-size: 32px 60px; } }

.column-03-block-02-all {
  padding: 50px 11% 50px 11%;
  background-color: #f7f5f1; }
  @media only screen and (max-width: 768px) {
    .column-03-block-02-all {
      padding: 25px 6% 25px 6%; } }

.column-03-block-02 {
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .column-03-block-02 {
      flex-wrap: wrap; } }

.column-03-block-02-list {
  flex-basis: 29.2%;
  box-sizing: border-box;
  margin: 0 6.2% 0 0;
  background-color: #fff; }
  @media only screen and (max-width: 768px) {
    .column-03-block-02-list {
      flex-basis: 100%;
      margin-right: 0;
      margin-bottom: 25px; } }
  .column-03-block-02-list figure img {
    max-width: 100%;
    width: 100%;
    height: auto; }
  .column-03-block-02-list p {
    padding: 28px 0 28px 0;
    text-align: center;
    color: #666;
    font-size: 20px; }
    @media only screen and (max-width: 768px) {
      .column-03-block-02-list p {
        padding-top: 14px;
        padding-bottom: 14px;
        font-size: 14px; } }

.column-03-block-02-list:nth-child(3n) {
  margin-right: 0; }
  @media only screen and (max-width: 768px) {
    .column-03-block-02-list:nth-child(3n) {
      margin-bottom: 0; } }

.column-03-block-03-all {
  margin: 0 6.1% 0 6.1%; }
  @media only screen and (max-width: 768px) {
    .column-03-block-03-all {
      margin-left: 6%;
      margin-right: 6%; } }

.column-03-block-03 {
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .column-03-block-03 {
      flex-wrap: wrap; } }

.column-03-block-03-list {
  position: relative;
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center;
  flex-basis: 30%;
  height: 180px;
  margin: 0 5% 0 0;
  text-align: center;
  line-height: 1.8;
  background-color: #fff;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .column-03-block-03-list {
      flex-basis: 100%;
      height: auto;
      margin-right: 0;
      margin-bottom: 25px;
      padding-top: 15px;
      padding-bottom: 15px;
      font-size: 14px; } }

.column-03-block-03-list:nth-child(3n) {
  margin-right: 0; }
  @media only screen and (max-width: 768px) {
    .column-03-block-03-list:nth-child(3n) {
      margin-bottom: 0; } }

.column-03-block-03-list:nth-of-type(1):after, .column-03-block-03-list:nth-of-type(2):after {
  content: "";
  z-index: 10;
  position: absolute;
  top: 64px;
  right: -52px;
  display: block;
  width: 0;
  height: 0;
  border-left: 26px solid #fff;
  border-right: 26px solid transparent;
  border-top: 26px solid transparent;
  border-bottom: 26px solid transparent; }
  @media only screen and (max-width: 768px) {
    .column-03-block-03-list:nth-of-type(1):after, .column-03-block-03-list:nth-of-type(2):after {
      top: auto;
      bottom: -26px;
      right: auto;
      left: 50%;
      margin-left: -13px;
      border-left: 13px solid transparent;
      border-right: 13px solid transparent;
      border-top: 13px solid #fff;
      border-bottom: 13px solid transparent; } }

.column-02-block-01-all {
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover; }

.column-02-block-01-inner {
  padding: 70px 10.5% 80px 10.5%; }
  @media only screen and (max-width: 768px) {
    .column-02-block-01-inner {
      padding: 35px 6% 35px 6%; } }

.column-02-block-01-head {
  position: relative;
  margin: 0 0 87px 0;
  padding: 25px 0 18px 55px;
  background-image: url(../img/common/bg_opacity_white_70.png);
  background-position: left top;
  background-repeat: repeat; }
  @media only screen and (max-width: 768px) {
    .column-02-block-01-head {
      margin-bottom: 44px;
      padding: 13px 0 9px 0; } }
  .column-02-block-01-head p {
    text-align: center;
    color: #666;
    font-size: 26px; }
    @media only screen and (max-width: 768px) {
      .column-02-block-01-head p {
        font-size: 16px; } }
    .column-02-block-01-head p span {
      position: relative; }
    .column-02-block-01-head p span:before {
      content: "";
      position: absolute;
      display: block;
      background-position: left top;
      background-repeat: no-repeat;
      background-position: left top;
      background-repeat: no-repeat; }
      @media only screen and (max-width: 768px) {
        .column-02-block-01-head p span:before {
          display: none; } }
    .column-02-block-01-head p strong {
      position: relative;
      top: -2px;
      display: inline-block;
      margin: 0 0 0 22px;
      padding: 3px 12px 4px 12px;
      background-color: #f6ab00;
      color: #fff;
      font-weight: normal;
      font-size: 20px; }
      @media only screen and (max-width: 768px) {
        .column-02-block-01-head p strong {
          top: -1px;
          padding-bottom: 2px;
          font-size: 12px; } }

.column-02-block-01-head:before {
  content: "";
  position: absolute;
  display: block;
  background-position: left top;
  background-repeat: no-repeat;
  bottom: -62px;
  left: 50%;
  width: 44px;
  height: 44px;
  margin-left: -22px;
  background-image: url(../img/common/icn_plus_01.png);
  background-position: left top;
  background-repeat: no-repeat; }
  @media only screen and (max-width: 768px) {
    .column-02-block-01-head:before {
      bottom: -31px;
      width: 22px;
      height: 22px;
      margin-left: -11px;
      background-size: 22px 22px; } }

.column-02-block-01-body {
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .column-02-block-01-body {
      flex-wrap: wrap; } }
  .column-02-block-01-body > div:first-child {
    margin: 0 6.2% 0 0; }
    @media only screen and (max-width: 768px) {
      .column-02-block-01-body > div:first-child {
        margin-right: 0;
        margin-bottom: 25px; } }

.column-02-block-01-list {
  flex-basis: 46.9%; }
  @media only screen and (max-width: 768px) {
    .column-02-block-01-list {
      flex-basis: 100%; } }
  .column-02-block-01-list .head {
    position: relative;
    padding: 32px 0 21px 0;
    background-color: #fff; }
    @media only screen and (max-width: 768px) {
      .column-02-block-01-list .head {
        padding-top: 16px;
        padding-bottom: 10px; } }
    .column-02-block-01-list .head dl dt, .column-02-block-01-list .head dl dd {
      text-align: center; }
    .column-02-block-01-list .head dl dt {
      font-size: 18px; }
      @media only screen and (max-width: 768px) {
        .column-02-block-01-list .head dl dt {
          font-size: 14px; } }
    .column-02-block-01-list .head dl dd {
      color: #666;
      font-size: 28px; }
      @media only screen and (max-width: 768px) {
        .column-02-block-01-list .head dl dd {
          font-size: 16px; } }
  .column-02-block-01-list .head:before {
    content: "";
    z-index: 10;
    position: absolute;
    bottom: -35px;
    left: 50%;
    width: 0;
    height: 0;
    margin-left: -43px;
    border-top: 20px solid #fff;
    border-right: 43px solid transparent;
    border-bottom: 20px solid transparent;
    border-left: 43px solid transparent; }
    @media only screen and (max-width: 768px) {
      .column-02-block-01-list .head:before {
        bottom: -20px;
        margin-left: -22px;
        border-width: 10px 22px 10px 22px; } }
  .column-02-block-01-list .image {
    position: relative; }
    .column-02-block-01-list .image figure img {
      max-width: 100%;
      width: 100%;
      height: auto; }
    .column-02-block-01-list .image p {
      position: absolute;
      bottom: 0;
      left: 0;
      width: 100%;
      padding: 6px 0 5px 0;
      text-align: center;
      background-image: url(../img/common/bg_opacity_white_80.png);
      background-position: left top;
      background-repeat: repeat;
      font-size: 18px; }
      @media only screen and (max-width: 768px) {
        .column-02-block-01-list .image p {
          font-size: 12px; } }
  .column-02-block-01-list .info {
    padding: 21px 0 20px 0; }
    @media only screen and (max-width: 768px) {
      .column-02-block-01-list .info {
        padding-top: 10px;
        padding-bottom: 10px; } }
    .column-02-block-01-list .info .txt {
      text-align: center;
      color: #fff;
      font-size: 18px; }
      @media only screen and (max-width: 768px) {
        .column-02-block-01-list .info .txt {
          font-size: 14px; } }
      .column-02-block-01-list .info .txt span {
        font-size: 22px; }
        @media only screen and (max-width: 768px) {
          .column-02-block-01-list .info .txt span {
            font-size: 18px; } }
  .column-02-block-01-list .btn-standard-01, .column-02-block-01-list .btn-standard-02, .column-02-block-01-list .btn-standard-03, .column-02-block-01-list .btn-standard-06, .column-02-block-01-list .btn-standard-07, .column-02-block-01-list .btn-standard-04, .column-02-block-01-list .btn-standard-05 {
    margin-top: 20px; }
    @media only screen and (max-width: 768px) {
      .column-02-block-01-list .btn-standard-01, .column-02-block-01-list .btn-standard-02, .column-02-block-01-list .btn-standard-03, .column-02-block-01-list .btn-standard-06, .column-02-block-01-list .btn-standard-07, .column-02-block-01-list .btn-standard-04, .column-02-block-01-list .btn-standard-05 {
        margin-top: 10px; } }

.column-02-block-01-list.color-01 .head dl dt {
  color: #f6ab00; }

.column-02-block-01-list.color-01 .info {
  background-color: #f6ab00; }
  .column-02-block-01-list.color-01 .info .price-block {
    color: #f6ab00; }

.column-02-block-01-list.color-02 .head dl dt {
  color: #f68b00; }

.column-02-block-01-list.color-02 .info {
  background-color: #f68b00; }
  .column-02-block-01-list.color-02 .info .price-block {
    color: #f68b00; }

.column-02-block-01-list.color-02 .btn-standard-01 a:after, .column-02-block-01-list.color-02 .btn-standard-02 a:after, .column-02-block-01-list.color-02 .btn-standard-03 a:after, .column-02-block-01-list.color-02 .btn-standard-06 a:after, .column-02-block-01-list.color-02 .btn-standard-07 a:after, .column-02-block-01-list.color-02 .btn-standard-04 a:after, .column-02-block-01-list.color-02 .btn-standard-05 a:after {
  background-image: url(../img/common/icn_arrow_right_02.png); }
  @media only screen and (max-width: 768px) {
    .column-02-block-01-list.color-02 .btn-standard-01 a:after, .column-02-block-01-list.color-02 .btn-standard-02 a:after, .column-02-block-01-list.color-02 .btn-standard-03 a:after, .column-02-block-01-list.color-02 .btn-standard-06 a:after, .column-02-block-01-list.color-02 .btn-standard-07 a:after, .column-02-block-01-list.color-02 .btn-standard-04 a:after, .column-02-block-01-list.color-02 .btn-standard-05 a:after {
      background-image: url(../img/common/icn_arrow_right_02_sp.png); } }

.column-02-block-02-all {
  margin: 0 11.7% 0 11.7%; }
  @media only screen and (max-width: 768px) {
    .column-02-block-02-all {
      margin-left: 6%;
      margin-right: 6%; } }

.column-02-block-02 {
  display: -webkit-box;
  display: flex; }

.column-02-block-02-list {
  flex-basis: 45.7%;
  margin: 0 8.7% 0 0; }
  @media only screen and (max-width: 768px) {
    .column-02-block-02-list {
      flex-basis: 47%;
      margin-right: 6%; } }
  .column-02-block-02-list figure {
    margin: 0 0 21px 0;
    border: 1px solid #eee; }
    @media only screen and (max-width: 768px) {
      .column-02-block-02-list figure {
        margin-bottom: 10px; } }
    .column-02-block-02-list figure img {
      max-width: 100%;
      width: 100%;
      height: auto; }
  .column-02-block-02-list dl dt, .column-02-block-02-list dl dd {
    text-align: center; }
  .column-02-block-02-list dl dt {
    margin: 0 0 8px 0;
    color: #f6ab00;
    font-size: 20px; }
    @media only screen and (max-width: 768px) {
      .column-02-block-02-list dl dt {
        margin-bottom: 4px;
        font-size: 14px; } }
  .column-02-block-02-list dl dd {
    color: #666;
    font-size: 18px; }
    @media only screen and (max-width: 768px) {
      .column-02-block-02-list dl dd {
        font-size: 12px; } }

.column-02-block-02-list:nth-child(2n) {
  margin-right: 0; }

/* ----------------------------------------
 * テーブル
 * ------------------------------------- */
.table-block-01 {
  width: 100%;
  border-spacing: 0; }
  @media only screen and (max-width: 768px) {
    .table-block-01 thead {
      display: none; } }
  .table-block-01 thead th {
    height: 82px;
    padding: 12px 0 10px 0;
    box-sizing: border-box;
    border-right: 1px solid #bbb;
    background-color: #999;
    color: #fff;
    font-size: 18px;
    font-weight: normal; }
  .table-block-01 thead th:first-child {
    background-color: transparent; }
  .table-block-01 thead th:first-child, .table-block-01 thead th:last-child {
    border-right: 0; }
  .table-block-01 thead .bg-accent-01, .table-block-01 thead .bg-accent-02 {
    font-size: 20px; }
  .table-block-01 thead .bg-accent-01 {
    background-color: #f6ab00; }
  .table-block-01 thead .bg-accent-02 {
    background-color: #f68b00; }
  .table-block-01 thead .head-01 {
    width: 16.3%; }
  .table-block-01 thead .head-02 {
    width: 26%; }
  .table-block-01 thead .head-03 {
    width: 19.1%; }
  .table-block-01 thead .head-04 {
    width: 19.1%; }
  .table-block-01 thead .head-05 {
    width: 19.1%; }
  @media only screen and (max-width: 768px) {
    .table-block-01 tbody tr {
      display: block;
      margin-bottom: 25px; } }
  .table-block-01 tbody th, .table-block-01 tbody td {
    text-align: center;
    padding: 24px 0 22px 0;
    border-right: 1px dotted #ccc;
    box-sizing: border-box;
    background-color: #fff;
    font-weight: normal; }
    @media only screen and (max-width: 768px) {
      .table-block-01 tbody th, .table-block-01 tbody td {
        display: block;
        padding-top: 12px;
        padding-bottom: 11px;
        border-right: 0; } }
  @media only screen and (max-width: 768px) {
    .table-block-01 tbody th {
      padding-top: 11px;
      background-color: #333 !important;
      color: #fff;
      font-size: 18px;
      font-weight: bold; } }
  .table-block-01 tbody td {
    font-size: 18px; }
    @media only screen and (max-width: 768px) {
      .table-block-01 tbody td {
        padding-top: 0;
        font-size: 14px; } }
    .table-block-01 tbody td .accent {
      color: #f6ab00; }
  .table-block-01 tbody td:last-child {
    border-right: none; }
    @media only screen and (max-width: 768px) {
      .table-block-01 tbody td:last-child {
        border-bottom: none; } }
  @media only screen and (max-width: 768px) {
    .table-block-01 tbody td:before {
      display: block;
      margin-bottom: 11px;
      padding-top: 11px;
      padding-bottom: 11px;
      background-color: #f7f5f1;
      font-size: 16px;
      font-weight: bold; } }
  @media only screen and (max-width: 768px) {
    .table-block-01 tbody td:nth-of-type(1):before {
      background-color: #f6ab00;
      color: #fff; } }
  .table-block-01 tbody tr:nth-child(even) th, .table-block-01 tbody tr:nth-child(even) td {
    background-color: #f7f5f1; }
    @media only screen and (max-width: 768px) {
      .table-block-01 tbody tr:nth-child(even) th, .table-block-01 tbody tr:nth-child(even) td {
        background-color: #fff; } }
  @media only screen and (max-width: 768px) {
    .table-block-01 tbody tr:last-child {
      margin-bottom: 0; } }
  /*.table-block-01 tbody tr:last-child th, .table-block-01 tbody tr:last-child td {
    padding: 9px 0 9px 0; }*/
  @media only screen and (max-width: 768px) {
    .table-block-01 tbody tr:last-child td {
      padding-top: 0; } }

.table-block-01-aside {
  margin-top: 20px;
  padding: 13px 2.5% 13px 2.5%;
  line-height: 2.0;
  background-image: url(../img/common/bg_opacity_white_50.png);
  background-position: left top;
  background-repeat: repeat; }
  @media only screen and (max-width: 768px) {
    .table-block-01-aside {
      margin-top: 15px;
      padding: 7px 6% 7px 6%;
      line-height: 1.5;
      background-image: url(../img/common/bg_opacity_white_80.png); } }

.table-block-01.layout-02 thead .head-01 {
  width: 16.3%; }

.table-block-01.layout-02 thead .head-02 {
  width: 26%; }

.table-block-01.layout-02 thead .head-03 {
  width: 26%; }

.table-block-01.layout-02 thead .head-04 {
  width: 15.7%; }

.table-block-01.layout-02 thead .head-05 {
  width: 15.7%; }

.table-block-01.layout-02 tbody th, .table-block-01.layout-02 tbody td {
  height: 70px;
  padding: 0 0 0 0;
  line-height: 1.3;
  font-size: 16px; }
  @media only screen and (max-width: 768px) {
    .table-block-01.layout-02 tbody th, .table-block-01.layout-02 tbody td {
      height: auto;
      padding-bottom: 11px;
      font-size: 14px; } }

@media only screen and (max-width: 768px) {
  .table-block-01.layout-02 tbody th {
    padding-top: 11px;
    padding-bottom: 11px;
    font-size: 16px; } }

@media only screen and (max-width: 768px) {
  .table-block-01.layout-02 tbody td {
    line-height: 1.5; } }

@media only screen and (max-width: 768px) {
  .table-block-01.layout-02 tbody td:nth-of-type(2):before {
    background-color: #f68b00;
    color: #fff; } }

.table-block-01.layout-02 tbody tr:last-child td {
  font-size: 18px; }
  @media only screen and (max-width: 768px) {
    .table-block-01.layout-02 tbody tr:last-child td {
      font-size: 14px; } }

.table-block-02 {
  width: 100%;
  border-spacing: 0; }
  @media only screen and (max-width: 768px) {
    .table-block-02 thead {
      display: none; } }
  .table-block-02 thead th {
    height: 80px;
    box-sizing: border-box;
    border-right: 1px solid #fff;
    background-color: #f6ab00;
    color: #fff;
    font-size: 20px; }
  .table-block-02 thead th:first-child {
    background-color: transparent; }
  .table-block-02 thead th:first-child, .table-block-02 thead th:last-child {
    border-right: 0; }
  .table-block-02 thead .head-01 {
    width: 20%; }
  .table-block-02 thead .head-02 {
    width: 26.5%; }
  .table-block-02 thead .head-03 {
    width: 26.5%; }
  .table-block-02 thead .head-04 {
    width: 26.5%; }
  .table-block-02 tbody th, .table-block-02 tbody td {
    padding: 18px 0 17px 0;
    text-align: center;
    line-height: 1.3;
    font-size: 16px;
    font-weight: normal; }
    @media only screen and (max-width: 768px) {
      .table-block-02 tbody th, .table-block-02 tbody td {
        display: block;
        padding-top: 14px;
        padding-bottom: 13px;
        line-height: 1.5; } }
  .table-block-02 tbody th {
    border-top: 1px solid #ccc;
    border-left: 1px solid #ccc;
    border-right: 1px solid #ccc;
    background-color: #f7f5f1;
    font-size: 18px; }
    @media only screen and (max-width: 768px) {
      .table-block-02 tbody th {
        font-weight: bold; } }
  .table-block-02 tbody td {
    border-right: 1px dotted #ccc;
    border-bottom: 1px solid #ccc; }
    @media only screen and (max-width: 768px) {
      .table-block-02 tbody td {
        padding-top: 0;
        border-right: 1px solid #ccc;
        border-left: 1px solid #ccc;
        border-bottom: none;
        font-size: 14px; } }
  .table-block-02 tbody .style-ul-01 {
    padding-left: 20px;
    padding-right: 20px;
    text-align: left; }
    @media only screen and (max-width: 768px) {
      .table-block-02 tbody .style-ul-01 {
        padding-left: 0;
        padding-right: 0;
        text-align: center; } }
    .table-block-02 tbody .style-ul-01 li ~ li {
      margin-top: 9px; }
      @media only screen and (max-width: 768px) {
        .table-block-02 tbody .style-ul-01 li ~ li {
          margin-top: 5px; } }
  @media only screen and (max-width: 768px) {
    .table-block-02 tbody td:before {
      display: block;
      margin-bottom: 14px;
      padding-top: 14px;
      padding-bottom: 13px;
      background-color: #f6ab00;
      color: #fff;
      font-size: 16px;
      font-weight: bold; } }
  .table-block-02 tbody td:last-child {
    border-right: 1px solid #ccc; }
    @media only screen and (max-width: 768px) {
      .table-block-02 tbody td:last-child {
        border-bottom: 1px solid #ccc; } }
  .table-block-02 tbody .style-01 td {
    padding-top: 22px;
    padding-bottom: 21px;
    font-size: 18px; }
    @media only screen and (max-width: 768px) {
      .table-block-02 tbody .style-01 td {
        padding-top: 0;
        padding-bottom: 13px;
        font-size: 14px; } }
  @media only screen and (max-width: 768px) {
    .table-block-02 tbody tr:last-child {
      margin-bottom: 0; } }
  .table-block-02 tbody tr:last-child th {
    border-bottom: 1px solid #ccc; }
    @media only screen and (max-width: 768px) {
      .table-block-02 tbody tr:last-child th {
        border-bottom: none; } }
  @media only screen and (max-width: 768px) {
    .table-block-02 tbody tr {
      display: block;
      margin-bottom: 25px; }
      .table-block-02 tbody tr td:nth-of-type(1):before {
        content: "1日目分（訪問日）"; }
      .table-block-02 tbody tr td:nth-of-type(2):before {
        content: "2日目分"; }
      .table-block-02 tbody tr td:nth-of-type(3):before {
        content: "3日目分"; } }

.table-block-02-aside {
  margin-top: 12px;
  padding: 0 1% 0 1%;
  line-height: 2.0; }
  @media only screen and (max-width: 768px) {
    .table-block-02-aside {
      margin-top: 13px;
      padding: 0;
      line-height: 1.5; } }

/* ----------------------------------------
 * 表組み
 * ------------------------------------- */
.graph-block-01-all {
  margin: 0 8.3% 0 8.3%; }
  @media only screen and (max-width: 768px) {
    .graph-block-01-all {
      margin-left: 6%;
      margin-right: 6%; } }

.graph-block-01 h3 {
  text-align: center;
  background-color: #f6ab00;
  color: #fff; }

.graph-block-01-body {
  display: -webkit-box;
  display: flex;
  padding: 30px 3% 23px 3%;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  border-left: 1px solid #ccc; }
  @media only screen and (max-width: 768px) {
    .graph-block-01-body {
      flex-wrap: wrap;
      padding: 15px 6% 15px 6%; } }

.graph-block-01-list {
  flex-basis: 32%;
  margin: 0 2.1% 0 0; }
  @media only screen and (max-width: 768px) {
    .graph-block-01-list {
      flex-basis: 100%;
      margin-right: 0; } }

.graph-block-01-list:nth-child(3n) {
  margin-right: 0; }

.graph-block-01-note {
  margin: 12px 2em 0 2em;
  color: #666; }
  @media only screen and (max-width: 768px) {
    .graph-block-01-note {
      margin: 5px 0 0 0; } }
  .graph-block-01-note .indent {
    margin-left: 2em; }
    @media only screen and (max-width: 768px) {
      .graph-block-01-note .indent {
        display: block;
        margin-left: 0; } }

.graph-block-01-list.block-01 .box {
  background-color: #f7f5f1; }

.graph-block-01-list.block-02 .box {
  background-color: #999;
  color: #fff; }

.graph-block-01.layout-01 h3 {
  padding: 10px 0 10px 0;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 h3 {
      line-height: 1.3;
      font-size: 16px; } }

.graph-block-01.layout-01 .graph-block-01-body .graph-block-01-list {
  position: relative; }

@media only screen and (max-width: 768px) {
  .graph-block-01.layout-01 .graph-block-01-body .graph-block-01-list ~ .graph-block-01-list {
    margin-top: 30px; } }

.graph-block-01.layout-01 .graph-block-01-body .box {
  padding: 19px 0 19px 0;
  text-align: center;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 .graph-block-01-body .box {
      padding-top: 10px;
      padding-bottom: 10px;
      font-size: 14px; } }
  .graph-block-01.layout-01 .graph-block-01-body .box .indent {
    margin-left: 1em; }
  .graph-block-01.layout-01 .graph-block-01-body .box strong {
    margin: 0 0 0 5px;
    font-size: 24px; }
    @media only screen and (max-width: 768px) {
      .graph-block-01.layout-01 .graph-block-01-body .box strong {
        font-size: 18px; } }

.graph-block-01.layout-01 .graph-block-01-body .note {
  text-align: center;
  color: #f6ab00; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 .graph-block-01-body .note {
      margin-top: 3px;
      font-size: 12px; } }
  .graph-block-01.layout-01 .graph-block-01-body .note span {
    font-size: 22px; }
    @media only screen and (max-width: 768px) {
      .graph-block-01.layout-01 .graph-block-01-body .note span {
        font-size: 16px; } }

.graph-block-01.layout-01 .graph-block-01-body > div:nth-of-type(2) .note {
  margin-top: 6px; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 .graph-block-01-body > div:nth-of-type(2) .note {
      margin-top: 3px; } }

.graph-block-01.layout-01 .graph-block-01-body > div:nth-of-type(3) .box {
  padding-top: 16px;
  padding-bottom: 16px; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 .graph-block-01-body > div:nth-of-type(3) .box {
      padding-top: 10px;
      padding-bottom: 10px; } }

.graph-block-01.layout-01 .graph-block-01-body > div:nth-child(1):after, .graph-block-01.layout-01 .graph-block-01-body > div:nth-child(2):after {
  content: "";
  position: absolute;
  display: block;
  background-position: left top;
  background-repeat: no-repeat;
  z-index: 10;
  top: 17px;
  right: -30px;
  width: 38px;
  height: 38px;
  background-position: left top;
  background-repeat: no-repeat; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 .graph-block-01-body > div:nth-child(1):after, .graph-block-01.layout-01 .graph-block-01-body > div:nth-child(2):after {
      top: auto;
      bottom: -23px;
      right: auto;
      left: 50%;
      width: 19px;
      height: 19px;
      margin-left: -10px; } }

.graph-block-01.layout-01 .graph-block-01-body > div:nth-child(1):after {
  background-image: url(../img/common/icn_plus_02.png); }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 .graph-block-01-body > div:nth-child(1):after {
      background-size: 19px 19px; } }

.graph-block-01.layout-01 .graph-block-01-body > div:nth-child(2):after {
  background-image: url(../img/common/icn_equal_01.png); }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-01 .graph-block-01-body > div:nth-child(2):after {
      background-size: 19px 19px; } }

.graph-block-01.layout-02 h3 {
  padding: 16px 0 22px 0;
  text-align: center;
  font-size: 24px; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-02 h3 {
      padding-top: 8px;
      padding-bottom: 11px;
      font-size: 16px; } }
  .graph-block-01.layout-02 h3 span {
    display: inline-block;
    padding: 4px 22px 3px 22px;
    border-radius: 5px;
    background-image: url(../img/common/bg_opacity_white_50.png);
    background-position: left top;
    background-repeat: repeat;
    color: #333;
    font-size: 16px;
    font-weight: normal; }
    @media only screen and (max-width: 768px) {
      .graph-block-01.layout-02 h3 span {
        margin-top: 5px;
        padding-left: 11px;
        padding-right: 11px;
        font-size: 14px; } }

.graph-block-01.layout-02 .graph-block-01-list .box {
  margin: 0 0 17px 0;
  padding: 19px 0 19px 0;
  text-align: center;
  font-size: 20px;
  font-weight: bold; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-02 .graph-block-01-list .box {
      margin-bottom: 5px;
      padding-top: 10px;
      padding-bottom: 10px;
      font-size: 14px; } }

.graph-block-01.layout-02 .graph-block-01-list .price {
  text-align: center;
  line-height: 1.4;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .graph-block-01.layout-02 .graph-block-01-list .price {
      font-size: 14px; } }
  .graph-block-01.layout-02 .graph-block-01-list .price strong {
    font-size: 30px; }
    @media only screen and (max-width: 768px) {
      .graph-block-01.layout-02 .graph-block-01-list .price strong {
        font-size: 18px; } }
  .graph-block-01.layout-02 .graph-block-01-list .price span {
    color: #f6ab00; }

@media only screen and (max-width: 768px) {
  .graph-block-01.layout-02 .graph-block-01-list ~ .graph-block-01-list {
    margin-top: 15px; } }

/* ----------------------------------------
 * ステップ
 * ------------------------------------- */
.step-block-01 {
  margin: 0 6.1% 0 6.1%;
  padding: 55px 10% 62px 10.8%;
  background-color: #f7f5f1; }
  @media only screen and (max-width: 768px) {
    .step-block-01 {
      margin-left: 6%;
      margin-right: 6%;
      padding: 29px 6% 29px 6%; } }

.step-block-01-inner {
  position: relative; }

.step-block-01-inner:before {
  content: "";
  z-index: 1;
  position: absolute;
  top: 36px;
  left: 54px;
  display: block;
  width: 10px;
  height: 650px;
  background-color: #fff; }
  @media only screen and (max-width: 768px) {
    .step-block-01-inner:before {
      display: none; } }

.step-block-01-list {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .step-block-01-list {
      flex-wrap: wrap; } }
  .step-block-01-list .figure {
    display: -webkit-box;
    display: flex;
    flex-basis: 20.6%;
    -webkit-box-align: center;
    align-items: center; }
    @media only screen and (max-width: 768px) {
      .step-block-01-list .figure {
        flex-basis: 100%; } }
    .step-block-01-list .figure p {
      width: 118px;
      height: 118px;
      padding-top: 24px;
      text-align: center;
      box-sizing: border-box;
      border-radius: 50%;
      background-color: #fff;
      font-size: 20px; }
      @media only screen and (max-width: 768px) {
        .step-block-01-list .figure p {
          width: 100%;
          height: auto;
          margin-bottom: 15px;
          padding: 5px 10px 4px 10px;
          border-radius: 0;
          font-size: 16px;
          font-weight: bold; } }
      .step-block-01-list .figure p span {
        display: block;
        margin-top: -7px;
        font-size: 40px; }
        @media only screen and (max-width: 768px) {
          .step-block-01-list .figure p span {
            display: inline;
            margin-top: 0;
            font-size: 16px; } }
  .step-block-01-list .content {
    flex-basis: 79.5%; }
    @media only screen and (max-width: 768px) {
      .step-block-01-list .content {
        flex-basis: 100%; } }
    .step-block-01-list .content dl dt {
      margin: 0 0 14px 0;
      color: #f68b00;
      font-size: 30px; }
      @media only screen and (max-width: 768px) {
        .step-block-01-list .content dl dt {
          margin-bottom: 5px;
          font-size: 16px; } }
    .step-block-01-list .content dl dd {
      line-height: 1.6;
      font-size: 18px; }
      @media only screen and (max-width: 768px) {
        .step-block-01-list .content dl dd {
          font-size: 14px; } }
    .step-block-01-list .content p {
      margin-top: 16px; }
      @media only screen and (max-width: 768px) {
        .step-block-01-list .content p {
          margin-top: 5px; } }

@media only screen and (max-width: 768px) {
  .step-block-01-list ~ .step-block-01-list {
    margin-top: 25px; } }

.step-block-01-list ~ .step-block-01-list .figure, .step-block-01-list ~ .step-block-01-list .content {
  margin-top: 45px;
  padding-top: 43px; }
  @media only screen and (max-width: 768px) {
    .step-block-01-list ~ .step-block-01-list .figure, .step-block-01-list ~ .step-block-01-list .content {
      margin-top: 0;
      padding-top: 0; } }

.step-block-01-list ~ .step-block-01-list .content {
  border-top: 1px dotted #999; }
  @media only screen and (max-width: 768px) {
    .step-block-01-list ~ .step-block-01-list .content {
      border-top: none; } }

.step-block-02-all {
  margin: 0 9.2% 50px 9.2%; }
  @media only screen and (max-width: 768px) {
    .step-block-02-all {
      margin: 0 6% 29px 6%; } }

.step-block-02 {
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .step-block-02 {
      flex-wrap: wrap; } }

.step-block-02-list {
  position: relative;
  display: -webkit-box;
  display: flex;
  flex-basis: 21.7%;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center;
  height: 180px;
  margin-right: 4.3%;
  text-align: center;
  line-height: 1.8;
  background-color: #f7f5f1;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .step-block-02-list {
      flex-basis: 100%;
      height: auto;
      padding-top: 15px;
      padding-bottom: 15px;
      margin-right: 0;
      font-size: 14px; } }

@media only screen and (max-width: 768px) {
  .step-block-02-list ~ .step-block-02-list {
    margin-top: 25px; } }

.step-block-02-list:nth-child(4n) {
  margin-right: 0; }

.step-block-02-list:after {
  content: "";
  z-index: 10;
  position: absolute;
  top: 64px;
  right: -52px;
  display: block;
  width: 0;
  height: 0;
  border-left: 26px solid #f7f5f1;
  border-right: 26px solid transparent;
  border-top: 26px solid transparent;
  border-bottom: 26px solid transparent; }
  @media only screen and (max-width: 768px) {
    .step-block-02-list:after {
      top: auto;
      bottom: -26px;
      right: auto;
      left: 50%;
      margin-left: -13px;
      border-left: 13px solid transparent;
      border-right: 13px solid transparent;
      border-top: 13px solid #f7f5f1;
      border-bottom: 13px solid transparent; } }

.step-block-02-list:nth-child(4n):after {
  display: none; }

/* ----------------------------------------
 * インフォメーション
 * ------------------------------------- */
.information-block-01-all {
  margin: 0 2.5% 0 2.5%;
  padding: 36px 6.1% 55px 6.1%;
  border: 1px solid #666; }
  @media only screen and (max-width: 768px) {
    .information-block-01-all {
      margin-left: 6%;
      margin-right: 6%;
      padding: 18px 6% 18px 6%; } }

.information-block-01 h3 {
  margin: 0 0 27px 0;
  text-align: center;
  font-size: 26px;
  font-weight: normal; }
  @media only screen and (max-width: 768px) {
    .information-block-01 h3 {
      margin-bottom: 15px;
      line-height: 1.3;
      font-size: 16px; } }

.information-block-01-list h4 {
  margin: 0 0 18px 0;
  padding: 9px 0 6px 0;
  text-align: center;
  background-color: #eee;
  font-size: 18px;
  font-weight: normal; }
  @media only screen and (max-width: 768px) {
    .information-block-01-list h4 {
      margin-bottom: 10px;
      padding-top: 6px;
      padding-bottom: 5px;
      font-size: 14px; } }

.information-block-01-list ~ .information-block-01-list {
  margin-top: 23px; }

.information-block-01-body {
  padding: 0 3.6% 0 3.6%; }
  @media only screen and (max-width: 768px) {
    .information-block-01-body {
      padding: 0; } }
  .information-block-01-body p {
    line-height: 1.8; }
    @media only screen and (max-width: 768px) {
      .information-block-01-body p {
        line-height: 1.5; } }

.information-block-02-all {
  margin: 0 8.3% 0 8.3%; }
  @media only screen and (max-width: 768px) {
    .information-block-02-all {
      margin-left: 6%;
      margin-right: 6%; } }

@media only screen and (max-width: 768px) {
  .information-block-02 {
    border: 1px solid #ccc; } }

.information-block-02-list h3 {
  margin: 0 0 28px 0;
  padding: 0 1.5% 7px 1.5%;
  border-bottom: 1px solid #f68b00;
  color: #f68b00;
  font-size: 26px;
  font-weight: normal; }
  @media only screen and (max-width: 768px) {
    .information-block-02-list h3 {
      position: relative;
      margin-bottom: 0;
      padding: 13px 13px 13px 13px;
      border-bottom: none;
      color: #333;
      font-size: 16px;
      font-weight: bold; } }
  @media only screen and (max-width: 768px) {
    .information-block-02-list h3 span {
      transition: 0.3s ease 0s;
      position: absolute;
      top: 16px;
      right: 15px;
      display: block;
      width: 14px;
      height: 15px;
      background-image: url(../img/common/icn_plus_03.png);
      background-position: left top;
      background-repeat: no-repeat;
      background-size: 14px 15px; } }

.information-block-02-list ~ .information-block-02-list {
  margin-top: 36px; }
  @media only screen and (max-width: 768px) {
    .information-block-02-list ~ .information-block-02-list {
      margin-top: 0;
      border-top: 1px solid #ccc; } }

.informationo-block-02-content {
  padding: 0 2% 0 2%; }
  @media only screen and (max-width: 768px) {
    .informationo-block-02-content {
      display: none;
      padding: 0 15px 15px 15px; } }
  .informationo-block-02-content dl dt {
    margin: 0 0 7px 1%;
    font-size: 18px;
    font-weight: bold; }
    @media only screen and (max-width: 768px) {
      .informationo-block-02-content dl dt {
        margin-bottom: 7px;
        font-size: 14px; } }
  .informationo-block-02-content dl dt ~ dt {
    margin-top: 31px; }
    @media only screen and (max-width: 768px) {
      .informationo-block-02-content dl dt ~ dt {
        margin-top: 15px; } }
  .informationo-block-02-content ul li {
    margin-left: 1em;
    text-indent: -1em;
    line-height: 1.8; }
    @media only screen and (max-width: 768px) {
      .informationo-block-02-content ul li {
        line-height: 1.5; } }
  @media only screen and (max-width: 768px) {
    .informationo-block-02-content ul li ~ li {
      margin-top: 5px; } }

@media only screen and (max-width: 768px) {
  .information-block-02-list.is-open h3 span {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg); } }

/* ----------------------------------------
 * フレーム
 * ------------------------------------- */
.frame-block-01 {
  height: 420px;
  padding: 68px 0 0 0;
  box-sizing: border-box;
  background-image: url(../img/iekeeping/bg_frame_01.png);
  background-position: center top;
  background-repeat: no-repeat; }
  @media only screen and (max-width: 768px) {
    .frame-block-01 {
      height: auto;
      margin-left: 6%;
      margin-right: 6%;
      padding-top: 29px;
      border-top: 1px solid #ccc;
      background-image: none; } }

.frame-block-01-ttl {
  margin: 0 0 42px 0;
  text-align: center;
  font-size: 26px;
  font-weight: bold; }
  @media only screen and (max-width: 768px) {
    .frame-block-01-ttl {
      margin-bottom: 20px;
      font-size: 15px; } }
  .frame-block-01-ttl span {
    margin: 0 0 0 5px; }

.frame-block-01-txt {
  margin: 40px 0 0 0;
  text-align: center;
  line-height: 1.8;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .frame-block-01-txt {
      margin-top: 20px;
      text-align: left;
      font-size: 14px; } }

.frame-block-02 {
  padding: 27px 0 19px 0;
  border: 3px solid #f68b00; }
  @media only screen and (max-width: 768px) {
    .frame-block-02 {
      padding-top: 14px;
      padding-bottom: 10px;
      border: 2px solid #f68b00; } }
  .frame-block-02 p {
    text-align: center;
    font-size: 28px;
    color: #f68b00; }
    @media only screen and (max-width: 768px) {
      .frame-block-02 p {
        line-height: 1.3;
        font-size: 14px; } }
    .frame-block-02 p strong {
      font-size: 40px; }
      @media only screen and (max-width: 768px) {
        .frame-block-02 p strong {
          font-size: 20px; } }
    .frame-block-02 p .icn {
      position: relative;
      top: -3px;
      margin-left: 20px;
      margin-right: 20px; }

.frame-block-02-label {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  margin: 0 0 6px 0; }
  @media only screen and (max-width: 768px) {
    .frame-block-02-label {
      margin-bottom: 13px; } }
  .frame-block-02-label li {
    width: 160px;
    padding: 2px 0 0 0;
    text-align: center;
    box-sizing: border-box;
    color: #fff;
    font-size: 20px; }
    @media only screen and (max-width: 768px) {
      .frame-block-02-label li {
        display: -webkit-box;
        display: flex;
        -webkit-box-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        align-items: center;
        width: 100px;
        padding-top: 6px;
        padding-bottom: 6px;
        font-size: 14px; } }
    .frame-block-02-label li span {
      font-size: 22px; }
      @media only screen and (max-width: 768px) {
        .frame-block-02-label li span {
          font-size: 14px; } }
  .frame-block-02-label .style-01 {
    padding-bottom: 3px; }
    @media only screen and (max-width: 768px) {
      .frame-block-02-label .style-01 {
        padding-bottom: 6px; } }
  .frame-block-02-label .color-01 {
    background-color: #f68b00; }
  .frame-block-02-label .color-02 {
    background-color: #999; }
  .frame-block-02-label li ~ li {
    margin-left: 30px; }
    @media only screen and (max-width: 768px) {
      .frame-block-02-label li ~ li {
        margin-left: 15px; } }

/* ----------------------------------------
 * ヘッダー
 * ------------------------------------- */
@media only screen and (max-width: 768px) {
  .header.cook .header-ci {
    width: 140px; } }

.header.cook .header-ci a {
  width: 240px;
  height: 180px;
  background-image: url(../img/iecook/header_ci_txt.png); }
  @media only screen and (max-width: 768px) {
    .header.cook .header-ci a {
      background-image: url(../img/iecook/header_ci_txt_sp.png);
      background-size: 101px 23px; } }

/* ----------------------------------------
 * グロナビ
 * ------------------------------------- */
@media only screen and (max-width: 768px) {
  .gnav-all.cook .gnav-head-ci a {
    width: 101px;
    background-image: url(../img/iecook/header_ci_txt_sp.png);
    background-size: 101px 23px; } }

.gnav-all.cook .gnav ul li {
  flex-basis: 19.5%; }
  @media only screen and (max-width: 768px) {
    .gnav-all.cook .gnav ul li {
      flex-basis: 100%; } }

.gnav-all.cook .gnav ul li:last-child {
  flex-basis: 21.5%; }
  @media only screen and (max-width: 768px) {
    .gnav-all.cook .gnav ul li:last-child {
      flex-basis: 100%; } }

/* ----------------------------------------
 * トップ：VI
 * ------------------------------------- */
.vi.cook {
  background-image: url(../img/iecook/vi_img.jpg); }
  .vi.cook dl dt {
    width: 198px;
    height: 50px;
    background-image: url(../img/iecook/vi_ttl.png); }
    @media only screen and (max-width: 768px) {
      .vi.cook dl dt {
        width: 99px;
        height: 25px;
        background-image: url(../img/iecook/vi_ttl.png);
        background-size: 99px 25px; } }
  .vi.cook dl dd {
    width: 580px;
    height: 82px;
    background-image: url(../img/iecook/vi_copy_txt.png); }
    @media only screen and (max-width: 768px) {
      .vi.cook dl dd {
        width: 251px;
        height: 72px;
        background-image: url(../img/iecook/vi_copy_txt_sp.png);
        background-size: 251px 72px; } }

/* ----------------------------------------
 * 下層：VI
 * ------------------------------------- */
.low-vi.cook .low-vi-visual {
  background-image: url(../img/iecook/vi_low_img.jpg); }

/* ----------------------------------------
 * プランページ：レイアウト
 * ------------------------------------- */
.cook-plan-layout-01, .cook-plan-layout-02 {
  margin-left: 8.3%;
  margin-right: 8.3%; }
  @media only screen and (max-width: 768px) {
    .cook-plan-layout-01, .cook-plan-layout-02 {
      margin-left: 6%;
      margin-right: 6%; } }
  .cook-plan-layout-01 .frame-block-02, .cook-plan-layout-02 .frame-block-02 {
    margin-top: 31px;
    margin-bottom: 50px; }
    @media only screen and (max-width: 768px) {
      .cook-plan-layout-01 .frame-block-02, .cook-plan-layout-02 .frame-block-02 {
        margin-top: 29px;
        margin-bottom: 29px; } }
  .cook-plan-layout-01 .txt-block-03, .cook-plan-layout-02 .txt-block-03 {
    margin-top: 13px;
    margin-bottom: 53px; }
    @media only screen and (max-width: 768px) {
      .cook-plan-layout-01 .txt-block-03, .cook-plan-layout-02 .txt-block-03 {
        margin-top: 7px;
        margin-bottom: 29px;
        padding-left: 0; } }

.cook-plan-layout-02 {
  margin-left: 2.5%;
  margin-right: 2.5%; }
  @media only screen and (max-width: 768px) {
    .cook-plan-layout-02 {
      margin-left: 0;
      margin-right: 0; } }
  .cook-plan-layout-02 .content-inner {
    padding-left: 6.1%;
    padding-right: 6.1%; }
    @media only screen and (max-width: 768px) {
      .cook-plan-layout-02 .content-inner {
        padding-left: 6%;
        padding-right: 6%; } }
  .cook-plan-layout-02 .information-block-02 {
    padding-left: 0;
    padding-right: 0; }

/* ----------------------------------------
 * トップ：フィーチャー
 * ------------------------------------- */
.cook-top-feature .column-03-block-01 > div {
  height: 350px; }

/* ----------------------------------------
 * トップ：サービス
 * ------------------------------------- */
.cook-top-service .column-02-block-01-head p span:before {
  top: -48px;
  left: -156px;
  width: 130px;
  height: 108px;
  background-image: url(../img/iecook/top_img_illust_01.png); }

.cook-top-service .column-02-block-01-all {
  background-image: url(../img/iecook/top_img_bg_layer_01.jpg); }

/* ----------------------------------------
 * トップ：ぜひ比べてください
 * ------------------------------------- */
.cook-top-compare-table-all {
  background-image: url(../img/iecook/top_img_bg_layer_02.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover; }
  @media only screen and (max-width: 768px) {
    .cook-top-compare-table-all .table-block-01 tbody tr td:nth-of-type(1):before {
      content: "当社ベーシック作り置きプラン"; }
    .cook-top-compare-table-all .table-block-01 tbody tr td:nth-of-type(2):before {
      content: "A社"; }
    .cook-top-compare-table-all .table-block-01 tbody tr td:nth-of-type(3):before {
      content: "B社"; }
    .cook-top-compare-table-all .table-block-01 tbody tr td:nth-of-type(4):before {
      content: "C社"; } }

.cook-top-compare-table-inner {
  padding: 50px 6.1% 50px 6.1%; }
  @media only screen and (max-width: 768px) {
    .cook-top-compare-table-inner {
      padding: 25px 6% 25px 6%; } }

/* ----------------------------------------
 * トップ：ご利用事例
 * ------------------------------------- */
.cook-top-case {
  margin-bottom: 100px; }
  @media only screen and (max-width: 768px) {
    .cook-top-case {
      margin-bottom: 29px; } }
  .cook-top-case .graph-block-01-all {
    margin-top: 44px; }
    @media only screen and (max-width: 768px) {
      .cook-top-case .graph-block-01-all {
        margin-top: 29px; } }

/* ----------------------------------------
 * トップ：安心の栄養士サポートプラン
 * ------------------------------------- */
.cook-top-plan-01 .btn-standard-02, .cook-top-plan-01 .btn-standard-03, .cook-top-plan-01 .btn-standard-06, .cook-top-plan-01 .btn-standard-07 {
  margin-top: 35px; }
  @media only screen and (max-width: 768px) {
    .cook-top-plan-01 .btn-standard-02, .cook-top-plan-01 .btn-standard-03, .cook-top-plan-01 .btn-standard-06, .cook-top-plan-01 .btn-standard-07 {
      margin-top: 29px;
      padding-left: 6%;
      padding-right: 6%;
      line-height: 1.3; }
      .cook-top-plan-01 .btn-standard-02 a, .cook-top-plan-01 .btn-standard-03 a, .cook-top-plan-01 .btn-standard-06 a, .cook-top-plan-01 .btn-standard-07 a {
        padding-top: 7px; } }

/* ----------------------------------------
 * トップ：ご利用開始までの流れ
 * ------------------------------------- */
.cook-top-flow .txt-block-02 {
  margin-bottom: 24px; }
  @media only screen and (max-width: 768px) {
    .cook-top-flow .txt-block-02 {
      margin-bottom: 16px; } }

.cook-top-flow .btn-standard-02, .cook-top-flow .btn-standard-03, .cook-top-flow .btn-standard-06, .cook-top-flow .btn-standard-07 {
  margin-top: 50px; }
  @media only screen and (max-width: 768px) {
    .cook-top-flow .btn-standard-02, .cook-top-flow .btn-standard-03, .cook-top-flow .btn-standard-06, .cook-top-flow .btn-standard-07 {
      margin-top: 29px;
      padding-left: 6%;
      padding-right: 6%; } }

/* ----------------------------------------
 * トップ：体験プラン
 * ------------------------------------- */
.cook-top-plan-02 .column-02-block-01-all {
  background-image: url(../img/iecook/top_img_bg_layer_01.jpg); }

.cook-top-plan-02 .txt-block-01, .cook-top-plan-02 .txt-block-02, .cook-top-plan-02 .txt-block-03, .cook-top-plan-02 .txt-block-04 {
  line-height: 1.8; }

.cook-top-plan-02 .information-block-01-all {
  margin-top: 50px; }
  @media only screen and (max-width: 768px) {
    .cook-top-plan-02 .information-block-01-all {
      margin-top: 29px; } }

/* ----------------------------------------
 * ベーシック作り置きプラン：イントロ
 * ------------------------------------- */
.cook-basic-intro {
  margin-bottom: 100px; }
  @media only screen and (max-width: 768px) {
    .cook-basic-intro {
      margin-bottom: 29px; } }

/* ----------------------------------------
 * ベーシック作り置きプラン：安心の栄養士サポートプラン
 * ------------------------------------- */
.cook-basic-plan-01 .btn-standard-02, .cook-basic-plan-01 .btn-standard-03, .cook-basic-plan-01 .btn-standard-06, .cook-basic-plan-01 .btn-standard-07 {
  margin-top: 35px;
  margin-bottom: 75px; }
  @media only screen and (max-width: 768px) {
    .cook-basic-plan-01 .btn-standard-02, .cook-basic-plan-01 .btn-standard-03, .cook-basic-plan-01 .btn-standard-06, .cook-basic-plan-01 .btn-standard-07 {
      margin-top: 29px;
      margin-bottom: 29px;
      padding-left: 6%;
      padding-right: 6%;
      line-height: 1.3; } }
  @media only screen and (max-width: 768px) {
    .cook-basic-plan-01 .btn-standard-02 a, .cook-basic-plan-01 .btn-standard-03 a, .cook-basic-plan-01 .btn-standard-06 a, .cook-basic-plan-01 .btn-standard-07 a {
      padding-top: 7px; } }

/* ----------------------------------------
 * ベーシック作り置きプラン：ご利用開始までの流れ
 * ------------------------------------- */
@media only screen and (max-width: 768px) {
  .cook-basic-flow .btn-standard-02, .cook-basic-flow .btn-standard-03, .cook-basic-flow .btn-standard-06, .cook-basic-flow .btn-standard-07 {
    padding-left: 6%;
    padding-right: 6%; } }

/* ----------------------------------------
 * 栄養士サポートプラン：ナビ
 * ------------------------------------- */
.cook-support-nav {
  background-image: url(../img/iecook/low_img_bg_layer_01.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover; }

.cook-support-nav-inner {
  display: -webkit-box;
  display: flex;
  padding: 105px 6.1% 135px 6.1%; }
  @media only screen and (max-width: 768px) {
    .cook-support-nav-inner {
      flex-wrap: wrap;
      padding: 29px 6% 50px 6%; } }

.cook-support-nav-list {
  position: relative;
  flex-basis: 31%;
  margin-right: 3.5%;
  border-radius: 5px 5px 0 0;
  background-color: #fff; }
  @media only screen and (max-width: 768px) {
    .cook-support-nav-list {
      flex-basis: 100%;
      margin-right: 0;
      margin-bottom: 50px; } }
  .cook-support-nav-list a {
    position: relative;
    display: block;
    padding: 55px 30px 33px 30px;
    text-decoration: none;
    line-height: 1.8; }
    @media only screen and (max-width: 768px) {
      .cook-support-nav-list a {
        padding: 29px 6% 24px 6%;
        line-height: 1.5; } }
  .cook-support-nav-list dl dt {
    margin: 0 0 11px 0;
    text-align: center;
    color: #f68b00;
    font-size: 22px;
    font-weight: bold; }
    @media only screen and (max-width: 768px) {
      .cook-support-nav-list dl dt {
        margin-bottom: 7px;
        font-size: 18px; } }
  .cook-support-nav-list dl dd {
    color: #333; }

.cook-support-nav-list:before {
  z-index: 2;
  content: "";
  position: absolute;
  display: block;
  background-position: left top;
  background-repeat: no-repeat;
  top: -13px;
  left: 50%;
  width: 52px;
  height: 30px;
  margin-left: -26px;
  background-image: url(../img/iecook/low_icn_clip.png);
  background-position: left top;
  background-repeat: no-repeat; }
  @media only screen and (max-width: 768px) {
    .cook-support-nav-list:before {
      top: -7px;
      width: 26px;
      height: 15px;
      margin-left: -13px;
      background-size: 26px auto; } }

.cook-support-nav-list:after {
  content: "";
  position: absolute;
  display: block;
  background-position: left top;
  background-repeat: no-repeat;
  bottom: -40px;
  left: 0;
  width: 100%;
  height: 40px;
  border-radius: 0 0 5px 5px;
  background-color: #f6ab00;
  background-image: url(../img/common/icn_arrow_bottom_01.png);
  background-position: center center;
  background-repeat: no-repeat; }
  @media only screen and (max-width: 768px) {
    .cook-support-nav-list:after {
      bottom: -25px;
      height: 25px;
      background-size: 14px auto; } }

.cook-support-nav-list:nth-child(3n) {
  margin-right: 0; }
  @media only screen and (max-width: 768px) {
    .cook-support-nav-list:nth-child(3n) {
      margin-bottom: 0; } }

/* ----------------------------------------
 * 栄養士サポートプラン：サービスご提供の流れ
 * ------------------------------------- */
.cook-support-flow {
  margin-top: 50px;
  margin-bottom: 90px; }
  @media only screen and (max-width: 768px) {
    .cook-support-flow {
      margin-top: 29px;
      margin-bottom: 29px; } }

/* ----------------------------------------
 * 栄養士サポートプラン：腎臓病対応プランのご案内
 * ------------------------------------- */
.cook-support-plan-03 .information-block-02-all {
  margin-top: 85px;
  margin-left: 0;
  margin-right: 0; }
  @media only screen and (max-width: 768px) {
    .cook-support-plan-03 .information-block-02-all {
      margin-top: 29px; } }

/* ----------------------------------------
 * ヘッダー
 * ------------------------------------- */
@media only screen and (max-width: 768px) {
  .header.keep .header-ci {
    width: 165px; } }

.header.keep .header-ci a {
  background-image: url(../img/iekeeping/header_ci_txt.png); }
  @media only screen and (max-width: 768px) {
    .header.keep .header-ci a {
      background-image: url(../img/iekeeping/header_ci_txt_sp.png);
      background-size: 131px 23px; } }

/* ----------------------------------------
 * グロナビ
 * ------------------------------------- */
@media only screen and (max-width: 768px) {
  .gnav-all.keep .gnav-head-ci a {
    width: 131px;
    background-image: url(../img/iekeeping/header_ci_txt_sp.png);
    background-size: 131px 23px; } }

.gnav-all.keep .gnav ul li {
  flex-basis: 15.6%; }
  @media only screen and (max-width: 768px) {
    .gnav-all.keep .gnav ul li {
      flex-basis: 100%; } }

.gnav-all.keep .gnav ul li:last-child {
  flex-basis: 21.5%; }
  @media only screen and (max-width: 768px) {
    .gnav-all.keep .gnav ul li:last-child {
      flex-basis: 100%; } }

/* ----------------------------------------
 * トップ：VI
 * ------------------------------------- */
.vi.keep {
  background-image: url(../img/iekeeping/vi_img.jpg); }
  .vi.keep dl dt {
    width: 188px;
    height: 48px;
    background-image: url(../img/iekeeping/vi_ttl.png); }
    @media only screen and (max-width: 768px) {
      .vi.keep dl dt {
        width: 94px;
        height: 24px;
        background-image: url(../img/iekeeping/vi_ttl.png);
        background-size: 94px 24px; } }
  .vi.keep dl dd {
    width: 538px;
    height: 82px;
    background-image: url(../img/iekeeping/vi_copy_txt.png); }
    @media only screen and (max-width: 768px) {
      .vi.keep dl dd {
        width: 220px;
        height: 74px;
        background-image: url(../img/iekeeping/vi_copy_txt_sp.png);
        background-size: 220px 74px; } }

/* ----------------------------------------
 * 下層：VI
 * ------------------------------------- */
.low-vi.keep .low-vi-visual {
  background-image: url(../img/iekeeping/vi_low_img.jpg); }

/* ----------------------------------------
 * トップ：フィーチャー
 * ------------------------------------- */
.keep-top-feature .column-03-block-01 > div {
  height: 370px; }

/* ----------------------------------------
 * プラン：イラスト
 * ------------------------------------- */
@media only screen and (max-width: 768px) {
  .plan-illust-block {
    margin-bottom: 13px; } }

.plan-illust-block ul {
  position: relative;
  display: -webkit-box;
  display: flex;
  flex-wrap: wrap; }
  .plan-illust-block ul li {
    position: relative;
    display: -webkit-box;
    display: flex;
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: end;
    align-items: flex-end;
    height: 86px;
    padding: 0 0 6px 0;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    box-sizing: border-box;
    background-repeat: no-repeat;
    font-size: 13px; }
    @media only screen and (max-width: 768px) {
      .plan-illust-block ul li {
        height: 60px;
        font-size: 9px; } }

.plan-illust-block.style-01 ul li {
  flex-basis: 25%;
  color: #fff; }

.plan-illust-block.style-01 ul li:nth-child(4n) {
  border-right: none; }

.ie .plan-illust-block.style-01 ul li {
  flex-basis: 24.8%; }

.plan-illust-block.style-02 ul li {
  flex-basis: 20%;
  border-top: 1px solid #f6ab00;
  border-right: 1px solid #f6ab00;
  border-bottom: 1px solid #f6ab00;
  color: #f6ab00; }

.plan-illust-block.style-02 ul li:first-child {
  border-left: 1px solid #f6ab00; }

.ie .plan-illust-block.style-02 ul li {
  flex-basis: 19.8%; }

.ie .plan-illust-block.style-02 ul li:nth-child(4n) {
  flex-basis: 19.6%; }

@media screen and (max-width: 1400px) {
  .ie .plan-illust-block.style-02 ul li {
    flex-basis: 19.7%;
    font-size: 12px; }
  .ie .plan-illust-block.style-02 ul li:nth-child(4n) {
    flex-basis: 19.6%; } }

.plan-illust-block.style-03 ul li {
  flex-basis: 25%;
  border-left: 1px solid #f68b00;
  border-bottom: 1px solid #f68b00;
  color: #f68b00; }

.plan-illust-block.style-03 ul li:nth-child(-n+4) {
  border-top: 1px solid #f68b00; }

.plan-illust-block.style-03 ul li:nth-child(4n) {
  border-right: 1px solid #f68b00; }

.ie .plan-illust-block.style-03 ul li {
  flex-basis: 24.8%; }

.ie .plan-illust-block.style-03 ul li:nth-child(4n) {
  flex-basis: 24.1%; }

@media screen and (max-width: 1500px) {
  .ie .plan-illust-block.style-03 ul li {
    flex-basis: 24.7%; }
  .ie .plan-illust-block.style-03 ul li:nth-child(4n) {
    flex-basis: 24.1%; } }

@media screen and (max-width: 1200px) {
  .ie .plan-illust-block.style-03 ul li {
    flex-basis: 24.6%; }
  .ie .plan-illust-block.style-03 ul li:nth-child(4n) {
    flex-basis: 24.1%; } }

.plan-illust {
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  background-repeat: no-repeat; }

.plan-illust.color-01 {
  background-position: left top; }

.plan-illust-living {
  top: 18px;
  width: 56px;
  height: 30px;
  margin-left: -28px;
  background-image: url(../img/iekeeping/icn_service_living.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-living {
      top: 15px;
      width: 28px;
      height: 15px;
      margin-left: -14px;
      background-size: 28px 45px; } }

.plan-illust-living.color-02 {
  background-position: left -30px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-living.color-02 {
      background-position: left -15px; } }

.plan-illust-living.color-03 {
  background-position: left -60px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-living.color-03 {
      background-position: left -30px; } }

.plan-illust-bath {
  top: 11px;
  width: 50px;
  height: 38px;
  margin-left: -25px;
  background-image: url(../img/iekeeping/icn_service_bath.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-bath {
      width: 25px;
      height: 19px;
      margin-left: -13px;
      background-size: 25px 57px; } }

.plan-illust-bath.color-02 {
  background-position: left -38px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-bath.color-02 {
      background-position: left -19px; } }

.plan-illust-bath.color-03 {
  background-position: left -76px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-bath.color-03 {
      background-position: left -38px; } }

.plan-illust-toilet {
  top: 22px;
  width: 36px;
  height: 26px;
  margin-left: -18px;
  background-image: url(../img/iekeeping/icn_service_toilet.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-toilet {
      top: 16px;
      width: 18px;
      height: 13px;
      margin-left: -9px;
      background-size: 18px 39px; } }

.plan-illust-toilet.color-02 {
  background-position: left -26px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-toilet.color-02 {
      background-position: left -13px; } }

.plan-illust-toilet.color-03 {
  background-position: left -52px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-toilet.color-03 {
      background-position: left -26px; } }

.plan-illust-bedmake {
  top: 15px;
  width: 44px;
  height: 36px;
  margin-left: -22px;
  background-image: url(../img/iekeeping/icn_service_bedmake.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-bedmake {
      top: 13px;
      width: 22px;
      height: 18px;
      margin-left: -11px;
      background-size: 22px 54px; } }

.plan-illust-bedmake.color-02 {
  background-position: left -36px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-bedmake.color-02 {
      background-position: left -18px; } }

.plan-illust-bedmake.color-03 {
  background-position: left -72px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-bedmake.color-03 {
      background-position: left -36px; } }

.plan-illust-gomisute {
  top: 14px;
  width: 30px;
  height: 38px;
  margin-left: -15px;
  background-image: url(../img/iekeeping/icn_service_gomisute.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-gomisute {
      top: 12px;
      width: 15px;
      height: 19px;
      margin-left: -8px;
      background-size: 15px 57px; } }

.plan-illust-gomisute.color-02 {
  background-position: left -38px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-gomisute.color-02 {
      background-position: left -19px; } }

.plan-illust-gomisute.color-03 {
  background-position: left -76px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-gomisute.color-03 {
      background-position: left -38px; } }

.plan-illust-bathroom {
  top: 17px;
  width: 70px;
  height: 32px;
  margin-left: -35px;
  background-image: url(../img/iekeeping/icn_service_bathroom.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-bathroom {
      top: 15px;
      width: 35px;
      height: 16px;
      margin-left: -18px;
      background-size: 35px 48px; } }

.plan-illust-bathroom.color-02 {
  background-position: left -32px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-bathroom.color-02 {
      background-position: left -16px; } }

.plan-illust-bathroom.color-03 {
  background-position: left -64px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-bathroom.color-03 {
      background-position: left -32px; } }

.plan-illust-restroom {
  top: 18px;
  width: 42px;
  height: 38px;
  margin-left: -21px;
  background-image: url(../img/iekeeping/icn_service_restroom.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-restroom {
      top: 16px;
      width: 21px;
      height: 19px;
      margin-left: -11px;
      background-size: 21px 57px; } }

.plan-illust-restroom.color-02 {
  background-position: left -42px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-restroom.color-02 {
      background-position: left -21px; } }

.plan-illust-restroom.color-03 {
  background-position: left -84px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-restroom.color-03 {
      background-position: left -42px; } }

.plan-illust-entrance {
  top: 13px;
  width: 24px;
  height: 38px;
  margin-left: -12px;
  background-image: url(../img/iekeeping/icn_service_entrance.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-entrance {
      width: 12px;
      height: 19px;
      margin-left: -6px;
      background-size: 12px 57px; } }

.plan-illust-entrance.color-02 {
  background-position: left -38px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-entrance.color-02 {
      background-position: left -19px; } }

.plan-illust-entrance.color-03 {
  background-position: left -76px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-entrance.color-03 {
      background-position: left -38px; } }

.plan-illust-floor {
  top: 23px;
  width: 50px;
  height: 22px;
  margin-left: -25px;
  background-image: url(../img/iekeeping/icn_service_floor.png); }
  @media only screen and (max-width: 768px) {
    .plan-illust-floor {
      top: 17px;
      width: 25px;
      height: 11px;
      margin-left: -13px;
      background-size: 25px 33px; } }

.plan-illust-floor.color-02 {
  background-position: left -22px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-floor.color-02 {
      background-position: left -11px; } }

.plan-illust-floor.color-03 {
  background-position: left -44px; }
  @media only screen and (max-width: 768px) {
    .plan-illust-floor.color-03 {
      background-position: left -22px; } }

/* ----------------------------------------
 * プラン：金額
 * ------------------------------------- */
.plan-price-block {
  text-align: center; }
  @media only screen and (max-width: 768px) {
    .plan-price-block .txt-01, .plan-price-block .price-01, .plan-price-block .price-02 {
      font-size: 16px !important; } }
  @media only screen and (max-width: 768px) {
    .plan-price-block .txt-01 strong, .plan-price-block .price-01 strong, .plan-price-block .price-02 strong {
      font-size: 18px !important; } }
  @media only screen and (max-width: 768px) {
    .plan-price-block .icn-plus-01 {
      margin-top: -8px !important;
      margin-bottom: -5px !important;
      font-size: 20px !important; } }

.plan-price-block.style-01 {
  margin: 13px 8.5% 15px 8.5%;
  padding: 13px 0 12px 0;
  border-radius: 5px;
  background-color: #fff; }
  @media only screen and (max-width: 768px) {
    .plan-price-block.style-01 {
      margin: 7px 6% 7px 6%;
      padding-top: 7px;
      padding-bottom: 7px; } }
  .plan-price-block.style-01 .price-01 {
    font-size: 20px; }
    .plan-price-block.style-01 .price-01 strong {
      font-size: 36px; }
  .plan-price-block.style-01 .icn-plus-01 {
    margin: -17px 0 -7px 0;
    font-size: 30px; }

.plan-price-block.style-02 {
  padding: 8px 0 15px 0; }
  @media only screen and (max-width: 768px) {
    .plan-price-block.style-02 {
      padding-bottom: 9px; } }
  .plan-price-block.style-02 .price-01 {
    font-size: 25px; }
    .plan-price-block.style-02 .price-01 strong {
      font-size: 40px; }
  .plan-price-block.style-02 .price:first-child {
    font-weight: bold; }
  .plan-price-block.style-02 .icn-plus-01 {
    margin: -24px 0 -10px 0;
    font-size: 40px; }

.plan-price-block.style-03 {
  padding: 8px 0 15px 0; }
  @media only screen and (max-width: 768px) {
    .plan-price-block.style-03 {
      padding-bottom: 9px; } }
  .plan-price-block.style-03 .txt-01 {
    font-size: 20px; }
  .plan-price-block.style-03 .price-01 {
    font-size: 20px; }
    .plan-price-block.style-03 .price-01 strong {
      font-size: 30px; }
  .plan-price-block.style-03 .icn-plus-01 {
    margin: -17px 0 -11px 0;
    font-size: 40px; }
  .plan-price-block.style-03 .price-02 {
    font-size: 25px; }

.plan-price-block.color-01 {
  color: #f6ab00; }

.plan-price-block.color-02 {
  color: #f68b00; }

.plan-price-block.color-03 {
  background-color: #f6ab00;
  color: #fff; }

.plan-price-block.color-04 {
  background-color: #f68b00;
  color: #fff; }

/* ----------------------------------------
 * プラン：間取り
 * ------------------------------------- */
.keep-plan-layout-01-all {
  margin: 0 10% 50px 10%; }
  @media only screen and (max-width: 768px) {
    .keep-plan-layout-01-all {
      margin: 0 6% 29px 6%; } }

.keep-plan-layout-01 .btn-standard-04 {
  width: 422px;
  margin: 0 auto; }
  @media only screen and (max-width: 768px) {
    .keep-plan-layout-01 .btn-standard-04 {
      width: 100%; } }

@media only screen and (max-width: 768px) {
  .keep-plan-layout-01 .plan-illust-block {
    margin-bottom: 0; } }

.keep-plan-layout-01-head {
  margin: 0 0 46px 0; }
  @media only screen and (max-width: 768px) {
    .keep-plan-layout-01-head {
      margin-bottom: 10px; } }
  .keep-plan-layout-01-head dl dt, .keep-plan-layout-01-head dl dd {
    text-align: center;
    font-size: 20px; }
    @media only screen and (max-width: 768px) {
      .keep-plan-layout-01-head dl dt, .keep-plan-layout-01-head dl dd {
        font-size: 16px; } }
  .keep-plan-layout-01-head dl dt {
    margin: 0 0 8px 0; }
    @media only screen and (max-width: 768px) {
      .keep-plan-layout-01-head dl dt {
        margin-bottom: 5px; } }
  .keep-plan-layout-01-head dl .color-01 {
    color: #f6ab00; }
  .keep-plan-layout-01-head dl .color-02 {
    color: #f68b00; }
  .keep-plan-layout-01-head dl dd {
    color: #666; }
  .keep-plan-layout-01-head p {
    margin-top: 3px;
    text-align: center;
    color: #666; }

.keep-plan-layout-01-body {
  display: -webkit-box;
  display: flex;
  margin: 0 0 50px 0; }
  @media only screen and (max-width: 768px) {
    .keep-plan-layout-01-body {
      flex-wrap: wrap;
      margin-bottom: 29px; } }

.keep-plan-layout-01-image {
  display: -webkit-box;
  display: flex;
  -webkit-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  align-items: center;
  flex-basis: 48%;
  margin-right: 2.6%;
  padding: 20px 2% 20px 2%;
  border: 1px solid #ccc;
  box-sizing: border-box; }
  @media only screen and (max-width: 768px) {
    .keep-plan-layout-01-image {
      flex-basis: 90%;
      margin: 0 auto;
      border: none; } }
  .keep-plan-layout-01-image figure img {
    max-width: 100%;
    width: 100%;
    height: auto; }

.keep-plan-layout-01-info {
  flex-basis: 49.6%; }
  @media only screen and (max-width: 768px) {
    .keep-plan-layout-01-info {
      flex-basis: 100%; } }

.plan-explain-block {
  margin-top: 17px;
  line-height: 1.8;
  font-size: 18px; }
  @media only screen and (max-width: 768px) {
    .plan-explain-block {
      margin-top: 13px;
      line-height: 1.5;
      font-size: 14px; } }

/* ----------------------------------------
 * プラン：掃除内容（スライド）
 * ------------------------------------- */
.keep-slide-layout-01-all {
  position: relative;
  padding: 50px 15% 128px 15%;
  background-color: #f7f5f1; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-all {
      padding: 29px 10% 68px 10%; } }

.keep-slide-layout-01-head {
  margin: 0 0 30px 0;
  text-align: center; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-head {
      margin-bottom: 15px; } }
  .keep-slide-layout-01-head p {
    display: inline-block;
    padding: 6px 30px 6px 30px;
    border-radius: 50px;
    letter-spacing: 0.1em;
    background-color: #fff;
    color: #666;
    font-size: 18px; }
    @media only screen and (max-width: 768px) {
      .keep-slide-layout-01-head p {
        padding: 4px 15px 4px 15px;
        font-size: 16px; } }

.keep-slide-layout-01-list {
  display: -webkit-box;
  display: flex; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-list {
      flex-wrap: wrap; } }

.keep-slide-layout-01-image, .keep-slide-layout-01-info {
  flex-basis: 47.6%; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-image, .keep-slide-layout-01-info {
      flex-basis: 100%; } }

.keep-slide-layout-01-image {
  margin-right: 4.8%; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-image {
      margin-right: 0;
      margin-bottom: 7px; } }
  .keep-slide-layout-01-image figure img {
    max-width: 100%;
    width: 100%;
    height: auto; }

.keep-slide-layout-01-info dl {
  margin-top: 3%; }
  .keep-slide-layout-01-info dl dt, .keep-slide-layout-01-info dl dd {
    color: #666; }
  .keep-slide-layout-01-info dl dt {
    margin: 0 0 16px 0;
    padding: 0 0 10px 0;
    border-bottom: 1px dashed #999;
    font-size: 30px; }
    @media only screen and (max-width: 768px) {
      .keep-slide-layout-01-info dl dt {
        margin-bottom: 13px;
        padding-bottom: 5px;
        font-size: 16px; } }

.keep-slide-layout-01-info ul li {
  margin-left: 1em;
  text-indent: -1em;
  font-size: 18px; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-info ul li {
      font-size: 14px; } }

.keep-slide-layout-01-info ul li ~ li {
  margin-top: 13px; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-info ul li ~ li {
      margin-top: 7px; } }

.keep-slide-layout-01-prev, .keep-slide-layout-01-next {
  position: absolute;
  top: 50%;
  margin-top: -31px; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-prev, .keep-slide-layout-01-next {
      margin-top: -15px; } }
  .keep-slide-layout-01-prev a, .keep-slide-layout-01-next a {
    display: block;
    width: 32px;
    height: 62px;
    background-position: left top;
    background-repeat: no-repeat;
    overflow: hidden;
    text-indent: 300%;
    white-space: nowrap; }
    @media only screen and (max-width: 768px) {
      .keep-slide-layout-01-prev a, .keep-slide-layout-01-next a {
        width: 16px;
        height: 31px;
        background-size: 16px 31px; } }

.keep-slide-layout-01-prev {
  left: 6.7%; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-prev {
      left: 3%; } }
  .keep-slide-layout-01-prev a {
    background-image: url(../img/common/btn_slide_prev_01.png); }

.keep-slide-layout-01-next {
  right: 6.7%; }
  @media only screen and (max-width: 768px) {
    .keep-slide-layout-01-next {
      right: 3%; } }
  .keep-slide-layout-01-next a {
    background-image: url(../img/common/btn_slide_next_01.png); }

/* ----------------------------------------
 * ご利用開始までの流れ
 * ------------------------------------- */
.keep-top-flow {
  margin-top: 88px; }
  @media only screen and (max-width: 768px) {
    .keep-top-flow {
      margin-top: 29px; } }
  .keep-top-flow .txt-block-02 {
    margin-bottom: 24px; }
    @media only screen and (max-width: 768px) {
      .keep-top-flow .txt-block-02 {
        margin-bottom: 16px; } }
  .keep-top-flow .btn-standard-03 {
    margin-top: 50px; }
    @media only screen and (max-width: 768px) {
      .keep-top-flow .btn-standard-03 {
        margin-top: 29px;
        padding-left: 6%;
        padding-right: 6%; } }

.keep-step-flow .btn-standard-07 {
  margin-top: 30px; }
  @media only screen and (max-width: 768px) {
    .keep-step-flow .btn-standard-07 {
      margin-top: 15px; } }

@media only screen and (max-width: 768px) {
  .keep-step-flow .btn-standard-03, .keep-step-flow .btn-standard-07 {
    padding-left: 6%;
    padding-right: 6%; } }

/* ----------------------------------------
 * サービス説明（アコーディオン）
 * ------------------------------------- */
.keep-information-01 {
  margin-top: 94px; }
  @media only screen and (max-width: 768px) {
    .keep-information-01 {
      margin-top: 29px; } }

/* ----------------------------------------
 * プラン：サービス
 * ------------------------------------- */
.keep-plan-service {
  margin-bottom: 100px; }
  @media only screen and (max-width: 768px) {
    .keep-plan-service {
      margin-bottom: 29px; } }
  .keep-plan-service .column-02-block-01-all {
    background-image: url(../img/iekeeping/top_img_bg_layer_01.jpg); }
  .keep-plan-service .column-02-block-01-body > div:nth-of-type(1) .head:after {
    background-image: url(../img/iekeeping/icn_star_01.png); }
  .keep-plan-service .column-02-block-01-body > div:nth-of-type(2) .head:after {
    background-image: url(../img/iekeeping/icn_star_02.png); }
  .keep-plan-service .column-02-block-01-list .head:after {
    content: "";
    position: absolute;
    display: block;
    background-position: left top;
    background-repeat: no-repeat;
    top: -12px;
    left: 50%;
    width: 28px;
    height: 32px;
    margin-left: -14px;
    background-position: left top;
    background-repeat: no-repeat; }
    @media only screen and (max-width: 768px) {
      .keep-plan-service .column-02-block-01-list .head:after {
        top: -5px;
        width: 14px;
        height: 16px;
        margin-left: -7px;
        background-size: 14px 16px; } }
  .keep-plan-service .column-02-block-01-list .info {
    padding-top: 0;
    padding-bottom: 13px; }
    .keep-plan-service .column-02-block-01-list .info .plan-price-block {
      margin-bottom: 0; }
  .keep-plan-service .btn-standard-03 {
    margin-top: 60px;
    margin-bottom: 60px; }
    @media only screen and (max-width: 768px) {
      .keep-plan-service .btn-standard-03 {
        margin-top: 15px;
        margin-bottom: 29px;
        padding-left: 6%;
        padding-right: 6%; } }

/* ----------------------------------------
 * トップ：ぜひ比べてください
 * ------------------------------------- */
.keep-top-compare {
  background-image: url(../img/iekeeping/top_img_bg_layer_02.jpg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover; }
  @media only screen and (max-width: 768px) {
    .keep-top-compare .txt-block-01, .keep-top-compare .txt-block-02, .keep-top-compare .txt-block-03, .keep-top-compare .txt-block-04 {
      padding-left: 0;
      padding-right: 0; } }
  @media only screen and (max-width: 768px) {
    .keep-top-compare .table-block-01 tbody tr td:nth-of-type(1):before {
      content: "当社ライトプラン"; }
    .keep-top-compare .table-block-01 tbody tr td:nth-of-type(2):before {
      content: "当社ベーシックプラン"; }
    .keep-top-compare .table-block-01 tbody tr td:nth-of-type(3):before {
      content: "A社"; }
    .keep-top-compare .table-block-01 tbody tr td:nth-of-type(4):before {
      content: "B社"; } }

.keep-top-compare-inner {
  padding: 50px 6.1% 50px 6.1%; }
  @media only screen and (max-width: 768px) {
    .keep-top-compare-inner {
      padding: 29px 6% 29px 6%; } }

/* ----------------------------------------
 * トップ：体験プラン
 * ------------------------------------- */
.keep-top-plan-02 {
  margin-bottom: 110px; }
  @media only screen and (max-width: 768px) {
    .keep-top-plan-02 {
      margin-bottom: 29px; } }
  @media only screen and (max-width: 768px) {
    .keep-top-plan-02 .btn-standard-06 {
      padding-left: 6%;
      padding-right: 6%; } }

/* ----------------------------------------
 * 体験プラン：イントロ
 * ------------------------------------- */
.keep-experience-plan-layout-01-all {
  margin: 0 14.2% 100px 14.2%; }
  @media only screen and (max-width: 768px) {
    .keep-experience-plan-layout-01-all {
      margin: 0 6% 29px 6%; } }

.keep-experience-plan-layout-01 h2 {
  margin: 0 0 32px 0;
  text-align: center;
  color: #f68b00;
  font-size: 36px;
  font-weight: normal; }
  @media only screen and (max-width: 768px) {
    .keep-experience-plan-layout-01 h2 {
      margin-bottom: 15px;
      font-size: 16px; } }

.keep-experience-plan-layout-01-body {
  display: -webkit-box;
  display: flex;
  margin: 0 0 63px 0; }
  @media only screen and (max-width: 768px) {
    .keep-experience-plan-layout-01-body {
      flex-wrap: wrap;
      margin-bottom: 15px; } }

.keep-experience-plan-layout-01-list {
  flex-basis: 46.5%; }
  @media only screen and (max-width: 768px) {
    .keep-experience-plan-layout-01-list {
      flex-basis: 100%; } }
  .keep-experience-plan-layout-01-list figure img {
    border-radius: 5px 5px 0 0;
    max-width: 100%;
    width: 100%;
    height: auto; }
  .keep-experience-plan-layout-01-list p {
    padding: 9px 0 9px 0;
    border-radius: 0 0 5px 5px;
    text-align: center;
    background-color: #f6ab00;
    color: #fff;
    font-size: 18px; }
    @media only screen and (max-width: 768px) {
      .keep-experience-plan-layout-01-list p {
        font-size: 14px; } }

.keep-experience-plan-layout-01-list:first-child {
  margin-right: 7%; }
  @media only screen and (max-width: 768px) {
    .keep-experience-plan-layout-01-list:first-child {
      margin-right: 0;
      margin-bottom: 15px; } }

.keep-experience-plan-layout-01-txt {
  position: relative;
  text-align: center;
  font-size: 20px; }
  @media only screen and (max-width: 768px) {
    .keep-experience-plan-layout-01-txt {
      padding-bottom: 7px;
      text-align: left;
      background-image: url(../img/iekeeping/low_experience_img_03.png);
      background-position: left bottom;
      background-repeat: repeat-x;
      background-size: 9px 4px;
      font-size: 14px; } }
  .keep-experience-plan-layout-01-txt span {
    color: #f6ab00;
    font-size: 30px; }
    @media only screen and (max-width: 768px) {
      .keep-experience-plan-layout-01-txt span {
        font-size: 16px; } }

.keep-experience-plan-layout-01-txt:before {
  content: "";
  position: absolute;
  display: block;
  background-position: left top;
  background-repeat: no-repeat;
  bottom: -11px;
  left: 50%;
  width: 720px;
  height: 8px;
  margin-left: -366px;
  background-image: url(../img/iekeeping/low_experience_img_03.png);
  background-position: left top;
  background-repeat: repeat-x; }
  @media only screen and (max-width: 768px) {
    .keep-experience-plan-layout-01-txt:before {
      display: none; } }

/* ----------------------------------------
 * 体験プラン：体験プランご提供にあたっての注意事項
 * ------------------------------------- */
.keep-experience-note {
  margin-bottom: 100px; }
  @media only screen and (max-width: 768px) {
    .keep-experience-note {
      margin-bottom: 29px; } }


/* ----------------------------------------
* 2019.03追加
* ------------------------------------- */
.Flex{
    display: -webkit-box;
    display: flex;
    flex-wrap: wrap;
    width: 100%;
}

.clearfix:after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: " ";
    clear: both;
    height: 0;
}
* html .clearfix{ zoom: 1; } /* IE6 */
*:first-child+html .clearfix { zoom: 1; } /* IE7 */
.clear{
    clear:both;
}
.sp{
    display: none;
}
.tac{
    text-align: center;
}
@media only screen and (max-width: 768px){
    .sp{
        display: block;
    }
    .pc{
        display: none;
    }
    .footer_btn{
        font-size: 3.2vw;
        background: #f6ab00;
        height: calc(177em / 24);
        padding: calc(20em / 24) calc(10em / 24) 0 calc(10em / 24);
        position: fixed;
        bottom:0;
        left: 0;
        width: 100%;
        z-index: 999;
        box-sizing: border-box;
    }
    .footer_btn p{
        color: #ffffff;
        font-weight: bold;
        margin-bottom:.5em;
    }
    .footer_btn .Flex{
        -webkit-box-pack: justify;
        justify-content: space-between;
        -webkit-box-align: center;
        align-items: center;
    }
    .footer_btn li{
        width:49%;
    }
    .footer_btn li img{
        width: 100%;
    }
    .footer2{
        padding-bottom: 23.6vw;
    } 
    
}