@charset "UTF-8";
/* # =================================================================
#	normalize
# ================================================================= */
/*! normalize.css v8.0.0 | 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.
 */
@import url("https://fonts.googleapis.com/css?family=Zen+Kaku+Gothic+New:700,900,600");
* {
  padding: 0;
  margin: 0;
  font-size: inherit;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html {
  overflow-y: scroll;
  /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%;
  /* iOS 8+ */
}

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 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;
  /* 2 */
  -webkit-text-decoration: underline dotted;
  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 {
  font-size: 75%;
  line-height: 0;
  position: relative;
  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 {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

/**
 * 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 {
  border-style: none;
  padding: 0;
}

/**
 * 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 {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 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 {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 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;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0;
}

[type="number"] {
  width: auto;
  /* Firefox 36+ */
}

[type="search"] {
  -webkit-appearance: textfield;
  /* Safari 8+ */
}

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  /* Safari 8 */
}

textarea {
  overflow: auto;
  /* Internet Explorer 11+ */
  resize: vertical;
  /* Specify textarea resizability */
}

button,
input,
optgroup,
select,
textarea {
  font: inherit;
  /* Specify font inheritance of form elements */
}

optgroup {
  font-weight: bold;
  /* Restore the font weight unset by the previous rule. */
}

button {
  overflow: visible;
  /* Address `overflow` set to `hidden` in IE 8/9/10/11 */
}

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

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

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

button,
select {
  text-transform: none;
  /* Firefox 40+, Internet Explorer 11- */
}

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
  color: inherit;
}

/* Style select like a standard input */
select {
  -moz-appearance: none;
  /* Firefox 36+ */
  -webkit-appearance: none;
  /* Chrome 41+ */
}

select::-ms-expand {
  display: none;
  /* Internet Explorer 11+ */
}

select::-ms-value {
  color: currentColor;
  /* Internet Explorer 11+ */
}

legend {
  border: 0;
  /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit;
  /* Correct the color inheritance from `fieldset` elements in IE */
  display: table;
  /* Correct the text wrapping in Edge and IE */
  max-width: 100%;
  /* Correct the text wrapping in Edge and IE */
  white-space: normal;
  /* Correct the text wrapping in Edge and IE */
}

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

/* Correct the text style of placeholders in Chrome, Edge, and Safari */
::-webkit-input-placeholder {
  color: inherit;
  opacity: 0.54;
}

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

