@charset "UTF-8";
/* =========================================================

First Wave Kit

========================================================= */
/* 共通 */
#wrapper {
	background: none !important;
}
.c_header_logo_link {
	background: #fff;
	width: 100%;
	text-align: center;
	padding: 26px 0;
	top: 0 !important;
}
.c_footer {
	margin-top: 0px !important;
}
#footer {
	margin-top:0;
}
/* 全体 */
#firstwavekit {
	font-weight: 500;
	display: block;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
	letter-spacing: 0.05em;
	color: #232323;
}
@media screen and (max-width: 767px){
	#firstwavekit{
		margin-top: 75px;
	}
}
#firstwavekit * {
	font-family: "Roboto", "Noto Sans JP", sans-serif;
	font-style: normal;
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	line-height: 1;
}
#firstwavekit *::before,
#firstwavekit *::after {
	box-sizing: border-box;
}
#firstwavekit a {
	display: inline-block;
	text-decoration: none;
}
#firstwavekit em {
	font-family: "Roboto", sans-serif;
}
#firstwavekit img {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	max-width: 100%;
}
#firstwavekit button {
	width: 100%;
	box-shadow: none;
}
/* 背景固定 */
.main_inner {
	position: relative;
	z-index: 1;
}
.background_fix {
	background: url(/campaign/firstwavekit/img/paper_background.jpg) repeat-y;
	background-size: cover;
	position: fixed;
	z-index: -1;
	width: calc(960 / 960 * var(--contents_width));
	height: 100vh;
	top: 0;
}
/* MV
------------------------------------------------------ */
#firstwavekit .sec_mv{
	margin-bottom: 9.5%;
}
/* リード
------------------------------------------------------ */
#firstwavekit .sec_lead {
	text-align: center;
	color: #0a0a0a;
	margin-bottom: 10%;
}
#firstwavekit .sec_lead_title {
	font-size: calc(38 / 960 * var(--contents_width));
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 9%;
}
#firstwavekit .sec_lead_title::before,
#firstwavekit .sec_lead_title::after {
	content: "";
	display: inline-block;
	width: calc(3 / 960 * var(--contents_width));
	height: calc(71 / 960 * var(--contents_width));
	background-color: #232323;
}
#firstwavekit .sec_lead_title::before {
	transform: rotate(-25deg);
	margin-right: 2%;
}
#firstwavekit .sec_lead_title::after {
	transform: rotate(25deg);
	margin-left: 2%;
}
#firstwavekit .sec_lead_title span {
	line-height: 1.5;
}
#firstwavekit .sec_lead_title em {
	color: #2477cc;
	font-weight: 600;
	font-family: 'Noto Sans JP';
}
#firstwavekit .sec_lead img {
	display: block;
	width: calc(780 / 960 * var(--contents_width));
	margin: 0 auto 6%;
}
#firstwavekit .sec_lead_text {
	font-size: calc(32 / 960 * var(--contents_width));
	line-height: 1.7;
	margin-bottom: 6%;
}
/* 商品内容
------------------------------------------------------ */
#firstwavekit .sec_set {
	position: relative;
}
#firstwavekit .sec_set_text {
	position: absolute;
	bottom: 11.5%;
	left: 0;
	right: 0;
	width: fit-content;
	margin: auto;
	color: #fff;
	font-size: calc(29 / 960 * var(--contents_width));
	font-weight: 400;
}
#firstwavekit .sec_set_text li {
	line-height: 1.85;
	white-space: nowrap;
}
#firstwavekit .sec_set_text li:before {
	content: "・";
}
/* 商品説明
------------------------------------------------------ */
#firstwavekit .sec_products {
	padding: calc(70 / 960 * var(--contents_width)) calc(90 / 960 * var(--contents_width)) calc(18 / 960 * var(--contents_width));
}
#firstwavekit .sec_products_title {
	font-size: calc(51 / 960 * var(--contents_width));
	color: #212121;
	text-align: center;
	margin-bottom: 10%;
	letter-spacing: 0.1em;
}
#firstwavekit .sec_products_title span {
	display: inline-block;
	border-bottom: solid calc(6 / 960 * var(--contents_width)) #212121;
	padding: 0 0.2em 0.2em;
}
#firstwavekit .sec_products_item {
	margin-bottom: 13%;
}
#firstwavekit .sec_products_item_title {
	background: url(/campaign/firstwavekit/img/products_title.png) no-repeat center;
	background-size: contain;
	margin: 0 2% 5%;
	text-align: center;
}
#firstwavekit .sec_products_item_title span {
	font-size: calc(39 / 960 * var(--contents_width));
	color: #fff;
	font-weight: 600;
	line-height: calc(85 / 960 * var(--contents_width));
}
#firstwavekit #water .sec_products_item_title span {
	font-size: calc(36 / 960 * var(--contents_width));
}
#firstwavekit .sec_products_item_catch {
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #2c73b0;
	font-size: calc(40 / 960 * var(--contents_width));
	font-weight: 500;
	margin-bottom: 4%;
}
#firstwavekit .sec_products_item_catch::before,
#firstwavekit .sec_products_item_catch::after {
	content: "";
	display: inline-block;
	width: calc(4 / 960 * var(--contents_width));
	height: calc(42 / 960 * var(--contents_width));
	background-color: #2c73b0;
}
#firstwavekit .sec_products_item_catch::before {
	transform: rotate(-35deg);
	margin-right: 3%;
}
#firstwavekit .sec_products_item_catch::after {
	transform: rotate(35deg);
	margin-left: 3%;
}
#firstwavekit .sec_products_item_text {
	font-family: "Zen Old Mincho";
	font-size: calc(37 / 960 * var(--contents_width));
	text-align: center;
	line-height: 1.7;
	margin-bottom: 4.5%;
	font-weight: 700;
}
#firstwavekit .sec_products_item_grid {
	display: grid;
	grid-template-columns: calc(422 / 960 * var(--contents_width)) 1fr;
	align-items: end;
	gap: calc(85 / 960 * var(--contents_width));
	margin: 0 auto 5%;
}
#firstwavekit .sec_products_item_grid_text {
	white-space: nowrap;
	font-size: calc(37 / 960 * var(--contents_width));
	margin-bottom: 4%;
}
#firstwavekit .sec_products_item_grid_text_title {
	display: inline-block;
	background-color: #222222;
	color: #fff;
	padding: 1px 0.8em 0;
	line-height: 1.3;
	letter-spacing: 0.08em;
	font-size: calc(38 / 960 * var(--contents_width));
	margin-bottom: 5.5%;
}
#firstwavekit .sec_products_item_grid_text_date {
	line-height: 1.5;
	font-weight: 500;
}
#firstwavekit .sec_products_item_btn_date a {
	font-size: calc(31 / 960 * var(--contents_width));
	line-height: 1.20;
	position: relative;
	display: grid;
	height: calc(112 / 960 * var(--contents_width));
	padding-right: 6%;
	text-align: center;
	border-radius: calc(5 / 960 * var(--contents_width));
	background-color: #00ceae;
	place-items: center;
	font-weight: 500;
}
#firstwavekit .sec_products_item_btn_date a:hover {
	color: #232323;
}
#firstwavekit .sec_products_item_btn_date:first-of-type a {
	margin-bottom: 3.5%;
	text-align: left;
	color: #fff;
	background-color: #090808;
}
#firstwavekit .sec_products_item_btn_date:first-of-type .dc_arrow::after {
	border-top-color: #45aad7;
	border-right-color: #45aad7;
}


