@charset "UTF-8";
/* ==========================================================================//
//
// [基本設定]
//
// ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;700;900&family=Oswald:wght@400;700&display=swap');


/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */

  -webkit-text-size-adjust: 100%;
  /* 2 */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  margin: 0.67em 0;
  font-size: 2em;
}

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  /* 1 */
  overflow: visible;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 2 */
}

/**
 * 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;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  text-decoration: underline dotted;
  /* 2 */

  -webkit-text-decoration: underline dotted;
  /* 2 */
}

/**
 * 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%;
}

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

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none;
}

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  /* 1 */
  margin: 0;
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 2 */
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  padding: 0;
  border-style: none;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  /* 2 */
  display: table;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 1 */
  color: inherit;
  /* 3 */
  white-space: normal;
  /* 1 */
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  /* 1 */
  font: inherit;
  -webkit-appearance: button;
  /* 2 */
}

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item;
}

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none;
}

/* ==========================================================================//
//
// [デフォルトスタイル]
//
// ========================================================================== */
html {
  font-size: 62.5%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;

  -webkit-overflow-scrolling: touch;
}

body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 3.75vw;
  line-height: 1;
  background: #fff;
  flex-direction: column;

  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
}

@media screen and (min-width: 768px) {
  body {
    font-size: 1.6rem;
  }
}

body > * {
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

*:not(hr):not(legend),
*::before,
*::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

h1,
h2,
h3,
h4,
h5,
h6,
p,
figure,
figcaption {
  margin: 0;
}

ul,
ol,
dl,
dt,
dd,
blockquote {
  margin: 0;
  padding: 0;
}

li {
  list-style-type: none;
}

a,
button {
  -webkit-transition: opacity 0.3s;
  transition: opacity 0.3s;
  outline: none;
}

@media screen and (min-width: 768px) {
  a:hover,
  button:hover {
    opacity: 0.7;
  }
}

a {
  color: inherit;
  text-decoration: none;
}

a[href^="tel"] {
  color: #000;
  text-decoration: none;
}

@media screen and (min-width: 768px) {
  a[href^="tel"] {
    display: inline-block;
    cursor: default !important;
    pointer-events: none !important;
  }
  a[href^="tel"]:hover {
    opacity: 1;
  }
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

svg {
  display: inline-block;
}

picture {
  display: block;
}

i {
  font-style: normal;
}

table {
  width: 100%;
  border-spacing: 0;
}

th {
  font-weight: normal;
}

td {
  text-align: center;
}

input {
  border-radius: 0;
}

[role=button],
[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
}

[disabled] {
  cursor: default;
  pointer-events: none;
}

[type=number] {
  width: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
  appearance: none;
}

textarea {
  overflow: auto;
  border-radius: 0;
  vertical-align: top;
  resize: vertical;
}

button,
input,
optgroup,
select,
textarea,
small {
  font: inherit;
}

optgroup {
  font-weight: 700;
}

button {
  overflow: visible;
  padding: 0;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  padding: 0;
  border-style: 0;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
  outline: 1px dotted ButtonText;
}

[type=reset],
[type=submit],
button,
html [type=button] {
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
}

button,
select {
  text-transform: none;
}

button,
input,
select,
textarea {
  border-style: none;
  color: inherit;
  background-color: transparent;
}

input:not([type="checkbox"]),
input:not([type="radio"]),
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

select {
  border-radius: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}

select::-ms-expand {
  display: none;
}

select::-ms-value {
  color: currentColor;
  background: none;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 0;
}

legend {
  display: table;
  max-width: 100%;
  border: none;
  color: inherit;
  white-space: normal;
}

::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button;
  appearance: button;
}

[type="search"] {
  -webkit-appearance: textfield;
  -moz-appearance: textfield;
  appearance: textfield;
  outline-offset: -0.02rem;
}

input,
textarea,
select {
  display: inline-block;
  width: 100%;
  padding: 0;
  border: none;
  background: #fff;
}

textarea {
  height: auto;
  resize: none;
}

:placeholder-shown {
  color: #999;
}

::-webkit-input-placeholder {
  color: #999;
}

::-moz-placeholder {
  opacity: 1;
  color: #999;
}

:-ms-input-placeholder {
  color: #999;
}

em {
  font-style: normal;
}

/* ==========================================================================//
//
// [レイアウト]
//
// ========================================================================== */
/* ******************************************************
footer
****************************************************** */
.n4-foot-wrap {
  display: none;
}

/* (min-width: 769px) 幅768pxのiPadはスマホ用フッタを表示させるため */
@media screen and (min-width: 769px), print {
  .n4-foot-wrap-sp {
    display: none;
  }
  .n4-foot-wrap {
    display: block;
    margin-top: 0;
  }
}

.l-header {
  position: relative;
  z-index: 10;
  background-color: rgba(6,30,57,0.8);
}

.l-header__in {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  height: 70px;
  -webkit-transition: 0.3s;
  transition: 0.3s;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .l-header__in {
    height: 45px;
  }
}

.l-header__logo {
  position: relative;
  z-index: 10;
  padding: 0 30px;
  font-size: 1px;
}

@media screen and (max-width: 767px) {
  .l-header__logo {
    padding: 0 15px;
  }
}

.l-header__logo-image {
  width: 190px;
  height: auto;
}

@media screen and (max-width: 767px) {
  .l-header__logo-image {
    width: 147px;
  }
}

@media screen and (max-width: 1039px) {
  .l-header__menu {
    overflow: hidden;
    position: absolute;
    top: 70px;
    right: 0;
    max-height: 0;
  }
}

@media screen and (max-width: 767px) {
  .l-header__menu {
    top: 45px;
	background-color: rgba(6,30,57,.8);
  }
}

.l-header__menu-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 70px;
}

@media screen and (max-width: 1039px) {
  .l-header__menu-list {
    display: block;
    width: 265px;
    height: auto;
    padding: 20px 0;
  }
}

.l-header__menu-item {
  display: block;
  position: relative;
}

@media screen and (min-width: 768px) {
  .l-header__menu-item:hover {
    opacity: 0.7;
  }
}

.l-header__menu-item:before {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 10px;
}

@media screen and (max-width: 1039px) {
  .l-header__menu-item:before {
    right: 0;
    bottom: 50%;
    left: auto;
    width: 10px;
    height: 1px;
  }
}

.l-header__menu-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  padding: 0 15px;
  color: #fff !important;
  font-size: 1.3rem;
  font-weight: bold;
  text-decoration: none !important;
  -webkit-transition: 0.3s;
  transition: 0.3s;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 1039px) {
  .l-header__menu-link {
    width: 100%;
    height: 70px;
    padding: 0 0 0 32px;

    -webkit-box-pack: unset;
    -ms-flex-pack: unset;
    justify-content: unset;
  }
}