/* # =================================================================
#	ベース
# ================================================================= */
@media all and (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

@media only screen and (max-width: 767px) {
  html {
    font-size: 16px;
  }
}

body {
  /*-webkit-font-smoothing:antialiased;
	-moz-font-smoothing:antialiased;
	font-smoothing:antialiased;*/
  letter-spacing: 0.04em;
  line-height: 1.5em;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
  background-color: #ffffff;
  color: #000000;
}

body, table, th, td, h1, h2, h3, h4, h5, h6 {
  font-family: "Zen Kaku Gothic New", "游ゴシック", "YuGothic", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Helvetica, Arial, Verdana, sans-serif;
  font-weight: 400;
  -webkit-font-feature-settings: "liga";
  font-feature-settings: "liga";
}

@media all and (min-width: 768px) {
  body, table, th, td, h1, h2, h3, h4, h5, h6 {
    font-size: 16px;
  }
}

@media only screen and (max-width: 767px) {
  body, table, th, td, h1, h2, h3, h4, h5, h6 {
    font-size: 16px;
  }
}

@media all and (min-width: 768px) {
  .pc-none {
    display: none !important;
  }
}

@media only screen and (max-width: 767px) {
  .sp-none {
    display: none !important;
  }
}

.small {
  line-height: 1.5em;
}

@media all and (min-width: 768px) {
  .small {
    font-size: 16px;
  }
}

@media only screen and (max-width: 767px) {
  .small {
    font-size: 4.26667vw;
  }
}

a,
button {
  color: #000000;
  text-decoration: none;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
}

img {
  max-width: 100%;
  height: auto;
  border: 0;
  vertical-align: middle;
}

ul {
  list-style-type: none;
}

/* clerfix ----- */
.clearfix {
  zoom: 1;
}

.clearfix:after {
  height: 0;
  display: block;
  clear: both;
  visibility: hidden;
  content: " ";
  line-height: 0;
}

/* ----- clerfix */
.clear {
  clear: both;
}

.txXXL {
  font-size: 160%;
  line-height: 145%;
}

.txXL {
  font-size: 140%;
  line-height: 145%;
}

.txL {
  font-size: 116%;
  line-height: 145%;
}

.txM {
  font-size: 100%;
  line-height: 160%;
}

.txS {
  font-size: 84%;
  line-height: 135%;
}

.txXS {
  font-size: 70%;
  line-height: 135%;
}

.txXXS {
  font-size: 60%;
  line-height: 135%;
}

.txRed {
  color: #ff0000;
}

.txOrange {
  color: #ff6600;
}

.txBold {
  font-weight: 500;
}

.txNormal {
  font-weight: 400;
}

.strong {
  font-weight: 600;
}

.error {
  color: #ff0000;
}

.nowrap {
  white-space: nowrap !important;
}

a:not([href]) {
  pointer-events: none;
}

a:not([href]):hover {
  opacity: 1.0 !important;
}

a:not([href]).dim {
  opacity: 0.6 !important;
}

.alnC {
  text-align: center !important;
}

.alnL {
  text-align: left !important;
}

.alnR {
  text-align: right !important;
}

.underline {
  border-bottom: 1px solid #22537d;
}

.list01 {
  list-style-type: none;
  margin: 0px 0px 0px 1.0em;
  padding: 0px;
}

.list01 li {
  margin: 0px;
  padding: 0px;
  text-indent: -1.0em;
}

.list01 li:before {
  content: "・";
}

.list02 {
  list-style-type: none;
  margin: 0px;
  padding: 0px;
}

.list02 li {
  margin: 0px;
  padding: 0px;
  margin-left: 1.0em;
  text-indent: -1.0em;
}

.decimal-list {
  list-style-type: decimal;
  margin: 0;
  padding: 0;
}

.decimal-list > li {
  margin-left: 1.0em;
}

.loader {
  display: block;
  font-size: 10px;
  position: absolute;
  left: 0px;
  right: 0px;
  top: 0px;
  bottom: 0px;
  margin: auto;
  text-align: left;
  overflow: hidden;
  text-indent: -9000px;
  border-top: 0.5em solid rgba(0, 0, 0, 0.2);
  border-right: 0.5em solid rgba(0, 0, 0, 0.2);
  border-bottom: 0.5em solid rgba(0, 0, 0, 0.2);
  border-left: 0.5em solid #000000;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation: loading 1.1s infinite linear;
  animation: loading 1.1s infinite linear;
}

@-webkit-keyframes loading {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

@keyframes loading {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

.loader,
.loader:after {
  border-radius: 50%;
}

@media all and (min-width: 768px) {
  .loader,
  .loader:after {
    width: 218.45333px;
    height: 218.45333px;
  }
}

@media only screen and (max-width: 767px) {
  .loader,
  .loader:after {
    width: 32vw;
    height: 32vw;
  }
}

/* # =================================================================
#	レイアウト
# ================================================================= */
/* # =================================================================
#	見出し
# ================================================================= */
/* # =================================================================
#	ボタン
# ================================================================= */
/* # =================================================================
#	リンク
# ================================================================= */
/* # =================================================================
#	アイコン
# ================================================================= */
/* # =================================================================
#	パンくず
# ================================================================= */
/* # =================================================================
#	ヘッダー
# ================================================================= */
/* header ------------------------------ */
/* # =================================================================
#	グローバルナビゲーション
# ================================================================= */
/* # =================================================================
#	メイン
# ================================================================= */
* {
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
}

body {
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  /*-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;*/
}

html {
  height: 100%;
  background-color: #ffffff;
}

body {
  height: 100%;
  background-color: #ffffff;
}

@media only screen and (max-width: 767px) {
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  p,
  table,
  tbody,
  tr,
  th,
  td,
  div,
  span {
    background-image: url(../img/spacer.gif);
    background-color: transparent;
    max-height: 999999px;
  }
}

a:link,
a:visited {
  color: #4700FF;
  text-decoration: underline;
}

a:hover,
a:active {
  color: #4700FF;
  text-decoration: underline;
}

/* basic style ------------------------------ */
.hover {
  display: inline-block;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  cursor: pointer;
}

@media all and (min-width: 768px) {
  a.hover:link,
  a.hover:visited,
  button.hover:link,
  button.hover:visited {
    opacity: 1.0;
  }
  a.hover:hover,
  a.hover:active,
  button.hover:hover,
  button.hover:active {
    opacity: 0.8;
  }
}

@media only screen and (max-width: 767px) {
  a.hover:link,
  a.hover:visited,
  a.hover:hover {
    opacity: 1.0;
  }
  a.hover:active {
    opacity: 1.0;
  }
}

button {
  cursor: pointer;
}

.anchor {
  pointer-events: none;
  /*@include media(){
		background-clip: padding-box !important;
		border-top: calc(80px + 20px) solid transparent !important;
		margin-top: calc(0px - 80px - 20px) !important;
	}*/
}

.anchor > * {
  pointer-events: auto;
}

.mb0 {
  margin-bottom: 0px !important;
}

.mb4 {
  margin-bottom: 4px !important;
}

.mb8 {
  margin-bottom: 8px !important;
}

#wrapper {
  width: 100%;
  overflow: hidden;
}

#fv {
  background-color: #f1eb02;
}

#fv .image {
  max-width: 1440px;
  margin: 0 auto;
}

#fv .image img {
  width: 100%;
  height: auto;
  aspect-ratio: 1440 / 1008;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center top;
  object-position: center top;
}

@media only screen and (max-width: 767px) {
  #fv .image img {
    aspect-ratio: 750 / 1334;
  }
}