#firstwavekit .sec_products_item_btn_date a::after {
	display: inline-block;
	width: 1.8em;
	height: 1.8em;
	margin-right: -0.8em;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 24 24' fill='none' stroke='%23232323' stroke-width='1.5' stroke-linecap='butt' stroke-linejoin='arcs'%3E%3Cpath d='M9 18l6-6-6-6'/%3E%3C/svg%3E");
	background-position: center;
	background-size: contain;
	background-repeat: no-repeat;
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 3%;
}
#firstwavekit .sec_products_item_btn_date:first-of-type a::after {
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='1.5' stroke-linecap='butt' stroke-linejoin='arcs'%3E%3Cpath d='M9 18l6-6-6-6'/%3E%3C/svg%3E");
}
/* ----- モーダル・スライド ----- */
.sec_products_modal {
	position: relative;
	width: calc(865 / 960 * var(--contents_width));
	margin: 0 auto;
	padding: calc(62 / 960 * var(--contents_width));
	background: #faf4ee;
}
.sec_products_modal .swiper {
	overflow: hidden;
	background-color: #ffffff;
}
.sec_products_modal .swiper::before {
	content: "";
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
	position: absolute;
	z-index: 2;
	top: 0;
	left: 0;
	width: 32%;
	max-width: 112px;
	padding: 4px 0 5px;
	text-align: center;
	letter-spacing: 0.2em;
	color: #fff;
}
.swiper-slide {
	display: flex;
	align-items: center;
	background-color: #fff;
}
.modal_spec {
	margin-bottom: 5%;
	padding: 5%;
	border: calc(4 / 960 * var(--contents_width)) solid #00a0e9;
	background: #fff;
}
.modal_slider {
	position: relative;
}
.swiper-button-next {
	z-index: 1000;
	right: -2%;
	width: calc(70 / 960 * var(--contents_width));
	height: calc(70 / 960 * var(--contents_width));
	transition: opacity 0.2s;
	transform: translateY(-50%);
	background-image: url(/campaign/firstwavekit/img/slide_next_arrow.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	image-rendering: -webkit-optimize-contrast;
}
.swiper-pagination {
	font-size: calc(22 / 960 * var(--contents_width));
	font-weight: 600;
	position: relative;
	bottom: 0;
	margin-top: 2%;
	text-align: right;
	color: #32627f;
}
.swiper-button-next:after,
.swiper-container-rtl .swiper-button-prev:after {
	display: none;
}
.swiper-button-next::after {
	display: none;
}
/* ----- レンズスペック ----- */
.modal_spec_main {
	width: 100%;
}
.modal_spec_title {
	width: calc(270 / 960 * var(--contents_width));
	margin: 0 auto 3%;
}
.modal_spec_subtitle {
	font-size: calc(28 / 960 * var(--contents_width));
	font-weight: 700;
	line-height: 1.36364;
	margin-bottom: 3%;
	padding: 3% 0 2.5%;
	text-align: center;
	letter-spacing: 0.15em;
	color: #fff;
	background-color: #00a0e9;
}
.modal_spec_table_wrap {
	display: flex;
	width: 100%;
}
.modal_spec_table {
	width: 50%;
	margin: 0;
}
.modal_spec_table:nth-child(1) {
	margin-right: 1%;
}
.modal_spec_table:nth-child(2) {
	margin-left: 1%;
}
.modal_spec_table th {
	font-size: calc(21 / 960 * var(--contents_width));
	font-weight: 700;
	line-height: 1.4;
	width: 35%;
	padding: 2% 5%;
	text-align: left;
	vertical-align: middle;
	letter-spacing: 0.075em;
	border: 1px solid #c9c9c9;
	background-color: #f2f2f2;
}
.modal_spec_table td {
	font-size: calc(21 / 960 * var(--contents_width));
	font-weight: 700;
	line-height: 1.4;
	padding: 2% 5%;
	text-align: left;
	vertical-align: middle;
	letter-spacing: 0.075em;
	border: 1px solid #c9c9c9;
	background-color: #ffffff;
}
.modal_spec_table .small {
	font-size: 0.8em;
	line-height: 1.2;
	display: inline-block;
}
.modal_spec_note {
	font-size: calc(21 / 960 * var(--contents_width));
	font-weight: 500;
	line-height: 1.6;
	margin-top: 3%;
	text-align: left;
	letter-spacing: 0.075em;
	color: #22224a;
}
/* COUPONクーポン
------------------------------------------------------ */
#firstwavekit .sec_coupon {
	position: relative;
	padding: calc(112 / 960 * var(--contents_width)) calc(90 / 960 * var(--contents_width)) calc(64 / 960 * var(--contents_width));
	background-color: #232323;
}
#firstwavekit .sec_coupon_title {
	margin-bottom: calc(60 / 960 * var(--contents_width));
}
#firstwavekit .sec_coupon_img {
	margin-bottom: 16%;
}
#firstwavekit .sec_coupon_area {
	font-weight: 600;
	margin-bottom: 7%;
	padding: calc(56 / 960 * var(--contents_width)) calc(52 / 960 * var(--contents_width)) calc(44 / 960 * var(--contents_width));
	text-align: center;
	background-color: #fff;
	position: relative;
}
#firstwavekit .sec_coupon_area_title {
	font-size: calc(35 / 960 * var(--contents_width));
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	margin: -5% auto 0;
	width: calc(590 / 960 * var(--contents_width));
	padding-left: 0.2em;
	letter-spacing: 0.08em;
	background: linear-gradient(45deg, #2e79af, #4acf98);
	color: #fff;
	transform: skewX(-27deg);
}
#firstwavekit .sec_coupon_area_title span {
	display: block;
	line-height: 2.25;
	transform: skewX(27deg);
}
#firstwavekit .sec_coupon_area_before {
	display: flex;
	align-items: center;
	width: calc(520 / 960 * var(--contents_width));
	margin: 0 auto;
}
#firstwavekit .sec_coupon_area_before_text_day {
	font-size: calc(28 / 960 * var(--contents_width));
	white-space: nowrap;
	display: block;
}
#firstwavekit .sec_coupon_area_before_text_box {
	font-size: calc(27 / 960 * var(--contents_width));
	line-height: 1.8;
	border: 1px solid;
	letter-spacing: 0.1em;
	margin-top: 3%;
}
#firstwavekit .sec_coupon_area_before_price {
	font-size: calc(58 / 960 * var(--contents_width));
}
#firstwavekit .sec_coupon_area_before_price {
	font-size: calc(58 / 960 * var(--contents_width));
	white-space: nowrap;
	margin-left: 3%;
	position: relative;
}
#firstwavekit .sec_coupon_area_before_price::before {
	content: "";
	display: block;
	width: 100%;
	height: 2px;
	background: #232323;
	position: absolute;
	inset: 0;
	margin: auto;
	top: 6%;
}
#firstwavekit .sec_coupon_area_before_price em {
	font-size: calc(115 / 960 * var(--contents_width));
	letter-spacing: -0.04em;
	margin-right: 0.04em;
}
#firstwavekit .sec_coupon_area_arrow{
	width: calc(34 / 960 * var(--contents_width));
	margin: 1% auto 2%;
}
#firstwavekit .sec_coupon_area_after {
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.5%;
	/* padding: 0 2%; */
}
#firstwavekit .sec_coupon_area_after_text {
	font-size: calc(47 / 960 * var(--contents_width));
	letter-spacing: 0.1em;
	line-height: 1.1;
	padding: 0.5em;
	padding-right: 0.4em;
	border: 1px solid;
	white-space: nowrap;
	font-weight: 600;
}
#firstwavekit .sec_coupon_area_after_price {
	font-size: calc(96 / 960 * var(--contents_width));
	margin-left: 3%;
	color: #06a88f;
	white-space: nowrap;
}
#firstwavekit .sec_coupon_area_after_price em {
	font-size: calc(226 / 960 * var(--contents_width));
	letter-spacing: -0.05em;
	margin-right: 2%;
	line-height: 0.8;
}
#firstwavekit .sec_coupon_area_text_left {
	font-size: calc(40 / 960 * var(--contents_width));
	position: relative;
	width: calc(232 / 960 * var(--contents_width));
}
#firstwavekit .sec_coupon_area_text_left::before {
	content: "";
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 5%;
	width: 100%;
	height: 1.9em;
	margin-bottom: -5%;
	border: calc(4 / 960 * var(--contents_width)) solid #3d70f1;
	border-radius: calc(5 / 960 * var(--contents_width));
}
#firstwavekit .sec_coupon_area_text_left span {
	line-height: 1.7;
	position: relative;
	z-index: 2;
	display: block;
	border: calc(4 / 960 * var(--contents_width)) solid #3d70f1;
	border-radius: calc(5 / 960 * var(--contents_width));
	background: #fff;
}
#firstwavekit .sec_coupon_area_text_center {
	font-size: calc(50 / 960 * var(--contents_width));
	display: inline-block;
	margin-left: 2%;
}
#firstwavekit .sec_coupon_area_text_right {
	font-size: calc(49 / 960 * var(--contents_width));
	display: inline-block;
	padding-bottom: 1%;
	border-bottom: calc(4 / 960 * var(--contents_width)) solid #3d70f1;
}
#firstwavekit .sec_coupon_area_text_point {
	font-size: 1.25em;
}
#firstwavekit .sec_coupon_area_text_point em {
	font-size: calc(82 / 960 * var(--contents_width));
	vertical-align: text-bottom;
	letter-spacing: 0.08em;
}
#firstwavekit .sec_coupon_code {
	margin-bottom: 2%;
	border: 1px solid #06a88f;
	display: flex;
	justify-content: space-between;
	align-items: revert-layer;
}
#firstwavekit .sec_coupon_code_text {
	background: #06a88f;
	width: 50%;
	display: grid;
	place-items: center;
	color: #fff;
	font-size: calc(24 / 960 * var(--contents_width));
}
#firstwavekit .sec_coupon_code_code {
	width: 50%;
	font-size: calc(56 / 960 * var(--contents_width));
	line-height: 1.4;
}
#firstwavekit .sec_coupon_attend {
	font-size: calc(21 / 960 * var(--contents_width));
	line-height: 1.5;
	display: flex;
	text-align: left;
}
#firstwavekit .sec_coupon_attend::before {
	content: "※";
}
#firstwavekit .sec_coupon_attend:first-of-type{
	color: #06a88f;
	font-weight: 700;
}
#firstwavekit .coupon_howto_btn {
	font-size: calc(33 / 960 * var(--contents_width));
	display: block;
	text-align: center;
	color: #06a88f;
	font-weight: 500;
}
#firstwavekit .coupon_howto_btn::after {
	content: "?";
	font-family: "Roboto", sans-serif;
	line-height: calc(48 / 960 * var(--contents_width));
	display: inline-grid;
	font-size: calc(38 / 960 * var(--contents_width));
	width: calc(48 / 960 * var(--contents_width));
	height: calc(48 / 960 * var(--contents_width));
	margin-left: 0.3em;
	text-align: center;
	color: #232323;
	border-radius: 50%;
	background-color: #06a88f;
	place-items: center;
	font-weight: 900;
}
/* Ajaxカートモーダル CSS制御 */
.aui_modal_product_cart_select_form {
	display: none !important;
}
.js_mfp_ajax.aui_modal_product_cart_detail_btn {
	display: none !important;
}


