@charset "UTF-8";

/* ==========================================================================
 * Font face
 * ========================================================================== */
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 100;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 200;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 300;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Medium");
	font-weight: 400;
}
@font-face {
	font-family: "Yu Gothic";
	src: local("Yu Gothic Bold");
	font-weight: bold;
}

/* ==========================================================================
 * Root
 * ========================================================================== */
*,
::before,
::after {
	background-repeat: no-repeat;
	box-sizing: border-box;
}
html {
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	font-size: 62.5%;
	overflow-x: hidden;
}
body {
	margin: 0 !important;
	padding: 0;
	font-family: "Yu Gothic", YuGothic, "Hiragino Kaku Gothic Pro", Meiryo, Osaka, sans-serif;
	font-size: 1.6em;
	font-size: 1.6rem;
	line-height: 1.5;
	background-color: #fff;
	overflow-x: hidden;
}

/*
@media screen and (max-width: 1200px) {
  html { zoom: 0.9; }
}
@media screen and (max-width: 1115px) {
  html { zoom: 0.8; }
}
@media screen and (max-width: 980px) {
  html { zoom: 0.7; }
}
@media screen and (max-width: 840px) {
  html { zoom: 0.6; }
}
@media screen and (max-width: 700px) {
  html { zoom: 0.5; }
}
@media screen and (max-width: 640px) {
  html { zoom: 1; }  リセット 
}
*/

@media screen and (max-width: 1200px) and (min-width: 641px) {
  #page_container {
    transform-origin: top left;
    width: calc(100% / 0.9);
  }
  #page_container { transform: scale(0.9); }
}
@media screen and (max-width: 1115px) and (min-width: 641px) {
  #page_container { transform: scale(0.8); width: calc(100% / 0.8); }
}
@media screen and (max-width: 980px) and (min-width: 641px) {
  #page_container { transform: scale(0.7); width: calc(100% / 0.7); }
}
@media screen and (max-width: 840px) and (min-width: 641px) {
  #page_container { transform: scale(0.6); width: calc(100% / 0.6); }
}
@media screen and (max-width: 700px) and (min-width: 641px) {
  #page_container { transform: scale(0.5); width: calc(100% / 0.5); }
}

/* ==========================================================================
 * HTML5 display definitions
 * ========================================================================== */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
	display: block;
}
audio,
canvas,
progress,
video {
	display: inline-block;
	vertical-align: baseline;
}
audio:not([controls]) {
	display: none;
	height: 0;
}

/* ==========================================================================
 * Anchor
 * ========================================================================== */
a:link,
a:visited {
	background-color: transparent;
	color: #4f7aac;
	text-decoration: none;
}
a:active,
a:hover {
	outline: 0;
	text-decoration: underline;
}

/* ==========================================================================
 * Embedded
 * ========================================================================== */
img {
	max-width: 100%;
	height: auto;
	border: 0;
	vertical-align: bottom;
}
svg:not(:root) {
	overflow: hidden;
}

/* ==========================================================================
 * Grouping
 * ========================================================================== */
figure {
	margin: 0;
}
hr {
	box-sizing: content-box;
	height: 0;
	border: none;
	border-top: 1px solid #bbb;
}
dd {
	margin-left: 0;
}

/* ==========================================================================
 * Float
 * ========================================================================== */
.clear {
	clear: both;
}
.clearfix:before,
.clearfix:after {
	content: " ";
	display: table;
}
.clearfix:after {
	clear: both;
}

/* ==========================================================================
 * List
 * ========================================================================== */
ul,
ol {
	padding: 0;
}
ul {
	margin: 0;
	list-style: none;
}
ul.list-disc {
	margin-left: 1.55em;
	list-style: disc;
}
ul.list-annotation {
	margin-left: 1.3em;
}
ul.list-annotation li::before {
	margin-left: -1.3em;
	content: "※\0020";
}
ol {
	margin-left: 1.3em;
}
ol.list-annotation {
	margin-left: 2em;
	padding: 0;
	counter-reset: number;
	list-style: none;
}
ol.list-annotation li::before {
	margin-left: -2em;
	counter-increment: number;
	content: "※"counter(number)"\0020";
}
ul.list-disc li + li,
ul.list-annotation li + li,
ol li + li {
	margin-top: 8px;
}

/* ==========================================================================
 * Text
 * ========================================================================== */
b,
strong {
	font-weight: bold;
}
mark {
	background: #ff0;
	color: #000;
}
small,
.txt-small{
	font-size: 80%;
}
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}
sub {
	bottom: -0.25em;
}
sup {
	top: -0.5em;
}
address {
	font-style: normal;
}
h1,
.h1 {
	font-size: 3.2rem;
	line-height: 1.2;
	margin: 0;
}
h2,
.h2 {
	font-size: 2.4rem;
	line-height: 1.2;
	margin: 0;
}
h3,
.h3 {
	font-size: 1.8rem;
	line-height: 1.2;
	margin: 0;
}
h4,
.h4 {
	font-size: 1.6rem;
	line-height: 1.2;
	margin: 0;
}
p {
	margin: 0;
}
.txt-left {
	text-align: left;
}
.txt-center {
	text-align: center;
}
.txt-right {
	text-align: right;
}
.txt-unbold {
	font-weight: normal;
}
.txt-bold {
	font-weight: bold;
}
.txt-emphasis {
	color: #e74c3c;
}
.txt-notes {
	color: #7f8c8d;
}

/* ==========================================================================
 * Table
 * ========================================================================== */
table {
	border-collapse: collapse;
	border-spacing: 0;
}
td,
th {
	padding: 0;
}

/* ==========================================================================
 * Form
 * ========================================================================== */
button,
input,
optgroup,
select,
textarea {
	color: inherit;
	font: inherit;
	margin: 0;
	border: 1px solid #c8c8c8;
}
input[type="text"],
input[type="email"],
input[type="tel"],
textarea {
	width: 100%;
	padding: 5px;
}
button {
	overflow: visible;
}
button,
select {
	text-transform: none;
}
select {
    -webkit-appearance: none;
    appearance: none;
    background-image: url("../images/pc/selct-arrow.png");
    background-repeat: no-repeat;
    background-size: 10px auto; /* 画像のサイズ（幅 高さ）*/
    background-position: right 12px center; /* 画像の位置 */
}
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button;
	cursor: pointer;
}
button[disabled],
html input[disabled] {
	cursor: default;
}
button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}
input {
	line-height: normal;
}
input[type="checkbox"],
input[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}
.vertical__align input{
	vertical-align: middle;
}
.privacy {
	margin-right: 10px;
	width: 20px;
	height: 20px;
}
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
	height: auto;
}
input[type="search"] {
	-webkit-appearance: textfield;
	box-sizing: content-box;
}
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}
textarea {
	overflow: auto;
	height: 133px;
}
select {
	width: 100%;
	padding: 15px 30px 15px 18px;
	color: inherit;
	background-color: #fff;
}
.basePcFlexList, .pcFlexList, .pcFlexList5, .pcFlexList4, .pcFlexList3, .pcFlexList2, .pcColList, .pcColList3, .pcColList2 {
    display: flex;
    flex-wrap: wrap;
	justify-content: space-between;
}
.basePcFlexList li, .pcFlexList li, .pcFlexList5 li, .pcFlexList4 li, .pcFlexList3 li, .pcFlexList2 li, .pcColList li, .pcColList3 li, .pcColList2 li {
	width: 48%;
}



/* ==========================================================================
 * Spacing
 * ========================================================================== */
.margin-none  {margin:           0 !important;}
.padding-none {padding:          0 !important;}

.margin-T0    {margin-top:       0 !important;}
.margin-T5    {margin-top:       5px !important;}
.margin-T10   {margin-top:      10px !important;}
.margin-T15   {margin-top:      15px !important;}
.margin-T20   {margin-top:      20px !important;}
.margin-T25   {margin-top:      25px !important;}
.margin-T30   {margin-top:      30px !important;}
.margin-T35   {margin-top:      35px !important;}
.margin-T40   {margin-top:      40px !important;}
.margin-T45   {margin-top:      45px !important;}
.margin-T50   {margin-top:      50px !important;}
.margin-T60   {margin-top:      60px !important;}
.margin-T70   {margin-top:      70px !important;}
.margin-T80   {margin-top:      80px !important;}
.margin-T90   {margin-top:      90px !important;}
.margin-T100  {margin-top:     100px !important;}

