@charset "UTF-8";
/*!
 * ress.css • v1.2.2
 * MIT License
 * github.com/filipelinhares/ress
 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow-y: scroll;
  /* iOS 8+ */
}

*,
::before,
::after {
  background-repeat: no-repeat;
  /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  -webkit-box-sizing: inherit;
  box-sizing: inherit;
}

::before,
::after {
  text-decoration: inherit;
  /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit;
}

* {
  /* Reset `padding` and `margin` of all elements */
  margin: 0;
  padding: 0;
}

/* # =================================================================
   # General elements
   # ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
  display: none;
  height: 0;
}

hr {
  overflow: visible;
  /* Show the overflow in Edge and IE */
}

/*
* Correct `block` display not defined for any HTML5 element in IE 8/9
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox
* Correct `block` display not defined for `main` in IE 11
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block;
}

summary {
  display: list-item;
  /* Add the correct display in all browsers */
}

small {
  font-size: 80%;
  /* Set font-size to 80% in `small` elements */
}

[hidden],
template {
  display: none;
  /* Add the correct display in IE */
}

abbr[title] {
  border-bottom: 1px dotted;
  /* Add a bordered underline effect in all browsers */
  text-decoration: none;
  /* Remove text decoration in Firefox 40+ */
}

a {
  /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects;
  background-color: transparent;
  /* Remove gaps in links underline in iOS 8+ and Safari 8+ */
}

a:active,
a:hover {
  outline-width: 0;
  /* Remove the outline when hovering in all browsers */
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* Specify the font family of code elements */
}

b,
strong {
  font-weight: bolder;
  /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */
}

dfn {
  font-style: italic;
  /* Address styling not present in Safari and Chrome */
}

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000;
}

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/* # =================================================================
   # Forms
   # ================================================================= */
input {
  border-radius: 0;
}

/* Apply cursor pointer to button elements */
button,
[type="button"],
[type="reset"],
[type="submit"],
[role="button"] {
  cursor: pointer;
}

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default;
}

[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 */
}

[type="search"] {
  -webkit-appearance: textfield;
  /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px;
  /* Correct the outline style in Safari */
}

/* # =================================================================
   # Specify media element style
   # ================================================================= */
img {
  border-style: none;
  /* Remove border when inside `a` element in IE 8/9/10 */
}

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline;
}

svg:not(:root) {
  overflow: hidden;
  /* Internet Explorer 11- */
}

audio,
canvas,
progress,
video {
  display: inline-block;
  /* Internet Explorer 11+, Windows Phone 8.1+ */
}

/* # =================================================================
   # Accessibility
   # ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~="screen"] {
    display: inherit;
  }
  [hidden~="screen"]:not(:active):not(:focus):not(:target) {
    clip: rect(0 0 0 0) !important;
    position: absolute !important;
  }
}

/* Specify the progress cursor of updating elements */
[aria-busy="true"] {
  cursor: progress;
}

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer;
}

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default;
}

/* # =================================================================
   # Selection
   # ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

::selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none;
}

/* default setting */
body {
  -webkit-text-size-adjust: 100%;
  background-color: #ffffff;
  color: #4a4a4a;
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
  font-size: 18px;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.30769;
}

a {
  color: #148df0;
  text-decoration: underline;
}

a:hover {
  text-decoration: none;
}

ol, ul, dl {
  list-style: none;
}

em, i {
  font-style: normal;
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 500;
}

