/* ============================================================
  Header
============================================================ */
.header {
  position: fixed;
  top: 0;
	left: 0;
	width: 100%;
	height: var(--header-h);
  display: block;
  background: transparent;
  z-index: 50;
  transition: background-color .25s ease, border-color .25s ease, backdrop-filter .25s ease;
}


.header.is-scrolled {
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(120%) blur(6px);
}

.header_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  padding-block: 1em;
	height: 100%;
}

.header_logo {
	width: 9rem;
}
.header_logo img {
  display: block;
	height: auto;
}

.header_actions {
  display: flex;
  align-items: center;
  gap: 1.6rem;
}

.header_actions__tel {
  display: flex;
  align-items: flex-end;
	flex-direction: column;
  gap: .2rem;
}
.header_actions__tel img {
	display: block;
  width: 13rem;
  height: auto;
  line-height: 0;
}
.header_actions__tel span {
	font-size: 1.3rem;
}

.header_actions__btn {
  display: flex;
	justify-content: flex-start;
  align-items: center;
  padding: 1rem 0 1rem .8rem;
	width: 14rem;
	font-size: .9rem;
	letter-spacing: var(--ls-15);
  background: var(--color-button);
  transition: opacity .25s ease;
}
.header_actions__btn span {
  color: var(--color-white);
  font-size: 1.4rem;
  font-weight: 700;
}
.header_actions__btn .btn_request {
	width: 1.5em;
	margin-right: 1rem;
}
.header_actions__btn .btn_contact {
	width: 1.7em;
	margin-right: 1rem;
}
.header_actions__btn:hover {
  opacity: .85;
}


/* ============================================================
  title
============================================================ */
.voice .ttl img {
	padding-inline-end: 4.5rem;
}
.solution .ttl img {
	padding-inline-end: 4rem;
}
.reasons .ttl img {
	padding-inline-end: 3rem;
}
.lineup_list .ttl img {
	padding-inline-end: 3rem;
}
.function .ttl img {
	padding-inline-end: 3rem;
}
.case .ttl img {
	padding-inline-end: 4rem;
}
.price .ttl img {
	padding-inline-end: 4rem;
}
.price_3buy .ttl img {
	padding-inline-end: 2rem;
}
.compare .ttl img {
	padding-inline-end: 6rem;
}
.flow .ttl img {
	padding-inline-end: 0;
}
.content .ttl img {
	padding-inline-end: 3rem;
}
.company .ttl img {
	padding-inline-end: 4.5rem;
}


@media screen and (max-width: 499px) {
	.voice .ttl img {
		padding-inline-end: 4.5rem;
	}
	.solution .ttl img {
		padding-inline-end: 0;
	}
	.reasons .ttl img {
		padding-inline-end: 3rem;
	}
	.lineup_list .ttl img {
		padding-inline-end: 2rem;
	}
	.function .ttl img {
		padding-inline-end: 1rem;
	}
	.case .ttl img {
		padding-inline-end: 3.5rem;
		height: 4.4rem;
	}
	.price .ttl img {
		padding-inline-end: 3rem;
	}
	.price_3buy .ttl img {
		padding-inline-end: 2rem;
	}
	.compare .ttl img {
		padding-inline-end: 1rem;
	}
	.flow .ttl img {
		padding-inline-end: 1rem;
	}
	.content .ttl img {
		padding-inline-end: 2rem;
		height: 4rem;
	}
	.company .ttl img {
		padding-inline-end: 2.5rem;
	}

}

/* ============================================================
  Hero
============================================================ */
.hero {
  position: relative;
  isolation: isolate;
}

.hero .container {
  position: relative;
}

.hero_background {
	position: relative;
	overflow: hidden;
}
.hero_background .hero_background__img {
  display: block;
  width: 100%;
  height: auto;
}

.hero_overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-inline: 1em;
  pointer-events: none;
}

.hero_content {
	width: 100%;
	position: absolute;
	top: calc(50% - 10%);
	left: 0;
	transform: translateY(-50%);
	z-index: var(--z-content);

  pointer-events: auto;
  z-index: var(--z-content);
}

.hero_title {
	text-align: center;
  font-size: 3.5rem;
	/*
	font-size: clamp(3rem, 5vw, 5.4rem);
	*/
	font-size: clamp(3rem, 5vw, 5rem);
  line-height: 1.45;
  font-weight: 700;
	letter-spacing: var(--ls-35);
}

.hero_points {
  pointer-events: auto;
	margin-block-start: 2.4rem;
	margin-inline-start: 3rem;
}

.hero_points img {
  display: block;
  width: clamp(5.6rem, 6.5vw, 7.2rem);
  height: auto;
	margin-block-end: .5rem;
}

.hero_pointList {
  display: grid;
  gap: .8rem;
	width: 22rem;
}

.hero_pointList li {
  background: var(--color-white);
  padding-block: .3rem;
  padding-inline-start: .5em;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  font-size: 1.6rem;
	font-size: clamp(1.6rem, 3vw, 1.7rem);
	font-size: clamp(1.5rem, 3vw, 1.9rem);
	font-weight: 700;
	letter-spacing: var(--ls-25);
	line-height: 1.45;
}