.margin-R0    {margin-right:     0 !important;}
.margin-R5    {margin-right:     5px !important;}
.margin-R10   {margin-right:    10px !important;}
.margin-R15   {margin-right:    15px !important;}
.margin-R20   {margin-right:    20px !important;}

.margin-B0    {margin-bottom:    0 !important;}
.margin-B5    {margin-bottom:    5px !important;}
.margin-B10   {margin-bottom:   10px !important;}
.margin-B15   {margin-bottom:   15px !important;}
.margin-B20   {margin-bottom:   20px !important;}

.margin-L0    {margin-left:      0 !important;}
.margin-L5    {margin-left:      5px !important;}
.margin-L10   {margin-left:     10px !important;}
.margin-L15   {margin-left:     15px !important;}
.margin-L20   {margin-left:     20px !important;}

.padding-T0   {padding-top:      0 !important;}
.padding-T5   {padding-top:      5px !important;}
.padding-T10  {padding-top:     10px !important;}
.padding-T15  {padding-top:     15px !important;}
.padding-T20  {padding-top:     20px !important;}
.padding-T25  {padding-top:     25px !important;}
.padding-T30  {padding-top:     30px !important;}
.padding-T35  {padding-top:     35px !important;}
.padding-T40  {padding-top:     40px !important;}
.padding-T45  {padding-top:     45px !important;}
.padding-T50  {padding-top:     50px !important;}
.padding-T60  {padding-top:     60px !important;}
.padding-T70  {padding-top:     70px !important;}
.padding-T80  {padding-top:     80px !important;}
.padding-T90  {padding-top:     90px !important;}
.padding-T100 {padding-top:    100px !important;}

.padding-R0   {padding-right:    0 !important;}
.padding-R5   {padding-right:    5px !important;}
.padding-R10  {padding-right:   10px !important;}
.padding-R15  {padding-right:   15px !important;}
.padding-R20  {padding-right:   20px !important;}

.padding-B0   {padding-bottom:   0 !important;}
.padding-B5   {padding-bottom:   5px !important;}
.padding-B10  {padding-bottom:  10px !important;}
.padding-B15  {padding-bottom:  15px !important;}
.padding-B20  {padding-bottom:  20px !important;}

.padding-L0   {padding-left:     0 !important;}
.padding-L5   {padding-left:     5px !important;}
.padding-L10  {padding-left:    10px !important;}
.padding-L15  {padding-left:    15px !important;}
.padding-L20  {padding-left:    20px !important;}

/* ==========================================================================
 * Common
 * ========================================================================== */
#page_container {
	max-width: 2000px;
	margin: 0 auto;
}
.inner-width {
	max-width: 920px;
	width: 100%;
	margin-right: auto;
	margin-left:  auto;
}
.section__ttl {
	text-align: center;
	margin-bottom: 6.5%;
	color: #fff;
	font-size: 4.8rem;
	font-family: a-otf-ryumin-pr6n, serif;
	font-weight: 300;
	letter-spacing: 2px;
}
.section__ttl span {
	letter-spacing: -8px;
}
.annotation {
	font-size: 1rem;
	display: block;
	font-family: "Yu Gothic";
}
em {
	font-style: normal;
}

.pr-hidden {
  display: none;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.pr-visible {
  display: block;
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.4s ease, transform 0.4s ease;
}

@media only screen and (max-width: 1020px) and (min-width: 641px) {
	.inner-width {
		width: 92%;
        margin-right: auto;
        margin-left: auto;
	}
}

@media screen and (max-width: 640px) {
	.inner-width {
		width: 92%;
        margin-right: auto;
        margin-left: auto;
	}
	.section__wrap {
		padding: 12.5% 0;
	}
	.section__ttl {
		font-size: 8.125vw;
		margin-bottom: 11%;
	}
	.common__pink-bg {
		background: url("../images/sp/common-pink-bg@2x.jpg")  no-repeat top center / cover;
	}
}
/*-------------------- Back to Top --------------------*/
a.backtotop {
	position: fixed;
	bottom: 10%;
	right: 5%;
	width: 40px;
	height: 40px;
	padding: 38px 0 0;
	background-color: #ccc;
	color: #fff;
	text-align: center;
	font-size: 14px;
	cursor: pointer;
	opacity: .5;
	border-radius: 50%;
}
a.backtotop::before {
	content: "";
	position: absolute;
	top: 10px;
	left: 10px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 10px 17.3px 10px;
	border-color: transparent transparent #ffffff transparent;
}

/* ==========================================================================
 * Responsive
 * ========================================================================== */
@media screen and (min-width: 641px) {
	.visible-sp {
		display: none !important;
	}
	.hidden-pc {
		display: none !important;
	}
}
@media screen and (max-width: 640px) {
	.visible-pc {
		display: none !important;
	}
}

/* ==========================================================================
 * FV
 * ========================================================================== */
.fv {
	background: url("../images/pc/fv-bg.jpg") no-repeat top center / cover;
	padding: 15% 0 16% 0;
	position: relative;
	margin-top: 3%;
}
.fv__cont {
	position: absolute;
    width: 34%;
    left: 22%;
    top: 30%;
}
.fv__cont img {
	width: 100%;
}
.fv__point {
	position: absolute;
	bottom: -7vw;
	left: 27vw;
	display: flex;
	align-items: center;
}
.fv__point img {
	width: 35vw;
}

@media screen and (max-width: 1200px) and (min-width: 1116px) {
	.fv__point {
		left: 29vw;
	}
}

@media screen and (max-width: 1115px) and (min-width: 981px) {
	.fv__point {
		bottom: -9vw;
		left: 31vw;
	}
	.fv__point img {
		width: 44vw;
	}
}

@media screen and (max-width: 980px) and (min-width: 841px) {
	.fv__point {
		bottom: -12vw;
		left: 38vw;
	}
	.fv__point img {
		width: 53vw;
	}
}

@media screen and (max-width: 840px) and (min-width: 701px) {
	.fv__point {
		bottom: -14vw;
		left: 44vw;
	}
	.fv__point img {
		width: 62vw;
	}
}

@media screen and (max-width: 700px) and (min-width: 641px) {
	.fv__point {
		bottom: -14vw;
        left: 53vw;
	}
	.fv__point img {
		width: 62vw;
	}
}

@media (max-width: 640px) {
	.fv {
		background: url("../images/sp/fv-bg@2x.jpg") no-repeat top center / cover;
		height: 100%;
		padding: 58% 0 100% 0;
	}
	.fv__cont {
		width: 90%;
		left: 5%;
		top: 30%;
	}
	.fv__point {
		flex-direction: column;
		align-items: flex-start;
		bottom: -16vw;
		left: 5%;
		right: 5%;
	}
	.fv__point img {
		width: 100vw;
	}
}


/* ==========================================================================
 * coupon
 * ========================================================================== */
.coupon {
	background: url("../images/pc/coupon-bg.jpg") no-repeat top center / cover;
	padding: 10% 0 5% 0;
}
.coupon__02 {
	padding: 5% 0;
}
.coupon__cont {
	text-align: center;
	margin-bottom: 5.5%;
}
.coupon-code__top {
	text-align: center;
	margin-bottom: 2%;
	letter-spacing: 1px;
	font-family: a-otf-ryumin-pr6n, serif;
	font-weight: 300;
}
.coupon-code {
	width: 50%;
	margin: 0 auto;
}
.coupon-code__txt {
	position: relative;
}
.coupon-code__txt,
.code {
	display: flex;
	justify-content: space-between;
}
.coupon-code__txt p {
	background: #22324d;
	color: #fff;
	width: 28.5%;
    display: flex;
    justify-content: center;
    align-items: center;
	font-weight: bold;
}
.code {
	width: 71.5%;
	background: #fff;
	padding: 4.5% 0;
}
.code p {
	background: none;
	color: #22324d;
	font-size: 3rem;
	font-weight: bold;
	margin-left: 70px;
}
.code button {
	margin-right: 20px;
	background: #a2a2a2;
	border-radius: 5px;
	color: #fff;
	padding: 6px;
	max-width: 75px;
	width: 100%;
	font-size: 1.6rem;
	box-shadow: 1px 1px 2px 1px rgba(0,0,0,0.15);
}
.copy-toast {
	display: block;
	opacity: 0;
	font-size: 1.6rem;
	transition: opacity 0.2s;
	pointer-events: none;
	position: absolute;
	background: #333;
	color: #fff;
	padding: 10px;
	top: 100%;
	right: 0;
}
.copy-toast.is-show {
	opacity: 1;
}

@media (max-width: 640px) {
	.coupon {
		background: url("../images/sp/coupon-bg@2x.jpg") no-repeat top center / cover;
		padding: 40% 0 15.5% 0;
	}
	.coupon-code {
		width: 100%;
	}
	.coupon-code__top {
		margin-bottom: 15px;
		letter-spacing: 0;
	}
	.coupon-code__txt p {
		font-size: 1.2rem;
		width: 30.5%;
		padding: 0 20px;
		text-align: center;
	}
	.code p {
		font-size: 1.8rem;
		margin-left: 30px;
	}
	.coupon__02 {
		padding: 15.5% 0;
	}
	.copy-toast {
		font-size: 1.2rem;
		padding: 5px;
	}
}

/* ==========================================================================
 * Header
 * ========================================================================== */
.hd {
	position: fixed;
    top: 0;
    z-index: 9999;
    background: #fff;
    width: 100%;
    box-shadow: 0 0 5px rgba(0, 0, 0, .15);
}
.header__wrap{
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 8px 0;
}
.header__logo {
	width: 30%;
}
.header__cta {
	width: 50%;
}

@media (max-width: 640px) {
    .header__wrap {
		gap: 8px;
		align-items: center;
		padding: 0;
    }
	.hd {
		background-color: #fff;
		position: fixed;
		width: 100%;
		z-index: 1000;
		padding: 5px 0;
	}
    .header__logo {
        width: 50%;
    }
    .header__logo img {
        width: 100%;
    }
    .header__cta {
		width: 43%;
    }
    .header__ctaBtn {
        display: block;
        width: 100%;
    }
    .header__ctaBtn img {
        width: 100%;
        height: auto;
        display: block;
    }
	/* hamburger menu */
	.menu__btn {
		align-items: center;
		display: flex;
		justify-content: center;
		height: 40px;
		width: 40px;
		padding: 10px;
		border-radius: 3px;
		position: relative;
		z-index: 9999;
	}
	.menu__btn span,
	.menu__btn span:before,
	.menu__btn span:after {
		content: '';
		background: #22324d;
		display: block;
		height: 2px;
		position: absolute;
		width: 30px;
	}
	.menu__btn span:before {
		bottom: 5px;
	}
	.menu__btn span:after {
		top: 5px;
	}
	#menu__btn--check:checked ~ .menu__btn span {
		background-color: rgba(255, 255, 255, 0);
	}
	#menu__btn--check:checked ~ .menu__btn span::before {
		bottom: 0;
		transform: rotate(45deg);
	}
	#menu__btn--check:checked ~ .menu__btn span::after {
		top: 0;
		transform: rotate(-45deg);
	}
	#menu__btn--check {
		display: none;
	}
	.gnavi__hamburger-menu {
		background: #fff;
		height: 100%;
		position: fixed;
		top: 0;
		left: 100%;
		z-index: 80;
		transition: all 0.5s;
		width: 100%;
	}
	#menu__btn--check:checked ~ .gnavi__hamburger-menu {
		left: 0;
	}
	.gnavi__hamburger-menu ul {
		padding: 70px 10px 0;
		flex-direction: column;
		margin: 0;
	}
	.gnavi__hamburger-menu ul li {
		border-bottom: solid 1px #315069;
		list-style: none;
		padding: 0 0 0 3%;
		width: 100%;
		margin: 0;
	}
	.gnavi__hamburger-menu ul li a {
		box-sizing: border-box;
		color: #000;
		display: block;
		font-size: 15px;
		padding: 18px 15px 15px 0;
		position: relative;
		text-decoration: none;
		width: 100%;
	}
	.gnavi__hamburger-menu ul li a::before {
		border-top: solid 2px #000;
		border-right: solid 2px #000;
		content: "";
		height: 7px;
		transform: rotate(45deg);
		position: absolute;
		right: 11px;
		top: 26px;
		width: 7px;
	}
	/* /hamburger menu */
	.sp {
		display: block;
	}
	.nav__cta {
		margin: 20px auto 0 auto;
		width: 90%;
	}
	.header__tel {
		align-items: center;
		display: flex;
		justify-content: center;
		height: 40px;
		width: 40px;
		background: #009a44;
		padding: 8px;
		border-radius: 3px;
		position: relative;
		z-index: 9999;
	}
	.header__tel img {
		width: 100%;
	}
	.header__menu {
		display: flex;
		column-gap: 10px;
	}
}

