/* ==================================================
	base
================================================== */

:root {
	--Electric-Blue: #024ad8;
	--Power-Storm: #568393;
	--Orange-Bloom: #ff5050;
}



/* ----------------------------------------
	breadcrumbs, title
---------------------------------------- */

.page_title_area_aem {
	display: none;
}

@media screen and (max-width: 1023px) {
	.breadcrumbs.for_mobile {
		display: none;
	}
}

@media screen and (min-width: 1024px) {
	.breadcrumbs.for_pc {
		display: none;
	}
}



/* ----------------------------------------
	page_top
---------------------------------------- */

@media screen and (min-width: 1024px) {
	.page_top {
		margin-top: 40px;
	}
}



/* ----------------------------------------
	image
---------------------------------------- */

.main_content img {
	height: auto;
}
.main_content a:hover img {
	opacity: 1;
}



/* ----------------------------------------
	strong
---------------------------------------- */

.main_content strong {
	color: var(--Electric-Blue);
	font-weight: normal;
}



/* ----------------------------------------
	sup
---------------------------------------- */

.main_content a.sup:link,
.main_content a.sup:visited,
.main_content a.sup:hover {
	color: var(--Electric-Blue);
}



/* ----------------------------------------
	footnote
---------------------------------------- */

.main_content .footnote > li,
.main_content p.footnote {
	color: #75787F;
	font-size: 12px;
}



/* ----------------------------------------
	button
---------------------------------------- */

.main_content .button {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	min-height: 36px;
	padding: 6px 12px;
	font-size: 16px;
	text-align: center;
	border-radius: 0;
}


/* color -------------------- */

/* primary */
.main_content .button.primary {
	background: #000;
}
.main_content .button.primary:hover {
	background: #5a5a5a;
}

/* white */
.main_content .button.white:link,
.main_content .button.white:visited,
.main_content .button.white:hover {
	color: #000;
}
.main_content .button.white:hover {
	background: #ECF1FA;
}


/* large -------------------- */

.main_content .button.large {
	min-height: 52px;
	padding: 8px 16px;
	font-size: 16px;
}

@media screen and (min-width: 720px) {
	.main_content .button.large {
		font-size: 18px;
	}
}

@media screen and (min-width: 1024px) {
	.main_content .button.large {
		font-size: 20px;
	}
}



/* ----------------------------------------
	modal
---------------------------------------- */

.main_content .modal_content {
	padding: 16px;
	color: #75787F;
	border: none;
	box-shadow: 0 0 16px 0 rgb(0 0 0 / .1);
}
.main_content .modal_content_inner {
	padding: 0;
}
.main_content .modal_close::before,
.main_content .modal_close::after {
	content: none;
}
.main_content .modal_close {
	transform: none;
	width: 24px;
	height: 24px;
	background: url(images/modal_close.png) no-repeat center center / cover;
}

@media screen and (max-width: 1023px) {
	.main_content .modal_content {
		padding-bottom: 52px;
	}
	.main_content .modal_close {
		top: auto;
		right: auto;
		bottom: 16px;
		left: 16px;
	}
}

@media screen and (min-width: 1024px) {
	.main_content .modal_content {
		width: 761px;
		padding-right: 52px;
	}
	.main_content .modal_close {
		top: 16px;
		right: 16px;
	}
}





/* ==================================================
	heading
================================================== */

.main_content h1,
.main_content h2,
.main_content h3,
.main_content h4,
.main_content h5,
.main_content h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
	font-weight: normal;
	line-height: 1.375;
}
.h1 {
	font-family: "FormaDJRJapaneseDisplay";
}
.h1 { font-size: 28px; }
.h2 { font-size: 22px; }
.h3 { font-size: 16px; }

@media screen and (max-width: 479px) {
	.h1 { font-size: 26px; }
}

@media screen and (min-width: 720px) {
	.h1 { font-size: 35px; }
	.h2 { font-size: 23px; }
	.h3 { font-size: 18px; }
}

@media screen and (min-width: 1024px) {
	.h1 { font-size: 42px; }
	.h2 { font-size: 24px; }
	.h3 { font-size: 20px; }
}





/* ==================================================
	navi（local_naviとtabの共通スタイル）
================================================== */