.shindan-sec1 {
  padding: 90px 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  width: 100%;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  position: relative;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  background: -webkit-gradient(linear, left top, left bottom, from(#fffee1), to(#fffc97));
  background: -webkit-linear-gradient(top, #fffee1 0%, #fffc97 100%);
  background: linear-gradient(180deg, #fffee1 0%, #fffc97 100%);
}

.shindan-sec1 > .inner {
  max-width: 948px;
  padding: 0 20px;
  margin: 0 auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.shindan-sec1 > .inner .paragraph {
  position: relative;
  font-weight: 500;
  color: #0D3460;
  font-size: 32px;
  text-align: center;
  letter-spacing: 0.1em;
  line-height: 2.0em;
  margin-bottom: 50px;
}

@media only screen and (max-width: 767px) {
  .shindan-sec1 {
    padding: 45px 0;
  }
  .shindan-sec1 > .inner {
    padding: 0 15px;
  }
  .shindan-sec1 > .inner .paragraph {
    font-size: 16px;
    line-height: 2.0em;
    margin-bottom: 50px;
  }
}

.btn {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  position: relative;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  text-decoration: none !important;
}

.btn:hover {
  color: inherit;
  text-decoration: none;
}

.btn .rectangle {
  position: absolute;
  top: 7px;
  left: 5px;
  width: 718px;
  height: 97px;
  background-color: #ffffff;
  border-radius: 48.5px;
  border: 2px solid #0D3460;
}

.btn .btn-text {
  position: relative;
  width: 718px;
  height: 97px;
  background-color: #06c755;
  border-radius: 48.5px;
  border: 2px solid #0D3460;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  font-weight: 700;
  color: #ffffff;
  font-size: 26px;
  line-height: normal;
  text-align: center;
}

@media only screen and (max-width: 767px) {
  .btn {
    width: 100%;
  }
  .btn .rectangle {
    position: absolute;
    top: 5px;
    left: 3px;
    width: 100%;
    height: 90px;
    border: 1px solid #0D3460;
  }
  .btn .btn-text {
    position: relative;
    width: 100%;
    height: 90px;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    font-weight: 700;
    color: #ffffff;
    font-size: 19px;
    line-height: normal;
    text-align: center;
    border: 1px solid #0D3460;
  }
}

.shindan-sec2 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 30px 20px 90px;
  position: relative;
  background-color: #fffd97;
}

.shindan-sec2 .image {
  position: relative;
  max-width: 1000px;
  width: 100%;
  text-align: center;
}

.shindan-sec2 .image:before {
  content: "";
  display: block;
  width: 175px;
  height: 348px;
  background-image: url("../img/eyecatch02.png.webp");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 100% auto;
  position: absolute;
  left: -50px;
  top: -30px;
  z-index: 1;
}

.shindan-sec2 .image:after {
  content: "";
  display: block;
  width: 208px;
  height: 340px;
  background-image: url("../img/eyecatch03.png.webp");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 100% auto;
  position: absolute;
  right: -80px;
  top: -40px;
  z-index: 1;
}

.shindan-sec2 .image img {
  position: relative;
  z-index: 2;
  width: 656px;
  height: auto;
}

@media only screen and (max-width: 767px) {
  .shindan-sec2 {
    padding: 0 15px 45px;
  }
  .shindan-sec2 .image {
    margin-left: -15px;
    margin-right: -15px;
  }
  .shindan-sec2 .image:before, .shindan-sec2 .image:after {
    display: none;
  }
}

.shindan-sec2 > .inner {
  position: relative;
  z-index: 3;
  margin-top: -50px;
  max-width: 1000px;
  width: 100%;
  min-height: 340px;
  border-radius: 20px;
  background-color: #06C755;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
}

.shindan-sec2 > .inner:before {
  content: "";
  display: block;
  width: calc(100% + 38px);
  aspect-ratio: 1038 / 236;
  position: absolute;
  left: -19px;
  right: -19px;
  top: 0;
  bottom: 0;
  z-index: 1;
  margin: auto auto;
  background-image: url("../img/bg01.png.webp");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 100% auto;
}

.shindan-sec2 > .inner .text {
  position: relative;
  z-index: 2;
  color: #ffffff;
}

.shindan-sec2 > .inner .text .catch {
  font-size: 30px;
  line-height: 1.25em;
  font-weight: 900;
  margin-bottom: 15px;
}

.shindan-sec2 > .inner .text .catch > span {
  font-size: 50px;
  line-height: 1.25em;
}

.shindan-sec2 > .inner .text .lead {
  font-size: 18px;
  line-height: 1.75em;
  margin-bottom: 30px;
}

@media only screen and (max-width: 767px) {
  .shindan-sec2 > .inner {
    margin-top: -60px;
    padding: 15px 10px 20px;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    min-height: 0;
  }
  .shindan-sec2 > .inner:before {
    width: 100%;
    aspect-ratio: 716 / 325;
    position: absolute;
    left: 0;
    right: 0;
    top: 10px;
    bottom: auto;
    z-index: 1;
    background-image: url("../img/sp/bg01.png.webp");
  }
  .shindan-sec2 > .inner .text .catch {
    font-size: 22px;
    line-height: 1.25em;
    margin-bottom: 20px;
  }
  .shindan-sec2 > .inner .text .catch > span {
    font-size: 37px;
    line-height: 1.25em;
  }
  .shindan-sec2 > .inner .text .lead {
    font-size: 14px;
    line-height: 1.75em;
    margin-bottom: 25px;
  }
}

.shindan-sec2 .btn2 {
  position: relative;
  z-index: 2;
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: start;
  -webkit-align-items: flex-start;
  -ms-flex-align: start;
  align-items: flex-start;
  position: relative;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  text-decoration: none;
}

.shindan-sec2 .btn2:hover {
  color: inherit;
  text-decoration: none;
}

.shindan-sec2 .btn2 .rectangle {
  position: absolute;
  top: 7px;
  left: 5px;
  width: 446px;
  height: 97px;
  background-color: #06c755;
  border-radius: 48.5px;
  border: 2px solid #0D3460;
}

.shindan-sec2 .btn2 .btn-text {
  position: relative;
  width: 446px;
  height: 97px;
  background-color: #ffffff;
  border-radius: 48.5px;
  border: 2px solid #0D3460;
  font-weight: 700;
  color: #06c755;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 26px;
  line-height: normal;
  text-align: center;
}

@media only screen and (max-width: 767px) {
  .shindan-sec2 .btn2 {
    width: 100%;
  }
  .shindan-sec2 .btn2 .rectangle {
    position: absolute;
    top: 5px;
    left: 3px;
    width: 100%;
    height: 65px;
    background-color: #06c755;
    border-radius: 48.5px;
    border: 1px solid #0D3460;
  }
  .shindan-sec2 .btn2 .btn-text {
    position: relative;
    width: 100%;
    height: 65px;
    background-color: #ffffff;
    border-radius: 48.5px;
    border: 1px solid #0D3460;
    font-weight: 700;
    color: #06c755;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    font-size: 19px;
    line-height: normal;
    text-align: center;
  }
}

.about-sec {
  background-image: url("../img/bg02.png.webp");
  background-repeat: repeat-x;
  background-position: -120% 0%;
  background-size: auto 100%;
  padding: 0 20px;
}

@media only screen and (max-width: 767px) {
  .about-sec {
    padding: 0 15px;
    background-size: 95% 100%;
  }
}

.about-sec > .inner {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 1000px;
  padding: 90px 0;
  margin: 0 auto;
}

@media only screen and (max-width: 767px) {
  .about-sec > .inner {
    padding: 45px 0;
  }
}

.about-sec .head {
  position: relative;
  color: #0D3460;
  max-width: 100%;
  min-width: 600px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  margin-bottom: 80px;
}

.about-sec .head > .heading {
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 462px;
  min-height: 90px;
  padding: 5px 10px;
  background-color: #0D3460;
  border-radius: 10px;
  color: #ffffff;
  font-size: 32px;
  line-height: 1.25em;
  font-weight: 500;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  margin: 0 auto 42px;
}

.about-sec .head > .heading:after {
  content: "";
  display: block;
  width: 58px;
  height: 35px;
  background-image: url("../img/arw01.svg");
  background-repeat: no-repeat;
  background-position: 50% 100%;
  background-size: 100% auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -20px;
  margin: 0 auto;
}

.about-sec .head > .catch {
  font-size: 48px;
  line-height: 1.25em;
  font-weight: 500;
  text-align: center;
  margin-bottom: 20px;
}

.about-sec .head > .text {
  font-size: 24px;
  line-height: 2.5em;
  font-weight: 500;
  text-align: center;
}

.about-sec .head .eyecatch1 {
  width: 258px;
  height: 505px;
  position: absolute;
  left: -258px;
  top: 40px;
}

.about-sec .head .eyecatch1 img {
  width: 100%;
  height: auto;
}

.about-sec .head .eyecatch2 {
  width: 253px;
  height: 511px;
  position: absolute;
  right: -253px;
  top: 40px;
}

.about-sec .head .eyecatch2 img {
  width: 100%;
  height: auto;
}

.about-sec .head .eyecatch-sp {
  display: none;
}

@media only screen and (max-width: 767px) {
  .about-sec .head {
    min-width: 0;
    margin-bottom: 30px;
  }
  .about-sec .head > .heading {
    max-width: 282px;
    min-height: 54px;
    padding: 15px 25px;
    background-color: #0D3460;
    border-radius: 12px;
    color: #ffffff;
    font-size: 18px;
    line-height: 1.25em;
    font-weight: 500;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    text-align: center;
    margin: 0 auto 25px;
  }
  .about-sec .head > .heading:after {
    content: "";
    display: block;
    width: 29px;
    height: 18px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10px;
    margin: 0 auto;
  }
  .about-sec .head > .catch {
    font-size: 27px;
    line-height: 1.25em;
    margin-bottom: 10px;
  }
  .about-sec .head > .text {
    font-size: 14px;
    line-height: 2.25em;
  }
  .about-sec .head .eyecatch1 {
    display: none;
  }
  .about-sec .head .eyecatch2 {
    display: none;
  }
  .about-sec .head .eyecatch-sp {
    display: block;
    margin-top: 20px;
    margin-left: -18px;
    margin-right: -18px;
    margin-bottom: 30px;
  }
  .about-sec .head .eyecatch-sp img {
    width: 100%;
    height: auto;
  }
}

.about-sec .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.about-sec .row > .column {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  width: calc(50% - 20px);
}

.about-sec .row > .column > .heading {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-radius: 50px;
  background-color: #333333;
  color: #ffffff;
  text-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  padding: 8px 15px;
  max-height: 64px;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 20px;
  line-height: 1.25em;
  letter-spacing: normal;
  font-weight: 500;
  margin-bottom: 16px;
}

.about-sec .row > .column > .text {
  color: #0D3460;
  text-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-flex: 50;
  -webkit-flex: 50 1 auto;
  -ms-flex: 50 1 auto;
  flex: 50 1 auto;
}

.about-sec .row > .column > .text p {
  font-size: 20px;
  line-height: 2.0em;
  font-weight: 700;
  margin-bottom: 1.0em;
}

.about-sec .row > .column > .text p:nth-last-child(1) {
  font-size: 18px;
  line-height: 1.5em;
  margin-bottom: 0;
}

.about-sec .row > .column > .text p > span {
  font-weight: 900;
}

.about-sec .row > .column > .eyecatch {
  height: 240px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.about-sec .row > .column > .eyecatch img {
  width: auto;
  height: auto;
}

.about-sec .row > .column > .image {
  text-align: center;
}

.about-sec .row > .column > .image img {
  max-width: min(380px, 100%);
  width: auto;
  height: auto;
}

@media only screen and (max-width: 767px) {
  .about-sec .row {
    display: block;
  }
  .about-sec .row > .column {
    width: 100%;
    margin-bottom: 50px;
  }
  .about-sec .row > .column:nth-last-child(1) {
    margin-bottom: 0;
  }
  .about-sec .row > .column > .heading {
    padding: 5px 20px;
    max-height: 30px;
    font-size: 14px;
    line-height: 1.25em;
    margin-bottom: 12px;
  }
  .about-sec .row > .column > .text {
    text-align: center;
    display: block;
  }
  .about-sec .row > .column > .text p {
    font-size: 14px;
    line-height: 2.0em;
    font-weight: 700;
    margin-bottom: 1.0em;
  }
  .about-sec .row > .column > .text p:nth-last-child(1) {
    font-size: 12px;
    line-height: 1.5em;
    margin-bottom: 0;
  }
  .about-sec .row > .column > .eyecatch {
    margin-top: 25px;
    height: auto;
    display: block;
    text-align: center;
  }
  .about-sec .row > .column > .image {
    text-align: center;
  }
  .about-sec .row > .column > .image img {
    max-width: 228px;
    width: auto;
    height: auto;
  }
}

#about1_eyecatch01 {
  max-height: 215px !important;
}

#about1_eyecatch02 {
  max-height: 215px !important;
}

#about2_eyecatch01 {
  max-height: 242px !important;
  margin-bottom: -60px;
}

#about2_eyecatch02 {
  max-height: 246px !important;
  margin-bottom: -60px;
}

#about3_eyecatch01 {
  max-height: 242px !important;
  margin-bottom: -90px;
}