/* 注意事項
------------------------------------------------------ */
#firstwavekit .sec_attend{
	background: #232323;
}
#firstwavekit .sec_attend_title{
	font-size: calc(46 / 960 * var(--contents_width));
	color: #232323;
	text-align: center;
	background: #06a88f;
	text-align: center;
	padding: 6% 0;
}
#firstwavekit .sec_attend_title::before {
	content: "";
	display: inline-block;
	width: calc(60 / 960 * var(--contents_width));
	height: calc(51 / 960 * var(--contents_width));
	background: url(/campaign/firstwavekit/img/attend_icon.png) no-repeat center;
	background-size: contain;
	vertical-align: sub;
	margin-right: 1%;
}
#firstwavekit .sec_attend_inner{
	padding: calc(80 / 960 * var(--contents_width)) calc(90 / 960 * var(--contents_width)) calc(92 / 960 * var(--contents_width));
}
#firstwavekit .sec_attend_img{
	margin-bottom: 7.5%;
}
#firstwavekit .sec_attend_text{
	color:#fff;
	font-size:calc(28 / 960 * var(--contents_width));
	line-height: 1.75;
	margin-bottom: 6%;
	letter-spacing: 0.07em;
	font-weight: 400;
}
#firstwavekit .sec_attend_text_point{
	display:flex;
}
#firstwavekit .sec_attend_text_point::before{
	content:"※";
}