.navi_list {
	display: flex;
}
.navi_list > li a {
	display: grid;
	align-items: center;
	position: relative;
	text-decoration: none !important;
	background: #fff;
}
.navi_list > li a::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	opacity: 0;
	transition: .4s;
	width: 100%;
	background: var(--Electric-Blue);
}
.navi_list > li a:hover::after,
.navi_list > li.current a::after {
	opacity: 1;
}
.navi_list > li:nth-child(n+3) a::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 1px;
	background: #C9CFDE;
}
.navi_list .cont h2 {
	color: #000;
}
.navi_list .cont p {
	color: #858B99;
}

@media screen and (max-width: 1023px) {
	.navi {
		width: 100vw;
		margin-right: calc(50% - 50vw);
		margin-left: calc(50% - 50vw);
	}
	.navi_list .for_pc {
		display: none;
	}
	.navi_list {
		overflow-x: scroll;
		overflow-y: visible;
		padding: 0 16px;
		background: none;
	}
	.navi_list > li {
		flex: 1;
		background: none;
		border-top: none;
	}
	.navi_list > li:nth-child(1) {
		margin-right: 10px;
	}
	.navi_list > li:last-child {
		border-bottom: none;
	}
	.navi_list > li a {
		grid-template-columns: 30px 1fr;
		gap: 6px;
		height: 73px;
		padding: 0 10px;
		white-space: nowrap;
	}
	.navi_list > li a::after {
		height: 4px;
	}
	.navi_list > li:nth-child(n+3) a::before {
		height: 33px;
	}
	.navi_list .cont h2 {
		font-size: 16px;
	}
	.navi_list .cont p {
		font-size: 10px;
	}
}

@media screen and (min-width: 1024px) {
	.navi_list .for_sp {
		display: none;
	}
	.navi_list > li:nth-child(1) {
		width: 245px;
		margin-right: 16px;
	}
	.navi_list > li:nth-child(3) {
		flex: 1;
	}
	.navi_list > li a {
		grid-template-columns: 62px 1fr;
		gap: 15px;
		height: 115px;
		padding: 0 12px;
	}
	.navi_list > li a::after {
		height: 6px;
	}
	.navi_list > li:nth-child(n+3) a::before {
		height: 57px;
	}
	.navi_list .cont h2 {
		font-size: 18px;
	}
	.navi_list .cont p {
		font-size: 12px;
	}
}


/* type -------------------- */

.navi_list {
	padding-top: 11px;
}
.navi_list > li {
	position: relative;
}
.navi_list > li::after {
	position: absolute;
	top: -11px;
	z-index: 1;
	height: 22px;
	padding: 0 8px;
	font-size: 13px;
	line-height: 22px;
	white-space: nowrap;
	border-radius: 100px;
}
.navi_list > li:nth-child(1)::after {
	content: "\30A4\30F3\30AF\30BF\30F3\30AF\5F0F"; /* インクタンク式 */
	left: 50%;
	transform: translateX(-50%);
	background: #BDC5D8;
}
.navi_list > li:nth-child(2)::after {
	content: "\30AB\30FC\30C8\30EA\30C3\30B8\5F0F"; /* カートリッジ式 */
	left: 38px;
	background: #ACBCE3;
}

@media screen and (min-width: 1024px) {
	.navi_list {
		padding-top: 15px;
	}
	.navi_list > li::after {
		top: -15px;
		padding: 0 12px;
		height: 30px;
		font-size: 14px;
		line-height: 30px;
	}
	.navi_list > li:nth-child(2)::after {
		left: 308px;
	}
}





/* ==================================================
	hero
================================================== */

.hero {
	position: relative;
}
.hero::before {
	content: "";
	position: absolute;
	top: 75.20161290322581%;
	left: 0;
	width: 100%;
	height: calc(100% - 75.20161290322581%);
	background: #D5DDED;
}
.hero > .cont {
	position: absolute;
	top: 0;
	left: 0;
	padding: 32px 16px 0;
	color: #fff;
}
.hero > .cont .h1 span {
	display: block;
}
.hero > .media {
	position: relative;
	width: 100%;
	max-width: 1512px;
	margin: 0 auto;
}
.hero > .media img {
	object-fit: cover;
	object-position: right;
}

@media screen and (max-width: 479px) {
	.hero > .cont {
		padding-top: 20px;
	}
}

@media screen and (max-width: 719px) {
	.hero > .media img {
		min-height: 496px;
	}
	.hero > .cont .h1 span {
		margin-bottom: 6px;
		font-size: 24px;
	}
}

@media screen and (min-width: 720px) {
	.hero::before {
		top: 559px;
		height: calc(950px - 559px);
	}
	.hero > .media img {
		height: 950px;
	}
}