.hero_pointList__price {
	display: flex;
	align-items: stretch;
	margin-block-start: 5px;
	margin-block-end: 5px;
}

.hero_pointList__price .price_top {
	font-size: 1.4rem;
	margin-block-end: .5em;
}
.hero_pointList__price .price_bottom {
	display: flex;
	align-items: flex-end;
}
.hero_pointList__price .price_bottom .price {
	font-size: clamp(2rem, 3.5vw, 3rem);
	line-height: 1;
	padding-block: 0;
}
.hero_pointList__price .price_bottom .small {
	font-size: 1.5rem;
}


.hero_scenes {
	margin-top: -.5rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}

.hero_scene img {
  width: 100%;
  height: auto;
}
.hero_scene:first-child img {
  border-radius: 0 0 0 20%;
}
.hero_scene:last-child img {
border-radius: 0 0 20% 0;
}

@media screen and (max-width: 699px) {
	.hero_content {
		top: 50%;
	}
	.hero_points {
		margin-inline-start: 1.5rem;
	}
	.hero_pointList {
		width: 22rem;
	}
}

@media screen and (max-width: 499px) {
	.hero_pointList {
		width: 17.5rem;
	}
	.hero_pointList__price .price_top {
    font-size: 1.1rem;
    margin-block-end: .6em;
	}
	.hero_pointList__price .price_bottom .small {
    font-size: 1.2rem;
	}
}





/* ============================================================
  VOICE
============================================================ */
.voice {
	padding-block-end: var(--space-20);
}

.voice__header {
  text-align: center;
  margin-bottom: var(--space-3);
}

.voice__header img {
  width: 100%;
}

.voice_list {
  --voice-gap: 2rem;
  --voice-avatar-min: 6rem;
  --voice-avatar-max: 10rem;
  --voice-bubble-min: 24rem;
  --voice-bubble-max: 55rem;

	width: min(100%, calc(var(--voice-avatar-max) + var(--voice-gap) + var(--voice-bubble-max)));
	margin-inline: auto;
	display: grid;
	gap: var(--space-12);
}

.voice_item {
	--voice-tail-offset: 4rem;
	display: grid;
	align-items: center;
	gap: var(--voice-gap);
}
.voice_item__left {
	grid-template-columns:
    minmax(var(--voice-avatar-min), var(--voice-avatar-max))
    minmax(var(--voice-bubble-min), var(--voice-bubble-max));
}

.voice_item__left .voice_item__avatar {
	order: 1;
}

.voice_item__left .speech {
	order: 2;
	justify-self: start;
	margin-inline-start: 0;
}

.voice_item__left .speech::after {
	left: var(--voice-tail-offset);
  right: auto;
}

/* ===== 右アバター（A/Cなど） ===== */
.voice_item__right {
	display: grid;
  grid-template-columns:
    minmax(var(--voice-bubble-min), var(--voice-bubble-max))
    minmax(var(--voice-avatar-min), var(--voice-avatar-max));
}

.voice_item__right .speech {
	order: 1;
	justify-self: end;
	margin-inline-end: 0;
}

.voice_item__right .voice_item__avatar {
	order: 2;
}

.voice_item__right .speech::after {
	right: var(--voice-tail-offset);
  left: auto;
}

/* アバター見た目 */
.voice_item__avatar {
	display: grid;
	justify-items: center;
	margin-block-start: 1.5rem;
}

.voice_item__avatar img {
  width: 100%;
  height: auto;
  object-fit: contain;
}

/* 吹き出し共通 */
.speech {
	position: relative;
	background: var(--color-bubble);
	border-radius: 99px;
	padding: 3rem 5rem;

	width: 100%;
  max-width: 55rem;
	line-height: 1.8;

	justify-self: end;
}
.speech::after {
  content: "";
  position: absolute;
  bottom: -4rem;
  width: 0;
  height: 0;
  border-style: solid;
  border-color: var(--color-bubble) transparent transparent transparent;
  transform-origin: center top;
}
.voice_item__left .speech::after {
  left: 7rem;
  right: auto;
	border-width: 5rem 5rem 0 0;
  transform: rotate(10deg);
}

.voice_item__right .speech::after {
  right: 7rem;
  left: auto;
  border-width: 5rem 0 0 5rem;
  transform: rotate(-10deg);
}


@media screen and (max-width: 699px) {
  .voice_list {
		--voice-gap: 1rem;

    width: 90%;
    margin-inline: auto;
  }
  .voice_item {
    display: flex;
    flex-direction: column;
    align-items: stretch;
  }
  .voice_item .speech {
    order: 1;
    margin-inline: 0;
    max-width: 100%;
    width: 100%;
    padding: 3rem 5rem;
    align-self: flex-end;
  }
  .voice_item .voice_item__avatar {
    order: 2;
    width: 100px;
    margin-block-start: 0;
    align-self: flex-start;
  }

	.speech::after {
    bottom: auto;
    top: calc(50% + 2.5rem);
    right: -2rem;
    transform: translateX(-50%) rotate(407deg);
    border-width: 1.5rem 1.5rem 0 1.5rem;
  }
  .voice_item__right .speech {
    align-self: flex-start;
  }
	.voice_item__right .speech::after {
		right: 13rem;
	}
	.voice_item__left .speech::after {
		left: 13rem;
	}

  .voice_item__right .voice_item__avatar {
    align-self: flex-end;
  }
}