#about3_eyecatch02 {
  max-height: 246px !important;
  margin-bottom: -70px;
}

#about4_eyecatch01 {
  max-height: 242px !important;
  margin-bottom: -80px;
}

#about4_eyecatch02 {
  max-height: 206px !important;
  margin-bottom: -40px;
}

@media only screen and (max-width: 767px) {
  #about1_eyecatch01 {
    max-height: 118px !important;
  }
  #about1_eyecatch02 {
    max-height: 105px !important;
  }
  #about2_eyecatch01 {
    max-height: 145px !important;
    margin-bottom: -40px;
  }
  #about2_eyecatch02 {
    max-height: 147px !important;
    margin-bottom: -40px;
    margin-left: -20px;
  }
  #about3_eyecatch01 {
    max-height: 150px !important;
    margin-bottom: -45px;
    margin-right: -20px;
  }
  #about3_eyecatch02 {
    max-height: 144px !important;
    margin-bottom: -40px;
  }
  #about4_eyecatch01 {
    max-height: 145px !important;
    margin-bottom: -50px;
  }
  #about4_eyecatch02 {
    max-height: 123px !important;
    margin-bottom: -30px;
  }
}

.aqua-sec {
  position: relative;
  background-color: #DFF2FC;
  padding: 0 20px;
}