@media screen and (min-width: 1024px) {
	.hero > .cont {
		top: 93px;
		left: 50%;
		transform: translateX(-50%);
		width: 100%;
		max-width: 1000px;
		padding: 0;
	}
	.hero > .cont .h1 br {
		display: none;
	}
}



/* ----------------------------------------
	share_no1
---------------------------------------- */

.hero .share_no1 {
	display: flex;
	align-items: flex-start;
	gap: 8px;
	margin-top: 10px;
}
.hero .share_no1 > .cont {
	font-size: 16px;
}
.hero .share_no1 > .cont p.footnote {
	margin-top: 5px;
	color: #fff;
	font-size: 10px;
}
.hero .share_no1 > .media {
	width: 78px;
	min-width: 78px;
}

@media screen and (min-width: 720px) {
	.hero .share_no1 {
		flex-direction: row-reverse;
		align-items: center;
		gap: 25px;
		width: max-content;
		margin-top: 32px;
	}
	.hero .share_no1 > .cont {
		font-size: 24px;
	}
	.hero .share_no1 > .cont p.footnote {
		margin-top: 10px;
		font-size: 13px;
	}
	.hero .share_no1 > .media {
		width: 127px;
		min-width: 127px;
	}
}





/* ==================================================
	section
================================================== */

.section {
	padding: 40px 16px;
}

@media screen and (min-width: 1024px) {
	.section {
		padding: 100px 0;
	}
}





/* ==================================================
	choose
================================================== */

.choose {
	background: #D5DDED;
}





/* ==================================================
	reason（HPプリンターを選ぶ理由）
================================================== */

.reason {
	position: relative;
	margin-top: calc(-34% - 40px);
}
.reason h2 {
	display: inline-flex;
	align-items: center;
	height: 40px;
	padding: 0 10px;
	color: #fff;
	font-size: 20px;
	background: rgb(2 74 216 / .6);
}

@media screen and (max-width: 479px) {
	.reason {
		margin-top: calc(-122px - 40px);
	}
}

@media screen and (min-width: 720px) {
	.reason {
		margin-top: calc(-456px - 40px);
	}
}

@media screen and (min-width: 1024px) {
	.reason {
		margin-top: calc(-494px - 100px);
	}
}



/* ----------------------------------------
	reason_list
---------------------------------------- */

.reason_list {
	display: grid;
	gap: 12px 8px;
}
.reason_list > li {
	background: #fff;
}
.reason_list .cont {
	padding: 20px;
	font-size: 15px;
}
.reason_list .cont * + p {
	margin-top: 8px;
}
.reason_list .media img {
	width: 100%;
}

@media screen and (min-width: 720px) {
	.reason_list {
		grid-template-columns: repeat(2, 1fr);
	}
	.reason_list > li {
		display: flex;
		flex-direction: column;
	}
	.reason_list > li:nth-child(even) {
		flex-direction: column-reverse;
		justify-content: flex-end;
	}
	.reason_list > li:nth-child(odd) .media {
		margin-top: auto;
	}
}

@media screen and (min-width: 1024px) {
	.reason_list .cont {
		padding: 32px;
	}
}





/* ==================================================
	for_you（あなたにぴったりのプリンターは？）
================================================== */

.for_you {
	margin-top: 40px;
}



/* ----------------------------------------
	for_you_header
---------------------------------------- */

.for_you_header .cont p {
	margin-top: 1em;
}

@media screen and (max-width: 719px) {
	.for_you_header {
		display: flex;
		flex-direction: column-reverse;
		gap: 16px;
	}
	.for_you_header .cont {
		font-size: 16px;
	}
	.for_you_header .media {
		text-align: center;
	}
}

@media screen and (min-width: 720px) {
	.for_you_header {
		display: grid;
		grid-template-columns: 1fr 203px;
		gap: 30px;
		align-items: center;
	}
	.for_you_header .cont {
		font-size: 18px;
	}
}



/* ----------------------------------------
	for_you_type
---------------------------------------- */

.for_you_type {
	display: grid;
	gap: 8px;
	margin: 20px 0 32px;
}
.for_you_type > li {
	padding: 15px 20px;
}
.for_you_type > li.inktank {
	background: #BDC5D8;
}
.for_you_type > li.cartridge {
	background: #ACBCE3;
}
.for_you_type > li > div {
	display: grid;
	grid-template-columns: 1fr 106px;
	align-items: center;
	gap: 10px;
}
.for_you_type_header h3 {
	font-size: 24px;
}
.for_you_type_header p {
	margin-top: 8px;
	color: #64749B;
}
.for_you_type_body {
	padding-top: 10px;
	margin-top: 10px;
	border-top: 1px solid #fff;
}
.for_you_type_body .cont {
	font-size: 16px;
}