@media screen and (max-width: 499px) {
	.speech p {
		font-size: 1.5rem;
	}
	.speech::after {
    top: calc(50% + 7.5rem);
	}
}

@media screen and (max-width: 399px) {
	.voice_item .speech {
		border-radius: 80px;
		padding: 3rem 4rem;
	}
	.speech::after {
    top: calc(50% + 7.5rem);
	}
}



/* ============================================================
  SOLUTION
============================================================ */
.solution {
	background: var(--color-blue);
	position: relative;
	padding-block-end: clamp(11rem, 18vw, 17rem);
	overflow: hidden;
}

.solution .ttl {
	display: grid;
	place-items: center;
}
.solution .ttl .icon {
	height: 12rem;
	margin-block-start: 4em;
}

.solution__copy {
	text-align: center;
	color: var(--color-white);
	line-height: 1.6;
	font-weight: 700;
	letter-spacing: var(--ls-30);
	font-size: clamp(1.8rem, 4.2vw, 3.5rem);
	font-size: clamp(2rem, 6vw, 5rem);
	margin-inline: auto;
	margin-block: 1em 5.8rem;
}

.solution__robot {
	width: clamp(20rem, 20vw, 23rem);
	position: absolute;
	bottom: -.2rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}
.solution__robot img {
	display: block;
	width: 100%;
	height: auto;
}

.solution-voice__item {
	margin-block: 7rem;
}
.solution-voice__row {
	position: relative;
	z-index: 0;
	display: grid;
	grid-template-columns: 5fr 7fr;
	margin-inline: 2rem;
	margin-inline: 5rem;
}

.solution-voice__row>* {
	position: relative;
	z-index: 1;
}

.solution-voice__robot img,
.solution-voice__person img {
	display: block;
	width: 12rem;
	height: auto;
	line-height: 0;
}

.solution-voice__left {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: flex-start;
	gap: 1rem;
}

.solution-voice__right {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: flex-start;
	gap: 0;
}

.solution-voice__badge {
  position: relative;
	z-index: 2;

  transform: translateY(-1.4rem);
  align-self: start;

	display: inline-grid;
	place-items: center;
	width: 9rem;
	height: 9rem;
	background: var(--color-yellow);
	border-radius: 999px;
	font-weight: 700;
  font-size: 2rem;
}

.solution-voice__badge::after {
	content: "";
	position: absolute;
	left: calc(50% - 10%);
  bottom: -1rem;
  transform: translateX(-50%);
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 2.5rem 3.8rem .2rem 0;
	border-color: var(--color-yellow) transparent transparent transparent;
	pointer-events: none;
}