/* ==========================================================================
 * NAV
 * ========================================================================== */
.gnavi {
	background: #fff;
	width: 70%;
}
.gnavi__list {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 20px;
}
.gnavi__list li {
	text-align: center;
}
.gnavi__list li:hover {
	border-bottom: solid #22324d 2px;
}
.gnavi__list li a {
	color: #22324d;
	font-size: 1.6rem;
	font-weight: bold;
	display: block;
	line-height: 1.2;
	text-decoration: none;
}
.fixed {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 998;
	width: 100%;
}

@media only screen and (max-width: 1020px) and (min-width: 641px) {
	.gnavi__list li a {
		font-size: 1.2rem;
	}
}

/* ==========================================================================
 * message
 * ========================================================================== */
.message {
	background: url("../images/pc/message-bg.jpg") no-repeat top center / cover;
	padding: 6% 0;
	font-family: a-otf-ryumin-pr6n, serif;
}
.message__txt {
	text-align: center;
	color: #fff;
	font-size: 2rem;
	line-height: 2;
	letter-spacing: 1.5px;
	font-weight: 300;
	margin-bottom: 6.5%;
}
.message__txt em {
	text-decoration: underline;
	color: #f9e5bb;
}

@media (max-width: 640px) {
	.message {
		background: url("../images/sp/message-bg@2x.jpg") no-repeat top center / cover;
		padding: 15.5% 0;
	}
	.message__txt {
		font-size: 1.6rem;
		text-align: left;
		line-height: 1.5;
		letter-spacing: 1px;
	}
}

/* ==========================================================================
 * worries
 * ========================================================================== */
.worries {
	background: url(../images/pc/worries-bg.jpg) no-repeat top center / cover;
	padding: 6% 0;
}
.worries__wrap {
	margin-bottom: 22.3%;
}
.omakase__ttl {
	margin-bottom: 6.5%;
}
.member {
	text-align: center;
}

@media (max-width: 640px) {
	.worries {
		background: url(../images/sp/worries-bg@2x.jpg) no-repeat top center / cover;
		padding: 15.5% 0 24% 0;
	}
	.worries__wrap {
		margin-bottom: 45%;
	}
}

/* ==========================================================================
 * CTA
 * ========================================================================== */
.cta{
	background: url("../images/pc/cta-bg.jpg") repeat top center / cover;
	padding: 80px 0 100px 0;
}
.cta__ttl {
	margin-bottom: 2.5%;
}
.three-step {
	margin-bottom: 6.5%;
}
.cta__btn {
	display: flex;
	justify-content: center;
}
.cta__btn:hover img {
	transform: scale(1.02);
}
@media (max-width: 640px) {
	.cta{
		background: url("../images/sp/cta-bg@2x.jpg") repeat top center / cover;
		padding: 15.5% 0;
	}
	.three-step {
		margin-bottom: 10%;
	}
	.cta__ttlSub {
		font-size: 2.4rem;
        letter-spacing: 0;
        line-height: 1.5;
	}
}

/* ==========================================================================
 * REASON
 * ========================================================================== */
