@charset "utf-8";
/* ==========================================================================
   Foundation
   ========================================================================== */
/* Document
 * ========================================================================== */
/**
 * Add border box sizing in all browsers (opinionated).
 */
*,
::before,
::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
/**
 * 1. Add text decoration inheritance in all browsers (opinionated).
 * 2. Add vertical alignment inheritance in all browsers (opinionated).
 */
::before,
::after {
  text-decoration: inherit; /* 1 */
  vertical-align: inherit; /* 2 */
}
/**
 * 1. Use the default cursor in all browsers (opinionated).
 * 2. Change the line height in all browsers (opinionated).
 * 3. Use a 4-space tab width in all browsers (opinionated).
 * 4. Remove the grey highlight on links in iOS (opinionated).
 * 5. Prevent adjustments of font size after orientation changes in
 *    IE on Windows Phone and in iOS.
 * 6. Breaks words to prevent overflow in all browsers (opinionated).
 */
html {
  cursor: default; /* 1 */
  line-height: 1.5; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
  tab-size: 4; /* 3 */
  -webkit-tap-highlight-color: transparent /* 4 */;
  -ms-text-size-adjust: 100%; /* 5 */
  -webkit-text-size-adjust: 100%; /* 5 */
  word-break: break-word; /* 6 */
}
/* Sections
 * ========================================================================== */
/**
 * Remove the margin in all browsers (opinionated).
 */
body {
  margin: 0;
}
/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Edge, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/* Grouping content
 * ========================================================================== */
/**
 * Remove the margin on nested lists in Chrome, Edge, IE, and Safari.
 */
dl dl,
dl ol,
dl ul,
ol dl,
ul dl {
  margin: 0;
}
/**
 * Remove the margin on nested lists in Edge 18- and IE.
 */
ol ol,
ol ul,
ul ol,
ul ul {
  margin: 0;
}
/**
 * 1. Add the correct sizing in Firefox.
 * 2. Show the overflow in Edge 18- and IE.
 */
hr {
  height: 0; /* 1 */
  overflow: visible; /* 2 */
}
/**
 * Add the correct display in IE.
 */
main {
  display: block;
}
/**
 * Remove the list style on navigation lists in all browsers (opinionated).
 */
nav ol,
nav ul {
  list-style: none;
  padding: 0;
}
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}
/* Text-level semantics
 * ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent;
}
/**
 * Add the correct text decoration in Edge 18-, IE, and Safari.
 */
abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
}
/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder;
}
/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace; /* 1 */
  font-size: 1em; /* 2 */
}
/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%;
}
/* Embedded content
 * ========================================================================== */
/*
 * Change the alignment on media elements in all browsers (opinionated).
 */
audio,
canvas,
iframe,
img,
svg,
video {
  vertical-align: middle;
}
/**
 * Add the correct display in IE 9-.
 */
audio,
video {
  display: inline-block;
}
/**
 * Add the correct display in iOS 4-7.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
 * Remove the border on iframes in all browsers (opinionated).
 */
iframe {
  border-style: none;
}
/**
 * Remove the border on images within links in IE 10-.
 */
img {
  border-style: none;
}
/**
 * Change the fill color to match the text color in all browsers (opinionated).
 */
svg:not([fill]) {
  fill: currentColor;
}
/**
 * Hide the overflow in IE.
 */
svg:not(:root) {
  overflow: hidden;
}
/* Tabular data
 * ========================================================================== */
/**
 * Collapse border spacing in all browsers (opinionated).
 */
table {
  border-collapse: collapse;
}
/* Forms
 * ========================================================================== */
/**
 * Remove the margin on controls in Safari.
 */
button,
input,
select {
  margin: 0;
}
/**
 * 1. Show the overflow in IE.
 * 2. Remove the inheritance of text transform in Edge 18-, Firefox, and IE.
 */
button {
  overflow: visible; /* 1 */
  text-transform: none; /* 2 */
}
/**
 * Correct the inability to style buttons in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}
/**
 * 1. Change the inconsistent appearance in all browsers (opinionated).
 * 2. Correct the padding in Firefox.
 */
fieldset {
  border: 1px solid #a0a0a0; /* 1 */
  padding: 0.35em 0.75em 0.625em; /* 2 */
}
/**
 * Show the overflow in Edge 18- and IE.
 */
input {
  overflow: visible;
}
/**
 * 1. Correct the text wrapping in Edge 18- and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 */
legend {
  color: inherit; /* 2 */
  display: table; /* 1 */
  max-width: 100%; /* 1 */
  white-space: normal; /* 1 */
}
/**
 * 1. Add the correct display in Edge 18- and IE.
 * 2. Add the correct vertical alignment in Chrome, Edge, and Firefox.
 */
progress {
  display: inline-block; /* 1 */
  vertical-align: baseline; /* 2 */
}
/**
 * Remove the inheritance of text transform in Firefox.
 */
select {
  text-transform: none;
}
/**
 * 1. Remove the margin in Firefox and Safari.
 * 2. Remove the default vertical scrollbar in IE.
 * 3. Change the resize direction in all browsers (opinionated).
 */
textarea {
  margin: 0; /* 1 */
  overflow: auto; /* 2 */
  resize: vertical; /* 3 */
}
/**
 * Remove the padding in IE 10-.
 */
[type="checkbox"],
[type="radio"] {
  padding: 0;
}
/**
 * 1. Correct the odd appearance in Chrome, Edge, and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/**
 * Correct the cursor style of increment and decrement buttons in Safari.
 */
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}
/**
 * Correct the text style of placeholders in Chrome, Edge, and Safari.
 */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}
/**
 * Remove the inner padding in Chrome, Edge, and Safari on macOS.
 */
::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
 * 1. Correct the inability to style upload buttons in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/**
 * Remove the inner border and padding of focus outlines in Firefox.
 */