@media screen and (max-width: 479px) {
	.for_you_type > li > div {
		grid-template-columns: 1fr 70px;
	}
	.for_you_type_body {
		padding-top: 15px;
		margin-top: 15px;
	}
}

@media screen and (min-width: 720px) {
	.for_you_type {
		grid-template-columns: repeat(2, 1fr);
		margin-top: 28px;
	}
}

@media screen and (min-width: 1024px) {
	.for_you_type {
		margin-bottom: 60px;
	}
}



/* ----------------------------------------
	local_navi
---------------------------------------- */

.local_navi_fixed {
	background: #D5DDED;
}

@media screen and (max-width: 1023px) {
	.local_navi_fixed {
		left: 0;
	}
}


/* local_naviを隠す -------------------- */

.local_navi {
	transition: .4s;
}
.local_navi_end .local_navi {
	transform: translateY(-100%);
}


/* content（ページ内リンクのズレ調整） -------------------- */

@media screen and (max-width: 1023px) {
	.for_you .content {
		padding-top: 84px;
		margin-top: -84px;
	}
}





/* ==================================================
	series
================================================== */

.series {
	margin-top: 20px;
	background: #fff;
}

@media screen and (min-width: 720px) {
	.series {
		margin-top: 60px;
		background: #fff url(images/series.png) no-repeat right top;
	}
}



/* ----------------------------------------
	series_header
---------------------------------------- */

.series_header .copy {
	color: var(--Electric-Blue);
}

@media screen and (max-width: 719px) {
	.series_header .cont {
		padding: 20px;
	}
	.series_header .media {
		padding: 10px 20px 40px;
		text-align: center;
		background: url(images/series_sp.png) no-repeat right top / cover;
	}
}

@media screen and (min-width: 720px) {
	.series_header {
		display: grid;
		grid-template-columns: 1fr 28.88888888888889%;
		align-items: center;
		gap: 40px;
		padding: 20px 50px 30px;
	}
}



/* ----------------------------------------
	series_body
---------------------------------------- */

.series_body {
	display: grid;
	row-gap: 20px;
	padding: 0 20px 40px;
	margin-top: -22px;
}

@media screen and (min-width: 720px) {
	.series_body {
		row-gap: 40px;
		padding: 0 50px 50px;
		margin-top: 0;
	}
}



/* ----------------------------------------
	series_recommend
---------------------------------------- */

.series_recommend {
	padding: 20px;
	background: #ECF1FA;
}
.series_recommend h3 {
	margin-bottom: 8px;
	font-size: 18px;
}
.series_recommend_list {
	display: grid;
	row-gap: 6px;
}
.series_recommend_list > li {
	position: relative;
	padding-left: 18px;
	font-size: 16px;
}
.series_recommend_list > li::before {
	content: "\25CF";
	position: absolute;
	left: 0;
	width: 10px;
	color: #7B9FE5;
	text-align: center;
}

@media screen and (min-width: 720px) {
	.series_recommend {
		padding: 24px 28px 20px;
	}
	.series_recommend h3 {
		margin-bottom: 12px;
		font-size: 20px;
	}
}



/* ----------------------------------------
	series_links
---------------------------------------- */

.series_links {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}





/* ==================================================
	hp_smart_app（HP Smartアプリ）
================================================== */

.hp_smart_app {
	margin-top: 40px;
}

@media screen and (min-width: 720px) {
	.hp_smart_app {
		margin-top: 100px;
	}
}



/* ----------------------------------------
	hp_smart_app_header
---------------------------------------- */

@media screen and (max-width: 719px) {
	.hp_smart_app_header .cont {
		display: none;
	}
}

@media screen and (min-width: 720px) {
	.hp_smart_app_header {
		position: relative;
		margin-top: 100px;
	}
	.hp_smart_app_header .cont {
		position: absolute;
		top: 50%;
		left: 50px;
		transform: translateY(-50%);
		color: #fff;
	}
}



/* ----------------------------------------
	hp_smart_app_body
---------------------------------------- */

.hp_smart_app_body {
	display: flex;
	flex-direction: column;
	gap: 40px;
	padding: 20px;
	background: #fff;
}
.hp_smart_app_body h3 {
	color: var(--Electric-Blue);
	font-size: 18px;
}