.aqua-sec > .inner {
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 1000px;
  padding: 90px 0;
  margin: 0 auto;
}

.aqua-sec > .inner > .heading {
  text-align: center;
  margin-bottom: 20px;
}

.aqua-sec > .inner > .heading img {
  width: 490px;
  height: auto;
}

@media only screen and (max-width: 767px) {
  .aqua-sec {
    padding: 0 15px;
  }
  .aqua-sec > .inner {
    padding: 45px 0;
  }
  .aqua-sec > .inner > .heading {
    text-align: center;
    margin-bottom: 25px;
  }
  .aqua-sec > .inner > .heading img {
    width: 294px;
    height: auto;
  }
}

.aqua-sec#world1 > .inner:before {
  content: "";
  display: block;
  width: 201px;
  height: 184px;
  background-image: url("../img/sec1_eyecatch01.svg");
  background-repeat: no-repeat;
  background-position: 50% 100%;
  background-size: auto 100%;
  position: absolute;
  right: 0;
  bottom: 0;
}

.aqua-sec#world1 .image {
  margin-bottom: 40px;
}

.aqua-sec#world1 .image img {
  width: 100%;
  height: auto;
}

.aqua-sec#world1 .text {
  width: 100%;
  max-width: 652px;
  min-height: 54px;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 5px 20px;
  background-color: #ffffff;
  color: #0D3460;
  font-size: 32px;
  line-height: 1.25em;
  font-weight: 500;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

@media only screen and (max-width: 767px) {
  .aqua-sec#world1 > .inner:before {
    display: none;
  }
  .aqua-sec#world1 .image {
    text-align: center;
    margin-bottom: 20px;
  }
  .aqua-sec#world1 .image img {
    max-width: 245px;
    width: 100%;
    height: auto;
  }
  .aqua-sec#world1 .text {
    width: 100%;
    max-width: 326px;
    min-height: 27px;
    padding: 5px 20px;
    font-size: 16px;
    line-height: 1.25em;
  }
}

.aqua-sec#world2 .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 -20px;
}

.aqua-sec#world2 .row .column {
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: calc(50% - 40px);
  margin: 0 20px 30px;
  background-color: #ffffff;
  border-radius: 20px;
  padding: 40px 36px;
  text-align: center;
  color: #0D3460;
}

.aqua-sec#world2 .row .column:nth-last-child(1) {
  margin-bottom: 0;
}

.aqua-sec#world2 .row .column > .heading {
  margin-bottom: 10px;
}

.aqua-sec#world2 .row .column > p {
  font-size: 18px;
  line-height: 1.75em;
  font-weight: 500;
}

.aqua-sec#world2 .row .column#world2-1 > .heading img {
  width: auto;
  height: 91px;
}

.aqua-sec#world2 .row .column#world2-1:before {
  content: "";
  display: block;
  width: 360px;
  aspect-ratio: 226 / 70;
  background-image: url("../img/sec2_eyecatch01.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: auto 100%;
  position: absolute;
  left: -10px;
  top: -25px;
}

.aqua-sec#world2 .row .column#world2-1:after {
  content: "";
  display: block;
  width: 70px;
  aspect-ratio: 74 / 98;
  background-image: url("../img/sec2_eyecatch01_2.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: auto 100%;
  position: absolute;
  right: 50px;
  top: 25px;
}

.aqua-sec#world2 .row .column#world2-2 > .heading img {
  width: auto;
  height: 129px;
}

.aqua-sec#world2 .row .column#world2-2:before {
  content: "";
  display: block;
  width: 200px;
  aspect-ratio: 182 / 128;
  background-image: url("../img/sec2_eyecatch02.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: 100% auto;
  position: absolute;
  right: -40px;
  top: -45px;
}

.aqua-sec#world2 .row .column#world2-3 > .heading img {
  width: auto;
  height: 91px;
}

.aqua-sec#world2 .row .column#world2-3:before {
  content: "";
  display: block;
  width: 184px;
  aspect-ratio: 184 / 178;
  background-image: url("../img/sec2_eyecatch03.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: 100% auto;
  position: absolute;
  right: -165px;
  bottom: 10px;
}