::-moz-focus-inner {
  border-style: none;
  padding: 0;
}
/**
 * Restore the focus outline styles unset by the previous rule in Firefox.
 */
:-moz-focusring {
  outline: 1px dotted ButtonText;
}
/**
 * Remove the additional :invalid styles in Firefox.
 */
:-moz-ui-invalid {
  box-shadow: none;
}
/* Interactive
 * ========================================================================== */
/*
 * Add the correct display in Edge 18- and IE.
 */
details {
  display: block;
}
/*
 * Add the correct styles in Edge 18-, IE, and Safari.
 */
dialog {
  background-color: white;
  border: solid;
  color: black;
  display: block;
  height: -moz-fit-content;
  height: -webkit-fit-content;
  height: fit-content;
  left: 0;
  margin: auto;
  padding: 1em;
  position: absolute;
  right: 0;
  width: -moz-fit-content;
  width: -webkit-fit-content;
  width: fit-content;
}
dialog:not([open]) {
  display: none;
}
/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}
/* Scripting
 * ========================================================================== */
/**
 * Add the correct display in IE 9-.
 */
canvas {
  display: inline-block;
}
/**
 * Add the correct display in IE.
 */
template {
  display: none;
}
/* User interaction
 * ========================================================================== */
/*
 * 1. Remove the tapping delay in IE 10.
 * 2. Remove the tapping delay on clickable elements
      in all browsers (opinionated).
 */
a,
area,
button,
input,
label,
select,
summary,
textarea,
[tabindex] {
  -ms-touch-action: manipulation; /* 1 */
  touch-action: manipulation; /* 2 */
}
/**
 * Add the correct display in IE 10-.
 */
[hidden] {
  display: none;
}
/* Accessibility
 * ========================================================================== */
/**
 * Change the cursor on busy elements in all browsers (opinionated).
 */
[aria-busy="true"] {
  cursor: progress;
}
/*
 * Change the cursor on control elements in all browsers (opinionated).
 */
[aria-controls] {
  cursor: pointer;
}
/*
 * Change the cursor on disabled, not-editable, or otherwise
 * inoperable elements in all browsers (opinionated).
 */
[aria-disabled="true"],
[disabled] {
  cursor: not-allowed;
}
/*
 * Change the display on visually hidden accessible elements
 * in all browsers (opinionated).
 */