@media screen and (min-width: 720px) {
	.hp_smart_app_body {
		gap: 50px;
		padding: 50px;
	}
}



/* ----------------------------------------
	hp_smart_app_features
---------------------------------------- */

.hp_smart_app_features > .media {
	text-align: center;
}

@media screen and (max-width: 1023px) {
	.hp_smart_app_features .media {
		margin-top: -20px;
	}
	.hp_smart_app_features .media + .cont {
		margin-top: -66px;
	}
	.hp_smart_app_features .cont + .cont {
		margin-top: 40px;
	}
}

@media screen and (min-width: 1024px) {
	.hp_smart_app_features {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.hp_smart_app_features > :nth-child(1) {
		order: 2;
	}
	.hp_smart_app_features > :nth-child(2) {
		order: 1;
	}
	.hp_smart_app_features > :nth-child(3) {
		order: 3;
	}
	.hp_smart_app_features .media {
		width: 183px;
	}
	.hp_smart_app_features .cont {
		width: 332px;
	}
}


/* hp_smart_app_features_list -------------------- */

.hp_smart_app_features_list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}
.hp_smart_app_features_list > li {
	padding: 16px;
	background: #EAEDF4;
}
.hp_smart_app_features_list > li > * + * {
	margin-top: 8px;
}



/* ----------------------------------------
	hp_smart_app_chara
---------------------------------------- */

.hp_smart_app_chara_list {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

@media screen and (max-width: 719px) {
	.hp_smart_app_chara_list .title {
		display: flex;
		align-items: center;
		gap: 10px;
		margin-bottom: 15px;
	}
	.hp_smart_app_chara_list > li:nth-child(even) .title {
		flex-direction: row-reverse;
	}
	.hp_smart_app_chara_list > li .title::before {
		content: "";
		width: 80px;
		min-width: 80px;
		height: 80px;
		background-repeat: no-repeat;
		background-position: 0 0;
		background-size: cover;
	}
	.hp_smart_app_chara_list > li:nth-child(1) .title::before {
		background-image: url(images/hp_smart_app_chara_setup.png);
	}
	.hp_smart_app_chara_list > li:nth-child(2) .title::before {
		background-image: url(images/hp_smart_app_chara_shortcut.png);
	}
	.hp_smart_app_chara_list > li:nth-child(3) .title::before {
		background-image: url(images/hp_smart_app_chara_correction.png);
	}
	.hp_smart_app_chara_list h3 {
		width: calc(100% - 90px);
	}
}

@media screen and (min-width: 720px) {
	.hp_smart_app_chara_list {
		gap: 40px;
	}
	.hp_smart_app_chara_list > li {
		display: flex;
		align-items: center;
		gap: 50px;
	}
	.hp_smart_app_chara_list > li:nth-child(even) {
		flex-direction: row-reverse;
	}
	.hp_smart_app_chara_list > li::before {
		content: "";
		width: 151px;
		height: 151px;
		background-repeat: no-repeat;
		background-position: 0 0;
	}
	.hp_smart_app_chara_list > li:nth-child(1)::before {
		background-image: url(images/hp_smart_app_chara_setup.png);
	}
	.hp_smart_app_chara_list > li:nth-child(2)::before {
		background-image: url(images/hp_smart_app_chara_shortcut.png);
	}
	.hp_smart_app_chara_list > li:nth-child(3)::before {
		background-image: url(images/hp_smart_app_chara_correction.png);
	}
	.hp_smart_app_chara_list .cont {
		width: calc(100% - 201px);
	}
	.hp_smart_app_chara_list h3 {
		margin-bottom: 15px;
	}
}





/* ==================================================
	compare（プリンター シリーズ比較表）
================================================== */

.compare {
	overflow-x: clip;
	background: #EAEDF4;
}



/* ----------------------------------------
	tab
---------------------------------------- */

.tab_header {
	margin-top: 25px;
}
.tab_content.open {
	display: block;
}
.tab_contents {
	margin-top: 12px;
}

@media screen and (min-width: 720px) {
	.tab_header {
		margin-top: 50px;
	}
	.tab_contents {
		margin-top: 32px;
	}
}



/* ----------------------------------------
	card
---------------------------------------- */

.card {
	background: #fff;
}


/* card_header -------------------- */

.card_header {
	display: grid;
	grid-template-columns: 1fr auto;
}
.card_header > div {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 12px;
	text-align: center;
}
.card_header_left h3 {
	font-size: 18px;
}
.card_header_left h3 span {
	display: block;
	font-size: 14px;
}
.card_header_right {
	position: relative;
}
.card_header_right::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 1px;
	height: 100%;
	background: #C9CFDE;
}
.card_header_right span {
	font-size: 20px;
	line-height: 1.26;
}