@media only screen and (max-width: 767px) {
  .aqua-sec#world2 .row {
    display: block;
    margin: 0;
  }
  .aqua-sec#world2 .row .column {
    width: 100%;
    margin: 0 0 15px;
    padding: 25px 16px;
  }
  .aqua-sec#world2 .row .column > .heading {
    margin-bottom: 10px;
  }
  .aqua-sec#world2 .row .column > p {
    font-size: 14px;
    line-height: 1.75em;
  }
  .aqua-sec#world2 .row .column#world2-1 > .heading img {
    width: auto;
    height: 61px;
  }
  .aqua-sec#world2 .row .column#world2-1:before {
    content: "";
    display: block;
    width: 320px;
    aspect-ratio: 226 / 70;
    background-image: url("../img/sec2_eyecatch01.svg");
    background-repeat: no-repeat;
    background-position: 100% auto;
    background-size: auto 100%;
    position: absolute;
    left: -15px;
    top: -15px;
  }
  .aqua-sec#world2 .row .column#world2-1:after {
    content: "";
    display: block;
    width: 37px;
    aspect-ratio: 74 / 98;
    background-image: url("../img/sec2_eyecatch01_2.svg");
    background-repeat: no-repeat;
    background-position: 100% auto;
    background-size: auto 100%;
    position: absolute;
    right: 25px;
    top: 30px;
  }
  .aqua-sec#world2 .row .column#world2-2 > .heading img {
    width: auto;
    height: 86px;
  }
  .aqua-sec#world2 .row .column#world2-2:before {
    content: "";
    display: block;
    width: 100px;
    aspect-ratio: 182 / 128;
    background-image: url("../img/sec2_eyecatch02.svg");
    background-repeat: no-repeat;
    background-position: 100% auto;
    background-size: 100% auto;
    position: absolute;
    right: auto;
    left: 15px;
    top: -15px;
  }
  .aqua-sec#world2 .row .column#world2-3 > .heading img {
    width: auto;
    height: 61px;
  }
  .aqua-sec#world2 .row .column#world2-3:before {
    content: "";
    display: block;
    width: 100px;
    aspect-ratio: 184 / 178;
    background-image: url("../img/sec2_eyecatch03.svg");
    background-repeat: no-repeat;
    background-position: 100% auto;
    background-size: 100% auto;
    position: absolute;
    right: 15px;
    bottom: auto;
    top: -35px;
  }
}

.aqua-sec#world3 > .inner > .heading {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}

.aqua-sec#world3 > .inner > .heading:before {
  content: "";
  display: block;
  width: 368px;
  aspect-ratio: 368 / 90;
  background-image: url("../img/sec3_eyecatch01.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: auto 100%;
  position: absolute;
  right: -428px;
  top: -20px;
}

.aqua-sec#world3 .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.aqua-sec#world3 .row .column {
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  width: 100%;
  background-color: #ffffff;
  border-radius: 20px;
  padding: 40px 36px;
  text-align: center;
  color: #0D3460;
  margin-bottom: 30px;
}

.aqua-sec#world3 .row .column:nth-child(4), .aqua-sec#world3 .row .column:nth-child(5) {
  margin-bottom: 0;
  width: calc(50% -  20px);
}

.aqua-sec#world3 .row .column > .ranking {
  margin-bottom: 15px;
}

.aqua-sec#world3 .row .column > .ranking img {
  width: 84px;
  height: auto;
}

.aqua-sec#world3 .row .column > .heading {
  font-size: 30px;
  line-height: 1.5em;
  font-weight: 500;
  margin-bottom: 10px;
}

.aqua-sec#world3 .row .column > p {
  font-size: 18px;
  line-height: 1.75em;
  font-weight: 500;
}

.aqua-sec#world3 .row .column#world3-2:before {
  content: "";
  display: block;
  width: 126px;
  aspect-ratio: 126 / 236;
  background-image: url("../img/sec3_eyecatch02.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: 100% auto;
  position: absolute;
  left: -20px;
  top: -80px;
}

.aqua-sec#world3 .row .column#world3-3:before {
  content: "";
  display: block;
  width: 220px;
  aspect-ratio: 220 / 182;
  background-image: url("../img/sec3_eyecatch03.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: 100% auto;
  position: absolute;
  right: 36px;
  top: 34p;
}

@media only screen and (max-width: 767px) {
  .aqua-sec#world3 > .inner > .heading {
    position: relative;
    z-index: 3;
  }
  .aqua-sec#world3 > .inner > .heading:before {
    width: 131px;
    aspect-ratio: 368 / 90;
    position: absolute;
    right: -30px;
    top: -35px;
  }
  .aqua-sec#world3 > .inner > .heading:after {
    content: "";
    display: block;
    width: 83px;
    aspect-ratio: 126 / 236;
    background-image: url("../img/sec3_eyecatch02.svg");
    background-repeat: no-repeat;
    background-position: 100% auto;
    background-size: 100% auto;
    position: absolute;
    left: -10px;
    top: 45px;
  }
  .aqua-sec#world3 .row {
    display: block;
  }
  .aqua-sec#world3 .row .column {
    border-radius: 20px;
    padding: 25px 15px;
    margin-bottom: 15px;
  }
  .aqua-sec#world3 .row .column:nth-child(4) {
    margin-bottom: 15px;
    width: 100%;
  }
  .aqua-sec#world3 .row .column:nth-child(5) {
    margin-bottom: 0;
    width: 100%;
  }
  .aqua-sec#world3 .row .column > .ranking {
    margin-bottom: 15px;
  }
  .aqua-sec#world3 .row .column > .ranking img {
    width: 63px;
    height: auto;
  }
  .aqua-sec#world3 .row .column > .heading {
    font-size: 18px;
    line-height: 1.5em;
    margin-bottom: 10px;
  }
  .aqua-sec#world3 .row .column > p {
    font-size: 14px;
    line-height: 1.75em;
  }
  .aqua-sec#world3 .row .column#world3-2:before {
    content: "";
    display: block;
    width: 105px;
    aspect-ratio: 220 / 182;
    background-image: url("../img/sec3_eyecatch03.svg");
    background-repeat: no-repeat;
    background-position: 100% auto;
    background-size: 100% auto;
    position: absolute;
    left: auto;
    right: 15px;
    top: -30px;
  }
  .aqua-sec#world3 .row .column#world3-3:before {
    display: none;
  }
}