.solution-voice__speech {
	position: relative;
	background: var(--color-bubble, #FFF8E6);
	border-radius: 99px;
	padding: 1rem 4rem;
	line-height: 1.8;
  font-weight: 700;
	width: fit-content;
	max-width: 52rem;
  width: 95%;
}

.solution-voice__speech--right::after {
	content: "";
	position: absolute;
	top: calc(33%);
  right: -2.2rem;
  width: 0;
	height: 0;
	border-style: solid;
	border-width: 1.5rem 0 1.5rem 3.9rem;
	border-color: transparent transparent transparent var(--color-bubble, #FFF8E6);
}
.solution-voice__speech--left::after {
	content: "";
	position: absolute;
	left: 7rem;
	bottom: -1rem;
	border-style: solid;
	border-width: 1.5rem 0 1.5rem 3.9rem;
	border-color: transparent transparent transparent var(--color-bubble, #FFF8E6);
	transform: rotate(12deg);
}

.solution-voice__border {
	content: "";
	position: relative;
	top: -.4rem;
	left: 0;
	height: var(--sv-bar-thickness);
	background: var(--color-blue);
	bottom: 8px;
	z-index: 1;
	pointer-events: none;
}

.solution-voice__body {
	margin-block-start: 1rem;
	margin-inline: 4rem;
	margin-inline: 10rem;
	line-height: 2;
}
.solution-voice__body p {
  text-align: justify;
  text-justify: inter-ideograph;
  line-height: 2;

}

@media screen and (max-width: 699px) {
	.solution-voice__badge::after {
		left: calc(50% - 33%);
		bottom: 0;
		transform: translateX(-50%) rotate(35deg);
	}

  .solution-voice__row {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 2rem;
    margin-inline: auto;
    width: 80%;
  }

  .solution-voice__left {
    order: 1;
    justify-content: flex-start;
    margin-inline: 0;
  }

  .solution-voice__right {
    order: 2;
  }

	.solution-voice__body {
		margin-inline: 5rem;
	}

	.solution-voice__speech {
		margin-inline-end: 0;
		max-width: 25rem;
		width: 25rem;
		display: flex;
    align-items: center;
    justify-content: center;
	}
	.solution-voice__speech p {
		text-align: left;
	}
	.solution-voice__speech--right::after {
		top: calc(50% + 30%);
    right: -4rem;
	}
}

@media screen and (max-width: 499px) {
	.solution__copy {
		margin-block: .5em 9rem;
	}
	.solution-voice__row {
		width: 90%;
	}
}


/* ============================================================
  REASON
============================================================ */
.reasons {
	background: var(--color-blue);
	position: relative;
	padding-block-end: 8rem;
	overflow: hidden;
}

.reasons .ttl {
	display: grid;
	place-items: center;
}
.reasons .ttl h2 {
  text-align: center;
  font-size: 4rem;
  color: var(--color-white);
	line-height: 1.4;
  letter-spacing: var(--ls-70);
}
.reasons .ttl h2 span {
  color: var(--color-yellow);
}
.reasons .ttl img {
	margin-block-end: var(--space-8);
}

.reasons_list {
  width: 83%;
  max-width: 55rem;
  margin: auto;
}
/* 各カード */
.reason_card {
	display: grid;
	grid-template-columns: 7.5rem 1fr;
	align-items: center;
	gap: 2.2rem;
  background: var(--color-white);
	border-radius: 25px;
	padding: 2rem 2.2rem;
  margin-block-end: 2em;
}

/* 左カラム（REASONラベル＋番号） */
.reason_card__head {
	display: grid;
	grid-template: "label"auto "num"1fr / 1fr;
	align-items: center;
	justify-items: start;
}

/* 右カラム（本文） */
.reason_card__body {
	display: grid;
	align-items: center;
	row-gap: .8rem;
}
.reason_card__lead {
	margin: 0;
  padding-inline: .5em;
	font-size: clamp(1.6rem, 3vw, 1.8rem);
	font-weight: 700;
}
.reason_card__underline {
	display: block;
	width: 100%;
	height: .2rem;
	background: var(--color-blue);
}
.reason_card__text {
	margin: 0;
  padding-inline: .5em;
	font-size: 1.4rem;
	line-height: 1.5;
	letter-spacing: var(--ls-15);
}


@media screen and (max-width: 699px) {
	.reasons_list {
		width: 90%;
		max-width: 90%;
	}
}

@media screen and (max-width: 499px) {
	.reason_card {
		gap: 1.8rem;
	}
}



/* ============================================================
  LINE UP
============================================================ */
.lineup_hero {
  position: relative;
  isolation: isolate;
}
.lineup__scenes {
	margin-top: -.5rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
}
.lineup__scene img {
  width: 100%;
  height: auto;
}
.lineup__scene:first-child img {
  border-radius: 0 0 0 20%;
}
.lineup__scene:last-child img {
border-radius: 0 0 20% 0;
}

.lineup_list {
	overflow-x: hidden;
}

.lineup_list .ttl {
	margin-block-end: 8rem;
}

.lineup_item {
	position: relative;
	margin-block-end: 13rem;
}
.lineup_item:last-child {
	margin-block-end: 0;
}

.lineup_item__header {
	position: relative;
}

.lineup_item__ttl {
	height: 2.9rem;
	margin-block-end: 1rem;
}
.lineup_item__header h3 {
	font-size: 2.3rem;
}
.lineup_item__product {
	position: relative;
	isolation: isolate;
	text-align: center;
	padding-top: 10rem;
	margin: 0;
}
.lineup-product {
	position: relative;
	z-index: 1;
	display: block;
	max-width: 100%;
	height: auto;
}


/* ===== BACKPACK 専用 ===== */
.lineup_item--backpack .lineup_item__product::before {
	content: "";
	position: absolute;
	left: 0;
  top: -2.6rem;

  width: min(61rem, 85%);
  aspect-ratio: 610 / 300;
  height: auto;
	min-height: 30rem;

	background: var(--color-beige);
	border-radius: 0 50px 50px 0;
	z-index: 0;
	pointer-events: none;
}
.lineup_item--backpack .lineup-product {
	width: 50rem;
	left: calc(50% + 8rem);
	transform: translateX(-50%);
	width: clamp(35rem, calc(var(--lineup-scale) * 0.968), 61rem);
}
.lineup_item--backpack .lineup_item__header {
	position: absolute;
	top: 0;
	left: 3rem;
	text-align: left;
}

/* ===== SHOULDER BAG 専用 ===== */
.lineup_item--shoulder .lineup_item__product::before {
	content: "";
	position: absolute;
	right: 0;
  top: -2.6rem;

  width: min(61rem, 85%);
  aspect-ratio: 610 / 300;
  height: auto;
	min-height: 30rem;

	background: var(--color-beige);
	border-radius: 50px 0 0 50px;
	z-index: 0;
	pointer-events: none;
}
.lineup_item--shoulder .lineup-product {
	width: 63rem;
	left: calc(50% - 3rem);
	transform: translateX(-50%);

	width: clamp(47rem, var(--lineup-scale), 63rem);
}
.lineup_item--shoulder .lineup_item__header {
	position: absolute;
	top: 0;
	right: 3rem;
	text-align: right;
}

/* ===== SHOE CASE 専用 ===== */
.lineup_item--shoescase .lineup_item__product::before {
	content: "";
	position: absolute;
	left: 0;
  top: -2.6rem;

  width: min(61rem, 85%);
  aspect-ratio: 610 / 300;
  height: auto;
	min-height: 30rem;

	background: var(--color-beige);
	border-radius: 0 50px 50px 0;
	z-index: 0;
	pointer-events: none;
}
.lineup_item--shoescase .lineup-product {
	width: 48rem;
	left: calc(50% + 8rem);
	transform: translateX(-50%);

	width: clamp(33rem, calc(var(--lineup-scale) * 0.762), 48rem);
}
.lineup_item--shoescase .lineup_item__header {
	position: absolute;
	top: 0;
	left: 3rem;
	text-align: left;
}


@media screen and (max-width: 699px) {
	.lineup_item--backpack .lineup-product {
		left: calc(50% + 6rem);
	}
	.lineup_item--shoulder .lineup-product {
		left: calc(50% - 1rem);
	}
	.lineup_item--shoescase .lineup-product {
		left: calc(50% + 7rem);
	}

	.lineup_item--backpack .lineup_item__product::before {
		width: 300px;
	}
	.lineup_item--shoulder .lineup_item__product::before {
		width: 300px;
	}
	.lineup_item--shoulder .lineup_item__product::before {
		width: 300px;
	}
}

@media screen and (max-width: 420px) {
	.lineup_item__ttl {
		height: 2rem;
	}
	.lineup_item--backpack .lineup-product {
		left: calc(50% + 4rem);
	}
	.lineup_item--shoulder .lineup-product {
		left: calc(50%);
    width: 43rem;
	}
	.lineup_item--shoescase .lineup-product {
		left: calc(50% + 5rem);
	}
}

@media screen and (max-width: 380px) {
	.lineup_item--backpack .lineup-product {
		left: calc(50% + 3rem);
	}
	.lineup_item--shoulder .lineup-product {
		left: calc(50%);
    width: 39rem;
	}
	.lineup_item--shoescase .lineup-product {
		left: calc(50% + 4rem);
	}
}



/* ============================================================
  FUNCTION
============================================================ */
.function {
	padding-block: 4rem 0;
}

.function_hero {
	margin-inline: 3rem;
}

.function_raincover {
	margin-block-start: 5rem;
}
.function_raincover__full {
	margin-inline: 5rem;
}
.function_raincover__full img {
	display: block;
	width: 100%;
	height: auto;
}

.function_raincover__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 0;
  align-self: stretch;
	align-items: stretch;
	margin-block-start: 3rem;
}

.function_raincover__grid img {
	display: block;
	width: 100%;
	height: auto;
}

.function_raincover__grid.function_raincover__grid-bg {
  margin-block-start: 0;
  padding-block-end: 3rem;
	background: var(--color-beige);
}

.function_text {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	text-align: left;
}

.function_raincover__grid>.function_text {
	align-self: center;
	justify-self: center;
}
.function_raincover__grid>div {
	display: grid;
}
.function_raincover__grid>div>.function_text {
	align-self: center;
	justify-self: center;
}

.function_raincover__grid img {
	display: block;
	width: 100%;
	height: auto;
}
.function_raincover__grid h3 {
	font-size: 2rem;
	font-size: 2.3rem;
	line-height: 1.5;
	letter-spacing: var(--ls-30, 0.03em);
	margin: 0;
}
.function_raincover__grid p {
	margin: 1rem 0 0;
	font-weight: 700;
	line-height: 1.7;
}
.function_raincover__grid span {
	display: block;
	margin-block-start: 1rem;
	font-size: 1.1rem;
	line-height: 1.8;
}


@media screen and (max-width: 699px) {
	.function_text {
		margin-inline: 3rem;
	}
	.function_raincover__grid h3 {
		font-size: 1.7rem;
	}

}


/* ========== FUNCTION (芯材) ========== */
.function_grid {
	/*
  width: 85%;
  margin-block: 8rem;
  margin-inline: auto;
  display: grid;
	grid-template-columns: 1fr 25rem;
	gap: 5rem;
	align-items: center;
	*/
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: 0;
  align-self: stretch;
	align-items: stretch;
}


.function_grid__img {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-block: 4rem;
}

.function_grid__img img {
	max-width: 34rem;
	width: 80%;
}

.function_grid__txt {
	display: flex;
	justify-content: center;
	align-items: center;
}
.function_grid__txt .inner {
	padding: 1rem;
	text-align: left;
}

.function_grid__txt .inner h3 {
	font-size: 2rem;
	line-height: 1.6;
	letter-spacing: var(--ls-30);
	margin: 0;
}
.function_grid__txt .inner p {
	font-size: 2rem;
	line-height: 1.7;
	font-weight: 700;
}


.function_grid.function_7 .function_grid__img {
	display: block;
	padding-block: var(--space-18) 0;
}
.function_grid.function_7 .function_grid__img img {
	width: 100%;
	max-width: 100%;
}



.function_full {
  padding-block: 3rem 0;
  background: var(--color-beige);
}
.function_full__content {
  width: 95%;
  margin: 0 0 0 auto;
}
.function_full__content h3 {
  font-size: 2rem;
	letter-spacing: var(--ls-30);
}

.function_full_bg {
	background: var(--color-beige);
	padding-block-end: 3rem;
}
.function_full_product {
	position: relative;
}
.function_full_product::before {
	content: "";
	position: absolute;
	right: 0;
	bottom: -3rem;
	width: 80%;
	height: 70%;
	background: var(--color-beige-accent, #d9d0c6);
	border-radius: 50px 0 0 0;
	z-index: 0;
	pointer-events: none;
}

.function_full_product h3 {
  position: absolute;
  margin: 3rem 0 0 3rem;
  font-size: 2.5rem;
	font-size: clamp(1.7rem, 3vw, 2.3rem);
	letter-spacing: var(--ls-30);
  line-height: 1.7;
}
.function_full_product img {
	position: relative;
	z-index: 1;
	display: block;
	width: 50rem;
	margin: 0 4rem 0 auto;
	padding-top: 2rem;
	padding-top: var(--space-5);
}

.function_full__content .point,
.function_grid__txt .point {
	display: inline-block;
	padding: 0px 1.3rem;
	border-radius: 25px;
	background: var(--color-blue);
	color: var(--color-white);
	font-size: 1.4rem;
	line-height: 1.9;
	letter-spacing: var(--ls-30);
}

.function_full__content .point {
	margin-block: .5rem 2rem;
}
.function_grid__txt .point {
	margin-block: 3.5rem .5rem;
	font-size: 1.4rem;
}

@media screen and (max-width: 699px) {
	.function_raincover__grid h3,
	.function_grid__txt .inner h3,
	.function_grid__txt .inner p,
	.function_7 h3 {
		font-size: 1.7rem;
	}
	.function_7 h3 {
		margin-block: 0;
	}
	.function_full_product img {
		width: 34rem;
	}
}

@media screen and (max-width: 499px) {
	.function_full_bg {
		padding-block-end: 1.5rem;
	}
	.function_full_product {
		padding-top: 20px;
	}
	.function_full_product img {
		width: 27rem;
		margin: 0 2rem 0 auto;
		padding-top: 1.5rem;
	}
	.function_full_product h3 {
		margin: 2rem 0 0 3rem;
		line-height: 1.5;
	}
}


/* ============================================================
  CASE STUDIES
============================================================ */
.case {
	background: var(--color-blue);
	padding-block: var(--space-10);
}

.case .ttl {
	text-align: center;
	margin-block-start: 0;
	margin-block-end: 3rem;
}
.case .ttl h2 {
  text-align: center;
  font-size: 3.5rem;
  color: var(--color-white);
  letter-spacing: var(--ls-90);
  margin-block-start: 2rem;
}

.case_list {
	display: grid;
	gap: 4rem;
  width: 90%;
  margin: auto;
}
.case_card {
	display: grid;
	grid-template-columns: 15rem 1fr;
	gap: 2rem;
	background: var(--color-white);
	border-radius: 28px;
	padding: 2rem 2.25rem;
}
.case_profile {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
}
.case_avatar {
	width: 13rem;
}
.case_name {
	margin-block-start: 1rem;
	font-size: 1.5rem;
	letter-spacing: var(--ls-30);
}
.case_body {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.case_body h3 {
	margin: 0 0 1rem 0;
	padding-inline: .8rem;
	font-size: 1.8rem;
	line-height: 1.7;
	letter-spacing: var(--ls-30);
	border-bottom: solid 2px var(--color-blue);
}
.case_body p {
	padding-inline: .8rem;
	margin: 0;
	font-size: 1.5rem;
	line-height: 1.9;
}

@media screen and (max-width: 699px) {
  .case_card {
		padding: 2.3rem;
    grid-template-columns: 1fr;
		gap: 0;
    text-align: center;
  }

  .case_profile {
    flex-direction: column;
    margin-block-end: 1.5rem;
  }

  .case_avatar {
    width: 10rem;
    margin-inline: auto;
  }

  .case_name {
    margin-block-start: .5rem;
  }

  .case_body {
    align-items: center;
    text-align: left;
    width: 100%;
  }

  .case_body h3,
  .case_body p {
    padding-inline: 0;
  }
}


@media screen and (max-width: 499px) {
	.case_avatar {
		width: 10rem;
	}
	.case_name {
		font-size: 1.3rem;
	}

	.case_body h3 {
		font-size: var(--fz-16);
	}

}

/* ============================================================
  PRICE
============================================================ */
.price {
	padding-block-end: var(--space-10);
}
.price_list {
	/*
  padding-block-end: 8rem;
	*/
}
.price_item {
  padding-block-end: var(--space-16);
}
.price_item:last-child {
	padding-block-end: var(--space-10);
}

.price_item__ttl {
	display: grid;
	grid-template-columns: minmax(4.8rem, 1fr) auto minmax(4.8rem, 1fr);
	align-items: center;
	column-gap: 2.5rem;
	width: 100%;
	margin-inline: auto;
	margin-block: 5rem;
}

.price_item__ttl::before,
.price_item__ttl::after {
	content: "";
	height: .2rem;
	background: var(--color-blue);
  align-self: center;
  transform: translateY(-1.3rem);
}

.price_item__ttl img {
	display: block;
	height: 5.3rem;
	width: auto;
}

.price_item__product {
  margin: auto;
}
.price_item__price {
	text-align: center;
  margin-block-start: 5rem;
}
.price_item__price img {
  height: 8rem;
  margin: auto;
}
.price_item__price p {
	margin-block-start: 3rem;
	font-size: 1.5rem;
}


@media screen and (max-width: 499px) {
	.price {
		padding-block-end: 3rem;
	}
	.price_item {
		padding-block-end: 3rem;
	}
	.price_item__ttl img {
		height: 5rem;
	}
	.price_item__price img {
		height: 6rem;
	}
}

/* ============================================================
  PRICE -3buy-
============================================================ */
.price_3buy {
  background: var(--color-beige);
	padding-block: var(--space-10);
}
.price_3buy .ttl {
  margin-block-start: 0;
}

.price_3buy_content {
	position: relative;
}
.price_3buy_content p {
  text-align: center;
  font-size: 2.8rem;
  font-weight: 900;
  letter-spacing: var(--ls-30);
  margin-block: 2em;
}
.price_3buy_content p {
  text-align: center;
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 900;
  letter-spacing: var(--ls-30);
  margin-block: 2rem 1.5rem;
}


.price_3buy_content__price {
  margin: 0 auto 2rem;
}
.price_3buy_content__product {
  width: 100%;
  margin: auto;
}
.price_3buy_content__batch {
	position: absolute;
	top: calc(50% - 14rem);
  left: calc(50% + 26rem);
  transform: translate(-50%, -50%);
	width: 17rem;
  height: auto;
  display: block;
}

@media screen and (max-width: 699px) {
	.price_3buy_content__batch {
		top: calc(50% - 13rem);
		left: calc(50% + 23rem);
		width: 15rem;
	}
}

@media screen and (max-width: 599px) {
	.price_3buy_content__batch {
		top: calc(50% - 11rem);
		left: calc(50% + 21rem);
		width: 14rem;
	}
}

@media screen and (max-width: 499px) {
	.price_3buy_content__batch {
		top: calc(50% - 9rem);
		left: calc(50% + 19rem);
		width: 13rem;
	}
}

@media screen and (max-width: 450px) {
	.price_3buy_content__batch {
		top: calc(50% - 8rem);
		left: calc(50% + 17rem);
		width: 11.5rem;
	}
}

@media screen and (max-width: 410px) {
	.price_3buy_content__batch {
		top: calc(50% - 5.5rem);
		left: calc(50% + 14rem);
		width: 10rem;
	}
}

/* ============================================================
  compare
============================================================ */
.compare {
  background: var(--color-blue);
  padding-block: var(--space-10);
}

.compare .ttl {
  margin-block-start: 0;
}
.compare .ttl h2 {
  text-align: center;
  color: var(--color-white);
  font-size: 2.8rem;
  letter-spacing: var(--ls-70);
  margin-block-start: 1.5rem;
}
.compare .ttl  h3 {
  text-align: center;
  color: var(--color-white);
  font-size: 2rem;
  letter-spacing: var(--ls-30);
}

.compare_grid {
  margin-inline: 3rem;
}



/* ============================================================
  flow
============================================================ */
.flow {
}

.flow .ttl {
  width: 80%;
  margin-inline: auto;
  padding-block-end: 3em;
  border-bottom: solid 0.45rem var(--color-blue);
}
.flow .ttl  h2 {
  text-align: center;
  font-size: 2.8rem;
  letter-spacing: var(--ls-30);
  margin-block-start: 1.5em;
}

.flow_list {
	--marker: 4rem;
	--line: .4rem;
	--col-gap: 3.5rem;
  --overshoot: 2rem;

	counter-reset: flow;
	width: 70%;
	margin-inline: auto;
	list-style: none;
	padding: 0;
	margin-block-start: 2.5rem;
}

.flow_item {
	display: grid;
	grid-template-columns: var(--marker) 1fr;
	gap: var(--col-gap);
	position: relative;
	padding-block: 2rem;
	height: 9em;
}

.flow_item::before {
	content: "";
	position: absolute;
	left: calc(var(--marker) / 2);
	top: 0;
	bottom: 0;
	width: var(--line);
	background: var(--color-blue);
	transform: translateX(-50%);
	z-index: 0;
}
.flow_item:first-child::before {
	top: 3.5rem;
}

.flow_marker {
	position: relative;
	z-index: 1;
	display: grid;
	place-items: center;
	width: var(--marker);
	height: var(--marker);
}
.flow_marker img {
	display: block;
	width: 100%;
	height: auto;
}

.flow_body {
	display: grid;
	align-content: start;
	gap: .75rem;
}
.flow_body h3 {
	margin: 0;
	font-size: 2rem;
	line-height: 1.5;
	letter-spacing: var(--ls-30, 0.03em);
}
.flow_body p {
	margin: 0;
	line-height: 1.7;
	font-size: 1.4rem;
}


@media screen and (max-width: 699px) {
	.flow .ttl {
		width: 85%;
	}
	.flow_list {
		width: 85%;
	}
	.flow_item {
		height: 15rem;
		gap: 2.5rem;
	}
}

@media screen and (max-width: 499px) {
	.flow .ttl {
		width: 90%;
	}
	.flow_item {
		padding-block: 0;
		height: 16rem;
	}
}

@media screen and (max-width: 469px) {
	.flow_item {
		height: 18rem;
	}
}

@media screen and (max-width: 399px) {
	.flow_item {
		height: 20rem;
	}
}


/* ============================================================
  contact
============================================================ */
.content {
  background: var(--color-blue);
  padding-block-start: var(--space-10);
}

.content .ttl {
  display: grid;
	place-items: center;
	margin-block-start: 0;
}
.content .ttl h2 {
  text-align: center;
  font-size: 2.8rem;
  color: var(--color-white);
  letter-spacing: var(--ls-90);
	line-height: 1.5;
  margin-block-start: 1em;
}

.content_product {
  margin-inline: 3rem;
  padding-block: 3rem;
	padding-inline: 4rem;
  background: var(--color-white);
  border-radius: 25px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.content h3 {
  color: var(--color-white);
  font-size: clamp(3rem, 4.5vw, 4rem);
  letter-spacing: var(--ls-30);
  text-align: center;
  margin-block: 3rem 1rem;
}


.content_recommend {
  margin-inline: 3rem;
  display: grid;
  grid-template-columns: 20rem 1fr;
}
.content_recommend__img {
	display: flex;
	align-items: flex-end;
}
.content_recommend__text {
  display: flex;
  align-items: flex-start;
	padding-block-start: 2rem;
}
.content_recommend__text li {
  margin-left: 1rem;
  color: var(--color-white);
  font-size: 2rem;
	font-size: clamp(1.6rem, 3vw, 2rem);
  margin-block-end: .8rem;
  font-weight: 500;
	letter-spacing: var(--ls-30);
}
.content_recommend__text li::before {
  content: "・";
}


@media screen and (max-width: 699px) {
	.content .ttl h2 {
    font-size: var(--fz-24);
	}
	.content_recommend {
		grid-template-columns: 1fr;
		margin-inline: 2rem;
	}
	.content_recommend__img {
		order: 2;
		width: 180px;
		margin: auto;
	}
	.content_recommend__text {
		justify-content: center;
	}
	.content_recommend__text li {
		margin-left: 0;
	}
}


/* ============================================================
  COMPANY
============================================================ */
.company {
	background: var(--color-beige);
	color: var(--color-black);
	padding-block: var(--space-10);
}

.company .ttl {
  margin-block-start: 0;
}
/* 見出し */
.company_header {
	position: relative;
	text-align: center;
	margin-block-end: 2.5rem;
}

.company_about {
	position: absolute;
	left: 8%;
	top: -1rem;
	width: 12rem;
	height: auto;
}

.company_ttl {
	margin: 0;
	font-size: clamp(2.2rem, 4.5vw, 3.5rem);
	letter-spacing: .14rem;
	font-weight: 800;
}

.company_table {
	width: 62%;
  max-width: 50rem;
	margin-inline: auto;
}

.company_row {
	display: grid;
	grid-template-columns: 8em 1fr;
	gap: 3rem;
	align-items: start;
	padding-block: 1rem;
	border-bottom: solid 1px var(--color-dark-gray);
}
.company_row:last-child {
	border-bottom: none;
}

.company_row dt {
	color: var(--color-dark-gray);
	letter-spacing: var(--ls-30);
  padding-inline-start: 1.6rem;
}

.company_row dd {
	margin: 0;
  padding-inline-end: 1.6rem;
	letter-spacing: var(--ls-30);
	line-height: 1.9;
}

.company_row a {
	color: inherit;
	text-decoration: none;
}

.company_row a:hover {
	opacity: .7;
}

/* 下ロゴ */
.company_logo {
	text-align: center;
	margin-block-start: 7rem;
}

.company_logo img {
	display: block;
	margin-inline: auto;
	width: 10rem;
	height: auto;
	filter: drop-shadow(0 0 0 rgba(0, 0, 0, 0));
}


@media screen and (max-width: 800px) {
	.company_table {
		width: 70%;
		max-width: 70%;
	}
}

@media screen and (max-width: 699px) {
	.company_table {
		width: 80%;
		max-width: 80%;
	}
}

@media screen and (max-width: 499px) {
	.company_table {
		width: 90%;
		max-width: 90%;
	}
	.company_row {
		gap: 2rem;
	}
}

@media screen and (max-width: 400px) {
	.company_row {
		gap: 1.5rem;
	}
	.company_row dt {
		padding-inline-start: 1.2rem;
		font-size: var(--fz-11);
	}
	.company_row dd {
		padding-inline-end: 1.2rem;
		font-size: var(--fz-11);
	}
	.company_row a {
		font-size: var(--fz-11);
		letter-spacing: var(--ls-15);
	}
}