@media screen and (min-width: 1024px) {
	.card_header {
		grid-template-columns: 1fr 150px;
	}
	.card_header_left {
		font-size: 16px;
	}
	.card_header_left h3 {
		font-size: 22px;
	}
	.card_header_left h3 span {
		font-size: 16px;
	}
	.card_header_right span {
		font-size: 20px;
	}
}


/* media -------------------- */

.card_body .media {
	text-align: center;
	background: #e6e6e6;
}


/* copy -------------------- */

.card_body .copy {
	display: flex;
	align-items: center;
	padding: 12px 16px;
	font-size: 14px;
}

@media screen and (min-width: 1024px) {
	.card_body .copy {
		padding: 16px 20px;
		font-size: 18px;
	}
}


/* rating -------------------- */

.card_body .rating {
	border-top: 1px solid #C9CFDE;
}
.card_body .rating_list > li {
	display: flex;
	align-items: center;
	gap: 10px;
	position: relative;
	padding: 12px 16px;
	font-size: 15px;
}
.card_body .rating_list > li:not(:last-child) {
	border-bottom: 1px solid #C9CFDE;
}

@media screen and (min-width: 375px) {
	.card_body .rating_list {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
	}
	.card_body .rating_list > li:nth-child(2)::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 1px;
		height: 100%;
		background: #C9CFDE;
	}
}

@media screen and (max-width: 1023px) {
	.card_body .rating_list img {
		width: auto;
		height: 16px;
	}
}

@media screen and (min-width: 1024px) {
	.card_body .rating_list > li {
		/*gap: 20px;*/
		padding-right: 20px;
		padding-left: 20px;
		font-size: 18px;
	}
}


/* spec -------------------- */

.card_body .spec {
	padding: 0 16px 16px;
}
.card_body .spec_list {
	display: grid;
	gap: 1px;
}
.card_body .spec_list > li {
	padding: 6px;
	font-size: 14px;
	text-align: center;
	line-height: 1.125;
	background: #CDDBFA;
}
.card_body .spec_list > li.not {
	color: #9298A3;
	background: #D3D3D3;
}

@media screen and (min-width: 1024px) {
	.card_body .spec {
		padding: 0 20px 20px;
	}
	.card_body .spec_list > li {
		padding: 8px 6px 5px;
		font-size: 16px;
	}
}


/* card_footer -------------------- */

.card_footer {
	padding: 16px;
	border-top: 1px solid #C9CFDE;
}
.card_footer_left .price {
	font-weight: normal;
}
.card_footer_left .price span {
	font-size: 30px;
}
.card_footer_right {
	display: flex;
	gap: 8px;
}
.card_footer_right .button {
	min-height: 50px;
}
.card_footer_right .button.learn {
	font-size: 17px;
	background: #fff;
	outline: 1px solid #000;
	outline-offset: -1px;
}
.card_footer_right .button.learn:link,
.card_footer_right .button.learn:visited {
	color: #000;
}
.card_footer_right .button.learn:hover {
	color: #fff;
	background: #000;
}
.card_footer_right .button.buy {
	font-size: 20px;
}

@media screen and (max-width: 374px) {
	.card_footer_right .button.learn {
		font-size: 16px;
	}
	.card_footer_right .button.buy {
		font-size: 18px;
	}
}

@media screen and (max-width: 1023px) {
	.card_footer_left {
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-end;
		align-items: center;
		gap: 0 20px;
		margin-bottom: 12px;
	}
	.card_footer_right .button {
		flex: 1;
	}
}

@media screen and (min-width: 1024px) {
	.card_footer {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 20px;
	}
}



/* ----------------------------------------
	Swiper
---------------------------------------- */

.compare .swiper {
	overflow: visible;
	position: relative;
}

@media screen and (min-width: 375px) and (max-width: 719px) {
	.compare .swiper-slide {
		width: 330px;
	}
}


/* swiper-controller（ページ送り） -------------------- */