[aria-hidden="false"][hidden] {
  display: inline;
  display: initial;
}
[aria-hidden="false"][hidden]:not(:focus) {
  clip: rect(0, 0, 0, 0);
  position: absolute;
}
@font-face {
	font-family: "Bold";
	src: url("font/GoPro-Bold.woff2") format('woff2'),
	url("font/GoPro-Bold.woff") format('woff');
}
.ffgb{
font-family: "Bold";
}
.ffm{
font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.ffg{
font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
html {
	overflow-x: hidden;
	width: 100%;
	font-size: 62.5%;
}
body {
	overflow-x: hidden;
	width: 100%;
	color: #333;
	background-color: #f1ece6;
	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 10pt;
	font-style: normal;
	font-weight: 400;
	line-height: 1.714;
	letter-spacing: 0.05em;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
@media (min-width: 801px) {
	body {
		font-size: 11.5pt;
	}
}
h1, h2, h3, h4, h5 {
	margin: 0;
}
p {
	margin-top: 0;
	margin-bottom: 1em;
}
ul, ol {
	margin: 0 0 1em 1em;
	padding: 0;
}
ul {
	list-style: disc inside;
}
ol {
	list-style: decimal inside;
}
a {
	color: #333;
	text-decoration: none;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
a:hover {
	text-decoration: underline;
}
em {
	font-style: normal;
}
iframe {
	display: block;
	width: 100%;
}
img, iframe, button, input, select, textarea {
	max-width: 100%;
}
img {
	height: auto;
}
/* ==========================================================================
   Layout
   ========================================================================== */
/*------------------------------------*\
    Header
\*------------------------------------*/
.header {
	width: 90%;
	max-width: 1200px;
	height: 120px;
	margin: 0 auto;
}
.header__logo {
	position: absolute;
	top: 35px;
	width: 200px;
	margin: 0;
}
.navi-btn {
	position: fixed;
	top: 10px;
	right: 10px;
	z-index: 101;
	width: 40px;
	height: 40px;
	border-radius: 0;
	border: none;
	background: #333 url(../image/menu_open_w.svg) no-repeat center 50%;
	background-size: cover;
	-webkit-transition: all 0.2s;
	transition: all 0.2s;
}
.navi a {
		display: inline-block;
		padding: 10px 0;
		border-bottom: 1px #333333 solid;
		font-family: "Bold";
		font-size: 9pt;
		line-height: 1;
		letter-spacing: .2em;
		text-decoration: none;
	}
.navi .mail a {
		padding: 0;
		border: 0;
	}
@media (max-width: 800px) {
	.navi {
		display: none;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 100;
		width: 100%;
		height: 100%;
		background-color: #f1ece6;
		text-align: center
	}
		.navi ul {
			margin: 0;
			padding: 15vh 0 0 0;
		}
		.navi li {
			padding: 1vh 0;
		}
}
@media (min-width: 801px) {
	.header {
		position: relative;
		height: 240px;
	}
	.header__logo {
		top: 75px;
		width: 250px;
	}
	.navi-btn {
		display: none;
	}
	.navi {
		position: relative;
		top: 100px;
		right: 0;
		text-align: right
	}
		.navi li {
			display: inline-block;
			padding: 0 20px;
			vertical-align: bottom;
		}
		.navi li.sp {
			display: none;
		}
		.navi a {
			font-size: 7.5pt;
		}
		.navi a:hover {
			opacity: 0.6;
		}
}
.navi-open,
.navi-open body {
	overflow: hidden;
}
.navi-open .navi-btn {
	background-image: url(../image/menu_close_w.svg);
}
/*------------------------------------*\
    Footer
\*------------------------------------*/
.footer {
  padding: 60px 0 50px 0;
  background: #fff;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  text-align: center;
}
.footer__navi1 ul, .footer__navi2 ul, .footer__navi3 ul {
    margin: 0;
    padding: 0;
  }
.footer__navi1 h2 {
    width: 224px;
    margin: 0 auto;
  }
.footer__navi1 ul {
    padding: 30px 0;
  }
.footer__navi1 a {
    display: block;
    padding: 14px 0;
    border-bottom: 1px #333 solid;
    font-family: "Bold";
    font-size: 10pt;
    letter-spacing: 0.2em;
    text-decoration: none;
  }
.footer__navi1 a:hover {
		opacity: 0.6;
	}
.footer__address {
  margin-top: 10px;
  font-style: normal;
  letter-spacing: 0
}
.footer__address .logo {
    margin-bottom: 5px;
    font-size: 10pt;
  }
.footer__address .logo small {
  display: inline-block;
  margin-bottom: 10px;
  font-size: 10px;
}
.footer__address .logo img {
    width: 150px;
    margin-bottom: 10px;
  }
.footer__navi2 {
  margin-top: 30px
}
.footer__navi2 li {
    margin-bottom: 15px;
  }
.footer__navi2 a {
    display: block;
    text-align: center;
    padding: 10px 0;
    border: 1px #ddd solid;
    font-family: "Bold";
    font-size: 8pt;
    letter-spacing: .2em;
    line-height: 2.25;
    text-decoration: none;
  }
.footer__navi2 a:hover {
    background: #333;
    color: #fff;
  }
.footer__navi3 {
  margin: 0;
  padding-top: 20px
}
.footer__navi3 li {
    display: inline-block;
  }
.footer__navi3 a {
    padding: 0 10px;
    font-size: 9pt;
    letter-spacing: 0;
  }
.footer__navi3 li:nth-of-type(n+2) a {
    border-left: 1px #333333 solid;
  }
.copyright {
  padding-top: 40px;
  font-size: 10pt;
  text-align: center;
  letter-spacing: 0;
}
@media (min-width: 801px) {
  .footer {
    padding: 100px 0 60px;
    text-align: left;
  }
  .footer .container {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .footer__left {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 66.6666%;
    flex: 1 0 66.6666%;
    width: 66.6666%;
  }
  .footer__right {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 33.3333%;
    flex: 1 0 33.3333%;
    max-width: 400px;
  }
    .footer__navi1::after {
      content: "";
      display: block;
      width: 9px;
      margin-bottom: 30px;
      border-bottom: 1px solid #333;
    }
    .footer__navi1 h2 {
      margin: 0;
    }
    .footer__navi1 ul {
      padding: 30px 0;
    }
    .footer__navi1 li {
      display: inline-block;
      padding: 0 30px 0 0;
    }
    .footer__navi1 a {
      padding: 0;
      border-bottom: none;
      font-size: 7.5pt;
    }
  .footer__navi2 {
    margin-top: 0;
  }
  .footer__navi3 {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
    -webkit-box-flex: 1;
    -ms-flex: 1 0 60%;
    flex: 1 0 60%;
    max-width: 60%;
    padding-top: 50px;
    text-align: right
  }
    .footer__navi3 a {
      padding: 0 30px;
      font-size: 9pt;
    }
    .footer__navi3 li:last-child a {
      padding-right: 0;
    }
  .copyright {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 40%;
    flex: 1 0 40%;
    max-width: 40%;
    padding-top: 50px;
    text-align: left;
  }
}
.pagetop {
  position: fixed;
  right: 0;
  bottom: -100px;
  z-index: 1000
}
.pagetop a {
    display: block;
    width: 50px;
    height: 50px;
    background: #333 url(../image/point_top.svg) no-repeat center 50% / cover;
  }
/*------------------------------------*\
    Main
\*------------------------------------*/
/* サイドメニュー */
.menu {
  display: none;
}
@media (min-width: 801px) {
  .menu {
    display: block;
    position: fixed;
    top: 50%;
    left: 25px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: 100;
    -webkit-transition: 0.5s;
    transition: 0.5s
  }
    .menu.off {
      opacity: 0;
    }
    .menu ul {
      list-style: none;
      margin: 0;
      padding: 0;
      -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
    }
    .menu li {
      position: relative;
      display: inline-block;
      padding: 16px 0;
      font-size: 7.5pt;
      line-height: 2.76;
    }
    .menu a {
      display: block;
      padding-right: 5px;
      font-family: "Bold";
      letter-spacing: .2em;
      text-decoration: none;
      -webkit-transition: .5s;
      transition: .5s;
    }
    .menu .dot {
      display: block;
      position: absolute;
      right: 0;
      top: 50%;
      opacity: 0;
      width: 5px;
      height: 5px;
      margin-top: -3px;
      border-radius: 50%;
      background-color: #333;
      -webkit-transition: .5s;
      transition: .5s;
    }
    .menu a:hover .dot {
      opacity: 1;
    }
    .menu .cr a {
      color: #009;
    }
    .menu .cr .dot {
      opacity: 1;
      background-color: #009;
    }
}
/* ==========================================================================
   Object
   ========================================================================== */
/* Component
   ----------------------------------------------------------------- */
/* -----------------------------------
  Flexbox Grid
  https://github.com/kristoferjoseph/flexboxgrid
 ----------------------------------- */
.container-fluid,
.container {
  margin-right: auto;
  margin-left: auto;
}
.container-fluid {
  padding-right: 2rem;
  padding-left: 2rem;
}
.row {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 0;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -0.5rem;
  margin-left: -0.5rem;
}
.row.reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.col.reverse {
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
}
.col-xs,
.col-xs-1,
.col-xs-2,
.col-xs-3,
.col-xs-4,
.col-xs-5,
.col-xs-6,
.col-xs-7,
.col-xs-8,
.col-xs-9,
.col-xs-10,
.col-xs-11,
.col-xs-12 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  padding-right: 0.5rem;
  padding-left: 0.5rem;
}
.col-xs {
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1;
  -ms-flex-preferred-size: 0;
  flex-basis: 0;
  max-width: 100%;
}
.col-xs-1 {
  -ms-flex-preferred-size: 8.33333333%;
  flex-basis: 8.33333333%;
  max-width: 8.33333333%;
}
.col-xs-2 {
  -ms-flex-preferred-size: 16.66666667%;
  flex-basis: 16.66666667%;
  max-width: 16.66666667%;
}
.col-xs-3 {
  -ms-flex-preferred-size: 25%;
  flex-basis: 25%;
  max-width: 25%;
}
.col-xs-4 {
  -ms-flex-preferred-size: 33.33333333%;
  flex-basis: 33.33333333%;
  max-width: 33.33333333%;
}
.col-xs-5 {
  -ms-flex-preferred-size: 41.66666667%;
  flex-basis: 41.66666667%;
  max-width: 41.66666667%;
}
.col-xs-6 {
  -ms-flex-preferred-size: 50%;
  flex-basis: 50%;
  max-width: 50%;
}
.col-xs-7 {
  -ms-flex-preferred-size: 58.33333333%;
  flex-basis: 58.33333333%;
  max-width: 58.33333333%;
}
.col-xs-8 {
  -ms-flex-preferred-size: 66.66666667%;
  flex-basis: 66.66666667%;
  max-width: 66.66666667%;
}
.col-xs-9 {
  -ms-flex-preferred-size: 75%;
  flex-basis: 75%;
  max-width: 75%;
}
.col-xs-10 {
  -ms-flex-preferred-size: 83.33333333%;
  flex-basis: 83.33333333%;
  max-width: 83.33333333%;
}
.col-xs-11 {
  -ms-flex-preferred-size: 91.66666667%;
  flex-basis: 91.66666667%;
  max-width: 91.66666667%;
}
.col-xs-12 {
  -ms-flex-preferred-size: 100%;
  flex-basis: 100%;
  max-width: 100%;
}
.start-xs {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
.center-xs {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.end-xs {
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
}
.top-xs {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.middle-xs {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.bottom-xs {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}
.around-xs {
  -ms-flex-pack: distribute;
  justify-content: space-around;
}
.between-xs {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
@media (min-width: 35.001em) {
  .col-sm,
  .col-sm-1,
  .col-sm-2,
  .col-sm-3,
  .col-sm-4,
  .col-sm-5,
  .col-sm-6,
  .col-sm-7,
  .col-sm-8,
  .col-sm-9,
  .col-sm-10,
  .col-sm-11,
  .col-sm-12 {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }

  .col-sm {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
  }

  .col-sm-1 {
    -ms-flex-preferred-size: 8.33333333%;
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }

  .col-sm-2 {
    -ms-flex-preferred-size: 16.66666667%;
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }

  .col-sm-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
  }

  .col-sm-4 {
    -ms-flex-preferred-size: 33.33333333%;
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }

  .col-sm-5 {
    -ms-flex-preferred-size: 41.66666667%;
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }

  .col-sm-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }

  .col-sm-7 {
    -ms-flex-preferred-size: 58.33333333%;
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }

  .col-sm-8 {
    -ms-flex-preferred-size: 66.66666667%;
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }

  .col-sm-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
  }

  .col-sm-10 {
    -ms-flex-preferred-size: 83.33333333%;
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }

  .col-sm-11 {
    -ms-flex-preferred-size: 91.66666667%;
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }

  .col-sm-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }

  .start-sm {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .center-sm {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .end-sm {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }

  .top-sm {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }

  .middle-sm {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .bottom-sm {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }

  .around-sm {
    -ms-flex-pack: distribute;
    justify-content: space-around;
  }

  .between-sm {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}
@media (min-width: 45.001em) {
  .col-md,
  .col-md-1,
  .col-md-2,
  .col-md-3,
  .col-md-4,
  .col-md-5,
  .col-md-6,
  .col-md-7,
  .col-md-8,
  .col-md-9,
  .col-md-10,
  .col-md-11,
  .col-md-12 {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }

  .col-md {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
  }

  .col-md-1 {
    -ms-flex-preferred-size: 8.33333333%;
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }

  .col-md-2 {
    -ms-flex-preferred-size: 16.66666667%;
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }

  .col-md-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
  }

  .col-md-4 {
    -ms-flex-preferred-size: 33.33333333%;
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }

  .col-md-5 {
    -ms-flex-preferred-size: 41.66666667%;
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }

  .col-md-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }

  .col-md-7 {
    -ms-flex-preferred-size: 58.33333333%;
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }

  .col-md-8 {
    -ms-flex-preferred-size: 66.66666667%;
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }

  .col-md-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
  }

  .col-md-10 {
    -ms-flex-preferred-size: 83.33333333%;
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }

  .col-md-11 {
    -ms-flex-preferred-size: 91.66666667%;
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }

  .col-md-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }

  .start-md {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .center-md {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .end-md {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }

  .top-md {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }

  .middle-md {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .bottom-md {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }

  .around-md {
    -ms-flex-pack: distribute;
    justify-content: space-around;
  }

  .between-md {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}
@media (min-width: 60.001em) {
  .col-lg,
  .col-lg-1,
  .col-lg-2,
  .col-lg-3,
  .col-lg-4,
  .col-lg-5,
  .col-lg-6,
  .col-lg-7,
  .col-lg-8,
  .col-lg-9,
  .col-lg-10,
  .col-lg-11,
  .col-lg-12 {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-box-flex: 0;
    -ms-flex: 0 0 auto;
    flex: 0 0 auto;
    padding-right: 0.5rem;
    padding-left: 0.5rem;
  }

  .col-lg {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -ms-flex-preferred-size: 0;
    flex-basis: 0;
    max-width: 100%;
  }

  .col-lg-1 {
    -ms-flex-preferred-size: 8.33333333%;
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }

  .col-lg-2 {
    -ms-flex-preferred-size: 16.66666667%;
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }

  .col-lg-3 {
    -ms-flex-preferred-size: 25%;
    flex-basis: 25%;
    max-width: 25%;
  }

  .col-lg-4 {
    -ms-flex-preferred-size: 33.33333333%;
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }

  .col-lg-5 {
    -ms-flex-preferred-size: 41.66666667%;
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }

  .col-lg-6 {
    -ms-flex-preferred-size: 50%;
    flex-basis: 50%;
    max-width: 50%;
  }

  .col-lg-7 {
    -ms-flex-preferred-size: 58.33333333%;
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }

  .col-lg-8 {
    -ms-flex-preferred-size: 66.66666667%;
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }

  .col-lg-9 {
    -ms-flex-preferred-size: 75%;
    flex-basis: 75%;
    max-width: 75%;
  }

  .col-lg-10 {
    -ms-flex-preferred-size: 83.33333333%;
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }

  .col-lg-11 {
    -ms-flex-preferred-size: 91.66666667%;
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }

  .col-lg-12 {
    -ms-flex-preferred-size: 100%;
    flex-basis: 100%;
    max-width: 100%;
  }

  .start-lg {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }

  .center-lg {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }

  .end-lg {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }

  .top-lg {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }

  .middle-lg {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }

  .bottom-lg {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
  }

  .around-lg {
    -ms-flex-pack: distribute;
    justify-content: space-around;
  }

  .between-lg {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}
/*------------------------------------*\
    Tables
\*------------------------------------*/
.table {
	empty-cells: show;
	width: 100%;
	margin-bottom: 1.5em;
	font-size: 1em;
	text-align: left
}
.table th,
  .table td {
    padding: 1em;
		vertical-align: top;
  }
.table th {
    font-weight: normal;
  }
/* Project
   ----------------------------------------------------------------- */
/*------------------------------------*\
    共通
\*------------------------------------*/
.container {
  position: relative;
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
}
.block-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  z-index: 0;
  height: 360px;
  margin-bottom: 65px;
  background-color: #e4dbcc;
}
.block-header__title {
  font-family: "Bold";
  font-size: 10pt;
  letter-spacing: .2em;
  text-align: center;
}
.block-header__image {
  position: absolute;
  top: 30px;
  right: 0;
  bottom: 30px;
  left: 0;
  z-index: -1;
}
.block-header__image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  pointer-events: none;
}
.btn {
  display: inline-block;
  width: 210px;
  padding: 10px 0;
  border: 1px #333 solid;
  text-align: center;
  text-decoration: none;
  letter-spacing: 0.1em
}
.btn.ffgb {
    padding: 13px 0;
    font-size: 8pt;
    letter-spacing: 0.2em;
  }
.btn:hover {
    background: #333;
    color: #fff;
    text-decoration: none;
  }
.btn2 {
  display: block;
  max-width: 400px;
  margin: 0 auto;
  padding: 10px 0;
  border: 1px #333333 solid;
  font-size: 12pt;
  text-align: center
}
.btn2:hover {
    background: #333;
    color: #fff;
    text-decoration: none;
  }
@media (min-width: 801px) {
  .block-header {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    height: 620px;
    margin-bottom: 130px;
    padding-left: 150px;
    background: none
  }
    .block-header::before {
      content: "";
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      z-index: -1;
      background-color: #e4dbcc;
      width: 750px;
      height: 620px;
    }
  .block-header__title {
    font-size: 12pt;
  }
  .block-header__image {
    top: 60px;
    bottom: 60px;
    max-width: 1220px;
  }
    .block:nth-of-type(even) .block-header {
      -webkit-box-pack: end;
      -ms-flex-pack: end;
      justify-content: flex-end;
      padding-left: 0;
      padding-right: 150px;
      text-align: right
    }
      .block:nth-of-type(even) .block-header::before {
        right: auto;
        left: 0;
      }
    .block:nth-of-type(even) .block-header__image {
      margin-left: auto;
    }
}
/*------------------------------------*\
    INDEX
\*------------------------------------*/
/* メインビジュアル */
.main {
  position: relative;
  z-index: 1;
  height: 300px
}
.main .bx-wrapper {
    margin-bottom: 0;
  }
.main__slider img {
    width: 100%;
    height: 300px;
    -o-object-fit: cover;
    object-fit: cover;
  }
.main__title {
  position: absolute;
  z-index: 100;
  top: 250px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 200px;
}
@media (min-width: 801px) {
  .main {
    height: 700px
  }
    .main .bx-wrapper {
      width: 84%;
      height: 700px;
    }
    .main__slider img {
      height: 700px;
    }
  .main__title {
    top: 50%;
    left: auto;
    right: 7%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 260px;
  }
}
/* コンセプト */
.concept {
  padding-bottom: 80px;
}
.concept__title {
  position: absolute;
  top: 150px;
  right: 0;
  width: 125px;
}
.concept__image1 {
  max-width: 75%;
  width: 400px;
  padding-top: 250px;
}
.concept__image2 {
  width: 330px;
  margin: -50px 0 0 150px;
}
.concept__text {
  padding-top: 20px;
}
.concept__text img {
  display: none;
}
@media (min-width: 801px) {
  .concept {
    position: relative;
    padding-bottom: 160px;
  }
  .concept__title {
    top: 230px;
    right: 48px;
    width: 166px;
  }
  .concept__image1 {
    width: 400px;
    padding-top: 150px;
  }
  .concept__image2 {
    width: 330px;
    margin: -50px 0 0 150px;
  }
  .concept__text {
    position: absolute;
    top: 300px;
    right: 290px;
    width: 356px;
  }
  .concept__text img {
    display: block;
  }
  .concept__text p {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
    -webkit-clip-path: inset(0px 0px 99.9% 99.9%);
    clip-path: inset(0px 0px 99.9% 99.9%);
    border: 0;
  }
}
/* INTRODUCTION */
.intro-block {
  padding-bottom: 40px;
}
.intro-block__header em {
    font-family: "Bold";
    font-size: 7.5pt;
    letter-spacing: 0.2em;
    color: #000099;
  }
.intro-block__header h3 {
    position: relative;
    margin: 20px 0;
    padding-left: 22px;
    font-size: 21pt;
    font-weight: normal;
    line-height: 1.5;
    letter-spacing: 0.1em
  }
.intro-block__header h3::before {
      content: "";
      display: block;
      position: absolute;
      left: 0;
      top: 0.25em;
      bottom: 0;
      border-left: 1px solid #e4dacb;
    }
.intro-block__header h3 small {
    display: block;
    margin-top: 5px;
    font-size: 10pt;
    font-weight: bold;
  }
.intro-block__image img {
  width: 100%;
}
.intro-block__wrap {
  position: relative;
  padding: 30px 35px 25px;
  width: 100%;
  background: #fff;
  letter-spacing: 0;
  text-align: justify;
}
@media (min-width: 801px) {
  .intro-block {
    overflow: auto;
    position: relative;
    padding-bottom: 70px;
  }
  .intro-block__header {
    margin-bottom: 30px
  }
    .intro-block__header em {
      font-size: 9pt;
    }
    .intro-block__header h3 {
      font-size: 24.5pt;
    }
    .intro-block__header h3 small {
      font-size: 11.5pt;
    }
  .intro-block__wrap {
    margin-top: 70px;
    float: right;
    width: 650px;
    padding: 75px;
  }
  .intro-block__image {
    position: absolute;
    top: 0;
    max-width: 650px;
  }
  .intro-block:nth-of-type(even) .intro-block__image {
    right: 0;
  }
  .intro-block:nth-of-type(even) .intro-block__wrap {
    float: left;
  }
}
/* FEATURE */
.feature-block section {
    margin-bottom: 30px;
    background: #fff;
  }
.feature-block__header {
  position: relative
}
.feature-block__header h3 {
    position: absolute;
    top: 20px;
    left: 20px;
    width: 36px;
  }
.feature-block__header img {
    width: 100%;
  }
.feature-block__wrap {
  padding: 30px;
  text-align: justify;
}
@media (min-width: 801px) {
  .feature-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    max-width: 1050px;
    margin: 0 auto
  }

    .feature-block section {
      -webkit-box-flex: 1;
      -ms-flex: 1 0 47.6%;
      flex: 1 0 47.6%;
      max-width: 47.6%;
      margin-bottom: 50px;
    }
    .feature-block__header h3 {
      top: 35px;
      left: 50px;
      font-size: 29.5pt;
    }
  .feature-block__wrap {
    padding: 35px 50px;
  }
}
/* LINEUP */
.lineup {
  margin: 60px 0;
}
.lineup__image img {
  width: 100%;
}
.lineup__wrap {
  padding: 50px 30px 30px 30px;
  width: 100%;
  background: #fff
}
.lineup__wrap h3 {
    margin-bottom: 15px;
    font-size: 15pt;
    font-weight: normal;
    letter-spacing: 0.1em;
    line-height: 1.25;
  }
.lineup__wrap .btn {
    display: block;
    width: 100%;
    margin-top: 20px;
  }
.lineup .bx-wrapper {
  margin-bottom: 0;
}
.lineup .bx-wrapper .bx-controls-direction a {
  z-index: 100;
}
.lineup .bx-wrapper .bx-prev::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 40%;
  margin: auto;
  width: 100%;
  height: 100%;
  border-bottom: 1px #f1ece6 solid;
  border-left: 1px #f1ece6 solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: .3s;
}
.lineup .bx-wrapper .bx-next::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 40%;
  margin: auto;
  width: 100%;
  height: 100%;
  border-top: 1px #f1ece6 solid;
  border-right: 1px #f1ece6 solid;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transition: .3s;
}
@media (min-width: 801px) {
  .lineup {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 120px 0;
  }
  .lineup__image {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%;
    max-width: 50%;
  }
  .lineup__wrap {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%;
    max-width: 50%;
    padding: 30px;
    font-size: 10pt;
  }
  .lineup .bx-wrapper .bx-pager {
    text-align: left;
  }
}
@media (min-width: 1025px) {
  .lineup__wrap {
    padding: 60px 70px;
    font-size: 11.5pt
  }
    .lineup__wrap h3 {
      font-size: 20pt;
    }
    .lineup__wrap h3 .smaller {
      font-size: 18.5pt;
    }
    .lineup__wrap .btn {
      margin-top: 30px;
    }
}
/* オプション */
.lineup-option__heading {
  margin: 40px 0;
  text-align: center
}
.lineup-option__heading span {
    display: inline-block;
    padding: 20px 0 10px 0;
    border-bottom: 1px #333333 solid;
    font-size: 13pt;
    font-weight: normal;
    letter-spacing: 0.1em;
  }
.option {
  margin-bottom: 60px;
}
.option__wrap {
  padding-top: 40px
}
.option__wrap h4 {
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px dotted #333;
    font-size: 11pt;
    font-weight: bold;
    letter-spacing: 0.1em;
    line-height: 1.5;
  }
.option__wrap .btn {
    display: block;
    margin-top: 20px;
  }
@media (max-width: 800px) {
  .option {
    width: 80%;
    max-width: 600px;
    margin-right: auto;
    margin-left: auto;
  }
}
@media (min-width: 801px) {
  .lineup-option__heading {
    margin: 130px 0 80px 0
  }
    .lineup-option__heading span {
      font-size: 19.5pt;
    }
  .option {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 80px;
  }
  .option__image {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 33.3333%;
    flex: 1 0 33.3333%;
    max-width: 400px;
  }
  .option__wrap {
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self: center;
    padding: 0 0 0 50px
  }
    .option__wrap h4 {
      font-size: 16.5pt;
      font-weight: normal;
    }
}
/* CROSSTALKバナー */
.cross-banner {
  padding: 30px 0 100px 0;
}
.cross-banner__image img {
  width: 100%;
  height: 260px;
  -o-object-fit: cover;
  object-fit: cover;
}
.cross-banner__wrap {
  position: relative;
  z-index: 1;
  width: 90%;
  max-width: 1200px;
  margin: -30px auto 0;
  padding: 40px 30px;
  background: #fff;
  text-align: center
}
.cross-banner__wrap h2 {
    padding: 0 0 20px 0;
    font-family: "Bold";
    letter-spacing: .2em;
    font-size: 18pt;
  }
@media (min-width: 801px) {
  .cross-banner {
    padding: 100px 0 150px 0;
  }
  .cross-banner__image img {
    height: 480px;
  }
  .cross-banner__wrap {
    padding: 60px 0;
    margin-top: -50px;
  }
}
/* HOWTO */
.question {
  margin-bottom: 40px;
}
.question__wrap {
  padding-top: 20px;
  text-align: justify
}
.question__wrap em {
    color: #009;
    font-family: "Bold";
    font-size: 7.5pt;
    letter-spacing: 0.1em;
  }
.question__wrap h3 {
    margin: 20px 0 25px;
    font-size: 16.5pt;
    line-height: 1.5;
    font-weight: normal;
  }
.question__wrap h3::after {
    content: "";
    display: block;
    width: 9px;
    padding-bottom: 20px;
    border-bottom: 1px solid #333;
  }
@media (min-width: 801px) {
  .question {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 80px;
  }
  .question__image {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 50%;
    flex: 1 0 50%;
    max-width: 400px;
  }
  .question__wrap {
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self: center;
    padding: 0 0 0 30px
  }
    .question__wrap h3 {
      font-size: 19pt;
    }
}
@media (min-width: 1025px) {
  .question__image {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 33.3333%;
    flex: 1 0 33.3333%;
    max-width: 400px;
  }
  .question__wrap {
    padding: 0 0 0 60px;
  }
}
/* GALLERY */
.gallery {
  margin: 70px 0;
}
@media (min-width: 801px) {
  .gallery {
    margin: 160px 0 120px;
  }
}
/* BANNER */
.banner {
  margin: 60px 0 80px;
}
@media (min-width: 801px) {
  .banner {
    margin: 120px 0 150px;
  }
}
/* .girido_banner ///////////////////////*/
.girido_banner{
color: #FFFFFF;
background-color: #FFFFFF;
overflow: hidden;
position:relative;
height:300px;
margin-bottom:40px;
}
.girido_banner::before {
content: "";
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
background: url(../../image/girido_banner2.jpg) no-repeat left 70% center / cover;
-webkit-transition: opacity .5s, -webkit-transform .5s;
transition: opacity .5s, transform .5s;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
.girido_banner:hover::before{
opacity: 0.3;
-webkit-transform: scale3d(1.1,1.1,1);
transform: scale3d(1.1,1.1,1);
}
.girido_banner a{
position:absolute;
top:0;
left:0;
background:url("../../image/kids_frame.png") no-repeat 0 0;
background-size:100% 100%;
text-align:left;
width:100%;
height:300px;
border:5px #FF0000 sloid;
}

.girido_banner a img{
position:absolute;
top:50px;
left:15%;
}

.girido_banner .new{
position:absolute;
top:0;
left:0;
}


@media (max-width: 700px) {
.girido_banner a img{
position:absolute;
top:120px;
left:7%;
width:75%;
}
}


@media (max-width: 800px) {
.girido_banner a{
background:url("../../image/kids_frame2.png") no-repeat 0 0;
background-size:100% 100%;
}
}

@media (max-width: 500px) {
.girido_banner a{
background:url("../../image/kids_frame3.png") no-repeat 0 0;
background-size:100% 100%;
}
}

/* .tanagokoro_banner ///////////////////////*/
.tanagokoro_banner{
color: #FFFFFF;
background-color: #FFFFFF;
overflow: hidden;
position:relative;
height:370px;
margin-bottom:40px;
}
.tanagokoro_banner::before {
content: "";
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
background: url(../../image/tanagokoro_banner2.jpg) no-repeat left 70% center / cover;
-webkit-transition: opacity .5s, -webkit-transform .5s;
transition: opacity .5s, transform .5s;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
}
.tanagokoro_banner:hover::before{
opacity: 0.3;
-webkit-transform: scale3d(1.1,1.1,1);
transform: scale3d(1.1,1.1,1);
}
.tanagokoro_banner a img{
position:absolute;
top:50%;
left:10%;
transform: translateY(-50%);
width: 80%;
}


@media (max-width: 700px) {
.tanagokoro_banner{
height: 300px;
}
.tanagokoro_banner a img{
left:-35%;
width:130%;
max-width: none;
}
}


/*------------------------------------*\
    CROSS TALK
\*------------------------------------*/
.talk-header {
  position: relative;
  margin-bottom: 30px;
}
.talk-header__image img {
    width: 100%;
    height: 300px;
    -o-object-fit: cover;
    object-fit: cover;
  }
.talk-header__image small {
    display: none;
  }
.talk-header__title {
  position: absolute;
  top: 250px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  width: 180px;
}
@media (min-width: 801px){
  .talk-header__image {
    width: 84%
  }
    .talk-header__image img {
      height: 500px;
    }
    .talk-header__image small {
      display: block;
      padding: 5px 0 0 0;
      font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
      text-align: right;
    }
  .talk-header__title {
    top: 170px;
    right: 7%;
    left: auto;
    -webkit-transform: none;
    transform: none;
    width: 260px;
  }
}

.talk {
  padding: 100px 0 60px 0;
}
.talk__heading {
  margin-bottom: 50px;
  font-family: "Bold";
  font-size: 12.5pt;
  letter-spacing: 0.2em
}
.talk__heading::after {
    content: "";
    display: block;
    width: 40px;
    margin: 40px auto 0;
    border-bottom: 1px solid #333;
  }
.talk__text {
  max-width: 800px;
  margin: 40px auto 0
}
.talk__text .btn2 {
    margin-top: 20px;
  }
.line {
  display: block;
  margin: 70px 0 60px;
  text-align: center
}
.line .dot {
    display: inline-block;
    width: 5px;
    height: 5px;
    margin: 0 10px;
    border-radius: 50%;
    background-color: #333;
  }
.talk__subheading {
  margin-bottom: 70px
}
.talk__subheading::after {
    content: "";
    display: block;
    width: 40px;
    margin-top: 60px;
    border-bottom: 1px solid #333;
  }
.talk-block {
  margin-bottom: 40px;
}
.talk-block__image {
  margin-bottom: 20px
}
.talk-block__image img {
    width: 100%;
    margin-bottom: 10px;
  }
.talk-block__text p {
    margin-bottom: 2em;
  }
.talk-full-image {
  margin-bottom: 70px
}
.talk-full-image img {
	padding:0 50px 50px 50px;
    width: 100%;
    height: 480px;
    -o-object-fit: cover;
    object-fit: cover;
  }
.crosstalk-full-image img {
	padding:0 0px 0px 0px;
    width: 100%;
    height: 200px;
    -o-object-fit: cover;
    object-fit: cover;
  }
.crosstalk-full-image a:hover{
	opacity: 0.6;
		}
.youtube-full-image img {
	padding:0 0px 0px 0px;
    width: 100%;
    height: 35px;
    -o-object-fit: cover;
    object-fit: cover;
  }
@media (min-width: 801px){
  .talk {
    clear: both;
    padding: 60px 0 60px 0;
  }
  .talk__subheading {
    margin-bottom: 40px;
  }
  .talk-block {
    position: relative;
    margin-top: 50px;
    margin-bottom: 70px
  }
    .talk-block::after {
      content: "";
      display: block;
      clear: both;
    }
  .talk-block__image {
    float: right;
    width: 33.3333%;
    max-width: 400px;
    margin-bottom: 0
  }
    .talk-block__image img {
      margin-bottom: 20px;
    }
  .talk-block__text {
    float: left;
    width: 61.67777%;
  }
    .talk-block:nth-of-type(even) .talk-block__image {
      float: left;
    }
    .talk-block:nth-of-type(even) .talk-block__text {
    width: 61.67777%;
      float: right;
    }
.crosstalk-full-image img {
	padding:0 0px 0px 0px;
    width: 100%;
    height: 400px;
    -o-object-fit: cover;
    object-fit: cover;
  }
.youtube-full-image img {
	padding:0 0px 0px 0px;
    width: 100%;
    height: 45px;
    -o-object-fit: cover;
    object-fit: cover;
  }
}
.talk-profile__heading {
  padding: 50px 0;
  text-align: center
}
.talk-profile__heading h2 {
    display: inline-block;
    padding: 0 0 10px 0;
    border-bottom: 1px #333 solid;
    font-family: "Bold";
    font-size: 15pt;
    letter-spacing: .2em;
  }
.talk-profile__col {
  margin-bottom: 40px
}
.talk-profile__col .image {
    margin-bottom: 20px;
  }
.talk-profile__col .name {
    margin-bottom: 20px;
    padding-bottom: 10px;
    border-bottom: 1px #333 dotted;
    font-size: 15pt;
  }
.talk-profile__col .name small {
    display: inline-block;
    padding-left: 10px;
    color: #f00;
    font-family: "Bold";
    font-size: 7.5pt;
    font-weight: bold;
    letter-spacing: .2em;
  }
.talk-profile__col .text em {
    display: block;
    margin-bottom: 10px;
    font-weight: bold;
  }
.talk-profile__col .text a {
    color: #f00;
  }
@media (min-width: 801px){
  .talk-profile {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .talk-profile__heading {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 15%;
    flex: 1 0 15%;
    max-width: 15%;
    padding: 0;
    text-align: left;
  }
  .talk-profile__col {
    -webkit-box-flex: 1;
    -ms-flex: 1 0 42.5%;
    flex: 1 0 42.5%;
    max-width: 42.5%;
    padding-left: 20px
  }
    .talk-profile__col .image {
      margin-bottom: 40px;
    }
    .talk-profile__col .text em {
      display: block;
      margin-bottom: 10px;
      font-weight: bold;
    }
    .talk-profile__col .text a {
      color: #f00;
    }
}
/* Utility
   ----------------------------------------------------------------- */
/* Text alignment utilities */
.tal { text-align: left!important; }
.tar { text-align: right!important; }
.tac { text-align: center!important;
padding-bottom: 10px;}
/* Text style utilities */
.normal { font-weight: normal; }
.bold { font-weight: bold; }
.white { color: #fff; }
.sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	-webkit-clip-path: inset(0px 0px 99.9% 99.9%);
	clip-path: inset(0px 0px 99.9% 99.9%);
	border: 0;
}

/* .video ///////////////////////*/
#videoArea {
  position: absolute;
  z-index: 10;
min-width: 100%;
min-height: 100%;
}