.aqua-sec#world4 .row {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  background-color: #ffffff;
  border-radius: 20px;
  padding: 40px 36px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  color: #0D3460;
  font-weight: 500;
  position: relative;
}

.aqua-sec#world4 .row:before {
  content: "";
  display: block;
  width: 200px;
  aspect-ratio: 180 / 222;
  background-image: url("../img/sec4_eyecatch01.svg");
  background-repeat: no-repeat;
  background-position: 100% auto;
  background-size: 100% auto;
  position: absolute;
  right: -40px;
  top: -50px;
}

.aqua-sec#world4 .row .column {
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 630px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 30px;
}

.aqua-sec#world4 .row .column:nth-last-child(1) {
  margin-bottom: 0;
}

.aqua-sec#world4 .row .column > .heading {
  width: 100%;
  font-size: 30px;
  line-height: 1.5em;
  font-weight: 500;
  margin-bottom: 30px;
}

.aqua-sec#world4 .row .column > .image {
  width: 240px;
}

.aqua-sec#world4 .row .column > .image img {
  width: 100%;
  height: auto;
}

.aqua-sec#world4 .row .column > .data {
  text-align: left;
  font-size: 22px;
  line-height: 2.0em;
}

.aqua-sec#world4 .row .column > .data p {
  margin-bottom: 1.0em;
}

.aqua-sec#world4 .row .column > .data p:nth-last-child(1) {
  font-size: 18px;
  line-height: 1.5em;
}

@media only screen and (max-width: 767px) {
  .aqua-sec#world4 > .inner > .heading {
    text-align: center;
    margin-bottom: 25px;
  }
  .aqua-sec#world4 > .inner > .heading img {
    width: 100%;
    max-width: 345px;
    height: auto;
  }
  .aqua-sec#world4 .row {
    border-radius: 20px;
    padding: 25px;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }
  .aqua-sec#world4 .row:before {
    content: "";
    display: block;
    width: 100px;
    aspect-ratio: 180 / 222;
    right: 15px;
    top: 75px;
    z-index: 10;
  }
  .aqua-sec#world4 .row .column {
    width: 100%;
    display: block;
    margin-bottom: 0;
  }
  .aqua-sec#world4 .row .column > .heading {
    width: 100%;
    font-size: 18px;
    line-height: 1.5em;
    margin-bottom: 24px;
  }
  .aqua-sec#world4 .row .column > .image {
    width: 190px;
    margin: 0 auto 5px;
  }
  .aqua-sec#world4 .row .column > .image img {
    width: 100%;
    height: auto;
  }
  .aqua-sec#world4 .row .column > .data {
    text-align: center;
    font-size: 14px;
    line-height: 2.0em;
  }
  .aqua-sec#world4 .row .column > .data p {
    margin-bottom: 1.0em;
  }
  .aqua-sec#world4 .row .column > .data p:nth-last-child(1) {
    font-size: 12px;
    line-height: 1.5em;
  }
}

.bg-green1 {
  background-color: #00B37E !important;
}

.bg-orange1 {
  background-color: #F08835 !important;
}

.bg-red1 {
  background-color: #E84447 !important;
}

.bg-purple1 {
  background-color: #6558A4 !important;
}

.bg-yellow1 {
  background-color: #FAC03A !important;
}

.bg-red2 {
  background-color: #E84447 !important;
}

.bg-green2 {
  background-color: #00B37E !important;
}

.bg-yellow2 {
  background-color: #FAC03A !important;
}

.cta-sec {
  border: 30px solid #F1EB02;
  padding: 0 20px;
  overflow: hidden;
}

.cta-sec > .inner {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 1000px;
  padding: 90px 0;
  margin: 0 auto;
}

@media only screen and (max-width: 767px) {
  .cta-sec {
    border-width: 20px;
    padding: 0 12px;
  }
  .cta-sec > .inner {
    padding: 45px 0;
    margin: 0 auto;
  }
}

.cta-sec .head {
  position: relative;
  color: #0D3460;
  max-width: 100%;
  min-width: 600px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  margin-bottom: 80px;
}

.cta-sec .head > .heading {
  position: relative;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 462px;
  min-height: 90px;
  padding: 5px 10px;
  background-color: #0D3460;
  border-radius: 10px;
  color: #ffffff;
  font-size: 32px;
  line-height: 1.25em;
  font-weight: 500;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  text-align: center;
  margin: 0 auto 42px;
}

.cta-sec .head > .heading:after {
  content: "";
  display: block;
  width: 58px;
  height: 35px;
  background-image: url("../img/arw01.svg");
  background-repeat: no-repeat;
  background-position: 50% 100%;
  background-size: 100% auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -20px;
  margin: 0 auto;
}

.cta-sec .head > .catch {
  font-size: 48px;
  line-height: 1.5em;
  font-weight: 500;
  text-align: center;
  margin-bottom: 80px;
}

.cta-sec .head .eyecatch1 {
  width: 407px;
  height: 365px;
  position: absolute;
  left: -407px;
  top: 0px;
}

.cta-sec .head .eyecatch1 img {
  width: 100%;
  height: auto;
}

.cta-sec .head .eyecatch2 {
  width: 413px;
  height: 369px;
  position: absolute;
  right: -413px;
  top: 0px;
}

.cta-sec .head .eyecatch2 img {
  width: 100%;
  height: auto;
}

@media only screen and (max-width: 767px) {
  .cta-sec .head {
    min-width: 0;
    margin-bottom: 40px;
  }
  .cta-sec .head > .heading {
    max-width: 282px;
    min-height: 54px;
    padding: 15px 25px;
    background-color: #0D3460;
    border-radius: 12px;
    color: #ffffff;
    font-size: 18px;
    line-height: 1.25em;
    font-weight: 500;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    text-align: center;
    margin: 0 auto 25px;
  }
  .cta-sec .head > .heading:after {
    content: "";
    display: block;
    width: 29px;
    height: 18px;
    position: absolute;
    left: 0;
    right: 0;
    bottom: -10px;
    margin: 0 auto;
  }
  .cta-sec .head > .catch {
    font-size: 27px;
    line-height: 1.25em;
    margin-bottom: 10px;
  }
  .cta-sec .head .eyecatch1,
  .cta-sec .head .eyecatch2 {
    display: none;
  }
}