.compare .swiper-controller {
	display: flex;
	gap: 8px;
	margin-top: 15px;
}
.compare [class*="swiper-button-"] {
	cursor: pointer;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: .2s;
	width: 44px;
	height: 44px;
	background: #fff;
}
.compare [class*="swiper-button-"]::after {
	content: "";
	display: block;
	width: 13px;
	height: 23px;
	background: url('data:image/svg+xml;charset=UTF-8,<svg width="13" height="23" viewBox="0 0 13 23" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 1.43945L11.5 10.9395L1 21.4395" stroke="black" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/></svg>');
}
.compare .swiper-button-prev::after {
	transform: rotate(180deg);
}

/* disabled */
.compare .swiper-button-disabled {
	background: #D3D3D3;
}
.compare .swiper-button-disabled::after {
	background: url('data:image/svg+xml;charset=UTF-8,<svg width="13" height="23" viewBox="0 0 13 23" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M1 1.43945L11.5 10.9395L1 21.4395" stroke="%239298A3" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/></svg>');
}

@media screen and (min-width: 1024px) {
	.compare .swiper-controller {
		margin-top: 25px;
	}
}



/* ----------------------------------------
	compare_banner
---------------------------------------- */

.compare_banner {
	margin-top: 25px;
	text-align: center;
}
.compare_banner a {
	display: block;
	transition: .2s;
	outline: 1px solid #fff;
	outline-offset: -1px;
}
.compare_banner a:hover {
	outline-color: var(--Electric-Blue);
}

@media screen and (min-width: 1024px) {
	.compare_banner {
		position: relative;
		z-index: 1;
		width: max-content;
		margin-top: -44px;
		margin-left: auto;
	}
}





/* ==================================================
	support（カスタマーサポート）
================================================== */

.support {
	background: var(--Electric-Blue);
}

@media screen and (min-width: 720px) {
	.support_content {
		display: grid;
		grid-template-columns: 1fr 257px;
		align-items: center;
		gap: 20px;
	}
}

@media screen and (min-width: 1024px) {
	.support {
		padding: 60px 0;
	}
}



/* ----------------------------------------
	support_title
---------------------------------------- */

.support_title {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 15px;
	color: #fff;
}
.support_title::before {
	content: "";
	width: 64px;
	height: 64px;
	background: url(images/support_icon.png) no-repeat center center / cover;
}
.support_title .text1 {
	font-size: 18px;
}
.support_title .text2 {
	margin-top: 8px;
	font-size: 16px;
}

@media screen and (max-width: 479px) {
	.support_title {
		grid-template-columns: 48px 1fr;
	}
	.support_title::before {
		width: 48px;
		height: 48px;
	}
}

@media screen and (min-width: 720px) {
	.support_title {
		grid-template-columns: 87px 1fr;
		align-items: center;
	}
	.support_title::before {
		width: 87px;
		height: 87px;
	}
	.support_title .text2 {
		margin-top: 12px;
	}
}

@media screen and (min-width: 1024px) {
	.support_title .text1 {
		font-size: 20px;
	}
	.support_title .text2 {
		display: flex;
		align-items: center;
		gap: 10px;
		font-size: 18px;
	}
}



/* ----------------------------------------
	support_links
---------------------------------------- */

.support_links .button.large {
	width: 100%;
	min-height: 60px;
	font-size: 20px;
}
.support_links_list {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin-top: 15px;
}
.support_links_list > li {
	min-width: 40px;
	height: 40px;
	background: #fff;
	border-radius: 20px;
}
.support_links_list > li a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
}
.support_links_tel {
	display: grid;
	grid-template-columns: 26px 1fr;
	align-items: center;
	gap: 6px;
	padding: 0 8px;
	font-size: 12px;
	line-height: 1.3;
}
.support_links_tel::before {
	content: "";
	width: 26px;
	height: 26px;
	background: url(images/support_icon_tel.png) no-repeat center center / cover;
}

@media screen and (max-width: 719px) {
	.support_links {
		margin-top: 24px;
	}
}

@media screen and (min-width: 1024px) {
	.support_links .button.large {
		min-height: 80px;
	}
}





/* ==================================================
	catalog_supply_links（カタログ・インクの情報はこちら）
================================================== */

.catalog_supply_links {
	background: #f2f2f2;
}

@media screen and (min-width: 1024px) {
	.catalog_supply_links {
		padding: 60px 0;
	}
}



/* ----------------------------------------
	catalog_supply_links_title
---------------------------------------- */

.catalog_supply_links_title {
	padding-bottom: 8px;
	text-align: center;
	border-bottom: 1px solid #000;
}

@media screen and (min-width: 1024px) {
	.catalog_supply_links_title h2 {
		font-size: 28px;
	}
}