/* iOS Form */
input[type="submit"],
input[type="button"],
button {
  -webkit-appearance: button;
  -webkit-box-sizing: content-box;
  -moz-appearance: button;
  appearance: button;
  border: none;
  border-radius: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration,
button::-webkit-search-decoration {
  display: none;
}

input[type="input"],
input[type="text"],
input[type="email"],
input[type="number"],
input[type="search"] {
  -webkit-appearance: input;
  -webkit-box-sizing: content-box;
  -moz-appearance: input;
  appearance: input;
  background-color: #fff;
  border: 1px solid #222;
  border-radius: 0;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  font-size: 16px;
  line-height: normal;
  padding: 3px 8px;
  -webkit-transition: 200ms;
  transition: 200ms;
  width: 100%;
}

input[type="input"]::-webkit-search-decoration,
input[type="text"]::-webkit-search-decoration,
input[type="email"]::-webkit-search-decoration,
input[type="number"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-decoration {
  display: none;
}

input[type="input"]:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="search"]:focus {
  background-color: #fff;
  border: 1px solid #0d0d0d;
}

@media print, screen and (min-width: 768px) {
  input[type="input"],
  input[type="text"],
  input[type="email"],
  input[type="number"],
  input[type="search"] {
    font-size: 18px;
    padding: 5px 10px;
  }
}

input[type="input"].error,
input[type="text"].error,
input[type="email"].error,
input[type="number"].error,
input[type="search"].error {
  background-color: #fee;
  border-color: #b40019;
}

textarea {
  background-color: #fff;
  border: 1px solid #222;
  font-size: 16px;
  height: 10em;
  padding: 3px 8px;
  -webkit-transition: 200ms;
  transition: 200ms;
  width: 100%;
}

@media print, screen and (min-width: 769px) {
  textarea {
    font-size: 18px;
    padding: 5px 10px;
  }
}

textarea.error {
  border-color: #b40019;
}

/* placeholder */
input::-webkit-input-placeholder {
  color: #ccc;
}
input::-moz-placeholder {
  color: #ccc;
}
input:-ms-input-placeholder {
  color: #ccc;
}
input::-ms-input-placeholder {
  color: #ccc;
}
input::placeholder {
  color: #ccc;
}

/* placeholder fot IE */
input:-ms-input-placeholder {
  color: #ccc;
}

/* placeholder for Edge */
input::-ms-input-placeholder {
  color: #ccc;
}

.Deco {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #fff799));
  background: linear-gradient(transparent 60%, #fff799 60%);
  background-position:center center;
}

/* SP style */
@media print, screen and (max-width: 768px) {
  img {
    height: auto;
    vertical-align: top;
    width: 100%;
  }
  .pc {
    display: none;
  }
  html {
    font-size: 14px;
  }
}

/* PC style */
@media print, screen and (min-width: 769px) {
  img {
    height: auto;
    vertical-align: top;
    width: 100%;
  }
  .sp {
    display: none;
  }
  html {
    font-size: 16px;
  }
}

.green { color:#8bbca5; }
.azuki { color:#ac8993; }
.pink { color:#ed8c91; }
.pink2 { color:#ff556a; }
.enji { color:#da808d; }

/* layouts */
/* # =============================================
   # LayoutSingle
   # ============================================= */
.LayoutSingle__inner { padding: 0 1.86667vw; }

@media print,
screen and (min-width: 769px) {
  .LayoutSingle { padding: 0 50px; }

  .LayoutSingle__inner {
    margin: 0 auto;
    max-width: 1000px;
    padding: 0;
    width: 100%;
  }
}

/*---------- fv ----------*/
.fv {
	width:100%;
  padding-bottom: 4vw;
  background-image: url("../images/fv_bg.png");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
}

@media print, screen and (max-width: 768px) {
  .fv {
  padding-bottom: 8vw;
  background-image: url("../images/fv_bg_sp.png");
  background-position: center top;
  background-repeat: no-repeat;
  background-size: cover;
  }
}

.fv .fv__cta {
	width:100%;
	max-width: 940px;
	margin: 45px auto 0;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.fv .fv__cta form {
	width:48.936170212%;
}

.fv .fv__cta figure {
	width:80.533333333%;
	max-width: 604px;
	margin:0 auto;
}

.fv .fv__cta button.btn01 {
	background: url("../images/cta_btn01_over.png") left top 20px no-repeat;
	background-size: 100%;
}

.fv .fv__cta button.btn02 {
	background: url("../images/cta_btn02_over.png") left top 20px no-repeat;
	background-size: 100%;
}

.fv .fv__cta button img:hover {
	opacity: 0;
	transition: ease 0.7s;
}

.fv__cta img { margin: 20px 0 0 0; }

@media print, screen and (min-width: 769px) and (max-width: 1500px) {
	.fv .fv__cta { font-size:2vw; width:62.666666666%;}
	.fv .fv__cta figure { width:60.4%; }
	.fv .fv__cta button.btn01 {
		background: url("../images/cta_btn01_over.png") left top 2vw no-repeat;
		background-size: 100%;
	}
	.fv .fv__cta button.btn02 {
		background: url("../images/cta_btn02_over.png") left top 2vw no-repeat;
		background-size: 100%;
	}
	.fv__cta img { margin: 2vw 0 0 0; }
}

@media print, screen and (max-width: 768px) {
	.fv .fv__cta {
		width:100%;
		margin: 4vw auto 0;
		font-size:2.995vw;
		display: block;
	}
	.fv .fv__cta form {	width:59.895833333%; margin:0 auto; }
	.fv .fv__cta button.btn01,
	.fv .fv__cta button.btn02 { background: none; }
	.fv .fv__cta button img:hover { opacity: 1;	}
	.fv__cta img { margin: 2.604vw 0 0 0; }
}

/*---------- banner ----------*/
.banner {
	width: 100%;
  margin: 55px auto 0;
  overflow: hidden;
}

.banner_inner {
	width:100%;
	max-width: 800px;
	margin:0 auto;
}

@media print, screen and (min-width: 769px) and (max-width: 1100px) {
	.banner_inner {
		width:96%;
	}
}

.banner figure {
  display: block;
  width: 100％;
  max-width: 800px;
  margin:0 auto;
}

@media print, screen and (max-width: 768px) {
  .banner { bottom:4%; margin: 6vw auto 0;}

	.banner_inner {
		width:93.75%;
		max-width: 720px;
		margin:0 auto;
	}

  .banner figure {
  	width:93.75%;
    max-width: 720px;
  	margin:0 auto;
  }
}

/*---------- cta ----------*/
.cta {
	width:100%;
	max-width: 940px;
	margin: 0 auto;
	padding:45px 0 60px;
	text-align: center;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.cta form {
	width:48.936170212%;
}

.cta figure {
	width:100%;
	max-width: 604px;
	margin:0 auto;
}

.cta button.btn01 {
	background: url("../images/cta_btn01_over.png") left top 20px no-repeat;
	background-size: 100%;
}

.cta button.btn02 {
	background: url("../images/cta_btn02_over.png") left top 20px no-repeat;
	background-size: 100%;
}

.cta button img:hover {
	opacity: 0;
	transition: ease 0.7s;
}

.cta img { margin: 20px 0 0 0; }

@media print, screen and (max-width: 768px) {
	.cta {
		width:87.23958%;
		padding:5vw 0 7.813vw;
		display:block;
	}
	.cta form {	width:76.158940397%; margin:0 auto; }
	.cta button.btn01,
	.cta button.btn02 { background: none; }
	.cta button.btn01 img:hover,
	.cta button.btn02 img:hover { opacity: 1; }
	.cta img { margin: 2.604vw 0 0 0; }
}

/*---------- sv ----------*/
.sv {
	width:100%;
	padding-top:60px;
	max-width: 1000px;
	margin:0 auto 60px;
}

.sv h2 {
	width:60.6%;
	margin:0 auto;
}

.sv figure.mobile {
	width:81.4%;
	margin:0 auto;
}

.sv .sv_text {
	font-size:36px;
	font-weight:700;
	text-align: center;
	padding:40px 0;
	line-height: 1.5;
}

.sv .sv_text span {
	font-size:48px;
	color:#ed707f;
	letter-spacing: -.8px;
}

.sv_under {
	width:100%;
	background: url("../images/sv_bg.png") center top repeat;
	padding:60px 0;
}

.sv_box {
	width:100%;
	max-width: 1000px;
	margin:0 auto;
	border:5px solid #eca6aa;
	background:#fff;
	border-radius: 20px;
}

figure.merit { 
	position:relative;
	font-size:30px;
	font-weight:700;
	letter-spacing: -.8px;
	padding-bottom:30px;
}

.merit01 {
	position:absolute;
	top:140px;
	left:75px;
	width:42.42424242424%;
	text-align: center;
}

.merit01 .merit01_atten { 
	font-size:16px;
	font-weight: 400;
	line-height: 1.4;
	display:block;
	padding-top:10px;
}

.merit02 {
	position:absolute;
	top:140px;
	right:130px;
	width:28.28282828282%;
	text-align: center;
}

.merit03 {
	position:absolute;
	bottom:60px;
	left:30px;
	width:48%;
	text-align: center;
}
.merit_text { font-size:18px; }

.merit04 {
	position:absolute;
	bottom:60px;
	right:120px;
	width:30.303030303%;
	text-align: center;
}

@media print, screen and (min-width: 769px) and (max-width: 1000px) {
	.sv .sv_text { font-size:3.6vw; }
	.sv .sv_text span {	font-size:4.8vw; }
	figure.merit { font-size:3vw; }

	.merit01 {
		top:13vw;
		left:6.5vw;
	}
	.merit01 .merit01_atten { font-size:14px; }

	.merit02 {
		top:13vw;
		right:13vw;
	}

	.merit03 {
		bottom:6.5vw;
		left:3vw;
	}

	.merit04 {
		bottom:6.5vw;
		right:12vw;
	}
}

@media print, screen and (max-width: 768px) {
	.sv {
		width:100%;
		padding-top:7.161vw;
		max-width: 768px;
		margin:0 auto 7.161vw;
	}
	.sv_box { width:89.333333333%; }
	.sv h2 { width:98%; }
	.sv figure.mobile { width:98%; }

	.sv .sv_text {
		font-size:4.2vw;
		padding:5.208vw 0;
	}
	.sv .sv_text span {	font-size:5.2vw; }
	.sv_under { padding:7.161vw 0; }
	figure.merit { font-size:5.067vw; padding-bottom:3.906vw; }

	.merit01 {
		top:0;
		left:21.5%;
		width:77%;
		text-align: left;
	}
	
	.merit01 .merit01_atten { 
		font-size:3.3vw;
		padding-top:1.309vw;
	}

	.merit02 {
		top:calc(260 / 768 * 100vw);
		right:3.5%;
		width:75%;
		text-align: left;
	}

	.merit03 {
		top:calc(400 / 768 * 100vw);
		left:21.5%;
		width:75%;
		text-align: left;
	}
	.merit_text { font-size:3.125vw; }

	.merit04 {
		top:calc(570 / 768 * 100vw);
		right:3.5%;
		width:75%;
		text-align: left;
	}
}

/*---------- d_ponta_area ----------*/
.d_ponta_area {
	width:100%;
	max-width: 1000px;
	margin:0 auto;
}

/*---------- dpoint ----------*/
.dpoint_area h2 {
	width:100%;
	max-width: 1000px;
	margin:-80px auto 40px;
}

.dpoint_area_bg {
	background: url("../images/dpoint_bg.png") center top no-repeat;
	background-size: 100%;
}

.dpoint_area_inner {
	width:100%;
	max-width: 1000px;
	margin:0 auto;
	text-align: left;
	font-size:16px;
}
.dpoint_area_inner img { margin:0 auto 40px; }
.dpoint_img01 { width:100%; max-width: 862px; margin: 60px auto 0; }

@media print, screen and (min-width: 769px) and (max-width: 1000px) {
	.dpoint_area h2 {
		width:100%;
		margin:-8vw auto 4vw;
	}
    .dpoint_area_inner { width:94%; }
	.dpoint_img01 { width:80%; }
}

@media print, screen and (max-width: 768px) {
	.dpoint_area {
		background: none;
		padding-top:0;
		margin-top:0;
	}

	.dpoint_area_bg { background: none; }
	.dpoint_area_inner { max-width: 728px; width:94%; font-size:3.3vw; }
    .dpoint_area_inner img { margin:0 auto 3.906vw; }
    
	.dpoint_area h2 {
		width:100%;
		margin:-6.667vw auto 0;
	}

	.dpoint_img01 { width:100%; margin: 0; }
}

/*---------- Point Sec1 ----------*/
.Sec1 {
  background-color: #ffffd9;
  padding: 0 0 13%;
}

.Sec1 .Sec1__points {
  background-color: #fff;
  border: 1.33333vw solid #60ceaf;
  padding: 8% 0 0;
}

.Sec1 .Sec1__pointsTitle {
  margin: 0 auto 9%;
  width: 100%;
}

@media print,
screen and (min-width: 769px) {
  .Sec1 { padding: 95px 50px 150px; }
}

@media print,
screen and (min-width: 769px) and (max-width: 1100px) {
  .Sec1 { padding: 8.63636vw 50px 13.63636vw; }
}

@media print,
screen and (min-width: 769px) {
  .Sec1 .Sec1__points {
    border: 20px solid #60ceaf;
    padding: 6.2% 0 0;
  }

  .Sec1 .Sec1__pointsTitle {
    margin: 0 auto 8%;
    width: 90.9%;
  }
}

/*---------- Point1 ----------*/
.Point .Point__item { padding: 0 3.2% 0.5%; }
.Point .Point__item:first-of-type { padding: 0 3.2% 3vw; }

.Point__text {
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-size: 5.067vw;
  font-weight: 700;
  line-height: 1.4;
  padding:5% 0 3% 25%;
  background: url("../images/point_img1_pc.png") left 3.4% center no-repeat;
  background-size: 18.522727272%;
  letter-spacing: -.5px;
  margin-top:5.333vw;
  margin-bottom: 4vw;
}

.Point .Point__1wrap {
  margin: 0;
  padding: 0 0 1.5%;
  position: relative;
}

.Point .Point__1figure {
  margin: 3% auto 2%;
  width: 90%;
}

.Point .Point__1figure2 {
  position: absolute;
  bottom: 10vw;
  left: 9%;
  width: 82%;
}

.Point .Point__1text {
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-size: 3.3vw;
  font-weight: 600;
  letter-spacing: -0.03em;
  text-align: center;
  line-height: 1.4;
  position: absolute;
  top: 25vw;
  left: 50%;
  transform: translateX(-50%);
  -webkit- transform: translateX(-50%);
  width: 75%
}

.Point .Point__1text span {
  display: block;
  padding-top: 4%;
}

@media print,
screen and (min-width: 769px) {
  .Point .Point__item {
    padding: 0 40px;
  }
	
  .Point__text {
    font-size: 50px;
	padding:5% 0 3% 25%;
	background: url("../images/point_img1_pc.png") left 3.4% center no-repeat;
	background-size: 18.522727272%;
	margin-top:40px;
  }
	
  .Point .Point__1wrap { margin: 7% 4% 0; }
  .Point .Point__1wrap:last-of-type { margin: 0 4% 7%; }
	
  .Point .Point__1figure {
    margin: 4% auto 2%;
    width: 100%;
  }
	
  .Point .Point__1figure2 {
    position: absolute;
    bottom: 15%;
    left: 3%;
    width: 94%;
  }
	
  .Point .Point__1text {
    font-size: 24px;
    top: 245px;
    left: 0;
    transform: translateX(0);
    -webkit- transform: translateX(0);
    width: 100%;
  }

  .Point .Point__1text span {
    display: block;
    padding-top: 0;
  }
}

@media print,
screen and (min-width: 769px) and (max-width: 1100px) {
  .Point .Point__item { padding: 0 3.636vw 0.5vw; }
  .Point__text { font-size: 4.3vw; }
	
  .Point .Point__1text {
    top: 55%;
    font-size: 2vw;
  }

  .Point .Point__1text.first { top: 38%; }
}

/*---------- Point2 ----------*/
.Point .Point__item2 { padding: 10% 3.2% 0; }

.Point .Point__2text {
  color: #454545;
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-size: 5.6vw;
  font-weight: 700;
  letter-spacing: 0.07em;
  letter-spacing: 0;
  line-height: 1.6;
  margin: 4% auto 0;
  text-align: center;
  position: relative;
  width:100%;
}

.Point .Point__2text3 {
  text-align: center;
  font-size:5.067vw;
  font-weight:700;
}
.Point .Point__2text3 span { font-size:3.125vw; }

.Point .Point__2text2Inner::after,
.Point .Point__2text2Inner::before {
  background-image: url("../images/text_bg.svg");
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.Point .Point__2text2Inner::after {
  -webkit-transform: translateY(-50%) rotateY(180deg);
  transform: translateY(-50%) rotateY(180deg);
}

.Point .Point__2text2Inner::after,
.Point .Point__2text2Inner::before {
  height: 9.866666666666667vw;
  width: 2vw;
}

.Point .Point__2text2Inner::after { right: 8.5%; }
.Point .Point__2text2Inner::before { left: 8.5%; }

.Point .Point__2text2 {
  font-size: 6.667vw;
  color: #fb5669;
}

.Point .Point__2figure {
  margin: 5% auto 12%;
  width: 100%;
}

@media print,
screen and (min-width: 769px) {
  .Point .Point__item2 { padding: 70px 40px 0; }
	
  .Point .Point__2text {
    font-size: 38px;
    margin: 5% auto 3%;
    width: 62%;
  }
  .Point .Point__2text3 { font-size:38px; }
  .Point .Point__2text3 span { font-size:30px; }
	
  .Point .Point__2text2Inner::after,
  .Point .Point__2text2Inner::before {
    height: 83px;
    width: 16px;
    top: 67%;
  }

  .Point .Point__2text2Inner::after { right: 1%; }
  .Point .Point__2text2Inner::before { left: 1%; }
  .Point .Point__2text2 { font-size: 50px; }
	
  .Point .Point__2figure {
    margin: 8% auto 100px;
    width: 100%;
  }
}

@media print,
screen and (min-width: 769px) and (max-width: 1100px) {
  .Point .Point__2text { font-size: 3.2vw; width:62%; }

  .Point .Point__2text2Inner::after,
  .Point .Point__2text2Inner::before {
    height: 7.54545vw;
  }

  .Point .Point__2text2 { font-size: 4.6vw; }
  .Point .Point__2text3 span { font-size:24px; }
}

/*---------- Point3 ----------*/
.Point .credit_text {
  font-size:32px;
  text-align: center;
  padding-top:60px;
}

.Point .credit__figure1 {
  width:92.5%;
  margin:80px auto 0;
  position: relative;
}

.Point .credit__box1 {
	border:4px solid #8abca5;
	box-sizing: border-box;
}

.Point .credit__box2 {
	border:4px solid #8abca5;
	border-top:none;
    border-radius:0px 0px 10px 10px ;
    -webkit-border-radius:0px 0px 10px 10px ;
    -moz-border-radius:0px 0px 10px 10px ;
	box-sizing: border-box;
	padding: 30px 15px;
}

.Point .credit__text { 
	padding-top:30px;
}

.Point .credit__text p { 
	font-size:16px;
	padding-left: 1rem;
	text-indent: -1rem;
}

.Point .credit__text p.last { 
	padding-left: 0;
	text-indent: 0;
	padding-top:30px;
}

.Point .credit__text4 { 
  font-size:52px;
  text-align: center;
  font-weight:700; 
  margin-top:5%;
}

.Point .credit__text4 span { font-size:60px; }

.Point .credit__figure3 {
  width:29.545454545%;
  margin:40px auto 80px;
}

.credit__text5 {
  font-size:16px;
  width:92.5%;
  margin:10px auto 60px;
}

@media print,
screen and (max-width: 768px) {
  .Point .credit_text {
    font-size:4.948vw;
    padding-top:7.813vw;
  }

  .Point .credit__figure1 {
	width:87.878787878%;
	margin:7.813vw auto 0;
  }

  .Point .credit__box2 {
	padding: 3.906vw 1.953vw;
  }

  .Point .credit__text { 
	padding-top:3.906vw;
  }

  .Point .credit__text p { 
	font-size: 2.474vw;
	padding-left: 0.7rem;
	text-indent: -0.7rem;
  }

  .Point .credit__text p.last { 
	padding-top:3.906vw;
  }	

  .Point .credit__text4 { 
	font-size:5.733vw;
	margin-top:8%;
  }

  .Point .credit__text4 span { font-size:6.667vw; }

  .Point .credit__figure3 {
    width:46.153846153%;
    margin:5.333vw auto 10.667vw;
  }

  .credit__text5 {
    font-size:2.474vw;
    width:87.878787878%;
    margin:1.309vw auto 7.813vw;
  }
}

@media print,
screen and (min-width: 769px) and (max-width: 1100px) {
  .Point .credit__text4 { font-size:4.727vw; }
  .Point .credit__text4 span { font-size:5.455vw; }
}

/*---------- 大和コネクト証券の特長 ----------*/
.About {
  background: url("../images/about_connect.png") left top repeat;
  padding-bottom: 15%;
}

.About h2 {
  width: 100%;
  margin: 0 auto 8%;
}
	
.About_aBox {
  width:80%;
  max-width: 600px;
  margin:0 auto;
}

.About_aBox div {
  width:100%;
  max-width: 600px;
  border-radius: 20px;
  text-align: center;
  font-size:3.733vw;
  box-sizing: border-box;
  padding:4% 0 4%;
  background: #fff;	
  letter-spacing: -.5px;
  box-shadow: 0px 0px 15px -5px #777777;
}

.About_aBox div.first { border:4px solid #8abba4; }

.About_aBox div.second {
  border:4px solid #ac8892;
  margin-top:8%;
}

.About_aBox div.third {
  border:4px solid #f6bdc1;
  margin-top:8%;
}

.About_aBox div.four {
  border: 4px solid #da808e;
  margin-top: 8%;
}

.About_aBox div.four p.text2 {
	font-size: 3vw;
	margin-inline: 2%;
	text-align: left;
}

.About_aBox div.four span.text1 {
  display:block;
  font-size:2.214vw;  
  text-align: left;
  margin:0 2%;
  padding-left:0.7rem;
  text-indent: -0.7rem;
}

@media print,
screen and (min-width: 769px) {
  .About {
    padding-top:6%;
	padding-bottom: 6%;
  }
	
  .About h2 {
    width: 91%;
    margin: 0 auto 80px;
  }
	
  .About_aBox {
	width:85%;
	max-width: 850px;
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
  }

  .About_aBox div {
	width:47.058823529%;
	padding:3% 0;
	max-width: 400px;
	font-size:20px;
  }

  .About_aBox div.first {
	border:8px solid #8abba4;
  }

  .About_aBox div.second {
    margin-top:0;
	border:8px solid #ac8892;
  }

  .About_aBox div.third {
	border:8px solid #f6bdc1;
    margin-top:5%;
  }
	
  .About_aBox div.four {
	border:8px solid #da808e;
	margin-top:5%;
  }

  .About_aBox div.four p.text2 {
	font-size: 16px;
	margin-inline: 1rem;
  }

  .About_aBox div.four span.text1 {
	font-size:12px;  
    padding-top:8px;
    padding-left:1rem;
	text-indent: -1rem;
	margin:0 1rem;
  }
}

@media print,
screen and (min-width: 769px) and (max-width: 1100px) {
  .About h2 { margin: 0 auto 7.273vw; }
  .About_aBox div {	font-size:1.818vw; }
}

/*---------- STEP ----------*/
.Sec2 {
  background: #d7f2e2;
  padding: 11% 0 0;
  margin:0 0 2.5%;
}

.Step .Step__title {
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-weight: 600;
  letter-spacing: 0.07em;
  letter-spacing: -0.05em;
  text-align: center;
}

.Step .Step__title {
  font-size: 5.33333vw;
  margin: 0 0 3%;
}

.Step .Step__titleText {
  display: inline-block;
  font-size: 6.4vw;
  position: relative;
  padding-bottom: 3%;
}

.Step .Step__titleText::after,
.Step .Step__titleText::before {
  background-image: url("../images/text_bg.svg");
  background-repeat: no-repeat;
  background-size: contain;
  content: '';
  display: block;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.Step .Step__titleText::after {
  -webkit-transform: translateY(-50%) rotateY(180deg);
  transform: translateY(-50%) rotateY(180deg);
}

.Step .Step__titleText::after,
.Step .Step__titleText::before {
  height: 11.066666666666666vw;
  width: 2.1333333333333333vw;
}

.Step .Step__titleText::after {
  right: -5%;
}

.Step .Step__titleText::before {
  left: -5%;
}

.Step .Step__titleTextNum {
  font-size: 9.33333vw;
  letter-spacing: -0.1em;
}

.Step .Step__titleStr {
  color: #fb5669;
}

.Step .Step__list {
  padding: 0 0 9%;
}

.Step .Step__figure {
  margin: auto;
  width: 90.933vw;
}

.Step .Step__text {
  font-family: 'Noto Sans JP', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', sans-serif;
  font-weight: 600;
  padding-bottom:5%;
  letter-spacing: -0.05em;
  text-align: center;
  font-size:4.267vw;
}

@media print,
screen and (min-width: 769px) {
  .Sec2 {
    padding: 62px 50px 0;
	margin-bottom: 80px;
  }
	
  .Step .Step__title {
    font-size: 40px;
	margin: 0 0 2.5%;
  }

  .Step .Step__titleText {
    font-size: 8vw;
  }
	
  .Step .Step__titleText::after,
  .Step .Step__titleText::before {
    height: 83px;
    width: 16px;
    top: 63%;
  }

  .Step .Step__titleText::after {
    right: -7%;
  }

  .Step .Step__titleText::before {
    left: -7%;
  }	
	
  .Step .Step__titleText {
    font-size: 48px;
    padding-bottom: 0;
  }
	
  .Step .Step__titleTextNum {
    font-size: 70px;
  }

  .Step .Step__list {
    padding: 0 0 7.3%;
  }

  .Step .Step__figure {
    width: 79.4%;
  }

  .Step .Step__text {
    font-size:32px;
  }
}

@media print,
screen and (min-width: 769px) and (max-width: 1100px) {
  .Step .Step__title {
    font-size: 3.63636vw;
  }

  .Step .Step__titleText {
    font-size: 5.45455vw;
  }

  .Step .Step__titleText::after,
  .Step .Step__titleText::before {
    height: 7.54545vw;
  }
	
  .Step .Step__titleText {
    font-size: 4.36364vw;
  }
	
  .Step .Step__titleTextNum {
    font-size: 6.36364vw;
  }
}

/*---------- under_banner ----------*/
@media print,
screen and (max-width: 768px) {
  figure.under_banner { 
	width:89.333333333%;
	margin: 0 auto;
	padding: 8vw 0 5vw;
  } 
}

@media print,
screen and (min-width: 769px) {
  figure.under_banner {	padding-bottom: 50px; } 
}

/*---------- foot_attention ----------*/
.foot_attention { margin-bottom:80px; }

.foot_attention h3 {
	font-size:20px;
	font-weight:700;
	text-align: center;
}

.foot_attention .text {
	font-size:18px;
	font-weight:700;
	width:700px;
	margin:30px auto 0;
}

.foot_attention .text2 {
	font-size:13px;
	width:700px;
	line-height: 1.5;
	margin:0 auto;
}

.foot_attention .break {
	word-break: break-all;
}

.foot_attention ul {
	width:720px;
	margin:0 auto 40px;
}

.foot_attention ul.text3 {
	margin:0 auto;
}

.foot_attention ul li {
	list-style: disc;
	margin-left:25px;
	font-size: 13px;
	line-height: 1.5;
}

.foot_attention .strike-through {
	text-decoration: line-through;
}

@media print, screen and (max-width: 768px) {
	.foot_attention { padding-top:2vw; }
	.foot_attention h3 { font-size:3.3vw; }

	.foot_attention .text {
		font-size:3.125vw;
		width:100%;
		margin:7vw auto 0;
	}

	.foot_attention .text2 {
		font-size:3.125vw;
		width:100%;
	}
	
	.foot_attention ul {
		width:100%;
		margin:0 auto 5.236vw;
	}

	.foot_attention ul li {
		margin-left:3.125vw;
		font-size: 3.125vw;
	}
}

.accordion-container2 {
	position: relative;
	width: 100%;
	max-width: 1000px;
	box-sizing: border-box;
	margin:0 auto;
	border-top: none;
	outline: 0;
	cursor: pointer;
}

.accordion-container2 h3 {
	font-size:20px;
	font-weight:700;
	text-align: center;
}

.accordion-container2 .accordion-title2 {
	display: block;
	width:450px;
	color: #454545;
	cursor: pointer;
	padding:3px 80px 0 0;
	margin:60px auto 0;
}

.accordion-container2 .accordion-title2:first-of-type {
	width:530px;
	margin:0 auto;
}
.accordion-title2 { position: relative; }

.accordion-container2 .accordion-title2:hover,
.accordion-container2 .accordion-title2:active,
.accordion-container2 .content-entry.open .accordion-title2 {
	color: #ccc;
}

.accordion-container2 .accordion-title2:hover i:before,
.accordion-container2 .accordion-title2:hover i:active,
.accordion-container2 .content-entry.open i {
	color: #ccc;
}

.accordion-title2:after {
	content: "";
	position: absolute;
	right: 40px;
	top: 0;
	transition: all 0.2s ease-in-out;
	display: block;
	width: 40px;
	height: 40px;
	background: url("../images/open.png") repeat;
}

.accordion-title2.open:after { 
	background: url("../images/close.png") repeat;
}

.Point__item .accordion-container2 .accordion-title2 {
	width:250px;
}

.accordion-content2 { display: none; }

@media print, screen and (max-width: 768px) {
	.foot_attention {margin-bottom:10.417vw; }
	.accordion-container2 h3 { font-size:3.3vw; }
	.accordion-container2 .accordion-title2 { 
		padding:0 7vw 0 0;
		width:66vw;
		margin:9.115vw auto 0;
	}

	.accordion-container2 .accordion-title2:first-of-type {
		width:80vw;
		margin:0 auto;
	}

	.accordion-title2:after {
		width: 5.208vw;
		height: 5.208vw;
		background: url("../images/open.png") repeat;
		background-size: 100%;
		right:0;
	}

	.accordion-title2.open:after { 
		background: url("../images/close.png") repeat;
		background-size: 100%;
	}
	
	.Point__item .accordion-container2 .accordion-title2 {
		width:34vw;
	}
	
	.accordion-content2 {
		width:88%;
		padding:0;
		margin:0 auto;
	}
	
	.Point__item .accordion-content2 {
		width:100%;
	}
}

/*---------- legal ----------*/
#legal--com {
  background: #fff;
  line-height: 1.4;
  padding: 1% 6% 12%;
}

#legal--com p {
  font-size: 14px;
}

#legal--com .container {
  background: #f7dcdd;
  border-radius: .625rem;
  color: #4c4949;
  margin-left: auto;
  margin-right: auto;
  max-width: 1000px;
  padding: 3rem 4%;
}

#legal--com .legal__headingLv3 {
  font-size: 1.25rem;
  text-align: center;
}

#legal--com .legal__link, #legal--com p {
  margin-top: 2rem;
}

#legal--com .legal__link, #legal--com p a {
  color: #e0586c;
  display: block;
  margin-top: 2rem;
  text-align: center;
  text-decoration: underline;
}

@media print, screen and (max-width: 769px -1) {
  #legal--com {
    /*---------- legal ----------*/
  }
  #legal--com .legal__link {
    text-align: left;
  }
}

@media print, screen and (max-width: 768px) {
  #legal--com .legal__headingLv3 {
    font-size: 1.15rem;
  }
}

@media print, screen and (min-width: 769px) {
  #legal--com {
    padding: 10px 0 80px;
  }
  #legal--com p {
    font-size: 16px;
  }
}

@media print, screen and (min-width: 769px) {
/*---------- display ----------*/
  .isSp,
  .isSp--inline {
	display: none !important;
  }
}

/*---------- footer ----------*/
.footer {
  background: #2d2c2c;
  color: #fff;
  font-size: 16px;
  line-height: 1.5;
  padding-bottom: 3rem;
  padding-top: 3rem;
  text-align: center;
  /*----------  ----------*/
}

.footer a {
  text-decoration: none;
}

.footer ul.footer__list {
  display: inline-block;
}

.footer .footer__list::after {
  clear: both;
  content: "";
  display: block;
}

.footer .footer__item {
  float: left;
  margin-right: 4.5rem;
}

.footer .footer__item:last-of-type {
  margin-right: 0;
}

.footer .footer__link {
  color: #fff;
}

.footer .footer__relate {
  font-size: .75rem;
  margin-top: 3rem;
}
.footer .footer__relate a {
	color: #fff;
	text-decoration: underline;
}
.footer .footer__relate a:hover {
	text-decoration: none;
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
}

.footer .footer__copy {
  display: block;
  font-size: .625rem;
  margin-top: 2rem;
}

@media print, screen and (max-width: 768px) {
  .footer {
    font-size: 14px;
    /*---------- footer ----------*/
  }
  .footer .footer__item {
    float: none;
    margin-bottom: 3rem;
    margin-right: 0;
  }
  .footer .footer__item:last-of-type {
    margin-bottom: 0;
  }
}