.cta-sec .event {
  max-width: 1000px;
  margin: 0 auto 70px;
}

.cta-sec .event > .heading {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-radius: 50px;
  background-color: #F1EB02;
  color: #0D3460;
  text-align: center;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  padding: 10px 10px;
  max-height: 64px;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  font-size: 48px;
  line-height: 1.25em;
  font-weight: 500;
  margin-bottom: 28px;
}

.cta-sec .event > .lead {
  text-align: center;
  font-size: 24px;
  line-height: 1.75em;
  font-weight: 500;
  color: #0D3460;
  margin-bottom: 50px;
}

.cta-sec .event > .lead > span {
  font-weight: 900;
}

.cta-sec .event .image01 {
  text-align: center;
}

.cta-sec .event .image01 img {
  width: 100%;
  height: auto;
}

.cta-sec .event .image02 {
  text-align: center;
  margin-bottom: 55px;
}

.cta-sec .event .image02 img {
  max-width: 750px;
}

.cta-sec .event .image03 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.cta-sec .event .image03 img {
  width: calc(50% - 10px);
  height: auto;
  -o-object-fit: cover;
  object-fit: cover;
}

@media only screen and (max-width: 767px) {
  .cta-sec .event {
    margin-bottom: 40px;
  }
  .cta-sec .event:nth-last-child(1) {
    margin-bottom: 0;
  }
  .cta-sec .event > .heading {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 5px 10px;
    min-height: 32px;
    max-height: none;
    font-size: 22px;
    line-height: 1.25em;
    margin-bottom: 12px;
  }
  .cta-sec .event > .lead {
    font-size: 14px;
    line-height: 1.75em;
    margin-bottom: 20px;
  }
  .cta-sec .event .image01 {
    text-align: center;
  }
  .cta-sec .event .image01 img {
    width: 100%;
    height: auto;
  }
  .cta-sec .event .image02 {
    text-align: center;
    margin-bottom: 25px;
  }
  .cta-sec .event .image02 img {
    max-width: 310px;
  }
  .cta-sec .event .image03 {
    display: block;
  }
  .cta-sec .event .image03 img {
    display: block;
    width: 100%;
    max-width: 315px;
    height: auto;
    margin: 0 auto;
    -o-object-fit: cover;
    object-fit: cover;
    margin-bottom: 15px;
  }
  .cta-sec .event .image03 img:nth-last-child(1) {
    margin-bottom: 0;
  }
}

.cta-sec .cta-box {
  position: relative;
  margin-left: -20px;
  margin-right: -20px;
  background: -webkit-gradient(linear, left top, left bottom, from(#fffee1), to(#fffc97));
  background: -webkit-linear-gradient(top, #fffee1 0%, #fffc97 100%);
  background: linear-gradient(180deg, #fffee1 0%, #fffc97 100%);
  padding: 90px 0 130px;
}

.cta-sec .cta-box:before {
  content: "";
  display: block;
  width: 1372px;
  height: 213px;
  background-image: url("../img/about5_cta_bg01.png.webp");
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: 100% auto;
  position: absolute;
  left: 81px;
  bottom: 150px;
  z-index: 1;
}

.cta-sec .cta-box > .heading {
  position: relative;
  z-index: 2;
  text-align: center;
  margin-bottom: 10px;
}

.cta-sec .cta-box > .heading img {
  width: 100%;
  height: auto;
}

.cta-sec .cta-box > .image {
  position: relative;
  z-index: 2;
  text-align: center;
}

.cta-sec .cta-box > .image img {
  max-width: 930px;
  width: 100%;
  height: auto;
}

.cta-sec .cta-box > .button {
  position: relative;
  z-index: 1;
  text-align: center;
  margin-top: 50px;
}

@media only screen and (max-width: 767px) {
  .cta-sec .cta-box {
    margin-left: -12px;
    margin-right: -12px;
    padding: 0 0 120px;
  }
  .cta-sec .cta-box:before {
    display: none;
  }
  .cta-sec .cta-box > .heading {
    position: relative;
    z-index: 2;
    text-align: center;
    margin-bottom: 25px;
  }
  .cta-sec .cta-box > .heading img {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    border-right: 20px solid transparent;
    max-width: 335px;
    height: auto;
  }
  .cta-sec .cta-box > .image {
    position: relative;
    z-index: 2;
    text-align: center;
  }
  .cta-sec .cta-box > .image img {
    max-width: 286px;
    width: 100%;
    height: auto;
  }
  .cta-sec .cta-box > .button {
    position: relative;
    z-index: 1;
    text-align: center;
    margin-top: 25px;
    padding: 0 20px;
  }
}

#line-banner {
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  width: 213px;
  position: fixed;
  right: -200px;
  bottom: 40px;
  z-index: 999;
  visibility: hidden;
  opacity: 0;
}

#line-banner img {
  width: 100%;
  height: auto;
}

#line-banner.show {
  right: 20px;
  opacity: 1.0;
  visibility: visible;
}

@media only screen and (max-width: 767px) {
  #line-banner {
    max-width: 335px;
    width: 100%;
    right: 0;
    left: 0;
    bottom: -100px;
    margin: 0 auto;
  }
  #line-banner.show {
    left: 0;
    right: 0;
    bottom: 0;
    opacity: 1.0;
    visibility: visible;
  }
}

/* # =================================================================
#	フッター
# ================================================================= */
/* # =================================================================
#	印刷用
# ================================================================= */
@media print {
  #head {
    position: absolute;
  }
  .recruit-nav {
    position: absolute;
  }
}

/*# sourceMappingURL=common.css.map */