/* ----------------------------------------
	catalog_supply_links_list
---------------------------------------- */

.catalog_supply_links_list {
	display: grid;
	gap: 20px;
	margin-top: 20px;
}
.catalog_supply_links_list > li {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 3;
	padding: 20px;
	background: #fff;
	border: 1px solid #000;
}
.catalog_supply_links_list h3 {
	font-size: 20px;
}
.catalog_supply_links_list .media {
	text-align: center;
}
.catalog_supply_links_list .links {
	padding-top: 20px;
	border-top: 1px solid #000;
}

@media screen and (min-width: 480px) {
	.catalog_supply_links_list {
		grid-template-columns: repeat(2, 1fr);
		max-width: 800px;
		margin-right: auto;
		margin-left: auto;
	}
}

@media screen and (min-width: 1024px) {
	.catalog_supply_links_list h3 {
		font-size: 22px;
	}
}





/* ==================================================
	printables
================================================== */

.printables {
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
}
.printables_content {
	display: grid;
	gap: 40px;
	color: #fff;
}

@media screen and (max-width: 719px) {
	.printables {
		background-image: url(images/printables_sp.jpg);
	}
}

@media screen and (min-width: 720px) {
	.printables {
		background-image: url(images/printables.jpg);
	}
}

@media screen and (min-width: 1024px) {
	.printables {
		padding: 95px 0;
	}
	.printables_content {
		grid-template-columns: 1fr 260px;
		align-items: center;
	}
}



/* ----------------------------------------
	printables_title
---------------------------------------- */

.printables_title .copy {
	margin-bottom: 8px;
	font-size: 22px;
	line-height: 1.2;
}
.printables_title h2 {
	font-size: 36px;
	line-height: 1.4;
}

@media screen and (max-width: 719px) {
	.printables_title .copy {
		font-size: 18px;
	}
	.printables_title h2 {
		font-size: 32px;
	}
}

@media screen and (min-width: 720px) {
	.printables_title h2 {
		font-size: 36px;
	}
}

@media screen and (min-width: 1024px) {
	.printables_title .copy {
		margin-bottom: 15px;
		font-size: 28px;
	}
	.printables_title h2 {
		font-size: 40px;
	}
}



/* ----------------------------------------
	printables_links
---------------------------------------- */

.printables_links {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 10px;
}

@media screen and (min-width: 1024px) {
	.printables_links .button {
		width: 100%;
	}
}





/* ==================================================
	menu
================================================== */

.menu {
	position: fixed;
	bottom: 16px;
	left: 16px;
	z-index: 500;
}
.menu_content {
	display: none;
	padding: 25px 30px 5px;
}
.menu_content > * {
	opacity: 0;
}
.menu_content h3 {
	margin-bottom: 20px;
	font-size: 18px;
	line-height: 1.166;
}
.menu_list > li {
	position: relative;
	padding-left: 22px;
	font-size: 16px;
	line-height: 1.3125;
}
.menu_list > li:nth-child(n+2) {
	margin-top: 15px;
}
.menu_list > li::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 14px;
	height: 21px;
	background: url('data:image/svg+xml;charset=UTF-8,<svg width="14" height="15" viewBox="0 0 14 15" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M5 2.5L10 7.5L5 12.5" stroke="%23024AD8"/></svg>') no-repeat center center / cover;
}
.menu_list > li a {
	color: #000 !important;
	text-decoration: none;
}
.menu_switch {
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 20px;
	width: 132px;
	height: 60px;
	padding: 0 12px;
	background: #CCDAF4;
	border-radius: 30px;
}
.menu_switch::before {
	content: "";
	width: 38px;
	height: 38px;
	background-color: #fff;
	background-image: url(images/menu_switch.png);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: 20px 15px;
	border-radius: 50%;
}
.menu_switch .text {
	font-size: 18px;
	text-align: center;
	line-height: 1.166;
}
.menu_switch .text span {
	display: block;
	font-size: 11px;
}



/* ----------------------------------------
	open
---------------------------------------- */

.menu.open {
	width: 313px;
	max-width: calc(100% - 32px);
	background: #CCDAF4;
	border-radius: 30px;
}
.menu.open .menu_content > * {
	opacity: 1;
}
.menu.open .menu_switch {
	width: auto;
}
.menu.open .menu_switch::before {
	background-image: url(images/menu_switch_close.png);
}
.menu.open .menu_switch .text {
	font-size: 12px;
}