@media screen and (max-width: 767px) {
  .l-header__menu-link {
    height: 45px;
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 1039px) {
  .is-loaded .l-header__menu {
    -webkit-transition: max-height 0.3s;
    transition: max-height 0.3s;
  }
}

.l-header__menu-trigger,
.l-header__menu-trigger::before,
.l-header__menu-trigger::after {
  display: inline-block;
  -webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: opacity 0.3s, -webkit-transform 0.3s;
  transition: transform 0.3s, opacity 0.3s;
  transition: transform 0.3s, opacity 0.3s, -webkit-transform 0.3s;
}

.l-header__menu-trigger {
  position: absolute;
  z-index: 10;
  top: 0;
  right: 0;
  width: 70px;
  height: 70px;
  background-color: #0071bc;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

@media screen and (max-width: 767px) {
  .l-header__menu-trigger {
    width: 45px;
    height: 45px;
  }
}

@media screen and (min-width: 1040px) {
  .l-header__menu-trigger {
    display: none;
  }
}

.l-header__menu-trigger::before,
.l-header__menu-trigger::after {
  position: absolute;
  left: 33.33%;
  width: 33.33%;
  height: 2px;
  border-radius: 2px;
  background-color: #fff;
}

.l-header__menu-trigger::before,
.l-header__menu-trigger::after {
  content: "";
}

.l-header__menu-trigger::before {
  top: 40%;
}

.l-header__menu-trigger::after {
  bottom: 40%;
}

.l-header__menu-trigger.is-active::before {
  top: calc(50% - 1px);
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
  -webkit-transform-origin: center;
  transform-origin: center;
}

.l-header__menu-trigger.is-active::after {
  bottom: calc(50% - 1px);
  -webkit-transform: translateY(-10%) rotate(135deg);
  transform: translateY(-10%) rotate(135deg);
  -webkit-transform-origin: center;
  transform-origin: center;
}

@media screen and (max-width: 1039px) {
  .l-header__menu-trigger.is-active + .l-header__menu {
    max-height: 100vh;
  }
}

.clone-nav {
  position: fixed;
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-transform: translateY(-100%);
  transform: translateY(-100%);
}

.is-show {
  -webkit-transform: translateY(0);
  transform: translateY(0);
  -webkit-box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.1);
  box-shadow: 0 3px 10px 0 rgba(0, 0, 0, 0.1);
}

.l-main {
  overflow: hidden;
  padding-bottom: 14.0625vw;
}

@media screen and (min-width: 768px) {
  .l-main {
    min-width: 1026px;
    padding-bottom: 150px;
  }
}

.l-section {
  width: 100%;
}

.l-section__in {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto;
  padding: 90px 50px;
}

@media screen and (max-width: 767px) {
  .l-section__in {
    padding: 7.8125vw 3.125vw 14.0625vw;
  }
}

.l-section:nth-child(odd) {
  background-color: #eaf3fd;
}

.l-section--life {
  position: relative;
}

@media screen and (min-width: 768px) {
  .l-section--life {
    background: #eaf3fd url("../img/bg_life_01_pc.png") no-repeat center bottom 600px;
  }
}

@media screen and (max-width: 767px) {
  .l-section--life {
    background: #eaf3fd url("../img/bg_life_01_sp.png") no-repeat center bottom 0/*25vw*/;
	  padding-bottom: 20px;
    background-size: contain;
  }
}

.l-showcase {
  min-width: 1026px;
  height: 612px;
  padding: 0 50px;
  background: url("../img/img_hero_01_pc.jpg") no-repeat center right/cover;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
  .l-showcase {
    background: url("../img/img_hero_01_pc@2x.jpg") no-repeat center right/cover;
  }
}

@media screen and (max-width: 767px) {
  .l-showcase {
    min-width: 0;
    height: auto;
    padding: 43.75% 6.25vw 0;
    background: url("../img/img_hero_01_sp.jpg") no-repeat top right/cover;
    background-size: 100% auto;
  }
}

.l-showcase__in {
  width: 980px;
  margin: 0 auto;
  padding-top: 40px;/*padding-top: 100px; 2023/1/20 update*/
  font-weight: bold;
}
.l-showcase__inline{
	width: 520px;
	text-align: center;
}

@media screen and (max-width: 767px) {
  .l-showcase__in {
    width: 100%;
    padding: 6.25vw 0 5.78125vw;
  }
.l-showcase__inline{
    width: 100%;
}
}

.l-showcase__text {
  font-size: 3.2rem;
	padding-right: .5em;
}

@media screen and (max-width: 767px) {
  .l-showcase__text {
    font-size: 4.0625vw;
  }
}

.l-showcase__text em {
  display: inline-block;
  padding-top: 5px;
  font-size: 4.2rem;
}

@media screen and (max-width: 767px) {
	.l-showcase__text {
		padding-right: 0;
	}
  .l-showcase__text em {
    padding-top: 0.78125vw;
    font-size: 7.1875vw;
  }
}

.l-showcase__text span {
  display: inline-block;
  margin-bottom: 5px;
  padding-bottom: 2px;
  /*border-bottom: 3px solid #000;*/
}

@media screen and (max-width: 767px) {
  .l-showcase__text span {
    margin-bottom: 0.78125vw;
    padding-bottom: 0.3125vw;
    border-bottom: 0.625vw solid #000;
  }
}

.l-showcase__text span em {
  padding-top: 0;
}

.l-showcase__catch {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  height: 30px;
  margin-top: 10px;
  padding: 0 8px;
  color: #fff;
  font-size: 1.8rem;
  background-color: #0071bc;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.l-showcase__catch2{
  margin-top: 10px;
	padding-left: 8px;
  font-size: 1.8rem;
}

@media screen and (max-width: 767px) {
  .l-showcase__catch {
    height: 5.15625vw;
    margin-top: 2vw;
    padding: 0 1.5625vw;
    font-size: 3.04688vw;
    letter-spacing: -0.05em;
  }
.l-showcase__catch2{
    margin-top: 3vw;
	text-align: left;
}
}

.l-showcase .c-button__wrap {
  width: 360px;
  height: 60px;
  margin: 20px auto auto auto;
}

@media screen and (max-width: 767px) {
  .l-showcase .c-button__wrap {
    width: 100%;
    height: 14.6875vw;
    margin-top: 3.25vw;
  }
}

/* ==========================================================================//
//
// [プラグイン]
//
// ========================================================================== */
/* ==========================================================================//
//
// [コンポーネント]
//
// ========================================================================== */
.c-button,
.c-button-anchor,
.c-button-inquiry,
.c-button-other-01,
.c-button-other-02,
.c-button-auto,
.c-button-small,
.c-button-middle,
.c-button-large,
.c-button[disabled] {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  width: 100%;
  height: 100%;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (min-width: 768px) {
  .c-button:hover,
  .c-button-anchor:hover,
  .c-button-inquiry:hover,
  .c-button-other-01:hover,
  .c-button-other-02:hover,
  .c-button-auto:hover,
  .c-button-small:hover,
  .c-button-middle:hover,
  .c-button-large:hover {
    color: #333 !important;
    text-decoration: none !important;
  }
}

.c-button:after,
.c-button-anchor:after,
.c-button-inquiry:after,
.c-button-other-01:after,
.c-button-other-02:after,
.c-button-auto:after,
.c-button-small:after,
.c-button-middle:after,
.c-button-large:after,
.c-button[disabled]:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 50%;
  width: 50px;
  height: 17px;
  border-right: 1px solid #000;
  border-bottom: 1px solid #000;
  -webkit-transform: skew(45deg, 0deg);
  transform: skew(45deg, 0deg);
  -webkit-transform-origin: right bottom;
  transform-origin: right bottom;
}

@media screen and (max-width: 767px) {
  .c-button:after,
  .c-button-anchor:after,
  .c-button-inquiry:after,
  .c-button-other-01:after,
  .c-button-other-02:after,
  .c-button-auto:after,
  .c-button-small:after,
  .c-button-middle:after,
  .c-button-large:after,
  .c-button[disabled]:after {
    width: 12.1875vw;
    border-right: 0.3125vw solid #000;
    border-bottom: 0.3125vw solid #000;
  }
}

.c-button-anchor {
  padding-left: 30px;
  color: #fff !important;
  font-size: 1.8rem;
  font-weight: bold;
  text-decoration: none !important;
  background-color: #F3821B;
  -webkit-box-shadow: 0 0 30px 0 rgba(10, 2, 5, 0.2);
  box-shadow: 0 0 30px 0 rgba(10, 2, 5, 0.2);

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

@media screen and (min-width: 768px) {
  .c-button-anchor:hover {
    color: #fff !important;
  }
}

@media screen and (max-width: 767px) {
  .c-button-anchor {
    padding-left: 7.5vw;
    font-size: 4.21875vw;
  }
}

.c-button-anchor:after {
  content: "";
  position: absolute;
  right: 7px;
  bottom: 0;
  width: 17px;
  height: 50px;
  border-right: none;
  border-bottom: 1px solid #fff;
  border-left: 1px solid #fff;
  -webkit-transform: skew(0deg, -45deg);
  transform: skew(0deg, -45deg);
  -webkit-transform-origin: left bottom;
  transform-origin: left bottom;
}

@media screen and (max-width: 767px) {
  .c-button-anchor:after {
    right: 1.71875vw;
    width: 4.0625vw;
    height: 12.5vw;
    border-bottom: 0.3125vw solid #fff;
    border-left: 0.3125vw solid #fff;
  }
}

.c-button-inquiry {
  color: #fff;
  font-size: 2.4rem;
  font-weight: bold;
  background-color: #F3821B;
  -webkit-box-shadow: 0 0 30px 0 rgba(10, 2, 5, 0.2);
  box-shadow: 0 0 30px 0 rgba(10, 2, 5, 0.2);
}

@media screen and (min-width: 768px) {
  .c-button-inquiry:hover {
    color: #fff !important;
  }
}

@media screen and (max-width: 767px) {
  .c-button-inquiry {
    font-size: 4.21875vw;
    -webkit-box-shadow: 0 0 4.6875vw 0 rgba(10, 2, 5, 0.2);
    box-shadow: 0 0 4.6875vw 0 rgba(10, 2, 5, 0.2);
  }
}

.c-button-inquiry:after {
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
}

.c-button-other-01,
.c-button-other-02 {
  width: 50%;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.33;
  background-color: #dbe8f8;
  flex-direction: column;

  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
}
.c-button-other-01,
.c-button-other-01:visited,
.c-button-other-01:link,
.c-button-other-02,
.c-button-other-02:visited,
.c-button-other-02:link {
  text-decoration: none;
  color: #000;
}

@media screen and (max-width: 767px) {
  .c-button-other-01,
.c-button-other-02 {
    width: 100%;
    height: 17.1875vw;
    padding-left: 4.6875vw;
    font-size: 4.21875vw;

    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
}

.c-button-other-01 span,
.c-button-other-02 span {
  font-size: 1.4rem;
}

@media screen and (max-width: 767px) {
  .c-button-other-01 span,
  .c-button-other-02 span {
    font-size: 2.8125vw;
  }
}

.c-button-other-02 {
  width: 50%;
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.33;
  background-color: #eaf3fd;
}

@media screen and (max-width: 767px) {
  .c-button-other-02 {
    width: 100%;
    height: 17.1875vw;
    padding-left: 4.6875vw;
    font-size: 4.21875vw;

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

.c-button__text {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
}

.c-button-auto {
  width: auto;
}

.c-button-small {
  max-width: 100px;
}

.c-button-middle {
  max-width: 200px;
}

.c-button-large {
  max-width: 300px;
}

.c-button--strong {
  border-color: #F3821B;
  background-color: #F3821B;
}

.c-button--weak {
  border-color: #999;
  background-color: #999;
}

.c-button-anchor[disabled],
.c-button-inquiry[disabled],
.c-button-other-01[disabled],
.c-button-other-02[disabled],
.c-button-auto[disabled],
.c-button-small[disabled],
.c-button-middle[disabled],
.c-button-large[disabled],
.c-button[disabled] {
  opacity: 0.3;
}

.c-button-group {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;

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

.c-heading-01 {
  color: #0071bc;
  font-size: 3.6rem;
  font-weight: bold;
  line-height: 1 !important;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-heading-01 {
    font-size: 6.09375vw;
    line-height: 1.38 !important;
  }
}

.c-heading-01 + .c-text {
  margin-top: 43px;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .c-heading-01 + .c-text {
    margin-top: 6.25vw;
  }
}

[data-ruby] {
  display: inline-block;
  position: relative;
}

[data-ruby]::before {
  content: attr(data-ruby);
  display: inline-block;
  position: absolute;
  top: -1em;
  right: 0;
  left: 0;
  margin-bottom: 3px;
  font-size: 1.2rem;
}

@media screen and (max-width: 767px) {
  [data-ruby]::before {
    margin-bottom: 0;
    margin-top: 2px;
    font-size: 3.875vw;
    -webkit-transform: scale(0.6);
    transform: scale(0.6);
    -webkit-transform-origin: center bottom;
    transform-origin: center bottom;
  }
}

.c-heading-02 {
  color: #0071bc;
  font-size: 3rem;
  font-weight: bold;
  line-height: 1;
}

@media screen and (max-width: 767px) {
  .c-heading-02 {
    font-size: 5.625vw;
    line-height: 5.625vw;
  }
}

.c-heading-02__sub {
  display: block;
  padding-bottom: 6px;
  font-size: 1.8rem;
}

@media screen and (max-width: 767px) {
  .c-heading-02__sub {
    padding-bottom: 0;
    font-size: 3.75vw;
    line-height: 5.625vw;
  }
}

.c-heading-02 + .c-text {
  margin-top: 32px;
}

@media screen and (max-width: 767px) {
  .c-heading-02 + .c-text {
    margin-top: 4.6875vw;
  }
}

.c-heading-03 {
  color: #0071bc;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.25;
}

@media screen and (max-width: 767px) {
  .c-heading-03 {
    font-size: 5.625vw;
    line-height: 1.17;
  }
}

.p-inquiry {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 800px;
  margin: 40px auto 0 auto;
  padding: 30px 10px;
  border: 1px solid #000;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .p-inquiry {
    display: block;
    width: 87.5vw;
    padding: 4.6875vw 7.8125vw;
    text-align: center;
  }
}

.p-inquiry__title {
  padding: 0 60px;
  font-size: 2.7rem;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .p-inquiry__title {
    padding: 0 0 4.6875vw;
    font-size: 5.625vw;
  }
}

.p-inquiry-main {
  padding-left: 47px;
  border-left: 1px solid #000;
}

@media screen and (max-width: 767px) {
  .p-inquiry-main {
    padding-top: 4.6875vw;
    padding-left: 0;
    border-top: 0.15625vw solid #000;
    border-left: none;
  }
}

.p-inquiry-main__title {
  font-size: 1.6rem;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .p-inquiry-main__title {
    font-size: 3.28125vw;
  }
}

.p-inquiry-main__phone {
  margin-top: 14px;
}

@media screen and (max-width: 767px) {
  .p-inquiry-main__phone {
    margin-top: 2.1875vw;
  }
}

.p-inquiry-main__phone a {
  display: inline-block;
  padding-left: 70px;
  color: inherit;
  font-family: "Oswald", sans-serif;
  font-size: 3.6rem;
  text-decoration: none;
  background: url("../img/ico_freedial_01.png") no-repeat left center;
}

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
  .p-inquiry-main__phone a {
    background: url("../img/ico_freedial_01@2x.png") no-repeat left center;
    background-size: 54px 31px;
  }
}

@media screen and (max-width: 767px) {
  .p-inquiry-main__phone a {
    padding-left: 10.9375vw;
    font-size: 7.5vw;
    background: url("../img/ico_freedial_01@2x.png") no-repeat left bottom 0.3125vw;
    background-size: 8.4375vw 4.84375vw;
  }
}

.p-inquiry-main__phone span {
  position: relative;
  top: -2px;
  font-size: 1.8rem;
}

@media screen and (max-width: 767px) {
  .p-inquiry-main__phone span {
    display: block;
    top: 0;
    margin-top: 2.5vw;
    font-size: 3.75vw;
  }
}

.c-text {
  line-height: 1.5;
}

/* ==========================================================================//
//
// [プロジェクト]
//
// ========================================================================== */
.p-business {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1050px;
  height: 388px;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .p-business {
    display: block;
    max-width: none;
    height: auto;
    padding: 0 3.125vw 56.8%;
  }
}

.p-business__in {
  width: 516px;
  height: 318px;
  padding: 40px 50px 0 40px;
  background-color: #fff;
  -webkit-box-shadow: 0 0 20px 0 rgba(10, 2, 5, 0.1);
  box-shadow: 0 0 20px 0 rgba(10, 2, 5, 0.1);
}

@media screen and (max-width: 767px) {
  .p-business__in {
    width: 100%;
    height: auto;
    padding: 4.6875vw 5.46875vw 6.25vw 6.25vw;
  }
}

.p-business + .p-business {
  margin-top: 60px;
}

@media screen and (max-width: 767px) {
  .p-business + .p-business {
    margin-top: 9.375vw;
  }
}

.p-business:nth-of-type(1) {
  margin-top: 63px;
  background: url("../img/img_01_pc.jpg") no-repeat left center/contain;

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

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
  .p-business:nth-of-type(1) {
    background: url("../img/img_01_pc@2x.jpg") no-repeat left center/contain;
  }
}

@media screen and (max-width: 767px) {
  .p-business:nth-of-type(1) {
    margin-top: 6.25vw;
    background: url("../img/img_01_sp.jpg") no-repeat bottom center/contain;
  }
}

@media screen and (min-width: 768px) {
  .p-business:nth-of-type(1) .p-business__in {
    height: 338px;
  }
}

.p-business:nth-of-type(2) {
  margin-left: auto;
  background: url("../img/img_02_pc.jpg") no-repeat right center/contain;

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

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
  .p-business:nth-of-type(2) {
    background: url("../img/img_02_pc@2x.jpg") no-repeat right center/contain;
  }
}

@media screen and (max-width: 767px) {
  .p-business:nth-of-type(2) {
    background: url("../img/img_02_sp.jpg") no-repeat bottom center/contain;
  }
}

.p-business:nth-of-type(3) {
  background: url("../img/img_03_pc.jpg") no-repeat left center/contain;

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

@media only screen and (-webkit-min-device-pixel-ratio: 2) {
  .p-business:nth-of-type(3) {
    background: url("../img/img_03_pc@2x.jpg") no-repeat left center/contain;
  }
}

@media screen and (max-width: 767px) {
  .p-business:nth-of-type(3) {
    background: url("../img/img_03_sp.jpg") no-repeat bottom center/contain;
  }
}

@media screen and (max-width: 767px) {
  .p-business .c-text {
    font-size: 3.28125vw;
    line-height: 1.43;
  }
}

.p-business-comparing {
  margin-top: 40px;
}

@media screen and (max-width: 767px) {
  .p-business-comparing {
    margin-top: 6.25vw;
  }
}

.p-faq + .p-faq {
  margin-top: 10px;
}

@media screen and (max-width: 767px) {
  .p-faq + .p-faq {
    margin-top: 1.5625vw;
  }
}

.p-faq__wrap {
  width: 960px;
  margin: 47px auto 0;
}

@media screen and (max-width: 767px) {
  .p-faq__wrap {
    width: 100%;
    margin-top: 7.34375vw;
  }
}

.p-faq__q {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  height: 108px;
  padding-left: 98px;
  color: #fff;
  font-size: 2.4rem;
  font-weight: bold;
  background-color: #0071bc;
  cursor: pointer;
  -webkit-transition: 0.3s;
  transition: 0.3s;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .p-faq__q {
    display: block;
    height: auto;
    padding: 5.9375vw 15.625vw 5.9375vw 13.75vw;
    font-size: 4.21875vw;
    line-height: 1.22;
  }
}

@media screen and (min-width: 768px) {
  .p-faq__q:hover {
    opacity: 0.7;
  }
}

.p-faq__q:before {
  content: "Q.";
  position: absolute;
  left: 36px;
  font-family: "Raleway", sans-serif;
  font-size: 3.6rem;
}

@media screen and (max-width: 767px) {
  .p-faq__q:before {
    top: 5.46875vw;
    left: 4.53125vw;
    font-size: 6.5625vw;
    line-height: 1;
  }
}

.p-faq__q:after {
  content: "";
  position: absolute;
  right: 38px;
  bottom: 50%;
  width: 17px;
  height: 51px;
  border-bottom: 1px solid #fff;
  border-left: 1px solid #fff;
  -webkit-transform: translateY(50%) skew(0deg, -45deg);
  transform: translateY(50%) skew(0deg, -45deg);
  -webkit-transform-origin: bottom left;
  transform-origin: bottom left;
}

@media screen and (max-width: 767px) {
  .p-faq__q:after {
    right: 2.65625vw;
    bottom: 50%;
    width: 4.0625vw;
    height: 12.5vw;
  }
}

.p-faq__q.is-active:after {
  top: 50%;
  bottom: auto;
  border: none;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  -webkit-transform: translateY(-50%) skew(0deg, -45deg);
  transform: translateY(-50%) skew(0deg, -45deg);
  -webkit-transform-origin: top right;
  transform-origin: top right;
}

@media screen and (max-width: 767px) {
  .p-faq__q.is-active:after {
    right: 5.78125vw;
  }
}

.p-faq__a {
  overflow: hidden;
  max-height: 0;
  background-color: #fff;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.p-faq__a .c-text {
  padding: 26px 30px;
}

@media screen and (max-width: 767px) {
  .p-faq__a .c-text {
    padding: 5.3125vw 6.25vw;
  }
}

@media screen and (min-width: 768px) {
  .p-faq__a a:hover {
    text-decoration: none;
  }
}

.p-life {
  width: 444px;
  padding: 44px 50px 50px;
  background-color: rgba(0, 113, 188, 0.8);
}

@media screen and (max-width: 767px) {
  .p-life {
    width: 100%;
    margin-top: 6.25vw;
    padding: 5.9375vw 6.25vw 6.25vw;
  }
}

.p-life-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 960px;
  margin: 46px auto 0;

  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .p-life-wrap {
    display: block;
    max-width: none;
    margin-top: 0.78125vw;
    padding: 0 3.125vw;
  }
}

.p-life-wrap + .p-life-wrap {
  /*margin-top: 384px;*/
	margin-top: 500px;
}

@media screen and (max-width: 767px) {
  .p-life-wrap + .p-life-wrap {
    margin-top: 0;
  }
}

.p-life__figure {
  margin-top: 35px;
}

@media screen and (max-width: 767px) {
  .p-life__figure {
    margin-top: 5.46875vw;
  }
}

.p-life__img {
  -webkit-box-shadow: 0 0 20px 0 rgba(10, 2, 5, 0.1);
  box-shadow: 0 0 20px 0 rgba(10, 2, 5, 0.1);
}

.p-life__img + .p-life__img {
  margin-top: 10px;
}

.p-life .c-heading-02 {
  color: #fff;
  font-size: 2.4rem;
  line-height: 1.5;
}

@media screen and (max-width: 767px) {
  .p-life .c-heading-02 {
    margin-right: -2em;
    font-size: 5.625vw;
    line-height: 1.1666;
  }
}

.p-life .c-text {
  margin-top: 17px;
  color: #fff;
}

@media screen and (max-width: 767px) {
  .p-life .c-text {
    font-size: 3.28125vw;
    line-height: 1.43;
  }
}

.p-life-type {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: absolute;
  /*bottom: 827px;*/
	bottom: 900px;
  left: 50%;
  width: 100%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);

  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (min-width: 768px) {
  .p-life-type {
    padding-right: 34px;
  }
}

@media screen and (max-width: 1199px) {
  .p-life-type {
    padding-right: 2.83333vw;
  }
}

@media screen and (max-width: 767px) {
  .p-life-type {
    display: block;
    position: relative;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 63.28125vw;
    margin-top: 7.96875vw;
    padding-right: 0;
    -webkit-transform: none;
    transform: none;
  }
}

.p-life-type__item {
  position: relative;
  width: 226px;
}

@media screen and (max-width: 1199px) {
  .p-life-type__item {
    width: 18.83333vw;
  }
}

@media screen and (max-width: 767px) {
  .p-life-type__item {
    position: absolute;
    width: 35.3125vw;
  }
}

@media screen and (min-width: 768px) {
  .p-life-type__item:nth-child(1) {
    margin-top: 70px;
  }
  .p-life-type__item:nth-child(1) .p-life-type__figcaption {
    bottom: 20px;
    left: -20px;
  }
}

@media screen and (max-width: 767px) {
  .p-life-type__item:nth-child(1) {
    top: 30.46875vw;
    left: 10.46875vw;
  }
  .p-life-type__item:nth-child(1) .p-life-type__figcaption {
    bottom: 3.125vw;
    left: -6.25vw;
  }
}

@media screen and (min-width: 768px) {
  .p-life-type__item:nth-child(2) {
    margin-left: 62px;
  }
  .p-life-type__item:nth-child(2) .p-life-type__figcaption {
    bottom: 20px;
    left: -20px;
  }
}

@media screen and (max-width: 1199px) {
  .p-life-type__item:nth-child(2) {
    margin-left: 5.16667vw;
  }
}

@media screen and (max-width: 767px) {
  .p-life-type__item:nth-child(2) {
    top: 0;
    left: 12.8125vw;
    margin-left: 0;
  }
  .p-life-type__item:nth-child(2) .p-life-type__figcaption {
    bottom: 3.125vw;
    left: -12.8125vw;
  }
}

@media screen and (min-width: 768px) {
  .p-life-type__item:nth-child(3) {
    margin: 84px 0 0 41px;
  }
  .p-life-type__item:nth-child(3) .p-life-type__figcaption {
    top: 20px;
    right: -20px;
  }
}

@media screen and (max-width: 1199px) {
  .p-life-type__item:nth-child(3) {
    margin-left: 3.41667vw;
  }
}

@media screen and (max-width: 767px) {
  .p-life-type__item:nth-child(3) {
    top: 6.25vw;
    left: 50.625vw;
    margin-left: 0;
  }
  .p-life-type__item:nth-child(3) .p-life-type__figcaption {
    top: 2.34375vw;
    right: -5.625vw;
  }
}

@media screen and (min-width: 768px) {
  .p-life-type__item:nth-child(4) {
    margin: 47px 0 0 73px;
  }
  .p-life-type__item:nth-child(4) .p-life-type__figcaption {
    right: -20px;
    bottom: 20px;
  }
}

@media screen and (max-width: 1199px) {
  .p-life-type__item:nth-child(4) {
    margin-left: 6.08333vw;
  }
}

@media screen and (max-width: 767px) {
  .p-life-type__item:nth-child(4) {
    top: 36.71875vw;
    left: 49.0625vw;
    margin-left: 0;
  }
  .p-life-type__item:nth-child(4) .p-life-type__figcaption {
    top: 2.5vw;
    right: -3.125vw;
    bottom: auto;
  }
}
.p-life-type__figcaption {
  display: inline-block;
  position: absolute;
  padding: 2px 6px 4px;
  color: #fff;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1;
  background-color: #333;
}

@media screen and (max-width: 767px) {
  .p-life-type__figcaption {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    height: 3.75vw;
    padding: 0 0.9375vw;
    font-size: 2.8125vw;

    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}

.p-reason {
  margin-top: 50px;
}

@media screen and (max-width: 767px) {
  .p-reason {
    margin-top: 6.25vw;
  }
}

.p-reason__in {
  width: 740px;
  margin: 0 auto;
  padding: 35px 40px 50px;
  background-color: #eaf3fd;
}

@media screen and (max-width: 767px) {
  .p-reason__in {
    width: 81.25vw;
    padding: 2.34375vw 3.125vw 9.375vw;
  }
}

.js-fade-img {
  position: relative;
  width: 659px;
  height: 699px;
}

@media screen and (max-width: 767px) {
  .js-fade-img {
    width: 75vw;
	height: 78.987vw;
    /*height: 64.6875vw;*/
  }
}

.js-fade-img img {
  opacity: 0;
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
}

.js-fade-img img.is-active {
  opacity: 1;
  z-index: 1;
}

.js-fade-img img.is-last {
  z-index: 0;
}

.p-reason-text {
  width: calc(33.33% - 40px);
  margin: 0 20px;
  padding: 26px 30px 40px;
  background-color: #fff;
  -webkit-box-shadow: 0 0 20px 0 rgba(10, 2, 5, 0.1);
  box-shadow: 0 0 20px 0 rgba(10, 2, 5, 0.1);
}

@media screen and (max-width: 767px) {
  .p-reason-text {
    width: 100%;
    margin: 6.25vw 0 0;
    padding: 4.0625vw 6.25vw 5.78125vw;
    -webkit-box-shadow: 0 0 3.125vw 0 rgba(10, 2, 5, 0.1);
    box-shadow: 0 0 3.125vw 0 rgba(10, 2, 5, 0.1);
  }
}

.p-reason-text__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  left: 330px;
  width: 1000px;
  margin: 50px -20px 0;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

@media screen and (max-width: 767px) {
  .p-reason-text__wrap {
    display: block;
    left: 0;
    width: auto;
    margin: 0 -6.25vw;
    -webkit-transform: none;
    transform: none;
  }
}

.p-reason-text .c-text {
  margin-top: 15px;
}

@media screen and (max-width: 767px) {
  .p-reason-text .c-text {
    margin-top: 3.75vw;
    font-size: 3.28125vw;
    line-height: 1.43;
  }
}

.p-subscription__in {
  width: 960px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .p-subscription__in {
    width: 87.5vw;
    margin: 0 auto;
  }
}

.p-subscription-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: row-reverse;

  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
}

@media screen and (max-width: 767px) {
  .p-subscription-main {
    display: block;
    padding: 0 6.25vw;
  }
}

.p-subscription-main__text {
  margin-left: 73px;
  padding-top: 40px;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__text {
    margin: 0;
    padding: 6.25vw 0 0 3.125vw;
  }
}

.p-subscription-main__catch {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  height: 24px;
  padding: 0 6px;
  color: #fff;
  font-size: 1.4rem;
  font-weight: bold;
  background-color: #0071bc;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__catch {
    height: 4.375vw;
    padding: 0 1.25vw;
    font-size: 3.125vw;
  }
}

.p-subscription-main__title {
  color: #0071bc;
  font-size: 2.4rem;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__title {
    font-size: 4.92188vw;
  }
}

.p-subscription-main__title em {
  display: inline-block;
  padding-top: 14px;
  font-size: 3.9rem;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__title em {
    padding-top: 2.34375vw;
    font-size: 8.04688vw;
  }
}

.p-subscription-main__title span {
  margin-right: 3px;
  border-bottom: 3px solid #0071bc;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__title span {
    margin-right: 1.71875vw;
    border-bottom: 0.625vw solid #0071bc;
  }
}

.p-subscription-main__title span em {
  margin-right: 14px;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__title span em {
    margin-right: 2.65625vw;
  }
}

.p-subscription-main__cost {
  margin-top: 20px;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__cost {
    margin-top: 7.5vw;
    padding-left: 2.65625vw;
  }
}

.p-subscription-main__cost-title {
  margin-right: 18px;
  font-size: 1.8rem;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__cost-title {
    margin-right: 3.90625vw;
    font-size: 3.125vw;
  }
}

.p-subscription-main__cost-amount {
  margin-right: 0.2em;
  font-size: 2.4rem;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__cost-amount {
    font-size: 5.39062vw;
  }
}

.p-subscription-main__cost-amount em {
  font-family: "Oswald", sans-serif;
  font-size: 6rem;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__cost-amount em {
    font-size: 12.26562vw;
  }
}

.p-subscription-main__cost-note {
  font-size: 2.1rem;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__cost-note {
    font-size: 4.6875vw;
  }
}

.p-subscription-main__cost + .c-text {
  margin-top: 15px;
}

@media screen and (max-width: 767px) {
  .p-subscription-main__cost + .c-text {
    margin-top: 2.96875vw;
    padding-left: 7.96875vw;
    font-size: 3.125vw;
  }
}

@media screen and (max-width: 767px) {
  .p-subscription-main__figure {
    margin-top: 5.78125vw;
  }
}

.p-subscription-main + .c-button__wrap {
  width: 480px;
  height: 80px;
  margin: 50px auto 0;
}

@media screen and (max-width: 767px) {
  .p-subscription-main + .c-button__wrap {
    width: 100%;
    height: 14.6875vw;
    margin-top: 8.4375vw;
  }
}

.p-subscription-other {
  margin-top: 60px;
  text-align: center;
  padding: 2em;
	background: #fff;
}

@media screen and (max-width: 767px) {
  .p-subscription-other {
    margin-top: 9.375vw;
  }
}

.p-subscription-other__title {
  display: inline-block;
  padding-bottom: 2px;
  border-bottom: 2px solid #000;
  font-size: 2.1rem;
  font-weight: bold;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .p-subscription-other__title {
    border-bottom: 0.46875vw solid #000;
    font-size: 4.6875vw;
  }
}

@media screen and (min-width: 768px) {
.p-subscription-other .c-button__wrap {
  display: flex;
  margin-top: 30px;
  justify-content: space-between;
}
.p-subscription-other .c-button__wrap li {
	width: 48%;
  }
}

@media screen and (max-width: 767px) {
  .p-subscription-other .c-button__wrap {
    margin-top: 4.6875vw;
  }
}

.p-subscription-other__note {
  margin-top: 18px;
  font-size: 1.4rem;
  text-align: center;
  padding-left: 10px;
}
.p-subscription-other .p-subscription-other__note{
  text-align: left;	
}
.p-subscription-other__note a {
	color: #0071bc;
}

@media screen and (max-width: 767px) {
  .p-subscription-other__note {
    margin-top: 2.96875vw;
    font-size: 3.125vw;
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    -webkit-transform-origin: top left;
    transform-origin: top left;
  }
}

/* ==========================================================================//
//
// [汎用]
//
// ========================================================================== */
.u-color-white {
  color: #fff !important;
}

.u-color-black {
  color: #000 !important;
}

.u-color-red {
  color: #ff1600 !important;
}

.u-bgcolor-transparent {
  background-color: transparent !important;
}

.u-bgcolor-current {
  background-color: currentColor !important;
}

.u-bg-none {
  background: none !important;
}

@media screen and (max-width: 767px) {
  .u-dn-md--down {
    display: none !important;
  }
}

@media screen and (max-width: 1039px) {
  .u-dn-lg--down {
    display: none !important;
  }
}

@media screen and (max-width: 1199px) {
  .u-dn-lf--down {
    display: none !important;
  }
}

@media screen and (max-width: 767px) {
  .u-db-md--down {
    display: block !important;
  }
}

@media screen and (max-width: 1039px) {
  .u-db-lg--down {
    display: block !important;
  }
}

@media screen and (max-width: 1199px) {
  .u-db-lf--down {
    display: block !important;
  }
}

@media screen and (max-width: 767px) {
  .u-di-md--down {
    display: inline !important;
  }
}

@media screen and (max-width: 1039px) {
  .u-di-lg--down {
    display: inline !important;
  }
}

@media screen and (max-width: 1199px) {
  .u-di-lf--down {
    display: inline !important;
  }
}

@media screen and (max-width: 767px) {
  .u-dib-md--down {
    display: inline-block !important;
  }
}

@media screen and (max-width: 1039px) {
  .u-dib-lg--down {
    display: inline-block !important;
  }
}

@media screen and (max-width: 1199px) {
  .u-dib-lf--down {
    display: inline-block !important;
  }
}

.u-dn {
  display: none !important;
}

@media screen and (min-width: 768px) {
  .u-dn-md {
    display: none !important;
  }
}

@media screen and (min-width: 1040px) {
  .u-dn-lg {
    display: none !important;
  }
}

@media screen and (min-width: 1200px) {
  .u-dn-lf {
    display: none !important;
  }
}

.u-db {
  display: block !important;
}

@media screen and (min-width: 768px) {
  .u-db-md {
    display: block !important;
  }
}

@media screen and (min-width: 1040px) {
  .u-db-lg {
    display: block !important;
  }
}

@media screen and (min-width: 1200px) {
  .u-db-lf {
    display: block !important;
  }
}

.u-di {
  display: inline !important;
}

@media screen and (min-width: 768px) {
  .u-di-md {
    display: inline !important;
  }
}

@media screen and (min-width: 1040px) {
  .u-di-lg {
    display: inline !important;
  }
}

@media screen and (min-width: 1200px) {
  .u-di-lf {
    display: inline !important;
  }
}

.u-dib {
  display: inline-block !important;
}

@media screen and (min-width: 768px) {
  .u-dib-md {
    display: inline-block !important;
  }
}

@media screen and (min-width: 1040px) {
  .u-dib-lg {
    display: inline-block !important;
  }
}

@media screen and (min-width: 1200px) {
  .u-dib-lf {
    display: inline-block !important;
  }
}

.deli{
	display: block;
	padding: .5em 1em;
	border: 1px solid #ccc;
	margin-top: 1em;
}
.deli span.title,
.deli span.text{
	display: block;
	font-size: 90%;
	padding: 0 1em .5em 1em;
	font-weight: normal;
}
.deli span.title{
	padding-top: 1em;
	text-decoration: underline;
}


/* modal */
/************************************************************************************/
.next-btn {
 position: absolute;
 bottom: 105px;
 left: 410px;
 display: block;
 width: 320px;
 height: 65px;
 background: transparent;
}
.next-btn i {
 display: none;
}
.overlay-box {
 display: none; 
 position: fixed;
 top: 0;
 left: 0;
 width: 100%;
 height: 100%;
 z-index: 200;
 overflow: auto;
}
.overlay-bg {
 display: none; 
 position: fixed;
 top: 0;
 left: 0;
 right: 0;
 width: 100%;
 height: 120%;
 background: url(../img/modal_bg.png)\9;
 background: rgba(0,0,0,.5);
 z-index: 120;
}
.modal-base {
 position: relative;
 margin: 50px auto 0;
 padding: 20px 4%;
 width: 60%;
 max-width: 620px;
 background-color: #fff;
 font-size: 14px;
 box-sizing: border-box;
}
.modal-base .btn-box {
 margin: 10px 0 0;
 text-align: center;
}
.modal-box {
 display: none;
 min-height: 80px;
}
.modal-box.disp {
 display: block;
}
.modal-cont {
 padding: 1em;
 min-height: 150px;
 background-color: #eee;
 box-sizing: border-box;
 -webkit-box-sizing: border-box;
}
.modal-inner {
 max-height: 280px;
 overflow-y: auto;
}
.modal-inner::-webkit-scrollbar{ 
 width: 5px;
}
.ad-df .modal-inner::-webkit-scrollbar{
 width: 0;
}
.modal-inner::-webkit-scrollbar-thumb{
 background: #969100;
 border-radius: 10px;
}
.modal-inner::-webkit-scrollbar-track-piece:start{
 background: #bebc9a;
}
.modal-inner::-webkit-scrollbar-track-piece:end{
 background: #ddd;
}
a.close-btn {
 display: inline-block;
 padding: .3em 2em .5em;
 color: #ffffff;
 background-color: #333333;
 border-radius: 3px;
 font-size: 16px;
 cursor: pointer;
 transition: all .2s ease-out;
}
a.close-btn:hover {
 background-color: #000000;
}
a.close-btn span {
 display: inline-block;
 padding-left: 20px;
 line-height: 1;
 height: 100%;
 background-image: url(../img/modal_ico_close.png);
 background-repeat: no-repeat;
 -webki-background-size: 13px;
 background-size: 13px;
 background-position: 0 50%;
 vertical-align: middle;
}

.ie8 a.close-btn span {
padding-left: 0;
background-image: none;
}
.close-btn2 {
 position: absolute;
 top: -6px;
 right: -6px;
 width: 23px;
 cursor: pointer;
}
.close-btn2 img {
 width: 100%;
}
html.ovlay-ie {
 overflow-y: hidden;
}
.ovlay-ie body {
 width: 100%;
 overflow-y: hidden;
}
.ovlay-ie .wrap-all {
 position: fixed;
 width: 100%;
 overflow-y: scroll;
}
.ovlay body {
 position: fixed;
 width: 100%;
 overflow-y: hidden;
}
.ovlay .wrap-all {
 overflow-y: scroll;
}
.ovlay-sp {
 width: 100%;
 height: 100%;
 overflow-y: hidden;
}
.ovlay-sp body {
 width: 100%;
 height: 100%;
 overflow-y: hidden;
}
.ovlay-sp .wrap-all {
/* display: none;*/ 
 position: fixed;
 left: 0;
 width: 100%;
}
html.ovlay-ad {
 overflow-y: hidden;
}
.ovlay-ad body {
 overflow-y: hidden;
}
.ovlay-ad .wrap-all {
overflow-y: scroll;
}
.n4-modal-ttl {
 display: block;
 margin-bottom: .3em;
 line-height: 1.4;
 color: #1f1f1f;
 font-size: 14px;
 font-weight: bold;
}
.n4-modal-tx {
 display: block;
 margin-bottom: .8em;
 line-height: 1.6;
 color: #1f1f1f;
 font-size: 12px;
}
.n4-modal-img {
 display: block;
 margin-bottom: .5em;
}
.n4-modal-img img {
 width: 100%;
}
.n4-modal-dl {
 margin: .5em 0 0;
 padding: 0;
 line-height: 1.4;
 color: #1f1f1f;
 font-size: 12px;
}
.n4-modal-dl dt {
 display: block;
 margin: 0 0 .5em;
 font-weight: bold;
 color: #1f1f1f;
 font-size: 13px;
}
.n4-modal-btnbox {
 margin: 15px 0 20px;
}
.n4-modal-btnbox ul {
 display: table;
 margin: 0;
 padding: 0;
 list-style: none;
 width: 100%;
}
.n4-modal-btnbox ul li {
 display: table-cell;
 padding: 0 2%;
 width: 40%;
}
.n4-modal-btnbox ul li a {
 line-height: 1.3;
 font-size: 24px;
}
.n4-modal-btnbox ul li a span {
 display: block;
 padding-top: 10px;
 font-size: 14px;
}
.n4-modal-dl dd {
 display: block;
 margin: 0 0 .5em;
}
.n4-hidden {
 display: none;
}
.modal-box .n4-entry2-btn:before {
 left: 20px;
 margin-top: -7px;
 border-width: 7px;
 border-left-width: 10px;
}
a.c-button-inquiry{
	color: #fff;
	text-decoration: none;
}




a.n4-btn-link-l {
position: relative;
display: block;
width: 100%;
height: 65px;
line-height: 65px;
color: #ffffff;
background-color: #0067B7;
border: none;
border-radius: 4px;
box-shadow: inset -1px -1px 0 rgba(0,0,0,.2);
font-size: 20px;
font-weight: bold;
text-align: center;
text-shadow: 1px 1px 0 rgba(0,0,0,.2);
transition: all .2s ease-out;
text-decoration: none;
}
a.n4-btn-link-l:hover {
text-decoration: none;
background-color: #005293;
opacity: 1;
}
a.n4-btn-link-l:after {
content: "";
position: absolute;
margin-top: -5px;
width: 6px;
height: 10px;
overflow: hidden;
top: 50%;
right: 10px;
background-image: url(../img/ico_arr_w.png);
background-repeat: no-repeat;
background-position: 0;
background-size: 6px;
}

@media screen and (max-width: 767px) {
  .n4-modal-btnbox ul {
    display: block;
  }
  .n4-modal-btnbox ul li {
    display: block;
    width: 100%;
    margin-bottom: 1em;
  }
  .n4-modal-btnbox ul li a {
    padding: 0 0 10px;
  }
  a.n4-btn-link-l {
    height: auto;
  }
}

.c-button-inquiry-textlink{
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  margin: 1em auto 2em auto;
    display: block;
    border-bottom: 1px dotted #999;
    padding-bottom: .3em;
    width: 7em;
}
.c-button-inquiry-textlink2{
  font-size: 1.6rem;
  font-weight: bold;
  text-align: center;
  margin: 2em auto 0 auto;
    display: block;
    border-bottom: 1px dotted #999;
    padding-bottom: .3em;
    width: 22em;
}

/* ********************************************************************************
  cta text
*********************************************************************************** */
.cta-button,
.cta-button-textlink{
    width: 100%;
}
.cta-button{
    margin-top: 50px;
}
.cta-button .cp-text{
    text-align: center;
    margin-bottom: 1em;
    line-height: 1.4;
    font-weight: bold;
    font-size: 110%;
}
.p-subscription-main__text{
  text-align: center;
}
.p-subscription-main__text .cp-text{
	margin-top: 2em;
}
.p-subscription-main__text .cp-text{
    text-align: center;
    margin-bottom: 1em;
    line-height: 1.4;
    font-weight: bold;
    font-size: 100%;
}
.p-subscription-main__text .cp-text span{
    background:linear-gradient(transparent 85%, #ea8ca8 85%);
    display:inline-block;
}
.p-subscription-main__text .cp-text a{
    width: 14em;
    padding: 10px;
    border: 2px solid #e2728e;
    margin: 1em auto;
    background: #e2728e;
    display: block;
    color: #fff;
    
}
.p-subscription-main__text .cp-text a::after{
    content: "→";
    border-left: 1px solid #fff;
    margin-left: 1em;
    padding-left: 1em;
}
.cp_text-top{
    width: 90%;
    text-align: center;
    margin-top: 1em;
    line-height: 1.4;
    font-weight: bold;
	color: #fff;
	margin-left: auto;
	margin-right: auto;
}
.cp_text-top span{
	display:inline-block;
	background:linear-gradient(transparent 85%, #ea8ca8 85%);
}
.cp_text-top a{
    width: 14em;
    padding: 10px;
    border: 2px solid #e2728e;
    margin: 1em auto;
    background: #e2728e;
    display: block;
    color: #fff;
    
}
.cp_text-top a::after{
    content: "→";
    border-left: 1px solid #fff;
    margin-left: 1em;
    padding-left: 1em;
}
@media screen and (min-width: 768px) { 
  
.p-subscription-main__text{
  text-align: left;
}  
.cp_text-top{
	width: 600px;
	line-height: 2;
  text-align: center;
}
}

/* ********************************************************************************
  floating
*********************************************************************************** */
.floatingbox{
  position: relative;
  margin: 0 auto;
  /*display: none;*/
}
.floatingbox.box{
  width: 34.25rem;    
}
.floatingbox .floatingbox__img{
  position: fixed;
  bottom: .5em;
  right: .5em;
  z-index: 88;
}
.floatingbox .floatingbox__img img{
    box-shadow: 0 0 8rem 0 rgba(2, 2, 2, 0.25);
}
.floatingbox__img__inner{
  width: 34.25rem;
  height: auto;
}
.floatingbox .floatingbox__img__inner a{
  position: relative;
  display: block;
  margin-top: .5rem;
}
.floatingbox .floatingbox__img__inner a:hover{
    opacity: .9;
}
.floatingbox .floatingbox__img p.close{
  position: absolute;
  top: -.6rem;
  right: -.6rem;
}
.floatingbox .floatingbox__img p.close a{
  display: block;
  width: 2.4rem;
  height: 2.4rem;
  text-align: center;
  background: #222;
  border-radius: 50%;
  color: #fff;
  font-size: 1.6rem;
  line-height: 1.4;
}
@media screen and (min-width: 768px), print {
.floatingbox{
}
.floatingbox .floatingbox__img{
  bottom: 1em;
}
.floatingbox__img__inner{}
.floatingbox__img__inner__title{}
.floatingbox .floatingbox__img__inner a{
  margin-top: 1.0rem;
}
}


/* ********************************************************************************
  cta text ※202305 TK update
*********************************************************************************** */
.cta-button,
.cta-button2,
.cta-button-textlink{
    width: 100%;
}
.cta-button,
.cta-button2{
    margin-top: 10px;
}
.cta-button .order,
.cta-button3 .order3,
.cta-button2 .order{
    width: 100%;
  font-size: 2.1rem;
  font-weight: bold;
  -webkit-box-shadow: 0 0 30px 0 rgba(10, 2, 5, 0.2);
  box-shadow: 0 0 30px 0 rgba(10, 2, 5, 0.2);
    display: block;
    text-align: center;
    padding: 1.2em 0;
  position: relative;
}
.cta-button .order,
.cta-button2 .order{
  color: #fff;
  background-color:#F3821B;
}
.cta-button3 .order3{
  color: #000;
  background-color: #9acff2;
}
.cta-button .order:after,
.cta-button3 .order3:after,  
.cta-button2 .order:after{
  content: "";
  position: absolute;
  right: 0;
  bottom: 50%;
  width: 30px;
  height: 17px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  -webkit-transform: skew(45deg, 0deg);
  transform: skew(45deg, 0deg);
  -webkit-transform-origin: right bottom;
  transform-origin: right bottom;
}
@media screen and (min-width: 768px) {     
.cp-text-top{
    width: 360px;
    font-size: 110%;
}
.cta-button{
    width: 480px;
    margin-left: auto;
    margin-right: auto;
}  
.cta-button2{
    width: 240px;
    margin-left: auto;
    margin-right: auto;
}   
.cta-button3{
    width: 420px;
    margin-left: auto;
    margin-right: auto;
	margin-top: 10px;
}  
.cta-button .order,
.cta-button2 .order,
.cta-button3 .order3{
  font-size: 2.4rem;
}
.cta-button .order:after,
.cta-button2 .order:after,
.cta-button3 .order3:after{
  width: 30px;
}
}

.cta-area{
	padding-top: 20px;
}
.p-subscription-main__cost {
  margin-top: 20px;
  font-weight: bold;
  text-align:center;
}
.p-subscription-main__cost2 {
  margin-top: 10px;
  font-weight: bold;
  text-align:center;
}
.p-subscription-main__cost-title {
  margin-right: 18px;
  font-size: 1.8rem;
  display: block;
}
.p-subscription-main__cost-amount {
  margin-right: 0.2em;
  font-size: 2.4rem;
}
.p-subscription-main__cost-amount2 {
  margin-right: 0.2em;
  font-size: 2.0rem;
}
.p-subscription-main__cost-amount em {
  font-family: "Oswald", sans-serif;
  font-size: 6rem;
}
.p-subscription-main__cost-amount2 em {
  font-family: "Oswald", sans-serif;
  font-size: 5rem;
}
.p-subscription-main__cost-note {
  font-size: 2.1rem;
}
.p-subscription-main__cost + .c-text {
  margin-top: 15px;
}
.flx-item{
	display: flex;
	margin: 10px auto 0 auto;
}
.flx-item li{
	width: 50%;
}
@media screen and (min-width: 768px), print {
.flx-item{
	width: 480px;
}
}
@media screen and (max-width: 767px) {
  .p-subscription-main__cost {
    margin-top: 7.5vw;
    padding-left: 2.65625vw;
  }
  .p-subscription-main__cost-title {
    margin-right: 3.90625vw;
    font-size: 3.125vw;
  }
  .p-subscription-main__cost-amount {
    font-size: 5.39062vw;
  }
  .p-subscription-main__cost-amount em {
    font-size: 12.26562vw;
  }
  .p-subscription-main__cost-amount2 {
    font-size: 3.7vw;
  }
  .p-subscription-main__cost-amount2 em {
    font-size: 11vw;
  }
  .p-subscription-main__cost-note {
    font-size: 4.6875vw;
  }
  .p-subscription-main__cost + .c-text {
    margin-top: 2.96875vw;
    padding-left: 7.96875vw;
    font-size: 3.125vw;
  }
}

.single_topics-txt{
    background-color: #fff;
	color: #000;
	line-height: 1.6;
	font-size: 90%;
}
.single_topics-txt a{
	text-decoration: underline;
}
.single_topics-txt em{
	font-weight: bold;
	color: #002b8e;
	display: block;
	margin-bottom:.5em;
	text-align: center;
}
.single_topics-txt ul{
	text-indent: -1em;
	padding-left: 1em;
}
@media screen and (max-width: 767px) {
.single_topics-txt{
    padding: 1em;
    margin-top: 8vw;
}
.single_topics-txt.s-bottom{
    margin-bottom: 10.67vw;
}
}
@media screen and (min-width: 768px), print {
.single_topics-txt{
    padding: 18px 40px;
    margin-top: 50px;
	text-align: left;
}
.single_topics-txt.s-bottom{
    margin-bottom: 50px;
}
}

/*
.c-button-other-01 em,
.c-button-other-02 em {
  font-family: "Oswald", sans-serif;
  font-size: 6rem;
  display: inline;
}*/

/* 20230623 update */
.l-showcase__cost{
	margin-top: 30px;
	padding: 1em 1em .5em 1em;
	background: #f9f08e;
	color: #0071bc;
}
.l-showcase__cost-ttl{
	font-size: 2.2rem;
}
.l-showcase__cost ul{
	display: flex;
	margin: 1.2rem auto;
	justify-content: space-between;
}
.l-showcase__cost li{
	display: flex;
	justify-content: space-between;
}
.l-showcase__cost li.item-left{
	width: 50%;
}
.l-showcase__cost li.item-right{
	width: 47%;
}
.l-showcase__cost li .cost__label{
	background: #fff;
	padding: .2em .5em;
	text-align: center;
	display: block;
	margin-right: .2em;
}
.l-showcase__cost li .cost__value em{
	font-size: 2.4rem;
	padding: .4em 0 .2em 0;
}
.l-showcase__cost li .cost__value small{
	font-size: 0.9rem;
	color: #000;
}
.cost__notes{
	font-size: 0.9rem;
	margin: 1em auto;
}
.l-showcase__cost2{
	margin-top: 10px;
	padding: 1em .8em;
	background: #fff;
	color: #0071bc;
}
.l-showcase__cost-ttl-s{
	font-size: 1.4rem;
	margin-bottom: .5em;
}
.cost__denshi{
	font-size:  1.9rem;
}
.cost__denshi small{
	font-size:  0.9rem;
}
.l-showcase__cost li .cost__label{
	color: #C40156;
}
@media screen and (max-width: 767px) {
	.l-showcase__cost li{
		display: block;
	}
.l-showcase__cost li .cost__label{
	font-size: 3vw;
	margin-bottom: .5em;
}
	.l-showcase__cost2{
		background: #d4f1ff;
		margin-bottom: 2em;
	}
	.l-showcase__cost2 .cost__denshi{
		font-size: 5vw;
		line-height: 1.2em;
	}
	.only-pc{
		display: none;
	}
}
@media screen and (min-width: 768px), print {
	.only-sp{
		display: none;
	}
}

/* 20231220 */
.head-item{
  background: url("../img/mv-new.png") no-repeat center left/cover;
  padding-bottom: 40px;
}

.l-header__menu-link-order {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  padding: 0 5px 0 15px;
  color: #000 !important;
  font-size: 1.3rem;
  font-weight: bold;
  text-decoration: none !important;
  -webkit-transition: 0.3s;
  transition: 0.3s;

  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
	.l-header__menu-link-order span{
	background: #ffff00;
		padding: 12px 15px;
		border-radius: 5px;
}
@media screen and (max-width: 767px){
  .l-header__menu-link-order {
    width: 100%;
    height: 70px;
    padding: 0 0 0 32px;

    -webkit-box-pack: unset;
    -ms-flex-pack: unset;
    justify-content: unset;
  }
	.flxpc-mv{
		width: 94%;
		margin: auto;
		padding-top: 50px;
	}
}

@media screen and (min-width: 768px), print{
  .l-header__menu-link-order {
    height: 45px;
	  padding-top: 25px;
    font-size: 1.3rem;
  }
	.flxpc-mv{
		width: 1026px;
		margin: auto;
		height: 480px;
		display: flex;
		padding-top: 50px;
	}
	.col-mv-left{
		width: 50%;
		height: 420px;
	}
	.col-mv-right{
		width: 50%;
		height: 420px;
		position: relative
	}
	.col-mv-right_img{
		position: absolute;
		top: 90px;
		left: 60px;
		width: 525px;
		height: auto;
	}
}

.col-mv__text,
.col-mv-point__text{
	color: #fff;
}
.col-mv__text span{
	display: block;
	padding: .2em 0;
}
.col-mv-point__text .sub-ttl{
	padding: 8px 0;
	text-align: center;
	width: 12em;
	border: 3px double #fff;
}
.col-mv-point__text ul{
	
}
.col-mv-point__text li{
	line-height: 2;
}
.col-mv-point__text li em{
	color: #ffff00;
	border-bottom: 1px solid #ffff00;
}
.col-mv-point__text li::before{
	content: url("../img/mv-icon.svg");
	width: 17.39px;
	height: 14px;
	margin-right: .4em;
}
	.col-mv-right_img p{
		text-align: center;
		color: #fff;
		padding-left: 1em;
	}
	.col-mv-right_img p em{
		color: #ffff00;
	}
	.col-mv-right_img p span{
		color: #ffff00;
	}
@media screen and (max-width: 767px) {
  .col-mv__text {
    font-size: 7.0625vw;
  }
	.col-mv-point__text{
		margin-top: 40px;
	}
	.col-mv-point__text .sub-ttl{
		font-size: 3vw;
	}
	.col-mv-point__text ul{
		margin-top: 30px;
	}
	.col-mv-point__text li{
		text-indent: -1em;
		padding-left: 1em;
	}
	.col-mv-right_img p{
		font-size: 4vw;
	}
	.col-mv-right_img em{
		font-size: 8vw;
		padding-left: .2em;
	}
}
@media screen and (min-width: 768px), print {
  .col-mv__text {
    font-size: 48px;
  }
	.col-mv-point__text{
		margin-top: 40px;
	}
	.col-mv-point__text .sub-ttl{
		font-size: 14px;
	}
	.col-mv-point__text ul{
		margin-top: 30px;
		font-size: 18px;
	}
	.col-mv-right_img p{
		font-size: 20px;
	}
	.col-mv-right_img em{
		font-size: 40px;
		padding-left: .2em;
	}
}

.mv-order{
	text-align: center;
}
.mv-order a{
	color: #fff;
	background: rgb(0,124,175);
	background: linear-gradient(233deg, rgba(0,124,175,1) 0%, rgba(1,175,166,1) 100%);
	display: block;
	margin: auto;
	border-radius: 50px;
	border: 2px solid #fff;
	box-shadow: 10px 10px 15px -10px rgba(0,0,0,.6);
}
.l-section.point .mv-order{
	margin-top: 20px;
}
.l-section.point .c-text-midashi{
	font-size: 128%;
	font-weight: bold;
	margin-bottom: .5em;
	display: block;
}
.l-section.point .c-text-midashi em{
	background: linear-gradient(transparent 70%, #fffe31 70%);
}
@media screen and (max-width: 767px) {
	.mv-order{
		padding-top: .5em;
	}
	.mv-order a{
		font-size: 4vw;
		width: 80%;
		padding: 20px 0;
	}
}
@media screen and (min-width: 768px), print {
	.mv-order a{
		font-size: 22px;
		width: 487px;
	padding: 24px 0;
	}
.l-section.point .mv-order{
	margin-top: 60px;
}
}

.l-section.point{
	background: #F4F5F7;
}
.flxpc-point{
	text-align: center;
}
.flxpc-point p{
	font-weight: 600;
	line-height: 1.6;
}
.blk-point-viewer{
	background: #fff;
	padding: 50px 20px;
	text-align: center;
	margin-top: 50px;
}
@media screen and (max-width: 767px) {
	.flxpc-point{
	}
	.col-point{
		margin-top: 2em;
	}
}
@media screen and (min-width: 768px), print {
	.flxpc-point{
		display: flex;
		justify-content: space-between;
		margin: 20px auto;
		width: 680px;
	}
	.col-point{
		width: 320px;
	}
}

.c-heading-viwer{
  font-size: 2.6rem;
  font-weight: bold;
  line-height: 1 !important;
  text-align: center;
}

@media screen and (max-width: 767px) {
  .c-heading-viwer{
    font-size: 6.09375vw;
    line-height: 1.38 !important;
  }
}

.c-heading-viwer + .c-text{
  margin-top: 43px;
  text-align: center;
}
	.blk-point-viewer .c-text small{
		font-size: 85%;
		background: #f2f2f2;
		display: block;
		margin-top: 1em;
		padding: 1em;
	}

@media screen and (max-width: 767px) {
  .c-heading-viwer + .c-text{
    margin-top: 6.25vw;
  }
	.blk-point-viewer .c-text{
		text-align: left;
	}
}
@media screen and (min-width: 768px), print {
	.blk-point-viewer{
		max-width: 940px;
		margin-left: auto;
		margin-right: auto;
	}
	.blk-point-viewer .c-text{
		width: 800px;
		margin: 40px auto 20px auto;
		line-height: 1.6;
		text-align: left;
	}
}

.flxpc-point-viewer{}
.col-point-viewer{
	line-height: 1.4;
}
.col-point-viewer em{
	font-weight: bold;
	color: #0071BC;
	display: block;
}

@media screen and (max-width: 767px) {
	.col-point-viewer{
		margin-top: 1.5em;
		border-bottom: 1px solid #B6BCC8;
		padding-bottom: 1.5em;
	}
	.col-point-viewer.last{
		border-bottom: none;
	}
}

@media screen and (min-width: 768px), print {
	.flxpc-point-viewer{
		display: flex;
		justify-content: space-between;
		width: 902px;
		margin: 40px auto 20px auto;
	}
	.col-point-viewer{
		width: 300px;
		border-right: solid 1px #B6BCC8;
	}
	.col-point-viewer.last{
		border-right: none;
	}
}

/* 20251218 update */
.flxpc-point-service{
	margin-top: 2em;
}
.point-service-img{
	width: 120px;
	margin: 0 auto 1em auto;
}
.col-point-newsletter,
.col-point-clubnikkei{
	background: #fff;
	padding: 40px 20px;
	text-align: center;
}
.flxpc-point-service .l-text{
	text-align: left!important;
	line-height: 1.4;
}
.blk-point-viewer a,
.col-point-newsletter a,
.col-point-clubnikkei a{
	border-bottom: 1px solid #F1812A;
	color: #F1812A;
}
.col-point-newsletter small{
	display: block;
	margin:1em 0;
	padding:1em;
	background: #f6f6f6;
	font-size: 70%;
}
@media screen and (max-width: 767px) {
	.col-point-newsletter{
		margin-bottom: 2em;
	}
	.col-point-newsletter .l-text,
	.col-point-clubnikkei .l-text{
		margin: 20px auto;
	}
}
@media screen and (min-width: 768px), print {
	.flxpc-point-service{
		display: flex;
		justify-content: space-between;
		margin: 20px auto;
		max-width: 940px;
	}
	.col-point-newsletter,
	.col-point-clubnikkei{
		width: 450px;
	}
	.col-point-newsletter .l-text,
	.col-point-clubnikkei .l-text{
		width: 350px;
		margin: 40px auto 20px auto;
		height: 10.5em;
	}
}
/* // */





.l-section.point .c-heading-01{
	line-height: 1.4!important;
}
.l-section.clubnikkei{
	background: #F4F5F7;
}
.l-section.clubnikkei .c-text{
	text-align: left;
	margin-left: auto;
	margin-right: auto;
}
.btn-link-cn{
	text-align: center;
}
.btn-link-cn a{
	color: #000;
	background: rgb(227,191,10);
	background: linear-gradient(233deg, rgba(227,191,10,1) 0%, rgba(217,235,43,1) 100%);
	display: block;
	margin: auto;
	border-radius: 50px;
	border: 2px solid #fff;
	box-shadow: 10px 10px 15px -10px rgba(0,0,0,.6);
}
@media screen and (max-width: 767px) {
.l-section.clubnikkei .c-text{
	width: 96%;
	margin-bottom: 1.5em;
}
	.btn-link-cn{
		padding-top: 1.5em;
	}
	.btn-link-cn a{
		font-size: 4vw;
		width: 60%;
		padding: 14px 0;
	}
}
@media screen and (min-width: 768px), print {
.l-section.clubnikkei .c-text{
	width: 920px;
	text-align: center;
	margin-bottom: 20px;
}
	.btn-link-cn{
		padding-top: 1.5em;
	}
	.btn-link-cn a{
		font-size: 22px;
		width: 354px;
		padding: 18px 0;
	}
}

/* -----------------------------------------------------------------------
 sec-yomikonashi
----------------------------------------------------------------------- */
.sec-yomikonashi{
	padding-top: 0;
	padding-bottom: 0;
	margin-bottom: 0;
}
.sec-yomikonashi .blk-sec{
	margin: 2em auto;
	padding: 2em;
	text-align: center;
}
.sec-yomikonashi .c-heading-01{
	margin-bottom: 2em;
}
.flxpc-yomikonashi-point li{
	padding: 1.2em .5em;
	background: #fff;
	border: 2px solid #01468F;
	color: #01468F;
	border-radius: 10px;
	text-align: left;
	padding-left: 3.5em;
	position: relative;
	line-height: 1.6;
}
.flxpc-yomikonashi-point li::after{
	position: absolute;
	content: "";
	display: block;
	width: 24px;
	height: auto;
	background: url("../img/icon-check_blue.svg") no-repeat;
}

@media screen and (max-width: 767px) {	
.sec-yomikonashi .blk-sec{
	width: 90%;
	margin: 2em auto;
}
	.flxpc-syomikonashi-img{
		width: 90%;
		margin: 1.5em auto;
	}
	.flxpc-syomikonashi-img li{
		margin-bottom: 1.5em;
	}
	.flxpc-yomikonashi-point{
		margin-top: 1em;
	}
	.flxpc-yomikonashi-point li{
		padding: .8em .5em;
		margin-bottom: .5em;
		padding-left: 3.5em;
	}
	.flxpc-yomikonashi-point li::after{
		top: 2em;
		bottom: 0;
		left: 1em;
	}
}

@media screen and (min-width: 768px), print {
	.sec-yomikonashi .blk-sec{
		margin: 2.5em auto;
		width: 90%;
		min-width: 860px;
		max-width: 1146px;
	}
	.flxpc-syomikonashi-img{
		width: 720px;
		display: flex;
		justify-content: space-between;
		margin: 40px auto;
	}
	.flxpc-yomikonashi-point{
		width: 860px;
		margin: 1em auto;
		display: flex;
		justify-content: space-between;
	}
	.flxpc-yomikonashi-point li{
		width: 32%;
	}
	.flxpc-yomikonashi-point li::after{
		top: 36px;
		bottom: 0;
		left: 20px;
	}
}