.reason {
	padding: 6% 0;
	background: url("../images/pc/reason-bg.jpg") no-repeat top center / cover;
	font-family: a-otf-ryumin-pr6n, serif;
}
.reason .section__ttl {
	color: #333;
}
.reason__first,
.reason__second,
.reason__third {
	padding: 8% 0 6% 0;
	position: relative;
}
.reason__first {
	margin-bottom: 4%;
}
.reason__first,
.reason__third {
	background-image: url("../images/pc/reason01-bg.jpg");
	background-size: 90% 100%;
	background-position: 0 0;
}
.reason__ttl {
	margin-bottom: 19%;
}
.reason__first .reason__ttl::after {
	content: "";
	background: url("../images/pc/reason01-top-img.png") no-repeat center/ contain;
	display: block;
    width: 50%;
    height: 12.15%;
    position: absolute;
	top: 1%;
	right: 0;
	filter: drop-shadow(4px 4px 4px #aaa);
}
.case__maker,
.case__sennnendo,
.reason__melit {
	margin-bottom: 6.5%;
}
.case__maker {
	position: relative;
}
.case__maker,
.case__sennnendo {
	filter: drop-shadow(4px 4px 4px #aaa);
}
.case__maker::after {
	position: absolute;
	content: "";
	background: url("../images/pc/expensive-icon.png") no-repeat;
	background-size: contain;
    width: 10%;
    height: 10%;
    top: -5%;
    left: -4%;
}
.therefore {
	margin-bottom: 6.5%;
	text-align: center;
}
.cost {
	background: #22324d;
	width: 87%;
	margin: 0 auto;
	padding: 5.5% 8%;
	position: relative;
}
.reason .cost::after {
	content: "";
	background: url("../images/pc/rolex-datejust.png") no-repeat center/ contain;
	position: absolute;
    width: 16.5%;
    height: 40%;
    right: -6%;
    top: -9%;
}
.cost h4 {
	text-align: center;
	font-size: 3.6rem;
	color: #fff;
	margin-bottom: 5%;
	font-weight: 300;
    display: flex;
    justify-content: space-around;
    align-items: center;
}
.cost h4 span {
	background: #fff;
	padding: 10px;
	color: #22324d;
	width: 20%;
	display: block;
}
.cost .annotation {
	color: #fff;
}
.comparison {
	margin-top: 5%;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.mekar__fee p {
	font-size: 5rem;
	color: #e4e4e4;
	font-weight: 500;
}
.mekar__fee p small {
	font-size: 60%;
}
.sennnendo__fee p,
.gradation {
	font-size: 7.4rem;
	background: linear-gradient(135deg, #fff4dc 0%, #e4cea3 26%, #fff3dc 50%, #e4cea3 74%, #fff4dc 100%);
	color: transparent;
	background-clip: text;
	margin-top: -4%;
	font-weight: 500;
}
.sennnendo__fee p small {
	font-size: 50%;
}
.sennnendo__fee p .white {
	color: #fff;
}
.great__value {
	margin-top: -2%;
	margin-bottom: 2%;
}
.reason__second {
	background-image: url("../images/pc/reason02-bg.jpg");
	background-position: 100% 0;
    background-size: 90% 100%;
    background-repeat: no-repeat;
	margin-bottom: 6%;
}
.reason__second .reason__ttl::before {
	content: "";
	background: url("../images/pc/reason02-top-img.png") no-repeat center/ contain;
	display: block;
    width: 50%;
    height: 27.4%;
    position: absolute;
    top: 0;
    left: -6%;
	filter: drop-shadow(4px 4px 4px rgba(0,0,0,0.1));
}
.reason__second .reason__ttl {
	text-align: right;
	margin-bottom: 24%;
}
.badge {
	margin-bottom: 6.5%;
}
.reason__second .annotation {
	color: #fff;
	margin-top: 10px;
}
.slider__root {
	margin-bottom: 3%;
}
.slide {
	display: flex !important;
	justify-content: space-between;
	margin: 0 10px;
}
.slick-initialized .slick-slide .slide {
	opacity: 1;
	visibility: visible;
	display: block;
	justify-content: space-between;
	align-items: center;
	min-height: 240px;
	max-height: none;
	pointer-events: auto;
}
.slide__body {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	color: #fff;
	line-height: 1.5;
	letter-spacing: -0.5px;
	margin-bottom: 16px;
}
.slide__content {
	width: 48%;
}
.slide__heading {
	font-size: 2.4rem;
	font-weight: 300;
	line-height: 1.5;
	letter-spacing: 1px;
	color: #fff;
	margin-bottom: 16px;
}
.slide__heading em {
	color: #f9e5bb;
	font-style: normal;
}
.slide__text {
	font-size: 13px;
	line-height: 2;
	color: #a09880;
	margin: 0 0 20px;
	letter-spacing: 0.02em;
}
.work__history {
	display: inline-block;
	background: #fff;
	color: #0e0e0e;
	font-size: 2.4rem;
	padding: 7px 0;
	text-align: center;
	font-weight: 300;
	width: 100%;
}
.slide__image {
	width: 47%;
	max-width: 440px;
	flex-shrink: 0;
	overflow: hidden;
}
.slide__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	filter: brightness(0.88);
}
.slide__image--placeholder {
	width: 100%;
	height: 100%;
	min-height: 240px;
	background: #2a2a2a;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #555;
	font-size: 13px;
}
.slick-dots {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 10px;
	padding: 16px 0 10px;
	margin: 2% 0;
}
.slick-dots li {
	width: 10px !important;
	height: 10px !important;
	border-radius: 50% !important;
	background: #a2a2a2 !important;
	cursor: pointer !important;
	transition: background 0.2s !important;
}
.slick-dots li.slick-active {
    background: #caa65a !important;
}
.slider-nav {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 32px;
	padding: 0 0 24px;
}
.slider-nav__btn {
	cursor: pointer;
	transition: all 0.2s;
	background: none;
    border: none;
}
.slider-nav__btn img:hover {
	transform: scale(1.02);
}
.slider-nav__btn--next img:hover {
	transform: scale(1.02);
}
.slideshow {
	overflow: hidden;
  	width: 100%;
	margin-bottom: 6%;
}
.slideshow__track {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
	width: max-content; /* ← 追加 */
	animation: slideshow-loop 20s linear infinite;
/*	will-change: transform;*/
	transform: translateZ(0); 
}
.slideshow:hover .slideshow__track {
  animation-play-state: paused;
}
.slideshow__item {
  flex: 0 0 auto;
  width: 40vw;
  max-width: 480px;
  padding: 0 8px;
}
.slideshow__image--placeholder {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #2a2a2a;
}
.slideshow__image--placeholder picture {
  display: block;
  width: 100%;
  height: 100%;
}
.slideshow__image--placeholder img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.88);
  transition: filter 0.3s;
}
@keyframes slideshow-loop {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.slideshow__item:hover .slideshow__image--placeholder img {
  filter: brightness(1);
}
.reason__third .reason__ttl::after {
	content: "";
	background: url("../images/pc/reason03-top-img.png") no-repeat center/ contain;
	display: block;
    width: 50%;
	height: 22.8%;
    position: absolute;
	top: 2%;
	right: 0;
	filter: drop-shadow(4px 4px 4px #aaa);
}
.reason__third .reason__ttl {
	margin-bottom: 22%;
}
.repair__cont {
	display: flex;
	flex-direction: column;
	gap: 40px;
	margin-bottom: 6%;
}
.consistent {
	margin-bottom: 6.5%;
}
.consistent .annotation {
	margin-top: 10px;
}
.reason__third .reason__melit {
	margin-bottom: 0;
}


@media (max-width: 640px) {
	.reason {
		padding: 15.5% 0;
		background: url("../images/sp/reason-bg@2x.jpg") no-repeat top center / cover;
	}
	.reason .section__ttl {
		font-size: 8.125vw;
	}
	.reason__first,
	.reason__second {
		margin-bottom: 12.5%;
	}
	.reason__first,
	.reason__third {
		background-image: url("../images/sp/reason01-bg@2x.jpg");
		background-size: cover;
	}
	.reason__first,
	.reason__second,
	.reason__third {
		padding: 57% 0 12.5% 0;
	}
	.reason__first .reason__ttl::after {
		background: url("../images/sp/reason01-top-img@2x.png") no-repeat center/ contain;
		width: 96%;
		top: -1.5%;
		right: 0;
		filter: drop-shadow(4px 4px 4px #aaa);
	}
	.reason__ttl {
		margin-bottom: 10%;
	}
	.case__maker::after {
		background: url("../images/sp/expensive-icon@2x.png") no-repeat;
		background-size: contain;
		width: 17%;
		height: 17%;
		top: -3%;
		left: 40%;
	}
	.case__maker,
	.case__sennnendo,
	.reason__melit {
		margin-bottom: 10%;
	}
	.reason__melit {
		margin: 0 calc(50% - 46vw);
        width: 98vw;
		margin-bottom: 10%;
	}
	.therefore {
		width: 28%;
		margin: 0 auto 10% auto;
	}
	.cost {
		padding: 10% 6.5%;
        width: 100%;
	}
	.reason .cost::after {
		background: url("../images/sp/rolex-datejust@2x.png") no-repeat center/ contain;
		position: absolute;
		width: 24%;
		height: 18.7%;
		right: -6%;
		top: -4%;
	}
	.cost h4 {
		font-size: 7.5vw;
		margin-bottom: 8%;
		justify-content: center;
	}
	.comparison {
		flex-direction: column;
		margin-top: 8%;
	}
	.mekar__fee,
	.sennnendo__fee {
		display: flex;
		justify-content: center;
    	flex-direction: column;
	}
	.mekar__fee picture,
	.sennnendo__fee picture {
		text-align: center;
	}
	.mekar__fee p,
	.sennnendo__fee p {
		text-align: center;
	}
	.mekar__fee p {
		font-size: 15.75vw;
	}
	.meker-arrow {
		margin-bottom: 5%;
		width: 16%;
		display: flex;
		justify-content: center;
	}
	.mekar__fee p small {
		font-size: 36%;
	}
	.sennnendo__fee p,
	.gradation {
		font-size: 18.75vw;
	}
	.sennnendo__fee p small {
		font-size: 30%;
	}
	.reason__second {
		background: url("../images/sp/reason02-bg@2x.jpg") no-repeat top center / cover;
	}
	.reason__second .reason__ttl::before {
		background: url("../images/sp/reason02-top-img@2x.png") no-repeat center/ contain;
        width: 100%;
        top: -8%;
		right: 0;
	}
	.reason__second .reason__ttl {
		margin-bottom: 10%;
	}
	.slider__root {
		margin-bottom: 3%;
		position: relative;
	}
	.slide {		
		display: flex;
		flex-direction: column;
	}
	.slick-initialized .slick-slide .slide {
		display: flex;
		opacity: 1;
		flex-direction: column;
		justify-content: space-between;
		align-items: center;
		min-height: 288px;
		max-height: none;
		pointer-events: auto;
	}
	.slider__root .slick-initialized::before {
        content: "";
        position: absolute;
        top: 55%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 60vw;
        height: 30vw;
        background-image: url(../images/sp/project_ex_icon@2x.png);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
        z-index: 10;
        pointer-events: none;
		opacity: 1;
		transition: opacity 0.6s ease;
    }
	.slider__root.is-swiped .slick-initialized::before {
		opacity: 0;
		pointer-events: none;
	}
	.slide__body {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		color: #fff;
		line-height: 1.5;
		margin-bottom: 16px;
		font-size: 1.4rem;
	}
	.slide__content {
		width: 100%;
		margin-bottom: 7%;
	}
	.slide__heading {
		font-size: 2rem;
		color: #fff;
		letter-spacing: -1px;
		margin-bottom: 16px;
	}
	.slide__heading em {
		color: #f9e5bb;
		font-style: normal;
	}
	.slide__text {
		font-size: 13px;
		line-height: 2;
		color: #a09880;
		margin: 0 0 20px;
		letter-spacing: 0.02em;
	}
	.work__history {
		font-size: 1.8rem;
		padding: 7px 0;
	}
	.slide__image {
		width: 100%;
	}
	.slide__image--placeholder {
		width: 100%;
		height: 100%;
		min-height: 240px;
		background: #2a2a2a;
		display: flex;
		align-items: center;
		justify-content: center;
		color: #555;
		font-size: 13px;
	}
	.slider-dots {
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 20px;
		padding: 16px 0 10px;
		margin: 2% 0;
	}
	.slider-dots__item {
		width: 6px;
		height: 6px;
		border-radius: 50%;
		background: #a2a2a2;
		cursor: pointer;
		transition: background 0.2s;
	}
	.slider-dots__item--active {
		background: #caa65a;
	}
	.slider-nav {
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 0;
		padding: 0 0 24px;
	}
	.slider-nav__btn {
		cursor: pointer;
		transition: all 0.2s;
		background: none;
		border: none;
	}
	.slider-nav__btn img:hover {
		transform: scale(1.02);
	}
	.slider-nav__btn--next img:hover {
		transform: scale(1.02);
	}
	.slideshow {
		margin-bottom: 12.5%;
	}
	.slideshow__track {
	  display: flex;
	  list-style: none;
	  margin: 0;
	  padding: 0;
	  animation: slideshow-loop 20s linear infinite;
	  will-change: transform;
	}
	.slideshow:hover .slideshow__track {
	  animation-play-state: paused;
	}
	.slideshow__item {
	  flex: 0 0 auto;
	  width: 40vw;
	  max-width: 480px;
	  padding: 0 8px;
	}
	.slideshow__image--placeholder {
	  width: 100%;
	  aspect-ratio: 4 / 3;
	  overflow: hidden;
	  background: #2a2a2a;
	}
	.slideshow__image--placeholder picture {
	  display: block;
	  width: 100%;
	  height: 100%;
	}
	.slideshow__image--placeholder img {
	  display: block;
	  width: 100%;
	  height: 100%;
	  object-fit: cover;
	  filter: brightness(0.88);
	  transition: filter 0.3s;
	}
	.slideshow__item:hover .slideshow__image--placeholder img {
		filter: brightness(1);
	}
	.reason__third .reason__ttl::after {
		background: url("../images/sp/reason03-top-img@2x.png") no-repeat center/ contain;
		width: 96%;
		top: -5.5%;
		filter: drop-shadow(4px 4px 4px #aaa);
	}
	.reason__third .reason__ttl {
		margin-bottom: 12.5%;
	}
	.repair__cont {
		gap: 20px;
		margin-bottom: 12.5%;
	}
}
/* ==========================================================================
 * clean-room
 * ========================================================================== */
.clean-room {
	background: url(../images/pc/clean-room-bg.jpg) no-repeat top center / cover;
	padding: 5% 0;
	font-family: a-otf-ryumin-pr6n, serif;
}
.clean-room p {
	font-size: 4.8rem;
	font-weight: 300;
	width: 52%;
    margin: 0 auto;
}
.clean-room p em {
	color: #caa65a;
}

@media (max-width: 640px) {
	.clean-room {
		background: url("../images/sp/clean-room-bg@2x.jpg") no-repeat top center / cover;
		padding: 15.5% 0;
	}
	.clean-room p {
		font-size: 2.4rem;
		width: 100%;
		letter-spacing: -1px;
		text-shadow: 1px 1px 10px #fff,
			-1px 1px 10px #fff,
			1px -1px 10px #fff,
			-1px -1px 10px #fff;
	}
}

/* ==========================================================================
 * environmental-maintenance
 * ========================================================================== */
.environmental-maintenance {
	padding: 6% 0;
	background: url("../images/pc/el-bg.png") no-repeat top center / cover;
}
.el-top {
	margin-bottom: 6%;
}
.el-middle {
	margin-bottom: 5%;
}
.el-bottom {
	margin-bottom: 5.5%;
}
.environmental-maintenance .therefore {
	margin-bottom: 5.5%;
}
.repair-record {
	margin-bottom: 2.5%;
	text-align: center;
}
.repair-record .annotation {
	color: #fff;
	margin-top: 10px;
}
@media (max-width: 640px) {
	.environmental-maintenance {
		padding: 15.5% 0;
		background: url("../images/sp/el-bg@2x.png") no-repeat top center / cover;
	}
	.el-bottom {
		margin-bottom: 12.5%;
	}
}

/* ==========================================================================
 * price
 * ========================================================================== */
.price {
	padding: 6% 0;
	background: url("../images/pc/price-bg.jpg") repeat;
	font-family: a-otf-ryumin-pr6n, serif;
}
.price .section__ttl {
	color: #22324d;
}
.q-block01,
.q-block02,
.repair-fee,
.warranty,
.cta__down {
	transition: opacity 0.4s ease, transform 0.4s ease;
}
.q-block01,
.q-block02,
.repair-fee {
	margin-bottom: 6.5%;
}
.q-block02 {
	display: none;
	opacity: 0;
	transform: translateY(10px);
}
.repair-fee {
	display: none;
	opacity: 0;
	transform: translateY(10px);
}
.repair-fee li {
	display: none;
}
.repair-fee li h4 {
	justify-content: center;
}
.cost::after {
	content: "";
	position: absolute;
    width: 16.5%;
    height: 40%;
    right: -6%;
    top: -9%;
}
.rolex-fee .cost::after {
	background: url("../images/pc/rolex-datejust.png") no-repeat center/ contain;
}
.omega-fee .cost::after {
	background: url("../images/pc/OMEGA.png") no-repeat center/ contain;
}
.tagheuer-fee .cost::after {
	background: url("../images/pc/TAG Heuer Aquaracer2.png") no-repeat center/ contain;
}
.cartier-fee .cost::after {
	background: url("../images/pc/Cartier.png") no-repeat center/ contain;
}
.breitling-fee .cost::after {
	background: url("../images/pc/Britling.png") no-repeat center/ contain;
}
.bvlgari-fee .cost::after {
	background: url("../images/pc/BVLGARI2.png") no-repeat center/ contain;
}
.request {
	font-size: 2.4rem;
	color: #fff;
	text-align: center;
	padding: 2%;
	border: solid 1px #fff;
	margin: 20px 0 10px 0;
}
.q-block {
	width: 100%;
	max-width: 920px;
}
.q-block__heading {
	background: #22324d;
	color: #fff;
	font-size: 2.4rem;
	font-weight: 300;
	padding: 18px 28px;
	margin-bottom: 4.4%;
}
.q-block__options {
	display: flex;
	flex-wrap: wrap;
	padding: 0 4px;
}
.q-block02 .q-block__options {
	justify-content: center;
}
.q-block01 .q-block__options {
	gap: 24px;
}
.q-block02 .q-block__options {
	gap: 10px;
}
.q-block01 .q-option {
	max-width: 288px;
	height: 100px
}
.q-block02 .q-option {
	max-width: 220px;
} 
.q-option {
	width: 100%;
	background: #ccc;
	border-radius: 10px;
	padding: 26px 10px;
	text-align: center;
	cursor: pointer;
	font-size: 2rem;
	font-weight: 300;
	color: #333;
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1.2;
	box-shadow: 0 3px 3px rgba(0,0,0,0.5);
}
.q-rolex,
.q-omega,
.q-tagheuer,
.q-cartier,
.q-breitling,
.q-bvlgari {
	display: flex;
	padding: 10px;
	gap: 10px;
}
.q-option img {
	max-width: 46px;
	max-height: 78px;
}
.q-option:hover {
	background: #070d1c;
	transform: translateY(-2px);
	box-shadow: 0 6px 5px rgba(0,0,0,0.12);
	color: #fff;
}
.q-option.selected {
	background: #070d1c;
	color: #fff;
	box-shadow: 0 6px 5px rgba(26,39,68,0.35);
	transform: translateY(-2px);
}
.percentage p {
	font-size: 3.6rem;
	text-align: center;
	color: #fff;
	line-height: 1.8;
}
.percentage p em {
	background: #fff;
	color: #22324d;
	padding: 5px 15px;
	font-weight: 600;
	font-size: 120%;
	margin-right: 5px;
}
.warranty {
	margin-bottom: 8%;
	display: none;
	opacity: 0;
	transform: translateY(10px);
}
.cta__down {
	display: none;
	opacity: 0;
	transform: translateY(10px);
	text-align: center;
}
.back-link {
	display: block;
	gap: 6px;
	margin-top: 20px;
	color: #4f7aac;
	font-size: 1.6rem;
	text-align: right;
	font-family: "Yu Gothic";
	font-weight: 300;
	text-decoration: none;
	cursor: pointer;
	border: none;
	background: none;
	padding: 0;
	opacity: 0.7;
	transition: opacity 0.2s ease;
}
.back-link:hover {
	opacity: 1;
}
.back-link::before {
	content: "←";
	font-size: 1.6rem;
}

@media (max-width: 640px) {
	.price {
		padding: 15.5% 0;
		background: url("../images/sp/price-bg@2x.jpg") repeat;
	}
	.price .section__ttl {
		font-size: 8.125vw;
	}
	.q-block__heading {
		font-size: 5vw;
		padding: 10px 0;
		margin-bottom: 4.4%;
		text-align: center;
	}
	.q-block01 .q-option,
	.q-block02 .q-option {
		width: 43vw;
		height: 60px
	}
	.q-option {
		font-size: 14px;
	}
	.q-block01 .q-block__options {
		gap: 10px;
	}
	.q-block02 {
		margin-bottom: 15%;
	}
	.q-block__options {
		justify-content: center;
	}
	.q-option img {
		width: 56%;
	}
	.q-rolex,
	.q-omega,
	.q-tagheuer,
	.q-cartier,
	.q-breitling,
	.q-bvlgari {
		padding: 5px;
		gap: 0;
	}
	.repair-fee {
		display: none;
		opacity: 0;
		transform: translateY(10px);
	}
	.repair-fee li {
		display: none;
	}
	.cost::after {
		content: "";
		position: absolute;
		width: 27%;
		height: 20%;
		right: -6%;
		top: -5%;
	}
	.rolex-fee .cost::after {
		background: url("../images/sp/rolex-datejust@2x.png") no-repeat center/ contain;
	}
	.omega-fee .cost::after {
		background: url("../images/sp/OMEGA@2x.png") no-repeat center/ contain;
	}
	.tagheuer-fee .cost::after {
		background: url("../images/sp/TAG Heuer Aquaracer2@2x.png") no-repeat center/ contain;
	}
	.cartier-fee .cost::after {
		background: url("../images/sp/Cartier@2x.png") no-repeat center/ contain;
	}
	.breitling-fee .cost::after {
		background: url("../images/sp/Britling@2x.png") no-repeat center/ contain;
	}
	.bvlgari-fee .cost::after {
		background: url("../images/sp/BVLGARI2@2x.png") no-repeat center/ contain;
	}
	.request {
		font-size: 2.4rem;
		color: #fff;
		text-align: center;
		padding: 2%;
		border: solid 1px #fff;
		margin: 20px 0 10px 0;
	}
	.percentage {
		margin-top: 5%;
	}
	.percentage p {
		font-size: 6.25vw;
		text-align: center;
		color: #fff;
		line-height: 1.8;
	}
	.percentage p em {
		font-size: 150%;
	}
}

/* ==========================================================================
 * case
 * ========================================================================== */
.case {
	padding: 6% 0;
	background: url("../images/pc/voice-bg.jpg") no-repeat top center / cover;
}
.case__list {
	display: flex;
	flex-direction: column;
	gap: 60px;
}

/* ==========================================================================
 * slick voice (SP case slider)
 * ========================================================================== */
@media screen and (max-width: 640px) {
	.case {
		padding: 15.5% 0;
		background: url("../images/sp/voice-bg@2x.jpg") no-repeat top center / cover;
	}
	.case__listSp {
		padding: 0 8px;
		position: relative
	}
	.case__listSp li {
		margin: 0 10px;
	}
	.slick-voice.slick-initialized::before {
        content: "";
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 60vw;
        height: 30vw;
        background-image: url(../images/sp/project_ex_icon@2x.png);
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
        z-index: 10;
        pointer-events: none;
		opacity: 1;
		transition: opacity 0.6s ease;
    }
	.slick-voice.slick-initialized.is-swiped::before {
		opacity: 0;
	}
    .slick-voice .slick-dots {
        bottom: -30px;
    }
    .slick-voice .slick-dots li button:before {
        font-size: 10px;
        color: #a2a2a2;
    }
    .slick-voice .slick-dots li.slick-active button:before {
        color: #fff;
    }
    /* slick適用後はliをブロック表示に戻す */
    .slick-voice .case__list01 {
        display: block;
    }
	.slick-prev:before,
	.slick-next:before {
		display: none;
	}
	.case__listSp .slick-prev,
	.case__listSp .slick-prev:focus {
		position: absolute;
		content: "";
		background: url("../images/sp/slick-arrow-left@2x.png") no-repeat;
		background-size: 30px;
		z-index: 100;
		width: 30px;
		height: 30px;
		top: 45%;
		left: -1%;
		transform: translateY(-50%);
		opacity: 1 !important;
	}
	.case__listSp .slick-next,
	.case__listSp .slick-next:focus {
		position: absolute;
		content: "";
		background: url("../images/sp/slick-arrow-right@2x.png") no-repeat;
		z-index: 100;
		background-size: 30px;
		width: 30px;
		height: 30px;
		top: 45%;
		right: -1%;
		transform: translateY(-50%);
		opacity: 1 !important;
	}
	.case__listSp .slick-prev,
	.case__listSp .slick-next {
		opacity: 1 !important;
		visibility: visible !important;
		display: block !important;
  }
	.case__listSp .slick-prev.slick-disabled,
	.case__listSp .slick-next.slick-disabled {
		opacity: 1 !important;
		visibility: visible !important;
	}
	.slick-dots li button {
		display: none!important;
	}
}

/* ==========================================================================
 * flow
 * ========================================================================== */
#flow {
	padding: 6% 0;
	background: url("../images/pc/flow-bg.jpg") no-repeat;
	background-size: cover;
	font-family: a-otf-ryumin-pr6n, serif;
	position: relative;
}
.flow .section__ttl {
	color: #333333;
}
.flow__list {
	position: relative;
}
.flow__list::after {
	content: "";
	background: url("../images/pc/return.png") no-repeat;
	position: absolute;
	width: 10%;
	height: 100%;
	top: -1%;
	right: -5%;
	background-size: 72%;
}
.item01 {
	margin-bottom: 0;
}
.item02 {
	margin-bottom: 4.4%;
}
.item03 {
	margin-bottom: 13%;
}
.flow-display__flex {
	display: flex;
	align-items: center;
	position: relative;
}
.flow__boxWrap {
	position: absolute;
}
.flow__box {
	max-width: 480px;
    width: 100%;
	max-height: 240px;
	height: 100vh;
	background: #fff;
    padding: 0 30px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.flow__img {
    position: relative;
	max-height: 300px;
	height: 100vh;
	width: 25vw;
}

/* item01 */
.item01 .flow__boxWrap {
	top: 14%;
	right: 5%;
}
.item01 .flow__box::after {
	content: "";
	background: url("../images/pc/flow01-number.png") no-repeat;
	display: block;
    width: 27.63%;
    height: 36.45%;
	position: absolute;
    top: 0;
    right: 0;
}
.flow01__detail {
	display: flex;
	justify-content: center;
	z-index: 10;
	margin-top: -4%;
	position: relative;
	margin-bottom: 11%;
	filter: drop-shadow(4px 4px 4px #aaa);
}

/* item02 */
.item02 .flow__img {
	position: absolute;
	top: -7%;
	right: 5%;
	z-index: 0;
}
.item02 .flow__boxWrap {
	position: relative;
	width: 100%;
	z-index: 1
}
.item02 .flow__box::after {
	content: "";
	background: url("../images/pc/flow02-number.png") no-repeat;
	display: block;
    width: 14%;
    height: 27%;
	position: absolute;
    top: 0;
    left: 38.3%;
}
.item02 .flow__boxWrap .annotation {
	margin-top: 10px;
}

/* item03 */
.item03 .flow__box::after {
	content: "";
	background: url("../images/pc/flow03-number.png") no-repeat;
	display: block;
    width: 27.63%;
    height: 43%;
	position: absolute;
    top: 0;
    right: 0;
}
.item03 .flow__boxWrap {
	top: 14%;
	right: 5%;
}

/* item04 */
.item04 .flow__img {
	position: absolute;
	top: -7%;
	right: 5%;
	z-index: 0;
}
.item04 .flow__boxWrap {
	position: relative;
	width: 100%;
	z-index: 1
}
.item04 .flow__box {
	max-height: 300px;
	padding: 42px 30px;
	margin-bottom: 10px;
}
.item04 .flow__box::after {
	content: "";
	background: url("../images/pc/flow04-number.png") no-repeat;
	display: block;
    width: 14%;
    height: 27%;
	position: absolute;
    top: 0;
    left: 38.3%;
}
.item04 .flow__boxWrap .annotation {
	margin-top: 10px;
}
.flow__boxTtl {
	font-size: 2.4rem;
	margin-bottom: 20px;
}
.flow__boxIcon {
    margin-top: 20px;
    background: #caa65a;
    font-size: 2rem;
    text-align: center;
    color: #fff;
    max-width: 180px;
}
#flow .consent {
	text-align: center;
	margin-bottom: 6.5%;
}
.pay {
    background: #e1e1e1;
    padding: 22px 18px;
    max-width: 387px;
    width: 100%;
	margin-top: 20px;
}
.pay-wrap {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.pay-box {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	text-align: center;
	column-gap: 10px;
}
.pay-box p{
	font-size: 1.2rem;
}

@media (max-width: 640px) {
	#flow {
		padding: 12.5% 0;
		background: url("../images/sp/flow-bg@2x.jpg") no-repeat;
		background-size: cover;
	}
	.flow__list::after {
		content: "";
		background: url("../images/sp/return@2x.png") no-repeat;
		position: absolute;
		width: 8%;
		height: 100%;
		top: 0;
		right: -3%;
		background-size: 92%;
	}
	.flow__cont {
		margin-bottom: 6.5%;
	}
	.flow-display__flex {
		flex-direction: column;
	}
	.item02 .flow-display__flex,
	.item04 .flow-display__flex {
		flex-direction: column-reverse;
	}
	.flow__box {
		background: #fff;
		min-width: 214px;
		width: 61vw;
		height: auto;
		padding: 24px 15px;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
	.flow__img {
		position: relative;
		width: 56.875vw;
		left: -19%;
	}
	
	/* item01 */
	.item01 .flow__boxWrap {
		top: 30%;
		right: 10%;
	}
	.flow01__detail {
        width: 87%;
        margin-top: -17%;
        left: 2%;
        margin-bottom: 45%;
	}
	
	/* item02 */
	.item02 {
		margin-bottom: 7%;
	}
	.item02 .flow__img {
		top: -52%;
        right: 0;
        left: 28%;
	}
	.item02 .flow__box {
        margin-top: 0;
		margin-bottom: 10px;
	}
	
	/* item03 */
	.item03 {
		margin-bottom: 26%;
	}
	.item03 .flow__boxWrap {
		top: 35%;
		right: 10%;
	}
	.item03 .flow__box {
		margin-top: 0;
	}
	
	/* item04 */
    .item04 .flow__img {
		top: -28%;
        right: 0;
        left: 28%;
    }
	.item04 .flow__box {
		max-height: 326px;
		margin-top: 0;
		padding: 24px 15px;
	}
	.item04 .flow__boxWrap .annotation {
		margin: 0;
	}
	.flow__boxTtl {
		font-size: 1.8rem;
		margin-bottom: 10px;
	}
	.flow__boxTxt {
		font-size: 1.4rem;
	}
	.flow__boxIcon {
		margin-top: 10px;
		font-size: 1.2rem;
		text-align: center;
		color: #fff;
		max-width: 84px;
	}
	.item01 .flow__box::after {
		background: url("../images/sp/flow01-number@2x.png") no-repeat;
        background-size: 100%;
        width: 20vw;
        height: 6vh;
	}
	.item02 .flow__box::after {
		background: url("../images/sp/flow02-number@2x.png") no-repeat;
        background-size: 100%;
        width: 20vw;
        height: 6vh;
		left: 45%;
	}
	.item03 .flow__box::after {
		background: url("../images/sp/flow03-number@2x.png") no-repeat;
        background-size: 100%;
        width: 20vw;
        height: 6vh;
	}
	.item04 .flow__box::after {
		background: url("../images/sp/flow04-number@2x.png") no-repeat;
        background-size: 100%;
        width: 20vw;
        height: 6vh;
		left: 45%;
	}
	.pay-wrap {
		flex-direction: column;
	}
	#flow .consent {
		width: 28.5%;
		margin: 0 auto 7% auto;
	}
	.pay-box {
		display: flex;
	}
	.pay {
		margin-top: 10px;
		padding: 20px 23px;
	}
}

/* ==========================================================================
 * form
 * ========================================================================== */
#form {
	padding: 6% 0;
	background: url("../images/pc/voice-bg.jpg") no-repeat top center / cover;
	font-family: a-otf-ryumin-pr6n, serif;
}
.form__detailTxt {
	text-align: center;
	color: #fff;
	margin-bottom: 4.5%;
}
.form__wrap {
	border: solid #fff 2px;
	padding: 6.5% 13%;
	font-family: "Yu Gothic", YuGothic, "Hiragino Kaku Gothic Pro", Meiryo, Osaka, sans-serif;
}
.contact__form-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 4.5%;
}
.contact__form-row-label {
	display: flex;
}
.fw-600 {
	color: #fff;
    font-size: 1.8rem;
    font-weight: bold;
}
.contact__form-required {
	background: #e60012;
	color: #fff;
	padding: 0 16px;
	margin-left: 10px;
}
.contact__form-row--input {
	max-width: 435px;
    width: 100%;
}
.contact__form-row-label--address {
    max-width: 435px;
    width: 100%;
}
.contact__form-row-label--address .contact__form-row--input {
    max-width: 100%;
}
.fw-300 {
	color: #fff;
}
.contact__form-submit {
	justify-content: center; 
}
.contact__form-submit a {
	font-size: 1.8rem;
	color: #acd3ff;
	text-decoration: underline;
}
.contact__form-submit--privacy label {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}
.contact__form-submit--privacy input[type="checkbox"] {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
    cursor: pointer;
    border: solid 1px #fff;
}
.contact__form-submit--button {
	width: 68.6%;
	margin: 0 auto;
	position: relative;
    display: flex;
    justify-content: center;
}
.contact__form-submit--button input[type="submit"] {
	width: 100%;
	background: #009a44;
	padding: 32px 0;
	border-radius: 60px;
	color: #fff;
	text-align: center;
	font-size: 3.2rem;
	font-weight: bold;
	border: none;
	cursor: pointer;
}
.contact__form-submit--button::after {
    content: "";
    display: block;
    width: 28px;
    height: 28px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    transform: translateY(-50%) rotate(45deg);
    position: absolute;
	top: 50%;
    right: 10%;
    pointer-events: none;
}
.none {
	display: none;
}

@media screen and (max-width: 640px) {
	#form {
		padding: 12.5% 0;
		background: url("../images/sp/voice-bg@2x.jpg") no-repeat top center / cover;
	}
	.form__wrap {
		border: solid #fff 1px;
		padding: 10% 6%;
	}
	.contact__form-row {
		flex-direction: column;
		align-items: baseline;
		margin-bottom: 8%;
	}
	.contact__form-row--align-top{
		margin-bottom: 0;
	}
	.contact__form-row-label {
		margin-bottom: 8px;
	}
	.fw-600 {
		font-size: 1.6rem;
	}
	.contact__form-required {
		background: #e60012;
		color: #fff;
		padding: 0 16px;
		margin-left: 10px;
	}
	.contact__form-row--input {
		max-width: 435px;
		width: 100%;
	}
	.contact__form-row-label--address {
		max-width: 435px;
		width: 100%;
	}
	.contact__form-row-label--address .contact__form-row--input {
		max-width: 100%;
	}
	.fw-300 {
		font-size: 1.2rem;
	}
	.contact__form-submit {
		justify-content: center; 
	}
	.contact__form-submit a {
		font-size: 1.6rem;
	}
	.contact__form-submit--privacy label {
		display: flex;
		align-items: center;
		gap: 10px;
		cursor: pointer;
	}
	.contact__form-submit--privacy input[type="checkbox"] {
		width: 20px;
		height: 20px;
		flex-shrink: 0;
		cursor: pointer;
		border: solid 1px #fff;
	}
	.contact__form-submit--button {
		width: 100%;
		margin: 0 auto;
	}
	.contact__form-submit--button input[type="submit"] {
		width: 100%;
		background: #009a44;
		padding: 17px 0;
		border-radius: 60px;
		color: #fff;
		text-align: center;
		font-size: 1.8rem;
		border: none;
	}
	.contact__form-submit--button::after {
		content: "";
		display: block;
		width: 15px;
		height: 15px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		transform: translateY(-50%) rotate(45deg);
		position: absolute;
		top: 50%;
        right: 10%;
		pointer-events: none; /* クリックをinputに透過 */
	}
}

/* ==========================================================================
 * faq
 * ========================================================================== */
.faq {
	padding: 6% 0;
	background: url("../images/pc/faq-bg.jpg") repeat;
	font-family: a-otf-ryumin-pr6n, serif;
}
.faq .section__ttl {
	color: #22324d;
	margin-bottom: 3%;
}
.faq__qaList dl {
	width: 100%;
	margin: 0 auto;
	border-top: solid 1px #22324d;
	border-bottom: solid 1px #22324d;
	margin-bottom: 40px;
}
.faq__qaList dt {
	background: url("../images/pc/q.png") left top no-repeat;
	background-position: 30px 50%;
	padding: 20px 12%;
	font-size: 2.4rem;
	color: #22324d;
	position: relative;
	cursor: pointer;
}
.faq__qaList dd {
	background: url("../images/pc/a.png") left 30px top 3px no-repeat;
	font-size: 1.6rem;
	color: #22324d;
	padding: 0 80px 40px 12%;
	display: none;
}
.line-break {
	margin-top: 30px;
	padding: 20px 0 0 0;
}
.faq__qaList dt.open::before {
	content: "";
	background: url("../images/pc/plus.png") no-repeat;
	display: block;
	position: absolute;
	right: 4%;
	top: 30%;
	width: 30px;
	height: 30px;
}
.faq__qaList dt.close::after {
	content: "";
	background: url("../images/pc/minus.png") no-repeat;
	margin: auto;
    position: absolute;
	top: 0;
    bottom: -35%;
    right: 4%;
	width: 30px;
	height: 30px;
}
.faq p + p {
	margin-top: .5em;
	margin-bottom: 0;
}

@media screen and (max-width: 640px) {
	.faq {
		padding: 15.5% 0;
		background: url("../images/sp/faq-bg@2x.jpg") repeat;
	}
	.faq .section__ttl {
		margin-bottom: 40px;
	}
	.faq__qaList dl {
		margin-bottom: 12.5%;
	}
	.faq__qaList dl:last-of-type {
		margin-bottom: 0;
	}
	.faq__qaList dt {
		background: url("../images/sp/q@2x.png") left top no-repeat;
		background-position: 5px 25px;
        background-size: 15px;
        padding: 7% 15%;
		color: #22324d;
		font-weight: bold;
		position: relative;
		cursor: pointer;
		font-size: 1.6rem;
		display: flex;
		align-items: center;
	}
	.faq__qaList dd {
		background: url("../images/sp/a@2x.png") left top no-repeat;
		background-position: 12px 5px;
		background-size: 15px;
		color: #22324d;
		padding: 0 5% 6% 15%;
		display: none;
		font-size: 1.6rem;
	}
	.line-break {
		margin-top: 30px;
		padding: 20px 0 0 0;
	}
	.faq__qaList dt.open::before {
		content: "";
		background: url("../images/sp/plus@2x.png") no-repeat;
		background-size: 15px;
		display: block;
		position: absolute;
		right: 4%;
		top: 38%;
		width: 15px;
		height: 15px;
	}
	.faq__qaList dt.close::after {
		content: "";
		background: url("../images/sp/minus@2x.png") no-repeat;
		background-size: 15px;
		margin: auto;
		position: absolute;
		top: 0;
		bottom: -16%;
		right: 4%;
		width: 15px;
		height: 15px;
	}
}

/* ==========================================================================
 * company
 * ========================================================================== */
#company {
	background: #fff;
	padding: 6% 0;
}
#company .section__ttl {
	color: #333;
	margin-bottom: 3%;
}
.company__profile {
	margin-bottom: 0;
}
.company__profile--item {
	display: flex;
	font-size: 2rem;
	border-bottom: solid 1px #333;
	padding-bottom: 30px;
	margin-bottom: 50px;
}
.company__profile--item dt {
	width: 25%;
}
.company__profile--item a {
	text-decoration: none;
	color: #333;
}
.company__profile .company__profile--item:last-child {
	margin-bottom: 0;
}

@media screen and (max-width: 640px) {
	#company {
		padding: 15.5% 0;
	}
	.company__profile::before {
		display: none;
	}
	.company__profile--item {
		font-size: 1.6rem;
		padding-bottom: 3%;
		margin-bottom: 6.5%;
	}
}

/* ==========================================================================
 * footer
 * ========================================================================== */
.ft {
	font-family: a-otf-ryumin-pr6n, serif;
	background: #333;
	padding: 20px 0;
}
.copyright {
	text-align: center;
	font-size: 1.8rem;
	font-weight: 300;
	color: #fff;
}
@media screen and (max-width: 640px) {
	.ft {
		padding: 10px 0;
	}
	.copyright {
		font-size: 1.2rem;
	}
}

/* ==========================================================================
 * float
 * ========================================================================== */

@media screen and (max-width: 640px) {
	.ft__cta {
		display: flex;
		justify-content: center;
		background: #fff;
		padding: 10px 6%;
		position: fixed;
		bottom: 0;
		z-index: 999;
		gap: 10px;
		width: 100vw;
	}
}