/* 購入はこちら
------------------------------------------------------ */
#firstwavekit .sec_cart{
	padding: calc(115 / 960 * var(--contents_width)) calc(50 / 960 * var(--contents_width)) calc(92 / 960 * var(--contents_width));
	background-color:#fff;
}
#firstwavekit .sec_cart_title{
	font-size:calc(48 / 960 * var(--contents_width));
	text-align:center;
	margin-bottom: 9.5%;
}

/* カート上書き
--------------------------------------- */
#firstwavekit .aui_goods_data_box{
	margin-bottom:5%
}
#firstwavekit .aui_goods_data_item {
	margin-top: 4%;
}

#firstwavekit .aui_goods_data_itemx:first-child {
	margin-top: 0;
}

#firstwavekit .aui_goods_data_title {
	padding: 4.45% 0 ;
}

#firstwavekit .aui_goods_data_content {
	padding: 0 4.5% 5%;
}

#firstwavekit .aui_goods_data_name {
	text-align: left;
}

#firstwavekit .goods_omake_box {
	margin: 10% auto 6%;
	border: 0;
}

#firstwavekit .goods_omake_title {
	padding: 4.45% 0;
}

#firstwavekit .goods_omake_content {
	padding: 4.45% 0;
}
#firstwavekit .aui_goods_data_box select{
	padding:0 30px 0 16px;
}
#firstwavekit .aui_goods_cart_btn {
	margin: 8% 0 0;
}
#firstwavekit .sec_cart_attend{
	font-size: calc(27 / 960 * var(--contents_width));
	color: #555;
	line-height: 1.5;
	display:flex;
	margin-top: 3%;
}
#firstwavekit .sec_cart_attend::before{
	content:"※";
}

/* 固定ボタン
--------------------------------------- */
#firstwavekit .fixed_btn {
	display: none;
	z-index: 1;
	position: fixed;
	left: 0;
	right: 0;
	bottom: 78px;
	width: min(81.5%,300px);
	margin: auto;
}
@media screen and (min-width: 768px) {
	#firstwavekit .fixed_btn {
		left:auto;
		bottom: 80px;
	}
}
#page_top_button {
	display: none !important;
	bottom: 40px;
}